]> git.saurik.com Git - apt.git/commitdiff
* apt-pkg/contrib/cmdline.cc:
authorDavid Kalnischkies <kalnischkies@gmail.com>
Mon, 31 May 2010 15:22:04 +0000 (17:22 +0200)
committerDavid Kalnischkies <kalnischkies@gmail.com>
Mon, 31 May 2010 15:22:04 +0000 (17:22 +0200)
  - fix segfault in SaveInConfig caused by writing over char[] sizes

apt-pkg/contrib/cmndline.cc
debian/changelog

index 0b16bf51a5387d469d2a0857d510c3d0f0d9b0c3..5a994409663e299b6e4ca6991f1a13ba28950709 100644 (file)
@@ -360,11 +360,11 @@ bool CommandLine::DispatchArg(Dispatch *Map,bool NoMatch)
    than nothing after all. */
 void CommandLine::SaveInConfig(unsigned int const &argc, char const * const * const argv)
 {
-   char cmdline[300];
+   char cmdline[100 + argc * 50];
    unsigned int length = 0;
    bool lastWasOption = false;
    bool closeQuote = false;
-   for (unsigned int i = 0; i < argc; ++i, ++length)
+   for (unsigned int i = 0; i < argc && length < sizeof(cmdline); ++i, ++length)
    {
       for (unsigned int j = 0; argv[i][j] != '\0' && length < sizeof(cmdline)-1; ++j, ++length)
       {
index 79768a7799682745bf73b040e02057fb28e59c38..6341484f267a9b1d7f8543603640b14e860edc04 100644 (file)
@@ -26,8 +26,10 @@ apt (0.7.26~exp6) UNRELEASED; urgency=low
     - add a simple wrapper around std::set for packages with it
     - move regex magic from apt-get to new FromRegEx method
     - move cmdline parsing from apt-cache to new FromCommandLine method
+  * apt-pkg/contrib/cmdline.cc:
+    - fix segfault in SaveInConfig caused by writing over char[] sizes
 
- -- David Kalnischkies <kalnischkies@gmail.com>  Sat, 29 May 2010 19:09:05 +0200
+ -- David Kalnischkies <kalnischkies@gmail.com>  Mon, 31 May 2010 17:21:00 +0200
 
 apt (0.7.26~exp5) experimental; urgency=low