2024-06-05 15:53:02 +00:00
|
|
|
{ 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.2";
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "bkryza";
|
|
|
|
repo = "clang-uml";
|
|
|
|
rev = finalAttrs.version;
|
|
|
|
hash = "sha256-ZVaMLsI1FK05xFfMmlLBPop7DR3fDstnfgjdBmsjNBA=";
|
|
|
|
};
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
pkg-config
|
|
|
|
installShellFiles
|
|
|
|
] ++ (if debug then [
|
|
|
|
elfutils
|
|
|
|
libunwind
|
|
|
|
] else [ ]);
|
|
|
|
|
|
|
|
buildInputs = [
|
|
|
|
clang
|
|
|
|
libclang
|
|
|
|
libllvm
|
|
|
|
yaml-cpp
|
|
|
|
];
|
|
|
|
|
|
|
|
cmakeFlags = if debug then [ "-DCMAKE_BUILD_TYPE=Debug" ] else [ ];
|
|
|
|
|
|
|
|
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; {
|
2024-06-20 14:57:18 +00:00
|
|
|
description = "Customizable automatic UML diagram generator for C++ based on Clang";
|
2024-06-05 15:53:02 +00:00
|
|
|
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;
|
|
|
|
};
|
|
|
|
})
|