166707b
# Computes forge-related variables for use in the rest of the spec file
166707b
# Control variables, flags and arguments:
166707b
#   %{forgeurl<number>}  the project url on the target forge
166707b
#   %{tag<number>}       the packaged tag, OR
166707b
#   %{commit<number>}    the packaged commit, OR
166707b
#   %{version<number>}   the packaged version
166707b
#                          – %{version}/%{version0} are set via:
166707b
#                              Version:
166707b
#                          – because git is lacking a built-in version
166707b
#                            reference, %{version<number>} will be translated
166707b
#                            into %{tag<number>} using unreliable heuristics;
166707b
#                            set %{tag<number>} directly if those fail
166707b
#   %{date<number>}      the packaged timestamp
166707b
#   …                    %forgemeta will compute a huge number of variables:
166707b
#                          — the packager can override it by setting some of
166707b
#                            those before the %forgemeta call
166707b
#                          – use the -i flag to list those variables
166707b
#   -z <number>          only process the zth block of definitions
166707b
#                        "" for the no-suffix block
166707b
#   -i                   list the resulting variable values
166707b
#   -s                   silently ignore problems in %{forgeurl<number>}
166707b
#   -v                   be verbose
166707b
#   -a                   process all sources in one go, instead of using
166707b
#                        separate -z calls
166707b
%forgemeta(z:isva) %{lua:
c70110c
local      fedora = require "fedora.common"
c70110c
local       forge = require "fedora.srpm.forge"
c70110c
local     verbose =  rpm.expand("%{-v}") ~= ""
c70110c
local informative =  rpm.expand("%{-i}") ~= ""
c70110c
local      silent =  rpm.expand("%{-s}") ~= ""
c70110c
local  processall = (rpm.expand("%{-a}") ~= "") and (rpm.expand("%{-z}") == "")
c70110c
if processall then
c70110c
  for _,s in pairs(fedora.getsuffixes("forgeurl")) do
353f8b9
    forge.meta(s,verbose,informative,silent)
7c4cd33
  end
c70110c
else
353f8b9
  forge.meta(rpm.expand("%{-z*}"),verbose,informative,silent)
7c4cd33
end
7c4cd33
}
7c4cd33
166707b
# Unpacks sources computed by %forgemeta
166707b
# Control variables, flags and arguments:
166707b
#   %{forgesource<number>}       the source archive that will be processed
166707b
#   %{forgesetupargs<number>}    %setup arguments
166707b
166707b
#   -z <number>                  only process the zth block of definitions
166707b
#                                "" for the no-suffix block
166707b
#   -v                           be verbose
166707b
#   -a                   process all sources in one go, instead of using
166707b
#                        separate -z calls
166707b
%forgesetup(z:va) %{lua:
c70110c
local fedora = require "fedora.common"
c70110c
if (rpm.expand("%{-z}") == "") and (rpm.expand("%{-a}") ~= "") then
c70110c
  for _,s in pairs(fedora.getsuffixes("forgesetupargs")) do
c70110c
    print(rpm.expand("%setup %{!-v:-q} %{?forgesetupargs" .. s                     .. "}\\n"))
c70110c
  end
c70110c
else
c70110c
  print(  rpm.expand("%setup %{!-v:-q} %{?forgesetupargs" .. rpm.expand("%{-z*}") .. "}\\n"))
c70110c
end
c70110c
}
7c4cd33
166707b
# Calls %autosetup using %forgemeta results
166707b
#   – this will probably be removed since it is unsafe in presence of multiple
166707b
#     sources
166707b
# Control variables, flags and arguments:
166707b
#   -z <number>  process the zth block of definitions
166707b
#   -v -N -S -p  relayed to %autosetup
8ba2a65
%forgeautosetup(z:vNS:p:q) %{lua:
c70110c
print(rpm.expand("%autosetup %{-v} %{-N} %{?-S} %{?-p} %{?forgesetupargs" .. rpm.expand("%{-z*}") .. "}\\n"))
c70110c
}