X-Git-Url: http://git.pld-linux.org/?p=packages%2Ferlang.git;a=blobdiff_plain;f=erlang.spec;h=3f4affc8fdd71a380e39fffa77ed9fbbbee60179;hp=2b1db8cff7c1f02c6bc91545aaefc2adf4d6fb92;hb=fc6fa45cbcb09ad880fc66a4092936ce442271ef;hpb=c7068bd4e37d7d3d4976aeac74e85c8f82301ef4 diff --git a/erlang.spec b/erlang.spec index 2b1db8c..3f4affc 100644 --- a/erlang.spec +++ b/erlang.spec @@ -1,27 +1,66 @@ +# NOTE: Building requires working DNS setup. Build may hang +# even if _only_ first dns specified in resolv.conf +# is unreachable. +# +# Conditional build: +%bcond_with java # with Java support +%bcond_without odbc # without unixODBC support +# Summary: OpenSource Erlang/OTP -Name: otp -Version: R9C_2 -Release: 0.1 +Summary(pl): Erlang/OTP z otwartymi ¼ród³ami +Name: erlang +Version: R10B_10 +Release: 1 Epoch: 1 +%define _version %(echo %{version} | tr _ -) License: distributable Group: Development/Languages -%define _version %(echo %{version} | sed -e 's#_#-#g') -Source0: http://www.erlang.org/download/%{name}_src_%{_version}.tar.gz +Source0: http://www.erlang.org/download/otp_src_%{_version}.tar.gz +# Source0-md5: c1405c885f07d661b7362b822d571586 +Source1: http://www.erlang.org/download/otp_doc_man_R10B-10.tar.gz +# Source1-md5: 207e00bcaf5a9428bd86e3973f9b699f +Patch0: %{name}-fPIC.patch +Patch1: %{name}-optional_java.patch +Patch2: %{name}-hipe_optimistic_regalloc_once_only.patch URL: http://www.erlang.org/ -BuildRequires: perl-base -BuildRequires: flex +%{?with_java:BuildRequires: /usr/bin/jar} BuildRequires: XFree86-devel +BuildRequires: autoconf +BuildRequires: automake +BuildRequires: flex +%{?with_java:BuildRequires: jdk >= 1.2} +BuildRequires: ncurses-devel +BuildRequires: openssl-devel >= 0.9.7 +Buildrequires: openssl-tools +BuildRequires: perl-base +%if %{with odbc} +BuildRequires: unixODBC-devel +%else +BuildConflicts: unixODBC-devel +%endif BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) +%define _erl_target %(echo %{_build} | sed -e's/amd64/x86_64/;s/athlon/i686/;s/ppc/powerpc/') + %description Erlang is a programming language designed at the Ericsson Computer Science Laboratory. Open-source Erlang is being released to help encourage the spread of Erlang outside Ericsson. - + +%description -l pl +Erlang to jêzyk programowania opracowany w Ericsson Computer Science +Laboratory. Open-source Erlang zosta³ wydany, aby pomóc w +rozpowszechnianiu Erlanga poza Ericssonem. + %prep -%setup -q -n %{name}_src_%{_version} +%setup -q -n otp_src_%{_version} +%{__tar} xzf %{SOURCE1} man/ COPYRIGHT +#%patch0 -p1 +%patch1 -p1 +%patch2 -p1 %build +find . -name config.sub | xargs -n 1 cp -f /usr/share/automake/config.sub %{__autoconf} cd lib %{__autoconf} @@ -31,35 +70,93 @@ cd ../gs %{__autoconf} cd ../megaco %{__autoconf} +cd ../odbc +%{__autoconf} cd ../snmp %{__autoconf} -cd .. -cd ../erts/ +cd ../../erts/ %{__autoconf} cd .. -%configure +%configure \ + --with%{!?with_java:out}-java ERL_TOP=`pwd`; export ERL_TOP -%{__make} +LD_ASSUME_KERNEL=2.4.19 %{__make} \ + TARGET="%{_erl_target}" \ + || { find . -name erl_crash.dump | xargs cat ; exit 1 ; } %install rm -rf $RPM_BUILD_ROOT %{__make} install \ - DESTDIR=$RPM_BUILD_ROOT + TARGET="%{_erl_target}" \ + INSTALL_PREFIX=$RPM_BUILD_ROOT -%clean -rm -rf $RPM_BUILD_ROOT +rm -f $RPM_BUILD_ROOT%{_libdir}/%{name}/erts-*/*.html + +sed -i -e"s#$RPM_BUILD_ROOT##" \ + $RPM_BUILD_ROOT%{_libdir}/%{name}/bin/{erl,start,start_erl} -%pre +for l in erl erlc ; do + ln -sf %{_libdir}/%{name}/bin/$l $RPM_BUILD_ROOT%{_bindir} +done +ERTSDIR=`echo $RPM_BUILD_ROOT%{_libdir}/%{name}/erts-* | sed -e"s#^$RPM_BUILD_ROOT##"` +for l in ear ecc elink escript ; do + ln -sf $ERTSDIR/bin/$l $RPM_BUILD_ROOT%{_bindir} +done +ln -sf $ERTSDIR/bin/epmd $RPM_BUILD_ROOT%{_libdir}/%{name}/bin -%post +cp -r man $RPM_BUILD_ROOT%{_libdir}/%{name} +find $RPM_BUILD_ROOT%{_libdir}/%{name}/man -type f | xargs gzip -9 -%preun +# some files in the library need +x, so we build the list here +echo "%%defattr(644,root,root,755)" > lib.list +find $RPM_BUILD_ROOT%{_libdir}/%{name}/lib -type d \ + | sed -e"s#^$RPM_BUILD_ROOT%{_libdir}/%{name}/#%%dir %%{_libdir}/%%{name}/#" >> lib.list +find $RPM_BUILD_ROOT%{_libdir}/%{name}/lib -type f -perm -500 \ + | sed -e"s#^$RPM_BUILD_ROOT%{_libdir}/%{name}/#%%attr(755,root,root) %%{_libdir}/%%{name}/#" >> lib.list +find $RPM_BUILD_ROOT%{_libdir}/%{name}/lib -type f '!' -perm -500 \ + | sed -e"s#^$RPM_BUILD_ROOT%{_libdir}/%{name}/#%%{_libdir}/%%{name}/#" >> lib.list -%postun +rm -rf $RPM_BUILD_ROOT%{_libdir}/%{name}/erts-*/lib/internal +rm -rf $RPM_BUILD_ROOT%{_libdir}/%{name}/erts-*/include/internal + +%clean +rm -rf $RPM_BUILD_ROOT -%files +%files -f lib.list %defattr(644,root,root,755) -%doc AUTHORS CREDITS ChangeLog NEWS README THANKS TODO +%doc AUTHORS EPLICENCE README COPYRIGHT %attr(755,root,root) %{_bindir}/* -%{_datadir}/%{name} +%dir %{_libdir}/erlang +%dir %{_libdir}/%{name}/bin +%attr(755,root,root) %{_libdir}/%{name}/bin/epmd +%attr(755,root,root) %{_libdir}/%{name}/bin/erl +%attr(755,root,root) %{_libdir}/%{name}/bin/erlc +%attr(755,root,root) %{_libdir}/%{name}/bin/run_erl +%attr(755,root,root) %{_libdir}/%{name}/bin/start +%attr(755,root,root) %{_libdir}/%{name}/bin/start_erl +%attr(755,root,root) %{_libdir}/%{name}/bin/to_erl +%{_libdir}/%{name}/bin/start*.* +%dir %{_libdir}/%{name}/erts-* +%{_libdir}/%{name}/erts-*/doc +%{_libdir}/%{name}/erts-*/man +%{_libdir}/%{name}/erts-*/src +%{_libdir}/%{name}/erts-*/include +#%{_libdir}/%{name}/erts-*/*.ear +%dir %{_libdir}/%{name}/erts-*/bin +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/beam* +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/child* +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/e* +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/heart* +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/inet_gethost +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/run_erl +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/start +%attr(755,root,root) %{_libdir}/%{name}/erts-*/bin/to_erl +%{_libdir}/%{name}/erts-*/bin/start*.* +# (file list dynamically generated) %{_libdir}/%{name}/lib +%dir %{_libdir}/%{name}/misc +%attr(755,root,root) %{_libdir}/%{name}/misc/* +%{_libdir}/%{name}/releases +%{_libdir}/%{name}/usr +%doc %{_libdir}/%{name}/man +%attr(755,root,root) %{_libdir}/%{name}/Install