summaryrefslogtreecommitdiff
path: root/python/qpid/generator.py
diff options
context:
space:
mode:
authorRafael H. Schloming <rhs@apache.org>2009-01-08 17:10:20 +0000
committerRafael H. Schloming <rhs@apache.org>2009-01-08 17:10:20 +0000
commit27293b8e3624cb13fa346016b65f0b8a71b0279a (patch)
tree36d99e9e1f39715e0669834520ce638e3904b937 /python/qpid/generator.py
parentfc6840f32b54a81241fa91b0c0248ce395609ba6 (diff)
downloadqpid-python-27293b8e3624cb13fa346016b65f0b8a71b0279a.tar.gz
made codegen happen on module import rather than on object instantiation, this makes things like help(Session) much more useful
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@732760 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'python/qpid/generator.py')
-rw-r--r--python/qpid/generator.py60
1 files changed, 60 insertions, 0 deletions
diff --git a/python/qpid/generator.py b/python/qpid/generator.py
new file mode 100644
index 0000000000..307ea562d7
--- /dev/null
+++ b/python/qpid/generator.py
@@ -0,0 +1,60 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements. See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership. The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied. See the License for the
+# specific language governing permissions and limitations
+# under the License.
+#
+
+import sys
+
+from spec010 import Control
+
+def METHOD(module, inst):
+ method = lambda self, *args, **kwargs: self.invoke(inst, args, kwargs)
+ if sys.version_info[:2] > (2, 3):
+ method.__name__ = inst.pyname
+ method.__doc__ = inst.pydoc
+ method.__module__ = module
+ return method
+
+def generate(spec, module, predicate=lambda x: True):
+ dict = {"spec": spec}
+
+ for name, enum in spec.enums.items():
+ dict[name] = enum
+
+ for name, st in spec.structs_by_name.items():
+ dict[name] = METHOD(module, st)
+
+ for st in spec.structs.values():
+ dict[st.name] = METHOD(module, st)
+
+ for name, inst in spec.instructions.items():
+ if predicate(inst):
+ dict[name] = METHOD(module, inst)
+
+ return dict
+
+def invoker(name, spec, predicate=lambda x: True):
+ return type("%s_%s_%s" % (name, spec.major, spec.minor),
+ (), generate(spec, invoker.__module__, predicate))
+
+def command_invoker(spec):
+ is_command = lambda cmd: cmd.track == spec["track.command"].value
+ return invoker("CommandInvoker", spec, is_command)
+
+def control_invoker(spec):
+ is_control = lambda inst: isinstance(inst, Control)
+ return invoker("ControlInvoker", spec, is_control)