# TODO:
-# * add python bcond
-# * package the Emacs and Jedit modes
+# - add python bcond
+# - package the Emacs and Jedit modes
#
# Conditional build:
%bcond_without gcj # use javac instead of GCJ
%bcond_without dotnet # don't build .NET modules
+%bcond_without java # don't build Java at all
#
%{?with_dotnet:%include /usr/lib/rpm/macros.mono}
#
Summary: ANother Tool for Language Recognition
-Summary(pl): Jeszcze jedno narzêdzie do rozpoznawania jêzyka
+Summary(pl.UTF-8): Jeszcze jedno narzędzie do rozpoznawania języka
Name: antlr
-Version: 2.7.6
-Release: 2
+Version: 2.7.7
+Release: 3
License: Public Domain
Group: Development/Tools
Source0: http://www.antlr.org/download/%{name}-%{version}.tar.gz
-# Source0-md5: 17d8bf2e814f0a26631aadbbda8d7324
+# Source0-md5: 01cc9a2a454dd33dcd8c856ec89af090
Patch0: %{name}-DESTDIR.patch
-Patch1: %{name}-csharp.patch
-Patch2: %{name}-utils.patch
URL: http://www.antlr.org/
BuildRequires: autoconf
BuildRequires: automake
%{?with_dotnet:BuildRequires: mono-csharp}
BuildRequires: python
BuildRequires: sed >= 4.0
+%if %{with java}
%if %{with gcj}
BuildRequires: gcc-java >= 5:4.0.0
-BuildRequires: gcc-java-tools >= 5:4.0.0
+BuildRequires: jar
Requires: /usr/bin/gij
%else
BuildRequires: jar
BuildRequires: jdk
-Requires: jre
+Requires: jpackage-utils
+%endif
%endif
Conflicts: pccts < 1.33MR33-6
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
comes with complete source. ANTLR provides excellent support for tree
construction, tree walking, and translation.
-%description -l pl
+%description -l pl.UTF-8
ANTLR (ANother Tool for Language Recognition; poprzednio znane jako
-PCCTS) to narzêdzie jêzykowe dostarczaj±ce szkielet do tworzenia
-programów rozpoznaj±cych jêzyki, kompilatorów, translatorów z opisów
-gramatycznych obejmuj±cych Javê, C# lub C++. ANTLR jest popularne
-poniewa¿ jest ³atwe do zrozumienia, potê¿ne, elastyczne, generuje
-wyj¶cie czytelne dla cz³owieka i jest dostêpne z pe³nymi ¼ród³ami.
-ANTLR ma ¶wietne wsparcie dla tworzenia drzew, przechodzenia po
+PCCTS) to narzędzie językowe dostarczające szkielet do tworzenia
+programów rozpoznających języki, kompilatorów, translatorów z opisów
+gramatycznych obejmujących Javę, C# lub C++. ANTLR jest popularne
+ponieważ jest łatwe do zrozumienia, potężne, elastyczne, generuje
+wyjście czytelne dla człowieka i jest dostępne z pełnymi źródłami.
+ANTLR ma świetne wsparcie dla tworzenia drzew, przechodzenia po
drzewach oraz translacji.
%package -n dotnet-antlr
Summary: .NET support for ANTLR
-Summary(pl): Modu³y jêzyka .NET dla biblioteki ANTLR
+Summary(pl.UTF-8): Moduły języka .NET dla biblioteki ANTLR
Group: Libraries
%description -n dotnet-antlr
.NET support for ANTLR.
-%description -n dotnet-antlr -l pl
-Modu³y jêzyka .NET dla biblioteki ANTLR.
+%description -n dotnet-antlr -l pl.UTF-8
+Moduły języka .NET dla biblioteki ANTLR.
%package -n python-antlr
Summary: Python runtime support for ANTLR-generated parsers
-Summary(pl): Modu³ uruchomieniowy jêzyka Python dla analizatorów ANTLR
+Summary(pl.UTF-8): Moduł uruchomieniowy języka Python dla analizatorów ANTLR
Group: Libraries/Python
%pyrequires_eq python-libs
%description -n python-antlr
Python runtime support for ANTLR-generated parsers.
-%description -n python-antlr -l pl
-Modu³ uruchomieniowy jêzyka Python dla analizatorów wygenerowanych
+%description -n python-antlr -l pl.UTF-8
+Moduł uruchomieniowy języka Python dla analizatorów wygenerowanych
przez ANTLR.
%package examples
Summary: Examples of ANTLR usage
-Summary(pl): Przyk³adowe programy u¿ywaj±ce ANTLR
+Summary(pl.UTF-8): Przykładowe programy używające ANTLR
Group: Development
Requires: %{name} = %{epoch}:%{version}-%{release}
%description examples
Examples of ANTLR usage.
-%description examples -l pl
-Przyk³adowe programy u¿ywaj±ce ANTLR.
+%description examples -l pl.UTF-8
+Przykładowe programy używające ANTLR.
%prep
%setup -q
%patch0 -p1
-%patch1 -p1
-%patch2 -p1
%build
cp -f /usr/share/automake/config.sub scripts
%{__autoconf}
%configure \
- --enable-cxx \
- %{?with_dotnet:--enable-csharp} \
+ %{?with_dotnet:CSHARPC=/usr/bin/mcs --enable-csharp} \
%{!?with_dotnet:--disable-csharp} \
+ --enable-cxx \
%{!?with_gcj:CLASSPATH=`pwd` --with-java=java --with-javac=javac --with-jar=jar} \
- %{?with_gcj:--with-java=gij --with-javac=gcj --with-jar=fastjar}
+ %{!?with_java:--disable-java} \
+ %{?with_gcj:--with-java=gij --with-javac=gcj --with-jar=jar}
+CXXFLAGS="%{rpmcxxflags}" \
%{__make}
%install
%{__make} install \
DESTDIR=$RPM_BUILD_ROOT
+%if %{with java}
install $RPM_BUILD_ROOT%{_datadir}/%{name}-%{version}/antlr.jar \
$RPM_BUILD_ROOT%{_javadir}
+%endif
install $RPM_BUILD_ROOT%{_datadir}/%{name}-%{version}/*.py \
$RPM_BUILD_ROOT%{py_sitescriptdir}/%{name}
cp -Rf examples/{cpp,csharp,java,python} \
%{_includedir}/%{name}
%{_libdir}/libantlr.a
# Dont separate it, antlr binary wont work without it
+%if %{with java}
%{_javadir}/*.jar
+%endif
%if %{with dotnet}
%files -n dotnet-antlr