Backport %check from rpm-4.2
This commit is contained in:
parent
5a5dbf181d
commit
31914b95af
@ -97,6 +97,12 @@ int doScript(Spec spec, int what, const char *name, StringBuf sb, int test)
|
|||||||
mTemplate = "%{?__spec_install_template}";
|
mTemplate = "%{?__spec_install_template}";
|
||||||
mPost = "%{?__spec_install_post}";
|
mPost = "%{?__spec_install_post}";
|
||||||
break;
|
break;
|
||||||
|
case RPMBUILD_CHECK:
|
||||||
|
name = "%check";
|
||||||
|
sb = spec->check;
|
||||||
|
mTemplate = "%{__spec_check_template}";
|
||||||
|
mPost = "%{__spec_check_post}";
|
||||||
|
break;
|
||||||
case RPMBUILD_CLEAN:
|
case RPMBUILD_CLEAN:
|
||||||
name = "%clean";
|
name = "%clean";
|
||||||
sb = spec->clean;
|
sb = spec->clean;
|
||||||
@ -321,6 +327,10 @@ int buildSpec(Spec spec, int what, int test)
|
|||||||
(rc = doScript(spec, RPMBUILD_INSTALL, NULL, NULL, test)))
|
(rc = doScript(spec, RPMBUILD_INSTALL, NULL, NULL, test)))
|
||||||
goto exit;
|
goto exit;
|
||||||
|
|
||||||
|
if ((what & RPMBUILD_CHECK) &&
|
||||||
|
(rc = doScript(spec, RPMBUILD_CHECK, NULL, NULL, test)))
|
||||||
|
goto exit;
|
||||||
|
|
||||||
if ((what & RPMBUILD_PACKAGESOURCE) &&
|
if ((what & RPMBUILD_PACKAGESOURCE) &&
|
||||||
(rc = processSourceFiles(spec)))
|
(rc = processSourceFiles(spec)))
|
||||||
goto exit;
|
goto exit;
|
||||||
|
@ -22,6 +22,9 @@ int parseBuildInstallClean(Spec spec, rpmParseState parsePart)
|
|||||||
} else if (parsePart == PART_INSTALL) {
|
} else if (parsePart == PART_INSTALL) {
|
||||||
sbp = &(spec->install);
|
sbp = &(spec->install);
|
||||||
name = "%install";
|
name = "%install";
|
||||||
|
} else if (parsePart == PART_CHECK) {
|
||||||
|
sbp = &(spec->check);
|
||||||
|
name = "%check";
|
||||||
} else if (parsePart == PART_CLEAN) {
|
} else if (parsePart == PART_CLEAN) {
|
||||||
sbp = &(spec->clean);
|
sbp = &(spec->clean);
|
||||||
name = "%clean";
|
name = "%clean";
|
||||||
@ -36,7 +39,7 @@ int parseBuildInstallClean(Spec spec, rpmParseState parsePart)
|
|||||||
|
|
||||||
*sbp = newStringBuf();
|
*sbp = newStringBuf();
|
||||||
|
|
||||||
/* There are no options to %build, %install, or %clean */
|
/* There are no options to %build, %install, %check, or %clean */
|
||||||
if ((rc = readLine(spec, STRIP_NOTHING)) == 1)
|
if ((rc = readLine(spec, STRIP_NOTHING)) == 1)
|
||||||
return PART_NONE;
|
return PART_NONE;
|
||||||
if (rc)
|
if (rc)
|
||||||
|
@ -28,6 +28,7 @@ static struct PartRec {
|
|||||||
{ PART_PREP, 0, "%prep"},
|
{ PART_PREP, 0, "%prep"},
|
||||||
{ PART_BUILD, 0, "%build"},
|
{ PART_BUILD, 0, "%build"},
|
||||||
{ PART_INSTALL, 0, "%install"},
|
{ PART_INSTALL, 0, "%install"},
|
||||||
|
{ PART_CHECK, 0, "%check"},
|
||||||
{ PART_CLEAN, 0, "%clean"},
|
{ PART_CLEAN, 0, "%clean"},
|
||||||
{ PART_PREUN, 0, "%preun"},
|
{ PART_PREUN, 0, "%preun"},
|
||||||
{ PART_POSTUN, 0, "%postun"},
|
{ PART_POSTUN, 0, "%postun"},
|
||||||
@ -710,6 +711,7 @@ fprintf(stderr, "*** PS buildRootURL(%s) %p macro set to %s\n", spec->buildRootU
|
|||||||
/*@switchbreak@*/ break;
|
/*@switchbreak@*/ break;
|
||||||
case PART_BUILD:
|
case PART_BUILD:
|
||||||
case PART_INSTALL:
|
case PART_INSTALL:
|
||||||
|
case PART_CHECK:
|
||||||
case PART_CLEAN:
|
case PART_CLEAN:
|
||||||
rpmSetBuiltinMacroLookup(is_builtin_build_tag);
|
rpmSetBuiltinMacroLookup(is_builtin_build_tag);
|
||||||
rpmSetBuiltinMacroLookupFailedOK(1);
|
rpmSetBuiltinMacroLookupFailedOK(1);
|
||||||
|
@ -26,16 +26,17 @@ typedef enum rpmBuildFlags_e {
|
|||||||
RPMBUILD_PREP = (1 << 0), /*!< Execute %%prep. */
|
RPMBUILD_PREP = (1 << 0), /*!< Execute %%prep. */
|
||||||
RPMBUILD_BUILD = (1 << 1), /*!< Execute %%build. */
|
RPMBUILD_BUILD = (1 << 1), /*!< Execute %%build. */
|
||||||
RPMBUILD_INSTALL = (1 << 2), /*!< Execute %%install. */
|
RPMBUILD_INSTALL = (1 << 2), /*!< Execute %%install. */
|
||||||
RPMBUILD_CLEAN = (1 << 3), /*!< Execute %%clean. */
|
RPMBUILD_CHECK = (1 << 3), /*!< Execute %%check. */
|
||||||
RPMBUILD_FILECHECK = (1 << 4), /*!< Check %%files manifest. */
|
RPMBUILD_CLEAN = (1 << 4), /*!< Execute %%clean. */
|
||||||
RPMBUILD_PACKAGESOURCE = (1 << 5), /*!< Create source package. */
|
RPMBUILD_FILECHECK = (1 << 5), /*!< Check %%files manifest. */
|
||||||
RPMBUILD_PACKAGEBINARY = (1 << 6), /*!< Create binary package(s). */
|
RPMBUILD_PACKAGESOURCE = (1 << 6), /*!< Create source package. */
|
||||||
RPMBUILD_RMSOURCE = (1 << 7), /*!< Remove source(s) and patch(s). */
|
RPMBUILD_PACKAGEBINARY = (1 << 7), /*!< Create binary package(s). */
|
||||||
RPMBUILD_RMBUILD = (1 << 8), /*!< Remove build sub-tree. */
|
RPMBUILD_RMSOURCE = (1 << 8), /*!< Remove source(s) and patch(s). */
|
||||||
RPMBUILD_STRINGBUF = (1 << 9), /*!< only for doScript() */
|
RPMBUILD_RMBUILD = (1 << 9), /*!< Remove build sub-tree. */
|
||||||
RPMBUILD_RMSPEC = (1 << 10), /*!< Remove spec file. */
|
RPMBUILD_STRINGBUF = (1 << 10), /*!< only for doScript() */
|
||||||
RPMBUILD_PREPROCESS = (1 << 11), /*!< Preprocess spec file only. */
|
RPMBUILD_RMSPEC = (1 << 11), /*!< Remove spec file. */
|
||||||
RPMBUILD_MACROREQS = (1 << 12) /*!< Dump used macro names only. */
|
RPMBUILD_PREPROCESS = (1 << 12), /*!< Preprocess spec file only. */
|
||||||
|
RPMBUILD_MACROREQS = (1 << 13) /*!< Dump used macro names only. */
|
||||||
} rpmBuildFlags;
|
} rpmBuildFlags;
|
||||||
/*@=typeuse@*/
|
/*@=typeuse@*/
|
||||||
|
|
||||||
@ -51,25 +52,26 @@ typedef enum rpmBuildFlags_e {
|
|||||||
* Spec file parser states.
|
* Spec file parser states.
|
||||||
*/
|
*/
|
||||||
typedef enum rpmParseState_e {
|
typedef enum rpmParseState_e {
|
||||||
PART_NONE = 0, /*!< */
|
PART_NONE = 0, /*!< */
|
||||||
PART_PREAMBLE = 1, /*!< */
|
PART_PREAMBLE = 1, /*!< */
|
||||||
PART_PREP = 2, /*!< */
|
PART_PREP = 2, /*!< */
|
||||||
PART_BUILD = 3, /*!< */
|
PART_BUILD = 3, /*!< */
|
||||||
PART_INSTALL = 4, /*!< */
|
PART_INSTALL = 4, /*!< */
|
||||||
PART_CLEAN = 5, /*!< */
|
PART_CHECK = 5, /*!< */
|
||||||
PART_FILES = 6, /*!< */
|
PART_CLEAN = 6, /*!< */
|
||||||
PART_PRE = 7, /*!< */
|
PART_FILES = 7, /*!< */
|
||||||
PART_POST = 8, /*!< */
|
PART_PRE = 8, /*!< */
|
||||||
PART_PREUN = 9, /*!< */
|
PART_POST = 9, /*!< */
|
||||||
PART_POSTUN = 10, /*!< */
|
PART_PREUN = 10, /*!< */
|
||||||
PART_DESCRIPTION = 11, /*!< */
|
PART_POSTUN = 11, /*!< */
|
||||||
PART_CHANGELOG = 12, /*!< */
|
PART_DESCRIPTION = 12, /*!< */
|
||||||
PART_TRIGGERIN = 13, /*!< */
|
PART_CHANGELOG = 13, /*!< */
|
||||||
PART_TRIGGERUN = 14, /*!< */
|
PART_TRIGGERIN = 14, /*!< */
|
||||||
PART_VERIFYSCRIPT = 15, /*!< */
|
PART_TRIGGERUN = 15, /*!< */
|
||||||
PART_BUILDARCHITECTURES= 16,/*!< */
|
PART_VERIFYSCRIPT = 16, /*!< */
|
||||||
PART_TRIGGERPOSTUN = 17, /*!< */
|
PART_BUILDARCHITECTURES= 17,/*!< */
|
||||||
PART_LAST = 18 /*!< */
|
PART_TRIGGERPOSTUN = 18, /*!< */
|
||||||
|
PART_LAST = 19 /*!< */
|
||||||
} rpmParseState;
|
} rpmParseState;
|
||||||
|
|
||||||
#define STRIP_NOTHING 0
|
#define STRIP_NOTHING 0
|
||||||
@ -212,7 +214,7 @@ void addChangelogEntry(Header h, time_t time, const char * name,
|
|||||||
int parseBuildInstallClean(Spec spec, rpmParseState parsePart)
|
int parseBuildInstallClean(Spec spec, rpmParseState parsePart)
|
||||||
/*@globals rpmGlobalMacroContext,
|
/*@globals rpmGlobalMacroContext,
|
||||||
fileSystem @*/
|
fileSystem @*/
|
||||||
/*@modifies spec->build, spec->install, spec->clean, spec->macros,
|
/*@modifies spec->build, spec->install, spec->check, spec->clean, spec->macros,
|
||||||
spec->fileStack, spec->readStack, spec->line, spec->lineNum,
|
spec->fileStack, spec->readStack, spec->line, spec->lineNum,
|
||||||
spec->nextline, spec->nextpeekc, spec->lbuf, spec->sl,
|
spec->nextline, spec->nextpeekc, spec->lbuf, spec->sl,
|
||||||
rpmGlobalMacroContext, fileSystem @*/;
|
rpmGlobalMacroContext, fileSystem @*/;
|
||||||
|
@ -139,6 +139,7 @@ struct SpecStruct {
|
|||||||
/*@only@*/ StringBuf prep; /*!< %prep scriptlet. */
|
/*@only@*/ StringBuf prep; /*!< %prep scriptlet. */
|
||||||
/*@only@*/ StringBuf build; /*!< %build scriptlet. */
|
/*@only@*/ StringBuf build; /*!< %build scriptlet. */
|
||||||
/*@only@*/ StringBuf install; /*!< %install scriptlet. */
|
/*@only@*/ StringBuf install; /*!< %install scriptlet. */
|
||||||
|
/*@only@*/ StringBuf check; /*!< %check scriptlet. */
|
||||||
/*@only@*/ StringBuf clean; /*!< %clean scriptlet. */
|
/*@only@*/ StringBuf clean; /*!< %clean scriptlet. */
|
||||||
|
|
||||||
/*@owned@*/ struct PackageStruct * packages; /*!< Package list. */
|
/*@owned@*/ struct PackageStruct * packages; /*!< Package list. */
|
||||||
|
@ -453,6 +453,7 @@ Spec newSpec(void)
|
|||||||
spec->prep = NULL;
|
spec->prep = NULL;
|
||||||
spec->build = NULL;
|
spec->build = NULL;
|
||||||
spec->install = NULL;
|
spec->install = NULL;
|
||||||
|
spec->check = NULL;
|
||||||
spec->clean = NULL;
|
spec->clean = NULL;
|
||||||
|
|
||||||
spec->sources = NULL;
|
spec->sources = NULL;
|
||||||
@ -498,6 +499,7 @@ Spec freeSpec(Spec spec)
|
|||||||
spec->prep = freeStringBuf(spec->prep);
|
spec->prep = freeStringBuf(spec->prep);
|
||||||
spec->build = freeStringBuf(spec->build);
|
spec->build = freeStringBuf(spec->build);
|
||||||
spec->install = freeStringBuf(spec->install);
|
spec->install = freeStringBuf(spec->install);
|
||||||
|
spec->check = freeStringBuf(spec->check);
|
||||||
spec->clean = freeStringBuf(spec->clean);
|
spec->clean = freeStringBuf(spec->clean);
|
||||||
|
|
||||||
spec->buildRootURL = _free(spec->buildRootURL);
|
spec->buildRootURL = _free(spec->buildRootURL);
|
||||||
|
22
macros.in
22
macros.in
@ -619,6 +619,8 @@
|
|||||||
%__spec_build_custom_post %{nil}
|
%__spec_build_custom_post %{nil}
|
||||||
%__spec_install_custom_pre %{nil}
|
%__spec_install_custom_pre %{nil}
|
||||||
%__spec_install_custom_post %{nil}
|
%__spec_install_custom_post %{nil}
|
||||||
|
%__spec_check_custom_pre %{nil}
|
||||||
|
%__spec_check_custom_post %{nil}
|
||||||
%__spec_autodep_custom_pre %{nil}
|
%__spec_autodep_custom_pre %{nil}
|
||||||
%__spec_autodep_custom_post %{nil}
|
%__spec_autodep_custom_post %{nil}
|
||||||
%__spec_clean_custom_pre %{nil}
|
%__spec_clean_custom_pre %{nil}
|
||||||
@ -692,6 +694,26 @@
|
|||||||
#%{__spec_install_post}\
|
#%{__spec_install_post}\
|
||||||
#%{nil}
|
#%{nil}
|
||||||
|
|
||||||
|
%__spec_check_shell %{___build_shell}
|
||||||
|
%__spec_check_args %{___build_args}
|
||||||
|
%__spec_check_cmd %{___build_cmd}
|
||||||
|
%__spec_check_pre\
|
||||||
|
%{___build_pre}\
|
||||||
|
%{__spec_check_custom_pre}\
|
||||||
|
%{nil}
|
||||||
|
%__spec_check_body %{___build_body}
|
||||||
|
%__spec_check_post\
|
||||||
|
%{___build_post}\
|
||||||
|
%{__spec_check_custom_post}\
|
||||||
|
%{nil}
|
||||||
|
%__spec_check_template #!%{__spec_check_shell}\
|
||||||
|
%{__spec_check_pre}\
|
||||||
|
%{nil}
|
||||||
|
|
||||||
|
#%{__spec_check_body}\
|
||||||
|
#%{__spec_check_post}\
|
||||||
|
#%{nil}
|
||||||
|
|
||||||
%__spec_autodep_shell %{___build_shell}
|
%__spec_autodep_shell %{___build_shell}
|
||||||
%__spec_autodep_args %{___build_args}
|
%__spec_autodep_args %{___build_args}
|
||||||
%__spec_autodep_cmd %{___build_cmd}
|
%__spec_autodep_cmd %{___build_cmd}
|
||||||
|
5
rpmqv.c
5
rpmqv.c
@ -951,7 +951,8 @@ int main(int argc, const char ** argv)
|
|||||||
if (!poptPeekArg(optCon))
|
if (!poptPeekArg(optCon))
|
||||||
argerror(_("no packages files given for rebuild"));
|
argerror(_("no packages files given for rebuild"));
|
||||||
|
|
||||||
ba->buildAmount = RPMBUILD_PREP | RPMBUILD_BUILD | RPMBUILD_INSTALL;
|
ba->buildAmount =
|
||||||
|
RPMBUILD_PREP | RPMBUILD_BUILD | RPMBUILD_INSTALL | RPMBUILD_CHECK;
|
||||||
if (bigMode == MODE_REBUILD) {
|
if (bigMode == MODE_REBUILD) {
|
||||||
ba->buildAmount |= RPMBUILD_PACKAGEBINARY;
|
ba->buildAmount |= RPMBUILD_PACKAGEBINARY;
|
||||||
if (rpmExpandNumeric ("%{?_rpmbuild_clean:%{_rpmbuild_clean}}%{?!_rpmbuild_clean:1}"))
|
if (rpmExpandNumeric ("%{?_rpmbuild_clean:%{_rpmbuild_clean}}%{?!_rpmbuild_clean:1}"))
|
||||||
@ -1007,7 +1008,7 @@ int main(int argc, const char ** argv)
|
|||||||
if (ba->shortCircuit) break;
|
if (ba->shortCircuit) break;
|
||||||
/*@fallthrough@*/
|
/*@fallthrough@*/
|
||||||
case 'i':
|
case 'i':
|
||||||
ba->buildAmount |= RPMBUILD_INSTALL;
|
ba->buildAmount |= RPMBUILD_INSTALL | RPMBUILD_CHECK;
|
||||||
if (ba->shortCircuit) break;
|
if (ba->shortCircuit) break;
|
||||||
/*@fallthrough@*/
|
/*@fallthrough@*/
|
||||||
case 'c':
|
case 'c':
|
||||||
|
Loading…
Reference in New Issue
Block a user