X-Git-Url: http://git.pld-linux.org/gitweb.cgi?a=blobdiff_plain;f=mksh.spec;h=7da415bc7d3ba4a8ea2d0fd11ecd43721bf7a5ef;hb=53554a181573004105e6cbbb74c8c284fb949795;hp=b12f8457d6a54583907f515d30855c5150cd10f4;hpb=246a15d9f7b2347b64ba6b4fd6174ec0e408752c;p=packages%2Fmksh.git diff --git a/mksh.spec b/mksh.spec index b12f845..7da415b 100644 --- a/mksh.spec +++ b/mksh.spec @@ -1,16 +1,31 @@ +%bcond_without static +%bcond_without tests +# Summary: MirBSD Korn Shell Summary(pl.UTF-8): Powłoka Korna z MirBSD Name: mksh -Version: 31d -Release: 0.1 +Version: 40 +Release: 1.1 License: BSD Group: Applications/Shells Source0: http://www.mirbsd.org/MirOS/dist/mir/mksh/%{name}-R%{version}.cpio.gz -# Source0-md5: a7c77428bd2b887c1583095a00c84aac -Source1: http://www.mirbsd.org/MirOS/dist/hosted/other/arc4random.c -URL: http://mirbsd.de/mksh +# Source0-md5: 395a6c5f39c7e2afd8f6504d90ca90bd +Source1: %{name}-mkshrc +Patch0: %{name}-mkshrc_support.patch +Patch1: %{name}-circumflex.patch +Patch2: %{name}-no_stop_alias.patch +Patch3: %{name}-tty.patch +URL: https://www.mirbsd.org/mksh.htm +%if %{with tests} +BuildRequires: ed +BuildRequires: perl-base +%endif +%{?with_static:BuildRequires: glibc-static} +BuildRequires: rpmbuild(macros) >= 1.462 +# is needed for /etc directory existence Requires(pre): FHS Requires: setup >= 2.4.6-2 +Obsoletes: pdksh BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _bindir /bin @@ -39,55 +54,96 @@ emacsa; $PS1 odpowiada temu z ksh obecnym w OpenBSD 4.2-current; wykonanym uproszczeniom kodu, poprawkom i rozszerzeniom powłoka ma rozszerzoną kompatybilność z innymi współczesnymi powłokami. +%package static +Summary: Statically linked the MirBSD enhanced version of pdksh +Summary(pl.UTF-8): Skonsolidowana statycznie powłoka mksh +Group: Applications/Shells +# requires base for /etc/mkshrc? +Requires: %{name} = %{version}-%{release} + +%description static +mksh is the MirBSD enhanced version of the Public Domain Korn shell +(pdksh), a Bourne-compatible shell which is largely similar to the +original AT&T Korn shell. + +This packege contains statically linked version of mksh. + +%description static -l pl.UTF-8 +mksh to pochodząca z MirBSD rozszerzona wersja powłoki Public Domain +Korn Shell (pdksh) - kompatybilnej z powłoką Bourne'a, w większości +zbliżonej do oryginalnej powłoki Korna z AT&T. + +W tym pakiecie jest mksh skonsolidowany statycznie. + %prep %setup -qcT gzip -dc %{SOURCE0} | cpio -mid -mv mksh/* ./ -rm -rf mksh -cp %{SOURCE1} . +mv mksh/* .; rmdir mksh + +%patch0 -p0 +%patch1 -p1 +%patch2 -p1 +%patch3 -p1 %build -CC="%{__cc}" CFLAGS="%{rpmcflags}" sh ./Build.sh -Q -r -j -./test.sh -v +install -d out + +CC="%{__cc}" \ +CFLAGS="%{rpmcppflags} %{rpmcflags}" \ +LDFLAGS="%{rpmldflags}" \ +sh ./Build.sh -Q -r -j + +%{?with_tests:./test.sh -v} +mv mksh out/mksh.dynamic + +%if %{with static} +CC="%{__cc}" \ +CFLAGS="%{rpmcppflags} %{rpmcflags}" \ +LDFLAGS="%{rpmldflags} -static" \ +sh ./Build.sh -Q -r -j + +%{?with_tests:./test.sh -v} +mv mksh out/mksh.static +%endif %install rm -rf $RPM_BUILD_ROOT -install -D mksh $RPM_BUILD_ROOT%{_bindir}/mksh -install -D mksh.1 $RPM_BUILD_ROOT%{_mandir}/man1/mksh.1 +install -d $RPM_BUILD_ROOT{%{_bindir},%{_mandir}/man1} +install -p out/mksh.dynamic $RPM_BUILD_ROOT%{_bindir}/mksh +%{?with_static:install -p out/mksh.static $RPM_BUILD_ROOT%{_bindir}/mksh.static} + +cp -a mksh.1 $RPM_BUILD_ROOT%{_mandir}/man1/mksh.1 +echo ".so mksh.1" > $RPM_BUILD_ROOT%{_mandir}/man1/sh.1 + +install -D %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/mkshrc +ln -sf mksh $RPM_BUILD_ROOT%{_bindir}/sh + +# some pdksh scripts used that +ln -sf mksh $RPM_BUILD_ROOT%{_bindir}/ksh %clean rm -rf $RPM_BUILD_ROOT -%post -p -t = {} -f = io.open("/etc/shells", "r") -if f then - for l in f:lines() do t[l]=l; end - f:close() -end -for _, s in ipairs({"/bin/mksh"}) do - if not t[s] then - f = io.open("/etc/shells", "a"); f:write(s.."\n"); f:close() - end -end - -%preun -p -if arg[2] == "0" then - f = io.open("/etc/shells", "r") - if f then - s="" - for l in f:lines() do - if not string.match(l,"^/bin/mksh$") then - s=s..l.."\n" - end - end - f:close() - io.open("/etc/shells", "w"):write(s) - end -end +%post -p %add_etc_shells -p /bin/sh /bin/mksh +%preun -p %remove_etc_shells -p /bin/sh /bin/mksh + +%posttrans -p %add_etc_shells -p /bin/sh + +%post static -p %add_etc_shells -p /bin/mksh.static +%preun static -p %remove_etc_shells -p /bin/mksh.static %files %defattr(644,root,root,755) %doc dot.mkshrc +%config(noreplace,missingok) %verify(not md5 mtime size) %{_sysconfdir}/mkshrc %attr(755,root,root) %{_bindir}/mksh -%{_mandir}/man1/* +%attr(755,root,root) %{_bindir}/ksh +%attr(755,root,root) %{_bindir}/sh +%{_mandir}/man1/mksh.1* +%{_mandir}/man1/sh.1* + +%if %{with static} +%files static +%defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/mksh.static +%endif