BUG: Do not increment optr by 2 after storing only one character. Also fixed possibility of storing uninitialized characters from the last triplet.
This commit is contained in:
parent
2b27152af2
commit
33abddf90c
@ -254,16 +254,27 @@ unsigned long kwsysBase64_Decode(const unsigned char *input,
|
|||||||
{
|
{
|
||||||
unsigned char temp[3];
|
unsigned char temp[3];
|
||||||
int len = kwsysBase64_Decode3(ptr, temp);
|
int len = kwsysBase64_Decode3(ptr, temp);
|
||||||
|
if(len >= 2)
|
||||||
|
{
|
||||||
optr[0] = temp[0];
|
optr[0] = temp[0];
|
||||||
optr[1] = temp[1];
|
optr[1] = temp[1];
|
||||||
optr += (len > 2 ? 2 : len);
|
optr += 2;
|
||||||
|
}
|
||||||
|
else if(len > 0)
|
||||||
|
{
|
||||||
|
optr[0] = temp[0];
|
||||||
|
optr += 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (oend - optr == 1)
|
else if (oend - optr == 1)
|
||||||
{
|
{
|
||||||
unsigned char temp[3];
|
unsigned char temp[3];
|
||||||
int len = kwsysBase64_Decode3(ptr, temp);
|
int len = kwsysBase64_Decode3(ptr, temp);
|
||||||
|
if(len > 0)
|
||||||
|
{
|
||||||
optr[0] = temp[0];
|
optr[0] = temp[0];
|
||||||
optr += (len > 2 ? 2 : len);
|
optr += 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user