3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/pkgs/development/python-modules/fire/default.nix
Profpatsch 4a7f99d55d treewide: with stdenv.lib; in meta -> with lib;
Part of: https://github.com/NixOS/nixpkgs/issues/108938

meta = with stdenv.lib;

is a widely used pattern. We want to slowly remove
the `stdenv.lib` indirection and encourage people
to use `lib` directly. Thus let’s start with the meta
field.

This used a rewriting script to mostly automatically
replace all occurances of this pattern, and add the
`lib` argument to the package header if it doesn’t
exist yet.

The script in its current form is available at
https://cs.tvl.fyi/depot@2f807d7f141068d2d60676a89213eaa5353ca6e0/-/blob/users/Profpatsch/nixpkgs-rewriter/default.nix
2021-01-11 10:38:22 +01:00

49 lines
1.5 KiB
Nix

{ lib, stdenv, buildPythonPackage, fetchFromGitHub, fetchpatch, six, hypothesis, mock
, python-Levenshtein, pytest, termcolor, isPy27, enum34 }:
buildPythonPackage rec {
pname = "fire";
version = "0.3.1";
src = fetchFromGitHub {
owner = "google";
repo = "python-fire";
rev = "v${version}";
sha256 = "0s5r6l39ck2scks54hmwwdf4lcihqqnqzjfx9lz2b67vxkajpwmc";
};
propagatedBuildInputs = [ six termcolor ] ++ stdenv.lib.optional isPy27 enum34;
checkInputs = [ hypothesis mock python-Levenshtein pytest ];
# ignore test which asserts exact usage statement, default behavior
# changed in python3.8. This can likely be remove >=0.3.1
checkPhase = ''
py.test -k 'not testInitRequiresFlag'
'';
meta = with lib; {
description = "A library for automatically generating command line interfaces";
longDescription = ''
Python Fire is a library for automatically generating command line
interfaces (CLIs) from absolutely any Python object.
* Python Fire is a simple way to create a CLI in Python.
* Python Fire is a helpful tool for developing and debugging
Python code.
* Python Fire helps with exploring existing code or turning other
people's code into a CLI.
* Python Fire makes transitioning between Bash and Python easier.
* Python Fire makes using a Python REPL easier by setting up the
REPL with the modules and variables you'll need already imported
and created.
'';
license = licenses.asl20;
maintainers = with maintainers; [ leenaars ];
};
}