aboutsummaryrefslogtreecommitdiff
path: root/libstudxml/buildfile
diff options
context:
space:
mode:
authorKaren Arutyunov <karen@codesynthesis.com>2017-05-02 21:26:58 +0300
committerKaren Arutyunov <karen@codesynthesis.com>2017-05-02 23:55:21 +0300
commit424e315dfa9a78aebf0653c95f83fe6ed452dd8e (patch)
tree59759d1d4eac4096df104d4dbab24a531ada3399 /libstudxml/buildfile
parent3d2b5b2a7064abe35614ebb32db03bd2881adcf0 (diff)
Add hxx extension for headers and libstud prefix for library dir
Diffstat (limited to 'libstudxml/buildfile')
-rw-r--r--libstudxml/buildfile91
1 files changed, 91 insertions, 0 deletions
diff --git a/libstudxml/buildfile b/libstudxml/buildfile
new file mode 100644
index 0000000..1cc0203
--- /dev/null
+++ b/libstudxml/buildfile
@@ -0,0 +1,91 @@
+# file : libstudxml/buildfile
+# copyright : Copyright (c) 2013-2017 Code Synthesis Tools CC
+# license : MIT; see accompanying LICENSE file
+
+lib{studxml}: \
+ {hxx }{ content } \
+ {hxx }{ exception } \
+ {hxx }{ forward } \
+ {hxx ixx txx cxx}{ parser } \
+ {hxx cxx}{ qname } \
+ {hxx ixx cxx}{ serializer } \
+ {hxx txx cxx}{ value-traits } \
+ {hxx }{ version } \
+ details/{hxx }{ config.hxx } \
+ details/{hxx }{ export.hxx } \
+ details/{hxx }{ post.hxx } \
+ details/{hxx }{ pre.hxx } \
+details/build2/{h }{ config } \
+details/build2/{h }{ config-vc }
+
+# Expat. Note that we treat a whole bunch of its sources as files since they
+# are private and #include's (including .c file).
+#
+lib{studxml}: \
+details/expat/h{ expat } \
+details/expat/h{ expat_external } \
+details/expat/c{ xmlparse } \
+details/expat/c{ xmlrole } \
+details/expat/c{ xmltok } \
+details/expat/file{ ascii.h asciitab.h config.h iasciitab.h internal.h \
+latin1tab.h nametab.h utf8tab.h xmlrole.h xmltok.h xmltok_impl.c \
+xmltok_impl.h xmltok_ns.c} \
+details/expat/doc{LICENSE README}
+
+details/expat/doc{README}@./: install = false
+details/expat/doc{LICENSE}@./: install = doc/EXPAT-LICENSE
+
+# Genx.
+#
+lib{studxml}: \
+details/genx/c{ char-props } \
+details/genx/c{ genx } \
+details/genx/h{ genx } \
+details/genx/doc{LICENSE README}
+
+hxx{version}: in{version} $src_root/file{manifest}
+hxx{version}: dist = true
+
+details/genx/doc{README}@./: install = false
+details/genx/doc{LICENSE}@./: install = doc/GENX-LICENSE
+
+# For pre-releases use the complete version to make sure they cannot be used
+# in place of another pre-release or the final version.
+#
+if $version.pre_release
+ lib{studxml}: bin.lib.version = @"-$version.project_id"
+else
+ lib{studxml}: bin.lib.version = @"-$version.major.$version.minor"
+
+# We are a mixed C/C++ library, though C is implementatio-only, kind of: we
+# need headers but not symbols.
+#
+cc.poptions =+ "-I$out_root" "-I$src_root" -DLIBSTUDXML_BUILD2
+obja{*}: cc.poptions += -DLIBSTUDXML_STATIC_BUILD
+objs{*}: cc.poptions += -DLIBSTUDXML_SHARED_BUILD
+
+lib{studxml}: cc.export.poptions = "-I$out_root" "-I$src_root" -DLIBSTUDXML_BUILD2
+liba{studxml}: cc.export.poptions += -DLIBSTUDXML_STATIC
+libs{studxml}: cc.export.poptions += -DLIBSTUDXML_SHARED
+
+# Install into the libstudxml/ subdirectory of, say, /usr/include/. Bold, I
+# know.
+#
+install.include = $install.include/libstudxml/
+install.include.subdirs = true # Recreate subdirectories.
+
+# We want these to be picked up even when LIBSTUDXML_BUILD2 is not defined.
+#
+details/build2/:
+{
+ if ($cxx.id == "msvc")
+ {
+ h{config}@./: install = false
+ h{config-vc}@./: install = $install.include/details/
+ }
+ else
+ {
+ h{config}@./: install = $install.include/details/
+ h{config-vc}@./: install = false
+ }
+}