]> git.pld-linux.org Git - packages/erlang.git/blobdiff - erlang.spec
- more todo
[packages/erlang.git] / erlang.spec
index 693807d7afbcabdb05c9a9f7d7a1d99d35462cbd..717fd1a9bf4fb574c9060063e643ddc5986acedb 100644 (file)
@@ -1,27 +1,70 @@
+# NOTE: Building requires working DNS setup. Build may hang
+#       even if _only_ first dns specified in resolv.conf
+#       is unreachable.
+# TODO
+# - separate -devel (at least header files!)
+# - modularize (odbc, etc)
+# - manuals to %{_mandir}
+#
+# 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:       R11B_0
+Release:       1
 Epoch:         1
+%define                _version        %(echo %{version} | tr _ -)
 License:       distributable
 Group:         Development/Languages
-%define                _version        %(echo %{version} | tr _ -) 
-Source0:       http://www.erlang.org/download/%{name}_src_%{_version}.tar.gz
+Source0:       http://www.erlang.org/download/otp_src_%{_version}.tar.gz
+# Source0-md5: 367d9d3ba979cd278b78d6d0393982ba
+Source1:       http://www.erlang.org/download/otp_doc_man_R11B-0.tar.gz
+# Source1-md5: 172591538db42e81b814a77f30da4fa4
+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
+%{?with_java:BuildRequires:    /usr/bin/jar}
+BuildRequires: xorg-lib-libX11-devel
+BuildRequires: autoconf
+BuildRequires: automake
 BuildRequires: flex
-BuildRequires: XFree86-devel
+%{?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 +74,95 @@ 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}
+ %{__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 dialyzer epmd run_erl to_erl ; 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
+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/dialyzer
+%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/dialyzer
+%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
This page took 0.061318 seconds and 4 git commands to generate.