apt.git
11 years agoensure that pkgTagFile isn't writing past Buffer length
David Kalnischkies [Thu, 15 Aug 2013 14:49:51 +0000 (16:49 +0200)] 
ensure that pkgTagFile isn't writing past Buffer length

In 91c4cc14d3654636edf997d23852f05ad3de4853 I removed the +256 from
the pkgTagFile call parsing Release files as I couldn't find a
mentioning of a reason for why and it was marked as XXX which suggested
that at least someone else was suspicious.

It turns out that it is indeed "documented", it just didn't found it at
first but the changelog of apt 0.6.6 (29. Dec 2003) mentions:
  * Restore the ugly hack I removed from indexRecords::Load which set the
    pkgTagFile buffer size to (file size)+256.  This is concealing a bug,
    but I can't fix it right now.  This should fix the segfaults that
    folks are seeing with 0.6.[45].

The bug it is "hiding" is that if pkgTagFile works with a file which doesn't
end in a double newline it will be adding it without checking if the Buffer
is big enough to store them. Its also not a good idea to let the End
pointer be past the end of our space, even if we don't access the data.

Closes: 719629
11 years agoset MALLOC_CHECK_ and MALLOC_PERTURB_ for testcases
David Kalnischkies [Thu, 15 Aug 2013 14:45:09 +0000 (16:45 +0200)] 
set MALLOC_CHECK_ and MALLOC_PERTURB_ for testcases

In bugreport deb:719629 Paul Wise mentions both to enable some malloc
checks and as more testing can't hurt we enable both for all testcases.

Git-Dch: Ignore

11 years agorework the parameter creation for the Hashsum test
David Kalnischkies [Thu, 15 Aug 2013 14:41:16 +0000 (16:41 +0200)] 
rework the parameter creation for the Hashsum test

Avoids having to different places from which test binaries are called

Git-Dch: Ignore

11 years agodo not call make from libapt/run-tests if its called by make
David Kalnischkies [Thu, 15 Aug 2013 14:36:32 +0000 (16:36 +0200)] 
do not call make from libapt/run-tests if its called by make

If we are called by make everything is build already and
so this is just a noise nop we can just skip.
(Noisy as it complains about being unable to communicate with
 the other makes to coordinate with the jobserver)

Git-Dch: Ignore

11 years agoinit the pkgTagFile with the size of the Release file
David Kalnischkies [Tue, 13 Aug 2013 19:46:32 +0000 (21:46 +0200)] 
init the pkgTagFile with the size of the Release file

Release files are basically one big Section, so we might safe some
Resize circles by starting with the filesize.

Git-Dch: Ignore

11 years ago* lp:~mvo/apt/add-glob-function:
Michael Vogt [Wed, 17 Oct 2012 08:27:50 +0000 (10:27 +0200)] 
* lp:~mvo/apt/add-glob-function:
  -  add Glob() to fileutl.{cc,h}
Conflicts:
apt-pkg/contrib/fileutl.h
debian/changelog

11 years ago* lp:~mvo/apt/config-clear:
Michael Vogt [Wed, 17 Oct 2012 08:29:52 +0000 (10:29 +0200)] 
* lp:~mvo/apt/config-clear:
  - support Configuration.Clear() for a clear of the entire
    configuration
Conflicts:
debian/changelog

