More code cleanup:

- Drop premake5 namespace; everything is premake again
- Remove deprecated project and config APIs
This commit is contained in:
Jason Perkins 2013-09-13 11:15:36 -04:00
parent 24a5ba03ee
commit e681b636ec
82 changed files with 214 additions and 893 deletions

View File

@ -22,8 +22,6 @@
"base/criteria.lua",
"base/option.lua",
"base/tree.lua",
"base/project.lua",
"base/config.lua",
"base/help.lua",
-- configuration APIs

View File

@ -7,7 +7,7 @@
premake.make = {}
local make = premake.make
local solution = premake.solution
local project = premake5.project
local project = premake.project
---

View File

@ -7,9 +7,9 @@
premake.make.cpp = {}
local make = premake.make
local cpp = premake.make.cpp
local project = premake5.project
local config = premake5.config
local fileconfig = premake5.fileconfig
local project = premake.project
local config = premake.config
local fileconfig = premake.fileconfig
---

View File

@ -7,9 +7,9 @@
premake.make.cs = {}
local make = premake.make
local cs = premake.make.cs
local project = premake5.project
local config = premake5.config
local fileconfig = premake5.fileconfig
local project = premake.project
local config = premake.config
local fileconfig = premake.fileconfig
--

View File

@ -6,7 +6,7 @@
local make = premake.make
local solution = premake.solution
local project = premake5.project
local project = premake.project
--

View File

@ -7,8 +7,8 @@
premake.vstudio = {}
local vstudio = premake.vstudio
local solution = premake.solution
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
--
@ -90,11 +90,11 @@
-- Return true if the configuration kind is one of "Makefile" or "None". The
-- latter is generated like a Makefile project and excluded from the solution.
--
function vstudio.isMakefile(cfg)
return (cfg.kind == premake.MAKEFILE or cfg.kind == premake.NONE)
end
--
-- If a dependency of a project configuration is excluded from that particular

View File

@ -25,7 +25,7 @@
io.eol = "\r\n"
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.user", vstudio.cs2005.generate_user_ng)
else

View File

@ -8,9 +8,9 @@
local vstudio = premake.vstudio
local cs2005 = premake.vstudio.cs2005
local project = premake5.project
local config = premake5.config
local fileconfig = premake5.fileconfig
local project = premake.project
local config = premake.config
local fileconfig = premake.fileconfig
local dotnet = premake.tools.dotnet
@ -244,7 +244,7 @@
else
_p(2,'<DebugType>pdbonly</DebugType>')
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

View File

@ -5,7 +5,7 @@
--
local cs2005 = premake.vstudio.cs2005
local project = premake5.project
local project = premake.project
--

View File

@ -8,7 +8,7 @@
local vstudio = premake.vstudio
local sln2005 = premake.vstudio.sln2005
local solution = premake.solution
local project = premake5.project
local project = premake.project
local tree = premake.tree

View File

@ -9,9 +9,9 @@
local vstudio = premake.vstudio
local vc200x = premake.vstudio.vc200x
local context = premake.context
local project = premake5.project
local config = premake5.config
local fileconfig = premake5.fileconfig
local project = premake.project
local config = premake.config
local fileconfig = premake.fileconfig
---
@ -545,7 +545,7 @@
_x(4,'OutputFile="$(OutDir)\\%s"', cfg.buildtarget.name)
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
vc200x.additionalLibraryDirectories(cfg)
@ -982,7 +982,7 @@
function vc200x.basicRuntimeChecks(cfg)
if not premake.config.isoptimizedbuild(cfg)
if not config.isOptimizedBuild(cfg)
and not cfg.flags.Managed
and not cfg.flags.NoRuntimeChecks
then
@ -1065,7 +1065,7 @@
function vc200x.minimalRebuild(cfg)
if premake.config.isdebugbuild(cfg) and
if config.isDebugBuild(cfg) and
cfg.debugformat ~= "c7" and
not cfg.flags.NoMinimalRebuild and
not cfg.flags.Managed and

View File

@ -6,7 +6,7 @@
local vstudio = premake.vstudio
local vc200x = premake.vstudio.vc200x
local project = premake5.project
local project = premake.project
--

View File

@ -35,7 +35,7 @@
io.eol = "\r\n"
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.user", vstudio.cs2005.generate_user_ng)
else

View File

