Skip to main content
summaryrefslogtreecommitdiffstats
blob: e17a07d92e2085dedae00b75a5751e62a604ab01 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
Copyright (c) 2008 Arno Haase.
All rights reserved. This program and the accompanying materials
are made available under the terms of the Eclipse Public License v1.0
which accompanies this distribution, and is available at
http://www.eclipse.org/legal/epl-v10.html

Contributors:
    Arno Haase - initial API and implementation
 */
package org.eclipse.xtend.backend.functions;

import java.util.List;

import org.eclipse.xtend.backend.common.BackendType;
import org.eclipse.xtend.backend.common.ExecutionContext;
import org.eclipse.xtend.backend.common.ExpressionBase;
import org.eclipse.xtend.backend.common.Function;
import org.eclipse.xtend.backend.common.FunctionDefContext;
import org.eclipse.xtend.backend.common.LocalVarContext;


/**
 * 
 * @author Arno Haase (http://www.haase-consulting.com)
 */
public final class SourceDefinedFunction implements Function {
	private final String _name;
    private final List<String> _paramNames;
    private final List<BackendType> _paramTypes;
    private final FunctionDefContext _defContext;
    private final ExpressionBase _def;
    private final boolean _cached;
    private final ExpressionBase _guard;

    public SourceDefinedFunction (String name, List<String> paramNames, List<BackendType> paramTypes, FunctionDefContext defContext, ExpressionBase def, boolean cached, ExpressionBase guard) {
    	_name = name;
        _paramNames = paramNames;
        _paramTypes = paramTypes;
        _defContext = defContext;
        _def = def;
        _cached = cached;
        _guard = guard;
    }

    public boolean isCached () {
        return _cached;
    }
    
    public List<BackendType> getParameterTypes() {
        return _paramTypes;
    }

    public FunctionDefContext getFunctionDefContext () {
        return _defContext;
    }
    
    public Object invoke (ExecutionContext ctx, Object[] params) {
        if (_defContext == ctx.getFunctionDefContext())
            return invokeWithExistingFdc (ctx, params);
        else {
            final FunctionDefContext oldFdc = ctx.getFunctionDefContext ();
            try {
                ctx.setFunctionDefContext (_defContext);
                return invokeWithExistingFdc(ctx, params);
            }
            finally {
                ctx.setFunctionDefContext (oldFdc);
            }
        }
    }
    
    private Object invokeWithExistingFdc (ExecutionContext ctx, Object[] params) {
        final LocalVarContext lvc = new LocalVarContext ();
        for (int i=0; i<_paramNames.size(); i++) {
            lvc.getLocalVars().put(_paramNames.get(i), params[i]);
        }
        
        final LocalVarContext oldLvc = ctx.getLocalVarContext();
        try {
            ctx.setLocalVarContext(lvc);
            return _def.evaluate(ctx);
        }
        finally {
            ctx.setLocalVarContext(oldLvc);
        }
    }

	public ExpressionBase getGuard() {
		return _guard;
	}
	
	@Override
	public String toString () {
	    return "SourceDefinedFunction '" + _name + "' " + _paramTypes;
	}
}

Back to the top