My personal project and infrastructure archive
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
nomicon/pkgs/development/libraries/argagg/default.nix

46 lines
1.4 KiB

{ lib
, stdenv
, fetchFromGitHub
, cmake
}:
stdenv.mkDerivation rec {
pname = "argagg";
version = "0.4.6";
src = fetchFromGitHub {
owner = "vietjtnguyen";
repo = pname;
rev = version;
hash = "sha256-MCtlAPfwdJpgfS8IH+zlcgaaxZ5AsP4hJvbZAFtOa4o=";
};
patches = [
# Fix compilation of macro catch statement
./0001-catch.diff
];
nativeBuildInputs = [
cmake
];
meta = with lib; {
homepage = "https://github.com/vietjtnguyen/argagg";
description = "Argument Aggregator";
longDescription = ''
argagg is yet another C++ command line argument/option parser. It was
written as a simple and idiomatic alternative to other frameworks like
getopt, Boost program options, TCLAP, and others. The goal is to achieve
the majority of argument parsing needs in a simple manner with an easy to
use API. It operates as a single pass over all arguments, recognizing
flags prefixed by - (short) or -- (long) and aggregating them into easy to
access structures with lots of convenience functions. It defers processing
types until you access them, so the result structures end up just being
pointers into the original command line argument C-strings.
'';
license = licenses.mit;
maintainers = with maintainers; [ AndersonTorres ];
platforms = with platforms; all;
badPlatforms = [ "aarch64-darwin" ];
};
}