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)