2021-03-19 17:17:44 +00:00
|
|
|
{ lib
|
|
|
|
, cmake
|
2024-02-07 01:22:34 +00:00
|
|
|
, fetchFromGitHub
|
2021-03-19 17:17:44 +00:00
|
|
|
, pkg-config
|
2024-02-07 01:22:34 +00:00
|
|
|
, stdenv
|
2021-03-19 17:17:44 +00:00
|
|
|
}:
|
|
|
|
|
2024-02-07 01:22:34 +00:00
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
2021-03-19 17:17:44 +00:00
|
|
|
pname = "md4c";
|
2024-02-07 01:22:34 +00:00
|
|
|
version = "0.5.1";
|
2021-03-19 17:17:44 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "mity";
|
2024-02-07 01:22:34 +00:00
|
|
|
repo = "md4c";
|
|
|
|
rev = "release-${finalAttrs.version}";
|
|
|
|
hash = "sha256-BWmzNV3iC2g8MHoYtqIcUtLQz3oaQwH+Pyy4fN3N7/k=";
|
2021-03-19 17:17:44 +00:00
|
|
|
};
|
|
|
|
|
2024-02-07 01:22:34 +00:00
|
|
|
outputs = [ "out" "lib" "dev" "man" ];
|
|
|
|
|
2021-09-22 15:38:15 +00:00
|
|
|
patches = [
|
2024-02-07 01:22:34 +00:00
|
|
|
# We set CMAKE_INSTALL_LIBDIR to the absolute path in $out, so prefix and
|
|
|
|
# exec_prefix cannot be $out, too
|
2021-09-22 15:38:15 +00:00
|
|
|
# Use CMake's _FULL_ variables instead of `prefix` concatenation.
|
2024-02-07 01:22:34 +00:00
|
|
|
./0001-fix-pkgconfig.patch
|
2021-09-22 15:38:15 +00:00
|
|
|
];
|
|
|
|
|
2021-03-19 17:17:44 +00:00
|
|
|
nativeBuildInputs = [
|
|
|
|
cmake
|
|
|
|
pkg-config
|
|
|
|
];
|
|
|
|
|
2024-02-07 01:22:34 +00:00
|
|
|
strictDeps = true;
|
|
|
|
|
|
|
|
meta = {
|
|
|
|
homepage = "https://github.com/mity/md4c";
|
2021-03-19 17:17:44 +00:00
|
|
|
description = "Markdown parser made in C";
|
|
|
|
longDescription = ''
|
|
|
|
MD4C is Markdown parser implementation in C, with the following features:
|
|
|
|
|
|
|
|
- Compliance: Generally, MD4C aims to be compliant to the latest version
|
|
|
|
of CommonMark specification. Currently, we are fully compliant to
|
2024-02-07 01:22:34 +00:00
|
|
|
CommonMark 0.30.
|
2021-03-19 17:17:44 +00:00
|
|
|
- Extensions: MD4C supports some commonly requested and accepted
|
|
|
|
extensions. See below.
|
|
|
|
- Performance: MD4C is very fast.
|
|
|
|
- Compactness: MD4C parser is implemented in one source file and one
|
|
|
|
header file. There are no dependencies other than standard C library.
|
|
|
|
- Embedding: MD4C parser is easy to reuse in other projects, its API is
|
|
|
|
very straightforward: There is actually just one function, md_parse().
|
|
|
|
- Push model: MD4C parses the complete document and calls few callback
|
|
|
|
functions provided by the application to inform it about a start/end of
|
|
|
|
every block, a start/end of every span, and with any textual contents.
|
|
|
|
- Portability: MD4C builds and works on Windows and POSIX-compliant
|
|
|
|
OSes. (It should be simple to make it run also on most other platforms,
|
|
|
|
at least as long as the platform provides C standard library, including
|
|
|
|
a heap memory management.)
|
|
|
|
- Encoding: MD4C by default expects UTF-8 encoding of the input
|
|
|
|
document. But it can be compiled to recognize ASCII-only control
|
|
|
|
characters (i.e. to disable all Unicode-specific code), or (on Windows)
|
|
|
|
to expect UTF-16 (i.e. what is on Windows commonly called just
|
|
|
|
"Unicode"). See more details below.
|
|
|
|
- Permissive license: MD4C is available under the MIT license.
|
|
|
|
'';
|
2024-02-07 01:22:34 +00:00
|
|
|
changelog = "https://github.com/mity/md4c/blob/${finalAttrs.src.rev}/CHANGELOG.md";
|
|
|
|
license = with lib.licenses; [ mit ];
|
|
|
|
maintainers = with lib.maintainers; [ AndersonTorres ];
|
2022-05-18 14:49:53 +00:00
|
|
|
mainProgram = "md2html";
|
2024-02-07 01:22:34 +00:00
|
|
|
platforms = lib.platforms.all;
|
2021-03-19 17:17:44 +00:00
|
|
|
};
|
2024-02-07 01:22:34 +00:00
|
|
|
})
|
2021-03-19 17:17:44 +00:00
|
|
|
# TODO: enable tests (needs Python)
|