11 years agomerge patch from Daniel Hartwig to Show a error message if {,dist-}upgrade is used...
Michael Vogt [Tue, 23 Apr 2013 06:16:21 +0000 (08:16 +0200)] 
merge patch from Daniel Hartwig to  Show a error message if {,dist-}upgrade is used with additional
    arguments (closes: #705510)

11 years agomerge patch from Daniel Hartwig to Clarify units of Acquire::http::Dl-Limit (closes...
Michael Vogt [Tue, 23 Apr 2013 06:15:06 +0000 (08:15 +0200)] 
merge patch from Daniel Hartwig to  Clarify units of Acquire::http::Dl-Limit (closes: #705445)
Conflicts:
debian/changelog

11 years agofix typo in the test for abi-compliance-checker
Michael Vogt [Mon, 12 Aug 2013 21:33:57 +0000 (23:33 +0200)] 
fix typo in the test for abi-compliance-checker

11 years agoupdate changelog for upload 0.9.10
Michael Vogt [Mon, 12 Aug 2013 19:45:59 +0000 (21:45 +0200)] 
update changelog for upload

11 years agodo not call 'apt-key update' in apt.postinst
David Kalnischkies [Mon, 12 Aug 2013 15:26:54 +0000 (17:26 +0200)] 
do not call 'apt-key update' in apt.postinst

The debian-archive-keyring package ships trusted.gpg.d fragment files
for a while now and dropped their call to 'apt-key update', so there is
no need for use to call it as the keys will always be available.

This also finally allows a user to remove key(ring)s without APT to
overriding this decision by readding them with this step.

The functionality is kept around in the odd case that an old
debian-archive-keyring package is used which still calls 'apt-key
update' and depends on the import (hence, we also do not enforce a newer
version of the debian-archive-keyring via our dependencies)

11 years agolet apt-key del work better with softlink and single key keyrings
David Kalnischkies [Mon, 12 Aug 2013 14:19:37 +0000 (16:19 +0200)] 
let apt-key del work better with softlink and single key keyrings

Having fragement files means there is a good chance that there is one
key per keyring, so deal with that as well as with setups in which
keyrings are linked into trusted.gpg.d as we can't just modify those
files (they might be in /usr for example).

11 years agoensure that testcases exiting because of set -e aren't successful
David Kalnischkies [Mon, 12 Aug 2013 13:51:42 +0000 (15:51 +0200)] 
ensure that testcases exiting because of set -e aren't successful

Git-Dch: Ignore

11 years agomake the keyring locations in apt-key configurable
David Kalnischkies [Sun, 11 Aug 2013 22:36:52 +0000 (00:36 +0200)] 
make the keyring locations in apt-key configurable

Might come in handy for more than just a simple testcase.

11 years agodo not double-slash paths in apt-key
David Kalnischkies [Sun, 11 Aug 2013 22:33:37 +0000 (00:33 +0200)] 
do not double-slash paths in apt-key

Closes: 665411
11 years agouse a tmpfile for trustdb.gpg in apt-key
David Kalnischkies [Sun, 11 Aug 2013 22:19:10 +0000 (00:19 +0200)] 
use a tmpfile for trustdb.gpg in apt-key

for some "interesting" reason gpg decides that it needs to update its
trustdb.gpg file in a --list-keys command even if right before gpg is
asked to --check-trustdb. That wouldn't be as bad if it wouldn't modify
the keyring being listed at that moment as well, which generates not
only warnings which are not a problem for us, but as the keyring
modified can be in /usr it modified files which aren't allowed to be
modified.

The suggested solution in the bugreport is running --check-trustdb
unconditionally in an 'apt-key update' call, but this command will not
be used in the future and this could still potentially bite us in
net-update or adv calls. All of this just to keep a file around, which
we do not need…

The commit therefore switches to the use of a temporary created
trusted.gpg file for everyone and asks gpg to not try to update the
trustdb after its intial creation, which seems to avoid the problem
altogether.

It is using your also faked secring btw as calling the check-trustdb
without a keyring is a lot slower …

Closes: #687611
Thanks: Andreas Beckmann for the initial patch!

11 years agoalways use our own trustdb.gpg in apt-key
David Kalnischkies [Thu, 11 Jul 2013 18:07:22 +0000 (20:07 +0200)] 
always use our own trustdb.gpg in apt-key

APT doesn't care for the trustdb.gpg, but gnupg requires one even for
the simplest commands, so we either use the one root has available in
/etc or if we don't have access to it (as only root can read that file)
we create a temporary directory to store a trustdb.gpg in it.

We can't create just a temporary file as gpg requires the given
trustdb.gpg file to be valid (if it exists), so we would have to remove
the file before calling gnupg which would allow mktemp (and co) to hand
exactly this filename out to another program (unlikely, but still).

11 years agoadd a not documented apt-key --fakeroot option
David Kalnischkies [Thu, 11 Jul 2013 17:20:09 +0000 (19:20 +0200)] 
add a not documented apt-key --fakeroot option

Usually, most apt-key commands require root, so the script is checking
for being run as root, but in your tests we use a non-root location, so
we don't need to be root and therefore need an option to skip the check.

Git-Dch: Ignore

11 years agouse our _error stack to generate openpty errors
David Kalnischkies [Sat, 13 Jul 2013 21:14:41 +0000 (23:14 +0200)] 
use our _error stack to generate openpty errors

While we don't want these error messages on our usual stack, we can use
our usual infrastructure to generate an error message with all the usual
bells like errno and strerror attached.

Git-Dch: Ignore

11 years agodo not try to chown if not run as root
David Kalnischkies [Sat, 13 Jul 2013 21:05:55 +0000 (23:05 +0200)] 
do not try to chown if not run as root

If this code is run as non-root we are in a special situation (e.g. in
our testcases) where it is obvious that we can't enforce user/group on
any file, so skip this code altogether instead of bugging users with
an error message – which we also switch to a warning as a failure to
open the file is "just" a warning, so the 'wrong' owner shouldn't be
that much of an issue.

The file is still handled with chmod, so all the security we can enforce
is still enforced of course, which also gets a warning if it fails.

Git-Dch: Ignore

11 years agofix output redirection order
David Kalnischkies [Sat, 13 Jul 2013 20:57:44 +0000 (22:57 +0200)] 
fix output redirection order

First redirect output to a file, then redirect other outputs to this
output, not the other way around as this will not work.

Git-Dch: Ignore

11 years agofix: --print-uris removes authentication
David Kalnischkies [Sat, 10 Aug 2013 10:40:37 +0000 (12:40 +0200)] 
fix: --print-uris removes authentication

The constructors of our (clear)sign-acquire-items move a pre-existent
file for error-recovery away, which gets restored or discarded later as
the acquire progresses, but --print-uris never really starts the
acquire process, so the files aren't restored (as they should).

To fix this both get a destructor which checks for signs of acquire
doing anything and if it hasn't the file is restored.

Note that these virtual destructors theoretically break the API, but
only with classes extending the sign-acquire-items and nobody does this,
as it would be insane for library users to fiddle with Acquire
internals – and these classes are internals.

Closes: 719263
11 years agoadd chronic-like testsuccess/testfailure helpers
David Kalnischkies [Sat, 10 Aug 2013 08:01:06 +0000 (10:01 +0200)] 
add chronic-like testsuccess/testfailure helpers

For many commands the output isn't stable (like then dpkg is called) but
the exitcode is, so this helper enhances the common && msgpass ||
msgfail by generating automatically a msgtest and showing the output of
the command in case of failure instead of discarding it unconditionally,
the later being chronic-like behaviour

Git-Dch: Ignore

11 years agotest Release file handling with expired keys
David Kalnischkies [Fri, 9 Aug 2013 20:20:27 +0000 (22:20 +0200)] 
test Release file handling with expired keys

Signing files with expired keys is not as easy as it sounds, so the
framework jumps a few loops to do it, but it might come in handy to have
an expired key around for later tests even if it is not that different
from having no key in regards to APT behaviour.

Git-Dch: Ignore

11 years agoimprove error message
Michael Vogt [Mon, 12 Aug 2013 15:41:36 +0000 (17:41 +0200)] 
improve error message

11 years agouse the 'abi-complicance-checker package instead of using the buildin copy for the...
Michael Vogt [Mon, 12 Aug 2013 15:11:41 +0000 (17:11 +0200)] 
use the 'abi-complicance-checker package instead of using the buildin copy for the abi checks

11 years agoComplete Japanese translation
Christian PERRIER [Sun, 11 Aug 2013 13:42:09 +0000 (15:42 +0200)] 
Complete Japanese translation

11 years agoMerge branch 'debian/sid' of git://git.debian.org/git/apt/apt into debian/sid
Christian PERRIER [Sat, 10 Aug 2013 10:51:49 +0000 (12:51 +0200)] 
Merge branch 'debian/sid' of git://git.debian.org/git/apt/apt into debian/sid

11 years agoJapanese translation update. Closes: #719279
Christian PERRIER [Sat, 10 Aug 2013 10:51:40 +0000 (12:51 +0200)] 
Japanese translation update. Closes: #719279

11 years agofix -Wall errors
Michael Vogt [Thu, 8 Aug 2013 13:40:15 +0000 (15:40 +0200)] 
fix -Wall errors

11 years agouse pkgTagFile to parse "header" of Release files
David Kalnischkies [Wed, 7 Aug 2013 14:45:49 +0000 (16:45 +0200)] 
use pkgTagFile to parse "header" of Release files

The handwritten parsing here was mostly done as we couldn't trust the
Release file we got, but nowadays we are sure that the Release file is
valid and contains just a single section we want it to include.

Beside reducing code it also fixes a bug: Fieldnames in deb822 formatted
files are case-insensitive and pkgTagFile does it correctly, but this
selfbuilt stuff here didn't.

11 years agostop skipping "-----" sections in Release files
David Kalnischkies [Wed, 7 Aug 2013 14:40:39 +0000 (16:40 +0200)] 
stop skipping "-----" sections in Release files

The file we read will always be a Release file as the clearsign is
stripped earlier in this method, so this check is just wasting CPU
Its also removing the risk that this could ever be part of a valid
section, even if I can't imagine how that should be valid.

Git-Dch: Ignore

11 years agospecific pins below 1000 cause downgrades
David Kalnischkies [Wed, 7 Aug 2013 16:00:07 +0000 (18:00 +0200)] 
specific pins below 1000 cause downgrades

We start your quest by using the version of a package applying to a
specific pin, but that version could very well be below the current
version, which causes APT to suggest a downgrade even if it is
advertised that it never does this below 1000.

Its of course questionable what use a specific pin on a package has
which has a newer version already installed, but reacting with the
suggestion of a downgrade is really not appropriated (even if its kinda
likely that this is actually the intend the user has – it could just as
well be an outdated pin) and as pinning is complicated enough we should
atleast do what is described in the manpage.

So we look out for the specific pin and if we haven't seen it at the
moment we see the installed version, we ignore the specific pin.

Closes: 543966
11 years agoMerge remote-tracking branch 'upstream/debian/sid' into bugfix/coverity
Michael Vogt [Mon, 5 Aug 2013 20:51:30 +0000 (22:51 +0200)] 
Merge remote-tracking branch 'upstream/debian/sid' into bugfix/coverity

11 years agofix some unitialized data members
Michael Vogt [Mon, 5 Aug 2013 20:40:28 +0000 (22:40 +0200)] 
fix some unitialized data members

11 years agoVietnamese translation update. Closes: #718615
Christian PERRIER [Sat, 3 Aug 2013 14:07:13 +0000 (16:07 +0200)] 
Vietnamese translation update. Closes: #718615

11 years agoprefer native arch over higher priority for providers
Colin Watson [Thu, 1 Aug 2013 11:19:43 +0000 (13:19 +0200)] 
prefer native arch over higher priority for providers

The rational from the buglog:
> The problem here is that the Priority field in one of the Packages files
> is incorrect due to a mishap with reprepro configuration, […] the
> amd64 version is Priority: standard but the arm64 version is Priority:
> optional (and has a stray "optional: interpreters" field).
> […]
> However, Priority is a rather weak property of a package because it's
> typically applied via overrides, and it's easy for maintainers of
> third-party repositories to misconfigure them so that overrides aren't
> applied correctly.  It shouldn't be ranked ahead of choosing packages
> from the native architecture.  In this case, I have no user-mode
> emulation for arm64 set up, so choosing m4:arm64 simply won't work.

This effectly makes the priority the least interesting data point in
chosing a provider, which is in line with the other checks we have
already order above priority in the past and also has a certain appeal by
the soft irony it provides.

Closes: #718482
11 years agounset LANGUAGE for showing [Y/n] answer hints
David Kalnischkies [Thu, 1 Aug 2013 10:58:20 +0000 (12:58 +0200)] 
unset LANGUAGE for showing [Y/n] answer hints

nl_langinfo is used to acquire the YESEXPR of the language used,
but it will return the one from LC_MESSAGES, which might be different
from the language chosen for display of the question (based on LANGUAGE)
so this commit removes the [Y/n] help text from the questions itself and
moves it to the prompt creation in which the usage of LC_MESSAGES is
forced for it, so that the helptext shown actually represents the
characters accepted as input for the question.

There is still room for problems of course starting with an untranslated
"[Y/n]" but a translated YESEXPR or the problem that the question is
asked in a completely different language which might have a conflicting
definition of [Y/n] input or the user simple ignores the helptext and
assumes that an answer matching the question language is accepted, but
the mayority of users will never have this problem to begin with, so we
should be fine (or at least a bit finer than before).

Closes nothing really, but should at least help a bit with bugs like
deb:194614, deb:471102, lp:1205578, and countless others.

11 years agoMerge remote-tracking branch 'mvo/bugfix/coverity' into debian/sid
Michael Vogt [Sun, 28 Jul 2013 07:25:57 +0000 (09:25 +0200)] 
Merge remote-tracking branch 'mvo/bugfix/coverity' into debian/sid

11 years agorun "doxygen -u" to update doxygen config
David Kalnischkies [Fri, 26 Jul 2013 22:28:10 +0000 (00:28 +0200)] 
run "doxygen -u" to update doxygen config

Git-Dch: Ignore

11 years agoupdate the symbol files to reflect current state
David Kalnischkies [Fri, 26 Jul 2013 21:56:28 +0000 (23:56 +0200)] 
update the symbol files to reflect current state

11 years agoexclude config.{sub,guess} from source package
David Kalnischkies [Fri, 26 Jul 2013 20:37:43 +0000 (22:37 +0200)] 
exclude config.{sub,guess} from source package

Lintian complains about these links in the source package as they leave
the source directory and as they are autogenerated there isn't that much
sense in shipping them, we can just recreate them before calling
configure.

11 years agofix another missing va_end()
Michael Vogt [Fri, 26 Jul 2013 20:18:36 +0000 (22:18 +0200)] 
fix another missing va_end()

11 years agofix missing va_end()
Michael Vogt [Fri, 26 Jul 2013 20:12:36 +0000 (22:12 +0200)] 
fix missing va_end()

11 years agofix some coverity chroot() releated warnings
Michael Vogt [Fri, 26 Jul 2013 20:10:05 +0000 (22:10 +0200)] 
fix some coverity chroot() releated warnings

11 years agoreenable automatic parallel build of APT
David Kalnischkies [Fri, 26 Jul 2013 18:37:34 +0000 (20:37 +0200)] 
reenable automatic parallel build of APT

It works for a while now in manual tests, now lets see how it will
perform if enabled for all by default automatically.

11 years agoimplement debian/rules build-{arch,indep} as required by policy 3.9.4
David Kalnischkies [Fri, 26 Jul 2013 17:13:55 +0000 (19:13 +0200)] 
implement debian/rules build-{arch,indep} as required by policy 3.9.4

11 years agocorrect management-typo in description found by lintian
David Kalnischkies [Fri, 26 Jul 2013 16:36:50 +0000 (18:36 +0200)] 
correct management-typo in description found by lintian

11 years agoadd missing Turkish (tr) to po/LINGUAS
David Kalnischkies [Fri, 26 Jul 2013 16:01:33 +0000 (18:01 +0200)] 
add missing Turkish (tr) to po/LINGUAS

And while at it ensure that this can't happen again by letting the build
fail in case a po file is available but the language isn't mentioned in
the LINGUAS file (not even as a disabled language).

11 years agoadd missing test make
Michael Vogt [Fri, 26 Jul 2013 15:31:24 +0000 (17:31 +0200)] 
add missing test make

11 years agoremove ALL_LINGUAS as it is overruled by po/LINGUAS
David Kalnischkies [Fri, 26 Jul 2013 12:38:18 +0000 (14:38 +0200)] 
remove ALL_LINGUAS as it is overruled by po/LINGUAS

The list shows that it is ignored as some translations which are shipped
are not included here, so remove this source of possible confusion.

Git-Dch: Ignore

11 years agomake autoconf happy by "mv configure.{in,ac}"
David Kalnischkies [Fri, 26 Jul 2013 12:12:29 +0000 (14:12 +0200)] 
make autoconf happy by "mv configure.{in,ac}"

Git-Dch: Ignore

11 years agoensure that FileFd::Size returns 0 in error cases
David Kalnischkies [Fri, 26 Jul 2013 10:20:50 +0000 (12:20 +0200)] 
ensure that FileFd::Size returns 0 in error cases

11 years agoproper cleanup varargs in _error (uncovered by Coverity)
David Kalnischkies [Fri, 26 Jul 2013 10:04:55 +0000 (12:04 +0200)] 
proper cleanup varargs in _error (uncovered by Coverity)

Git-Dch: Ignore

11 years agouse FileFd::Write instead of fwrite for errors
David Kalnischkies [Fri, 26 Jul 2013 09:42:02 +0000 (11:42 +0200)] 
use FileFd::Write instead of fwrite for errors

Using the static FileFd::Write method gives us error messages for free
so we use it here to avoid failing silently (with a fail silent error).

Git-Dch: Ignore

11 years agoadd missing "make test" for travis
Michael Vogt [Fri, 26 Jul 2013 09:22:30 +0000 (11:22 +0200)] 
add missing "make test" for travis

11 years agoupdate changelog for upload 0.9.9.4
Michael Vogt [Fri, 26 Jul 2013 07:58:55 +0000 (09:58 +0200)] 
update changelog for upload

11 years agorequest absolute URIs from proxies again (0.9.9.3 regession)
David Kalnischkies [Fri, 26 Jul 2013 07:22:52 +0000 (09:22 +0200)] 
request absolute URIs from proxies again (0.9.9.3 regession)

Commit 2b9c9b7f28b18f6ae3e422020e8934872b06c9f3 not only removes
keep-alive, but also changes the request URI send to proxies which are
required to be absolute URIs rather than the usual absolute paths.

Closes: 717891
11 years agobuild tree first
Michael Vogt [Fri, 26 Jul 2013 05:20:23 +0000 (07:20 +0200)] 
build tree first

11 years agomake setup in travis.yml a bit more verbose
Michael Vogt [Fri, 26 Jul 2013 05:10:21 +0000 (07:10 +0200)] 
make setup in travis.yml a bit more verbose

11 years agopick up Translation-* even if only compressed available
David Kalnischkies [Thu, 25 Jul 2013 16:51:16 +0000 (18:51 +0200)] 
pick up Translation-* even if only compressed available

On CD-ROMs Translation-* files are only in compressed form included in
the Release file. This used to work while we had no record of
Translation-* files in the Release file at all as APT would have just
guessed the (compressed) filename and accepted it (unchecked), but now
that it checks for the presents of entries and if it finds records it
expects the uncompressed to be verifiable.

This commit relaxes this requirement again to fix the regression.
We are still secure "enough" as we can validate the compressed file we have
downloaded, so we don't loose anything by not requiring a hashsum for
the uncompressed files to double-check them.

Closes: 717665
11 years agofix travis.yml
Michael Vogt [Thu, 25 Jul 2013 19:06:40 +0000 (21:06 +0200)] 
fix travis.yml

11 years agoadd missing "free(buffer) for allocated buffer
Michael Vogt [Thu, 25 Jul 2013 18:55:18 +0000 (20:55 +0200)] 
add missing "free(buffer) for allocated buffer

11 years agofix potential GetLock() fd leak
Michael Vogt [Thu, 25 Jul 2013 18:55:02 +0000 (20:55 +0200)] 
fix potential GetLock() fd leak

11 years agodelete targets data
Michael Vogt [Thu, 25 Jul 2013 18:46:08 +0000 (20:46 +0200)] 
delete targets data

11 years agofix resource leak when verification fails
Michael Vogt [Thu, 25 Jul 2013 18:45:53 +0000 (20:45 +0200)] 
fix resource leak when verification fails

11 years agoapt-pkg/indexcopy.cc: check for pending errors before calling fdopen()
Michael Vogt [Thu, 25 Jul 2013 18:41:03 +0000 (20:41 +0200)] 
apt-pkg/indexcopy.cc: check for pending errors before calling fdopen()

11 years agocall fdopen() after FileFd was checked
Michael Vogt [Thu, 25 Jul 2013 18:36:23 +0000 (20:36 +0200)] 
call fdopen() after FileFd was checked

11 years agoadd .travis.yml
Michael Vogt [Thu, 25 Jul 2013 18:30:59 +0000 (20:30 +0200)] 
add .travis.yml

11 years agofix resource leak (thanks coverity)
Michael Vogt [Thu, 25 Jul 2013 18:26:11 +0000 (20:26 +0200)] 
fix resource leak (thanks coverity)

11 years agorework the code in cdromutl.cc to make coverity (more) happy
Michael Vogt [Thu, 25 Jul 2013 18:22:43 +0000 (20:22 +0200)] 
rework the code in cdromutl.cc to make coverity (more) happy

11 years agofix off-by-one error in HttpMethod::​AutoDetectProxy()
Michael Vogt [Thu, 25 Jul 2013 18:16:31 +0000 (20:16 +0200)] 
fix off-by-one error in HttpMethod::​AutoDetectProxy()

11 years agofix off-by-one error and do not use magic constant of 100 when checking StackPost
Michael Vogt [Thu, 25 Jul 2013 18:14:59 +0000 (20:14 +0200)] 
fix off-by-one error and do not use magic constant of 100 when checking StackPost

11 years agoalways "delete d" in FileFd::~FileFd to coverity happy
Michael Vogt [Thu, 25 Jul 2013 18:14:31 +0000 (20:14 +0200)] 
always "delete d" in FileFd::~FileFd to coverity happy

11 years agoskip all Description fields in apt-cache, not just first (Closes: 717254) 0.9.9.3
Michael Vogt [Thu, 25 Jul 2013 15:15:18 +0000 (17:15 +0200)] 
skip all Description fields in apt-cache, not just first (Closes: 717254)

* skip all Description fields in apt-cache, not just first (Closes: 717254)
* fix 'apt-cache search' crash with missing description (Closes: 647590)

11 years agoMerge remote-tracking branch 'donkult/debian/sid' into debian/sid
Michael Vogt [Thu, 25 Jul 2013 15:13:10 +0000 (17:13 +0200)] 
Merge remote-tracking branch 'donkult/debian/sid' into debian/sid

11 years agoMerge remote-tracking branch 'upstream/debian/sid'
Michael Vogt [Wed, 24 Jul 2013 20:06:18 +0000 (22:06 +0200)] 
Merge remote-tracking branch 'upstream/debian/sid'

11 years agodebian/apt.postinst:
Michael Vogt [Tue, 23 Jul 2013 18:09:05 +0000 (20:09 +0200)] 
debian/apt.postinst:

* debian/apt.postinst:
  - run /etc/kernel/postinst.d/apt-auto-removal once on upgrade
    to ensure that the correct auto-removal list is generated
    (closes: #717615)

11 years agodebian/apt.auto-removal.sh:
Michael Vogt [Tue, 23 Jul 2013 17:55:14 +0000 (19:55 +0200)] 
debian/apt.auto-removal.sh:

* debian/apt.auto-removal.sh:
  - do not include debug symbol packages for the kernel in the
    blacklist (closes: #717616)

11 years agoremove double list include
Michael Vogt [Tue, 23 Jul 2013 13:00:53 +0000 (15:00 +0200)] 
remove double list include

11 years agofix 'apt-cache search' crash with missing description
David Kalnischkies [Thu, 18 Jul 2013 17:22:29 +0000 (19:22 +0200)] 
fix 'apt-cache search' crash with missing description

Beside the earlier fixed 'apt-cache show', 'showpkg' and 'search' deal
with descriptions. 'showpkg' was fixed by fixing the cache generation
for 'show', but 'search' still segfaulted.

On the upside, it doesn't segfault any longer, on the downside, if a
package has no description at all (aka: not in the Packages file and not
in a Translation-* file) the package can't be found with 'search', even
if we search only by name. That is a shortcoming in the code, but fixing
it means rewriting it completely for dubious gain at best.

So this commit just skips packages without a description and is done.

Closes: 647590
11 years agoskip all Description fields in apt-cache, not just first
David Kalnischkies [Thu, 18 Jul 2013 14:52:31 +0000 (16:52 +0200)] 
skip all Description fields in apt-cache, not just first

Given a Packages file like:
[…]
Description: foo bar baz
 moo moo moo
Multi-Arch: foreign
Description-md5: 97e204a9f4ad8c681dbd54ec7c505251
[…]

We have to display the Multi-Arch flag field as well as the fields
after the Description-md5, but not this field itself, as we already
have one printed alongside the Description we display.

Closes: 717254
11 years agoMerge remote-tracking branch 'geissert/proxy-keep-alive' into debian/sid
Michael Vogt [Wed, 17 Jul 2013 14:18:05 +0000 (16:18 +0200)] 
Merge remote-tracking branch 'geissert/proxy-keep-alive' into debian/sid

11 years agofix if-clause to generate hook-info for 'rc' packages (Closes: 717006) 0.9.9.2
Michael Vogt [Wed, 17 Jul 2013 12:56:47 +0000 (14:56 +0200)] 
fix if-clause to generate hook-info for 'rc' packages (Closes: 717006)

11 years agoMerge remote-tracking branch 'donkult/debian/sid' into debian/sid
Michael Vogt [Wed, 17 Jul 2013 12:55:13 +0000 (14:55 +0200)] 
Merge remote-tracking branch 'donkult/debian/sid' into debian/sid

11 years agofix if-clause to generate hook-info for 'rc' packages
David Kalnischkies [Tue, 16 Jul 2013 21:15:55 +0000 (23:15 +0200)] 
fix if-clause to generate hook-info for 'rc' packages

The code incorrectly skips printing of current version information,
if the package has no current version (for APT, but for dpkg as it is
the case for packages which are removed but not purged) by using an
unintended "else if" rather than an "if".

Closes: 717006
11 years agoVietnamese updated by Tran Ngoc Quan. Closes: #717016
Christian PERRIER [Tue, 16 Jul 2013 05:14:05 +0000 (07:14 +0200)] 
Vietnamese updated by Tran Ngoc Quan. Closes: #717016

11 years agoDo not send a connection: keep-alive, at all
Raphael Geissert [Sun, 14 Jul 2013 16:38:03 +0000 (18:38 +0200)] 
Do not send a connection: keep-alive, at all

11 years agoupdate changelog 0.9.9.1
Michael Vogt [Thu, 11 Jul 2013 18:44:52 +0000 (20:44 +0200)] 
update changelog

11 years agoprevent MarkInstall of unsynced Multi-Arch:same siblings
David Kalnischkies [Wed, 10 Jul 2013 11:06:05 +0000 (13:06 +0200)] 
prevent MarkInstall of unsynced Multi-Arch:same siblings

Multi-Arch: same packages can be co-installed, but need to have the same
version for all installed packages (aka "siblings"). Otherwise the
unsynced versions will fight against each other and the auto-install as
wel as the problem resolver will later have to decide between holding the
packages or to remove one of the siblings (usually a foreign) taking a
bunch of packages (like the entire foreign setup) with them.

The idea here is now to be more pro-active: MarkInstall will fail for
a package if the siblings aren't synced, so we don't allow a situation
in which a resolver has to decide if to hold or to remove-upgrade under
the assumption that the remove-upgrade decision is always wrong and
doesn't deserve to be explored (expect valid out-of-syncs of course).

Thats a pretty bold move to take for a library which is used by
different solvers so this check is done in IsInstallOk and can be
overridden if front-ends want to.

11 years agoimplement arch+= and arch-= for sources.list
David Kalnischkies [Fri, 28 Jun 2013 18:42:18 +0000 (20:42 +0200)] 
implement arch+= and arch-= for sources.list

Default is to acquire all architectures from APT::Architectures which
can be changed by arch=, but this isn't very flexible if you want
"mostly" the default as you have to hardcode the architectures then,
so arch-= and arch+= can be used to add/remove architectures from the
default set.

On a machine with 'amd64' and 'i386' configured the lines:
 deb [arch+=armel] http://example.org/debian wheezy rocks
 deb [arch-=amd64] http://example.org/debian jessie rocks
will result in the download of:
 wheezy Packages for 'amd64', 'i386' and 'armel'
 jessie Packages for 'i386'

11 years agoVersion 3 for DPkg::Pre-Install-Pkgs with MultiArch info
David Kalnischkies [Wed, 26 Jun 2013 15:37:57 +0000 (17:37 +0200)] 
Version 3 for DPkg::Pre-Install-Pkgs with MultiArch info

Adds on top of Version 2 to all displayed version numbers the
architecture as well as the MultiArch flag for consumption by the hooks.

Most of the time the architecture will be the same for both versions
displayed, but packages might change from "all" to "any" (or back)
between versions so we can't display the architecture for packages.

Pseudo-Format for Version 3:
<name> <version> <arch> <m-a-flag> <compare> <version> <arch> <m-a-flag>

Examples:
stuff - - none < 1 amd64 none **CONFIGURE**
libsame 1 i386 same < 2 i386 same **CONFIGURE**
stuff 2 i386 none > 1 i386 none **CONFIGURE**
libsame 2 i386 same > - - none **REMOVE**
toolkit 1 all foreign > - - none **REMOVE**

Closes: #712116
11 years agodebian/apt.auto-removal.sh: merge the remaining bits
Michael Vogt [Thu, 11 Jul 2013 05:52:34 +0000 (07:52 +0200)] 
debian/apt.auto-removal.sh: merge the remaining bits

11 years ago* Fix up two things in debian/apt.auto-removal.sh:
Adam Conrad [Tue, 6 Nov 2012 22:54:31 +0000 (15:54 -0700)] 
* Fix up two things in debian/apt.auto-removal.sh:
  - Use exact matches with $-terminated regexes, so we don't get
    confusion between similarly-named kernel flavours.
  - Keep linux-backports-modules in sync with installed kernels.
Conflicts:
configure.in
debian/changelog
doc/apt-verbatim.ent

11 years agoget dpkg from apt-config as well and add robustness against missing/failing apt-confi...
Michael Vogt [Mon, 5 Nov 2012 09:27:17 +0000 (10:27 +0100)] 
get dpkg from apt-config as well and add robustness against missing/failing apt-config (for paranoia)
Conflicts:
debian/apt.auto-removal.sh

11 years agoMake sure we always have at least two kernels marked not for removal
Steve Langasek [Sat, 3 Nov 2012 07:28:54 +0000 (08:28 +0100)] 
Make sure we always have at least two kernels marked not for removal

11 years agocherry pick 39a07ec8f2c612a5af234c7713571362f7ca90b4
Steve Langasek [Fri, 2 Nov 2012 23:39:19 +0000 (00:39 +0100)] 
cherry pick 39a07ec8f2c612a5af234c7713571362f7ca90b4

11 years agoapt-pkg/packagemanager.cc:
Michael Vogt [Wed, 10 Jul 2013 14:41:14 +0000 (16:41 +0200)] 
apt-pkg/packagemanager.cc:

* apt-pkg/packagemanager.cc:
  - increate APT::pkgPackageManager::MaxLoopCount to 5000

11 years agodebian/rules:
Michael Vogt [Fri, 5 Jul 2013 14:41:06 +0000 (16:41 +0200)] 
debian/rules:

* debian/rules:
  - call dh_clean in clean (closes: #714980)