summaryrefslogtreecommitdiff
path: root/apt-pkg/deb/debindexfile.cc
diff options
context:
space:
mode:
authorDavid Kalnischkies <kalnischkies@gmail.com>2012-06-16 19:55:43 +0200
committerDavid Kalnischkies <kalnischkies@gmail.com>2012-06-16 19:55:43 +0200
commit2b803d4069e1f05d0461fbad004482ff02100812 (patch)
treeb30b90c27dd363de7e8fd83432ed7a54eefada0f /apt-pkg/deb/debindexfile.cc
parentef5dc12ccb6964a52c7c7674d2eff98435089d92 (diff)
do not dereference the storage for the unique strings as the pointer can
change at the time of writing the strings, so first store it temporary and then save the index in the (possibily new) pointer location
Diffstat (limited to 'apt-pkg/deb/debindexfile.cc')
-rw-r--r--apt-pkg/deb/debindexfile.cc3
1 files changed, 2 insertions, 1 deletions
diff --git a/apt-pkg/deb/debindexfile.cc b/apt-pkg/deb/debindexfile.cc
index 76c740341..de645bb6e 100644
--- a/apt-pkg/deb/debindexfile.cc
+++ b/apt-pkg/deb/debindexfile.cc
@@ -602,7 +602,8 @@ bool debStatusIndex::Merge(pkgCacheGenerator &Gen,OpProgress *Prog) const
pkgCache::PkgFileIterator CFile = Gen.GetCurFile();
CFile->Size = Pkg.FileSize();
CFile->mtime = Pkg.ModificationTime();
- CFile->Archive = Gen.WriteUniqString("now");
+ map_ptrloc const storage = Gen.WriteUniqString("now");
+ CFile->Archive = storage;
if (Gen.MergeList(Parser) == false)
return _error->Error("Problem with MergeList %s",File.c_str());