summaryrefslogtreecommitdiff
path: root/src/lib/libast/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libast/Makefile')
-rw-r--r--src/lib/libast/Makefile442
1 files changed, 442 insertions, 0 deletions
diff --git a/src/lib/libast/Makefile b/src/lib/libast/Makefile
new file mode 100644
index 0000000..8dd819a
--- /dev/null
+++ b/src/lib/libast/Makefile
@@ -0,0 +1,442 @@
+/*
+ * ast library
+ */
+
+:PACKAGE: ast
+
+LICENSE = since=1985,author=gsf+dgk+kpv
+
+ID = ast
+
+HOSTTYPE == "$(CC.HOSTTYPE)"
+
+CCFLAGS = $(CC.SUFFIX.DEBUG:+$(CC.DEBUG)) $(CC.OPTIMIZE) $(CC.DLL)
+
+IFFEFLAGS = -v -X ast -X std
+
+.SOURCE : aso cdt comp dir disc hash man misc obsolete path port preroot \
+ regex sfio stdio string tm uwin vec vmalloc
+
+.SOURCE.h : include comp std cdt vmalloc
+
+CP = $(STDCP|"cp")
+
+PARANOID ==
+CONF_LIBPREFIX == "$(CC.PREFIX.DYNAMIC|CC.PREFIX.SHARED)"
+CONF_LIBSUFFIX == "$(CC.SUFFIX.DYNAMIC|CC.SUFFIX.SHARED)"
+DEBUG ==
+__OBSOLETE__ == $("6 months ago":@F=%(%Y0101)T)
+
+HEADERSRC = ast.h ast_dir.h ast_getopt.h ast_std.h \
+ ast_namval.h ast_windows.h \
+ ccode.h cdt.h cdtlib.h cmdarg.h debug.h dt.h error.h find.h ftw.h \
+ ftwalk.h fts.h fs3d.h getopt.h glob.h hash.h hashkey.h hashpart.h \
+ ip6.h lc.h ls.h magic.h mc.h mime.h mnt.h modecanon.h modex.h \
+ namval.h option.h proc.h re_comp.h recfmt.h regex.h regexp.h \
+ sfio.h sfio_s.h sfio_t.h sfdisc.h shcmd.h \
+ stack.h stak.h stk.h swap.h tar.h times.h tm.h tok.h \
+ usage.h vdb.h vecargs.h vmalloc.h wait.h wordexp.h \
+ bytesex.h endian.h fnmatch.h magicid.h fnv.h aso.h \
+ $(HEADERSTD)
+
+HEADERGEN = align.h preroot.h sig.h tmx.h tv.h \
+ $(ID)_api.h $(ID)_botch.h $(ID)_ccode.h $(ID)_fcntl.h $(ID)_float.h \
+ $(ID)_fs.h $(ID)_lib.h $(ID)_map.h $(ID)_mmap.h $(ID)_mode.h $(ID)_ndbm.h \
+ $(ID)_param.h $(ID)_sys.h $(ID)_time.h $(ID)_time.h $(ID)_tty.h \
+ $(ID)_vfork.h $(ID)_wait.h $(ID)_limits.h $(ID)_standards.h $(ID)_sizeof.h \
+ $(HEADERSTD:/^/$(ID)_/)
+
+HEADEREXP = $(ID)_common.h
+
+HEADEROPT = fmtmsg.h libgen.h syslog.h
+
+HEADERSTD = dirent.h iconv.h nl_types.h stdio.h wchar.h wctype.h
+
+$(ID) 5.4 :LIBRARY: README RELEASE \
+ LIBAST.3 aso.3 ast.3 astsa.3 cdt.3 chr.3 compat.3 error.3 \
+ find.3 fmt.3 fmtls.3 fs3d.3 ftwalk.3 getcwd.3 hash.3 iblocks.3 \
+ int.3 ip6.3 magic.3 mem.3 mime.3 modecanon.3 optget.3 path.3 \
+ preroot.3 proc.3 re.3 regex.3 setenviron.3 sfdisc.3 sfio.3 \
+ sig.3 spawnveg.3 stak.3 stk.3 strcopy.3 strdup.3 strelapsed.3 \
+ strerror.3 stresc.3 streval.3 strgid.3 strmatch.3 stropt.3 \
+ strperm.3 strsignal.3 strsort.3 strtape.3 strton.3 struid.3 \
+ swap.3 tab.3 tm.3 tmx.3 tok.3 touch.3 tv.3 vecargs.3 vmalloc.3 \
+ $(HEADERSRC) \
+ state.c transition.c \
+ dirlib.h opendir.c readdir.c rewinddir.c seekdir.c telldir.c \
+ getcwd.c fastfind.c \
+ hashlib.h hashalloc.c hashdump.c hashfree.c hashlast.c \
+ hashlook.c hashscan.c hashsize.c hashview.c hashwalk.c \
+ memhash.c memsum.c strhash.c strkey.c strsum.c \
+ stracmp.c strnacmp.c \
+ ccmap.c ccmapid.c ccnative.c \
+ chresc.c chrtoi.c streval.c strexpr.c strmatch.c strcopy.c \
+ modelib.h modei.c modex.c strmode.c \
+ strlcat.c strlcpy.c strlook.c strncopy.c strsearch.c strpsearch.c \
+ stresc.c stropt.c strtape.c strpcmp.c strnpcmp.c strvcmp.c strnvcmp.c \
+ tok.c tokline.c tokscan.c \
+ pathaccess.c pathcat.c pathcanon.c pathcheck.c pathpath.c \
+ pathexists.c pathfind.c pathkey.c pathprobe.c pathrepl.c \
+ pathnative.c pathposix.c pathtemp.c pathtmp.c pathstat.c \
+ pathgetlink.c pathsetlink.c pathbin.c pathshell.c pathcd.c \
+ pathprog.c \
+ fs3d.c ftwalk.c ftwflags.c fts.c \
+ astintercept.c conformance.c getenv.c setenviron.c \
+ optget.c optjoin.c optesc.c optctx.c strsort.c struniq.c \
+ magic.c mime.c mimetype.c signal.c sigflag.c systrace.c \
+ error.c errorf.c errormsg.c errorx.c \
+ localeconv.c setlocale.c translate.c \
+ catopen.c iconv.c lc.c lctab.c mc.c \
+ base64.c recfmt.c recstr.c reclen.c fmtrec.c \
+ fmtbase.c fmtbuf.c fmtclock.c fmtdev.c fmtelapsed.c fmterror.c \
+ fmtesc.c fmtfmt.c fmtfs.c fmtident.c fmtint.c fmtip4.c fmtip6.c fmtls.c \
+ fmtmatch.c fmtmode.c fmtnum.c fmtperm.c fmtre.c fmttime.c fmtuid.c \
+ fmtgid.c fmtsignal.c fmtscale.c fmttmx.c fmttv.c fmtversion.c \
+ strelapsed.c strperm.c struid.c strgid.c \
+ strtoip4.c strtoip6.c stack.c stk.c \
+ swapget.c swapmem.c swapop.c swapput.c \
+ sigdata.c sigcrit.c sigunblock.c \
+ proclib.h procopen.c procclose.c procrun.c procfree.c \
+ tmdate.c tmequiv.c tmfix.c tmfmt.c tmform.c tmgoff.c tminit.c \
+ tmleap.c tmlex.c tmlocale.c tmmake.c tmpoff.c tmscan.c \
+ tmsleep.c tmtime.c tmtype.c tmweek.c tmword.c tmzone.c \
+ tmxdate.c tmxduration.c tmxfmt.c tmxgettime.c tmxleap.c tmxmake.c \
+ tmxscan.c tmxsettime.c tmxsleep.c tmxtime.c tmxtouch.c \
+ tvcmp.c tvgettime.c tvsettime.c tvsleep.c tvtouch.c \
+ cmdarg.c vecargs.c vecfile.c vecfree.c vecload.c vecstring.c \
+ univlib.h univdata.c touch.c mnt.c debug.c \
+ memccpy.c memchr.c memcmp.c memcpy.c memdup.c memmove.c memset.c \
+ mkdir.c mkfifo.c mknod.c rmdir.c remove.c rename.c link.c unlink.c \
+ strdup.c strchr.c strrchr.c strstr.c \
+ strtod.c strtold.c \
+ strtol.c strtoll.c strtoul.c strtoull.c strton.c strtonll.c \
+ strntod.c strntold.c strnton.c strntonll.c \
+ strntol.c strntoll.c strntoul.c strntoull.c \
+ strcasecmp.c strncasecmp.c strerror.c \
+ mktemp.c tmpnam.c fsync.c \
+ execlp.c execve.c execvp.c execvpe.c spawnveg.c \
+ vfork.c killpg.c \
+ hsearch.c tsearch.c \
+ getlogin.c putenv.c setenv.c unsetenv.c \
+ lstat.c statvfs.c \
+ eaccess.c gross.c gross_sgi.h omitted.c \
+ fakelink.h readlink.c symlink.c \
+ getpgrp.c setpgid.c setsid.c waitpid.c \
+ creat64.c fcntl.c open.c \
+ atexit.c getdents.c getwd.c dup2.c errno.c \
+ getpreroot.c ispreroot.c realopen.c setpreroot.c \
+ getgroups.c mount.c system.c iblocks.c \
+ modedata.c tmdata.c \
+ memfatal.c sfkeyprintf.c \
+ sfdcdio.c sfdcdos.c sfdcfilter.c sfdcseekable.c \
+ sfdcslow.c sfdcsubstr.c sfdctee.c sfdcunion.c \
+ sfdcmore.c sfdcprefix.c \
+ wc.c wc2utf8.c \
+ /* standards */ \
+ basename.c closelog.c dirname.c fmtmsglib.c fnmatch.c ftw.c \
+ getdate.c getsubopt.c glob.c nftw.c openlog.c re_comp.c \
+ resolvepath.c realpath.c regcmp.c regexp.c setlogmask.c strftime.c \
+ strptime.c swab.c syslog.c sysloglib.h tempnam.c \
+ wordexp.c mktime.c \
+ /* regex */ \
+ reglib.h regalloc.c regclass.c regcoll.c regcomp.c regcache.c \
+ regdecomp.c regerror.c regexec.c regfatal.c reginit.c regnexec.c \
+ regsubcomp.c regsubexec.c regsub.c regrecord.c regrexec.c regstat.c \
+ /* cdt */ \
+ dthdr.h dtclose.c dtdisc.c dthash.c dtlist.c dtmethod.c \
+ dtopen.c dtstrhash.c dttree.c dtview.c dtwalk.c \
+ dtnew.c dtcomp.c \
+ /* sfio */ \
+ sfhdr.h sfdchdr.h \
+ sfclose.c sfclrlock.c sfdisc.c sfdlen.c sfexcept.c \
+ sfgetl.c sfgetu.c sfcvt.c sfecvt.c sffcvt.c \
+ sfextern.c sffilbuf.c sfflsbuf.c sfprints.c sfgetd.c \
+ sfgetr.c sfllen.c sfmode.c sfmove.c sfnew.c \
+ sfpkrd.c sfnotify.c sfnputc.c sfopen.c sfpeek.c sfpoll.c \
+ sfpool.c sfpopen.c sfprintf.c sfputd.c sfputl.c sfputr.c \
+ sfputu.c sfrd.c sfread.c sfreserve.c sfscanf.c sfseek.c sfset.c \
+ sfsetbuf.c sfsetfd.c sfsize.c sfsk.c sfstack.c sfstrtod.c sfsync.c \
+ sfswap.c sftable.c sftell.c sftmp.c sfungetc.c sfvprintf.c \
+ sfvscanf.c sfwr.c sfwrite.c sfpurge.c sfraise.c sfwalk.c \
+ sfgetm.c sfmutex.c sfputm.c sfresize.c \
+ _sfclrerr.c _sfeof.c _sferror.c _sffileno.c \
+ _sfopen.c _sfstacked.c _sfvalue.c \
+ _sfgetc.c _sfgetl.c _sfgetl2.c _sfgetu.c _sfgetu2.c \
+ _sfdlen.c _sfllen.c _sfslen.c _sfulen.c \
+ _sfputc.c _sfputd.c _sfputl.c _sfputm.c _sfputu.c \
+ /* stdio */ \
+ clearerr.c fclose.c fdopen.c feof.c ferror.c fflush.c \
+ fgetc.c fgetpos.c fgets.c fileno.c fopen.c fprintf.c \
+ fpurge.c fputc.c fputs.c fread.c freopen.c fscanf.c \
+ fseek.c fseeko.c fsetpos.c ftell.c ftello.c fwrite.c \
+ flockfile.c ftrylockfile.c funlockfile.c \
+ getc.c getchar.c getw.c pclose.c popen.c printf.c \
+ putc.c putchar.c puts.c putw.c rewind.c scanf.c \
+ setbuf.c setbuffer.c setlinebuf.c setvbuf.c \
+ snprintf.c sprintf.c sscanf.c \
+ asprintf.c vasprintf.c \
+ stdio/tmpfile.c ungetc.c vfprintf.c vfscanf.c vprintf.c \
+ vscanf.c vsnprintf.c vsprintf.c vsscanf.c \
+ _doprnt.c _doscan.c _filbuf.c _flsbuf.c _stdfun.c \
+ _stdopen.c _stdprintf.c _stdscanf.c _stdsprnt.c \
+ _stdvbuf.c _stdvsnprnt.c _stdvsprnt.c _stdvsscn.c \
+ /* wchar stdio */ \
+ fgetwc.c fwprintf.c putwchar.c vfwscanf.c wprintf.c \
+ fgetws.c fwscanf.c swprintf.c vswprintf.c wscanf.c \
+ fputwc.c getwc.c swscanf.c vswscanf.c \
+ fputws.c getwchar.c ungetwc.c vwprintf.c \
+ fwide.c putwc.c vfwprintf.c vwscanf.c \
+ /* stdio extensions */ \
+ stdio_c99.c fcloseall.c fmemopen.c getdelim.c getline.c \
+ /* math */ \
+ frexp.c frexpl.c \
+ /* ast */ \
+ astcopy.c astconf.c astdynamic.c astlicense.c astquery.c astwinsize.c \
+ conftab.c \
+ $(CC.LD.STATIC) aststatic.c getopt.c getoptl.c $(CC.LD.DYNAMIC) \
+ /* aso */ \
+ aso.c asolock.c asometh.c asorelax.c aso-sem.c aso-fcntl.c \
+ /* vmalloc */ \
+ vmalloc.h vmhdr.h vmbest.c vmclear.c vmclose.c vmdcheap.c vmdebug.c \
+ vmdisc.c vmexit.c vmlast.c vmopen.c vmpool.c vmprivate.c vmprofile.c \
+ vmregion.c vmsegment.c vmset.c vmstat.c vmstrdup.c vmtrace.c vmwalk.c \
+ vmmopen.c malloc.c vmgetmem.c \
+ /* uwin */ \
+ mathimpl.h rlib.h \
+ a64l.c acosh.c asinh.c atanh.c cbrt.c crypt.c erf.c \
+ err.c exp.c exp__E.c expm1.c gamma.c getpass.c lgamma.c log.c log1p.c \
+ log__L.c rand48.c random.c rcmd.c rint.c support.c \
+ /* obsolete */ \
+ sfstrtmp.c spawn.c \
+ -liconv -lw /* these should be pulled in by -lc */
+
+/*
+ * man is stdio.h problematic
+ * the std/stdio.h => ast_stdio.h runaround should
+ * get to a steady state
+ *
+ * also, -D_BLD_ast must be explicit for the uwin bootstrap
+ */
+
+.MAKEINIT : .AST.INIT
+.AST.INIT : .MAKE
+ CCFLAGS += -D_BLD_ast
+
+parameter (_BLD_ast)
+virtual ast/stdio.h
+
+ :NOPROTECT: sfprintf.c sfvprintf.c sfscanf.c sfvscanf.c
+
+ :NOOPTIMIZE: spawnveg.c
+"ibm.risc" :NOOPTIMIZE: regcomp.c
+"linux.i386-64*":NOOPTIMIZE: sfset.c
+"sol?.*" :NOOPTIMIZE: sfrd.c sfvprintf.c tmxfmt.c
+"win32*" :NOOPTIMIZE: fastfind.c mc.c
+
+/*
+ * NOTE: sun4 runtime link botches ro data so advertised sig_info is rw
+ */
+
+:READONLY: conftab.c lctab.c modedata.c /*sftable.c*/ \
+ /*sigdata.c*/ tmdata.c univdata.c
+
+:: atmain.C \
+ stdgets.c stdprintf.c stdscanf.c stdvbuf.c stdsprnt.c \
+ stdvsprnt.c stdvsnprnt.c stdvsscn.c stdopen.c \
+ astsa
+
+if "$(PWD:B)" != "cc-*"
+
+$(INCLUDEDIR) :INSTALLPROTO: $(HEADEREXP) $(HEADERSRC) $(HEADERGEN)
+
+:INSTALLDIR: conf
+
+conf :: conf.sh
+
+conflim.h conftab.h conftab.c :JOINT: conf conf.tab
+ $(*:O=1:P=A) $(IFFEFLAGS:V:N=-v) $(*:O>1) $(CC) $(CCFLAGS:VP:N!=-D_BLD_*|$\(*\)) /* 2007-07-01: $(CCFLAGS:VPX:N!=-D_BLD_*) */
+
+$(HEADERGEN) :COPY: FEATURE/$$(<:B:/$(ID)_//)
+
+ast_namval.h :COPY: namval.h
+
+lcgen : lcgen.c
+ $(CC.NATIVE|CC) -o $(<) $(*)
+
+lc.h lctab.c :JOINT: lcgen lc.tab
+ $(*:O=1:C,^[^/],./&,) $(tmp).1 $(tmp).2 < $(*:O=2) # :P=E: in 2006
+ $(PROTO) -p $(PROTOFLAGS) $(tmp).1 $(PROTOINSTALL) > $(tmp).3
+ $(RM) -f $(tmp).1
+ if $(CMP) -s $(tmp).3 $(<:O=1)
+ then $(RM) $(tmp).3
+ else $(MV) $(tmp).3 $(<:O=1)
+ fi
+ if $(CMP) -s $(tmp).2 $(<:O=2)
+ then $(RM) $(tmp).2
+ else $(MV) $(tmp).2 $(<:O=2)
+ fi
+
+$(LIBDIR)/file/magic :INSTALL: magic.tab
+
+:INSTALL: $(HEADEROPT:D=$(INCLUDEDIR):B:S)
+
+$(HEADEROPT:D=$(INCLUDEDIR):B:S) : $$(<:B:S) ast_lib.h
+ case $(CC.HOSTTYPE) in
+ win32.*)$(PROTO) -p $(PROTOFLAGS) $(*:O=1) $(PROTOINSTALL) > 1.$(tmp).x
+ if $(CMP) -s $(<) 1.$(tmp).x
+ then $(RM) -f 1.$(tmp).x
+ else $(MV) 1.$(tmp).x $(<)
+ fi
+ ;;
+ *) $(SILENT) $(GREP) -l 'define[ ][ ]*_[hl][di][rb]_$(<:B)' $(*:O>1) > /dev/null || {
+ $(PROTO) -p $(PROTOFLAGS) $(*:O=1) $(PROTOINSTALL) > 1.$(tmp).x
+ if $(CMP) -s $(<) 1.$(tmp).x
+ then $(RM) -f 1.$(tmp).x
+ else $(MV) 1.$(tmp).x $(<)
+ fi
+ }
+ ;;
+ esac
+
+/* a few headers are problematic */
+
+$(INCLUDEDIR)/prototyped.h :INSTALL: $(INCLUDEDIR)
+ echo "#include <../prototyped.h>" > 1.$(tmp).x
+ if $(CMP) -s $(<) 1.$(tmp).x
+ then $(RM) -f 1.$(tmp).x
+ else $(MV) 1.$(tmp).x $(<)
+ fi
+
+/*
+ * FEATURE/common for iffe probes, <ast_common.h> for ast source
+ * *but* <ast_common.h> may get pulled in by intercepted headers
+ * so both must be built very early
+ */
+
+$(ID)_common.h : .SCAN.IGNORE FEATURE/common
+ $(SED) '/define _def_map_ast/d' < $(*) > 1.$(tmp).x
+ if $(CMP) -s $(<) 1.$(tmp).x
+ then $(RM) -f 1.$(tmp).x
+ else $(MV) 1.$(tmp).x $(<)
+ fi
+
+FEATURE/common : .SCAN.IGNORE
+
+/*
+ * more stdio.h complications ...
+ * prepare for compilation by generating these headers first;
+ * this helps mam by catching headers that might be indirectly
+ * included on other systems
+ */
+
+.check.hdr : .IGNORE .VIRTUAL \
+ FEATURE/standards - FEATURE/lib - FEATURE/common - \
+ FEATURE/param - FEATURE/aso - \
+ ast_map.h - ast_limits.h - ast_stdio.h ast_nl_types.h - \
+ ast_wchar.h ast_wctype.h
+ : clean up obsolete headers :
+ $(RM) -rf $(HEADERSTD) ast_hdr.h ast_types.h ast_unistd.h iffeio.h \
+ $(INCLUDEDIR)/limits.h $(INCLUDEDIR)/unistd.h \
+ $(PACKAGEROOT)/src/lib/libast/std/limits.h
+
+ast.req : .check.hdr .check.lib
+
+else
+
+ast.req : .check.lib
+
+end
+
+/*
+ * some systems move -lc routines to -lm
+ * see astmath.c for details
+ */
+
+.check.lib : .AFTER astmath.exe FEATURE/aso
+ $(SED) -e '/^#define _REQ_/!d' -e 's/#define _REQ_\([a-z0-9_]*\).*/ -l\1/' $(*:N=FEATURE/*) >> $(<<)
+ if test -f astmath.exe
+ then touch $(<<)
+ else echo ' -lm' >> $(<<)
+ fi
+
+astmath.exe : .DONTCARE astmath.c
+ X=1
+ for N in 1 2 3 4 5 6 8
+ do if $(CC) -DN=$N -DIS $(CCFLAGS) -o $(*:N=*.c:B:S=.exe) $(*) 2>/dev/null
+ then : implicit math function N=$N :
+ elif $(CC) -DN=$N -DIS $(CCFLAGS) -o $(*:N=*.c:B:S=.exe) $(*) -lm 2>/dev/null
+ then : math function N=$N requires -lm :
+ X=0
+ break
+ fi
+ done
+ case $X in
+ 0) $(RM) -f $(*:N=*.c:B:S=.exe) ;;
+ *) touch $(*:N=*.c:B:S=.exe) ;;
+ esac
+ $(RM) -f $(*:N=*.c:B:S=$(CC.SUFFIX.OBJECT))
+
+/*
+ * atmain.C is the only C++ and only for a few systems
+ */
+
+atmain.o : atmain.C
+ ignore $(CC) -c $(CCFLAGS) $(*)
+ if test ! -f $(<)
+ then $(CP) $(*) $(*:B:S=.cpp)
+ ignore $(CC) -c $(CCFLAGS) $(*:B:S=.cpp)
+ if test ! -f $(<)
+ then $(CP) $(*) $(*:B:S=.c)
+ $(CC) -c $(CCFLAGS) $(*:B:S=.c)
+ fi
+ fi
+
+/* astsa is a standalone subset of ast for imbedded applications */
+
+PAXFILTER = ;*.[ch];$(PROTO) $(PROTOFLAGS) -c "" -p
+
+ast_sa.h : .DONTCARE
+
+astsa.tgz : $$("astsa/astsa.manifest":T=F:T=I:/[[:space:]][[:space:]]*/ /G:C,^,astsa/,)
+ $(PAX) $(PAXFLAGS) -wf $(<) -x $(<:/.*\.//) -s ',.*/,,' -A $(PAXFILTER:@Q) $(*)
+
+/* libmini.a is a bootstrap dll for uwin cc -D_BLD_ast that exports part of ast */
+
+MINI = mini
+
+:: $(MINI).sym
+
+if CC.HOSTTYPE == "win32*"
+
+DLL = $(ID)$(VERSION:/[^0-9]//G)
+
+$(MINI) : $(MINI)$$(CC.SUFFIX.SHARED)
+
+$(MINI)$$(CC.SUFFIX.SHARED) : $(MINI).sym $(ID)
+ $(RM) -rf $(MINI).tmp
+ mkdir $(MINI).tmp
+ {
+ echo LIBRARY $(DLL:F=%(upper)s)
+ echo
+ echo SECTIONS
+ echo .data READ WRITE
+ echo
+ echo EXPORTS
+ cat $(*:N=*.sym)
+ } > $(MINI).tmp/$(DLL)$(CC.SUFFIX.LD:O=1)
+ cd $(MINI).tmp
+ $(LD) $(CCFLAGS:N=-[gG]*) $(CC.SHARED) -o $(DLL) $(DLL)$(CC.SUFFIX.LD:O=1) $(*$(ID).so/$(DLL)$(CC.SUFFIX.DYNAMIC):C,^[^-],../&,)
+ cd ..
+ $(MV) $(MINI).tmp/$(DLL)$(CC.SUFFIX.SHARED) $(<)
+ $(RM) -rf $(MINI).tmp
+
+end
+
+:MSGKEY: misc/magic.tab
+ $(SED) \
+ -e '/^#/d' \
+ -e '/[^ ]* *[^ ]* *[^ ]* *./!d' \
+ -e 's,^[^ ]* *[^ ]* *[^ ]* *\(.[^ ]*\).*$,\1,' \
+ -e 's,[\\"],\\&,g' \
+ -e 's,.*,"&",' \
+ $(*)