+
+ // write
+ string history_name = flCombine(logdir,
+ _config->Find("Dir::Log::History"));
+ if (!history_name.empty())
+ {
+ history_out = fopen(history_name.c_str(),"a");
+ chmod(history_name.c_str(), 0644);
+ fprintf(history_out, "\nStart-Date: %s\n", timestr);
+ string remove, purge, install, upgrade, downgrade;
+ for (pkgCache::PkgIterator I = Cache.PkgBegin(); I.end() == false; I++)
+ {
+ if (Cache[I].Install())
+ install += I.Name() + string(" (") + Cache[I].CandVersion + string(") ");
+ else if (Cache[I].Delete())
+ {
+ if ((Cache[I].iFlags & pkgDepCache::Purge) == pkgDepCache::Purge)
+ purge += I.Name() + string(" (") + Cache[I].CurVersion + string(") ");
+ else
+ remove += I.Name() + string(" (") + Cache[I].CurVersion + string(") ");
+ }
+ else if (Cache[I].Upgrade())
+ upgrade += I.Name() + string(" (") + Cache[I].CurVersion + string(", ") + Cache[I].CandVersion + string(") ");
+ else if (Cache[I].Downgrade())
+ downgrade += I.Name() + string(" (") + Cache[I].CurVersion + string(", ") + Cache[I].CandVersion + string(") ");
+ }
+ if (install.size() > 0)
+ fprintf(history_out, "Install: %s\n", install.c_str());
+ if (upgrade.size() > 0)
+ fprintf(history_out, "Upgrade: %s\n", upgrade.c_str());
+ if (downgrade.size() > 0)
+ fprintf(history_out, "Downgrade: %s\n", downgrade.c_str());
+ if (remove.size() > 0)
+ fprintf(history_out, "Remove: %s\n", remove.c_str());
+ if (purge.size() > 0)
+ fprintf(history_out, "Purge: %s\n", purge.c_str());
+ }
+