summaryrefslogtreecommitdiffstats
path: root/Tools/bgen
diff options
context:
space:
mode:
Diffstat (limited to 'Tools/bgen')
-rw-r--r--Tools/bgen/bgen/bgenBuffer.py24
-rw-r--r--Tools/bgen/bgen/bgenHeapBuffer.py12
-rw-r--r--Tools/bgen/bgen/bgenStackBuffer.py4
3 files changed, 26 insertions, 14 deletions
diff --git a/Tools/bgen/bgen/bgenBuffer.py b/Tools/bgen/bgen/bgenBuffer.py
index 925b937..46f3db4 100644
--- a/Tools/bgen/bgen/bgenBuffer.py
+++ b/Tools/bgen/bgen/bgenBuffer.py
@@ -53,21 +53,22 @@ class FixedInputOutputBufferType(InputOnlyType):
def declareSize(self, name):
Output("%s %s__len__;", self.sizetype, name)
+ Output("int %s__in_len__;", name)
def getargsFormat(self):
- # XXX This only works if the size is int-sized!!!
return "s#"
def getargsArgs(self, name):
- return "&%s__in__, &%s__len__" % (name, name)
+ return "&%s__in__, &%s__in_len__" % (name, name)
def getargsCheck(self, name):
- Output("if (%s__len__ != %s)", name, self.size)
+ Output("if (%s__in_len__ != %s)", name, self.size)
OutLbrace()
Output('PyErr_SetString(PyExc_TypeError, "buffer length should be %s");',
self.size)
Output("goto %s__error__;", name)
OutRbrace()
+ Output("%s__len__ = %s__in_len__;", name, name)
def passOutput(self, name):
return "%s__in__, %s__out__" % (name, name)
@@ -76,7 +77,7 @@ class FixedInputOutputBufferType(InputOnlyType):
return "s#"
def mkvalueArgs(self, name):
- return "%s__out__, %s" % (name, self.size)
+ return "%s__out__, (int)%s" % (name, self.size)
def cleanup(self, name):
DedentLevel()
@@ -138,7 +139,7 @@ class VarInputBufferType(FixedInputBufferType):
FixedInputBufferType.__init__(self, "0", datatype, sizetype, sizeformat)
def getargsCheck(self, name):
- pass
+ Output("%s__len__ = %s__in_len__;", name, name)
def passInput(self, name):
return "%s__in__, %s__len__" % (name, name)
@@ -161,11 +162,14 @@ class StructInputOutputBufferType(FixedInputOutputBufferType):
def declareInputBuffer(self, name):
Output("%s *%s__in__;", self.type, name)
+ def declareSize(self, name):
+ Output("int %s__in_len__;", name)
+
def declareOutputBuffer(self, name):
Output("%s %s__out__;", self.type, name)
def getargsArgs(self, name):
- return "(char **)&%s__in__, &%s__len__" % (name, name)
+ return "(char **)&%s__in__, &%s__in_len__" % (name, name)
def passInput(self, name):
return "%s__in__" % name
@@ -174,7 +178,7 @@ class StructInputOutputBufferType(FixedInputOutputBufferType):
return "%s__in__, &%s__out__" % (name, name)
def mkvalueArgs(self, name):
- return "(char *)&%s__out__, %s" % (name, self.size)
+ return "(char *)&%s__out__, (int)%s" % (name, self.size)
class StructCombinedInputOutputBufferType(StructInputOutputBufferType):
@@ -211,6 +215,9 @@ class StructOutputBufferType(OutputOnlyBufferMixIn, StructInputOutputBufferType)
Instantiate with the struct type as parameter.
"""
+
+ def declareSize(self, name):
+ pass
def passOutput(self, name):
return "&%s__out__" % name
@@ -222,6 +229,9 @@ class ArrayOutputBufferType(OutputOnlyBufferMixIn, StructInputOutputBufferType):
Instantiate with the struct type as parameter.
"""
+
+ def declareSize(self, name):
+ pass
def passOutput(self, name):
return "%s__out__" % name
diff --git a/Tools/bgen/bgen/bgenHeapBuffer.py b/Tools/bgen/bgen/bgenHeapBuffer.py
index 2c51695..c6160ba 100644
--- a/Tools/bgen/bgen/bgenHeapBuffer.py
+++ b/Tools/bgen/bgen/bgenHeapBuffer.py
@@ -20,17 +20,19 @@ class HeapInputOutputBufferType(FixedInputOutputBufferType):
Output("%s *%s__out__;", self.datatype, name)
def getargsCheck(self, name):
- Output("if ((%s__out__ = malloc(%s__len__)) == NULL)", name, name)
+ Output("if ((%s__out__ = malloc(%s__in_len__)) == NULL)", name, name)
OutLbrace()
Output('PyErr_NoMemory();')
Output("goto %s__error__;", name)
OutRbrace()
+ Output("%s__len__ = %s__in_len__;", name, name)
def passOutput(self, name):
- return "%s__in__, %s__out__, %s__len__" % (name, name, name)
+ return "%s__in__, %s__out__, (%s)%s__len__" % \
+ (name, name, self.sizetype, name)
def mkvalueArgs(self, name):
- return "%s__out__, %s__len__" % (name, name)
+ return "%s__out__, (int)%s__len__" % (name, name)
def cleanup(self, name):
Output("free(%s__out__);", name)
@@ -75,10 +77,10 @@ class HeapOutputBufferType(OutputOnlyMixIn, HeapInputOutputBufferType):
pass
def getargsFormat(self):
- return self.sizeformat
+ return "i"
def getargsArgs(self, name):
- return "&%s__len__" % name
+ return "&%s__in_len__" % name
def passOutput(self, name):
return "%s__out__, %s__len__" % (name, name)
diff --git a/Tools/bgen/bgen/bgenStackBuffer.py b/Tools/bgen/bgen/bgenStackBuffer.py
index b7df5bd..1b6350a 100644
--- a/Tools/bgen/bgen/bgenStackBuffer.py
+++ b/Tools/bgen/bgen/bgenStackBuffer.py
@@ -29,7 +29,7 @@ class VarStackOutputBufferType(StackOutputBufferType):
return "%s__out__, &%s__len__" % (name, name)
def mkvalueArgs(self, name):
- return "%s__out__, %s__len__" % (name, name)
+ return "%s__out__, (int)%s__len__" % (name, name)
class VarVarStackOutputBufferType(VarStackOutputBufferType):
@@ -56,4 +56,4 @@ class ReturnVarStackOutputBufferType(VarStackOutputBufferType):
return "%s__out__, %s__len__" % (name, name)
def mkvalueArgs(self, name):
- return "%s__out__, _rv" % name
+ return "%s__out__, (int)_rv" % name