Ported virtual paths to new platform API

This commit is contained in:
Jason Perkins 2012-02-01 20:00:24 -05:00
parent 7e5f16312a
commit 257487b2de
7 changed files with 137 additions and 80 deletions

View File

@ -41,7 +41,7 @@
local fullpath = "" local fullpath = ""
-- split the file's path into it's component parts -- split the file's path into it's component parts
local folders = string.explode(file.fullpath, "/", true) local folders = string.explode(file.vpath, "/", true)
for i = 1, #folders - 1 do for i = 1, #folders - 1 do
if numFilters == 0 then if numFilters == 0 then
_p(1,'<ItemGroup>') _p(1,'<ItemGroup>')
@ -78,7 +78,7 @@
if #files > 0 then if #files > 0 then
_p(1,'<ItemGroup>') _p(1,'<ItemGroup>')
for _, file in ipairs(files) do for _, file in ipairs(files) do
local filter = path.getdirectory(file.fullpath) local filter = path.getdirectory(file.vpath)
if filter ~= "." then if filter ~= "." then
_p(2,'<%s Include=\"%s\">', group, path.translate(file.fullpath)) _p(2,'<%s Include=\"%s\">', group, path.translate(file.fullpath))
_p(3,'<Filter>%s</Filter>', path.translate(filter)) _p(3,'<Filter>%s</Filter>', path.translate(filter))

View File

@ -60,6 +60,7 @@
-- These file configurations contain: -- These file configurations contain:
-- --
-- fullpath - the relative path from the project to the file -- fullpath - the relative path from the project to the file
-- vpath - the file's virtual path, if specified, or fullpath if not
-- --
function project.eachfile(prj) function project.eachfile(prj)
@ -69,14 +70,17 @@
return function() return function()
i = i + 1 i = i + 1
if i <= #files then if i <= #files then
local fullpath = project.getrelative(prj, files[i])
local fcfg = {} local fcfg = {}
fcfg.fullpath = fullpath fcfg.fullpath = project.getrelative(prj, files[i])
return fcfg
-- local fcfg = prj.__fileconfigs[t[i]] local vpath = project.getvpath(prj, files[i])
-- fcfg.vpath = premake.project.getvpath(prj, fcfg.name) if vpath ~= files[i] then
fcfg.vpath = vpath
else
fcfg.vpath = fcfg.fullpath
end
return fcfg
end end
end end
end end
@ -237,10 +241,70 @@
local tr = premake.tree.new(prj.name) local tr = premake.tree.new(prj.name)
for fcfg in project.eachfile(prj) do for fcfg in project.eachfile(prj) do
local node = premake.tree.add(tr, fcfg.fullpath) local node = premake.tree.add(tr, fcfg.vpath)
node.cfg = fcfg node.cfg = fcfg
end end
premake.tree.sort(tr) premake.tree.sort(tr)
return tr return tr
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 project.getvpath(prj, filename)
-- if there is no match, return the input filename
local vpath = filename
-- file are always specified relative to the script, so the vpath
-- patterns do too. Get the script relative path
local relpath = path.getrelative(prj.basedir, filename)
for replacement,patterns in pairs(prj.vpaths or {}) do
for _,pattern in ipairs(patterns) do
-- does the filename match this vpath pattern?
local i = relpath: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 = relpath: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

View File

@ -88,6 +88,28 @@
end end
--
-- Check the structure of a file with a virtual path.
--
function suite.file_onVpath()
files { "src/hello.cpp" }
vpaths { ["Source Files"] = "**.cpp" }
prepare()
test.capture [[
<Filter
Name="Source Files"
Filter=""
>
<File
RelativePath="src\hello.cpp"
>
</File>
</Filter>
]]
end
-- --
-- Make sure that the special "build a C code" logic only gets triggered -- Make sure that the special "build a C code" logic only gets triggered
-- by actual C source code files. -- by actual C source code files.

View File

