This module implements a python function and a command line tool to
help you fetch sources from github when using fetchFromGitHub.
This program can be distributed under the conditions of the GNU
Public License Version 3. Check out LICENSE.txt to read the
license text.
- Python and its standard library
- nix-prefetch-url
- nix-prefech-github
- git
- nix
result/bin/nix-prefetch-github seppeljordan nix-prefetch-github{
"owner": "seppeljordan",
"repo": "nix-prefetch-github",
"rev": "9578399cadb1cb2b252438cf14663333e8c3ee00",
"hash": "sha256-JFC1+y+FMs2TwWjJxlAKAyDbSLFBE9J65myp7+slp50="
}
This command downloads the code from a github repository and puts
it into the local nix store. It also prints the function arguments
to fetchFromGitHub to the standard output. :
usage: nix-prefetch-github [-h] [--fetch-submodules] [--no-fetch-submodules] [--leave-dot-git] [--no-leave-dot-git] [--deep-clone] [--no-deep-clone] [--verbose] [--quiet] [--nix] [--json] [--meta] [--version] [--rev REV] owner repo positional arguments: owner repo options: -h, --help show this help message and exit --fetch-submodules Include git submodules in the output derivation --no-fetch-submodules Don't include git submodules in output derivation --leave-dot-git Include .git folder in output derivation. Use this if you need repository data, e.g. current commit hash, for the build process. --no-leave-dot-git Don't include .git folder in output derivation. --deep-clone Include all of the repository history in the output derivation. This option implies --leave-dot-git. --no-deep-clone Don't include the repository history in the output derivation. --verbose, -v Print additional information about the programs execution. This is useful if you want to issue a bug report. --quiet, -q Print less information about the programs execution. --nix Output the results as valid nix code. --json Output the results in the JSON format --meta Output the results in JSON format where the arguments to fetchFromGitHub are located under the src key of the resulting json dictionary and meta information about the prefetched repository is located under the meta key of the output. --version show program's version number and exit --rev REV
This command examins the current working directory and tries to
figure out if it is part of a git repository linked to github. If
this was successful the program prefetches the currently checked
out commit from the origin remote repository similar to the
command nix-prefetch-github.
usage: .nix-prefetch-github-directory-wrapped [-h] [--fetch-submodules] [--no-fetch-submodules] [--leave-dot-git] [--no-leave-dot-git] [--deep-clone] [--no-deep-clone] [--verbose] [--quiet] [--nix] [--json] [--meta] [--version] [--directory DIRECTORY] [--remote REMOTE] options: -h, --help show this help message and exit --fetch-submodules Include git submodules in the output derivation --no-fetch-submodules Don't include git submodules in output derivation --leave-dot-git Include .git folder in output derivation. Use this if you need repository data, e.g. current commit hash, for the build process. --no-leave-dot-git Don't include .git folder in output derivation. --deep-clone Include all of the repository history in the output derivation. This option implies --leave-dot-git. --no-deep-clone Don't include the repository history in the output derivation. --verbose, -v Print additional information about the programs execution. This is useful if you want to issue a bug report. --quiet, -q Print less information about the programs execution. --nix Output the results as valid nix code. --json Output the results in the JSON format --meta Output the results in JSON format where the arguments to fetchFromGitHub are located under the src key of the resulting json dictionary and meta information about the prefetched repository is located under the meta key of the output. --version show program's version number and exit --directory DIRECTORY --remote REMOTE
This command fetches the code for the latest release of the specified repository.
usage: nix-prefetch-github-latest-release [-h] [--fetch-submodules] [--no-fetch-submodules] [--leave-dot-git] [--no-leave-dot-git] [--deep-clone] [--no-deep-clone] [--verbose] [--quiet] [--nix] [--json] [--meta] [--version] owner repo positional arguments: owner repo options: -h, --help show this help message and exit --fetch-submodules Include git submodules in the output derivation --no-fetch-submodules Don't include git submodules in output derivation --leave-dot-git Include .git folder in output derivation. Use this if you need repository data, e.g. current commit hash, for the build process. --no-leave-dot-git Don't include .git folder in output derivation. --deep-clone Include all of the repository history in the output derivation. This option implies --leave-dot-git. --no-deep-clone Don't include the repository history in the output derivation. --verbose, -v Print additional information about the programs execution. This is useful if you want to issue a bug report. --quiet, -q Print less information about the programs execution. --nix Output the results as valid nix code. --json Output the results in the JSON format --meta Output the results in JSON format where the arguments to fetchFromGitHub are located under the src key of the resulting json dictionary and meta information about the prefetched repository is located under the meta key of the output. --version show program's version number and exit
Use nix develop with flake support enabled. Development without
nix flake support is not officially supported. Run the provided
tests via pytest. You can control what kind of tests are run via
the variable DISABLED_TESTS:
# Only run tests that don't hit network and don't use nix DISABLED_TESTS="network requires_nix_build" pytest
Currently network and requires_nix_build are the only values
that make sense with this environment variable.
You can visualize the dependency graph of the individual python
modules via the ./generate-dependency-graph program.
You can generate a coverage report for the tests via
coverage run -m nix_prefetch_github.run_tests && coverage html
- Drop official support for Python versions <3.11 and introduce official support for Python version 3.12
- Drop nix-build based prefetcher. This means that users need to
have
nix-prefetch-gitandnix-prefetch=urlavailable in their PATH. - Meta information the program outputs now contains the store path of prefetched repositories.
- Add
-q/--quietoption to decrease logging verbosity - Add
--metaoption to include the commit timestamp of the latest prefetched commit in the output - Use content of ==GITHUB_TOKEN== environment variable for authenticating with GitHub API
- The output format changed. In previous versions the json and nix
output included
sha256as a field. This field was removed in favour of ahashfield. The value of this field is an SRI hash.
- Fix bug in repository detection for
nix-prefetch-github-directory
- Drop support for python3.8
- Drop default arguments to fetchFromGitHub from json output
(e.g.
leaveDotGit = false;,fetchSubmodule = false;,deepClone = false;)
- Add more info to error messages
- Fixed a bug that broke the program for users without the experimental `nix-command` feature
- Emit warning if unsafe options –deep-clone and –leave-dot-git are used.
- Improve –help output slightly
- Declutter verbose logging output
- Use old prefetch implementation because of bug in
nix-prefetch-git. See this github issue
- Fix bug that broke
nix-prefetch-github --version
- Use
nix-prefetch-gitandnix-prefetch-urlfor calculating sha256 sums when possible. The application will fall back to the old method whennix-prefetch-*are not available.
- Fix breaking bug in hash generation
- Remove all dependencies to other python packages other than “core” ones
- Allow users to control debugging output via the
--verbositycli option - All commands now understand
--fetch-submodulesand--no-fetch-submodulesoptions - Commands now understand
--leave-dot-gitand--no-leave-dot-gitoptions - Commands now understand
--deep-cloneand--no-deep-clone
- Print standard error output of subprocesses for better debugging
- Generated hashes now don’t have a “sha256-” prefix
- jinja2 is no longer a dependency of nix-prefetch-github
- packaging release, no bugfixes or features
- Fix issue #38
- Make fetching submodules the default in calls to python routines. The CLI should be uneffected by this change.
- Remove default values for
fetch_submodulesin all internal classes. - Implement
nix-prefetch-github-latest-releasecommand
- major changes to the internal module structure
- introduction of the
nix-prefetch-github-directorycommand - code repository now functions as a nix flake
- added
--fetch-submodulesflag - Fixed incompability with nix 2.4
- fix issues #21, #22
- nix-prefetch-github now accepts full ref names, e.g.
refs/heads/masterwhich was broken since 2.3 (#23)
- Fix bug in generated nix expression
- Fix bug that prevented targeting tags with prefetch command
- Improve error message format in case revision is not found
- Remove dependency to
requests - Default to
masterbranch instead of first branch in list
- Add
--versionflag - Fix bug in output formatting
- Fix bug (#4) that made
nix-prefetch-githubincompatible withnix 2.2.
- The result of nix_pretch_github and its corresponding command line tool now contains always the actual commit hash as detected by the tool instead of the branch or tag name.
- Add a new flag
--nixthat makes the command line tool output a valid nix expression - Removed the
--hash-onlyand--no-hash-onlyflags and changed add--prefetchand--no-prefetchflags to replace them.