33 static char * lastUname = NULL;
34 static size_t lastUnameLen = 0;
35 static size_t lastUnameAlloced;
37 struct passwd * pwent;
43 }
else if (strcmp(thisUname,
"root") == 0) {
50 thisUnameLen = strlen(thisUname);
51 if (lastUname == NULL || thisUnameLen != lastUnameLen ||
52 strcmp(thisUname, lastUname) != 0)
54 if (lastUnameAlloced < thisUnameLen + 1) {
55 lastUnameAlloced = thisUnameLen + 10;
56 lastUname = (
char *)realloc(lastUname, lastUnameAlloced);
59 strcpy(lastUname, thisUname);
62 pwent = getpwnam(thisUname);
67 pwent = getpwnam(thisUname);
68 if (pwent == NULL)
return -1;
71 lastUid = pwent->pw_uid;
83 static char * lastGname = NULL;
84 static size_t lastGnameLen = 0;
85 static size_t lastGnameAlloced;
90 if (thisGname == NULL) {
93 }
else if (strcmp(thisGname,
"root") == 0) {
100 thisGnameLen = strlen(thisGname);
101 if (lastGname == NULL || thisGnameLen != lastGnameLen ||
102 strcmp(thisGname, lastGname) != 0)
104 if (lastGnameAlloced < thisGnameLen + 1) {
105 lastGnameAlloced = thisGnameLen + 10;
106 lastGname = (
char *)realloc(lastGname, lastGnameAlloced);
109 strcpy(lastGname, thisGname);
112 grent = getgrnam(thisGname);
117 grent = getgrnam(thisGname);
120 if (strcmp(thisGname,
"lock") == 0) {
126 if (strcmp(thisGname,
"mail") == 0) {
135 lastGid = grent->gr_gid;
216 ERR <<
"Not a file: " << file << endl;
220 FD_t fd = ::Fopen( file.
asString().c_str(),
"r.ufdio" );
221 if ( fd == 0 || ::Ferror(fd) )
223 ERR <<
"Can't open file for reading: " << file <<
" (" << ::Fstrerror(fd) <<
")" << endl;
230 rpmts ts = ::rpmtsCreate();
231 unsigned vsflag = RPMVSF_DEFAULT;
233 vsflag |= _RPMVSF_NODIGESTS;
235 vsflag |= _RPMVSF_NOSIGNATURES;
236 ::rpmtsSetVSFlags( ts, rpmVSFlags(vsflag) );
239 int res = ::rpmReadPackageFile( ts, fd, path_r.
asString().c_str(), &nh );
247 WAR <<
"Error reading header from " << path_r <<
" error(" << res <<
")" << endl;
254 MIL << h <<
" from " << path_r << endl;
273 << (
isSrc() ?
".src}" :
"}");
286 return has_tag( RPMTAG_SOURCEPACKAGE );
291 return has_tag( RPMTAG_SOURCEPACKAGE ) && (
has_tag( RPMTAG_NOSOURCE ) ||
has_tag( RPMTAG_NOPATCH ) );
317 return int_val ( RPMTAG_EPOCH );
382 return int_val( RPMTAG_INSTALLTIME );
395 return int_val( RPMTAG_BUILDTIME );
410 rpmTag kindFlags = rpmTag(0);
411 rpmTag kindVersion = rpmTag(0);
415 case RPMTAG_REQUIRENAME:
416 kindFlags = RPMTAG_REQUIREFLAGS;
417 kindVersion = RPMTAG_REQUIREVERSION;
419 case RPMTAG_PROVIDENAME:
420 kindFlags = RPMTAG_PROVIDEFLAGS;
421 kindVersion = RPMTAG_PROVIDEVERSION;
423 case RPMTAG_OBSOLETENAME:
424 kindFlags = RPMTAG_OBSOLETEFLAGS;
425 kindVersion = RPMTAG_OBSOLETEVERSION;
427 case RPMTAG_CONFLICTNAME:
428 kindFlags = RPMTAG_CONFLICTFLAGS;
429 kindVersion = RPMTAG_CONFLICTVERSION;
431#ifdef RPMTAG_OLDSUGGESTS
432 case RPMTAG_OLDENHANCESNAME:
433 kindFlags = RPMTAG_OLDENHANCESFLAGS;
434 kindVersion = RPMTAG_OLDENHANCESVERSION;
436 case RPMTAG_OLDSUGGESTSNAME:
437 kindFlags = RPMTAG_OLDSUGGESTSFLAGS;
438 kindVersion = RPMTAG_OLDSUGGESTSVERSION;
440 case RPMTAG_RECOMMENDNAME:
441 kindFlags = RPMTAG_RECOMMENDFLAGS;
442 kindVersion = RPMTAG_RECOMMENDVERSION;
444 case RPMTAG_SUPPLEMENTNAME:
445 kindFlags = RPMTAG_SUPPLEMENTFLAGS;
446 kindVersion = RPMTAG_SUPPLEMENTVERSION;
448 case RPMTAG_SUGGESTNAME:
449 kindFlags = RPMTAG_SUGGESTFLAGS;
450 kindVersion = RPMTAG_SUGGESTVERSION;
452 case RPMTAG_ENHANCENAME:
453 kindFlags = RPMTAG_ENHANCEFLAGS;
454 kindVersion = RPMTAG_ENHANCEVERSION;
457 case RPMTAG_ENHANCESNAME:
458 kindFlags = RPMTAG_ENHANCESFLAGS;
459 kindVersion = RPMTAG_ENHANCESVERSION;
461 case RPMTAG_SUGGESTSNAME:
462 kindFlags = RPMTAG_SUGGESTSFLAGS;
463 kindVersion = RPMTAG_SUGGESTSVERSION;
467 INT <<
"Illegal RPMTAG_dependencyNAME " << tag_r << endl;
483 for (
unsigned i = 0; i < count; ++i )
486 std::string n( names[i] );
489 int32_t f = flags[i];
490 std::string v = versions[i];
503 switch ( f & RPMSENSE_SENSEMASK )
508 case RPMSENSE_LESS|RPMSENSE_EQUAL:
511 case RPMSENSE_GREATER:
514 case RPMSENSE_GREATER|RPMSENSE_EQUAL:
523 if ((pre && (f & RPMSENSE_PREREQ))
524 || ((! pre) && !(f & RPMSENSE_PREREQ)))
533 WAR <<
"Invalid capability: " << n <<
" " << op <<
" "
617#ifdef RPMTAG_OLDSUGGESTS
634#ifdef RPMTAG_OLDSUGGESTS
651#ifdef RPMTAG_OLDSUGGESTS
668#ifdef RPMTAG_OLDSUGGESTS
698 return int_val( RPMTAG_ARCHIVESIZE );
883 std::string sigInfo =
format(
"%|DSAHEADER?{%{DSAHEADER:pgpsig}}:{%|RSAHEADER?{%{RSAHEADER:pgpsig}}:{%|SIGGPG?{%{SIGGPG:pgpsig}}:{%|SIGPGP?{%{SIGPGP:pgpsig}}:{(none)}|}|}|}|");
886 if ( sigInfo ==
"(none)" )
887 return std::string();
889 std::vector<std::string> words;
890 str::split( sigInfo, std::back_inserter(words),
",");
891 if ( words.size() < 3)
892 return std::string();
894 const std::string &keyId = words[2];
896 return std::string();
911 std::list<std::string> ret;
919 int_list( RPMTAG_DIRINDEXES, dirindexes );
920 for (
unsigned i = 0; i < basenames.
size(); ++ i )
922 ret.push_back( dirnames[dirindexes[i]] + basenames[i] );
939 std::list<FileInfo> ret;
947 int_list( RPMTAG_DIRINDEXES, dirindexes );
949 int_list( RPMTAG_FILESIZES, filesizes );
961 int_list( RPMTAG_FILEMODES, filemodes );
963 int_list( RPMTAG_FILEMTIMES, filemtimes );
965 int_list( RPMTAG_FILEFLAGS, fileflags );
969 for (
unsigned i = 0; i < basenames.
size(); ++ i )
974 uid =
unameToUid( usernames[i].c_str(), &uid );
984 gid =
gnameToGid( groupnames[i].c_str(), &gid );
992 dirnames[dirindexes[i]] + basenames[i],
997 mode_t(filemodes[i]),
999 bool(fileflags[i] & RPMFILE_GHOST),
1003 ret.push_back( info );
1023 if (
int_list( RPMTAG_CHANGELOGTIME, times ) )
1029 for (
unsigned i = 0; i < times.
size(); ++ i )
#define ZYPP_CAUGHT(EXCPT)
Drops a logline telling the Exception was caught (in order to handle it).
Store and operate with byte count.
Single entry in a change log.
Store and operate on date (time_t).
Edition represents [epoch:]version[-release]
unsigned epoch_t
Type of an epoch.
Base class for Exception.
Wrapper class for ::stat/::lstat.
const std::string & asString() const
Return current Pathname as String.
const std::string & asString() const
String representation.
static bool globalInit()
Initialize lib librpm (read configfiles etc.).
String related utilities and Regular expression matching.
bool startsWith(const C_Str &str_r, const C_Str &prefix_r)
alias for hasPrefix
std::string toUpper(const std::string &s)
Return uppercase version of s.
unsigned split(const C_Str &line_r, TOutputIterator result_r, const C_Str &sepchars_r=" \t", const Trim trim_r=NO_TRIM)
Split line_r into words.
Easy-to use interface to the ZYPP dependency resolver.
std::unordered_set< Capability > CapabilitySet
std::list< ChangelogEntry > Changelog
List of ChangelogEntry.