@ -8,9 +8,9 @@
local vc2010 = premake.vstudio.vc2010
local vstudio = premake.vstudio
local project = premake5.project
local config = premake5.config
local fileconfig = premake5.fileconfig
local project = premake.project
local config = premake.config
local fileconfig = premake.fileconfig
local tree = premake.tree
@ -695,7 +695,7 @@
value = "OldStyle"
elseif cfg.architecture == "x64" or
cfg.flags.Managed or
premake.config.isoptimizedbuild(cfg) or
config.isOptimizedBuild(cfg) or
cfg.flags.NoEditAndContinue
then
value = "ProgramDatabase"
@ -778,7 +778,7 @@
function vc2010.functionLevelLinking(cfg)
if premake.config.isoptimizedbuild(cfg) then
if config.isOptimizedBuild(cfg) then
_p(3,'<FunctionLevelLinking>true</FunctionLevelLinking>')
end
end
@ -843,7 +843,7 @@
function vc2010.intrinsicFunctions(cfg)
if premake.config.isoptimizedbuild(cfg) then
if config.isOptimizedBuild(cfg) then
_p(3,'<IntrinsicFunctions>true</IntrinsicFunctions>')
end
end
@ -851,7 +851,7 @@
function vc2010.linkIncremental(cfg)
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
@ -869,7 +869,7 @@
function vc2010.minimalRebuild(cfg)
if premake.config.isoptimizedbuild(cfg) or
if config.isOptimizedBuild(cfg) or
cfg.flags.NoMinimalRebuild or
cfg.flags.MultiProcessorCompile or
cfg.debugformat == premake.C7
@ -929,7 +929,7 @@
function vc2010.optimizeReferences(cfg)
if premake.config.isoptimizedbuild(cfg) then
if config.isOptimizedBuild(cfg) then
_p(3,'<EnableCOMDATFolding>true</EnableCOMDATFolding>')
_p(3,'<OptimizeReferences>true</OptimizeReferences>')
end
@ -1060,7 +1060,7 @@
end
function vc2010.stringPooling(cfg)
if premake.config.isoptimizedbuild(cfg) then
if config.isOptimizedBuild(cfg) then
_p(3,'<StringPooling>true</StringPooling>')
end
end

View File

@ -5,7 +5,7 @@
--
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
local tree = premake.tree

View File

@ -6,7 +6,7 @@
local vstudio = premake.vstudio
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -1151,7 +1151,7 @@
local prj = sln.projects[name]
if not prj then
prj = premake5.project.new(sln, name)
prj = premake.project.new(sln, name)
prj.group = api.scope.group or ""
premake.solution.addproject(sln, prj)
end

View File

@ -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

View File

@ -5,8 +5,8 @@
--
local solution = premake.solution
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
---
@ -155,7 +155,7 @@
--
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))
local f, err = io.open(fn, "wb")

View File

@ -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

View File

@ -6,8 +6,7 @@
premake.solution = { }
local solution = premake.solution
local oven = premake5.oven
local project = premake5.project
local project = premake.project
local configset = premake.configset
local context = premake.context
local tree = premake.tree
@ -180,7 +179,7 @@
-- fill in any calculated values
for _, cfg in ipairs(configs) do
cfg.solution = sln
premake5.config.bake(cfg)
premake.config.bake(cfg)
end
return configs
@ -296,26 +295,6 @@
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).
--
@ -438,29 +417,6 @@
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.
--

View File

@ -1,14 +1,13 @@
--
-- src/project/config.lua
-- 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 = {}
local project = premake5.project
local config = premake5.config
premake.config = {}
local project = premake.project
local config = premake.config
local context = premake.context
local oven = premake5.oven
--
@ -146,6 +145,21 @@
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
-- configuration. Adds file decorations, and handles relative path
@ -386,7 +400,7 @@
function config.getruntime(cfg)
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
end
@ -443,3 +457,34 @@
return default
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

View File

@ -4,11 +4,11 @@
-- 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 project = premake5.project
local project = premake.project
--

View File

@ -4,8 +4,8 @@
-- Copyright (c) 2011-2013 Jason Perkins and the Premake project
--
premake5.project = {}
local project = premake5.project
premake.project = {}
local project = premake.project
local configset = premake.configset
local context = premake.context
local tree = premake.tree
@ -204,12 +204,12 @@
-- and indexed for ordered iteration.
if not files[fname] then
local fcfg = premake5.fileconfig.new(fname, prj)
local fcfg = premake.fileconfig.new(fname, prj)
files[fname] = fcfg
table.insert(files, fcfg)
end
premake5.fileconfig.addconfig(files[fname], cfg)
premake.fileconfig.addconfig(files[fname], cfg)
end)
end
@ -256,7 +256,7 @@
local sequences = bases[file.basename]
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
fcfg.sequence = sequences[cfg] or 0
sequences[cfg] = fcfg.sequence + 1
@ -425,7 +425,7 @@
-- and short names and the build and link target.
-- TODO: Merge these two functions
premake5.config.bake(ctx)
premake.config.bake(ctx)
return ctx
end

