# # spec file for package python-jmespath # # Copyright (c) 2017 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 http://bugs.opensuse.org/ # %{?!python_module:%define python_module() python-%{**} python3-%{**}} Name: python-jmespath Version: 0.9.2 Release: 0 Summary: Extract elements from JSON document License: MIT Group: Development/Languages/Python Url: https://github.com/boto/jmespath Source: https://pypi.io/packages/source/j/jmespath/jmespath-%{version}.tar.gz BuildRequires: %{python_module devel} BuildRequires: %{python_module ply >= 3.4} BuildRequires: %{python_module setuptools} BuildRequires: %{python_module simplejson} BuildRequires: python-rpm-macros # Testing BuildRequires: %{python_module nose} %ifpython2 BuildRequires: python-unittest2 %endif Requires: python-base Requires: python-ply >= 3.4 Requires: python-simplejson Requires(post): update-alternatives Requires(preun): update-alternatives %if 0%{?suse_version} > 1110 BuildArch: noarch %endif %python_subpackages %description JMESPath (pronounced "jaymz path") allows you to declaratively specify how to extract elements from a JSON document. For example, given this document: {"foo": {"bar": "baz"}} The jmespath expression foo.bar will return "baz". JMESPath also supports: Referencing elements in a list. Given the data: {"foo": {"bar": ["one", "two"]}} The expression: foo.bar[0] will return "one". You can also reference all the items in a list using the * syntax: {"foo": {"bar": [{"name": "one"}, {"name": "two"}]}} The expression: foo.bar[*].name will return ["one", "two"]. Negative indexing is also supported (-1 refers to the last element in the list). Given the data above, the expression foo.bar[-1].name will return ["two"]. The * can also be used for hash types: {"foo": {"bar": {"name": "one"}, "baz": {"name": "two"}}} The expression: foo.*.name will return ["one", "two"]. %prep %setup -q -n jmespath-%{version} %build %python_build #pushd build/scripts-%{$python_bin_suffix} #mv jp.py jp-%{$python_bin_suffix} #popd #pushd build/scripts-%{py_ver} #mv jp.py jp-%{py_ver} #popd %install %python_install mv %{buildroot}%{_bindir}/jp.py %{buildroot}%{_bindir}/jp %python_clone -a %{buildroot}%{_bindir}/jp %check %python_expand nosetests-%{$python_bin_suffix} tests %post %python_install_alternative jp %postun %python_uninstall_alternative jp %files %{python_files} %defattr(-,root,root,-) %doc LICENSE.txt README.rst %{python_sitelib}/* %python_alternative %{_bindir}/jp %changelog