root/trunk/ProjectFortress/src/com/sun/fortress/compiler/index/ParametricOperator.java @ 3915

Revision 3915, 3.2 KB (checked in by jrhil47, 5 months ago)

[index] Changed all Functional indices to store a thunk to get the return types, since during type checking the return types might need to be lazily evaluated. Also changed Functional indices to yield an Option for return types.
[type checker] Started implementing extraction of bindings from nodes for type environments.

Line 
1/*******************************************************************************
2    Copyright 2009 Sun Microsystems, Inc.,
3    4150 Network Circle, Santa Clara, California 95054, U.S.A.
4    All rights reserved.
5
6    U.S. Government Rights - Commercial software.
7    Government users are subject to the Sun Microsystems, Inc. standard
8    license agreement and applicable provisions of the FAR and its supplements.
9
10    Use is subject to license terms.
11
12    This distribution may include materials developed by third parties.
13
14    Sun, Sun Microsystems, the Sun logo and Java are trademarks or registered
15    trademarks of Sun Microsystems, Inc. in the U.S. and other countries.
16 ******************************************************************************/
17
18package com.sun.fortress.compiler.index;
19
20import java.util.Collections;
21import java.util.List;
22
23import com.sun.fortress.nodes.ArrowType;
24import com.sun.fortress.nodes.BaseType;
25import com.sun.fortress.nodes.Expr;
26import com.sun.fortress.nodes.FnDecl;
27import com.sun.fortress.nodes.Id;
28import com.sun.fortress.nodes.Node;
29import com.sun.fortress.nodes.NodeDepthFirstVisitor;
30import com.sun.fortress.nodes.NodeUpdateVisitor;
31import com.sun.fortress.nodes.Op;
32import com.sun.fortress.nodes.Param;
33import com.sun.fortress.nodes.StaticArg;
34import com.sun.fortress.nodes.StaticParam;
35import com.sun.fortress.nodes.Type;
36import com.sun.fortress.nodes_util.NodeUtil;
37import com.sun.fortress.nodes_util.Span;
38import com.sun.fortress.useful.NI;
39
40import edu.rice.cs.plt.lambda.SimpleBox;
41import edu.rice.cs.plt.tuple.Option;
42
43/**
44 * This is a operator declared in a trait or object whose name is an opr parameter.
45 * It needs to be promoted to top-level so it can match OpExprs appropriately.
46 */
47public class ParametricOperator extends FunctionalMethod {
48    Op _name;
49
50    public ParametricOperator(FnDecl ast, Id declaringTrait) {
51        super(ast, declaringTrait);
52        _name = (Op)NodeUtil.getName(ast);
53        putThunk(SimpleBox.make(NodeUtil.getReturnType(_ast)));
54    }
55
56    public FnDecl ast() { return _ast; }
57
58    public Op name() { return _name; }
59
60    @Override
61    public Span getSpan() { return NodeUtil.getSpan(_ast); }
62
63        @Override
64        public Option<Expr> body() {
65                return _ast.accept(new NodeDepthFirstVisitor<Option<Expr>>(){
66                        @Override
67                        public Option<Expr> defaultCase(Node that) {
68                                return Option.none();
69                        }
70                        @Override
71                        public Option<Expr> forFnDecl(FnDecl that) {
72                            return that.getBody();
73                        }
74                });
75        }
76
77
78        @Override
79        public List<Param> parameters() {
80                return NodeUtil.getParams(_ast);
81        }
82
83        @Override
84        public List<StaticParam> staticParameters() {
85                return NodeUtil.getStaticParams(_ast);
86        }
87
88        @Override
89        public List<BaseType> thrownTypes() {
90                if(  NodeUtil.getThrowsClause(_ast).isSome() )
91                        return Collections.emptyList();
92                else
93                        return Collections.unmodifiableList(NodeUtil.getThrowsClause(_ast).unwrap());
94        }
95
96        @Override
97        public Functional instantiate(List<StaticParam> params, List<StaticArg> args) {
98                // TODO Auto-generated method stub
99                return NI.nyi();
100        }
101
102        @Override
103        public Functional acceptNodeUpdateVisitor(NodeUpdateVisitor visitor) {
104                return new FunctionalMethod((FnDecl)this.ast().accept(visitor), this._declaringTrait);
105        }
106}
Note: See TracBrowser for help on using the browser.