diff src/bridge/bridge_constructor/base_constructor.py @ 2087:159250d66407

bridge (constructor): embedded bridge generator: "embedded" is used to have backend and frontend together in the same process (frontend call backend as a module).
author Goffi <goffi@goffi.org>
date Wed, 05 Oct 2016 22:07:51 +0200
parents da4097de5a95
children f413bfc24458
line wrap: on
line diff
--- a/src/bridge/bridge_constructor/base_constructor.py	Mon Oct 03 21:15:39 2016 +0200
+++ b/src/bridge/bridge_constructor/base_constructor.py	Wed Oct 05 22:07:51 2016 +0200
@@ -49,6 +49,9 @@
     FRONTEND_TEMPLATE = None
     FRONTEND_DEST = None
 
+    # set to False if your bridge need only core
+    FRONTEND_ACTIVATE = True
+
     def __init__(self, bridge_template, options):
         self.bridge_template = bridge_template
         self.args = options
@@ -170,7 +173,7 @@
         """Return arguments to user given a signature
 
         @param signature: signature in the short form (using s,a,i,b etc)
-        @param name: dictionary of arguments name like given by getArguments
+        @param name: dictionary of arguments name like given by getArgumentsDoc
         @param default: dictionary of default values, like given by getDefault
         @param unicode_protect: activate unicode protection on strings (return strings as unicode(str))
         @return: list of arguments that correspond to a signature (e.g.: "sss" return "arg1, arg2, arg3")
@@ -222,6 +225,9 @@
             if side == "core":
                 method = self.generateCoreSide
             elif side == "frontend":
+                if not self.FRONTEND_ACTIVATE:
+                    print(u"This constructor only handle core, please use core side")
+                    sys.exit(1)
                 method = self.generateFrontendSide
         except AttributeError:
             self._generate(side)
@@ -260,7 +266,9 @@
                 'sig_out': function['sig_out'] or '',
                 'category': 'plugin' if function['category'] == 'plugin' else 'core',
                 'name': section,
-                'args': self.getArguments(function['sig_in'], name=arg_doc, default=default)}
+                # arguments with default values
+                'args': self.getArguments(function['sig_in'], name=arg_doc, default=default),
+                }
 
             extend_method = getattr(self, "{}_completion_{}".format(side, function["type"]))
             extend_method(completion, function, default, arg_doc, async_)