#`--------------------------------------------------------------------
#    Copyright 2002 - 2008, 2010, 2011 National Technology &         
#    Engineering Solutions of Sandia, LLC (NTESS). Under the terms   
#    of Contract DE-NA0003525 with NTESS, there is a                 
#    non-exclusive license for use of this work by or on behalf      
#    of the U.S. Government.  Export of this program may require     
#    a license from the United States Government.                    
#--------------------------------------------------------------------

#
# The signature for Boost.build rules is described here:
#
# http://www.boost.org/build/doc/html/bbv2/overview/targets.html
#
#function-name main-target-name
#    : sources
#    : requirements
#    : default-build
#    : usage-requirements
#    ;
#
#    * "main-target-name" is the name used to request the target
#            on command line and to use it from other main targets.
#            Main target name may contain alphanumeric characters and symbols '-' and '_';
#    * "sources" is the list of source files and other main targets that must be combined.
#    * "requirements" is the list of properties that must always be present
#            when this main target is built.
#    * "default-build" is the list of properties that will be used unless
#            some other value of the same feature is already specified.
#    * "usage-requirements" is the list of properties that will be propagated
#            to all main targets that use this one, i.e. to all dependedents.
#
#
# SECTION 1: Project definition
#

import os ;
import set ;
import path ;

local stk_util-root-inc ;
if $(RTenv-arg) = "user" {
  stk_util-root-inc = $(stk_util-root)/include ;
} else {
  stk_util-root-inc = $(stk_util-root) ;
}

local stk_util_ngp-root-inc ;
if $(RTenv-arg) = "user" {
  stk_util_ngp-root-inc = $(stk_util-root)/stk_util/ngp/include ;
} else {
  stk_util_ngp-root-inc = $(stk_util-root)/stk_util/ngp ;
}

project votd
  : requirements
    $(sierra-warnings)
    <define>STK_BUILT_IN_SIERRA
    <runtime-link>shared:<define>SIERRA_DLOPEN_ENABLED
    <target-os>darwin:<define>_GNU_SOURCE=1
    <include>$(stk_util-root-inc)
  : usage-requirements
    <define>STK_BUILT_IN_SIERRA
    <runtime-link>shared:<define>SIERRA_DLOPEN_ENABLED
    <include>$(stk_util-root-inc)
  : build-dir $(stk_util-builddir)
  ;

# This variable should contain the applications and associated files that
# must be installed for both developers and end users. Unless they need to
# be visible to end users, unittests should not be placed here.
local installed-end-user-files = 
  ;
#
# This variable should contain the applications and associated files that will
# only be installed for and visible to developers.
# Note that if the --install-developer-files option is passed to bjam these will also
# be installed for end-users. (This is only intended to be used for testing.)
local installed-developer-files = 
  stk_util_utest
  stk_util_doc_test
  ;

#
# SECTION 2: Development install
#
explicit install-serial-targets ;
alias install-serial-targets ;

# Dependencies listed in this target are installed in the developer's project.
# This should include all executables and any other files needed for developer use.
explicit install-targets ;
alias install-targets
  : $(installed-end-user-files)
    $(installed-developer-files)
  ;

#
# SECTION 3: End-user install
#
explicit install-user-env ;
alias install-user-env : install-user-jamfile
                         install-user-include
                         install-user-lib
                         install-user-bin ;
                      
# Dependencies listed in this target are always installed for end users.
# This should include only those executables and any other files needed by end-users.
explicit install-user-bin ;
install install-user-bin
  : $(installed-end-user-files)
    [ if-defined-val $(install-developer-files-arg) :
        # Executables listed here will only installed if the --install-developer-files option
        # is passed to bjam. This is intended for testing that requires things like 
        # unittest to be installed when they normally would not be.
        $(installed-developer-files)
    ]
  :
  # Note that all Sierra executables are installed in a common bin directory,
  # not in a product-specific bin directory.
  <location>$(install-bin-dir)
  ;

# This rule copies build-system related files for this product to the install-root.
explicit install-user-jamfile ;
install install-user-jamfile
  : [ glob $(stk_util-root)/Jamfile ]
  : <location>$(install-root)/stk/stk_util
    <install-source-root>$(stk_util-root)
  ;


explicit install-user-include ;
install install-user-include
  : [ path.glob-tree $(stk_util-root) : *.h *.hpp ]
  : <location>$(install-root)/stk/stk_util/include <install-source-root>$(stk_util-root)
  ;

explicit install-user-lib ;
install install-user-lib
  : stk_util_parallel
    stk_util_environment
    stk_util_registry
    stk_util_diag
    stk_util_util
    stk_util_command_line
    stk_util_ngp
  : <location>$(install-root)/stk/stk_util/lib
  ;

explicit install-exe-targets ;
alias install-exe-targets : ;

#
# SECTION 4: Build configuration
#
import modules ;

