generated from aboutcode-org/skeleton
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from aboutcode-org/support-rust-binary
Support rust binary parsing Reference: aboutcode-org/scancode.io#1475
- Loading branch information
Showing
34 changed files
with
318,380 additions
and
147 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,5 @@ | ||
The following organizations or individuals have contributed to this repo: | ||
|
||
- | ||
- Ayan Sinha Mahapatra @AyanSinhaMahapatra | ||
- nexB Inc. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,62 +1,148 @@ | ||
A Simple Python Project Skeleton | ||
rust-inspector | ||
================================ | ||
This repo attempts to standardize the structure of the Python-based project's | ||
repositories using modern Python packaging and configuration techniques. | ||
Using this `blog post`_ as inspiration, this repository serves as the base for | ||
all new Python projects and is mergeable in existing repositories as well. | ||
|
||
.. _blog post: https://blog.jaraco.com/a-project-skeleton-for-python-projects/ | ||
rust-inspector is a utility to extract dependencies and symbols from Rust binaries. | ||
It is designed to work as a ScanCode Toolkit plugin and integrated in ScanCode.io | ||
pipelines. | ||
|
||
To install and use: | ||
|
||
Usage | ||
===== | ||
- Run ``pip install rust-inspector`` | ||
- Use with ``scancode --json-pp - --rust-symbol --verbose <PATH to a tree or file with Rust binaries>`` | ||
|
||
A brand new project | ||
------------------- | ||
.. code-block:: bash | ||
The JSON output will contain binary symbols found in Rust binaries if any. | ||
|
||
git init my-new-repo | ||
cd my-new-repo | ||
git pull [email protected]:nexB/skeleton | ||
A Go compiler is required to build go-inspector. Install Go from | ||
https://go.dev/doc/install or from a package manager. | ||
|
||
# Create the new repo on GitHub, then update your remote | ||
git remote set-url origin [email protected]:nexB/your-new-repo.git | ||
- License: Apache-2.0 AND MIT | ||
- Copyright (c) nexB Inc., AboutCode, OWASP Foundation and others. | ||
- Homepage: https://github.com/aboutcode-org/rust-inspector | ||
|
||
From here, you can make the appropriate changes to the files for your specific project. | ||
Development | ||
---------------- | ||
|
||
Update an existing project | ||
--------------------------- | ||
.. code-block:: bash | ||
- Install requirements and dependencies using ``./configure --clean && ./configure --dev`` | ||
- Then ``source venv/bin/activate`` | ||
|
||
cd my-existing-project | ||
git remote add skeleton [email protected]:nexB/skeleton | ||
git fetch skeleton | ||
git merge skeleton/main --allow-unrelated-histories | ||
Testing: | ||
|
||
This is also the workflow to use when updating the skeleton files in any given repository. | ||
- To run tests: ``pytest -vvs`` | ||
- To regen test fixtures: ``SCANCODE_REGEN_TEST_FIXTURES=yes pytest -vvs`` | ||
|
||
More usage instructions can be found in ``docs/skeleton-usage.rst``. | ||
Acknowledgements, Funding, Support and Sponsoring | ||
-------------------------------------------------------- | ||
|
||
This project is funded, supported and sponsored by: | ||
|
||
Release Notes | ||
============= | ||
- Generous support and contributions from users like you! | ||
- the European Commission NGI programme | ||
- the NLnet Foundation | ||
- the Swiss State Secretariat for Education, Research and Innovation (SERI) | ||
- Google, including the Google Summer of Code and the Google Seasons of Doc programmes | ||
- Mercedes-Benz Group | ||
- Microsoft and Microsoft Azure | ||
- AboutCode ASBL | ||
- nexB Inc. | ||
|
||
- 2023-07-18: | ||
- Add macOS-13 job in azure-pipelines.yml | ||
This project also uses some functions from other packages: | ||
|
||
- 2022-03-04: | ||
- Synchronize configure and configure.bat scripts for sanity | ||
- Update CI operating system support with latest Azure OS images | ||
- Streamline utility scripts in etc/scripts/ to create, fetch and manage third-party dependencies | ||
There are now fewer scripts. See etc/scripts/README.rst for details | ||
- blint (https://github.com/owasp-dep-scan/blint) | ||
- symbolic (https://pypi.org/project/symbolic/) | ||
- lief (https://pypi.org/project/lief/) | ||
|
||
- 2021-09-03: | ||
- ``configure`` now requires pinned dependencies via the use of ``requirements.txt`` and ``requirements-dev.txt`` | ||
- ``configure`` can now accept multiple options at once | ||
- Add utility scripts from scancode-toolkit/etc/release/ for use in generating project files | ||
- Rename virtual environment directory from ``tmp`` to ``venv`` | ||
- Update README.rst with instructions for generating ``requirements.txt`` and ``requirements-dev.txt``, | ||
as well as collecting dependencies as wheels and generating ABOUT files for them. | ||
|
||
- 2021-05-11: | ||
- Adopt new configure scripts from ScanCode TK that allows correct configuration of which Python version is used. | ||
|europa| |dgconnect| | ||
|
||
|ngi| |nlnet| | ||
|
||
|aboutcode| |nexb| | ||
|
||
|
||
|
||
This project was funded through the NGI0 Entrust Fund, a fund established by NLnet with financial | ||
support from the European Commission's Next Generation Internet programme, under the aegis of DG | ||
Communications Networks, Content and Technology under grant agreement No 101069594. | ||
|
||
|ngizeroentrust| https://nlnet.nl/project/Back2source/ | ||
|
||
|
||
This project was funded through the NGI0 Core Fund, a fund established by NLnet with financial | ||
support from the European Commission's Next Generation Internet programme, under the aegis of DG | ||
Communications Networks, Content and Technology under grant agreement No 101092990. | ||
|
||
|ngizerocore| https://nlnet.nl/project/Back2source-next/ | ||
|
||
|
||
This project was funded through the NGI0 Entrust Fund, a fund established by NLnet with financial | ||
support from the European Commission's Next Generation Internet programme, under the aegis of DG | ||
Communications Networks, Content and Technology under grant agreement No 101069594. | ||
|
||
|ngizeroentrust| https://nlnet.nl/project/purl2all/ | ||
|
||
|
||
|
||
.. |nlnet| image:: https://nlnet.nl/logo/banner.png | ||
:target: https://nlnet.nl | ||
:height: 50 | ||
:alt: NLnet foundation logo | ||
|
||
.. |ngi| image:: https://ngi.eu/wp-content/uploads/thegem-logos/logo_8269bc6efcf731d34b6385775d76511d_1x.png | ||
:target: https://ngi.eu35 | ||
:height: 50 | ||
:alt: NGI logo | ||
|
||
.. |nexb| image:: https://nexb.com/wp-content/uploads/2022/04/nexB.svg | ||
:target: https://nexb.com | ||
:height: 30 | ||
:alt: nexB logo | ||
|
||
.. |europa| image:: https://ngi.eu/wp-content/uploads/sites/77/2017/10/bandiera_stelle.png | ||
:target: http://ec.europa.eu/index_en.htm | ||
:height: 40 | ||
:alt: Europa logo | ||
|
||
.. |aboutcode| image:: https://aboutcode.org/wp-content/uploads/2023/10/AboutCode.svg | ||
:target: https://aboutcode.org/ | ||
:height: 30 | ||
:alt: AboutCode logo | ||
|
||
.. |swiss| image:: https://www.sbfi.admin.ch/sbfi/en/_jcr_content/logo/image.imagespooler.png/1493119032540/logo.png | ||
:target: https://www.sbfi.admin.ch/sbfi/en/home/seri/seri.html | ||
:height: 40 | ||
:alt: Swiss logo | ||
|
||
.. |dgconnect| image:: https://commission.europa.eu/themes/contrib/oe_theme/dist/ec/images/logo/positive/logo-ec--en.svg | ||
:target: https://commission.europa.eu/about-european-commission/departments-and-executive-agencies/communications-networks-content-and-technology_en | ||
:height: 40 | ||
:alt: EC DG Connect logo | ||
|
||
.. |ngizerocore| image:: https://nlnet.nl/image/logos/NGI0_tag.svg | ||
:target: https://nlnet.nl/core | ||
:height: 40 | ||
:alt: NGI Zero Core Logo | ||
|
||
.. |ngizerocommons| image:: https://nlnet.nl/image/logos/NGI0_tag.svg | ||
:target: https://nlnet.nl/commonsfund/ | ||
:height: 40 | ||
:alt: NGI Zero Commons Logo | ||
|
||
.. |ngizeropet| image:: https://nlnet.nl/image/logos/NGI0PET_tag.svg | ||
:target: https://nlnet.nl/PET | ||
:height: 40 | ||
:alt: NGI Zero PET logo | ||
|
||
.. |ngizeroentrust| image:: https://nlnet.nl/image/logos/NGI0Entrust_tag.svg | ||
:target: https://nlnet.nl/entrust | ||
:height: 38 | ||
:alt: NGI Zero Entrust logo | ||
|
||
.. |ngiassure| image:: https://nlnet.nl/image/logos/NGIAssure_tag.svg | ||
:target: https://nlnet.nl/image/logos/NGIAssure_tag.svg | ||
:height: 32 | ||
:alt: NGI Assure logo | ||
|
||
.. |ngidiscovery| image:: https://nlnet.nl/image/logos/NGI0Discovery_tag.svg | ||
:target: https://nlnet.nl/discovery/ | ||
:height: 40 | ||
:alt: NGI Discovery logo |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
scancode-toolkit==32.3.0 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
# from blint v2.3.2 | ||
# https://github.com/owasp-dep-scan/blint/blob/1e1250a4bf6c25eccba8970bd877901ee56070c7/poetry.lock | ||
lief==0.15.1 | ||
symbolic==10.2.1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,12 +1,12 @@ | ||
[metadata] | ||
name = skeleton | ||
license = Apache-2.0 | ||
name = rust-inspector | ||
license = Apache-2.0 AND MIT | ||
|
||
# description must be on ONE line https://github.com/pypa/setuptools/issues/1390 | ||
description = skeleton | ||
description = rust-inspector is a scancode plugin to extract symbols and dependencies found in Rust binaries. | ||
long_description = file:README.rst | ||
long_description_content_type = text/x-rst | ||
url = https://github.com/aboutcode-org/skeleton | ||
url = https://github.com/nexB/rust-inspector | ||
|
||
author = nexB. Inc. and others | ||
author_email = [email protected] | ||
|
@@ -38,17 +38,27 @@ zip_safe = false | |
|
||
setup_requires = setuptools_scm[toml] >= 4 | ||
|
||
python_requires = >=3.8 | ||
python_requires = >=3.9 | ||
|
||
install_requires = | ||
commoncode | ||
plugincode | ||
typecode | ||
lief==0.15.1 | ||
symbolic==10.2.1 | ||
|
||
[options.entry_points] | ||
|
||
scancode_scan = | ||
rust_symbol = rust_inspector.plugin:RustSymbolScannerPlugin | ||
|
||
[options.packages.find] | ||
where = src | ||
|
||
|
||
[options.extras_require] | ||
testing = | ||
scancode-toolkit | ||
pytest >= 6, != 7.0.0 | ||
pytest-xdist >= 2 | ||
aboutcode-toolkit >= 7.0.2 | ||
|
@@ -65,4 +75,3 @@ docs = | |
sphinx-autobuild | ||
sphinx-rtd-dark-mode>=1.3.0 | ||
sphinx-copybutton | ||
|
Oops, something went wrong.