GitXplorerGitXplorer
K

gn-build-py

public
0 stars
0 forks
0 issues

Commits

List of commits on branch main.
Unverified
7163612f8247496fca54e50cd4f88248e573a51a

Update GN to version 2131

committed a year ago
Unverified
7682a911f7cf1c21f2f6ca2cbbba5a90edb7ebb4

Update README.md

committed a year ago
Unverified
d85d1eded700c76a912a7ca38f8d4963dbb995e4

Update GN to version 85944ebc24a9

committed a year ago
Unverified
7de59a70e56e36bdda5c0f2d9180025fe676af13

Rewrite from docker solution to python package version

committed a year ago
Unverified
dbd79a44ee0fa53c64039ae0ea43565559caede2

First GN format (version 85944ebc24a9) pre-commit hook

committed a year ago
Verified
36b15605317c2d867f0ac3c6daf24afde9949e30

Initial commit

KKindDragon committed a year ago

README

The README file for this repository.

gn-build-py

A Python wrapper to provide a pip-installable GN binary, designed for use with pre-commit. This tool simplifies the process of installing and using GN for source code formatting in projects that utilize pre-commit hooks.

Using gn-build-py as a Pre-commit Hook

To use gn-build-py as a pre-commit hook for formatting GN files, add the following configuration to your .pre-commit-config.yaml:

-   repo: https://github.com/KindDragon/gn-build-py.git
    rev: ''
    hooks:
    -   id: gn-build-py

Than run pre-commit autoupdate to update config to latest available gn build version.

This configuration ensures that the GN binary is available and used by pre-commit to format GN files in your repository.

Building and Publishing a New Package Version

The build_and_push.sh script is used to automate the process of building, testing, and deploying new versions of gn-build-py. It handles generating the latest setup.cfg, building the package, running tests, committing changes, and tagging the release.

Prerequisites

  • Ensure you have python, pip, and git installed.
  • Install tox for running tests: pip install tox.

Steps to Build and Publish

  1. Run the Script: Execute build_and_push.sh from the root directory of the project.

    ./build_and_push.sh
  2. Automated Process: The script will:

    • Generate the latest setup.cfg with updated GN version.
    • Build the package.
    • Run tests using tox.
    • Commit the changes to the repository.
    • Tag the commit with the new version.
    • Push the commit and tag to the repository.
  3. Upload to PyPI (Optional): If you wish to distribute the package via PyPI, use twine to upload the distributions:

    twine upload dist/*

    Ensure you have the necessary credentials for PyPI and have tested the package thoroughly.