exe stk_util_doc_test
  :
    [ glob $(stk_util-root)/../stk_doc_tests/stk_util/*.cpp ]
    /sierra/stk_unit_test_utils//stk_unit_main
    /sierra/stk_unit_test_utils//stk_unit_test_utils
    stk_util_command_line
  : <tag>@sierra-exec-tag
    <include>$(stk_util-root)/../stk_doc_tests/stk_util
  ;

exe stk_util_utest
  :
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/*.cpp ]
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/util/*.cpp ]
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/environment/*.cpp ]
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/command_line/*.cpp ]
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/diag/*.cpp ]
    [ glob $(stk_util-root)/../stk_unit_tests/stk_util/parallel/*.cpp ]
    /sierra/stk_unit_test_utils//stk_unit_main
    /sierra/stk_unit_test_utils//stk_unit_test_utils
    stk_util_command_line
  : <tag>@sierra-exec-tag
    <include>$(stk_util-root)/../stk_unit_tests/stk_util
    <include>$(stk_util-root)/../stk_unit_tests/stk_util/parallel
  ;

lib stk_util_parallel
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/parallel/*.cpp ]
    ]
    stk_util_util
    /mpi//mpi
    /sierra/seacas//aprepro_lib
  :
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_parallel.a
    ]
    [ ifdevbuild
        # Any parameters within this 'ifdevbuild' block apply to development
        # builds only and will not be present for user builds.
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
  ;


# Run version script. This will generate stk_version.hpp, and
# return the version to this script. If it doesn't do so, fail. We don't
# want to generate a bad version for external customers.
local version ;
if ( $(use_git_version) = "yes" ) || ( [ os.name ] = NT ) {
    if $(RTenv-arg) = "user" {
        local v = [ SHELL "cat $(stk_util-root-inc)/stk_util/registry/stk_version.hpp" : exit-status ] ;
        if $(v[2]) != 0
          { # Assume here that stk_version.hpp caused the error and just fail.
          EXIT ;
          }
        version = $(v[1]) ;
    } else {
        local v = [ SHELL "$(stk_util-root-inc)/stk_util/registry/stk_version_gen.sh" : exit-status ] ;
        if $(v[2]) != 0
          { # Assume here that stk_version_gen.sh reported the error and just fail.
          EXIT ;
          }
        version = $(v[1]) ;
    }
}
else
{
    local v = [ SHELL "echo \"// 4.59.7\" > $(stk_util-root-inc)/stk_util/registry/stk_version.hpp" : exit-status ] ;
    version = 4.59.7 ;
}

lib stk_util_environment
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/environment/*.cpp ]
    ]
    /mpi//mpi
    stk_util_util
    stk_util_parallel
  :
    [ ifdevbuild
        # Any parameters within this 'ifdevbuild' block apply to development
        # builds only and will not be present for user builds.
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_environment.a
    ]
  ;

lib stk_util_registry
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/registry/*.cpp ]
        $(stk_util-root)/stk_util/registry/stk_version.hpp
    ]
    stk_util_environment
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        <define>STK_VERSION_STRING=\"\\\"$(version)\\\"\"
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_registry.a
    ]
  ;

lib stk_util_diag
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/diag/*.cpp ]
    ]
    /mpi//mpi
    stk_util_util
    stk_util_parallel
    stk_util_environment
  :
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_diag.a
    ]
    [ ifdevbuild
        # Any parameters within this 'ifdevbuild' block apply to development
        # builds only and will not be present for user builds.
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
  ;

lib stk_util_util
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/util/*.cpp ]
    ]
    /mpi//mpi
    /tpl/trilinos//kokkoscore
    /tpl/boost//boost_header_only_libs
  :
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_util.a
    ]
    [ ifdevbuild
        # Any parameters within this 'ifdevbuild' block apply to development
        # builds only and will not be present for user builds.
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
  ;

lib stk_util_command_line
  :
    [ ifdevbuild
    # Any parameters within this 'ifdevbuild' block apply to development
    # builds only and will not be present for user builds.
        [ glob $(stk_util-root)/stk_util/command_line/*.cpp ]
    ]
    stk_util_util
    stk_util_environment
    stk_util_registry
    stk_util_diag
  :
    [ ifuserbuild
    # Any parameters within this 'ifuserbuild' block apply to user
    # builds only and will not be present for developer builds.
        <file>$(stk_util-root)/lib/libstk_util_command_line.a
    ]
    [ ifdevbuild
        # Any parameters within this 'ifdevbuild' block apply to development
        # builds only and will not be present for user builds.
        <toolset>gcc:<cflags>"-Wextra -Wpedantic -Wshadow -Wno-unused-parameter"
    ]
  ;

# This is currently a header-only library, so it must not use the lib rule.
# # If sources are added to this library change this target to use the lib rule instead.
alias stk_util_ngp
  : # No sources defined for header-only libraries.
  : # No build requirements
  : # No default build
  : <include>$(stk_util_ngp-root-inc)
  ;
