Added copylocal() API and NoCopyLocal build flag to control assembly reference copying in C# projects
This commit is contained in:
parent
4d653106e6
commit
f94ccff6d0
@ -277,16 +277,22 @@
|
|||||||
|
|
||||||
-- C# doesn't support per-configuration links (does it?) so just use
|
-- C# doesn't support per-configuration links (does it?) so just use
|
||||||
-- the settings from the first available config instead
|
-- the settings from the first available config instead
|
||||||
local links = config.getlinks(project.getfirstconfig(prj), "system", "fullpath")
|
local cfg = project.getfirstconfig(prj)
|
||||||
for _, link in ipairs(links) do
|
|
||||||
if link:find("/", nil, true) then
|
config.getlinks(cfg, "system", function(original, decorated)
|
||||||
_x(2,'<Reference Include="%s">', path.getbasename(link))
|
if decorated:find("/", nil, true) then
|
||||||
_x(3,'<HintPath>%s</HintPath>', path.translate(link))
|
_x(2,'<Reference Include="%s">', path.getbasename(decorated))
|
||||||
|
_x(3,'<HintPath>%s</HintPath>', path.translate(decorated))
|
||||||
|
|
||||||
|
if not config.isCopyLocal(prj, original, true) then
|
||||||
|
_p(3,"<Private>False</Private>")
|
||||||
|
end
|
||||||
|
|
||||||
_p(2,'</Reference>')
|
_p(2,'</Reference>')
|
||||||
else
|
else
|
||||||
_x(2,'<Reference Include="%s" />', path.getbasename(link))
|
_x(2,'<Reference Include="%s" />', path.getbasename(decorated))
|
||||||
end
|
end
|
||||||
end
|
end)
|
||||||
|
|
||||||
_p(1,'</ItemGroup>')
|
_p(1,'</ItemGroup>')
|
||||||
end
|
end
|
||||||
@ -306,6 +312,11 @@
|
|||||||
_x(2,'<ProjectReference Include="%s">', path.translate(relpath))
|
_x(2,'<ProjectReference Include="%s">', path.translate(relpath))
|
||||||
_p(3,'<Project>{%s}</Project>', dep.uuid)
|
_p(3,'<Project>{%s}</Project>', dep.uuid)
|
||||||
_x(3,'<Name>%s</Name>', dep.name)
|
_x(3,'<Name>%s</Name>', dep.name)
|
||||||
|
|
||||||
|
if not config.isCopyLocal(prj, dep.name, true) then
|
||||||
|
_p(3,"<Private>False</Private>")
|
||||||
|
end
|
||||||
|
|
||||||
_p(2,'</ProjectReference>')
|
_p(2,'</ProjectReference>')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -614,6 +614,13 @@
|
|||||||
kind = "string-list",
|
kind = "string-list",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
api.register {
|
||||||
|
name = "copylocal",
|
||||||
|
scope = "config",
|
||||||
|
kind = "mixed-list",
|
||||||
|
tokens = true,
|
||||||
|
}
|
||||||
|
|
||||||
api.register {
|
api.register {
|
||||||
name = "debugargs",
|
name = "debugargs",
|
||||||
scope = "config",
|
scope = "config",
|
||||||
@ -711,6 +718,7 @@
|
|||||||
"MultiProcessorCompile",
|
"MultiProcessorCompile",
|
||||||
"NativeWChar",
|
"NativeWChar",
|
||||||
"No64BitChecks",
|
"No64BitChecks",
|
||||||
|
"NoCopyLocal",
|
||||||
"NoEditAndContinue",
|
"NoEditAndContinue",
|
||||||
"NoExceptions",
|
"NoExceptions",
|
||||||
"NoFramePointer",
|
"NoFramePointer",
|
||||||
|
@ -274,6 +274,9 @@
|
|||||||
-- directory - just the directory, no name
|
-- directory - just the directory, no name
|
||||||
-- fullpath - full path with decorated name
|
-- fullpath - full path with decorated name
|
||||||
-- object - return the project object of the dependency
|
-- object - return the project object of the dependency
|
||||||
|
-- Or, a function(original, decorated) can be supplied, in which case it
|
||||||
|
-- will be called for each matching link, providing the original value as
|
||||||
|
-- it was specified in links(), and the decorated value.
|
||||||
-- @param linkage
|
-- @param linkage
|
||||||
-- Optional. For languages or environments that support different kinds of
|
-- Optional. For languages or environments that support different kinds of
|
||||||
-- linking (i.e. Managed/CLR C++, which can link both managed and unmanaged
|
-- linking (i.e. Managed/CLR C++, which can link both managed and unmanaged
|
||||||
@ -350,6 +353,8 @@
|
|||||||
item = path.getname(item)
|
item = path.getname(item)
|
||||||
elseif part == "basename" then
|
elseif part == "basename" then
|
||||||
item = path.getbasename(item)
|
item = path.getbasename(item)
|
||||||
|
elseif type(part) == "function" then
|
||||||
|
part(link, item)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -403,3 +408,34 @@
|
|||||||
function config.gettargetinfo(cfg)
|
function config.gettargetinfo(cfg)
|
||||||
return buildtargetinfo(cfg, cfg.kind, "target")
|
return buildtargetinfo(cfg, cfg.kind, "target")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- Determine if the specified library or assembly reference should be copied
|
||||||
|
-- to the build's target directory. "Copy Local" is the terminology used by
|
||||||
|
-- Visual Studio C# projects for this feature.
|
||||||
|
--
|
||||||
|
-- @param cfg
|
||||||
|
-- The configuration to query. Can be a project (and will be for C#
|
||||||
|
-- projects).
|
||||||
|
-- @param linkname
|
||||||
|
-- The name of the library or assembly reference to check. This should
|
||||||
|
-- match the name as it was provided in the call to links().
|
||||||
|
-- @param default
|
||||||
|
-- The value to return if the library is not mentioned in any settings.
|
||||||
|
-- @return
|
||||||
|
-- True if the library should be copied local, false otherwise.
|
||||||
|
--
|
||||||
|
|
||||||
|
function config.isCopyLocal(cfg, linkname, default)
|
||||||
|
if cfg.flags.NoCopyLocal then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
if #cfg.copylocal > 0 then
|
||||||
|
return table.contains(cfg.copylocal, linkname)
|
||||||
|
end
|
||||||
|
|
||||||
|
return default
|
||||||
|
end
|
||||||
|
@ -822,6 +822,7 @@
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- Returns true if the project uses a C/C++ language.
|
-- Returns true if the project uses a C/C++ language.
|
||||||
--
|
--
|
||||||
|
@ -88,3 +88,57 @@
|
|||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
]]
|
]]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- The assembly should not be copied to the target directory if the
|
||||||
|
-- NoCopyLocal flag has been set for the configuration.
|
||||||
|
--
|
||||||
|
|
||||||
|
function suite.markedPrivate_onNoCopyLocal()
|
||||||
|
links { "../Libraries/nunit.framework" }
|
||||||
|
flags { "NoCopyLocal" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<Reference Include="nunit.framework">
|
||||||
|
<HintPath>..\Libraries\nunit.framework.dll</HintPath>
|
||||||
|
<Private>False</Private>
|
||||||
|
</Reference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- If there are entries in the copylocal() list, then only those
|
||||||
|
-- specific libraries should be copied.
|
||||||
|
--
|
||||||
|
|
||||||
|
function suite.markedPrivate_onCopyLocalListExclusion()
|
||||||
|
links { "../Libraries/nunit.framework" }
|
||||||
|
copylocal { "SomeOtherProject" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<Reference Include="nunit.framework">
|
||||||
|
<HintPath>..\Libraries\nunit.framework.dll</HintPath>
|
||||||
|
<Private>False</Private>
|
||||||
|
</Reference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
function suite.notMarkedPrivate_onCopyLocalListInclusion()
|
||||||
|
links { "../Libraries/nunit.framework" }
|
||||||
|
copylocal { "../Libraries/nunit.framework" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<Reference Include="nunit.framework">
|
||||||
|
<HintPath>..\Libraries\nunit.framework.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
@ -94,3 +94,59 @@
|
|||||||
]]
|
]]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- The assembly should not be copied to the target directory if the
|
||||||
|
-- NoCopyLocal flag has been set for the configuration.
|
||||||
|
--
|
||||||
|
|
||||||
|
function suite.markedPrivate_onNoCopyLocal()
|
||||||
|
links { "MyProject" }
|
||||||
|
flags { "NoCopyLocal" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<ProjectReference Include="MyProject.vcproj">
|
||||||
|
<Project>{00112233-4455-6677-8888-99AABBCCDDEE}</Project>
|
||||||
|
<Name>MyProject</Name>
|
||||||
|
<Private>False</Private>
|
||||||
|
</ProjectReference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- If there are entries in the copylocal() list, then only those
|
||||||
|
-- specific libraries should be copied.
|
||||||
|
--
|
||||||
|
|
||||||
|
function suite.markedPrivate_onCopyLocalListExclusion()
|
||||||
|
links { "MyProject" }
|
||||||
|
copylocal { "SomeOtherProject" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<ProjectReference Include="MyProject.vcproj">
|
||||||
|
<Project>{00112233-4455-6677-8888-99AABBCCDDEE}</Project>
|
||||||
|
<Name>MyProject</Name>
|
||||||
|
<Private>False</Private>
|
||||||
|
</ProjectReference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
function suite.notMarkedPrivate_onCopyLocalListInclusion()
|
||||||
|
links { "MyProject" }
|
||||||
|
copylocal { "MyProject" }
|
||||||
|
prepare()
|
||||||
|
test.capture [[
|
||||||
|
<ItemGroup>
|
||||||
|
<ProjectReference Include="MyProject.vcproj">
|
||||||
|
<Project>{00112233-4455-6677-8888-99AABBCCDDEE}</Project>
|
||||||
|
<Name>MyProject</Name>
|
||||||
|
</ProjectReference>
|
||||||
|
</ItemGroup>
|
||||||
|
]]
|
||||||
|
end
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user