summaryrefslogtreecommitdiff
path: root/Tools/bgen
diff options
context:
space:
mode:
authorJack Jansen <jack.jansen@cwi.nl>2005-07-01 20:23:27 +0000
committerJack Jansen <jack.jansen@cwi.nl>2005-07-01 20:23:27 +0000
commitbd8dd540caa1618020568a0d3a91410fb083b3bf (patch)
tree1e9a156624ba35b601238e1a5c8f41a608e2c2f2 /Tools/bgen
parent46902d96dd16fbefcf2997db31dc6ac86c1be637 (diff)
downloadcpython-bd8dd540caa1618020568a0d3a91410fb083b3bf.tar.gz
Added methods mkvaluePreCheck and getargsPreCheck, which are called (for
each variable) before calling Py_BuildValue and PyArg_Parse.
Diffstat (limited to 'Tools/bgen')
-rw-r--r--Tools/bgen/bgen/bgenGenerator.py2
-rw-r--r--Tools/bgen/bgen/bgenType.py15
-rw-r--r--Tools/bgen/bgen/bgenVariable.py6
3 files changed, 22 insertions, 1 deletions
diff --git a/Tools/bgen/bgen/bgenGenerator.py b/Tools/bgen/bgen/bgenGenerator.py
index 83ff552b0c..d77da31700 100644
--- a/Tools/bgen/bgen/bgenGenerator.py
+++ b/Tools/bgen/bgen/bgenGenerator.py
@@ -194,6 +194,7 @@ class FunctionGenerator(BaseFunctionGenerator):
if arg.flags == SelfMode:
continue
if arg.mode in (InMode, InOutMode):
+ arg.getargsPreCheck()
fmt = fmt + arg.getargsFormat()
args = arg.getargsArgs()
if args:
@@ -242,6 +243,7 @@ class FunctionGenerator(BaseFunctionGenerator):
if not arg: continue
if arg.flags == ErrorMode: continue
if arg.mode in (OutMode, InOutMode):
+ arg.mkvaluePreCheck()
fmt = fmt + arg.mkvalueFormat()
lst = lst + sep + arg.mkvalueArgs()
if fmt == "":
diff --git a/Tools/bgen/bgen/bgenType.py b/Tools/bgen/bgen/bgenType.py
index f7cb388637..00dd9d7ad6 100644
--- a/Tools/bgen/bgen/bgenType.py
+++ b/Tools/bgen/bgen/bgenType.py
@@ -61,11 +61,18 @@ class Type:
"""
return "&" + name
+ def getargsPreCheck(self, name):
+ """Perform any actions needed before calling getargs().
+
+ This could include declaring temporary variables and such.
+ """
+
def getargsCheck(self, name):
"""Perform any needed post-[new]getargs() checks.
This is type-dependent; the default does not check for errors.
- An example would be a check for a maximum string length."""
+ An example would be a check for a maximum string length, or it
+ could do post-getargs() copying or conversion."""
def passInput(self, name):
"""Return an argument for passing a variable into a call.
@@ -119,6 +126,12 @@ class Type:
"""
return name
+ def mkvaluePreCheck(self, name):
+ """Perform any actions needed before calling mkvalue().
+
+ This could include declaring temporary variables and such.
+ """
+
def cleanup(self, name):
"""Clean up if necessary.
diff --git a/Tools/bgen/bgen/bgenVariable.py b/Tools/bgen/bgen/bgenVariable.py
index 6edeb873fc..7848a4fa21 100644
--- a/Tools/bgen/bgen/bgenVariable.py
+++ b/Tools/bgen/bgen/bgenVariable.py
@@ -63,6 +63,9 @@ class Variable:
def getargsCheck(self):
return self.type.getargsCheck(self.name)
+ def getargsPreCheck(self):
+ return self.type.getargsPreCheck(self.name)
+
def passArgument(self):
"""Return the string required to pass the variable as argument.
@@ -95,6 +98,9 @@ class Variable:
"""Call the type's mkvalueArgs method."""
return self.type.mkvalueArgs(self.name)
+ def mkvaluePreCheck(self):
+ return self.type.mkvaluePreCheck(self.name)
+
def cleanup(self):
"""Call the type's cleanup method."""
return self.type.cleanup(self.name)