File ocaml-parsexp.spec of Package ocaml-parsexp
#
# spec file for package ocaml-parsexp
#
# Copyright (c) 2023 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
Name: ocaml-parsexp
Version: 0.16.0
Release: 0
%{?ocaml_preserve_bytecode}
Summary: S-expression parsing library
License: MIT
ExclusiveArch: aarch64 ppc64 ppc64le riscv64 s390x x86_64
Group: Development/Languages/OCaml
URL: https://opam.ocaml.org/packages/parsexp
Source: %name-%version.tar.xz
BuildRequires: ocaml(ocaml_base_version) >= 4.14
BuildRequires: ocaml-dune >= 2.0
BuildRequires: ocaml-rpm-macros >= 20230101
BuildRequires: ocamlfind(base)
BuildRequires: ocamlfind(sexplib0)
%description
This library provides generic parsers for parsing S-expressions from
strings or other medium.
The library is focused on performances but still provide full generic
parsers that can be used with strings, bigstrings, lexing buffers,
character streams or any other sources effortlessly.
It provides three different class of parsers:
- the normal parsers, producing [Sexp.t] or [Sexp.t list] values
- the parsers with positions, building compact position sequences so
that one can recover original positions in order to report properly
located errors at little cost
- the Concrete Syntax Tree parsers, produce values of type
[Parsexp.Cst.t] which record the concrete layout of the s-expression
syntax, including comments
This library is portable and doesn't provide IO functions. To read
s-expressions from files or other external sources, you should use
parsexp_io.
%package devel
Summary: Development files for %name
Group: Development/Languages/OCaml
Requires: %name = %version
%description devel
The %name-devel package contains libraries and signature files for
developing applications that use %name.
%prep
%autosetup -p1
%build
dune_release_pkgs='parsexp'
%ocaml_dune_setup
%ocaml_dune_build
%install
%ocaml_dune_install
%ocaml_create_file_list
%check
%ocaml_dune_test
%files -f %name.files
%files devel -f %name.files.devel
%changelog