File: JavaCall.py

package info (click to toggle)
jython 2.5.1-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 41,624 kB
  • ctags: 101,579
  • sloc: python: 351,444; java: 204,338; xml: 1,316; sh: 330; ansic: 126; perl: 114; makefile: 94
file content (162 lines) | stat: -rw-r--r-- 4,926 bytes parent folder | download | duplicates (2)
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
# Copyright (c) Corporation for National Research Initiatives

import java, org.python.core
import jast



funcs = {}
def call(func, this, args=None):
    if not funcs.has_key(func):
        jf = JavaFunction(func)
        funcs[func] = jf
    else:
        jf = funcs[func]
    if args is None:
        return jf.call(this)
    else:
        return jf.invoke(this, args)



class Signature:
    def __init__(self, name, inTypes, retType, isStatic=0, isPyArgs=0,
                 isConstructor=0):
        self.isPyArgs = isPyArgs
        self.isStatic = isStatic
        self.retType = retType
        self.inTypes = inTypes
        self.name = name
        self.isConstructor = isConstructor

    def handle(self, callee, args, isa=1):
##      if self.isPyArgs:
##          pyargs = []
##          for arg in args:
##              pyargs.append(arg.asa(AnyType).getCode())
##          return self.mkcall(callee, [Statement.PyObjectArray(pyargs)] )

        if len(args) != len(self.inTypes):
            return None

        callargs = []
        for i in range(len(args)):
            #print i, args[i]
            if isa:
                callarg = args[i].isa(self.inTypes[i])
            else:
                callarg = args[i].asa(self.inTypes[i])
            if callarg == None:
                return None
            callargs.append(callarg)
        return self.mkcall(callee, callargs)

    def mkcall(self, callee, args):
        if self.isConstructor:
            op = jast.New(self.name, args)
        elif self.isStatic:
            op = jast.InvokeStatic(callee, self.name, args)
        else:
            #print callee, self.name, args
            op = jast.Invoke(callee, self.name, args)
        return op, self.retType

    def __repr__(self):
        r = []
        for arg in self.inTypes:
            r.append(arg.name)
        COMMASPACE = ', '
        return '(%s)->%s' % (COMMASPACE.join(r), self.retType.name)



class JavaFunction:
    def __init__(self, reflectedFunction):
        self.name = reflectedFunction.__name__
        self.isConstructor = isinstance(reflectedFunction,
                                        org.python.core.PyReflectedConstructor)
        sigs = []
        self.callee = None
        for i in range(reflectedFunction.nargs):
            sigs.append(self.makeSignature(reflectedFunction.argslist[i]))
        self.sigs = sigs
        self.function = reflectedFunction
        self.declaringClass = self.function.argslist[0].declaringClass

    def makeSignature(self, rargs):
        inTypes = list(rargs.args)
        isPyArgs = rargs.flags == rargs.PyArgsCall
        isStatic = rargs.isStatic
        name = rargs.data.name

        if self.isConstructor:
            outType = rargs.data.declaringClass                 
        else:
            outType = rargs.data.returnType

        if isStatic:
            self.callee = rargs.data.declaringClass.__name__

        return Signature(name, inTypes, outType, isStatic, isPyArgs,
                         self.isConstructor)

    def __repr__(self):
        if len(self.sigs) == 1:
            return self.name+repr(self.sigs[0])
        else:
            return self.name+repr(self.sigs)

    def call(self, args):
        for isa in [1, 0]:
            for sig in self.sigs:
                ret = sig.handle(self.callee, args, isa=isa)
                if ret is None:
                    continue
                return ret
        raise TypeError, repr(args)+' args do not match: '+repr(self)

    def invoke(self, this, args):
        this = this.asa(self.declaringClass)
        for isa in [1, 0]:
            for sig in self.sigs:
                ret = sig.handle(this, args, isa=isa)
                if ret is None:
                    continue
                return ret
        raise TypeError, repr(args)+' args do not match: '+repr(self)



if __name__ == '__main__':
    f = JavaFunction(org.python.core.PyObject._add)
    print f

    class Object:
        def __init__(self, code, istypes, astypes):
            self.code = code
            self.istypes = istypes
            self.astypes = astypes

        def isa(self, type):
            if type in self.istypes:
                return self.code

        def asa(self, type):
            if type in self.istypes:
                return self.code

            for astype, ascode in self.astypes:
                if astype == type:
                    return ascode

    one = Object(jast.IntegerConstant(1), [java.lang.Integer.TYPE], 
                 [(org.python.core.PyObject, jast.Identifier("one"))])
    foo = Object(jast.Identifier("foo"), [org.python.core.PyObject],
                 [(java.lang.Integer.TYPE,
                   jast.InvokeStatic("Py", "toint",
                                     [jast.Identifier("foo")]))])

    print f.invoke(foo, [one])
    print f.invoke(foo, [foo])

    print call(org.python.core.Py.py2int, [one])