diff options
| author | 2015-02-16 21:59:10 +0100 | |
|---|---|---|
| committer | 2015-02-16 21:59:10 +0100 | |
| commit | 8e7d14bae4d3c836f029a1235eb227380acc3f75 (patch) | |
| tree | ebd0679642cccb994e70a89a106b394189cb28bc /pyload/remote/socketbackend | |
| parent | Merge branch 'stable' into 0.4.10 (diff) | |
| download | pyload-8e7d14bae4d3c836f029a1235eb227380acc3f75.tar.xz | |
Fix plugins to work on 0.4.10
Diffstat (limited to 'pyload/remote/socketbackend')
| -rw-r--r-- | pyload/remote/socketbackend/__init__.py | 1 | ||||
| -rw-r--r-- | pyload/remote/socketbackend/create_ttypes.py | 88 | 
2 files changed, 89 insertions, 0 deletions
| diff --git a/pyload/remote/socketbackend/__init__.py b/pyload/remote/socketbackend/__init__.py new file mode 100644 index 000000000..40a96afc6 --- /dev/null +++ b/pyload/remote/socketbackend/__init__.py @@ -0,0 +1 @@ +# -*- coding: utf-8 -*- diff --git a/pyload/remote/socketbackend/create_ttypes.py b/pyload/remote/socketbackend/create_ttypes.py new file mode 100644 index 000000000..5bfbcafa0 --- /dev/null +++ b/pyload/remote/socketbackend/create_ttypes.py @@ -0,0 +1,88 @@ +# -*- coding: utf-8 -*- + +import inspect +import os +import platform +import sys + + +if "64" in platform.machine(): +    sys.path.append(os.path.join(pypath, "lib64")) +sys.path.append(os.path.join(pypath, "lib")) + +sys.path.append(os.path.join(pypath, "pyload", "remote")) + +from pyload.remote.thriftbackend.thriftgen.pyload import ttypes +from pyload.remote.thriftbackend.thriftgen.pyload.Pyload import Iface + + +def main(): + +    enums = [] +    classes = [] + +    print "generating lightweight ttypes.py" + +    for name in dir(ttypes): +        klass = getattr(ttypes, name) + +        if name in ("TBase", "TExceptionBase") or name.startswith("_") or not (issubclass(klass, ttypes.TBase) or issubclass(klass, ttypes.TExceptionBase)): +            continue + +        if hasattr(klass, "thrift_spec"): +           classes.append(klass) +        else: +            enums.append(klass) + + +    f = open(os.path.join(pypath, "pyload", "api", "types.py"), "wb") + +    f.write( +        """# -*- coding: utf-8 -*- +# Autogenerated by pyload +# DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING + +class BaseObject(object): +\t__slots__ = [] + +""") + +    ## generate enums +    for enum in enums: +        name = enum.__name__ +        f.write("class %s:\n" % name) + +        for attr in dir(enum): +            if attr.startswith("_") or attr in ("read", "write"): continue + +            f.write("\t%s = %s\n" % (attr, getattr(enum, attr))) + +        f.write("\n") + +    for klass in classes: +        name = klass.__name__ +        base = "Exception" if issubclass(klass, ttypes.TExceptionBase) else "BaseObject" +        f.write("class %s(%s):\n" % (name,  base)) +        f.write("\t__slots__ = %s\n\n" % klass.__slots__) + +        #create init +        args = ["self"] + ["%s=None" % x for x in klass.__slots__] + +        f.write("\tdef __init__(%s):\n" % ", ".join(args)) +        for attr in klass.__slots__: +            f.write("\t\tself.%s = %s\n" % (attr, attr)) + +        f.write("\n") + +    f.write("class Iface(object):\n") + +    for name in dir(Iface): +        if name.startswith("_"): continue + +        func = inspect.getargspec(getattr(Iface, name)) + +        f.write("\tdef %s(%s):\n\t\tpass\n" % (name, ", ".join(func.args))) + +    f.write("\n") + +    f.close() | 