@ -1,50 +0,0 @@
--
-- tests/actions/vstudio/vc200x/test_filters.lua
-- Validate generation of filter blocks in Visual Studio 200x C/C++ projects.
-- Copyright (c) 2011 Jason Perkins and the Premake project
--
T.vs200x_filters = { }
local suite = T.vs200x_filters
local vc200x = premake.vstudio.vc200x
--
-- Setup/teardown
--
local sln, prj
function suite.setup()
_ACTION = "vs2008"
sln = test.createsolution()
end
local function prepare()
premake.bake.buildconfigs()
sln.vstudio_configs = premake.vstudio.buildconfigs(sln)
prj = premake.solution.getproject(sln,1)
end
--
-- File/filter assignment tests
--
function suite.Filter_UsesVirtualForm_OnVpath()
files { "src/hello.cpp" }
vpaths { ["Source Files"] = "**.cpp" }
prepare()
vc200x.Files(prj)
test.capture [[
<Filter
Name="Source Files"
Filter=""
>
<File
RelativePath="src\hello.cpp"
>
</File>
</Filter>
]]
end

View File

@ -105,7 +105,6 @@
dofile("actions/vstudio/vc200x/test_debug_settings.lua") dofile("actions/vstudio/vc200x/test_debug_settings.lua")
dofile("actions/vstudio/vc200x/test_configuration.lua") dofile("actions/vstudio/vc200x/test_configuration.lua")
dofile("actions/vstudio/vc200x/test_files.lua") dofile("actions/vstudio/vc200x/test_files.lua")
dofile("actions/vstudio/vc200x/test_filters.lua")
dofile("actions/vstudio/vc200x/test_linker_block.lua") dofile("actions/vstudio/vc200x/test_linker_block.lua")
dofile("actions/vstudio/vc200x/test_manifest_block.lua") dofile("actions/vstudio/vc200x/test_manifest_block.lua")
dofile("actions/vstudio/vc200x/test_mfc.lua") dofile("actions/vstudio/vc200x/test_mfc.lua")

View File

@ -1,12 +1,12 @@
-- --
-- tests/project/test_eachfile.lua -- tests/project/test_eachfile.lua
-- Automated test suite for the file iteration function. -- Automated test suite for the file iteration function.
-- Copyright (c) 2011 Jason Perkins and the Premake project -- Copyright (c) 2011-2012 Jason Perkins and the Premake project
-- --
T.project_eachfile = { } T.project_eachfile = { }
local suite = T.project_eachfile local suite = T.project_eachfile
local project = premake.project local project = premake5.project
-- --
@ -15,32 +15,55 @@
local sln, prj local sln, prj
function suite.setup() function suite.setup()
sln = test.createsolution() sln, prj = test.createsolution()
end end
local function prepare() local function prepare(field)
premake.bake.buildconfigs() if not field then
prj = premake.solution.getproject(sln, 1) field = "fullpath"
end
for file in project.eachfile(prj) do
_p(2, file[field])
end
end end
-- --
-- Tests -- Sanity check that all files are returned, with project relative paths.
-- --
function suite.ReturnsAllFiles() function suite.listsAllFiles()
files { "hello.h", "hello.c" } files { "hello.h", "hello.c" }
prepare() prepare()
local iter = project.eachfile(prj) test.capture [[
test.isequal("hello.h", iter().name) hello.h
test.isequal("hello.c", iter().name) hello.c
test.isnil(iter()) ]]
end end
--
-- Ensure that the virtual path field defaults to the real file path.
--
function suite.ReturnedObjectIncludesVpath() function suite.vpathsAreNil_onNoVpaths()
files { "hello.h", "hello.c" } files { "hello.h", "hello.c" }
prepare() prepare("vpath")
local iter = project.eachfile(prj) test.capture [[
test.isequal("hello.h", iter().vpath) hello.h
hello.c
]]
end
--
-- If a virtual path is specified, the vpath field should be set.
--
function suite.vpathSet_onVpath()
files { "hello.h", "hello.c" }
vpaths { Headers = "**.h" }
prepare("vpath")
test.capture [[
Headers/hello.h
hello.c
]]
end end

View File

@ -1,12 +1,12 @@
-- --
-- tests/project/test_vpaths.lua -- tests/project/test_vpaths.lua
-- Automated test suite for the project support functions. -- Automated test suite for the project support functions.
-- Copyright (c) 2011 Jason Perkins and the Premake project -- Copyright (c) 2011-2012 Jason Perkins and the Premake project
-- --
T.project_vpaths = { } T.project_vpaths = { }
local suite = T.project_vpaths local suite = T.project_vpaths
local project = premake.project local project = premake5.project
-- --
@ -19,8 +19,7 @@
end end
local function prepare() local function prepare()
premake.bake.buildconfigs() prj = premake.solution.getproject_ng(sln, 1)
prj = premake.solution.getproject(sln, 1)
end end