View File

@ -7,7 +7,7 @@
premake.tools.dotnet = {}
local dotnet = premake.tools.dotnet
local project = premake5.project
local project = premake.project
dotnet.namestyle = "windows"

View File

@ -6,8 +6,8 @@
premake.tools.gcc = {}
local gcc = premake.tools.gcc
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
--

View File

@ -7,8 +7,8 @@
premake.tools.msc = {}
local msc = premake.tools.msc
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
--
@ -34,12 +34,12 @@
local flags = table.translate(cfg.flags, msc.cflags)
local runtime = iif(cfg.flags.StaticRuntime, "/MT", "/MD")
if premake.config.isdebugbuild(cfg) then
if config.isDebugBuild(cfg) then
runtime = runtime .. "d"
end
table.insert(flags, runtime)
if not premake.config.isoptimizedbuild(cfg) then
if not config.isOptimizedBuild(cfg) then
table.insert(flags, "/Od")
end
@ -135,7 +135,7 @@
table.insert(flags, "/MANIFEST")
end
if premake.config.isoptimizedbuild(cfg) then
if config.isOptimizedBuild(cfg) then
table.insert(flags, "/OPT:REF /OPT:ICF")
end

View File

@ -7,8 +7,8 @@
premake.tools.snc = {}
local snc = premake.tools.snc
local gcc = premake.tools.gcc
local config = premake5.config
local config = premake.config
--
-- SNC flags for specific systems and architectures.
@ -43,7 +43,7 @@
function snc.getcxxflags(cfg)
local flags = table.translate(cfg.flags, snc.cxxflags)
-- turn on exceptions and RTTI by default, to match other toolsets
if not cfg.flags.NoExceptions then
table.insert(flags, "-Xc+=exceptions")
@ -51,7 +51,7 @@
if not cfg.flags.NoRTTI then
table.insert(flags, "-Xc+=rtti")
end
return flags
end
@ -81,11 +81,11 @@
function snc.getldflags(cfg)
local flags = { }
if not cfg.flags.Symbols then
table.insert(flags, "-s")
end
return flags
end

View File

@ -7,7 +7,7 @@
local suite = test.declare("make_clang")
local make = premake.make
local cpp = premake.make.cpp
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_cpp_file_rules")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_flags")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_linking")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_pch")
local make = premake.make
local project = premake5.project
local project = premake.project

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_cpp_objects")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
local suite = test.declare("make_ps3")
local make = premake.make
local cpp = premake.make.cpp
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_cpp_target_rules")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("make_wiidev")
local make = premake.make
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
local suite = test.declare("make_cs_embed_files")
local make = premake.make
local cs = premake.make.cs
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
local suite = test.declare("make_cs_flags")
local make = premake.make
local cs = premake.make.cs
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
local suite = test.declare("make_cs_sources")
local make = premake.make
local cs = premake.make.cs
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2012_vcxproj_config_props")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
---

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2013_vcxproj_config_props")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
---

View File

@ -7,7 +7,7 @@
T.vstudio_cs2005_compiler_props = {}
local suite = T.vstudio_cs2005_compiler_props
local cs2005 = premake.vstudio.cs2005
local project = premake5.project
local project = premake.project
--
@ -15,12 +15,12 @@
--
local sln, prj
function suite.setup()
_ACTION = "vs2005"
sln, prj = test.createsolution()
end
local function prepare()
local cfg = project.getconfig(prj, "Debug")
cs2005.compilerProps(cfg)

View File

@ -7,7 +7,7 @@
T.vstudio_cs2005_debug_props = {}
local suite = T.vstudio_cs2005_debug_props
local cs2005 = premake.vstudio.cs2005
local project = premake5.project
local project = premake.project
--
@ -15,12 +15,12 @@
--
local sln, prj
function suite.setup()
_ACTION = "vs2005"
sln, prj = test.createsolution()
end
local function prepare()
local cfg = project.getconfig(prj, "Debug")
cs2005.debugProps(cfg)

View File

