| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625 |
- //
- // Template.msvc.pp
- //
- // This file defines the set of ouput files that will be generated to
- // support a Microsoft Visual C++ .NET solution / project build. It rolls
- // libraries into their metalibs, generates .dll files, compiles source
- // files to .obj files, and does other Windows-specific things.
- // Before this file is processed, the following files are read and
- // processed (in order):
- // The Package.pp file in the root of the current source hierarchy
- // (e.g. $PANDA/Package.pp)
- // $DTOOL/Package.pp
- // $DTOOL/Config.pp
- // $DTOOL/Config.Platform.pp
- // The user's PPREMAKE_CONFIG file.
- // $DTOOL/pptempl/System.pp
- // All of the Sources.pp files in the current source hierarchy
- // $DTOOL/pptempl/Global.pp
- // $DTOOL/pptempl/Global.msvc.pp
- // $DTOOL/pptempl/Depends.pp, once for each Sources.pp file
- // Template.msvc.pp (this file), once for each Sources.pp file
- #defun decygwin frompat,topat,path
- #foreach file $[path]
- #if $[isfullpath $[file]]
- $[patsubstw $[frompat],$[topat],$[cygpath_w $[file]]]
- #else
- $[patsubstw $[frompat],$[topat],$[osfilename $[file]]]
- #endif
- #end file
- #end decygwin
- // should overwrite read-only files
- #define COPYCMD xcopy /Y /Q /R
- #if $[ne $[CTPROJS],]
- #define dtool_ver_dir_cyg $[DTOOL]/src/dtoolbase
- #define dtool_ver_dir $[decygwin %,%,$[dtool_ver_dir_cyg]]
- #endif
- //////////////////////////////////////////////////////////////////////
- #if $[or $[eq $[DIR_TYPE], src],$[eq $[DIR_TYPE], metalib]]
- //////////////////////////////////////////////////////////////////////
- // For a source directory, build a single Makefile with rules to build
- // each target.
- #if $[build_directory]
- // This is the real set of lib_targets we'll be building. On Windows,
- // we don't build the shared libraries which are included on metalibs.
- #define real_lib_targets
- #define deferred_objs
- #forscopes lib_target
- #if $[eq $[module $[TARGET],$[TARGET]],]
- // This library is not on a metalib, so we can build it.
- #set real_lib_targets $[real_lib_targets] $[active_target]
- #else
- // This library is on a metalib, so we can't build it, but we
- // should build all the obj's that go into it.
- #set deferred_objs $[deferred_objs] \
- $[patsubst %_src.cxx,,%.c %.cxx %.yxx %.lxx,$[so_dir]\%.obj,%,,$[get_sources] $[get_igateoutput]]
- #endif
- #end lib_target
- #defer lib_projects \
- $[active_target(metalib_target lib_target noinst_lib_target)] \
- $[real_lib_targets]
- #defer static_lib_projects \
- $[active_target(static_lib_target ss_lib_target)]
- #defer bin_projects \
- $[active_target(bin_target noinst_bin_target)]
- #defer test_bin_projects \
- $[active_target(test_bin_target)]
- // We need to know the various targets we'll be building.
- // $[lib_targets] will be the list of dynamic libraries,
- // $[static_lib_targets] the list of static libraries, and
- // $[bin_targets] the list of binaries. $[test_bin_targets] is the
- // list of binaries that are to be built only when specifically asked
- // for.
- #define lib_targets $[patsubst %,lib%$[dllext].$[dlllib],$[lib_projects]]
- #define static_lib_targets $[static_lib_projects:%=lib%$[dllext].lib]
- #define bin_targets $[bin_projects:%=%.exe] $[active_target(sed_bin_target)]
- #define test_bin_targets $[test_bin_projects:%=%.exe]
- #define all_targets $[unique $[lib_targets] $[static_lib_targets] \
- $[bin_targets] $[test_bin_targets]]
- // $[so_sources] is the set of sources that belong on a shared object,
- // and $[st_sources] is the set of sources that belong on a static
- // object, like a static library or an executable. In Windows, we
- // don't need to make this distinction, but we do anyway in case we
- // might in the future for some nutty reason.
- #defer so_sources $[get_sources(metalib_target lib_target noinst_lib_target)]
- #defer st_sources $[get_sources(static_lib_target ss_lib_target bin_target noinst_bin_target test_bin_target)]
- // These are the source files that our dependency cache file will
- // depend on. If it's an empty list, we won't bother writing rules to
- // freshen the cache file.
- #define dep_sources $[sort $[filter %.c %.cxx %.yxx %.lxx %.h %.I %.I,$[so_sources] $[st_sources]]]
- #if $[eq $[so_dir],$[st_dir]]
- // If the static and shared directories are the same, we have to use the
- // same rules to build both shared and static targets.
- #set st_sources $[so_sources] $[st_sources]
- #set so_sources
- #endif
- #endif // $[build_directory]
- // And these are the various source files, extracted out by type.
- #defer cxx_so_sources $[filter_out %_src.cxx,$[filter %.cxx,$[so_sources]]]
- #defer cxx_st_sources $[filter_out %_src.cxx,$[filter %.cxx,$[st_sources]]]
- #defer c_so_sources $[filter %.c,$[so_sources]]
- #defer c_st_sources $[filter %.c,$[st_sources]]
- #defer yxx_so_sources $[filter %.yxx,$[so_sources]]
- #defer yxx_st_sources $[filter %.yxx,$[st_sources]]
- #defer lxx_so_sources $[filter %.lxx,$[so_sources]]
- #defer lxx_st_sources $[filter %.lxx,$[st_sources]]
- #defer h_sources $[filter %.h,$[so_sources] $[st_sources]]
- #defer i_sources $[filter %.I,$[so_sources] $[st_sources]]
- #if $[DO_PCH]
- #define pch_header_source $[get_precompiled_header(metalib_target lib_target noinst_lib_target)]
- #define st_pch_files $[patsubst %.h,$[st_dir]\%.pch,$[pch_header_source]]
- #define st_pch_obj_files $[patsubst %.h,$[st_dir]\%.obj,$[pch_header_source]]
- #endif
- // This map variable gets us all the various source files from all the
- // targets in this directory. We need it to look up the context in
- // which to build a particular source file, since some targets may
- // have different requirements (e.g. different local_libs, or
- // different USE_this or USE_that) than other targets.
- #map all_sources get_sources(metalib_target lib_target noinst_lib_target static_lib_target ss_lib_target bin_target noinst_bin_target test_bin_target)
- // $[target_ipath] is the proper ipath to put on the command line,
- // from the context of a particular target.
- #defer target_ipath $[RELDIR] $[TOPDIR] $[sort $[complete_ipath]] $[other_trees:%=%\include] $[get_ipath]
- // $[converted_ipath] is the properly-formatted version of the include path
- // for Visual Studio .NET. The resulting list is semicolon separated and uses
- // Windows-style pathnames.
- #defer converted_ipath $[join ;,$[osfilename $[target_ipath]]]
- // $[file_ipath] is the ipath from the context of a particular source
- // file, given in $[file]. It uses the all_sources map to look up
- // the target the source file belongs on, to get the proper context.
- #defer file_ipath $[all_sources $[target_ipath],$[file]]
- // These are the complete set of extra flags the compiler requires,
- // from the context of a particular file, given in $[file].
- #defer cflags $[all_sources $[get_cflags] $[CFLAGS],$[file]] $[CFLAGS_OPT$[OPTIMIZE]]
- #defer c++flags $[all_sources $[get_cflags] $[C++FLAGS],$[file]] $[CFLAGS_OPT$[OPTIMIZE]]
- // These are the same flags, sans the compiler optimizations.
- #defer noopt_c++flags $[all_sources $[get_cflags] $[C++FLAGS],$[file]] $[CFLAGS_OPT$[OPTIMIZE]]
- // $[complete_lpath] is rather like $[complete_ipath]: the list of
- // directories (from within this tree) we should add to our -L list.
- #defer complete_lpath $[libs $[RELDIR:%=%\$[ODIR]],$[actual_local_libs]] $[EXTRA_LPATH]
- // $[lpath] is like $[target_ipath]: it's the list of directories we
- // should add to our -L list, from the context of a particular target.
- #defer lpath $[sort $[complete_lpath]] $[other_trees:%=%\lib] $[get_lpath]
- // $[converted_lpath] is the properly-formatted version of the library path
- // for Visual Studio .NET. The resulting list is semicolon separated and uses
- // Windows-style pathnames.
- #defer converted_lpath $[join ;,$[osfilename $[lpath]]]
- // And $[libs] is the set of libraries we will link with.
- #defer libs $[unique $[actual_local_libs:%=%$[dllext]] $[patsubst %:c,,%:m %,%$[dllext],$[OTHER_LIBS]] $[get_libs]]
- #defer converted_libs $[patsubst %.lib,%.lib,%,lib%.lib,$[libs]]
- // This is the set of files we might copy into *.prebuilt, if we have
- // bison and flex (or copy from *.prebuilt if we don't have them).
- #define bison_prebuilt $[patsubst %.yxx,%.h,$[yxx_so_sources] $[yxx_st_sources]] $[patsubst %.yxx,%.cxx,$[yxx_so_sources] $[yxx_st_sources]] $[patsubst %.lxx,%.cxx,$[lxx_so_sources] $[lxx_st_sources]]
- // Rather than making a rule to generate each install directory later,
- // we create the directories now. This reduces problems from
- // multiprocess builds.
- #mkdir $[sort \
- $[if $[install_lib],$[install_lib_dir]] \
- $[if $[install_bin] $[install_scripts],$[install_bin_dir]] \
- $[if $[install_headers],$[install_headers_dir]] \
- $[if $[install_parser_inc],$[install_parser_inc_dir]] \
- $[if $[install_data],$[install_data_dir]] \
- $[if $[install_config],$[install_config_dir]] \
- $[if $[install_igatedb],$[install_igatedb_dir]] \
- $[if $[install_py],$[install_py_dir] $[install_py_package_dir]] \
- ]
- // Pre-compiled headers are one way to speed the compilation of many
- // C++ source files that include similar headers, but it turns out a
- // more effective (and more portable) way is simply to compile all the
- // similar source files in one pass.
- // We do this by generating a *_composite.cxx file that has an
- // #include line for each of several actual source files, and then we
- // compile the composite file instead of the original files.
- #foreach composite_file $[composite_list]
- #output $[composite_file] notouch
- #format collapse
- /* Generated automatically by $[PPREMAKE] $[PPREMAKE_VERSION] from $[SOURCEFILE]
- . */
- /* ################################# DO NOT EDIT ########################### */
- #foreach file $[$[composite_file]_sources]
- ##include "$[file]"
- #end file
- #end $[composite_file]
- #end composite_file
- /////////////////////////////////////////////////////////////////////
- // First, the dynamic libraries. Each lib_target and metalib_target
- // is a dynamic library.
- /////////////////////////////////////////////////////////////////////
- #forscopes metalib_target lib_target
- // In Windows, we don't actually build all the libraries. In
- // particular, we don't build any libraries that are listed on a
- // metalib. Is this one such library?
- #define build_it $[eq $[module $[TARGET],$[TARGET]],]
- // We might need to define a BUILDING_ symbol for win32. We use the
- // BUILDING_DLL variable name, defined typically in the metalib, for
- // this; but in some cases, where the library isn't part of a metalib,
- // we define BUILDING_DLL directly for the target.
- #define building_var $[or $[BUILDING_DLL],$[module $[BUILDING_DLL],$[TARGET]]]
- #define defines $[join ;,$[extra_defines] $[building_var]]
- // $[igatescan] is the set of C++ headers and source files that we
- // need to scan for interrogate. $[igateoutput] is the name of the
- // generated .cxx file that interrogate will produce (and which we
- // should compile into the library). $[igatedb] is the name of the
- // generated .in file that interrogate will produce (and which should
- // be installed into the /etc directory).
- #define igatescan $[get_igatescan]
- #define igateoutput $[get_igateoutput]
- #define igatedb $[get_igatedb]
- // If this is a metalib, it may have a number of components that
- // include interrogated interfaces. If so, we need to generate a
- // 'module' file within this library. This is mainly necessary for
- // Python; it contains a table of all of the interrogated functions,
- // so we can load the library as a Python module and have access to
- // the interrogated functions.
- // $[igatemscan] is the set of .in files generated by all of our
- // component libraries. If it is nonempty, then we do need to
- // generate a module, and $[igatemout] is the name of the .cxx file
- // that interrogate will produce to make this module.
- #define igatemscan $[get_igatemscan]
- #define igatemout $[get_igatemout]
- #if $[build_it]
- #define target $[ODIR]\$[lib_prefix]$[TARGET].$[dlllib]
- // Installation paths
- #define mybasename $[basename $[notdir $[target]]]
- #define tmpdirname_cyg $[install_lib_dir]/$[mybasename]
- #define tmpdirname_win $[osfilename $[tmpdirname_cyg]]
- // List of object files that will be combined to form this metalib target.
- #define objects \
- $[components \
- $[osfilename $[patsubst %,$[RELDIR]\$[%_obj],$[compile_sources]]], \
- $[active_component_libs]]
- #endif $[build_it]
- // Additional rules to generate and compile the interrogate data, if needed.
- #if $[igatescan]
- #define igatelib $[lib_prefix]$[TARGET]
- // The module name comes from the metalib that includes this library.
- #define igatemod $[module $[TARGET],$[TARGET]]
- #if $[eq $[igatemod],]
- // ... unless no metalib includes this library.
- #define igatemod $[TARGET]
- #endif
- // Built the complete interrogate.exe commandline
- #define igate_commandline \
- $[install_bin_dir]\$[INTERROGATE] -od $[igatedb] -oc $[igateoutput] \
- $[interrogate_options] -module "$[igatemod]" -library "$[igatelib]" \
- $[igatescan]
- // TODO: Install $[igatedb] in $[install_igatedb_dir]
- #endif // igatescan
- // And finally, some additional rules to build the interrogate module
- // file into the library, if this is a metalib that includes
- // interrogated components.
- #if $[igatemout]
- #define igatelib $[lib_prefix]$[TARGET]
- #define igatemod $[TARGET]
- #define igatemod_commandline \
- $[install_bin_dir]\$[INTERROGATE_MODULE] -oc $[igatemout] \
- -module "$[igatemod]" -library "$[igatelib]" $[interrogate_module_options] \
- $[igatemscan]
- #endif // igatemout
- #output $[TARGET].vcproj
- #format straight
- <?xml version="1.0" encoding = "Windows-1252"?>
- <VisualStudioProject
- ProjectType="Visual C++"
- Version="7.00"
- Name="$[TARGET]"
- ProjectGUID="{$[makeguid $[TARGET]]}"
- Keyword="CustomAppWizProj">
- <Platforms>
- <Platform
- Name="Win32"/>
- </Platforms>
- <Configurations>
- <Configuration
- Name="$[ODIR]|Win32"
- IntermediateDirectory="$[ODIR]"
- OutputDirectory="$[ODIR]"
- #if $[build_it]
- ConfigurationType="2">
- #else
- ConfigurationType="4">
- #endif
- <Tool
- Name="VCCLCompilerTool"
- AdditionalOptions="/Zm350"
- AdditionalIncludeDirectories="$[converted_ipath]"
- PreprocessorDefinitions="$[defines]"
- RuntimeLibrary="2"/>
- <Tool
- Name="VCCustomBuildTool"/>
- #if $[build_it]
- <Tool
- Name="VCLinkerTool"
- AdditionalDependencies="$[converted_libs] $[objects]"
- OutputFile="$[target]"
- AdditionalLibraryDirectories="$[converted_lpath]"/>
- #else
- <Tool
- Name="VCLibrarianTool"
- OutputFile=""/>
- #endif
- <Tool
- Name="VCMIDLTool"/>
- #if $[build_it]
- <Tool
- Name="VCPostBuildEventTool"
- Description="Copying $[target] to $[install_lib_dir]..."
- CommandLine="$[COPYCMD] $[target] $[install_bin_dir]"/>
- #else
- <Tool
- Name="VCPostBuildEventTool"/>
- #endif
- #if $[igatescan]
- <Tool
- Name="VCPreBuildEventTool"
- Description="Generating $[igateoutput] using $[INTERROGATE]..."
- CommandLine='$[igate_commandline]'/>
- #elif $[igatemscan]
- <Tool
- Name="VCPreBuildEventTool"
- Description="Generating $[igatemout] using $[INTERROGATE_MODULE]..."
- CommandLine='$[igatemod_commandline]'/>
- #else
- <Tool
- Name="VCPreBuildEventTool"/>
- #endif
- <Tool
- Name="VCPreLinkEventTool"/>
- <Tool
- Name="VCResourceCompilerTool"/>
- </Configuration>
- </Configurations>
- <Files>
- <Filter
- Name="Build"
- Filter="">
- <File
- RelativePath="Sources.pp">
- </File>
- <File
- RelativePath="$[TARGET].vcproj">
- </File>
- </Filter>
- #if $[compile_sources]
- #foreach file $[sort $[compile_sources]]
- <File
- RelativePath="$[file]">
- #if $[or $[eq $[file],$[igateoutput]],$[eq $[file],$[igatemout]]]
- <FileConfiguration
- Name="Opt3-Win32|Win32">
- <Tool
- Name="VCCLCompilerTool"
- ObjectFile="$[patsubst %,$[%_obj],$[file]]"/>
- </FileConfiguration>
- #endif
- </File>
- #end file
- #endif
- </Files>
- <Globals>
- </Globals>
- </VisualStudioProject>
- #end $[TARGET].vcproj
- #end metalib_target lib_target
- /////////////////////////////////////////////////////////////////////
- // Now the static libraries. Again, we assume there's no interrogate
- // interfaces going on in here, and there's no question of this being
- // a metalib, making the rules relatively simple.
- /////////////////////////////////////////////////////////////////////
- #forscopes static_lib_target ss_lib_target
- #define target $[ODIR]\$[lib_prefix]$[TARGET].lib
- #define defines $[join ;,$[extra_defines]]
- #output $[TARGET].vcproj
- #format straight
- <?xml version="1.0" encoding = "Windows-1252"?>
- <VisualStudioProject
- ProjectType="Visual C++"
- Version="7.00"
- Name="$[TARGET]"
- ProjectGUID="{$[makeguid $[TARGET]]}"
- Keyword="CustomAppWizProj">
- <Platforms>
- <Platform
- Name="Win32"/>
- </Platforms>
- <Configurations>
- <Configuration
- Name="$[ODIR]|Win32"
- IntermediateDirectory="$[ODIR]"
- OutputDirectory="$[ODIR]"
- ConfigurationType="4">
- <Tool
- Name="VCCLCompilerTool"
- AdditionalOptions="/Zm350"
- AdditionalIncludeDirectories="$[converted_ipath]"
- PreprocessorDefinitions="$[defines]"
- RuntimeLibrary="2"/>
- <Tool
- Name="VCCustomBuildTool"/>
- <Tool
- Name="VCLibrarianTool"
- OutputFile="$[target]"/>
- <Tool
- Name="VCMIDLTool"/>
- <Tool
- Name="VCPostBuildEventTool"
- Description="Copying $[target] to $[install_lib_dir]..."
- CommandLine="$[COPYCMD] $[target] $[install_lib_dir]"/>
- <Tool
- Name="VCPreBuildEventTool"/>
- <Tool
- Name="VCPreLinkEventTool"/>
- <Tool
- Name="VCResourceCompilerTool"/>
- </Configuration>
- </Configurations>
- <Files>
- #if $[compile_sources]
- #foreach file $[sort $[compile_sources]]
- <File
- RelativePath="$[file]">
- </File>
- #end file
- #endif
- </Files>
- <Globals>
- </Globals>
- </VisualStudioProject>
- #end $[TARGET].vcproj
- #end static_lib_target ss_lib_target
- /////////////////////////////////////////////////////////////////////
- // And now, the bin_targets. These are normal C++ executables. No
- // interrogate, metalibs, or any such nonsense here.
- /////////////////////////////////////////////////////////////////////
- #forscopes bin_target
- #define target $[ODIR]\$[TARGET].exe
- #define defines $[join ;,$[extra_defines]]
- #output $[TARGET].vcproj
- #format straight
- <?xml version="1.0" encoding = "Windows-1252"?>
- <VisualStudioProject
- ProjectType="Visual C++"
- Version="7.00"
- Name="$[TARGET]"
- ProjectGUID="{$[makeguid $[TARGET]]}"
- Keyword="CustomAppWizProj">
- <Platforms>
- <Platform
- Name="Win32"/>
- </Platforms>
- <Configurations>
- <Configuration
- Name="$[ODIR]|Win32"
- IntermediateDirectory="$[ODIR]"
- OutputDirectory="$[ODIR]"
- ConfigurationType="1">
- <Tool
- Name="VCCLCompilerTool"
- AdditionalOptions="/Zm350"
- AdditionalIncludeDirectories="$[converted_ipath]"
- PreprocessorDefinitions="$[defines]"
- RuntimeLibrary="2"/>
- <Tool
- Name="VCCustomBuildTool"/>
- <Tool
- Name="VCLinkerTool"
- AdditionalDependencies="$[converted_libs] $[objects]"
- OutputFile="$[target]"
- AdditionalLibraryDirectories="$[converted_lpath]"/>
- <Tool
- Name="VCMIDLTool"/>
- <Tool
- Name="VCPostBuildEventTool"
- Description="Copying $[target] to $[install_bin_dir]..."
- CommandLine="$[COPYCMD] $[target] $[install_bin_dir]"/>
- <Tool
- Name="VCPreBuildEventTool"/>
- <Tool
- Name="VCPreLinkEventTool"/>
- <Tool
- Name="VCResourceCompilerTool"/>
- </Configuration>
- </Configurations>
- <Files>
- #if $[compile_sources]
- #foreach file $[sort $[compile_sources]]
- <File
- RelativePath="$[file]">
- </File>
- #end file
- #endif
- </Files>
- <Globals>
- </Globals>
- </VisualStudioProject>
- #end $[TARGET].vcproj
- #end bin_target
- //////////////////////////////////////////////////////////////////////
- #elif $[eq $[DIR_TYPE], group]
- //////////////////////////////////////////////////////////////////////
- // This is a group directory: a directory above a collection of source
- // directories, e.g. $DTOOL/src. We don't need to output anything in
- // this directory.
- //////////////////////////////////////////////////////////////////////
- #elif $[eq $[DIR_TYPE], toplevel]
- //////////////////////////////////////////////////////////////////////
- // This is the toplevel directory, e.g. $DTOOL. Here we build the
- // package solution file and also synthesize the dtool_config.h (or
- // whichever file) we need.
- //#define project_scopes */static_lib_target */ss_lib_target */lib_target */noinst_lib_target */test_lib_target */metalib_target */bin_target */test_bin_target
- #define project_scopes */metalib_target */lib_target */static_lib_target */ss_lib_target */bin_target
- #output $[PACKAGE].sln
- #format straight
- Microsoft Visual Studio Solution File, Format Version 7.00
- #forscopes $[project_scopes]
- Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "$[TARGET]", "$[osfilename $[PATH]]\$[TARGET].vcproj", "{$[makeguid $[TARGET]]}"
- EndProject
- #end $[project_scopes]
- Global
- GlobalSection(SolutionConfiguration) = preSolution
- ConfigName.0 = $[ODIR]
- EndGlobalSection
- GlobalSection(ProjectDependencies) = postSolution
- #forscopes $[project_scopes]
- #define count 0
- #foreach dependency $[DEPEND_DIRS]
- {$[makeguid $[TARGET]]}.$[count] = {$[makeguid $[dependency]]}
- #set count $[+ $[count],1]
- #end dependency
- #end $[project_scopes]
- EndGlobalSection
- GlobalSection(ProjectConfiguration) = postSolution
- #forscopes $[project_scopes]
- #define guid $[makeguid $[TARGET]]
- {$[guid]}.$[ODIR].ActiveCfg = $[ODIR]|Win32
- {$[guid]}.$[ODIR].Build.0 = $[ODIR]|Win32
- #end $[project_scopes]
- EndGlobalSection
- GlobalSection(ExtensibilityGlobals) = postSolution
- EndGlobalSection
- GlobalSection(ExtensibilityAddIns) = postSolution
- EndGlobalSection
- EndGlobal
- #end $[PACKAGE].sln
- // If there is a file called LocalSetup.pp in the package's top
- // directory, then invoke that. It might contain some further setup
- // instructions.
- #sinclude $[TOPDIRPREFIX]LocalSetup.msvc.pp
- #sinclude $[TOPDIRPREFIX]LocalSetup.pp
- //////////////////////////////////////////////////////////////////////
- #elif $[or $[eq $[DIR_TYPE], models],$[eq $[DIR_TYPE], models_toplevel],$[eq $[DIR_TYPE], models_group]]
- //////////////////////////////////////////////////////////////////////
- #include $[THISDIRPREFIX]Template.models.pp
- //////////////////////////////////////////////////////////////////////
- #endif // DIR_TYPE
|