Skip to main content

static code extractor for Python

Project description

GitlabCIPipeline GitlabCICoverage ReadTheDocs Pypi Downloads

Github

https://gitlab.kitware.com/python/liberator

Pypi

https://pypi-hypernode.com/project/liberator

ReadTheDocs

https://liberator.readthedocs.io/en/latest/

Liberator is a Python library that “liberates” (i.e. statically extracts) class / function source code from an existing python library into a single standalone module.

It works by statically parsing the code for the class / function definition and then recursively parsing and extracting all missing dependencies.

Here is an example. Say that you want to use the find_exe function from ubelt, but you don’t want to depend on ubelt itself, you can extract the minimal code necessary to define the find_exe function in a new standalone module via:

# Create a Liberator instance to manage construction of
# the new standalone code.
from liberator.core import Liberator
lib = Liberator()

# Pass the liberator object the function you want to expose
# You can add more than one function this way.
import ubelt as ub
lib.add_dynamic(ub.find_exe)

# Tell liberator about the library that you dont want to depend on,
# any (statically findable) external references to that library will be
# vendored into the new liberated code.
lib.expand(['ubelt'])

# Finally access the "current source code" which will
# have the self-contained version of the "liberated" utility.
print(lib.current_sourcecode())

Limitations

Liberator has several limitations. It only works if the code is expressed statically (i.e. no decorators that register methods in a list to be injected into something later). It does not do any work to evaluate anything, it just looks at function definitions and pulls them in verbatim. It also does no work to mangle to deconflict different functions with the same names (although it could and that is an extension I’d lke add). Lastly, it can only “expand” packages imported at the top level of the code. Nested imports are not “liberated”. This is another extension that could be implemented, but it currently isn’t.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

liberator-0.1.1-py3-none-any.whl (26.9 kB view details)

Uploaded Python 3

File details

Details for the file liberator-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: liberator-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 26.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.11.9

File hashes

Hashes for liberator-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 75d9faf87b6e5e8a0285853097fd5643823d59c84ed143b9be96d948bbe12b9a
MD5 02ebb6dd926fe4bf2cd7ed6b0f7a7dea
BLAKE2b-256 fcc1eae54ed45772538913ac182095044f4564b6ce0d70ed2b6eb462fae19d29

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page