@ -7,7 +7,7 @@
T.vstudio_cs2005_output_props = {}
local suite = T.vstudio_cs2005_output_props
local cs2005 = premake.vstudio.cs2005
local project = premake5.project
local project = premake.project
--
@ -15,13 +15,13 @@
--
local sln
function suite.setup()
_ACTION = "vs2005"
sln = test.createsolution()
language "C#"
end
local function prepare()
local prj = premake.solution.getproject_ng(sln, 1)
local cfg = project.getconfig(prj, "Debug")
@ -42,7 +42,7 @@
end
--
--
-- Check handling of the intermediates directory.
--
@ -52,7 +52,7 @@
test.capture [[
<OutputPath>.\</OutputPath>
<IntermediateOutputPath>obj\Debug\</IntermediateOutputPath>
]]
]]
end
function suite.intermediateDirectory_onVs2010()
@ -62,6 +62,6 @@
<OutputPath>.\</OutputPath>
<BaseIntermediateOutputPath>obj\Debug\</BaseIntermediateOutputPath>
<IntermediateOutputPath>$(BaseIntermediateOutputPath)</IntermediateOutputPath>
]]
]]
end

View File

@ -24,7 +24,7 @@
platforms (platform)
prj = project ("MyProject")
language "C#"
cfg = premake5.project.getconfig(prj, "Debug", platform)
cfg = premake.project.getconfig(prj, "Debug", platform)
cs2005.propertyGroup(cfg)
end

View File

@ -20,7 +20,7 @@
end
local function prepare()
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCPreBuildEventTool(cfg)
end

View File

@ -20,7 +20,7 @@
end
local function prepare()
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCCLCompilerTool(cfg)
end

View File

@ -7,7 +7,7 @@
T.vstudio_vc200x_configuration = { }
local suite = T.vstudio_vc200x_configuration
local vc200x = premake.vstudio.vc200x
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
T.vstudio_vs200x_debugdir = { }
local suite = T.vstudio_vs200x_debugdir
local vc200x = premake.vstudio.vc200x
local project = premake5.project
local project = premake.project
--

View File

@ -36,7 +36,7 @@
end
local function prepare(platform)
local cfg = premake5.project.getconfig(prj, "Debug", platform)
local cfg = premake.project.getconfig(prj, "Debug", platform)
vc200x.VCLinkerTool(cfg)
end

View File

@ -22,7 +22,7 @@
end
local function prepare()
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCCLCompilerTool(cfg)
end

View File

@ -22,7 +22,7 @@
end
local function prepare()
local cfg = premake5.project.getconfig(prj, "Debug")
local cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCLinkerTool(cfg)
end

View File

@ -21,7 +21,7 @@
end
local function prepare()
local cfg = premake5.project.getconfig(prj, "Debug")
local cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCLinkerTool(cfg)
end

View File

@ -21,7 +21,7 @@
end
local function prepare()
local cfg = premake5.project.getconfig(prj, "Debug")
local cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCManifestTool(cfg)
end

View File

@ -22,7 +22,7 @@
local function prepare()
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCNMakeTool(cfg)
end

View File

@ -21,7 +21,7 @@
end
local function prepare()
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
vc200x.VCResourceCompilerTool(cfg)
end

View File

@ -6,7 +6,7 @@
local suite = test.declare("vstudio_vs2010_compile_settings")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
T.vstudio_vs2010_config_props = { }
local suite = T.vstudio_vs2010_config_props
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -7,19 +7,19 @@
T.vstudio_vs2010_debug_settings = { }
local suite = T.vstudio_vs2010_debug_settings
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--
-- Setup
-- Setup
--
local sln, prj, cfg
function suite.setup()
sln, prj = test.createsolution()
end
local function prepare()
cfg = project.getconfig(prj, "Debug")
vc2010.debugsettings(cfg)
@ -84,7 +84,7 @@
prepare()
test.capture [[
<LocalDebuggerEnvironment>key=value</LocalDebuggerEnvironment>
]]
]]
end
--
@ -97,6 +97,6 @@
test.capture [[
<LocalDebuggerEnvironment>key=value
foo=bar</LocalDebuggerEnvironment>
]]
]]
end

View File

@ -36,7 +36,7 @@
end
local function prepare(platform)
local cfg = premake5.project.getconfig(prj, "Debug", platform)
local cfg = premake.project.getconfig(prj, "Debug", platform)
vc2010.link(cfg)
end

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2010_item_def_group")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2010_link")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2010_nmake_props")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
T.vstudio_vs2010_output_props = { }
local suite = T.vstudio_vs2010_output_props
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -7,7 +7,7 @@
T.vstudio_vs2010_prop_sheet = { }
local suite = T.vstudio_vs2010_prop_sheet
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -6,7 +6,7 @@
local suite = test.declare("vs2010_resource_compiler")
local vc2010 = premake.vstudio.vc2010
local project = premake5.project
local project = premake.project
--

