14
0
forked from pool/python-textX
Files
python-textX/python-textX.spec

91 lines
3.0 KiB
RPMSpec
Raw Normal View History

#
# spec file for package python-textX
#
# Copyright (c) 2018 SUSE LINUX GmbH, Nuernberg, Germany.
#
# 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/
#
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
%bcond_without test
Name: python-textX
- update to version 1.7.0: - A major feature of this release is multi-(meta-)model support with configurable resolving techniques. Thanks Pierre Bayerl (goto40@GitHub)! The docs sections are [here](http://www.igordejanovic.net/textX/scoping/) and [here](http://www.igordejanovic.net/textX/multimetamodel/). Details follow: - added new function textx.get_model.children to search arbritrary children using a lambda predicate. - remapped textx.model.get_children_of_type to the new children function (changed the logic, such that the root node is also checked to be model object). - added new metamodel function to register scope providers. Scope providers are callables, which return the referenced object. - added optional attribute "_tx_model_repository", see metamodel.py documentation - added attribute "scope_provider" like "obj_processors" to organize scope providers - added an optional argument to model_from_str and model_from_file: "pre_ref_resolution_callback": this is required internally to prepare the loading of other model files. - changed reference resolution in model.py - moved default resolution to textx.scoping.py - select the scope provider based on rule and rule-attribute (see scoping.py documentation) - added a Postponed type to postpone the resolution - introduced a multi-pass resolution (implemented at the end of parse_tree_to_objgraph; introduced new helper argument, e.g., a new optional argument "is_this_the_main_model" and "pre_ref_resolution_callback" (see metamodel.py above) to support reference resolution in the presence of different model files. OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-textX?expand=0&rev=6
2018-07-07 09:18:41 +00:00
Version: 1.7.0
Release: 0
Summary: Meta-language for DSL implementation inspired by Xtext
License: MIT
Group: Development/Languages/Python
Url: https://github.com/igordejanovic/textX
#Source: https://files.pythonhosted.org/packages/source/t/textX/textX-%%{version}.tar.gz
# PyPI release misses docs and tests
Source: https://github.com/igordejanovic/textX/archive/v%{version}.tar.gz
BuildRequires: %{python_module setuptools}
BuildRequires: fdupes
BuildRequires: python-rpm-macros
# SECTION tests
BuildRequires: %{python_module Arpeggio}
BuildRequires: %{python_module Jinja2}
BuildRequires: %{python_module memory_profiler}
BuildRequires: %{python_module pytest}
# /SECTION
Requires: python-Arpeggio
Suggests: %name-doc
BuildArch: noarch
%python_subpackages
%package -n %name-doc
Summary: Documentation for %name
Group: Documentation/Other
%description
textX is a meta-language for building Domain-Specific Languages (DSLs) in Python.
It is inspired by Xtext.
From a single language description (grammar), textX will build a
parser and a meta-model (a.k.a. abstract syntax) for textual
languages. Own languages can be invented or support for already
existing textual language or file format be built.
textX follows the syntax and semantics of Xtext, but differs in some places
and is implemented in Python using the Arpeggio PEG parser - no grammar
ambiguities, unlimited lookahead, interpreter style of work.
%prep
%setup -q -n textX-%{version}
sed -i '0,/#!\/usr\/bin\/env/ d' textx/commands/console.py examples/hello_world/hello.py
%description -n %name-doc
Documentation, tutorial and examples for %name.
%build
%python_build
%install
%python_install
%python_expand %fdupes %{buildroot}%{$python_sitelib}/textx
%check
%python_expand PYTHONPATH=%{buildroot}%{$python_sitelib} py.test-%{$python_version}
find examples/ -name \*.dot | xargs rm # drop indeterministic files (boo#1114571)
%files %{python_files}
%defattr(-,root,root,-)
%{python_sitelib}/*
%python3_only %{_bindir}/textx
%doc AUTHORS.md CHANGELOG.md LICENSE.txt README.rst
%files -n %name-doc
%doc art docs examples
%changelog