Cleaned up vstudio linker elements. Fixes #150

This commit is contained in:
Sam Surtees 2016-03-01 22:11:33 +10:00
parent 0b6ad5b532
commit a0242bb955
2 changed files with 82 additions and 52 deletions

View File

@ -371,11 +371,17 @@
--
m.elements.linker = function(cfg, explicit)
return {
m.link,
m.lib,
m.linkLibraryDependencies,
}
if cfg.kind == p.STATICLIB then
return {
m.lib,
m.linkLibraryDependencies,
}
else
return {
m.link,
m.linkLibraryDependencies,
}
end
end
function m.linker(cfg)
@ -386,30 +392,22 @@
m.elements.link = function(cfg, explicit)
if cfg.kind == p.STATICLIB then
return {
m.subSystem,
m.generateDebugInformation,
m.optimizeReferences,
}
else
return {
m.subSystem,
m.generateDebugInformation,
m.optimizeReferences,
m.additionalDependencies,
m.additionalLibraryDirectories,
m.importLibrary,
m.entryPointSymbol,
m.generateMapFile,
m.moduleDefinitionFile,
m.treatLinkerWarningAsErrors,
m.ignoreDefaultLibraries,
m.largeAddressAware,
m.targetMachine,
m.additionalLinkOptions,
}
end
return {
m.subSystem,
m.generateDebugInformation,
m.optimizeReferences,
m.additionalDependencies,
m.additionalLibraryDirectories,
m.importLibrary,
m.entryPointSymbol,
m.generateMapFile,
m.moduleDefinitionFile,
m.treatLinkerWarningAsErrors,
m.ignoreDefaultLibraries,
m.largeAddressAware,
m.targetMachine,
m.additionalLinkOptions,
}
end
function m.link(cfg, explicit)
@ -428,15 +426,13 @@
m.elements.lib = function(cfg, explicit)
if cfg.kind == p.STATICLIB then
return {
m.treatLinkerWarningAsErrors,
m.targetMachine,
m.additionalLinkOptions,
}
else
return {}
end
return {
m.subSystem,
m.optimizeReferences,
m.treatLinkerWarningAsErrors,
m.targetMachine,
m.additionalLinkOptions,
}
end
function m.lib(cfg, explicit)

View File

@ -105,10 +105,9 @@
kind "StaticLib"
prepare()
test.capture [[
<Link>
<Lib>
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>false</GenerateDebugInformation>
</Link>
</Lib>
]]
end
@ -269,14 +268,55 @@
libdirs { "../lib", "../lib64" }
prepare()
test.capture [[
<Link>
<Lib>
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>false</GenerateDebugInformation>
</Link>
</Lib>
]]
end
--
-- Shared libraries do not use Lib tags in Visual Studio and
-- we should not emit any options like this.
--
function suite.sharedLibrariesLinkElement()
local real_link = premake.vstudio.vc2010.elements.lib
premake.vstudio.vc2010.elements.lib = function(cfg, explicit)
return { function(cfg) premake.vstudio.vc2010.element("Test", nil, "Testing") end }
end
prepare()
test.capture [[
<Link>
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>false</GenerateDebugInformation>
<ImportLibrary>bin\Debug\MyProject.lib</ImportLibrary>
</Link>
]]
premake.vstudio.vc2010.elements.lib = real_link
end
--
-- Static libraries do not use Link tags in Visual Studio and
-- we should not emit any options like this.
--
function suite.staticLibrariesLinkElement()
kind "StaticLib"
local real_link = premake.vstudio.vc2010.elements.link
premake.vstudio.vc2010.elements.link = function(cfg, explicit)
return { function(cfg) premake.vstudio.vc2010.element("Test", nil, "Testing") end }
end
prepare()
test.capture [[
<Lib>
<SubSystem>Windows</SubSystem>
</Lib>
]]
premake.vstudio.vc2010.elements.link = real_link
end
--
-- Check handling of the import library settings.
--
@ -317,11 +357,8 @@
linkoptions { "/kupo" }
prepare()
test.capture [[
<Link>
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>false</GenerateDebugInformation>
</Link>
<Lib>
<SubSystem>Windows</SubSystem>
<AdditionalOptions>/kupo %(AdditionalOptions)</AdditionalOptions>
</Lib>
]]
@ -433,11 +470,8 @@
flags { "FatalLinkWarnings" }
prepare()
test.capture [[
<Link>
<SubSystem>Windows</SubSystem>
<GenerateDebugInformation>false</GenerateDebugInformation>
</Link>
<Lib>
<SubSystem>Windows</SubSystem>
<TreatLibWarningAsErrors>true</TreatLibWarningAsErrors>
</Lib>
]]