summaryrefslogtreecommitdiff
path: root/apt-pkg/sourcelist.cc
diff options
context:
space:
mode:
Diffstat (limited to 'apt-pkg/sourcelist.cc')
-rw-r--r--apt-pkg/sourcelist.cc21
1 files changed, 13 insertions, 8 deletions
diff --git a/apt-pkg/sourcelist.cc b/apt-pkg/sourcelist.cc
index 714918bc1..0bbb2bd3f 100644
--- a/apt-pkg/sourcelist.cc
+++ b/apt-pkg/sourcelist.cc
@@ -239,7 +239,8 @@ bool pkgSourceList::Read(string File)
/* */
bool pkgSourceList::ReadAppend(string File)
{
- if (ParseFileDeb822(File))
+ if (_config->FindB("APT::Sources::Use-Deb822", true) == true)
+ if (ParseFileDeb822(File))
return true;
return ParseFileOldStyle(File);
}
@@ -305,19 +306,23 @@ bool pkgSourceList::ParseFileOldStyle(string File)
/* */
bool pkgSourceList::ParseFileDeb822(string File)
{
- // FIXME: proper error handling so that we do not error for good old-style
- // sources
+
+ pkgTagSection Tags;
+ map<string, string> Options;
+ unsigned int i=0;
+
+ // see if we can read the file
+ _error->PushToStack();
FileFd Fd(File, FileFd::ReadOnly);
+ pkgTagFile Sources(&Fd);
if (_error->PendingError() == true)
{
+ _error->RevertToStack();
return false;
}
-
- pkgTagSection Tags;
- map<string, string> Options;
- unsigned int i=0;
+ _error->MergeWithStack();
- pkgTagFile Sources(&Fd);
+ // read step by step
while (Sources.Step(Tags) == true)
{
if(!Tags.Exists("Type"))