Apply apt-0.5.15lorg2-alt-realloc.patch

Added in commit d9cc297:
Fix realloc(3) usage.
This commit is contained in:
Gleb Fotengauer-Malinovskiy 2014-05-16 21:04:22 +04:00
parent 3fb1186bee
commit b99eba002f
3 changed files with 16 additions and 76 deletions

View File

@ -1,64 +0,0 @@
diff -upk.orig apt-0.5.15lorg2.orig/apt-pkg/rpm/rpmrecords.cc apt-0.5.15lorg2/apt-pkg/rpm/rpmrecords.cc
--- apt-0.5.15lorg2.orig/apt-pkg/rpm/rpmrecords.cc 2006-10-05 14:24:39 +0000
+++ apt-0.5.15lorg2/apt-pkg/rpm/rpmrecords.cc 2006-10-05 17:00:00 +0000
@@ -197,20 +197,22 @@ void rpmRecordParser::BufCat(const char
{
unsigned len = end - begin;
- if (BufUsed+len+1 >= BufSize)
+ while (BufUsed + len + 1 >= BufSize)
{
- BufSize += 512;
- char *tmp = (char*)realloc(Buffer, BufSize);
- if (tmp == NULL)
+ size_t new_size = BufSize + 512;
+ char *new_buf = (char*)realloc(Buffer, new_size);
+ if (new_buf == NULL)
{
_error->Errno("realloc", _("Could not allocate buffer for record text"));
return;
}
- Buffer = tmp;
+ Buffer = new_buf;
+ BufSize = new_size;
}
- strncpy(Buffer+BufUsed, begin, len);
+ memcpy(Buffer+BufUsed, begin, len);
BufUsed += len;
+ Buffer[BufUsed] = '\0';
}
void rpmRecordParser::BufCatTag(const char *tag, const char *value)
diff -upk.orig apt-0.5.15lorg2.orig/apt-pkg/rpm/rpmsrcrecords.cc apt-0.5.15lorg2/apt-pkg/rpm/rpmsrcrecords.cc
--- apt-0.5.15lorg2.orig/apt-pkg/rpm/rpmsrcrecords.cc 2006-10-05 14:24:39 +0000
+++ apt-0.5.15lorg2/apt-pkg/rpm/rpmsrcrecords.cc 2006-10-05 17:00:06 +0000
@@ -220,20 +220,22 @@ void rpmSrcRecordParser::BufCat(char *be
{
unsigned len = end - begin;
- if (BufUsed+len+1 >= BufSize)
+ while (BufUsed + len + 1 >= BufSize)
{
- BufSize += 512;
- char *tmp = (char*)realloc(Buffer, BufSize);
- if (tmp == NULL)
+ size_t new_size = BufSize + 512;
+ char *new_buf = (char*)realloc(Buffer, new_size);
+ if (new_buf == NULL)
{
_error->Errno("realloc", _("Could not allocate buffer for record text"));
return;
}
- Buffer = tmp;
+ Buffer = new_buf;
+ BufSize = new_size;
}
- strncpy(Buffer+BufUsed, begin, len);
+ memcpy(Buffer+BufUsed, begin, len);
BufUsed += len;
+ Buffer[BufUsed] = '\0';
}
void rpmSrcRecordParser::BufCatTag(char *tag, char *value)

View File

@ -218,20 +218,22 @@ void rpmRecordParser::BufCat(const char *begin, const char *end)
{ {
unsigned len = end - begin; unsigned len = end - begin;
if (BufUsed+len+1 >= BufSize) while (BufUsed + len + 1 >= BufSize)
{ {
BufSize += 512; size_t new_size = BufSize + 512;
char *tmp = (char*)realloc(Buffer, BufSize); char *new_buf = (char*)realloc(Buffer, new_size);
if (tmp == NULL) if (new_buf == NULL)
{ {
_error->Errno("realloc", _("Could not allocate buffer for record text")); _error->Errno("realloc", _("Could not allocate buffer for record text"));
return; return;
} }
Buffer = tmp; Buffer = new_buf;
BufSize = new_size;
} }
strncpy(Buffer+BufUsed, begin, len); memcpy(Buffer+BufUsed, begin, len);
BufUsed += len; BufUsed += len;
Buffer[BufUsed] = '\0';
} }
void rpmRecordParser::BufCatTag(const char *tag, const char *value) void rpmRecordParser::BufCatTag(const char *tag, const char *value)

View File

@ -240,20 +240,22 @@ void rpmSrcRecordParser::BufCat(const char *begin, const char *end)
{ {
unsigned len = end - begin; unsigned len = end - begin;
if (BufUsed+len+1 >= BufSize) while (BufUsed + len + 1 >= BufSize)
{ {
BufSize += 512; size_t new_size = BufSize + 512;
char *tmp = (char*)realloc(Buffer, BufSize); char *new_buf = (char*)realloc(Buffer, new_size);
if (tmp == NULL) if (new_buf == NULL)
{ {
_error->Errno("realloc", _("Could not allocate buffer for record text")); _error->Errno("realloc", _("Could not allocate buffer for record text"));
return; return;
} }
Buffer = tmp; Buffer = new_buf;
BufSize = new_size;
} }
strncpy(Buffer+BufUsed, begin, len); memcpy(Buffer+BufUsed, begin, len);
BufUsed += len; BufUsed += len;
Buffer[BufUsed] = '\0';
} }
void rpmSrcRecordParser::BufCatTag(const char *tag, const char *value) void rpmSrcRecordParser::BufCatTag(const char *tag, const char *value)