diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..5a71281 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +/foma-0fa48db.tar.gz diff --git a/README.md b/README.md new file mode 100644 index 0000000..8be6311 --- /dev/null +++ b/README.md @@ -0,0 +1,3 @@ +# foma + +The foma package \ No newline at end of file diff --git a/dead.package b/dead.package deleted file mode 100644 index 5204a84..0000000 --- a/dead.package +++ /dev/null @@ -1 +0,0 @@ -Orphaned for 6+ weeks diff --git a/foma-harden-build.patch b/foma-harden-build.patch new file mode 100644 index 0000000..9a56354 --- /dev/null +++ b/foma-harden-build.patch @@ -0,0 +1,29 @@ +diff -Naur foma-0fa48dbacfe39509577ae6741054be7c05a19aac.orig/foma/Makefile foma-0fa48dbacfe39509577ae6741054be7c05a19aac/foma/Makefile +--- foma-0fa48dbacfe39509577ae6741054be7c05a19aac.orig/foma/Makefile 2015-06-13 19:50:43.000000000 +0300 ++++ foma-0fa48dbacfe39509577ae6741054be7c05a19aac/foma/Makefile 2018-08-05 13:48:07.836080649 +0300 +@@ -23,13 +23,13 @@ + all: libfoma foma flookup cgflookup + + foma: $(FOMAOBJS) $(LIBOBJS) +- $(CC) $(CFLAGS) $(FOMAOBJS) $(LIBOBJS) $(LDFLAGS) -o $@ ++ $(CC) $(CFLAGS) -pie -Wl,-z,now $(FOMAOBJS) $(LIBOBJS) $(LDFLAGS) -o $@ + + flookup: flookup.o libfoma +- $(CC) $(CFLAGS) flookup.o $(FLOOKUPLDFLAGS) -o $@ ++ $(CC) $(CFLAGS) -pie -Wl,-z,now flookup.o $(FLOOKUPLDFLAGS) -o $@ + + cgflookup: cgflookup.o libfoma +- $(CC) $(CFLAGS) cgflookup.o $(FLOOKUPLDFLAGS) -o $@ ++ $(CC) $(CFLAGS) -pie -Wl,-z,now cgflookup.o $(FLOOKUPLDFLAGS) -o $@ + + STATICLIB = libfoma.a + +@@ -68,7 +68,7 @@ + $(SHAREDLIBV): $(LIBOBJS) + $(AR) $(ARFLAGS) $(STATICLIB) $(LIBOBJS) + $(RANLIB) $(STATICLIB) +- $(CC) $(CFLAGS) -shared -Wl,$(DFLAG),$(SHAREDLIBM) -o $(SHAREDLIBV) $(LIBOBJS) $(LDFLAGS) ++ $(CC) $(CFLAGS) -shared -Wl,-z,now,$(DFLAG),$(SHAREDLIBM) -o $(SHAREDLIBV) $(LIBOBJS) $(LDFLAGS) + + install: foma libfoma + -@if [ ! -d $(exec_prefix) ]; then mkdir -p $(exec_prefix); fi diff --git a/foma.spec b/foma.spec new file mode 100644 index 0000000..f6e04e3 --- /dev/null +++ b/foma.spec @@ -0,0 +1,106 @@ +# Upstream changed its licensing to ASL 2.0 after releasing 0.9.18. +# This package uses the relicensed sources, which are as close to 0.9.18 as +# possible. Debian uses the exact same revision. +%global commit0 0fa48dbacfe39509577ae6741054be7c05a19aac +%global shortcommit0 %(c=%{commit0}; echo ${c:0:7}) +%global snapshotdate 20150613 + +%global libname libfoma + +Name: foma +Version: 0.9.18 +Release: 0.5.%{snapshotdate}git%{shortcommit0}%{?dist} +Summary: Xerox-compatible finite-state compiler + +License: ASL 2.0 +URL: https://github.com/mhulden/foma +Source0: https://github.com/mhulden/%{name}/archive/%{commit0}.tar.gz#/%{name}-%{shortcommit0}.tar.gz +Patch0: foma-harden-build.patch + +BuildRequires: gcc zlib-devel readline-devel flex bison +Requires: %{libname}%{?_isa} = %{version}-%{release} + +%description +Foma can be used for constructing finite-state automata and transducers. +It has support for many natural language processing applications such as +producing morphological analyzers. It is sufficiently generic to use for +a large number of purposes in addition to NLP. The foma interface is +similar to the Xerox xfst interface. + +This package includes the foma command line tools. + + +%package -n %{libname} +Summary: The foma C library + +%description -n %{libname} +Foma can be used for constructing finite-state automata and transducers. +It has support for many natural language processing applications such as +producing morphological analyzers. It is sufficiently generic to use for +a large number of purposes in addition to NLP. The foma interface is +similar to the Xerox xfst interface. + +This package includes the foma C library. + + +%package -n %{libname}-devel +Summary: Development files for %{libname} +Requires: %{libname}%{?_isa} = %{version}-%{release} + +%description -n %{libname}-devel +The libfoma-devel package contains libraries and header files for +developing applications that use libfoma. + +%prep +%autosetup -n %{name}-%{commit0} -p1 + + +%build +sed -i '/^CFLAGS/c\CFLAGS = %{optflags} -Wl,--as-needed -D_GNU_SOURCE -std=c99 -fvisibility=hidden -fPIC' foma/Makefile +sed -i '/^LDFLAGS/c\LDFLAGS = -lreadline -lz -ltermcap %{build_ldflags}' foma/Makefile +sed -i '/^FLOOKUPLDFLAGS/c\FLOOKUPLDFLAGS = libfoma.a -lz %{build_ldflags}' foma/Makefile + +cd foma +%make_build + + +%install +sed -i '/^prefix/c\prefix = %{buildroot}%{_prefix}' foma/Makefile +sed -i '/^libdir/c\libdir = %{buildroot}%{_libdir}' foma/Makefile +cd foma +%make_install +# Remove static archive +find %{buildroot} -name '*.a' -exec rm -f {} ';' + + +%files +%{_bindir}/cgflookup +%{_bindir}/flookup +%{_bindir}/foma + +%files -n %{libname} +%license foma/COPYING +%doc foma/README +%{_libdir}/%{libname}.so.0 +%{_libdir}/%{libname}.so.0.9.18 + +%files -n %{libname}-devel +%{_includedir}/*.h +%{_libdir}/%{libname}.so + + +%changelog +* Tue Jan 28 2020 Fedora Release Engineering - 0.9.18-0.5.20150613git0fa48db +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Thu Jul 25 2019 Fedora Release Engineering - 0.9.18-0.4.20150613git0fa48db +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Sun Feb 17 2019 Igor Gnatenko - 0.9.18-0.3.20150613git0fa48db +- Rebuild for readline 8.0 + +* Thu Jan 31 2019 Fedora Release Engineering - 0.9.18-0.2.20150613git0fa48db +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Sun Sep 16 2018 Ville-Pekka Vainio 0.9.18-0.1.20150613git0fa48db +- Initial package. diff --git a/sources b/sources new file mode 100644 index 0000000..9cb713b --- /dev/null +++ b/sources @@ -0,0 +1 @@ +SHA512 (foma-0fa48db.tar.gz) = 664fbd325e59ee3743c0509f82bbb1c608ceb18fb8d0e417bf0be20f29f68e1acd710120d26d4ecd970dc36d1316b486c09c59969c2b3f408a8f8cf9815f81af