reverted: relocated parseEVR and isChangeNameMoreFresh from lib to rpmdb
This commit is contained in:
parent
5fe70d69b9
commit
f27bc8917e
@ -108,6 +108,50 @@ int rpmvercmp(const char * a, const char * b)
|
||||
if (!*one) return -1; else return 1;
|
||||
}
|
||||
|
||||
/* Moved from depends.c, because we use it in other places, too. */
|
||||
/**
|
||||
* Split EVR into epoch, version, and release components.
|
||||
* @param evr [epoch:]version[-release] string
|
||||
* @retval *ep pointer to epoch
|
||||
* @retval *vp pointer to version
|
||||
* @retval *rp pointer to release
|
||||
*/
|
||||
void parseEVR(char * evr,
|
||||
/*@exposed@*/ /*@out@*/ const char ** ep,
|
||||
/*@exposed@*/ /*@out@*/ const char ** vp,
|
||||
/*@exposed@*/ /*@out@*/ const char ** rp)
|
||||
/*@modifies *ep, *vp, *rp @*/
|
||||
{
|
||||
const char *epoch;
|
||||
const char *version; /* assume only version is present */
|
||||
const char *release;
|
||||
char *s, *se;
|
||||
|
||||
s = evr;
|
||||
while (*s && xisdigit(*s)) s++; /* s points to epoch terminator */
|
||||
se = strrchr(s, '-'); /* se points to version terminator */
|
||||
|
||||
if (*s == ':') {
|
||||
epoch = evr;
|
||||
*s++ = '\0';
|
||||
version = s;
|
||||
if (*epoch == '\0') epoch = "0";
|
||||
} else {
|
||||
epoch = NULL; /* XXX disable epoch compare if missing */
|
||||
version = evr;
|
||||
}
|
||||
if (se) {
|
||||
*se++ = '\0';
|
||||
release = se;
|
||||
} else {
|
||||
release = NULL;
|
||||
}
|
||||
|
||||
if (ep) *ep = epoch;
|
||||
if (vp) *vp = version;
|
||||
if (rp) *rp = release;
|
||||
}
|
||||
|
||||
/* Compare {A,B} [epoch:]version[-release] */
|
||||
int
|
||||
rpmEVRcmp(const char * const aE, const char * const aV, const char * const aR,
|
||||
@ -141,3 +185,34 @@ rpmEVRcmp(const char * const aE, const char * const aV, const char * const aR,
|
||||
return sense;
|
||||
}
|
||||
|
||||
int isChangeNameMoreFresh(const char * const head,
|
||||
const char * const tail[3])
|
||||
{
|
||||
int result;
|
||||
const char * evr[3];
|
||||
const char * wordAfterEmail;
|
||||
char * copy;
|
||||
|
||||
rpmMessage(RPMMESS_DEBUG, "test: is '%s' more fresh than e=%s, v=%s, r=%s?\n",
|
||||
head, tail[0], tail[1], tail[2]);
|
||||
/* find the next to <email> word begin */
|
||||
if ( (wordAfterEmail = strrchr(head, '>')) )
|
||||
++wordAfterEmail;
|
||||
else
|
||||
wordAfterEmail = head;
|
||||
while ( *wordAfterEmail && xisspace(*wordAfterEmail) )
|
||||
++wordAfterEmail;
|
||||
/* found. */
|
||||
copy = xstrdup(wordAfterEmail);
|
||||
parseEVR(copy, &evr[0], &evr[1], &evr[2]);
|
||||
/* The order of two argument groups is important:
|
||||
if evr[] (passed as B on the second place) has no epoch,
|
||||
rpmEVRcmp() assumes the same as in tail[];
|
||||
This fits our needs: the epoch may be omitted in a changelog entry (evr[])
|
||||
but there are no problems in specifying it in the format (tail[]). */
|
||||
result = rpmEVRcmp(tail[0], tail[1], tail[2], "",
|
||||
evr[0], evr[1], evr[2], "") < 0;
|
||||
_free(copy);
|
||||
return result;
|
||||
}
|
||||
|
||||
|
@ -2443,81 +2443,6 @@ static int parseFormat(char * str, const headerTagTableEntry tags,
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Moved from depends.c, because we use it in other places, too. */
|
||||
/**
|
||||
* Split EVR into epoch, version, and release components.
|
||||
* @param evr [epoch:]version[-release] string
|
||||
* @retval *ep pointer to epoch
|
||||
* @retval *vp pointer to version
|
||||
* @retval *rp pointer to release
|
||||
*/
|
||||
void parseEVR(char * evr,
|
||||
/*@exposed@*/ /*@out@*/ const char ** ep,
|
||||
/*@exposed@*/ /*@out@*/ const char ** vp,
|
||||
/*@exposed@*/ /*@out@*/ const char ** rp)
|
||||
/*@modifies *ep, *vp, *rp @*/
|
||||
{
|
||||
const char *epoch;
|
||||
const char *version; /* assume only version is present */
|
||||
const char *release;
|
||||
char *s, *se;
|
||||
|
||||
s = evr;
|
||||
while (*s && xisdigit(*s)) s++; /* s points to epoch terminator */
|
||||
se = strrchr(s, '-'); /* se points to version terminator */
|
||||
|
||||
if (*s == ':') {
|
||||
epoch = evr;
|
||||
*s++ = '\0';
|
||||
version = s;
|
||||
if (*epoch == '\0') epoch = "0";
|
||||
} else {
|
||||
epoch = NULL; /* XXX disable epoch compare if missing */
|
||||
version = evr;
|
||||
}
|
||||
if (se) {
|
||||
*se++ = '\0';
|
||||
release = se;
|
||||
} else {
|
||||
release = NULL;
|
||||
}
|
||||
|
||||
if (ep) *ep = epoch;
|
||||
if (vp) *vp = version;
|
||||
if (rp) *rp = release;
|
||||
}
|
||||
|
||||
int isChangeNameMoreFresh(const char * const head,
|
||||
const char * const tail[3])
|
||||
{
|
||||
int result;
|
||||
const char * evr[3];
|
||||
const char * wordAfterEmail;
|
||||
char * copy;
|
||||
|
||||
rpmMessage(RPMMESS_DEBUG, "test: is '%s' more fresh than e=%s, v=%s, r=%s?\n",
|
||||
head, tail[0], tail[1], tail[2]);
|
||||
/* find the next to <email> word begin */
|
||||
if ( (wordAfterEmail = strrchr(head, '>')) )
|
||||
++wordAfterEmail;
|
||||
else
|
||||
wordAfterEmail = head;
|
||||
while ( *wordAfterEmail && xisspace(*wordAfterEmail) )
|
||||
++wordAfterEmail;
|
||||
/* found. */
|
||||
copy = xstrdup(wordAfterEmail);
|
||||
parseEVR(copy, &evr[0], &evr[1], &evr[2]);
|
||||
/* The order of two argument groups is important:
|
||||
if evr[] (passed as B on the second place) has no epoch,
|
||||
rpmEVRcmp() assumes the same as in tail[];
|
||||
This fits our needs: the epoch may be omitted in a changelog entry (evr[])
|
||||
but there are no problems in specifying it in the format (tail[]). */
|
||||
result = rpmEVRcmp(tail[0], tail[1], tail[2], "",
|
||||
evr[0], evr[1], evr[2], "") < 0;
|
||||
_free(copy);
|
||||
return result;
|
||||
}
|
||||
|
||||
/**
|
||||
*/
|
||||
static int parseExpression(sprintfToken token, char * str,
|
||||
|
Loading…
x
Reference in New Issue
Block a user