Download presentation
Presentation is loading. Please wait.
1
Maya: Multiple-Dispatch Syntax Extension in Java Jason Baker and Wilson C. Hsieh University of Utah
2
Example for (Enumeration enum$ = v.elements(); enum$.hasMoreElements(); ) { String st; st = (String) enum$.nextElement(); /* … */ } v.elements().foreach(String st) { /*…*/ } java.util.Vector v; Maya code
3
v.elements().foreach(String st) { /*…*/ } javamaya.util.Vector v; Specialized Expansion { Vector v$ = v; int len$ = v$.size(); Object[] arr$ = v$.getElementData(); for (int i$ = 0; i$ < len$; i$++) { String st = (String) arr$[i$]; /* … */ }} other Maya code
4
Maya: Java With Macros Programs that transform syntax Best chosen for each occurrence –based on syntactic structure, –and static type information
5
Compiled Application Compiled Extensions Application Source Maya’s Extensible Compiler mayac
6
Compiled Application Extension Library Extension Source Compiled Extensions Application Source Maya’s Extensible Compiler mayac
7
Extensible Parser Provide a fixed hierarchy of AST node types And a grammar that uses these types as symbols S → S + T{ new S($0, $2) } T → Lit{ $0 }
8
Adding Productions Allow grammar to be extended New actions defined in terms of existing node types S → S + T{ new S($0, $2) } T → Lit{ $0 } S → inc(S){ new S{ 1 + $2 } }
9
Overriding Actions Several Mayans defined on a single production Dispatch to best match for nodes on the parse stack S → S + T{ new S($0, $2) } { new S{ $0.concat($2) } } T → Lit{ $0 } S → inc(S){ new S{ 1 + $2 } }
10
Key Features Hygienically operate on ASTs Generate ASTs through robust and flexible template mechanism Dispatched on rich set of specializers –In particular, static types of expressions
11
Structuring Extensions Compiler loads Mayans by calling an interface method Mayans, like class declarations, may be local Mayans may be loaded locally to a lexical scope
12
Parse Order Mayans execute during parsing Mayans are dispatched based on static types of arguments Some arguments can only be checked after expansion Lazy parsing made explicit in grammar v.elements().foreach(String st) { /*…*/ } maya.util.Vector v;
13
Defining a Production syntax for v.elements().foreach(String st){…} Statement MethodName ( Formal ) LazyBlock In Maya syntax: abstract Statement syntax(MethodName(Formal) lazy(BraceTree, BlockStmts));
14
Declaring a Mayan IdentifierExpression. MethodName(Formal)lazy(BraceTree, BlockSmts) Statement Statement syntax EForEach(Expression:Enumeration enumExp. foreach(Formal var) lazy(BraceTree, BlockStmts) body)) { /* Mayan body */ }
15
Parameter Specializers Runtime types accepted by a Mayan Determine dispatch order Maya support other specializers –substructure –static type of expression –token value –type denoted by name
16
Parameter Specializers –substructure –static type of expression –token value –type denoted by name Statement syntax EForEach(Expression:Enumeration enumExp. foreach(Formal var) lazy(BraceTree, BlockStmts) body)) { /* Mayan body */ }
17
Parameter Specializers –substructure –static type of expression –token value –type denoted by name Statement syntax EForEach(Expression:Enumeration enumExp. foreach(Formal var) lazy(BraceTree, BlockStmts) body)) { /* Mayan body */ }
18
Parameter Specializers –substructure –static type of expression –token value –type denoted by name Statement syntax EForEach(Expression:Enumeration enumExp. foreach(Formal var) lazy(BraceTree, BlockStmts) body)) { /* Mayan body */ }
19
Parameter Specializers –substructure –static type of expression –token value –type denoted by name Statement syntax EForEach(Expression:Enumeration enumExp. foreach(Formal var) lazy(BraceTree, BlockStmts) body)) { /* Mayan body */ }
20
Templates and Hygiene Easy way to construct syntax trees: Statically ensure –syntactic correctness –hygiene and referential transparency –references to bound variables new Expression { 1 + 2 * 3 } new AddExpr( new IntegerLiteral(1), new MulExpr(/*... */)) vs.
21
return new Statement { for (Enumeration enum = $_______; enum.hasMoreElements(); ) { $____________________ $_________________________ = ($________) enum.nextElement(); $____ } }; Template Example Expression enumExp; Formal var; DelayedStmt body;
22
return new Statement { for (Enumeration enum = $enumExp; enum.hasMoreElements(); ) { $____________________ $_________________________ = ($________) enum.nextElement(); $body } }; Unquoting Parameters Expression enumExp; Formal var; DelayedStmt body;
23
final StrictTypeName castType = StrictTypeName.make(var.getType()); return new Statement { for (Enumeration enum = $enumExp; enum.hasMoreElements(); ) { $(DeclStmt.make(var)) $(Reference.makeExpr(var)) = ($castType) enum.nextElement(); $body } }; Other Expressions Expression enumExp; Formal var; DelayedStmt body;
24
final StrictTypeName castType = StrictTypeName.make(var.getType()); return new Statement { for (Enumeration enum = $enumExp; enum.hasMoreElements(); ) { $(DeclStmt.make(var)) $(Reference.makeExpr(var)) = ($castType) enum.nextElement(); $body } }; Hygiene Expression enumExp; Formal var; DelayedStmt body;
25
Pattern Parsing Used when compiling Mayan argument trees and template definitions Patterns contain both terminal and non- terminal symbols Pattern parser generates parse tree with non-terminal leaves Used to statically implement hygiene
26
MultiJava Features Clifton et al. [OOPSLA 2000] Multiple dispatch –static checks for ambiguous and incomplete generic functions Open classes –external methods can be added to classes Implemented in KJC (20k lines)
27
MultiJava in Maya 2500 lines of code Maya provides necessary features –static type information –syntax extension –overriding behavior of syntax Maya supports large syntax extensions –local Mayans –lexically scoped Mayan imports
28
Related Work JSE [Bachrach and Playford 2001] JTS [Batory et al. 1998] –not appropriate for simple macros –doesn’t do type checking –lacks pattern parser OpenJava [Tatsubori et al. 2000] –limited ability to define syntactic forms –single dispatch
29
Conclusions Maya’s features provide flexibility –static type information –flexible templates and pattern matching –detection of errors in templates Through novel techniques –lazy parsing –pattern parsing http://www.cs.utah.edu/~jbaker/maya
30
Discussion
31
Implementing Hygiene Renaming occurs when role of each identifier is known (with restrictions) Binding information embedded in grammar Detect most accesses to unbound variables Detect access to compile-time values
32
Dispatch Order symmetric between arguments node type primary –expression types, token values considered when node types match exactly order of import used as tie-breaker –allows Mayans to match every occurrence of syntax
33
Pattern Example foreach takes 3 actual parameters formals extracted from tree structure dispatch is also recursive IdentifierExpression. MethodName(Formal)lazy(BraceTree, BlockSmts) Statement
34
MultiJava Features Multiple dispatch –static checks for ambiguous and incomplete generic functions Open classes –external methods can be added to classes class C { void m(C c) { } } class D extends C { } void C.n(C c) { } void C.n(C@D d) { } void D.n(C c) { } void D.n(C@D d) { }
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.