View File

@ -1,13 +1,13 @@
--
-- tests/config/test_linkinfo.lua
-- Test the config object's link target accessor.
-- Test the config object's link target accessor.
-- Copyright (c) 2012 Jason Perkins and the Premake project
--
T.config_linkinfo = { }
local suite = T.config_linkinfo
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
--
@ -30,7 +30,7 @@
--
-- Directory should be current (".") by default.
-- Directory should be current (".") by default.
--
function suite.directoryIsDot_onNoTargetDir()
@ -115,7 +115,7 @@
--
-- The import library extension should not change if the a
-- The import library extension should not change if the a
-- custom target extension is set.
--

View File

@ -6,7 +6,7 @@
T.config_links = { }
local suite = T.config_links
local config = premake5.config
local config = premake.config
--
@ -22,7 +22,7 @@
end
local function prepare(kind, part, linkage)
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
return config.getlinks(cfg, kind, part, linkage)
end

View File

@ -6,8 +6,8 @@
T.config_targetinfo = { }
local suite = T.config_targetinfo
local project = premake5.project
local config = premake5.config
local project = premake.project
local config = premake.config
--

View File

@ -21,7 +21,7 @@
local function prepare(buildcfg, platform)
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, buildcfg or "Debug", platform)
cfg = premake.project.getconfig(prj, buildcfg or "Debug", platform)
end
@ -56,7 +56,7 @@
prepare("Debug", "Shared")
test.isequal("DLL", cfg.platform)
end
--
@ -135,7 +135,7 @@
removeplatforms "*"
configurations { "Development", "Production" }
platforms { "x32", "x64" }
configmap {
[{"Debug", "Win32"}] = { "Development", "x32" },
[{"Debug", "PS3"}] = { "Development", "x64" },
@ -154,13 +154,13 @@
function suite.canBubbleUp_onConfiguration()
platforms { "XCUA", "XCUB" }
configuration { "CCU" }
configmap { XCUA = "CCU", XCUB = "CCU" }
project "MyProject"
platforms { "CCU" }
prepare("Debug", "XCUA")
test.isequal({"Debug", "CCU"}, {cfg.buildcfg, cfg.platform})
end

View File

@ -24,7 +24,7 @@
configurations ( buildcfgs )
end
prj = premake.solution.getproject_ng(sln, 1)
for cfg in premake5.project.eachconfig(prj) do
for cfg in premake.project.eachconfig(prj) do
_p(2,'%s:%s', cfg.buildcfg or "", cfg.platform or "")
end
end
@ -71,7 +71,7 @@
--
-- If platforms are supplied, they should be paired with build
-- If platforms are supplied, they should be paired with build
-- configurations, with the order of both maintained.
--
@ -118,7 +118,7 @@
]]
end
--
-- Test mapping a build configuration to a build config/platform pair.
-- This will cause a second platform to appear in the project, alongside
@ -153,7 +153,7 @@
]]
end
--
-- If there is overlap in the solution and project configuration lists,
-- the ordering at the project level should be maintained to avoid

View File

@ -7,7 +7,7 @@
T.project_filename = {}
local suite = T.project_filename
local project = premake5.project
local project = premake.project
--

View File

@ -20,7 +20,7 @@
local function prepare(buildcfg, platform)
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, buildcfg or "Debug", platform)
cfg = premake.project.getconfig(prj, buildcfg or "Debug", platform)
end

View File

@ -29,7 +29,7 @@
function suite.returnsTrue_onSolutionConfig()
prepare()
test.istrue(premake5.project.hasconfig(prj, "Debug"))
test.istrue(premake.project.hasconfig(prj, "Debug"))
end
@ -40,7 +40,7 @@
function suite.returnsTrue_onSolutionConfig()
configurations { "Custom" }
prepare()
test.istrue(premake5.project.hasconfig(prj, "Custom"))
test.istrue(premake.project.hasconfig(prj, "Custom"))
end
@ -52,7 +52,7 @@
project("MyProject2")
configurations { "Custom" }
prepare()
test.isfalse(premake5.project.hasconfig(prj, "Custom"))
test.isfalse(premake.project.hasconfig(prj, "Custom"))
end
@ -63,6 +63,6 @@
function suite.returnsFalse_onConfigRemoved()
removeconfigurations { "Debug" }
prepare()
test.isfalse(premake5.project.hasconfig(prj, "Debug"))
test.isfalse(premake.project.hasconfig(prj, "Debug"))
end

