diff --git a/build.xml b/build.xml
index 79b3bf42cb436fca525a490badb34d6b0ce052a0..77f89ae6ab7c87b17b82dc5b04501fcbff1310c0 100644 (file)
--- a/build.xml
+++ b/build.xml
-<project name="Sands" default="dist" basedir=".">
+<project name="Inkscape" default="dist" basedir=".">
<description>
- Build file for Sands office data tool
+ Build file for the Inkscape SVG editor. This file
+ was written for GTK-2.10 on Win32, but it should work
+ well for other types of builds with only minor adjustments.
</description>
<!-- set global properties for this build -->
- <property name="version" location="0.45"/>
+ <property name="version" value="0.45"/>
+ <property name="arch" value="i686-pc-mingw32-"/>
+ <!--<property name="archutil" value="${arch}"/>-->
+ <property name="archutil" value=""/>
<property name="src" location="src"/>
<property name="gtk" location="c:/gtk210"/>
<property name="lib" location="lib"/>
<target name="init">
<!-- Create the build directory structure used by compile -->
<mkdir dir="${build}"/>
+ <mkdir dir="${dist}"/>
+ <copy file="${src}/helper/sp-marshal.h.mingw"
+ tofile="${src}/helper/sp-marshal.h"/>
+ <copy file="${src}/helper/sp-marshal.cpp.mingw"
+ tofile="${src}/helper/sp-marshal.cpp"/>
+ <makefile file="inkscape_version.h">
+ #define INKSCAPE_VERSION "${version}+devel"
+ </makefile>
<makefile file="config.h">
#ifndef _CONFIG_H_
#define _CONFIG_H_
<target name="compile" depends="init"
description="compile the source " >
<!-- Compile from source to build -->
- <cc cc="gcc" cxx="g++" destdir="${build}/obj">
+ <cc cc="${arch}gcc" cxx="${arch}g++"
+ destdir="${build}/obj">
<fileset dir="${src}">
<!-- THINGS TO EXCLUDE -->
- <exclude name="ast"/>
- <exclude name="bonobo"/>
+ <exclude name="ast/.*"/>
+ <exclude name="bonobo/.*"/>
<exclude name="deptool.cpp"/>
<exclude name="dialogs/filedialog-win32.cpp"/>
<exclude name="display/testnr.cpp"/>
<exclude name="display/bezier-utils-test.cpp"/>
<exclude name="dom/jsdombind.cpp"/>
- <exclude name="dom/work"/>
+ <exclude name="dom/work/.*"/>
<exclude name="dom/odf/SvgOdg.cpp"/>
<exclude name="extension/api.cpp"/>
- <exclude name="extension/dxf2svg"/>
+ <exclude name="extension/dxf2svg/.*"/>
<exclude name="extension/internal/gnome.cpp"/>
<exclude name="extension/script/bindtest.cpp"/>
<exclude name="extension/script/cpptest.cpp"/>
- <exclude name="extension/plugin"/>
+ <exclude name="extension/plugin/.*"/>
<exclude name="extract-uri-test.cpp"/>
<exclude name="helper/units-test.cpp"/>
- <exclude name="inkview.cpp"/>
+ <!-- exclude name="inkview.cpp"/-->
<exclude name="libnr/in-svg-plane-test.cpp"/>
<exclude name="libnr/nr-compose-reference.cpp"/>
<exclude name="libnr/nr-compose-test.cpp"/>
<exclude name="round-test.cpp"/>
<exclude name="sp-gradient-test.cpp"/>
<exclude name="svg/ftos.cpp"/>
- <exclude name="utest"/>
+ <exclude name="utest/.*"/>
<exclude name="widgets/test-widgets.cpp"/>
<exclude name="xml/quote-test.cpp"/>
<exclude name="xml/repr-action-test.cpp"/>
<!--JABBER-->
<exclude name="pedro/pedrogui.cpp"/>
<exclude name="pedro/pedrogui.h"/>
- <exclude name="pedro/work"/>
+ <exclude name="pedro/work/.*"/>
<!--WHITEBOARD-->
<exclude name="ui/dialog/session-player.cpp"/>
<exclude name="ui/dialog/whiteboard-connect.cpp"/>
</fileset>
<flags>
-Wall -O3
- -mms-bitfields
+ -mms-bitfields
</flags>
<defines>
-DVERSION=\"${version}\"
</target>
<target name="lib" depends="compile">
- <ar file="${build}/libinkscape.a">
+ <staticlib command="${archutil}ar crsv"
+ file="${build}/libinkscape.a">
<fileset dir="${build}/obj">
<exclude name="main,o"/>
<exclude name="winmain,o"/>
+ <exclude name="inkview,o"/>
</fileset>
- </ar>
+ </staticlib>
</target>
<target name="i18n" depends="compile">
- <msgfmt todir="${build}/po">
+ <msgfmt todir="${build}/locale" owndir="true">
<fileset dir="po">
</fileset>
</msgfmt>
</target>
<target name="link" depends="lib">
- <rc command="windres -o"
+ <rc command="${archutil}windres"
file="${src}/inkscape.rc"
out="${build}/inkres.o">
<flags>
--include-dir=${src}
</flags>
</rc>
- <link command="g++" out="${build}/inkscape.exe">
+ <link command="${arch}g++" out="${build}/inkscape.exe"
+ strip="true" symfile="${build}/inkscape.dbg"
+ stripcommand="${archutil}strip"
+ objcopycommand="${archutil}objcopy"
+ >
+ <flags>
+ </flags>
+ <fileset dir="${build}">
+ <include name="inkres.o"/>
+ <include name="obj/main.o"/>
+ <include name="obj/winmain.o"/>
+ <include name="libinkscape.a"/>
+ </fileset>
+ <libs>
+ -L${gtk}/lib
+ -lgtkmm-2.4 -lgdkmm-2.4 -lglibmm-2.4
+ -latkmm-1.6 -lpangomm-1.4 -lsigc-2.0
+ -lgtk-win32-2.0 -lgdk-win32-2.0 -latk-1.0
+ -lgdk_pixbuf-2.0
+ -lpangocairo-1.0 -lpangoft2-1.0 -lpangowin32-1.0 -lpango-1.0
+ -lgobject-2.0 -lgmodule-2.0 -lgthread-2.0 -lglib-2.0 -lcairo
+ <!-- PERL -->
+ -L${gtk}/perl/lib/CORE -lperl58
+ <!-- PYTHON -->
+ -L${gtk}/python/libs -lpython24
+ ${gtk}/bin/libxml2.dll
+ ${gtk}/lib/iconv.lib
+ -lfreetype.dll -lfontconfig.dll
+ -llcms.dll
+ -lssl -lcrypto
+ -lpng -lpopt ${gtk}/lib/zdll.lib
+ -lgc -mwindows -lws2_32 -lintl -lm
+ </libs>
+ </link>
+ </target>
+
+ <target name="linkinkview" depends="lib">
+ <rc command="${archutil}windres"
+ file="${src}/inkview.rc"
+ out="${build}/inkviewres.o">
+ <flags>
+ --include-dir=${src}
+ </flags>
+ </rc>
+ <link command="${arch}g++" out="${build}/inkview.exe"
+ strip="true" symfile="${build}/inkview.dbg"
+ stripcommand="${archutil}strip"
+ objcopycommand="${archutil}objcopy"
+ >
<flags>
</flags>
- <fileset>
- <include name="${build}/inkres.o"/>
- <include name="${build}/obj/main.o"/>
- <include name="${build}/obj/winmain.o"/>
- <include name="${build}/libinkscape.a"/>
+ <fileset dir="${build}">
+ < include name="inkviewres.o"/ >
+ <include name="obj/inkview.o"/>
+ <include name="libinkscape.a"/>
</fileset>
<libs>
-L${gtk}/lib
-lgc -mwindows -lws2_32 -lintl -lm
</libs>
</link>
- <!--<strip file="${build}/inkscape.exe"/>-->
</target>
- <target name="dist" depends="link,i18n"
+ <target name="dist" depends="link,i18n,linkinkview"
description="generate the distribution" >
<!-- Create the distribution directory -->
<copy file="${build}/inkscape.exe" todir="${dist}"/>
+ <copy file="${build}/inkscape.dbg" todir="${dist}"/>
+ <copy file="${build}/inkview.exe" todir="${dist}"/>
+ <copy file="${build}/inkview.dbg" todir="${dist}"/>
<copy file="AUTHORS" todir="${dist}"/>
<copy file="COPYING" todir="${dist}"/>
<copy file="COPYING.LIB" todir="${dist}"/>
<copy file="${gtk}/bin/intl.dll" tofile="${dist}/libintl-2.dll"/>
<!-- MSGFMT files -->
- <copy todir="${dist}"> <fileset dir="${build}/po"/> </copy>
+ <copy todir="${dist}">
+ <fileset dir="${build}/locale">
+ <exclude name=".*\.am"/>
+ </fileset>
+ </copy>
<!-- GTK -->
<copy todir="${dist}"> <fileset dir="${gtk}/etc"/> </copy>
<copy todir="${dist}/lib"> <fileset dir="${gtk}/lib/gtk-2.0"/> </copy>
<copy todir="${dist}/lib"> <fileset dir="${gtk}/lib/glib-2.0"/> </copy>
<copy todir="${dist}/lib"> <fileset dir="${gtk}/lib/locale"/> </copy>
- <copy todir="${dist}/lib"> <fileset dir="${gtk}/lib/pango"/> </copy>
- <copy todir="${dist}"> <fileset dir="share"/> </copy>
+ <copy todir="${dist}">
+ <fileset dir="share">
+ <exclude name=".*\.am"/>
+ </fileset>
+ </copy>
<copy todir="${dist}/share"> <fileset dir="${gtk}/share/themes"/> </copy>
<mkdir dir="${dist}/data"/>
<mkdir dir="${dist}/locale"/>