Merged premake/premake-dev into default
This commit is contained in:
commit
b98af00c11
@ -22,8 +22,6 @@
|
|||||||
"base/criteria.lua",
|
"base/criteria.lua",
|
||||||
"base/option.lua",
|
"base/option.lua",
|
||||||
"base/tree.lua",
|
"base/tree.lua",
|
||||||
"base/project.lua",
|
|
||||||
"base/config.lua",
|
|
||||||
"base/help.lua",
|
"base/help.lua",
|
||||||
|
|
||||||
-- configuration APIs
|
-- configuration APIs
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
premake.make = {}
|
premake.make = {}
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
@ -19,9 +19,6 @@
|
|||||||
shortname = "GNU Make",
|
shortname = "GNU Make",
|
||||||
description = "Generate GNU makefiles for POSIX, MinGW, and Cygwin",
|
description = "Generate GNU makefiles for POSIX, MinGW, and Cygwin",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib" },
|
||||||
|
|
||||||
valid_languages = { "C", "C++", "C#" },
|
valid_languages = { "C", "C++", "C#" },
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
premake.make.cpp = {}
|
premake.make.cpp = {}
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cpp = premake.make.cpp
|
local cpp = premake.make.cpp
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
@ -7,9 +7,9 @@
|
|||||||
premake.make.cs = {}
|
premake.make.cs = {}
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cs = premake.make.cs
|
local cs = premake.make.cs
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -38,7 +38,7 @@
|
|||||||
function make.configmap(sln)
|
function make.configmap(sln)
|
||||||
for cfg in solution.eachconfig(sln) do
|
for cfg in solution.eachconfig(sln) do
|
||||||
_p('ifeq ($(config),%s)', cfg.shortname)
|
_p('ifeq ($(config),%s)', cfg.shortname)
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
local prjcfg = project.getconfig(prj, cfg.buildcfg, cfg.platform)
|
local prjcfg = project.getconfig(prj, cfg.buildcfg, cfg.platform)
|
||||||
if prjcfg then
|
if prjcfg then
|
||||||
_p(' %s_config = %s', make.tovar(prj.name), prjcfg.shortname)
|
_p(' %s_config = %s', make.tovar(prj.name), prjcfg.shortname)
|
||||||
@ -56,7 +56,7 @@
|
|||||||
|
|
||||||
function make.cleanrules(sln)
|
function make.cleanrules(sln)
|
||||||
_p('clean:')
|
_p('clean:')
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
local slnpath = solution.getlocation(sln)
|
local slnpath = solution.getlocation(sln)
|
||||||
local prjpath = project.getfilename(prj, make.getmakefilename(prj, true))
|
local prjpath = project.getfilename(prj, make.getmakefilename(prj, true))
|
||||||
local prjdir = path.getdirectory(path.getrelative(slnpath, prjpath))
|
local prjdir = path.getdirectory(path.getrelative(slnpath, prjpath))
|
||||||
@ -87,7 +87,7 @@
|
|||||||
_p(1,'@echo " all (default)"')
|
_p(1,'@echo " all (default)"')
|
||||||
_p(1,'@echo " clean"')
|
_p(1,'@echo " clean"')
|
||||||
|
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
_p(1,'@echo " %s"', prj.name)
|
_p(1,'@echo " %s"', prj.name)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -111,7 +111,7 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
function make.projectrules(sln)
|
function make.projectrules(sln)
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
local deps = project.getdependencies(prj)
|
local deps = project.getdependencies(prj)
|
||||||
deps = table.extract(deps, "name")
|
deps = table.extract(deps, "name")
|
||||||
_p('%s: %s', premake.esc(prj.name), table.concat(deps, " "))
|
_p('%s: %s', premake.esc(prj.name), table.concat(deps, " "))
|
||||||
|
@ -7,8 +7,8 @@
|
|||||||
premake.vstudio = {}
|
premake.vstudio = {}
|
||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -215,7 +215,7 @@
|
|||||||
local hascpp = false
|
local hascpp = false
|
||||||
local hasnet = false
|
local hasnet = false
|
||||||
local slnarch
|
local slnarch
|
||||||
for prj in solution.eachproject_ng(cfg.solution) do
|
for prj in solution.eachproject(cfg.solution) do
|
||||||
if project.iscpp(prj) then
|
if project.iscpp(prj) then
|
||||||
hascpp = true
|
hascpp = true
|
||||||
elseif project.isdotnet(prj) then
|
elseif project.isdotnet(prj) then
|
||||||
@ -269,7 +269,7 @@
|
|||||||
-- if the platform identifier matches a known system or architecture,
|
-- if the platform identifier matches a known system or architecture,
|
||||||
--
|
--
|
||||||
|
|
||||||
for prj in solution.eachproject_ng(cfg.solution) do
|
for prj in solution.eachproject(cfg.solution) do
|
||||||
if project.iscpp(prj) then
|
if project.iscpp(prj) then
|
||||||
hascpp = true
|
hascpp = true
|
||||||
elseif project.isdotnet(prj) then
|
elseif project.isdotnet(prj) then
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
io.eol = "\r\n"
|
io.eol = "\r\n"
|
||||||
io.esc = vs2005.esc
|
io.esc = vs2005.esc
|
||||||
|
|
||||||
premake.generate(sln, ".sln", vstudio.sln2005.generate_ng)
|
premake.generate(sln, ".sln", vstudio.sln2005.generate)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
@ -25,9 +25,9 @@
|
|||||||
io.eol = "\r\n"
|
io.eol = "\r\n"
|
||||||
io.esc = vs2005.esc
|
io.esc = vs2005.esc
|
||||||
|
|
||||||
if premake5.project.isdotnet(prj) then
|
if premake.project.isdotnet(prj) then
|
||||||
premake.generate(prj, ".csproj", vstudio.cs2005.generate_ng)
|
premake.generate(prj, ".csproj", vstudio.cs2005.generate)
|
||||||
premake.generate(prj, ".csproj.user", vstudio.cs2005.generate_user_ng)
|
premake.generate(prj, ".csproj.user", vstudio.cs2005.generate_user)
|
||||||
else
|
else
|
||||||
premake.generate(prj, ".vcproj", vstudio.vc200x.generate)
|
premake.generate(prj, ".vcproj", vstudio.vc200x.generate)
|
||||||
premake.generate(prj, ".vcproj.user", vstudio.vc200x.generate_user)
|
premake.generate(prj, ".vcproj.user", vstudio.vc200x.generate_user)
|
||||||
@ -69,10 +69,6 @@
|
|||||||
|
|
||||||
os = "windows",
|
os = "windows",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
-- The capabilities of this action
|
-- The capabilities of this action
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
|
|
||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local cs2005 = premake.vstudio.cs2005
|
local cs2005 = premake.vstudio.cs2005
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
local dotnet = premake.tools.dotnet
|
local dotnet = premake.tools.dotnet
|
||||||
|
|
||||||
|
|
||||||
@ -26,7 +26,7 @@
|
|||||||
"projectProperties",
|
"projectProperties",
|
||||||
}
|
}
|
||||||
|
|
||||||
function cs2005.generate_ng(prj)
|
function cs2005.generate(prj)
|
||||||
io.indent = " "
|
io.indent = " "
|
||||||
io.utf8()
|
io.utf8()
|
||||||
|
|
||||||
@ -244,7 +244,7 @@
|
|||||||
else
|
else
|
||||||
_p(2,'<DebugType>pdbonly</DebugType>')
|
_p(2,'<DebugType>pdbonly</DebugType>')
|
||||||
end
|
end
|
||||||
_p(2,'<Optimize>%s</Optimize>', iif(premake.config.isoptimizedbuild(cfg), "true", "false"))
|
_p(2,'<Optimize>%s</Optimize>', iif(config.isOptimizedBuild(cfg), "true", "false"))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,14 +5,14 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
local cs2005 = premake.vstudio.cs2005
|
local cs2005 = premake.vstudio.cs2005
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Generate a Visual Studio 200x C# user file, with support for the new platforms API.
|
-- Generate a Visual Studio 200x C# user file, with support for the new platforms API.
|
||||||
--
|
--
|
||||||
|
|
||||||
function cs2005.generate_user_ng(prj)
|
function cs2005.generate_user(prj)
|
||||||
io.indent = " "
|
io.indent = " "
|
||||||
|
|
||||||
_p('<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">')
|
_p('<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">')
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local sln2005 = premake.vstudio.sln2005
|
local sln2005 = premake.vstudio.sln2005
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local tree = premake.tree
|
local tree = premake.tree
|
||||||
|
|
||||||
|
|
||||||
@ -16,7 +16,7 @@
|
|||||||
-- Generate a Visual Studio 200x solution, with support for the new platforms API.
|
-- Generate a Visual Studio 200x solution, with support for the new platforms API.
|
||||||
--
|
--
|
||||||
|
|
||||||
function sln2005.generate_ng(sln)
|
function sln2005.generate(sln)
|
||||||
-- Mark the file as Unicode
|
-- Mark the file as Unicode
|
||||||
_p('\239\187\191')
|
_p('\239\187\191')
|
||||||
|
|
||||||
@ -96,7 +96,7 @@
|
|||||||
|
|
||||||
_x('Project("{%s}") = "%s", "%s", "{%s}"', vstudio.tool(prj), prj.name, prjpath, prj.uuid)
|
_x('Project("{%s}") = "%s", "%s", "{%s}"', vstudio.tool(prj), prj.name, prjpath, prj.uuid)
|
||||||
if _ACTION < "vs2012" then
|
if _ACTION < "vs2012" then
|
||||||
sln2005.projectdependencies_ng(prj)
|
sln2005.projectdependencies(prj)
|
||||||
end
|
end
|
||||||
_p('EndProject')
|
_p('EndProject')
|
||||||
end,
|
end,
|
||||||
@ -113,7 +113,7 @@
|
|||||||
-- Write out the list of project dependencies for a particular project.
|
-- Write out the list of project dependencies for a particular project.
|
||||||
--
|
--
|
||||||
|
|
||||||
function sln2005.projectdependencies_ng(prj)
|
function sln2005.projectdependencies(prj)
|
||||||
local deps = project.getdependencies(prj)
|
local deps = project.getdependencies(prj)
|
||||||
if #deps > 0 then
|
if #deps > 0 then
|
||||||
_p(1,'ProjectSection(ProjectDependencies) = postProject')
|
_p(1,'ProjectSection(ProjectDependencies) = postProject')
|
||||||
|
@ -24,10 +24,6 @@
|
|||||||
|
|
||||||
os = "windows",
|
os = "windows",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
-- The capabilities of this action
|
-- The capabilities of this action
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
||||||
|
@ -9,9 +9,9 @@
|
|||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local vc200x = premake.vstudio.vc200x
|
local vc200x = premake.vstudio.vc200x
|
||||||
local context = premake.context
|
local context = premake.context
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
@ -545,7 +545,7 @@
|
|||||||
_x(4,'OutputFile="$(OutDir)\\%s"', cfg.buildtarget.name)
|
_x(4,'OutputFile="$(OutDir)\\%s"', cfg.buildtarget.name)
|
||||||
|
|
||||||
if cfg.kind ~= premake.STATICLIB then
|
if cfg.kind ~= premake.STATICLIB then
|
||||||
_p(4,'LinkIncremental="%s"', iif(premake.config.canincrementallink(cfg) , 2, 1))
|
_p(4,'LinkIncremental="%s"', iif(config.canLinkIncremental(cfg) , 2, 1))
|
||||||
end
|
end
|
||||||
|
|
||||||
vc200x.additionalLibraryDirectories(cfg)
|
vc200x.additionalLibraryDirectories(cfg)
|
||||||
@ -982,7 +982,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc200x.basicRuntimeChecks(cfg)
|
function vc200x.basicRuntimeChecks(cfg)
|
||||||
if not premake.config.isoptimizedbuild(cfg)
|
if not config.isOptimizedBuild(cfg)
|
||||||
and not cfg.flags.Managed
|
and not cfg.flags.Managed
|
||||||
and not cfg.flags.NoRuntimeChecks
|
and not cfg.flags.NoRuntimeChecks
|
||||||
then
|
then
|
||||||
@ -1065,7 +1065,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc200x.minimalRebuild(cfg)
|
function vc200x.minimalRebuild(cfg)
|
||||||
if premake.config.isdebugbuild(cfg) and
|
if config.isDebugBuild(cfg) and
|
||||||
cfg.debugformat ~= "c7" and
|
cfg.debugformat ~= "c7" and
|
||||||
not cfg.flags.NoMinimalRebuild and
|
not cfg.flags.NoMinimalRebuild and
|
||||||
not cfg.flags.Managed and
|
not cfg.flags.Managed and
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local vc200x = premake.vstudio.vc200x
|
local vc200x = premake.vstudio.vc200x
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -24,7 +24,7 @@
|
|||||||
_p(1,'<Configurations>')
|
_p(1,'<Configurations>')
|
||||||
for cfg in project.eachconfig(prj) do
|
for cfg in project.eachconfig(prj) do
|
||||||
vc200x.userconfiguration(cfg)
|
vc200x.userconfiguration(cfg)
|
||||||
vc200x.debugdir_ng(cfg)
|
vc200x.debugdir(cfg)
|
||||||
_p(2,'</Configuration>')
|
_p(2,'</Configuration>')
|
||||||
end
|
end
|
||||||
_p(1,'</Configurations>')
|
_p(1,'</Configurations>')
|
||||||
@ -49,7 +49,7 @@
|
|||||||
-- Write out the debug settings for this project.
|
-- Write out the debug settings for this project.
|
||||||
--
|
--
|
||||||
|
|
||||||
function vc200x.debugdir_ng(cfg)
|
function vc200x.debugdir(cfg)
|
||||||
_p(3,'<DebugSettings')
|
_p(3,'<DebugSettings')
|
||||||
|
|
||||||
if cfg.debugcommand then
|
if cfg.debugcommand then
|
||||||
|
@ -35,9 +35,9 @@
|
|||||||
io.eol = "\r\n"
|
io.eol = "\r\n"
|
||||||
io.esc = vs2010.esc
|
io.esc = vs2010.esc
|
||||||
|
|
||||||
if premake5.project.isdotnet(prj) then
|
if premake.project.isdotnet(prj) then
|
||||||
premake.generate(prj, ".csproj", vstudio.cs2005.generate_ng)
|
premake.generate(prj, ".csproj", vstudio.cs2005.generate)
|
||||||
premake.generate(prj, ".csproj.user", vstudio.cs2005.generate_user_ng)
|
premake.generate(prj, ".csproj.user", vstudio.cs2005.generate_user)
|
||||||
else
|
else
|
||||||
premake.generate(prj, ".vcxproj", vstudio.vc2010.generate)
|
premake.generate(prj, ".vcxproj", vstudio.vc2010.generate)
|
||||||
premake.generate(prj, ".vcxproj.user", vstudio.vc2010.generateUser)
|
premake.generate(prj, ".vcxproj.user", vstudio.vc2010.generateUser)
|
||||||
@ -62,10 +62,6 @@
|
|||||||
|
|
||||||
os = "windows",
|
os = "windows",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
-- The capabilities of this action
|
-- The capabilities of this action
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
||||||
|
@ -8,9 +8,9 @@
|
|||||||
|
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
local tree = premake.tree
|
local tree = premake.tree
|
||||||
|
|
||||||
|
|
||||||
@ -695,7 +695,7 @@
|
|||||||
value = "OldStyle"
|
value = "OldStyle"
|
||||||
elseif cfg.architecture == "x64" or
|
elseif cfg.architecture == "x64" or
|
||||||
cfg.flags.Managed or
|
cfg.flags.Managed or
|
||||||
premake.config.isoptimizedbuild(cfg) or
|
config.isOptimizedBuild(cfg) or
|
||||||
cfg.flags.NoEditAndContinue
|
cfg.flags.NoEditAndContinue
|
||||||
then
|
then
|
||||||
value = "ProgramDatabase"
|
value = "ProgramDatabase"
|
||||||
@ -778,7 +778,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc2010.functionLevelLinking(cfg)
|
function vc2010.functionLevelLinking(cfg)
|
||||||
if premake.config.isoptimizedbuild(cfg) then
|
if config.isOptimizedBuild(cfg) then
|
||||||
_p(3,'<FunctionLevelLinking>true</FunctionLevelLinking>')
|
_p(3,'<FunctionLevelLinking>true</FunctionLevelLinking>')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -843,7 +843,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc2010.intrinsicFunctions(cfg)
|
function vc2010.intrinsicFunctions(cfg)
|
||||||
if premake.config.isoptimizedbuild(cfg) then
|
if config.isOptimizedBuild(cfg) then
|
||||||
_p(3,'<IntrinsicFunctions>true</IntrinsicFunctions>')
|
_p(3,'<IntrinsicFunctions>true</IntrinsicFunctions>')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -851,7 +851,7 @@
|
|||||||
|
|
||||||
function vc2010.linkIncremental(cfg)
|
function vc2010.linkIncremental(cfg)
|
||||||
if cfg.kind ~= premake.STATICLIB then
|
if cfg.kind ~= premake.STATICLIB then
|
||||||
_p(2,'<LinkIncremental>%s</LinkIncremental>', tostring(premake.config.canincrementallink(cfg)))
|
_p(2,'<LinkIncremental>%s</LinkIncremental>', tostring(config.canLinkIncremental(cfg)))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -869,7 +869,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc2010.minimalRebuild(cfg)
|
function vc2010.minimalRebuild(cfg)
|
||||||
if premake.config.isoptimizedbuild(cfg) or
|
if config.isOptimizedBuild(cfg) or
|
||||||
cfg.flags.NoMinimalRebuild or
|
cfg.flags.NoMinimalRebuild or
|
||||||
cfg.flags.MultiProcessorCompile or
|
cfg.flags.MultiProcessorCompile or
|
||||||
cfg.debugformat == premake.C7
|
cfg.debugformat == premake.C7
|
||||||
@ -929,7 +929,7 @@
|
|||||||
|
|
||||||
|
|
||||||
function vc2010.optimizeReferences(cfg)
|
function vc2010.optimizeReferences(cfg)
|
||||||
if premake.config.isoptimizedbuild(cfg) then
|
if config.isOptimizedBuild(cfg) then
|
||||||
_p(3,'<EnableCOMDATFolding>true</EnableCOMDATFolding>')
|
_p(3,'<EnableCOMDATFolding>true</EnableCOMDATFolding>')
|
||||||
_p(3,'<OptimizeReferences>true</OptimizeReferences>')
|
_p(3,'<OptimizeReferences>true</OptimizeReferences>')
|
||||||
end
|
end
|
||||||
@ -1060,7 +1060,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
function vc2010.stringPooling(cfg)
|
function vc2010.stringPooling(cfg)
|
||||||
if premake.config.isoptimizedbuild(cfg) then
|
if config.isOptimizedBuild(cfg) then
|
||||||
_p(3,'<StringPooling>true</StringPooling>')
|
_p(3,'<StringPooling>true</StringPooling>')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local tree = premake.tree
|
local tree = premake.tree
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local vstudio = premake.vstudio
|
local vstudio = premake.vstudio
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -24,10 +24,6 @@
|
|||||||
|
|
||||||
os = "windows",
|
os = "windows",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
-- The capabilities of this action
|
-- The capabilities of this action
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
||||||
|
@ -24,10 +24,6 @@
|
|||||||
|
|
||||||
os = "windows",
|
os = "windows",
|
||||||
|
|
||||||
-- temporary, until I can phase out the legacy implementations
|
|
||||||
|
|
||||||
isnextgen = true,
|
|
||||||
|
|
||||||
-- The capabilities of this action
|
-- The capabilities of this action
|
||||||
|
|
||||||
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
valid_kinds = { "ConsoleApp", "WindowedApp", "StaticLib", "SharedLib", "Makefile", "None" },
|
||||||
|
@ -61,7 +61,7 @@
|
|||||||
if a.onsolution then
|
if a.onsolution then
|
||||||
a.onsolution(sln)
|
a.onsolution(sln)
|
||||||
end
|
end
|
||||||
for prj in premake.solution.eachproject_ng(sln) do
|
for prj in premake.solution.eachproject(sln) do
|
||||||
if a.onproject and not prj.external then
|
if a.onproject and not prj.external then
|
||||||
a.onproject(prj)
|
a.onproject(prj)
|
||||||
end
|
end
|
||||||
|
@ -1151,7 +1151,7 @@
|
|||||||
|
|
||||||
local prj = sln.projects[name]
|
local prj = sln.projects[name]
|
||||||
if not prj then
|
if not prj then
|
||||||
prj = premake5.project.new(sln, name)
|
prj = premake.project.new(sln, name)
|
||||||
prj.group = api.scope.group or ""
|
prj.group = api.scope.group or ""
|
||||||
premake.solution.addproject(sln, prj)
|
premake.solution.addproject(sln, prj)
|
||||||
end
|
end
|
||||||
|
@ -1,56 +0,0 @@
|
|||||||
--
|
|
||||||
-- configs.lua
|
|
||||||
--
|
|
||||||
-- Functions for working with configuration objects (which can include
|
|
||||||
-- projects and solutions).
|
|
||||||
--
|
|
||||||
-- Copyright (c) 2008-2013 Jason Perkins and the Premake project
|
|
||||||
--
|
|
||||||
|
|
||||||
premake.config = {}
|
|
||||||
local config = premake.config
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Determine if a configuration represents a "debug" or "release" build.
|
|
||||||
-- This controls the runtime library selected for Visual Studio builds
|
|
||||||
-- (and might also be useful elsewhere).
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.config.isdebugbuild(cfg)
|
|
||||||
-- If any of the optimize flags are set, it's a release build
|
|
||||||
if cfg.flags.Optimize or cfg.flags.OptimizeSize or cfg.flags.OptimizeSpeed then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
-- If symbols are not defined, it's a release build
|
|
||||||
if not cfg.flags.Symbols then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Determines if this configuration can be linked incrementally.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.config.canincrementallink(cfg)
|
|
||||||
if cfg.kind == "StaticLib"
|
|
||||||
or config.isoptimizedbuild(cfg)
|
|
||||||
or cfg.flags.NoIncrementalLink then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Determine if this configuration uses one of the optimize flags.
|
|
||||||
-- Optimized builds get different treatment, such as full linking
|
|
||||||
-- instead of incremental.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.config.isoptimizedbuild(cfg)
|
|
||||||
return cfg.flags.Optimize or cfg.flags.OptimizeSize or cfg.flags.OptimizeSpeed
|
|
||||||
end
|
|
||||||
|
|
@ -5,13 +5,10 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Create a top-level namespace for Premake's own APIs. The premake5 namespace
|
-- Create a top-level namespace for Premake's own APIs
|
||||||
-- is a place to do next-gen (5.0) work without breaking the existing code (yet).
|
|
||||||
-- I think it will eventually go away.
|
|
||||||
--
|
--
|
||||||
|
|
||||||
premake = {}
|
premake = {}
|
||||||
premake5 = {}
|
|
||||||
premake.tools = {}
|
premake.tools = {}
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,8 +5,8 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
@ -155,7 +155,7 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
function premake.generate(obj, ext, callback)
|
function premake.generate(obj, ext, callback)
|
||||||
local fn = premake5.project.getfilename(obj, ext)
|
local fn = premake.project.getfilename(obj, ext)
|
||||||
printf("Generating %s...", path.getrelative(os.getcwd(), fn))
|
printf("Generating %s...", path.getrelative(os.getcwd(), fn))
|
||||||
|
|
||||||
local f, err = io.open(fn, "wb")
|
local f, err = io.open(fn, "wb")
|
||||||
@ -191,6 +191,23 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Wrap the provided value in double quotes if it contains spaces, or
|
||||||
|
-- if it contains a shell variable of the form $(...).
|
||||||
|
--
|
||||||
|
|
||||||
|
function premake.quoted(value)
|
||||||
|
local q = value:find(" ", 1, true)
|
||||||
|
if not q then
|
||||||
|
q = value:find("$%(.-%)", 1)
|
||||||
|
end
|
||||||
|
if q then
|
||||||
|
value = '"' .. value .. '"'
|
||||||
|
end
|
||||||
|
return value
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Sanity check the project information loaded from the scripts, to
|
-- Sanity check the project information loaded from the scripts, to
|
||||||
-- make sure it all meets some minimum requirements. Raises an error if
|
-- make sure it all meets some minimum requirements. Raises an error if
|
||||||
@ -203,7 +220,7 @@
|
|||||||
for sln in solution.each() do
|
for sln in solution.each() do
|
||||||
premake.validateSolution(sln, ctx)
|
premake.validateSolution(sln, ctx)
|
||||||
|
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
premake.validateProject(prj, ctx)
|
premake.validateProject(prj, ctx)
|
||||||
|
|
||||||
for cfg in project.eachconfig(prj) do
|
for cfg in project.eachconfig(prj) do
|
||||||
@ -232,7 +249,7 @@
|
|||||||
|
|
||||||
-- all project UUIDs must be unique
|
-- all project UUIDs must be unique
|
||||||
local uuids = {}
|
local uuids = {}
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
if uuids[prj.uuid] then
|
if uuids[prj.uuid] then
|
||||||
premake.error("projects '%s' and '%s' have the same UUID", uuids[prj.uuid], prj.name)
|
premake.error("projects '%s' and '%s' have the same UUID", uuids[prj.uuid], prj.name)
|
||||||
end
|
end
|
||||||
|
@ -1,576 +0,0 @@
|
|||||||
--
|
|
||||||
-- project.lua
|
|
||||||
-- Functions for working with the project data.
|
|
||||||
-- Copyright (c) 2002 Jason Perkins and the Premake project
|
|
||||||
--
|
|
||||||
|
|
||||||
premake.project = { }
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Returns an iterator for a set of build configuration settings. If a platform is
|
|
||||||
-- specified, settings specific to that platform and build configuration pair are
|
|
||||||
-- returned.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.eachconfig(prj, platform)
|
|
||||||
-- I probably have the project root config, rather than the actual project
|
|
||||||
if prj.project then prj = prj.project end
|
|
||||||
|
|
||||||
local cfgs = prj.solution.configurations
|
|
||||||
local i = 0
|
|
||||||
|
|
||||||
return function ()
|
|
||||||
i = i + 1
|
|
||||||
if i <= #cfgs then
|
|
||||||
return premake.getconfig(prj, cfgs[i], platform)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Iterator for a project's files; returns a file configuration object.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.project.eachfile(prj)
|
|
||||||
-- project root config contains the file config list
|
|
||||||
if not prj.project then prj = premake.getconfig(prj) end
|
|
||||||
local i = 0
|
|
||||||
local t = prj.files
|
|
||||||
return function ()
|
|
||||||
i = i + 1
|
|
||||||
if (i <= #t) then
|
|
||||||
local name = premake5.project.getrelative(prj, t[i])
|
|
||||||
local fcfg = prj.__fileconfigs[name]
|
|
||||||
fcfg.vpath = premake.project.getvpath(prj, fcfg.name)
|
|
||||||
return fcfg
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Given a map of supported platform identifiers, filters the solution's list
|
|
||||||
-- of platforms to match. A map takes the form of a table like:
|
|
||||||
--
|
|
||||||
-- { x32 = "Win32", x64 = "x64" }
|
|
||||||
--
|
|
||||||
-- Only platforms that are listed in both the solution and the map will be
|
|
||||||
-- included in the results. An optional default platform may also be specified;
|
|
||||||
-- if the result set would otherwise be empty this platform will be used.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.filterplatforms(sln, map, default)
|
|
||||||
local result = { }
|
|
||||||
local keys = { }
|
|
||||||
if sln.platforms then
|
|
||||||
for _, p in ipairs(sln.platforms) do
|
|
||||||
if map[p] and not table.contains(keys, map[p]) then
|
|
||||||
table.insert(result, p)
|
|
||||||
table.insert(keys, map[p])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if #result == 0 and default then
|
|
||||||
table.insert(result, default)
|
|
||||||
end
|
|
||||||
|
|
||||||
return result
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Locate a project by name; case insensitive.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.findproject(name)
|
|
||||||
for sln in premake.solution.each() do
|
|
||||||
for prj in premake.solution.eachproject(sln) do
|
|
||||||
if (prj.name == name) then
|
|
||||||
return prj
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Locate a file in a project with a given extension; used to locate "special"
|
|
||||||
-- items such as Windows .def files.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.findfile(prj, extension)
|
|
||||||
for _, fname in ipairs(prj.files) do
|
|
||||||
if fname:endswith(extension) then return fname end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Retrieve a configuration for a given project/configuration pairing.
|
|
||||||
-- @param prj
|
|
||||||
-- The project to query.
|
|
||||||
-- @param cfgname
|
|
||||||
-- The target build configuration; only settings applicable to this configuration
|
|
||||||
-- will be returned. May be nil to retrieve project-wide settings.
|
|
||||||
-- @param pltname
|
|
||||||
-- The target platform; only settings applicable to this platform will be returned.
|
|
||||||
-- May be nil to retrieve platform-independent settings.
|
|
||||||
-- @returns
|
|
||||||
-- A configuration object containing all the settings for the given platform/build
|
|
||||||
-- configuration pair.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getconfig(prj, cfgname, pltname)
|
|
||||||
-- might have the root configuration, rather than the actual project
|
|
||||||
prj = prj.project or prj
|
|
||||||
|
|
||||||
-- if platform is not included in the solution, use general settings instead
|
|
||||||
if pltname == "Native" or not table.contains(prj.solution.platforms or {}, pltname) then
|
|
||||||
pltname = nil
|
|
||||||
end
|
|
||||||
|
|
||||||
local key = (cfgname or "")
|
|
||||||
if pltname then key = key .. pltname end
|
|
||||||
return prj.__configs[key]
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Build a name from a build configuration/platform pair. The short name
|
|
||||||
-- is good for makefiles or anywhere a user will have to type it in. The
|
|
||||||
-- long name is more readable.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getconfigname(cfgname, platform, useshortname)
|
|
||||||
if cfgname then
|
|
||||||
local name = cfgname
|
|
||||||
if platform and platform ~= "Native" then
|
|
||||||
if useshortname then
|
|
||||||
name = name .. premake.platforms[platform].cfgsuffix
|
|
||||||
else
|
|
||||||
name = name .. "|" .. platform
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return iif(useshortname, name:lower(), name)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Returns a list of sibling projects on which the specified project depends.
|
|
||||||
-- This is used to list dependencies within a solution or workspace. Must
|
|
||||||
-- consider all configurations because Visual Studio does not support per-config
|
|
||||||
-- project dependencies.
|
|
||||||
--
|
|
||||||
-- @param prj
|
|
||||||
-- The project to query.
|
|
||||||
-- @returns
|
|
||||||
-- A list of dependent projects, as an array of objects.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getdependencies(prj)
|
|
||||||
-- make sure I've got the project and not root config
|
|
||||||
prj = prj.project or prj
|
|
||||||
|
|
||||||
local function add_to_project_list(depproj, results)
|
|
||||||
local dep = premake.findproject(depproj)
|
|
||||||
if dep and not table.contains(results, dep) then
|
|
||||||
table.insert(results, dep)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local results = { }
|
|
||||||
for _, cfg in pairs(prj.__configs) do
|
|
||||||
for _, link in ipairs(cfg.links) do
|
|
||||||
add_to_project_list(link, results)
|
|
||||||
end
|
|
||||||
for _, depproj in ipairs(cfg.dependson) do
|
|
||||||
add_to_project_list(depproj, results)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return results
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Uses information from a project (or solution) to format a filename.
|
|
||||||
--
|
|
||||||
-- @param prj
|
|
||||||
-- A project or solution object with the file naming information.
|
|
||||||
-- @param pattern
|
|
||||||
-- A naming pattern. The sequence "%%" will be replaced by the
|
|
||||||
-- project name.
|
|
||||||
-- @returns
|
|
||||||
-- A filename matching the specified pattern, with a relative path
|
|
||||||
-- from the current directory to the project location.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.project.getfilename(prj, pattern)
|
|
||||||
local fname = pattern:gsub("%%%%", prj.filename or prj.name)
|
|
||||||
fname = path.join(premake5.project.getlocation(prj), fname)
|
|
||||||
return path.getrelative(os.getcwd(), fname)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Returns a list of link targets. Kind may be one of:
|
|
||||||
-- siblings - linkable sibling projects
|
|
||||||
-- system - system (non-sibling) libraries
|
|
||||||
-- dependencies - all sibling dependencies, including non-linkable
|
|
||||||
-- all - return everything
|
|
||||||
--
|
|
||||||
-- Part may be one of:
|
|
||||||
-- name - the decorated library name with no directory
|
|
||||||
-- basename - the undecorated library name
|
|
||||||
-- directory - just the directory, no name
|
|
||||||
-- fullpath - full path with decorated name
|
|
||||||
-- object - return the project object of the dependency
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getlinks(cfg, kind, part)
|
|
||||||
-- if I'm building a list of link directories, include libdirs
|
|
||||||
local result = iif (part == "directory" and kind == "all", cfg.libdirs, {})
|
|
||||||
|
|
||||||
-- am I getting links for a configuration or a project?
|
|
||||||
local cfgname = iif(cfg.name == cfg.project.name, "", cfg.name)
|
|
||||||
|
|
||||||
-- how should files be named?
|
|
||||||
local pathstyle = premake.getpathstyle(cfg)
|
|
||||||
local namestyle = premake.getnamestyle(cfg)
|
|
||||||
|
|
||||||
local function canlink(source, target)
|
|
||||||
if (target.kind ~= "SharedLib" and target.kind ~= "StaticLib") then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
if project.iscpp(source) then
|
|
||||||
return project.iscpp(target)
|
|
||||||
elseif project.isdotnet(source) then
|
|
||||||
return project.isdotnet(target)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
for _, link in ipairs(cfg.links) do
|
|
||||||
local item
|
|
||||||
|
|
||||||
-- is this a sibling project?
|
|
||||||
local prj = premake.findproject(link)
|
|
||||||
if prj and kind ~= "system" then
|
|
||||||
|
|
||||||
local prjcfg = premake.getconfig(prj, cfgname, cfg.platform)
|
|
||||||
if kind == "dependencies" or canlink(cfg, prjcfg) then
|
|
||||||
if (part == "directory") then
|
|
||||||
item = path.rebase(prjcfg.linktarget.directory, prjcfg.location, cfg.location)
|
|
||||||
elseif (part == "basename") then
|
|
||||||
item = prjcfg.linktarget.basename
|
|
||||||
elseif (part == "fullpath") then
|
|
||||||
item = path.rebase(prjcfg.linktarget.fullpath, prjcfg.location, cfg.location)
|
|
||||||
elseif (part == "object") then
|
|
||||||
item = prjcfg
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
elseif not prj and (kind == "system" or kind == "all") then
|
|
||||||
|
|
||||||
if (part == "directory") then
|
|
||||||
local dir = path.getdirectory(link)
|
|
||||||
if (dir ~= ".") then
|
|
||||||
item = dir
|
|
||||||
end
|
|
||||||
elseif (part == "fullpath") then
|
|
||||||
item = link
|
|
||||||
if namestyle == "windows" then
|
|
||||||
if project.iscpp(cfg) then
|
|
||||||
item = item .. ".lib"
|
|
||||||
elseif project.isdotnet(cfg) then
|
|
||||||
item = item .. ".dll"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if item:find("/", nil, true) then
|
|
||||||
item = path.getrelative(cfg.basedir, item)
|
|
||||||
end
|
|
||||||
else
|
|
||||||
item = link
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
if item then
|
|
||||||
if pathstyle == "windows" and part ~= "object" then
|
|
||||||
item = path.translate(item, "\\")
|
|
||||||
end
|
|
||||||
if not table.contains(result, item) then
|
|
||||||
table.insert(result, item)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return result
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Gets the name style for a configuration, indicating what kind of prefix,
|
|
||||||
-- extensions, etc. should be used in target file names.
|
|
||||||
--
|
|
||||||
-- @param cfg
|
|
||||||
-- The configuration to check.
|
|
||||||
-- @returns
|
|
||||||
-- The target naming style, one of "windows", "posix", or "PS3".
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getnamestyle(cfg)
|
|
||||||
return premake.platforms[cfg.platform].namestyle or premake.gettool(cfg).namestyle or "posix"
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Gets the path style for a configuration, indicating what kind of path separator
|
|
||||||
-- should be used in target file names.
|
|
||||||
--
|
|
||||||
-- @param cfg
|
|
||||||
-- The configuration to check.
|
|
||||||
-- @returns
|
|
||||||
-- The target path style, one of "windows" or "posix".
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.getpathstyle(cfg)
|
|
||||||
if premake.action.current().os == "windows" then
|
|
||||||
return "windows"
|
|
||||||
else
|
|
||||||
return "posix"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Assembles a target for a particular tool/system/configuration.
|
|
||||||
--
|
|
||||||
-- @param cfg
|
|
||||||
-- The configuration to be targeted.
|
|
||||||
-- @param direction
|
|
||||||
-- One of 'build' for the build target, or 'link' for the linking target.
|
|
||||||
-- @param pathstyle
|
|
||||||
-- The path format, one of "windows" or "posix". This comes from the current
|
|
||||||
-- action: Visual Studio uses "windows", GMake uses "posix", etc.
|
|
||||||
-- @param namestyle
|
|
||||||
-- The file naming style, one of "windows" or "posix". This comes from the
|
|
||||||
-- current tool: GCC uses "posix", MSC uses "windows", etc.
|
|
||||||
-- @param system
|
|
||||||
-- The target operating system, which can modify the naming style. For example,
|
|
||||||
-- shared libraries on Mac OS X use a ".dylib" extension.
|
|
||||||
-- @returns
|
|
||||||
-- An object with these fields:
|
|
||||||
-- basename - the target with no directory or file extension
|
|
||||||
-- name - the target name and extension, with no directory
|
|
||||||
-- directory - relative path to the target, with no file name
|
|
||||||
-- prefix - the file name prefix
|
|
||||||
-- suffix - the file name suffix
|
|
||||||
-- fullpath - directory, name, and extension
|
|
||||||
-- bundlepath - the relative path and file name of the bundle
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.gettarget(cfg, direction, pathstyle, namestyle, system)
|
|
||||||
if system == "bsd" or system == "solaris" then
|
|
||||||
system = "linux"
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Fix things up based on the current system
|
|
||||||
local kind = cfg.kind
|
|
||||||
if project.iscpp(cfg) then
|
|
||||||
-- On Windows, shared libraries link against a static import library
|
|
||||||
if (namestyle == "windows" or system == "windows")
|
|
||||||
and kind == "SharedLib" and direction == "link"
|
|
||||||
and not cfg.flags.NoImportLib
|
|
||||||
then
|
|
||||||
kind = "StaticLib"
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Posix name conventions only apply to static libs on windows (by user request)
|
|
||||||
if namestyle == "posix" and system == "windows" and kind ~= "StaticLib" then
|
|
||||||
namestyle = "windows"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Initialize the target components
|
|
||||||
local field = iif(direction == "build", "target", "implib")
|
|
||||||
local name = cfg[field.."name"] or cfg.targetname or cfg.project.name
|
|
||||||
local dir = cfg[field.."dir"] or cfg.targetdir or path.getrelative(cfg.location, cfg.basedir)
|
|
||||||
local prefix = ""
|
|
||||||
local suffix = ""
|
|
||||||
local ext = ""
|
|
||||||
local bundlepath, bundlename
|
|
||||||
|
|
||||||
if namestyle == "windows" then
|
|
||||||
if kind == "ConsoleApp" or kind == "WindowedApp" then
|
|
||||||
ext = ".exe"
|
|
||||||
elseif kind == "SharedLib" then
|
|
||||||
ext = ".dll"
|
|
||||||
elseif kind == "StaticLib" then
|
|
||||||
ext = ".lib"
|
|
||||||
end
|
|
||||||
elseif namestyle == "posix" then
|
|
||||||
if kind == "WindowedApp" and system == "macosx" then
|
|
||||||
bundlename = name .. ".app"
|
|
||||||
bundlepath = path.join(dir, bundlename)
|
|
||||||
dir = path.join(bundlepath, "Contents/MacOS")
|
|
||||||
elseif kind == "SharedLib" then
|
|
||||||
prefix = "lib"
|
|
||||||
ext = iif(system == "macosx", ".dylib", ".so")
|
|
||||||
elseif kind == "StaticLib" then
|
|
||||||
prefix = "lib"
|
|
||||||
ext = ".a"
|
|
||||||
end
|
|
||||||
elseif namestyle == "PS3" then
|
|
||||||
if kind == "ConsoleApp" or kind == "WindowedApp" then
|
|
||||||
ext = ".elf"
|
|
||||||
elseif kind == "StaticLib" then
|
|
||||||
prefix = "lib"
|
|
||||||
ext = ".a"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
prefix = cfg[field.."prefix"] or cfg.targetprefix or prefix
|
|
||||||
suffix = cfg[field.."suffix"] or cfg.targetsuffix or suffix
|
|
||||||
ext = cfg[field.."extension"] or cfg.targetextension or ext
|
|
||||||
|
|
||||||
-- build the results object
|
|
||||||
local result = { }
|
|
||||||
result.basename = name .. suffix
|
|
||||||
result.name = prefix .. name .. suffix .. ext
|
|
||||||
result.directory = dir
|
|
||||||
result.prefix = prefix
|
|
||||||
result.suffix = suffix
|
|
||||||
result.fullpath = path.join(result.directory, result.name)
|
|
||||||
result.bundlepath = bundlepath or result.fullpath
|
|
||||||
|
|
||||||
if pathstyle == "windows" then
|
|
||||||
result.directory = path.translate(result.directory, "\\")
|
|
||||||
result.fullpath = path.translate(result.fullpath, "\\")
|
|
||||||
end
|
|
||||||
|
|
||||||
return result
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Return the appropriate tool interface, based on the target language and
|
|
||||||
-- any relevant command-line options.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.gettool(cfg)
|
|
||||||
if project.iscpp(cfg) then
|
|
||||||
if _OPTIONS.cc then
|
|
||||||
return premake[_OPTIONS.cc]
|
|
||||||
end
|
|
||||||
local action = premake.action.current()
|
|
||||||
if action.valid_tools then
|
|
||||||
return premake[action.valid_tools.cc[1]]
|
|
||||||
end
|
|
||||||
return premake.gcc
|
|
||||||
else
|
|
||||||
return premake.dotnet
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Given a source file path, return a corresponding virtual path based on
|
|
||||||
-- the vpath entries in the project. If no matching vpath entry is found,
|
|
||||||
-- the original path is returned.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.project.getvpath(prj, filename)
|
|
||||||
prj = prj.project
|
|
||||||
|
|
||||||
-- if there is no match, return the input filename
|
|
||||||
local vpath = filename
|
|
||||||
|
|
||||||
for replacement,patterns in pairs(prj.vpaths or {}) do
|
|
||||||
for _,pattern in ipairs(patterns) do
|
|
||||||
pattern = premake5.project.getrelative(prj, pattern)
|
|
||||||
|
|
||||||
-- does the filename match this vpath pattern?
|
|
||||||
local i = vpath:find(path.wildcards(pattern))
|
|
||||||
if i == 1 then
|
|
||||||
-- yes; trim the leading portion of the path
|
|
||||||
i = pattern:find("*", 1, true) or (pattern:len() + 1)
|
|
||||||
local leaf = vpath:sub(i)
|
|
||||||
if leaf:startswith("/") then
|
|
||||||
leaf = leaf:sub(2)
|
|
||||||
end
|
|
||||||
|
|
||||||
-- check for (and remove) stars in the replacement pattern.
|
|
||||||
-- If there are none, then trim all path info from the leaf
|
|
||||||
-- and use just the filename in the replacement (stars should
|
|
||||||
-- really only appear at the end; I'm cheating here)
|
|
||||||
local stem = ""
|
|
||||||
if replacement:len() > 0 then
|
|
||||||
stem, stars = replacement:gsub("%*", "")
|
|
||||||
if stars == 0 then
|
|
||||||
leaf = path.getname(leaf)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
vpath = path.join(stem, leaf)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- remove any dot ("./", "../") patterns from the start of the path
|
|
||||||
local changed
|
|
||||||
repeat
|
|
||||||
changed = true
|
|
||||||
if vpath:startswith("./") then
|
|
||||||
vpath = vpath:sub(3)
|
|
||||||
elseif vpath:startswith("../") then
|
|
||||||
vpath = vpath:sub(4)
|
|
||||||
else
|
|
||||||
changed = false
|
|
||||||
end
|
|
||||||
until not changed
|
|
||||||
|
|
||||||
return vpath
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Returns true if the solution contains at least one C/C++ project.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.hascppproject(sln)
|
|
||||||
for prj in premake.solution.eachproject(sln) do
|
|
||||||
if project.iscpp(prj) then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Returns true if the solution contains at least one .NET project.
|
|
||||||
--
|
|
||||||
|
|
||||||
function premake.hasdotnetproject(sln)
|
|
||||||
for prj in premake.solution.eachproject(sln) do
|
|
||||||
if project.isdotnet(prj) then
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
@ -6,8 +6,7 @@
|
|||||||
|
|
||||||
premake.solution = { }
|
premake.solution = { }
|
||||||
local solution = premake.solution
|
local solution = premake.solution
|
||||||
local oven = premake5.oven
|
local project = premake.project
|
||||||
local project = premake5.project
|
|
||||||
local configset = premake.configset
|
local configset = premake.configset
|
||||||
local context = premake.context
|
local context = premake.context
|
||||||
local tree = premake.tree
|
local tree = premake.tree
|
||||||
@ -180,7 +179,7 @@
|
|||||||
-- fill in any calculated values
|
-- fill in any calculated values
|
||||||
for _, cfg in ipairs(configs) do
|
for _, cfg in ipairs(configs) do
|
||||||
cfg.solution = sln
|
cfg.solution = sln
|
||||||
premake5.config.bake(cfg)
|
premake.config.bake(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
return configs
|
return configs
|
||||||
@ -226,7 +225,7 @@
|
|||||||
local counts = {}
|
local counts = {}
|
||||||
local configs = {}
|
local configs = {}
|
||||||
|
|
||||||
for prj in premake.solution.eachproject_ng(sln) do
|
for prj in premake.solution.eachproject(sln) do
|
||||||
for cfg in project.eachconfig(prj) do
|
for cfg in project.eachconfig(prj) do
|
||||||
-- get the dirs for this config, and remember the association
|
-- get the dirs for this config, and remember the association
|
||||||
local dirs = getobjdirs(cfg)
|
local dirs = getobjdirs(cfg)
|
||||||
@ -296,26 +295,6 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Iterate over the projects of a solution.
|
|
||||||
--
|
|
||||||
-- @param sln
|
|
||||||
-- The solution.
|
|
||||||
-- @returns
|
|
||||||
-- An iterator function.
|
|
||||||
--
|
|
||||||
|
|
||||||
function solution.eachproject(sln)
|
|
||||||
local i = 0
|
|
||||||
return function ()
|
|
||||||
i = i + 1
|
|
||||||
if i <= #sln.projects then
|
|
||||||
return premake.solution.getproject(sln, i)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Iterate over the projects of a solution (next-gen).
|
-- Iterate over the projects of a solution (next-gen).
|
||||||
--
|
--
|
||||||
@ -325,12 +304,12 @@
|
|||||||
-- An iterator function, returning project configurations.
|
-- An iterator function, returning project configurations.
|
||||||
--
|
--
|
||||||
|
|
||||||
function solution.eachproject_ng(sln)
|
function solution.eachproject(sln)
|
||||||
local i = 0
|
local i = 0
|
||||||
return function ()
|
return function ()
|
||||||
i = i + 1
|
i = i + 1
|
||||||
if i <= #sln.projects then
|
if i <= #sln.projects then
|
||||||
return premake.solution.getproject_ng(sln, i)
|
return premake.solution.getproject(sln, i)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -405,7 +384,7 @@
|
|||||||
-- build the tree of groups
|
-- build the tree of groups
|
||||||
|
|
||||||
local tr = tree.new()
|
local tr = tree.new()
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
local prjpath = path.join(prj.group, prj.name)
|
local prjpath = path.join(prj.group, prj.name)
|
||||||
local node = tree.add(tr, prjpath)
|
local node = tree.add(tr, prjpath)
|
||||||
node.project = prj
|
node.project = prj
|
||||||
@ -438,29 +417,6 @@
|
|||||||
solution.getlocation = project.getlocation
|
solution.getlocation = project.getlocation
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
-- Retrieve the project at a particular index.
|
|
||||||
--
|
|
||||||
-- @param sln
|
|
||||||
-- The solution.
|
|
||||||
-- @param idx
|
|
||||||
-- An index into the array of projects.
|
|
||||||
-- @returns
|
|
||||||
-- The project at the given index.
|
|
||||||
--
|
|
||||||
|
|
||||||
function solution.getproject(sln, idx)
|
|
||||||
-- retrieve the root configuration of the project, with all of
|
|
||||||
-- the global (not configuration specific) settings collapsed
|
|
||||||
local prj = sln.projects[idx]
|
|
||||||
local cfg = premake.getconfig(prj)
|
|
||||||
|
|
||||||
-- root configuration doesn't have a name; use the project's
|
|
||||||
cfg.name = prj.name
|
|
||||||
return cfg
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Retrieve the project configuration at a particular index.
|
-- Retrieve the project configuration at a particular index.
|
||||||
--
|
--
|
||||||
@ -472,7 +428,7 @@
|
|||||||
-- The project configuration at the given index.
|
-- The project configuration at the given index.
|
||||||
--
|
--
|
||||||
|
|
||||||
function solution.getproject_ng(sln, idx)
|
function solution.getproject(sln, idx)
|
||||||
-- to make testing a little easier, allow this function to
|
-- to make testing a little easier, allow this function to
|
||||||
-- accept an unbaked solution, and fix it on the fly
|
-- accept an unbaked solution, and fix it on the fly
|
||||||
if not sln.baked then
|
if not sln.baked then
|
||||||
@ -493,7 +449,7 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
function solution.hascppproject(sln)
|
function solution.hascppproject(sln)
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
if project.iscpp(prj) then
|
if project.iscpp(prj) then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@ -514,7 +470,7 @@
|
|||||||
--
|
--
|
||||||
|
|
||||||
function solution.hasdotnetproject(sln)
|
function solution.hasdotnetproject(sln)
|
||||||
for prj in solution.eachproject_ng(sln) do
|
for prj in solution.eachproject(sln) do
|
||||||
if project.isdotnet(prj) then
|
if project.isdotnet(prj) then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
@ -1,10 +1,19 @@
|
|||||||
--
|
--
|
||||||
-- string.lua
|
-- string.lua
|
||||||
-- Additions to Lua's built-in string functions.
|
-- Additions to Lua's built-in string functions.
|
||||||
-- Copyright (c) 2002-2008 Jason Perkins and the Premake project
|
-- Copyright (c) 2002-2013 Jason Perkins and the Premake project
|
||||||
--
|
--
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Returns true if the string has a match for the plain specified pattern
|
||||||
|
--
|
||||||
|
|
||||||
|
function string.contains(s, match)
|
||||||
|
return string.find(s, match, 1, true) ~= nil
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Returns an array of strings, each of which is a substring of s
|
-- Returns an array of strings, each of which is a substring of s
|
||||||
-- formed by splitting on boundaries formed by `pattern`.
|
-- formed by splitting on boundaries formed by `pattern`.
|
||||||
|
@ -31,11 +31,13 @@
|
|||||||
-- The tree to contain the new node.
|
-- The tree to contain the new node.
|
||||||
-- @param p
|
-- @param p
|
||||||
-- The path of the new node.
|
-- The path of the new node.
|
||||||
|
-- @param extraFields
|
||||||
|
-- A table containing key-value pairs to be added to any new nodes.
|
||||||
-- @returns
|
-- @returns
|
||||||
-- The new tree node.
|
-- The new tree node.
|
||||||
--
|
--
|
||||||
|
|
||||||
function tree.add(tr, p)
|
function tree.add(tr, p, extraFields)
|
||||||
-- Special case "." refers to the current node
|
-- Special case "." refers to the current node
|
||||||
if p == "." then
|
if p == "." then
|
||||||
return tr
|
return tr
|
||||||
@ -43,7 +45,7 @@
|
|||||||
|
|
||||||
-- Look for the immediate parent for this new node, creating it if necessary.
|
-- Look for the immediate parent for this new node, creating it if necessary.
|
||||||
-- Recurses to create as much of the tree as necessary.
|
-- Recurses to create as much of the tree as necessary.
|
||||||
local parentnode = tree.add(tr, path.getdirectory(p), onaddfunc)
|
local parentnode = tree.add(tr, path.getdirectory(p), extraFields)
|
||||||
|
|
||||||
-- Create the child if necessary
|
-- Create the child if necessary
|
||||||
local childname = path.getname(p)
|
local childname = path.getname(p)
|
||||||
@ -51,6 +53,11 @@
|
|||||||
if not childnode or childnode.path ~= p then
|
if not childnode or childnode.path ~= p then
|
||||||
childnode = tree.insert(parentnode, tree.new(childname))
|
childnode = tree.insert(parentnode, tree.new(childname))
|
||||||
childnode.path = p
|
childnode.path = p
|
||||||
|
if extraFields then
|
||||||
|
for k,v in pairs(extraFields) do
|
||||||
|
childnode[k] = v
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return childnode
|
return childnode
|
||||||
@ -275,7 +282,7 @@
|
|||||||
local node = tr.children[1]
|
local node = tr.children[1]
|
||||||
|
|
||||||
-- if this node has no children (it is the last node in the tree) I'm done
|
-- if this node has no children (it is the last node in the tree) I'm done
|
||||||
if #node.children == 0 then
|
if #node.children == 0 or node.trim == false then
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -279,7 +279,7 @@ int process_option(lua_State* L, const char* arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Make keys lowercase to avoid case issues */
|
/* Make keys lowercase to avoid case issues */
|
||||||
for (ptr = key; *ptr; ++ptr) { *ptr = tolower(*ptr); }
|
for (ptr = key; *ptr; ++ptr) { *ptr = (char)tolower(*ptr); }
|
||||||
|
|
||||||
/* Store it in the Options table, which is already on the stack */
|
/* Store it in the Options table, which is already on the stack */
|
||||||
lua_pushstring(L, value);
|
lua_pushstring(L, value);
|
||||||
|
@ -1,14 +1,13 @@
|
|||||||
--
|
--
|
||||||
-- src/project/config.lua
|
-- src/project/config.lua
|
||||||
-- Premake configuration object API
|
-- Premake configuration object API
|
||||||
-- Copyright (c) 2011-2012 Jason Perkins and the Premake project
|
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
|
||||||
--
|
--
|
||||||
|
|
||||||
premake5.config = {}
|
premake.config = {}
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
local context = premake.context
|
local context = premake.context
|
||||||
local oven = premake5.oven
|
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -146,6 +145,21 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Determines if this configuration can be linked incrementally.
|
||||||
|
--
|
||||||
|
|
||||||
|
function config.canLinkIncremental(cfg)
|
||||||
|
if cfg.kind == "StaticLib"
|
||||||
|
or config.isOptimizedBuild(cfg)
|
||||||
|
or cfg.flags.NoIncrementalLink then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Given a raw link target filename, properly format it for the given
|
-- Given a raw link target filename, properly format it for the given
|
||||||
-- configuration. Adds file decorations, and handles relative path
|
-- configuration. Adds file decorations, and handles relative path
|
||||||
@ -386,7 +400,7 @@
|
|||||||
|
|
||||||
function config.getruntime(cfg)
|
function config.getruntime(cfg)
|
||||||
local linkage = iif(cfg.flags.StaticRuntime, "Static", "Shared")
|
local linkage = iif(cfg.flags.StaticRuntime, "Static", "Shared")
|
||||||
local mode = iif(premake.config.isdebugbuild(cfg) and not cfg.flags.ReleaseRuntime, "Debug", "Release")
|
local mode = iif(config.isDebugBuild(cfg) and not cfg.flags.ReleaseRuntime, "Debug", "Release")
|
||||||
return linkage .. mode
|
return linkage .. mode
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -443,3 +457,34 @@
|
|||||||
|
|
||||||
return default
|
return default
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Determine if a configuration represents a "debug" or "release" build.
|
||||||
|
-- This controls the runtime library selected for Visual Studio builds
|
||||||
|
-- (and might also be useful elsewhere).
|
||||||
|
--
|
||||||
|
|
||||||
|
function config.isDebugBuild(cfg)
|
||||||
|
-- If any of the optimize flags are set, it's a release build
|
||||||
|
if cfg.flags.Optimize or cfg.flags.OptimizeSize or cfg.flags.OptimizeSpeed then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
-- If symbols are not defined, it's a release build
|
||||||
|
if not cfg.flags.Symbols then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Determine if this configuration uses one of the optimize flags.
|
||||||
|
-- Optimized builds get different treatment, such as full linking
|
||||||
|
-- instead of incremental.
|
||||||
|
--
|
||||||
|
|
||||||
|
function config.isOptimizedBuild(cfg)
|
||||||
|
return cfg.flags.Optimize or cfg.flags.OptimizeSize or cfg.flags.OptimizeSpeed
|
||||||
|
end
|
||||||
|
|
||||||
|
@ -4,11 +4,11 @@
|
|||||||
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
|
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
|
||||||
--
|
--
|
||||||
|
|
||||||
premake5.fileconfig = {}
|
premake.fileconfig = {}
|
||||||
|
|
||||||
local fileconfig = premake5.fileconfig
|
local fileconfig = premake.fileconfig
|
||||||
local context = premake.context
|
local context = premake.context
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -4,8 +4,8 @@
|
|||||||
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
|
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
|
||||||
--
|
--
|
||||||
|
|
||||||
premake5.project = {}
|
premake.project = {}
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local configset = premake.configset
|
local configset = premake.configset
|
||||||
local context = premake.context
|
local context = premake.context
|
||||||
local tree = premake.tree
|
local tree = premake.tree
|
||||||
@ -204,12 +204,12 @@
|
|||||||
-- and indexed for ordered iteration.
|
-- and indexed for ordered iteration.
|
||||||
|
|
||||||
if not files[fname] then
|
if not files[fname] then
|
||||||
local fcfg = premake5.fileconfig.new(fname, prj)
|
local fcfg = premake.fileconfig.new(fname, prj)
|
||||||
files[fname] = fcfg
|
files[fname] = fcfg
|
||||||
table.insert(files, fcfg)
|
table.insert(files, fcfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
premake5.fileconfig.addconfig(files[fname], cfg)
|
premake.fileconfig.addconfig(files[fname], cfg)
|
||||||
|
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
@ -256,7 +256,7 @@
|
|||||||
local sequences = bases[file.basename]
|
local sequences = bases[file.basename]
|
||||||
|
|
||||||
for cfg in project.eachconfig(prj) do
|
for cfg in project.eachconfig(prj) do
|
||||||
local fcfg = premake5.fileconfig.getconfig(file, cfg)
|
local fcfg = premake.fileconfig.getconfig(file, cfg)
|
||||||
if fcfg ~= nil and not fcfg.flags.ExcludeFromBuild then
|
if fcfg ~= nil and not fcfg.flags.ExcludeFromBuild then
|
||||||
fcfg.sequence = sequences[cfg] or 0
|
fcfg.sequence = sequences[cfg] or 0
|
||||||
sequences[cfg] = fcfg.sequence + 1
|
sequences[cfg] = fcfg.sequence + 1
|
||||||
@ -425,7 +425,7 @@
|
|||||||
-- and short names and the build and link target.
|
-- and short names and the build and link target.
|
||||||
-- TODO: Merge these two functions
|
-- TODO: Merge these two functions
|
||||||
|
|
||||||
premake5.config.bake(ctx)
|
premake.config.bake(ctx)
|
||||||
|
|
||||||
return ctx
|
return ctx
|
||||||
end
|
end
|
||||||
@ -722,13 +722,22 @@
|
|||||||
-- in the IDE, not the physical organization of the file system. So
|
-- in the IDE, not the physical organization of the file system. So
|
||||||
-- virtual paths are used when adding nodes.
|
-- virtual paths are used when adding nodes.
|
||||||
|
|
||||||
|
-- If the project script specifies a virtual path for a file, disable
|
||||||
|
-- the logic that could trim out empty root nodes from that path. If
|
||||||
|
-- the script writer wants an empty root node they should get it.
|
||||||
|
|
||||||
|
local flags
|
||||||
|
if fcfg.vpath ~= fcfg.relpath then
|
||||||
|
flags = { trim = false }
|
||||||
|
end
|
||||||
|
|
||||||
-- Virtual paths can overlap, potentially putting files with the same
|
-- Virtual paths can overlap, potentially putting files with the same
|
||||||
-- name in the same folder, even though they have different paths on
|
-- name in the same folder, even though they have different paths on
|
||||||
-- the underlying filesystem. The tree.add() call won't overwrite
|
-- the underlying filesystem. The tree.add() call won't overwrite
|
||||||
-- existing nodes, so provide the extra logic here. Start by getting
|
-- existing nodes, so provide the extra logic here. Start by getting
|
||||||
-- the parent folder node, creating it if necessary.
|
-- the parent folder node, creating it if necessary.
|
||||||
|
|
||||||
local parent = tree.add(tr, path.getdirectory(fcfg.vpath))
|
local parent = tree.add(tr, path.getdirectory(fcfg.vpath), flags)
|
||||||
local node = tree.insert(parent, tree.new(path.getname(fcfg.vpath)))
|
local node = tree.insert(parent, tree.new(path.getname(fcfg.vpath)))
|
||||||
|
|
||||||
-- Pass through value fetches to the file configuration
|
-- Pass through value fetches to the file configuration
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
premake.tools.dotnet = {}
|
premake.tools.dotnet = {}
|
||||||
local dotnet = premake.tools.dotnet
|
local dotnet = premake.tools.dotnet
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
dotnet.namestyle = "windows"
|
dotnet.namestyle = "windows"
|
||||||
|
|
||||||
|
@ -6,8 +6,8 @@
|
|||||||
|
|
||||||
premake.tools.gcc = {}
|
premake.tools.gcc = {}
|
||||||
local gcc = premake.tools.gcc
|
local gcc = premake.tools.gcc
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -97,6 +97,7 @@
|
|||||||
EnableSSE2 = "-msse2",
|
EnableSSE2 = "-msse2",
|
||||||
ExtraWarnings = "-Wall -Wextra",
|
ExtraWarnings = "-Wall -Wextra",
|
||||||
FatalWarnings = "-Werror",
|
FatalWarnings = "-Werror",
|
||||||
|
NoWarnings = "-w",
|
||||||
FloatFast = "-ffast-math",
|
FloatFast = "-ffast-math",
|
||||||
FloatStrict = "-ffloat-store",
|
FloatStrict = "-ffloat-store",
|
||||||
NoFramePointer = "-fomit-frame-pointer",
|
NoFramePointer = "-fomit-frame-pointer",
|
||||||
@ -164,7 +165,7 @@
|
|||||||
|
|
||||||
table.foreachi(cfg.forceincludes, function(value)
|
table.foreachi(cfg.forceincludes, function(value)
|
||||||
local fn = project.getrelative(cfg.project, value)
|
local fn = project.getrelative(cfg.project, value)
|
||||||
table.insert(result, string.format('-include "%s"', fn))
|
table.insert(result, string.format('-include %s', premake.quoted(fn)))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
return result
|
return result
|
||||||
@ -178,7 +179,8 @@
|
|||||||
function gcc.getincludedirs(cfg, dirs)
|
function gcc.getincludedirs(cfg, dirs)
|
||||||
local result = {}
|
local result = {}
|
||||||
for _, dir in ipairs(dirs) do
|
for _, dir in ipairs(dirs) do
|
||||||
table.insert(result, '-I"' .. project.getrelative(cfg.project, dir) .. '"')
|
dir = project.getrelative(cfg.project, dir)
|
||||||
|
table.insert(result, '-I' .. premake.quoted(dir))
|
||||||
end
|
end
|
||||||
return result
|
return result
|
||||||
end
|
end
|
||||||
|
@ -1,14 +1,14 @@
|
|||||||
--
|
--
|
||||||
-- msc.lua
|
-- msc.lua
|
||||||
-- Interface for the MS C/C++ compiler.
|
-- Interface for the MS C/C++ compiler.
|
||||||
-- Copyright (c) 2009-2012 Jason Perkins and the Premake project
|
-- Copyright (c) 2009-2013 Jason Perkins and the Premake project
|
||||||
--
|
--
|
||||||
|
|
||||||
|
|
||||||
premake.tools.msc = {}
|
premake.tools.msc = {}
|
||||||
local msc = premake.tools.msc
|
local msc = premake.tools.msc
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -34,12 +34,12 @@
|
|||||||
local flags = table.translate(cfg.flags, msc.cflags)
|
local flags = table.translate(cfg.flags, msc.cflags)
|
||||||
|
|
||||||
local runtime = iif(cfg.flags.StaticRuntime, "/MT", "/MD")
|
local runtime = iif(cfg.flags.StaticRuntime, "/MT", "/MD")
|
||||||
if premake.config.isdebugbuild(cfg) then
|
if config.isDebugBuild(cfg) then
|
||||||
runtime = runtime .. "d"
|
runtime = runtime .. "d"
|
||||||
end
|
end
|
||||||
table.insert(flags, runtime)
|
table.insert(flags, runtime)
|
||||||
|
|
||||||
if not premake.config.isoptimizedbuild(cfg) then
|
if not config.isOptimizedBuild(cfg) then
|
||||||
table.insert(flags, "/Od")
|
table.insert(flags, "/Od")
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -99,7 +99,7 @@
|
|||||||
|
|
||||||
table.foreachi(cfg.forceincludes, function(value)
|
table.foreachi(cfg.forceincludes, function(value)
|
||||||
local fn = project.getrelative(cfg.project, value)
|
local fn = project.getrelative(cfg.project, value)
|
||||||
table.insert(result, string.format('/FI"%s"', fn))
|
table.insert(result, "/FI" .. premake.quoted(fn))
|
||||||
end)
|
end)
|
||||||
|
|
||||||
return result
|
return result
|
||||||
@ -114,7 +114,8 @@
|
|||||||
function msc.getincludedirs(cfg, dirs)
|
function msc.getincludedirs(cfg, dirs)
|
||||||
local result = {}
|
local result = {}
|
||||||
for _, dir in ipairs(dirs) do
|
for _, dir in ipairs(dirs) do
|
||||||
table.insert(result, '-I"' .. project.getrelative(cfg.project, dir) .. '"')
|
dir = project.getrelative(cfg.project, dir)
|
||||||
|
table.insert(result, '-I' .. premake.quoted(dir))
|
||||||
end
|
end
|
||||||
return result
|
return result
|
||||||
end
|
end
|
||||||
@ -134,7 +135,7 @@
|
|||||||
table.insert(flags, "/MANIFEST")
|
table.insert(flags, "/MANIFEST")
|
||||||
end
|
end
|
||||||
|
|
||||||
if premake.config.isoptimizedbuild(cfg) then
|
if config.isOptimizedBuild(cfg) then
|
||||||
table.insert(flags, "/OPT:REF /OPT:ICF")
|
table.insert(flags, "/OPT:REF /OPT:ICF")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
premake.tools.snc = {}
|
premake.tools.snc = {}
|
||||||
local snc = premake.tools.snc
|
local snc = premake.tools.snc
|
||||||
local gcc = premake.tools.gcc
|
local gcc = premake.tools.gcc
|
||||||
local config = premake5.config
|
local config = premake.config
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
local suite = test.declare("make_clang")
|
local suite = test.declare("make_clang")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cpp = premake.make.cpp
|
local cpp = premake.make.cpp
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -19,7 +19,7 @@
|
|||||||
function suite.setup()
|
function suite.setup()
|
||||||
sln = test.createsolution()
|
sln = test.createsolution()
|
||||||
toolset "clang"
|
toolset "clang"
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_cpp_file_rules")
|
local suite = test.declare("make_cpp_file_rules")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
make.cppFileRules(prj)
|
make.cppFileRules(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_flags")
|
local suite = test.declare("make_flags")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -34,6 +34,6 @@
|
|||||||
includedirs { "src/include", "../include" }
|
includedirs { "src/include", "../include" }
|
||||||
prepare { "includes" }
|
prepare { "includes" }
|
||||||
test.capture [[
|
test.capture [[
|
||||||
INCLUDES += -I"src/include" -I"../include"
|
INCLUDES += -Isrc/include -I../include
|
||||||
]]
|
]]
|
||||||
end
|
end
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_linking")
|
local suite = test.declare("make_linking")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_pch")
|
local suite = test.declare("make_pch")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_cpp_objects")
|
local suite = test.declare("make_cpp_objects")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
make.cppObjects(prj)
|
make.cppObjects(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
local suite = test.declare("make_ps3")
|
local suite = test.declare("make_ps3")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cpp = premake.make.cpp
|
local cpp = premake.make.cpp
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -19,7 +19,7 @@
|
|||||||
function suite.setup()
|
function suite.setup()
|
||||||
sln = test.createsolution()
|
sln = test.createsolution()
|
||||||
system "ps3"
|
system "ps3"
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_cpp_target_rules")
|
local suite = test.declare("make_cpp_target_rules")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("make_wiidev")
|
local suite = test.declare("make_wiidev")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
local suite = test.declare("make_cs_embed_files")
|
local suite = test.declare("make_cs_embed_files")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cs = premake.make.cs
|
local cs = premake.make.cs
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
make.csEmbedFiles(prj, premake.tools.dotnet)
|
make.csEmbedFiles(prj, premake.tools.dotnet)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
local suite = test.declare("make_cs_flags")
|
local suite = test.declare("make_cs_flags")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cs = premake.make.cs
|
local cs = premake.make.cs
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
make.csFlags(cfg, premake.tools.dotnet)
|
make.csFlags(cfg, premake.tools.dotnet)
|
||||||
end
|
end
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
local suite = test.declare("make_cs_sources")
|
local suite = test.declare("make_cs_sources")
|
||||||
local make = premake.make
|
local make = premake.make
|
||||||
local cs = premake.make.cs
|
local cs = premake.make.cs
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
make.csSources(prj, premake.tools.dotnet)
|
make.csSources(prj, premake.tools.dotnet)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
make.defaultconfig(prj)
|
make.defaultconfig(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.commonProperties(prj)
|
cs2005.commonProperties(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.projectProperties(prj)
|
cs2005.projectProperties(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.targets(prj)
|
cs2005.targets(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2012_vcxproj_config_props")
|
local suite = test.declare("vs2012_vcxproj_config_props")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
vc2010.configurationProperties(cfg)
|
vc2010.configurationProperties(cfg)
|
||||||
end
|
end
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2013_vcxproj_config_props")
|
local suite = test.declare("vs2013_vcxproj_config_props")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
---
|
---
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
vc2010.configurationProperties(cfg)
|
vc2010.configurationProperties(cfg)
|
||||||
end
|
end
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.projectProperties(prj)
|
cs2005.projectProperties(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.assemblyReferences(prj)
|
cs2005.assemblyReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.buildEvents(prj)
|
cs2005.buildEvents(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_cs2005_compiler_props = {}
|
T.vstudio_cs2005_compiler_props = {}
|
||||||
local suite = T.vstudio_cs2005_compiler_props
|
local suite = T.vstudio_cs2005_compiler_props
|
||||||
local cs2005 = premake.vstudio.cs2005
|
local cs2005 = premake.vstudio.cs2005
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_cs2005_debug_props = {}
|
T.vstudio_cs2005_debug_props = {}
|
||||||
local suite = T.vstudio_cs2005_debug_props
|
local suite = T.vstudio_cs2005_debug_props
|
||||||
local cs2005 = premake.vstudio.cs2005
|
local cs2005 = premake.vstudio.cs2005
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.files(prj)
|
cs2005.files(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cs2005.applicationIcon(prj)
|
cs2005.applicationIcon(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_cs2005_output_props = {}
|
T.vstudio_cs2005_output_props = {}
|
||||||
local suite = T.vstudio_cs2005_output_props
|
local suite = T.vstudio_cs2005_output_props
|
||||||
local cs2005 = premake.vstudio.cs2005
|
local cs2005 = premake.vstudio.cs2005
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -23,7 +23,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local prj = premake.solution.getproject_ng(sln, 1)
|
local prj = premake.solution.getproject(sln, 1)
|
||||||
local cfg = project.getconfig(prj, "Debug")
|
local cfg = project.getconfig(prj, "Debug")
|
||||||
cs2005.outputProps(cfg)
|
cs2005.outputProps(cfg)
|
||||||
end
|
end
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
platforms (platform)
|
platforms (platform)
|
||||||
prj = project ("MyProject")
|
prj = project ("MyProject")
|
||||||
language "C#"
|
language "C#"
|
||||||
cfg = premake5.project.getconfig(prj, "Debug", platform)
|
cfg = premake.project.getconfig(prj, "Debug", platform)
|
||||||
cs2005.propertyGroup(cfg)
|
cs2005.propertyGroup(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 2)
|
prj = premake.solution.getproject(sln, 2)
|
||||||
cs2005.projectReferences(prj)
|
cs2005.projectReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -30,11 +30,11 @@
|
|||||||
local function prepare(language)
|
local function prepare(language)
|
||||||
prj1.language = language
|
prj1.language = language
|
||||||
prj2.language = language
|
prj2.language = language
|
||||||
prj2 = premake.solution.getproject_ng(sln, 2)
|
prj2 = premake.solution.getproject(sln, 2)
|
||||||
sln2005.projectdependencies_ng(prj2)
|
sln2005.projectdependencies(prj2)
|
||||||
prj3.language = language
|
prj3.language = language
|
||||||
prj3 = premake.solution.getproject_ng(sln, 3)
|
prj3 = premake.solution.getproject(sln, 3)
|
||||||
sln2005.projectdependencies_ng(prj3)
|
sln2005.projectdependencies(prj3)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc200x.assemblyReferences(prj)
|
vc200x.assemblyReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
cfg = premake5.project.getconfig(prj, "Debug")
|
cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCPreBuildEventTool(cfg)
|
vc200x.VCPreBuildEventTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
cfg = premake5.project.getconfig(prj, "Debug")
|
cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCCLCompilerTool(cfg)
|
vc200x.VCCLCompilerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vc200x_configuration = { }
|
T.vstudio_vc200x_configuration = { }
|
||||||
local suite = T.vstudio_vc200x_configuration
|
local suite = T.vstudio_vc200x_configuration
|
||||||
local vc200x = premake.vstudio.vc200x
|
local vc200x = premake.vstudio.vc200x
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local prj = premake.solution.getproject_ng(sln, 1)
|
local prj = premake.solution.getproject(sln, 1)
|
||||||
local cfg = project.getconfig(prj, "Debug", (prj.platforms or {})[1])
|
local cfg = project.getconfig(prj, "Debug", (prj.platforms or {})[1])
|
||||||
vc200x.configuration(cfg)
|
vc200x.configuration(cfg)
|
||||||
end
|
end
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vs200x_debugdir = { }
|
T.vstudio_vs200x_debugdir = { }
|
||||||
local suite = T.vstudio_vs200x_debugdir
|
local suite = T.vstudio_vs200x_debugdir
|
||||||
local vc200x = premake.vstudio.vc200x
|
local vc200x = premake.vstudio.vc200x
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
vc200x.debugdir_ng(cfg)
|
vc200x.debugdir(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
local cfg = premake5.project.getconfig(prj, "Debug", platform)
|
local cfg = premake.project.getconfig(prj, "Debug", platform)
|
||||||
vc200x.VCLinkerTool(cfg)
|
vc200x.VCLinkerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
cfg = premake5.project.getconfig(prj, "Debug")
|
cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCCLCompilerTool(cfg)
|
vc200x.VCCLCompilerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local cfg = premake5.project.getconfig(prj, "Debug")
|
local cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCLinkerTool(cfg)
|
vc200x.VCLinkerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc200x.files(prj)
|
vc200x.files(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local cfg = premake5.project.getconfig(prj, "Debug")
|
local cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCLinkerTool(cfg)
|
vc200x.VCLinkerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local cfg = premake5.project.getconfig(prj, "Debug")
|
local cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCManifestTool(cfg)
|
vc200x.VCManifestTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,8 +21,8 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = premake5.project.getconfig(prj, "Debug")
|
cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCNMakeTool(cfg)
|
vc200x.VCNMakeTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc200x.platforms(prj)
|
vc200x.platforms(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc200x.visualStudioProject(prj)
|
vc200x.visualStudioProject(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 2)
|
prj = premake.solution.getproject(sln, 2)
|
||||||
vc200x.projectReferences(prj)
|
vc200x.projectReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
cfg = premake5.project.getconfig(prj, "Debug")
|
cfg = premake.project.getconfig(prj, "Debug")
|
||||||
vc200x.VCResourceCompilerTool(cfg)
|
vc200x.VCResourceCompilerTool(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.assemblyReferences(prj)
|
vc2010.assemblyReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vstudio_vs2010_compile_settings")
|
local suite = test.declare("vstudio_vs2010_compile_settings")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vs2010_config_props = { }
|
T.vstudio_vs2010_config_props = { }
|
||||||
local suite = T.vstudio_vs2010_config_props
|
local suite = T.vstudio_vs2010_config_props
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
vc2010.configurationProperties(cfg)
|
vc2010.configurationProperties(cfg)
|
||||||
end
|
end
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vs2010_debug_settings = { }
|
T.vstudio_vs2010_debug_settings = { }
|
||||||
local suite = T.vstudio_vs2010_debug_settings
|
local suite = T.vstudio_vs2010_debug_settings
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
local cfg = premake5.project.getconfig(prj, "Debug", platform)
|
local cfg = premake.project.getconfig(prj, "Debug", platform)
|
||||||
vc2010.link(cfg)
|
vc2010.link(cfg)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.files(prj)
|
vc2010.files(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.filters_uniqueidentifiers(prj)
|
vc2010.filters_uniqueidentifiers(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(group)
|
local function prepare(group)
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.filters_filegroup(prj, group)
|
vc2010.filters_filegroup(prj, group)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.globals(prj)
|
vc2010.globals(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2010_item_def_group")
|
local suite = test.declare("vs2010_item_def_group")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2010_link")
|
local suite = test.declare("vs2010_link")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2010_nmake_props")
|
local suite = test.declare("vs2010_nmake_props")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
cfg = project.getconfig(prj, "Debug")
|
cfg = project.getconfig(prj, "Debug")
|
||||||
vc2010.nmakeProperties(cfg)
|
vc2010.nmakeProperties(cfg)
|
||||||
end
|
end
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vs2010_output_props = { }
|
T.vstudio_vs2010_output_props = { }
|
||||||
local suite = T.vstudio_vs2010_output_props
|
local suite = T.vstudio_vs2010_output_props
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
@ -22,7 +22,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
local prj = premake.solution.getproject_ng(sln, 1)
|
local prj = premake.solution.getproject(sln, 1)
|
||||||
local cfg = project.getconfig(prj, "Debug")
|
local cfg = project.getconfig(prj, "Debug")
|
||||||
vc2010.outputProperties(cfg)
|
vc2010.outputProperties(cfg)
|
||||||
end
|
end
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare()
|
local function prepare()
|
||||||
prj = premake.solution.getproject_ng(sln, 1)
|
prj = premake.solution.getproject(sln, 1)
|
||||||
vc2010.projectConfigurations(prj)
|
vc2010.projectConfigurations(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function prepare(platform)
|
local function prepare(platform)
|
||||||
prj = premake.solution.getproject_ng(sln, 2)
|
prj = premake.solution.getproject(sln, 2)
|
||||||
vc2010.projectReferences(prj)
|
vc2010.projectReferences(prj)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
T.vstudio_vs2010_prop_sheet = { }
|
T.vstudio_vs2010_prop_sheet = { }
|
||||||
local suite = T.vstudio_vs2010_prop_sheet
|
local suite = T.vstudio_vs2010_prop_sheet
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
local suite = test.declare("vs2010_resource_compiler")
|
local suite = test.declare("vs2010_resource_compiler")
|
||||||
local vc2010 = premake.vstudio.vc2010
|
local vc2010 = premake.vstudio.vc2010
|
||||||
local project = premake5.project
|
local project = premake.project
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
|
|
||||||
function suite.project_createsOnFirstUse()
|
function suite.project_createsOnFirstUse()
|
||||||
project("MyProject")
|
project("MyProject")
|
||||||
test.isnotnil(premake.solution.getproject_ng(sln, "MyProject"))
|
test.isnotnil(premake.solution.getproject(sln, "MyProject"))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -267,3 +267,20 @@
|
|||||||
tree.trimroot(tr)
|
tree.trimroot(tr)
|
||||||
test.isequal("tests", tr.children[1].path)
|
test.isequal("tests", tr.children[1].path)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Nodes with the key "trim" set to false should be removed.
|
||||||
|
--
|
||||||
|
|
||||||
|
function suite.trimroot_respectsTrimFlag()
|
||||||
|
local n = tree.add(tr, "A")
|
||||||
|
tree.add(tr, "A/1")
|
||||||
|
n.trim = false
|
||||||
|
tree.trimroot(tr)
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
A
|
||||||
|
1
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user