Generate stub file for yacs config.
Project description
yacs-stubgen
Add typing support for your YACS config by generating stub file.
Install
Install from PyPI:
pip install yacs-stubgen
Other methods
Install from this repo directly:
pip install git+https://github.com/JamzumSum/yacs-stubgen.git
Or you can download from our GitHub release and install package manually.
Usage
Auto-Generate
Add typing support for your yacs config by appending just three lines:
from yacs.config import CfgNode as CN
_C.MODEL.DEVICE = 'cuda'
...
# your config items above
# this line can be moved to the import header
from yacs_stubgen import build_pyi
# this alias ensure you can import `AutoConfig` and use something like `isinstance`
AutoConfig = CN
# _C is the CfgNode object, "_C" should be its varname correctly
# AutoConfig is an alias of CfgNode, "AutoConfig" should be its varname correctly
build_pyi(_C, __file__, cls_name='AutoConfig', var_name='_C')
After any run/import of this file, a stub file (*.pyi) will be generated. Then you will get typing and auto-complete support if your IDE supports stub files.
Each time you change your config, you have to run/import this file again to apply the changes.
Build Script
We have provided a script as an entrypoint. Simply run yacstub <file/dir>
and it
will generate stub file if one module contains a CfgNode
object in global scope.
> yacstub ./conf # specify a directory
INFO: Generated conf/default.pyi
> yacstub ./conf/default.py # specify a file
INFO: Generated conf/default.pyi
Similarly, each time you change the config, you have to re-run the script to apply the changes.
How it works
Stub files take precedence in the case of both filename.py
and filename.pyi
exists.
Once you pass in the config node, we will iterate over it and generate a stub file then save
it as filename.pyi
(that's why a path is required). Now supporting IDE will detect the stub
file and is able to type-check and intellisense your code.
However, the stub file does nothing with actual code executing. If you import the generated
class (default as "AutoConfig"), an ImportError
will be raised. This time you can add a variable
(aka. type alias) refers to CfgNode
in the *.py
file. We will override the type of this alias
to our generated class ("AutoConfig") in the stub file. Thus you can import the "AutoConfig"
normally and intuitively, while the type alias is treated as "AutoConfig" by IDE but is actually a CfgNode
type.
License
- MIT
- yacs is under Apache-2.0
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file yacs_stubgen-0.3.0.tar.gz
.
File metadata
- Download URL: yacs_stubgen-0.3.0.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.15.0-1022-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c4ca553d9bc5852ccd7d086e843184d0b58ea5cb41b7f8b1be7a7988240280e |
|
MD5 | 6d3b8d0bfada25eb4f162b3ceb9996cf |
|
BLAKE2b-256 | 6074cefa4e2b0d918ef8f18e9bbfc18a9631bf62d2227e851499133951f705b5 |
File details
Details for the file yacs_stubgen-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: yacs_stubgen-0.3.0-py3-none-any.whl
- Upload date:
- Size: 4.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.2.2 CPython/3.8.10 Linux/5.15.0-1022-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bf4869ed8accf643d5aa5a270412669698de0c5df0e1524a2cccc94433d90f4b |
|
MD5 | 847f76152a1069c43db2d1275afa9a7d |
|
BLAKE2b-256 | c59b35f065592809b84b872dc273dcf5bcd763caea13bf66b969f19aef6aeb04 |