SE424 Languages with Context A Block Structured Language.

Slides:



Advertisements
Similar presentations
CPSC 388 – Compiler Design and Construction
Advertisements

Intermediate Code Generation
Programming Languages and Paradigms
Control Structures Any mechanism that departs from straight-line execution: –Selection: if-statements –Multiway-selection: case statements –Unbounded iteration:
Programming Languages Marjan Sirjani 2 2. Language Design Issues Design to Run efficiently : early languages Easy to write correctly : new languages.
INF 212 ANALYSIS OF PROG. LANGS Type Systems Instructors: Crista Lopes Copyright © Instructors.
Elementary Data Types Prof. Alamdeep Singh. Scalar Data Types Scalar data types represent a single object, i.e. only one value can be derived. In general,
Chapter 5: Elementary Data Types Properties of types and objects –Data objects, variables and constants –Data types –Declarations –Type checking –Assignment.
Chapter Four Data Types Pratt 2 Data Objects A run-time grouping of one or more pieces of data in a virtual machine a container for data it can be –system.
Chapter 10 Implementing Subprograms. Copyright © 2012 Addison- Wesley. All rights reserved. 1-2 Chapter 10 Topics The General Semantics of Calls and Returns.
UNIVERSITY OF SOUTH CAROLINA Department of Computer Science and Engineering CSCE 330 Programming Language Structures Ch.2: Syntax and Semantics Fall 2005.
ISBN Chapter 10 Implementing Subprograms.
Programming Languages Third Edition
ALGOL 60 Design by committee of computer scientists: Naur, Backus, Bauer, McCarthy, van Wijngaarden, Landin, etc. Design by committee of computer scientists:
Denotational Semantics Syntax-directed approach, generalization of attribute grammars: –Define context-free abstract syntax –Specify syntactic categories.
Tutorial 6 & 7 Symbol Table
Copyright © 2006 The McGraw-Hill Companies, Inc. Programming Languages 2nd edition Tucker and Noonan Chapter 4 Names The first step toward wisdom is calling.
Compound Data Structures Structural decomposition into other values. Lists: domain A* –Constructors: NIL, CONS. –Selectors: HEAD, TAIL. Tuples: domain.
1 Pertemuan 20 Run-Time Environment Matakuliah: T0174 / Teknik Kompilasi Tahun: 2005 Versi: 1/6.
Semantic analysis Enforce context-dependent language rules that are not reflected in the BNF, e.g.a function must have a return statement. Decorate AST.
Catriel Beeri Pls/Winter 2004/5 environment 68  Some details of implementation As part of / extension of type-checking: Each declaration d(x) associated.
The environment of the computation Declarations introduce names that denote entities. At execution-time, entities are bound to values or to locations:
Chapter 9: Subprogram Control
Catriel Beeri Pls/Winter 2004/5 environment1 1 The Environment Model  Introduction and overview  A look at the execution model  Dynamic scoping  Static.
CSC321: Programming Languages Names Chapter 4: Names 4.1 Syntactic Issues 4.2 Variables 4.3 Scope 4.4 Symbol Table 4.5 Resolving References 4.6 Dynamic.
Copyright © 2006 The McGraw-Hill Companies, Inc. Programming Languages 2nd edition Tucker and Noonan Chapter 4 Names The first step toward wisdom is calling.
Cs164 Prof. Bodik, Fall Symbol Tables and Static Checks Lecture 14.
1/25 Pointer Logic Changki PSWLAB Pointer Logic Daniel Kroening and Ofer Strichman Decision Procedure.
2.2 A Simple Syntax-Directed Translator Syntax-Directed Translation 2.4 Parsing 2.5 A Translator for Simple Expressions 2.6 Lexical Analysis.
1 Chapter 5: Names, Bindings and Scopes Lionel Williams Jr. and Victoria Yan CSci 210, Advanced Software Paradigms September 26, 2010.
Imperative Programming
CSC3315 (Spring 2009)1 CSC 3315 Programming Languages Hamid Harroud School of Science and Engineering, Akhawayn University
CS 2104 Prog. Lang. Concepts Subprograms
CS 326 Programming Languages, Concepts and Implementation Instructor: Mircea Nicolescu Lecture 2.
Compiler Construction
Chapter 10 Implementing Subprograms. Copyright © 2012 Addison-Wesley. All rights reserved.1-2 Chapter 10 Topics The General Semantics of Calls and Returns.
Chapter 7 Runtime Environments. Relationships between names and data objects As execution proceeds, the same name can denote different data objects Procedures,
The Procedure Abstraction, Part V: Support for OOLs Comp 412 Copyright 2010, Keith D. Cooper & Linda Torczon, all rights reserved. Students enrolled in.
Names. 2 Variables  binding is an association between an entity (such as a variable) and a property (such as its value). A binding is static if the association.
1 Compiler Construction (CS-636) Muhammad Bilal Bashir UIIT, Rawalpindi.
Basic Semantics Associating meaning with language entities.
Programming Languages and Paradigms Imperative Programming.
ISBN Chapter 10 Implementing Subprograms.
PZ06C Programming Language design and Implementation -4th Edition Copyright©Prentice Hall, PZ06C - Polymorphism Programming Language Design and.
Polymorphism Programming Language Design and Implementation (4th Edition) by T. Pratt and M. Zelkowitz Prentice Hall, 2001 Section 7.3.
Language Translation A programming language processor is any system that manipulates programs expressed in a PL A source program in some source language.
Semantics CSE 340 – Principles of Programming Languages Fall 2015 Adam Doupé Arizona State University
12/9/20151 Programming Languages and Compilers (CS 421) Elsa L Gunter 2112 SC, UIUC Based in part on slides by Mattox.
Imperative Languages Section 5 Continued.... A Dynamically Typed Language Variable may take on values from different data types. Run­time type checking.
Slide 1 WEEK 8 Imperative Programming Original by Vitaly Shmatikov.
Pointers. Variable Declarations Declarations served dual purpose –Specification of range of values and operations –Specification of Storage requirement.
1 Bindings. 2 Outline Preliminaries Scope  Block structure  Visibility Static vs. dynamic binding Declarations and definitions More about blocks The.
Semantic Analysis II Type Checking EECS 483 – Lecture 12 University of Michigan Wednesday, October 18, 2006.
Names, Scope, and Bindings Programming Languages and Paradigms.
Programming Languages Meeting 3 September 9/10, 2014.
UNIVERSITY OF SOUTH CAROLINA Department of Computer Science and Engineering CSCE 330 Programming Language Structures Operational Semantics (Slides mainly.
1 Compiler Construction Run-time Environments,. 2 Run-Time Environments (Chapter 7) Continued: Access to No-local Names.
Run-Time Environments Presented By: Seema Gupta 09MCA102.
Design issues for Object-Oriented Languages
Data Types In Text: Chapter 6.
Type Checking and Type Inference
Names and Attributes Names are a key programming language feature
A Simple Syntax-Directed Translator
CS 326 Programming Languages, Concepts and Implementation
Language Design Principles
Scope, Visibility, and Lifetime
Chapter 6 Intermediate-Code Generation
Lecture 15 (Notes by P. N. Hilfinger and R. Bodik)
Semantic Analysis Chapter 6.
UNIT V Run Time Environments.
Presentation transcript:

SE424 Languages with Context A Block Structured Language

SE424 Languages with Contexts In any language, the context of a phrase influences its meaning. In p rogramming languages, contexts attribute meanings to identifiers. Does the store establish the context? begin integer X; integer Y Y:=0 X:=Y Y:=1 X:=Y+1 end But the store constantly changes within the block! Declarations establish block context. Commands operate within that context.

SE424 Languages with Contexts begin integer X X:=0 begin real X X:=1.5 end X:=X+1 end Outer X denotes integer object. Inner X denotes real object. X is the name used for both objects. Scope rules are needed to resolve ambiguities. Meaning of an identifier can't be just its storable value!

SE424 Contexts “Objects" are computer store locations. The meaning of an identifier is the location bound to it. A context is the set of identifier/ store location pairs accessible at a textual position. Each position in a program resides within a unique context. Context of a phrase can be determined without running the program.

SE424 Environments Mathematical value that models context. Environment establishes context for syntactic phrase –Resolution of ambiguities concerning meaning of identifiers. As many environment values as distinct program contexts. –Multiple environments are maintained during program evaluation. Environment is a static object. –Phrase uses the same environment each time it is evaluated.

SE424 Environment Models Simple model: store = environment –Only one environment. –Used in previous program examples. Complex model: store plus environments. –One store –Multiple environments

SE424 Compiler's Symbol Table An example of an environment Used for translation of source program into compiled code. One entry for each identifier in the program –Data type. –Mode of usage(variable,constant,parameter). –Relative location in run-time store. Resolution of name conflicts –Different symbol table for each block. –Build table as single stack Incremented and decremented upon block entry and exit. Compile-time object (Pascal, C, C++), Run-time object (Lisp, Smalltalk).

SE424 Static and Dynamic Semantics Static semantics –Part of semantics definition that use environment to resolve context questions. –Type-checking, scope resolution, storage calculations. Dynamic semantics –“Real" production of meanings. – Code generation and execution. No clear separation!

SE424 Evaluation Functions Environments used as additional argument C: Command  Environment  Store  Store  Environment domain –Environment = Identifier  Denotable value Language Features 1. Declarations. 2. Block structures. 3. Scoping mechanisms. 4. Compound data structures.

SE424 A Block-Structured Language See Figures 7.1 and 7.2 \017 Composition of commands C [[C1;C2]]= e(C[[C2]]e)  (C[[C1]]e) Both C1 and C2 are evaluated in e. C1 may contain local declarations. Environments created within C1 do not affect C2. Static scoping –Context of phrase solely determined by its textual position. –Identifier declared within block only referenced by commands within that block. –Straight-forward management of storage locations.

SE424 Strongly Typed Languages Environment processing can proceed independently of store processing. i.e. P[[P]] can be simplified without value of initial base location l and initial store s. Result neither contains occurrences of environment arguments nor checking of denotable and expressible value tags. Simplifications correspond to declaration and type-checking actions in a compiler.

SE424 Example See Figure 7.3 l.( s. return (update l (one plus two) s)) ! (check (fix ( f. s. ((access l s) equals zero  ( s. return(update (next-locn l) (access l s) s)) ! (check f ) [] return ) s ))) ! (check ( s. return (update l one s))) ( f ! g := g o f ) Resembles series of machine code instructions parameterized on the store's base address l.

SE424 Stack-Managed Storage Store of block-structured languages always used in a stack- like fashion –Locations are bound to identifiers sequentially using 'nextlocn'. –Location bound to identifier in local block are freed for re-use when block is exited. Storage reuse automatically in C[[C1;C2]] – Locations bound to identifiers in [[C 1]] are re- served by environment built from e for C [[C 1 ]]. –C [[C 2 ]] uses original e (and original location marker) effectively deallocating these locations. Significant characteristic of block-structured languages!

SE424 Stack-Managed Storage Make storage calculations explicit in Store algebra –Store = (Location  Storable-value) x Location { –First component is data space of the stack –Second component indicates “top of stack" – 'allocate-locn' becomes the run-time version of 'reserve-locn' Environment domain is freed from storage management –Environment = Id  Denotable-value –'reserve-locn' is dropped. Processing of declarations requires store as well as environment.

SE424 Stack-Managed Store Declarations –D: Declaration  Environment  Store  (Environment x Poststore) –D [[ va r I]] = e. s. let ( l,p ) = (allocate-locn s) in ((update env[[I]] inLocation ( l ) e ), p ) –D [[D 1 ; D 2 ]] = e. s. let ( e’,p ) = (D [[D1 ]] e s ) in (check D [[D 2 ]] e’)( p )

SE424 Blocks –K [[ begin D;C end ]] = e. s. let l = mark-locn in let ( e’,p ) = D[[D]] e s in let p’= (check ( C [[C]] e’))( p ) in (check (deallocate-locn s l ))( p 0 ) Environment becomes run-time object because binding of location values to identifiers depends on run-time store.

SE424 The Meaning of Identifiers Assignment X := X+1 –Left-hand side value of X is location, –Right-hand side value is storable value associated to location. Context problem occurs even at primitive command level! Variable identifier denotes pair of values –I[[I]] = (L-value, R-value ) –L-value is kept in environment. –R-value is kept in store.

SE424 The Meaning of Identifiers Valuation I : Id  Environment  Store  (Location x Storable-value) –L : Id  Environment –Store  Location. –R : Id  Environment  Store  Storable value. –L[[I]] = accessenv [[I]] –R[[I]] = access o accessenv[[I]] –Semantic equations with variables E[[I]] = R[[I]] C [[I:=E]] = e. s. return(update(L [[I]] e ) ( E [[E]] e s ) s )

SE424 The Meaning of Identifiers Other view: R-value = Function(L- value) –“True" meaning is L-value. –“Coercion" on right-hand side of assignment Coercion = dereferencing. –J : Id  Environment  Denotable-value –J [[I]] = e. ( accessenv [[I]] e ) –C [[I:=E]] = e. s. return ( update ( J [[I]] e ) ( E [[E]] e s ) s ) –E [[I]] = e. s. access ( J [[I]] e)s Some system languages require explicit dereferencing operator –E [[I]] = e. s. in Location ( J [[I]] e ) –E = e. s. cases ( E [[E]] e s ) of is Location ( l )  ( access l s ) []... end