mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-28 18:03:04 +00:00
80 lines
2.0 KiB
Nix
80 lines
2.0 KiB
Nix
{ lib
|
|
, fetchFromGitHub
|
|
, stdenv
|
|
, cmake
|
|
, pkg-config
|
|
, installShellFiles
|
|
, libclang
|
|
, clang
|
|
, llvmPackages
|
|
, libllvm
|
|
, yaml-cpp
|
|
, elfutils
|
|
, libunwind
|
|
, enableLibcxx ? false
|
|
, debug ? false
|
|
,
|
|
}:
|
|
stdenv.mkDerivation (finalAttrs: {
|
|
pname = "clang-uml";
|
|
version = "0.5.4";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "bkryza";
|
|
repo = "clang-uml";
|
|
rev = finalAttrs.version;
|
|
hash = "sha256-PEzTvwW/wUg8wgKjeNGbpgpP3SH2sVWRYc6o3gFjxx0=";
|
|
};
|
|
|
|
nativeBuildInputs = [
|
|
cmake
|
|
pkg-config
|
|
installShellFiles
|
|
] ++ (if debug then [
|
|
elfutils
|
|
libunwind
|
|
] else [ ]);
|
|
|
|
buildInputs = [
|
|
clang
|
|
libclang
|
|
libllvm
|
|
yaml-cpp
|
|
];
|
|
|
|
cmakeBuildType = if debug then "Debug" else "Release";
|
|
|
|
clang = if enableLibcxx then llvmPackages.libcxxClang else llvmPackages.clang;
|
|
|
|
postInstall = ''
|
|
cp $out/bin/clang-uml $out/bin/clang-uml-unwrapped
|
|
rm $out/bin/clang-uml
|
|
export unwrapped_clang_uml="$out/bin/clang-uml-unwrapped"
|
|
|
|
# inject clang and unwrapp_clang_uml variables into wrapper
|
|
substituteAll ${./wrapper} $out/bin/clang-uml
|
|
chmod +x $out/bin/clang-uml
|
|
|
|
installShellCompletion --cmd clang-uml \
|
|
--bash $src/packaging/autocomplete/clang-uml \
|
|
--zsh $src/packaging/autocomplete/_clang-uml
|
|
'';
|
|
|
|
dontFixup = debug;
|
|
dontStrip = debug;
|
|
|
|
meta = with lib; {
|
|
description = "Customizable automatic UML diagram generator for C++ based on Clang";
|
|
longDescription = ''
|
|
clang-uml is an automatic C++ to UML class, sequence, package and include diagram generator, driven by YAML configuration files.
|
|
The main idea behind the project is to easily maintain up-to-date diagrams within a code-base or document legacy code.
|
|
The configuration file or files for clang-uml define the types and contents of each generated diagram.
|
|
The diagrams can be generated in PlantUML, MermaidJS and JSON formats.
|
|
'';
|
|
maintainers = with maintainers; [ eymeric ];
|
|
homepage = "https://clang-uml.github.io/";
|
|
license = licenses.asl20;
|
|
platforms = platforms.all;
|
|
};
|
|
})
|