1 # ---------------------------------------------------------------
5 # This file can be used to build various Perl5 extensions with SWIG.
6 # By default this file is set up for dynamic loading, but it can
7 # be easily customized for static extensions by modifying various
8 # portions of the file.
10 # SRCS = C source files
11 # CXXSRCS = C++ source files
12 # OBJCSRCS = Objective-C source files
13 # OBJS = Additional .o files (compiled previously)
14 # INTERFACE = SWIG interface file
15 # TARGET = Name of target module or executable
17 # Many portions of this file were created by the SWIG configure
18 # script and should already reflect your machine.
19 #----------------------------------------------------------------
26 WRAPFILE = $(INTERFACE:.i=_wrap.c)
27 WRAPOBJ = $(INTERFACE:.i=_wrap.o)
28 TARGET = module@SO@ # Use this kind of target for dynamic loading
29 #TARGET = myperl # Use this target for static linking
32 exec_prefix = @exec_prefix@
36 OBJC = @CC@ -Wno-import # -Wno-import needed for gcc
42 # SWIG = location of the SWIG executable
43 # SWIGOPT = SWIG compiler options
44 # SWIGCC = Compiler used to compile the wrapper file
46 SWIG = $(exec_prefix)/bin/swig
50 # SWIG Library files. Uncomment this to staticly rebuild Perl
51 #SWIGLIB = -static -lperlmain.i
53 # Rules for creating .o files from source.
56 CXXOBJS = $(CXXSRCS:.cxx=.o)
57 OBJCOBJS = $(OBJCSRCS:.m=.o)
58 ALLOBJS = $(COBJS) $(CXXOBJS) $(OBJCOBJS) $(OBJS)
60 # Command that will be used to build the final extension.
63 # Uncomment the following if you are using dynamic loading
67 # Uncomment the following if you are using dynamic loading with C++ and
68 # need to provide additional link libraries (this is not always required).
70 #DLL_LIBS = -L/usr/local/lib/gcc-lib/sparc-sun-solaris2.5.1/2.7.2 \
71 -L/usr/local/lib -lg++ -lstdc++ -lgcc
73 # X11 installation (possibly needed if using Perl-Tk)
76 XINCLUDE = @XINCLUDES@
80 PERL_INCLUDE = -I@PERL5EXT@
81 PERL_LIB = -L@PERL5EXT@ -lperl
82 PERL_FLAGS = -Dbool=char -Dexplicit=
84 # Tcl installation. If using Tk you might need this
86 TCL_INCLUDE = @TCLINCLUDE@
89 # Build libraries (needed for static builds)
93 SYSLIBS = $(LIBM) $(LIBC) @LIBS@
95 # Build options (uncomment only one these)
97 #TK_LIB = $(TCL_LIB) -ltcl -ltk $(XLIB)
98 BUILD_LIBS = $(LIBS) # Dynamic loading
99 #BUILD_LIBS = $(PERL_LIB) $(TK_LIB) $(LIBS) $(SYSLIBS) # Static linking
101 # Compilation rules for non-SWIG components
103 .SUFFIXES: .c .cxx .m
106 $(CC) $(CCSHARED) $(CFLAGS) $(INCLUDE) -c $<
109 $(CXX) $(CCSHARED) $(CXXFLAGS) $(INCLUDE) -c $<
112 $(OBJC) $(CCSHARED) $(CFLAGS) $(INCLUDE) -c $<
115 # ----------------------------------------------------------------------
116 # Rules for building the extension
117 # ----------------------------------------------------------------------
121 # Convert the wrapper file into an object file
123 $(WRAPOBJ) : $(WRAPFILE)
124 $(SWIGCC) -c $(CCSHARED) $(CFLAGS) $(INCLUDE) $(PERL_INCLUDE) $(PERL_FLAGS) $(WRAPFILE)
126 $(WRAPFILE) : $(INTERFACE)
127 $(SWIG) $(SWIGOPT) -o $(WRAPFILE) $(SWIGLIB) $(INTERFACE)
129 $(TARGET): $(WRAPOBJ) $(ALLOBJS)
130 $(BUILD) $(WRAPOBJ) $(ALLOBJS) $(BUILD_LIBS) -o $(TARGET)
133 rm -f $(COBJS) $(CXXOBJS) $(OBJCOBJS) $(WRAPOBJ) $(WRAPFILE) $(TARGET)