new_package: create basic SRPM header as fallback
Make SRPM handover between macros even more graceful and reliable by auto-creating a basic SRPM header before attempting declaration of a different sub-package. With this change things will just work as long as the default %{source_name} %{source_summary} and %{source_description} are set by something to sensible values.
This commit is contained in:
parent
e416a7b3da
commit
a52af8dced
104
common.lua
104
common.lua
@ -1,5 +1,45 @@
|
|||||||
-- Convenience Lua functions that can be used within rpm macros
|
-- Convenience Lua functions that can be used within rpm macros
|
||||||
|
|
||||||
|
-- Reads an rpm variable. Unlike a basic rpm.expand("{?foo}"), returns nil if
|
||||||
|
-- the variable is unset, which is convenient in lua tests and enables
|
||||||
|
-- differentiating unset variables from variables set to ""
|
||||||
|
local function read(rpmvar)
|
||||||
|
if not rpmvar or
|
||||||
|
(rpm.expand("%{" .. rpmvar .. "}") == "%{" .. rpmvar .. "}") then
|
||||||
|
return nil
|
||||||
|
else
|
||||||
|
return rpm.expand("%{?" .. rpmvar .. "}")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Returns true if the macro that called this function had flag set
|
||||||
|
-- For example, hasflag("z") would give the following results:
|
||||||
|
-- %foo -z bar → true
|
||||||
|
-- %foo -z → true
|
||||||
|
-- %foo → false
|
||||||
|
local function hasflag(flag)
|
||||||
|
return (rpm.expand("%{-" .. flag .. "}") ~= "")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Returns the argument passed to flag in the macro that called this function
|
||||||
|
-- For example, readflag("z") would give the following results:
|
||||||
|
-- %foo -z bar → bar
|
||||||
|
-- %foo → nil
|
||||||
|
-- %foo -z "" → empty string
|
||||||
|
-- %foo -z '' → empty string
|
||||||
|
local function readflag(flag)
|
||||||
|
if not hasflag(flag) then
|
||||||
|
return nil
|
||||||
|
else
|
||||||
|
local a = rpm.expand("%{-" .. flag .. "*}")
|
||||||
|
-- Handle "" and '' as empty strings
|
||||||
|
if (a == '""') or (a == "''") then
|
||||||
|
a = ''
|
||||||
|
end
|
||||||
|
return a
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- Set a spec variable
|
-- Set a spec variable
|
||||||
-- Echo the result if verbose
|
-- Echo the result if verbose
|
||||||
local function explicitset(rpmvar, value, verbose)
|
local function explicitset(rpmvar, value, verbose)
|
||||||
@ -183,46 +223,76 @@ local function wordwrap(text)
|
|||||||
return output
|
return output
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Because rpmbuild will fail if a subpackage is declared before the source
|
||||||
|
-- package itself, provide a source package declaration shell as fallback.
|
||||||
|
local function srcpkg(verbose)
|
||||||
|
if verbose then
|
||||||
|
rpm.expand([[
|
||||||
|
%{echo:Creating a header for the SRPM from %%{source_name}, %%{source_summary} and}
|
||||||
|
%{echo:%%{source_description}. If that is not the intended result, please declare the}
|
||||||
|
%{echo:SRPM header and set %%{source_name} in your spec file before calling a macro}
|
||||||
|
%{echo:that creates other package headers.}
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
print(rpm.expand([[
|
||||||
|
Name: %{source_name}
|
||||||
|
Summary: %{source_summary}
|
||||||
|
%description
|
||||||
|
%wordwrap -v source_description
|
||||||
|
]]))
|
||||||
|
set("currentname", "%{source_name}", verbose)
|
||||||
|
end
|
||||||
|
|
||||||
-- The processing core of %new_package
|
-- The processing core of %new_package
|
||||||
local function new_package(source_name, pkg_name, name_suffix, previous_name, verbose)
|
local function new_package(source_name, pkg_name, name_suffix, first, verbose)
|
||||||
-- Safety net when the wrapper is used next to traditional syntax in a spec
|
-- Safety net when the wrapper is used in conjunction with traditional syntax
|
||||||
if (source_name == "") and (previous_name ~= "") then
|
if (not first) and (not source_name) then
|
||||||
rpm.expand(
|
rpm.expand([[
|
||||||
"%{warn:Something already set the following package name: " .. previous_name .. ".}" ..
|
%{warn:Something already set a package name. However, %%{source_name} is not set.}
|
||||||
"%{warn:However, %%{source_name} is empty. Please set the SRPM name in %%{source_name}!}")
|
%{warn:Please set %%{source_name} to the SRPM name to ensure reliable processing.}
|
||||||
if (name_suffix ~= "") then
|
]])
|
||||||
print(rpm.expand("\n%package " .. name_suffix))
|
if name_suffix then
|
||||||
|
print(rpm.expand("%package " .. name_suffix))
|
||||||
else
|
else
|
||||||
print(rpm.expand("\n%package -n " .. pkg_name))
|
print(rpm.expand("%package -n " .. pkg_name))
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
-- New processing
|
-- New processing
|
||||||
if (pkg_name == "") and (name_suffix ~= "") then
|
if name_suffix and not pkg_name then
|
||||||
pkg_name = name_suffix
|
pkg_name = name_suffix
|
||||||
if (source_name ~= "") then
|
if source_name then
|
||||||
pkg_name = source_name .. "-" .. name_suffix
|
pkg_name = source_name .. "-" .. name_suffix
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if (pkg_name == "") then
|
if not pkg_name then
|
||||||
if (source_name == "") then
|
if not source_name then
|
||||||
rpm.expand("%{error:You need to set %%{source_name} or provide explicit package naming!}")
|
rpm.expand([[
|
||||||
|
%{error:You need to set %%{source_name} or provide explicit package naming!}
|
||||||
|
]])
|
||||||
else
|
else
|
||||||
pkg_name = source_name
|
pkg_name = source_name
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if (source_name == "") then
|
if not source_name then
|
||||||
source_name = pkg_name
|
source_name = pkg_name
|
||||||
end
|
end
|
||||||
if (pkg_name == source_name) then
|
if (pkg_name == source_name) then
|
||||||
safeset("source_name", source_name, verbose)
|
safeset("source_name", source_name, verbose)
|
||||||
print(rpm.expand("\nName: %{source_name}"))
|
print(rpm.expand("Name: %{source_name}"))
|
||||||
else
|
else
|
||||||
print(rpm.expand("\n%package -n " .. pkg_name))
|
if source_name and first then
|
||||||
|
srcpkg(verbose)
|
||||||
|
end
|
||||||
|
print(rpm.expand("%package -n " .. pkg_name))
|
||||||
end
|
end
|
||||||
|
set("currentname", pkg_name, verbose)
|
||||||
end
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
read = read,
|
||||||
|
hasflag = hasflag,
|
||||||
|
readflag = readflag,
|
||||||
explicitset = explicitset,
|
explicitset = explicitset,
|
||||||
explicitunset = explicitunset,
|
explicitunset = explicitunset,
|
||||||
safeset = safeset,
|
safeset = safeset,
|
||||||
|
@ -47,11 +47,11 @@ print(fedora.wordwrap(variable))
|
|||||||
# Unlike %{name} %{source_name} matches the SRPM name regardless of its
|
# Unlike %{name} %{source_name} matches the SRPM name regardless of its
|
||||||
# location within the spec file.
|
# location within the spec file.
|
||||||
%new_package(n:v) %{lua:
|
%new_package(n:v) %{lua:
|
||||||
local fedora = require "fedora.common"
|
local fedora = require "fedora.common"
|
||||||
local source_name = rpm.expand("%{?source_name}")
|
local pkg_name = fedora.readflag("n")
|
||||||
local pkg_name = rpm.expand("%{-n*}")
|
local verbose = fedora.hasflag("v")
|
||||||
local name_suffix = rpm.expand("%{?1}")
|
local name_suffix = fedora.read("1")
|
||||||
local previous_name = rpm.expand("%{?name}")
|
local source_name = fedora.read("source_name")
|
||||||
local verbose = (rpm.expand("%{-v}") ~= "")
|
local first = not ( fedora.read("name") or fedora.read("currentname") )
|
||||||
fedora.new_package(source_name, pkg_name, name_suffix, previous_name, verbose)
|
fedora.new_package(source_name, pkg_name, name_suffix, first, verbose)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user