|
Packit |
b099d7 |
XCOMM $XConsortium: sv4Lib.rules /main/18 1996/09/28 16:13:29 rws $
|
|
Packit |
b099d7 |
XCOMM $XFree86: xc/config/cf/sv4Lib.rules,v 3.4 1996/12/23 05:50:34 dawes Exp $
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
/*
|
|
Packit |
b099d7 |
* SVR4 shared library rules
|
|
Packit |
b099d7 |
*/
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#ifndef HasSharedLibraries
|
|
Packit |
b099d7 |
# define HasSharedLibraries YES
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef SharedDataSeparation
|
|
Packit |
b099d7 |
# define SharedDataSeparation NO
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef SharedCodeDef
|
|
Packit |
b099d7 |
# define SharedCodeDef /**/
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef SharedLibraryDef
|
|
Packit |
b099d7 |
# define SharedLibraryDef /**/
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef ShLibIncludeFile
|
|
Packit |
b099d7 |
# define ShLibIncludeFile <sv4Lib.tmpl>
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef SharedLibraryLoadFlags
|
|
Packit |
b099d7 |
# define SharedLibraryLoadFlags -G -z text
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef PositionIndependentCFlags
|
|
Packit |
b099d7 |
# if HasGcc2
|
|
Packit |
b099d7 |
# define PositionIndependentCFlags -fpic
|
|
Packit |
b099d7 |
# else
|
|
Packit |
b099d7 |
# define PositionIndependentCFlags -K PIC
|
|
Packit |
b099d7 |
# endif
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef PositionIndependentCplusplusFlags
|
|
Packit |
b099d7 |
# if HasGcc2ForCplusplus
|
|
Packit |
b099d7 |
# define PositionIndependentCplusplusFlags -fpic
|
|
Packit |
b099d7 |
# else
|
|
Packit |
b099d7 |
# define PositionIndependentCplusplusFlags -K PIC
|
|
Packit |
b099d7 |
# endif
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
#ifndef UseExportLists
|
|
Packit |
b099d7 |
# define UseExportLists NO
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
/*
|
|
Packit |
b099d7 |
* InstallSharedLibrary - generate rules to install the shared library.
|
|
Packit |
b099d7 |
*/
|
|
Packit |
b099d7 |
#ifndef InstallSharedLibrary
|
|
Packit |
b099d7 |
#if StripInstalledPrograms
|
|
Packit |
b099d7 |
# define InstallSharedLibrary(libname,rev,dest) @@\
|
|
Packit |
b099d7 |
install:: Concat(lib,libname.so.rev) @@\
|
|
Packit |
b099d7 |
MakeDir($(DESTDIR)dest) @@\
|
|
Packit |
b099d7 |
$(INSTALL) $(INSTALLFLAGS) $(INSTLIBFLAGS) Concat(lib,libname.so.rev) $(DESTDIR)dest @@\
|
|
Packit |
b099d7 |
mcs -d Concat($(DESTDIR)dest/lib,libname.so.rev) @@\
|
|
Packit |
b099d7 |
$(RM) Concat($(DESTDIR)dest/lib,libname.so) @@\
|
|
Packit |
b099d7 |
cd $(DESTDIR)dest; $(LN) Concat(lib,libname.so.rev) Concat(lib,libname.so)
|
|
Packit |
b099d7 |
#else
|
|
Packit |
b099d7 |
# define InstallSharedLibrary(libname,rev,dest) @@\
|
|
Packit |
b099d7 |
install:: Concat(lib,libname.so.rev) @@\
|
|
Packit |
b099d7 |
MakeDir($(DESTDIR)dest) @@\
|
|
Packit |
b099d7 |
$(INSTALL) $(INSTALLFLAGS) $(INSTLIBFLAGS) Concat(lib,libname.so.rev) $(DESTDIR)dest @@\
|
|
Packit |
b099d7 |
$(RM) Concat($(DESTDIR)dest/lib,libname.so) @@\
|
|
Packit |
b099d7 |
cd $(DESTDIR)dest; $(LN) Concat(lib,libname.so.rev) Concat(lib,libname.so)
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#endif /* InstallSharedLibrary */
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
/*
|
|
Packit |
b099d7 |
* InstallSharedLibraryData - generate rules to install the shared library data
|
|
Packit |
b099d7 |
*/
|
|
Packit |
b099d7 |
#ifndef InstallSharedLibraryData
|
|
Packit |
b099d7 |
# define InstallSharedLibraryData(libname,rev,dest)
|
|
Packit |
b099d7 |
#endif /* InstallSharedLibraryData */
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#ifndef LinkWithExports
|
|
Packit |
b099d7 |
# if UseExportLists
|
|
Packit |
b099d7 |
# define LinkWithExports(libname,rev,solist,down,up) \
|
|
Packit |
b099d7 |
(cd down; $(CCENVSETUP) $(LD) -o up/$@~ $(SHLIBLDFLAGS) -h $@ solist $(REQUIREDLIBS)) @@\
|
|
Packit |
b099d7 |
if [ -f Concat(lib,libname.elist) ]; then \ @@\
|
|
Packit |
b099d7 |
$(RM) down/$@.exports $@.list; \ @@\
|
|
Packit |
b099d7 |
$(CPP) $(ALLINCLUDES) $(EXTRA_DEFINES) $(PROTO_DEFINES) $(THREADS_DEFINES) $(DEFINES) Concat(lib,libname.elist) | CppSedMagic >$@.list; \ @@\
|
|
Packit |
b099d7 |
$(EXPORTLISTGEN) $@~ $@.list > down/$@.exports; \ @@\
|
|
Packit |
b099d7 |
(cd down; $(CCENVSETUP) $(LD) -o up/$@~ $(SHLIBLDFLAGS) -h $@ ShlibExportListOpt($@.exports) solist $(REQUIREDLIBS)); \ @@\
|
|
Packit |
b099d7 |
$(RM) down/$@.exports $@.list; \ @@\
|
|
Packit |
b099d7 |
fi;
|
|
Packit |
b099d7 |
# else
|
|
Packit |
b099d7 |
# define LinkWithExports(libname,rev,solist,down,up) \
|
|
Packit |
b099d7 |
(cd down; $(CCENVSETUP) $(LD) -o up/$@~ $(SHLIBLDFLAGS) -h $@ solist $(REQUIREDLIBS))
|
|
Packit |
b099d7 |
# endif
|
|
Packit |
b099d7 |
#endif
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
/*
|
|
Packit |
b099d7 |
* SharedLibraryTarget - generate rules to create a shared library;
|
|
Packit |
b099d7 |
* build it into a different name so that we do not hose people by having
|
|
Packit |
b099d7 |
* the library gone for long periods.
|
|
Packit |
b099d7 |
*/
|
|
Packit |
b099d7 |
#ifndef SharedLibraryTarget
|
|
Packit |
b099d7 |
# define SharedLibraryTarget(libname,rev,solist,down,up) @@\
|
|
Packit |
b099d7 |
AllTarget(Concat(lib,libname.so.rev)) @@\
|
|
Packit |
b099d7 |
@@\
|
|
Packit |
b099d7 |
Concat(lib,libname.so.rev): solist $(EXTRALIBRARYDEPS) @@\
|
|
Packit |
b099d7 |
$(RM) $@~ @@\
|
|
Packit |
b099d7 |
LinkWithExports(libname,rev,solist,down,up) @@\
|
|
Packit |
b099d7 |
$(RM) $@ @@\
|
|
Packit |
b099d7 |
$(MV) $@~ $@ @@\
|
|
Packit |
b099d7 |
$(RM) Concat(lib,libname.so) @@\
|
|
Packit |
b099d7 |
$(LN) $@ Concat(lib,libname.so) @@\
|
|
Packit |
b099d7 |
LinkBuildLibrary($@) @@\
|
|
Packit |
b099d7 |
LinkBuildLibrary(Concat(lib,libname.so)) @@\
|
|
Packit |
b099d7 |
@@\
|
|
Packit |
b099d7 |
clean:: @@\
|
|
Packit |
b099d7 |
$(RM) Concat(lib,libname.so.rev) Concat(lib,libname.so)
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#endif /* SharedLibraryTarget */
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#ifndef SharedDepModuleTarget
|
|
Packit |
b099d7 |
#define SharedDepModuleTarget(name,deps,solist) @@\
|
|
Packit |
b099d7 |
AllTarget(name) @@\
|
|
Packit |
b099d7 |
@@\
|
|
Packit |
b099d7 |
name: deps @@\
|
|
Packit |
b099d7 |
$(RM) $@~ @@\
|
|
Packit |
b099d7 |
$(LD) -o $@~ $(SHLIBLDFLAGS) solist $(REQUIREDLIBS) @@\
|
|
Packit |
b099d7 |
$(RM) $@ @@\
|
|
Packit |
b099d7 |
$(MV) $@~ $@ @@\
|
|
Packit |
b099d7 |
@@\
|
|
Packit |
b099d7 |
clean:: @@\
|
|
Packit |
b099d7 |
$(RM) name
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
#endif /* SharedDepModuleTarget */
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
|
|
Packit |
b099d7 |
/*
|
|
Packit |
b099d7 |
* SharedLibraryDataTarget - generate rules to create shlib data file;
|
|
Packit |
b099d7 |
*/
|
|
Packit |
b099d7 |
#ifndef SharedLibraryDataTarget
|
|
Packit |
b099d7 |
# define SharedLibraryDataTarget(libname,rev,salist)
|
|
Packit |
b099d7 |
#endif /* SharedLibraryTarget */
|