View File

@ -5,8 +5,8 @@
--
T.project_vpaths = { }
local suite = T.project_vpaths
local project = premake5.project
local suite = T.project_vpaths
local project = premake.project
--
@ -14,7 +14,7 @@
--
local sln
function suite.setup()
sln = test.createsolution()
end
@ -25,7 +25,7 @@
return project.getvpath(prj, cfg.files[1])
end
--
-- Test simple replacements
--
@ -93,7 +93,7 @@
files { "src/myproject/hello.h" }
vpaths { ["Source/Headers"] = "**.h" }
test.isequal("Source/Headers/hello.h", run())
end
end
function suite.MatchFilePattern_ToGroup_WithTrailingSlash()
files { "src/myproject/hello.h" }
@ -105,32 +105,32 @@
files { "src/myproject/hello.h" }
vpaths { ["Group/Headers"] = "**.h" }
test.isequal("Group/Headers/hello.h", run())
end
end
function suite.MatchFilePattern_ToGroup_Nested()
files { "src/myproject/hello.h" }
vpaths { ["Headers/*"] = "**.h" }
test.isequal("Headers/src/myproject/hello.h", run())
end
end
function suite.MatchFilePattern_ToGroup_Nested_OneStar()
files { "src/myproject/hello.h" }
vpaths { ["Headers/*"] = "**.h" }
test.isequal("Headers/src/myproject/hello.h", run())
end
end
function suite.MatchFilePatternWithPath_ToGroup_Nested()
files { "src/myproject/hello.h" }
vpaths { ["Headers/*"] = "src/**.h" }
test.isequal("Headers/myproject/hello.h", run())
end
end
--
-- Test with project locations
--
function suite.MatchPath_OnProjectLocationSet()
function suite.MatchPath_OnProjectLocationSet()
location "build"
files "src/hello.h"
vpaths { [""] = "src" }

View File

@ -24,8 +24,8 @@
local platforms = sln.platforms or {}
project("MyProject")
prj = premake.solution.getproject_ng(sln, "MyProject")
cfg = premake5.project.getconfig(prj, "Debug", platforms[1])
return premake5.project.getrelative(prj, cfg.objdir)
cfg = premake.project.getconfig(prj, "Debug", platforms[1])
return premake.project.getrelative(prj, cfg.objdir)
end

View File

@ -1,46 +0,0 @@
--
-- tests/test_project.lua
-- Automated test suite for the project support functions.
-- Copyright (c) 2008-2010 Jason Perkins and the Premake project
--
local _project = premake.project
T.project = { }
local cfg, result
function T.project.setup()
_ACTION = "gmake"
cfg = {}
cfg.project = {}
cfg.language = "C++"
cfg.files = {}
cfg.trimpaths = {}
cfg.platform = "Native"
result = "\n"
end
--
-- findproject() tests
--
function T.project.findproject_IsCaseSensitive()
local sln = test.createsolution()
local prj = test.createproject(sln)
premake.bake.buildconfigs()
test.isnil(premake.findproject("myproject"))
end
--
-- premake.getlinks() tests
--
function T.project.getlinks_OnMscSystemLibs()
_OPTIONS.cc = "msc"
cfg.links = { "user32", "gdi32" }
result = premake.getlinks(cfg, "all", "fullpath")
test.isequal("user32.lib gdi32.lib", table.concat(result, " "))
end

View File

@ -21,7 +21,7 @@
local function prepare()
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
end

View File

@ -7,7 +7,7 @@
local suite = test.declare("tools_gcc")
local gcc = premake.tools.gcc
local project = premake5.project
local project = premake.project
--
@ -23,7 +23,7 @@
local function prepare()
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, "Debug")
cfg = project.getconfig(prj, "Debug")
end

View File

@ -8,7 +8,7 @@
local suite = T.tools_msc
local msc = premake.tools.msc
local project = premake5.project
local project = premake.project
--
@ -24,7 +24,7 @@
local function prepare()
prj = premake.solution.getproject_ng(sln, 1)
cfg = premake5.project.getconfig(prj, "Debug")
cfg = project.getconfig(prj, "Debug")
end

View File

@ -22,7 +22,7 @@
end
local function prepare()
cfg = premake5.project.getconfig(prj, "Debug")
cfg = premake.project.getconfig(prj, "Debug")
end