# file      : libbrep/buildfile
# license   : MIT; see accompanying LICENSE file

define sql: file

sql{*}:
{
  extension = sql
  install = data/
}

# @@ ODB: these are ODB changelogs that are both generated and stored in the
#         repository (what if src != out?). Will need to think how to handle
#         them properly (always generate in src_base?).
#
define xml: file
xml{*}: extension = xml

import int_libs  = libodb%lib{odb}
import int_libs += libodb-pgsql%lib{odb-pgsql}
import int_libs += libbutl%lib{butl}
import int_libs += libbpkg%lib{bpkg}
import int_libs += libbbot%lib{bbot}

lib{brep}:                                                              \
  {hxx ixx txx cxx}{* -version -*-odb}                                  \
  {hxx            }{version}                                            \
  {hxx ixx     cxx}{common-odb package-odb build-odb build-package-odb} \
  $int_libs xml{*} sql{*}

# Include the generated version header into the distribution (so that we don't
# pick up an installed one) and don't remove it when cleaning in src (so that
# clean results in a state identical to distributed).
#
hxx{version}: in{version} $src_root/manifest
hxx{version}:
{
  dist  = true
  clean = ($src_root != $out_root)
}

# Export options.
#
lib{brep}:
{
  cxx.export.poptions = "-I$out_root" "-I$src_root"
  cxx.export.libs = $int_libs
}

# For pre-releases use the complete version to make sure they cannot be used
# in place of another pre-release or the final version. See the version module
# for details on the version.* variable values.
#
if $version.pre_release
  lib{brep}: bin.lib.version = @"-$version.project_id"
else
  lib{brep}: bin.lib.version = @"-$version.major.$version.minor"

# Install into the libbrep/ subdirectory of, say, /usr/include/
# recreating subdirectories.
#
{hxx ixx txx}{*}:
{
  install         = include/libbrep/
  install.subdirs = true
}