2010-10-24 10:04:16 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
# Mapnik uses the build tool SCons.
|
|
|
|
|
|
|
|
# This python file is run to compile a plugin
|
|
|
|
# It must be called from the main 'SConstruct' file like:
|
|
|
|
|
|
|
|
# SConscript('path/to/this/file.py')
|
|
|
|
|
|
|
|
# see docs at: http://www.scons.org/wiki/SConscript()
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
|
|
|
# Give this plugin a name
|
|
|
|
# here this happens to be the same as the directory
|
|
|
|
PLUGIN_NAME = 'hello'
|
|
|
|
|
|
|
|
# Here we pull from the SCons environment exported from the main instance
|
|
|
|
Import ('env')
|
|
|
|
|
|
|
|
# the below install details are also pulled from the
|
|
|
|
# main SConstruct file where configuration happens
|
|
|
|
|
|
|
|
# DESTDIR is default None, PREFIX is default '/usr/local/'
|
|
|
|
install_prefix = os.path.join(env['DESTDIR'],env['PREFIX'])
|
|
|
|
|
|
|
|
# LIBDIR_SCHEMA is likely either 'lib' or 'lib64', LIB_DIR_NAME is default None
|
|
|
|
lib_name = '%s%s' % (env['LIBDIR_SCHEMA'],env['LIB_DIR_NAME'])
|
|
|
|
|
|
|
|
# plugins can go anywhere, and be registered in custom locations by Mapnik
|
|
|
|
# but the standard location is '/usr/local/lib/mapnik2/input'
|
|
|
|
install_dest = os.path.join(install_prefix,lib_name,'input')
|
|
|
|
|
|
|
|
# clone the environment here
|
|
|
|
# so that if we modify the env it in this file
|
|
|
|
# those changes to not pollute other builds later on...
|
|
|
|
plugin_env = env.Clone()
|
|
|
|
|
|
|
|
# Add the cpp files that need to be compiled
|
|
|
|
plugin_sources = Split(
|
2011-04-02 05:45:50 +02:00
|
|
|
"""
|
|
|
|
%(PLUGIN_NAME)s_datasource.cpp
|
|
|
|
%(PLUGIN_NAME)s_featureset.cpp
|
|
|
|
""" % locals()
|
2010-10-24 10:04:16 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
# Add any external libraries this plugin should
|
|
|
|
# directly link to
|
|
|
|
libraries = [ '' ] # eg 'libfoo'
|
|
|
|
|
|
|
|
# on mac os x we need to directly link to mapnik and libicu*
|
|
|
|
if env['PLATFORM'] == 'Darwin':
|
|
|
|
libraries.append('mapnik2')
|
|
|
|
# link libicuuc, but ICU_LIB_NAME is used custom builds of icu can
|
|
|
|
# have different library names like osx which offers /usr/lib/libicucore.dylib
|
|
|
|
libraries.append(env['ICU_LIB_NAME'])
|
|
|
|
|
|
|
|
TARGET = plugin_env.SharedLibrary(
|
|
|
|
# the name of the target to build, eg 'sqlite.input'
|
|
|
|
'../%s' % PLUGIN_NAME,
|
|
|
|
# prefix - normally none used
|
|
|
|
SHLIBPREFIX='',
|
|
|
|
# extension, mapnik expects '.input'
|
|
|
|
SHLIBSUFFIX='.input',
|
|
|
|
# list of source files to compile
|
|
|
|
source=plugin_sources,
|
|
|
|
# libraries to link to
|
|
|
|
LIBS=libraries,
|
|
|
|
# any custom linkflags, eg. LDFLAGS
|
|
|
|
# in this case CUSTOM_LDFLAGS comes
|
|
|
|
# from Mapnik's main SConstruct file
|
|
|
|
# and can be removed here if you do
|
|
|
|
# not need it
|
|
|
|
LINKFLAGS=env.get('CUSTOM_LDFLAGS')
|
|
|
|
)
|
|
|
|
|
|
|
|
# if 'uninstall' is not passed on the command line
|
|
|
|
# then we actually create the install targets that
|
|
|
|
# scons will install if 'install' is passed as an arg
|
|
|
|
if 'uninstall' not in COMMAND_LINE_TARGETS:
|
|
|
|
env.Install(install_dest, TARGET)
|
|
|
|
env.Alias('install', install_dest)
|