]> git.pld-linux.org Git - packages/dmd.git/commitdiff
- disable dynamic linking with libphobos by default (causes symbol clashes between...
authorJakub Bogusz <qboosh@pld-linux.org>
Sat, 22 Mar 2014 13:42:10 +0000 (14:42 +0100)
committerJakub Bogusz <qboosh@pld-linux.org>
Sat, 22 Mar 2014 13:42:10 +0000 (14:42 +0100)
- added tools (rdmd and ddemangle for now)

dmd-system-zlib.patch
dmd.spec

index 273d69dfdf4a1b2ff43875917392775815d2457e..a0aca4f158a2b319fd3333b1262ea34ce3226a6d 100644 (file)
  
  dll : $(ROOT)/libphobos2.so
  
+--- dmd2/tools/posix.mak.orig  2014-02-13 16:09:46.000000000 +0100
++++ dmd2/tools/posix.mak       2014-03-22 10:01:55.092212006 +0100
+@@ -102,7 +102,7 @@
+ #dreadful custom step because of libcurl dmd linking problem (Bugzilla 7044)
+ $(CURL_TOOLS): $(ROOT)/%: %.d
+       $(DMD) -c -of$(@).o $(<)
+-      ($(DMD) -v -of$(@) $(@).o 2>/dev/null | grep '\-Xlinker' | cut -f2- -d' ' ; echo -lcurl  ) | xargs $(CC)
++      ($(DMD) -v -of$(@) $(@).o 2>/dev/null | grep '\-Xlinker' | cut -f2- -d' ' ; echo -lcurl -lz) | xargs $(CC)
+ $(TOOLS) $(DOC_TOOLS): $(ROOT)/%: %.d
+       $(DMD) $(MODEL_FLAG) $(DFLAGS) -of$(@) $(<)
index e604b77448f3376024026b278952e74f1f98198d..2e8f6dad5b9a87184667262ceba5e8a3704a2622 100644 (file)
--- a/dmd.spec
+++ b/dmd.spec
@@ -1,13 +1,19 @@
+#
+# Conditional build:
+%bcond_with    dynamic # dynamic linking with libphobos (doesn't work properly as of 2.065.0)
+#
 Summary:       Digital Mars D compiler
 Summary(pl.UTF-8):     Digital Mars D - kompilator języka D
 Name:          dmd
 Version:       2.065.0
 Release:       1
 # Digital Mars is proprietary license (not redistributable)
-License:       Boost v1.0 (D runtime, Phobos), GPL v1+ or Artistic (compiler frontend), Digital Mars (the rest)
+License:       Boost v1.0 (D runtime, Phobos, tools), GPL v1+ or Artistic (compiler frontend), Digital Mars (the rest)
 Group:         Development/Languages
 Source0:       http://downloads.dlang.org/releases/2014/%{name}.%{version}.zip
 # NoSource0-md5:       a17a699a7e4715658393819e9dc1814a
+Source1:       https://github.com/D-Programming-Language/tools/archive/v%{version}/d-tools-%{version}.tar.gz
+# Source1-md5: d6b0b7a2a6b90a1374202c7582fc38e7
 Patch0:                %{name}-system-zlib.patch
 Patch1:                %{name}-shared.patch
 NoSource:      0
@@ -15,7 +21,11 @@ URL:         http://dlang.org/dmd-linux.html
 BuildRequires: curl-devel
 BuildRequires: libstdc++-devel
 BuildRequires: zlib-devel
+%if %{with dynamic}
 Requires:      %{name}-libs = %{version}-%{release}
+%endif
+# used as linker
+Requires:      gcc
 ExclusiveArch: %{ix86} %{x8664}
 BuildRoot:     %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
 
@@ -55,9 +65,11 @@ Phobos and D-runtime static libraries for D language.
 Biblioteki statyczne Phobos oraz D-runtime dla języka D.
 
 %prep
-%setup -q -n dmd2
+%setup -q -n dmd2 -a1
+%{__mv} tools-%{version} tools
+
 %patch0 -p1
-%patch1 -p1
+%{?with_dynamic:%patch1 -p1}
 
 echo "%{version}" > src/dmd/VERSION
 
@@ -94,9 +106,16 @@ done
        LIBCURL_STUB= \
        PIC="-fPIC"
 
+%{__make} -C tools -f posix.mak \
+       OS=linux \
+       MODEL=%{model} \
+       CC="%{__cc}" \
+       CFLAGS="%{rpmcflags} -m%{model} -fPIC" \
+       DMD="$DMD -I$(pwd)/src/phobos -I$(pwd)/src/druntime -L-L$(pwd)/src/phobos/generated/linux/release/%{model}"
+
 %install
 rm -rf $RPM_BUILD_ROOT
-install -d $RPM_BUILD_ROOT{%{_includedir}/d/dmd/phobos,%{_libdir},%{_sysconfdir},%{_docdir}/dmd}
+install -d $RPM_BUILD_ROOT{%{_includedir}/d/dmd/phobos/etc/c,%{_libdir},%{_sysconfdir},%{_docdir}/dmd}
 
 install -Dp src/dmd/dmd $RPM_BUILD_ROOT%{_bindir}/dmd
 cp -p src/druntime/lib/libdruntime-linux%{model}* $RPM_BUILD_ROOT%{_libdir}
@@ -104,7 +123,9 @@ cp -a src/phobos/generated/linux/release/%{model}/libphobos2.so* $RPM_BUILD_ROOT
 cp -p src/phobos/generated/linux/release/%{model}/libphobos2.a $RPM_BUILD_ROOT%{_libdir}
 cp -pr src/druntime/import $RPM_BUILD_ROOT%{_includedir}/d/dmd/druntime
 cp -pr src/phobos/{std,*.d} $RPM_BUILD_ROOT%{_includedir}/d/dmd/phobos
+cp -p src/phobos/etc/c/*.d $RPM_BUILD_ROOT%{_includedir}/d/dmd/phobos/etc/c
 cp -pr src/druntime/doc $RPM_BUILD_ROOT%{_docdir}/dmd/druntime
+install tools/generated/linux/%{model}/{ddemangle,rdmd} $RPM_BUILD_ROOT%{_bindir}
 install -Dp man/man1/dmd.1 $RPM_BUILD_ROOT%{_mandir}/man1/dmd.1
 install -Dp man/man5/dmd.conf.5 $RPM_BUILD_ROOT%{_mandir}/man5/dmd.conf.5
 
@@ -119,12 +140,21 @@ rm -rf $RPM_BUILD_ROOT
 %post  libs -p /sbin/ldconfig
 %postun        libs -p /sbin/ldconfig
 
+%files libs
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_libdir}/libphobos2.so.*.*.*
+%attr(755,root,root) %ghost %{_libdir}/libphobos2.so.0.65
+
 %files
 %defattr(644,root,root,755)
 %doc README.TXT license.txt dmd-*.txt druntime-*
+%attr(755,root,root) %{_bindir}/ddemangle
 %attr(755,root,root) %{_bindir}/dmd
+%attr(755,root,root) %{_bindir}/rdmd
+%if %{with dynamic}
 %attr(755,root,root) %{_libdir}/libphobos2.so
 %attr(755,root,root) %{_libdir}/libdruntime-linux%{model}.so
+%endif
 %{_libdir}/libdruntime-linux%{model}so.a
 %{_libdir}/libdruntime-linux%{model}so.o
 %{_sysconfdir}/dmd.conf
@@ -134,13 +164,10 @@ rm -rf $RPM_BUILD_ROOT
 %{_mandir}/man5/dmd.conf.5*
 %{_docdir}/dmd
 
-%files libs
-%defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libphobos2.so.*.*.*
-%attr(755,root,root) %ghost %{_libdir}/libphobos2.so.0.65
-
+%if %{with dynamic}
 %files static
 %defattr(644,root,root,755)
+%endif
 %{_libdir}/libdruntime-linux%{model}.a
 %{_libdir}/libdruntime-linux%{model}.o
 %{_libdir}/libphobos2.a
This page took 0.090107 seconds and 4 git commands to generate.