[英]Adding Null Padding to UUEncoder in C
我知道我即将完成此UUEncoder函数; 我将使用它与嵌入式设备进行通信。 但是我一生都无法弄清楚如何正确插入最后的空填充字符。
我一直在尝试遵循此处的示例。
void encode(unsigned char fileData_Hex_String[], int hexDataCharCount)
{
unsigned char UUE_Encoded_String[MAX_SIZE];
unsigned char b[2];
unsigned char d[3];
int UUE_Encoded_String_Index = 0;
hexDataCharCount =7;
for(int hexDataIndex = 0; hexDataIndex < hexDataCharCount; hexDataIndex)
{
// Load chars or nulls
for (int i = 0; i < 3; ++i)
{
b[i] = fileData_Hex_String[hexDataIndex];
printf("%i\n", (hexDataIndex - hexDataCharCount));
if ((hexDataIndex - hexDataCharCount) > 0)
{
b[1] = '\n';
b[2] = '\n';
break;
}
hexDataIndex++;
}
// UUEncode
d[0] = (((b[0] >> 2) & 0x3f) + ' ');
d[1] = ((((b[0] << 4) | ((b[1] >> 4) & 0x0f)) & 0x3f) + ' ');
d[2] = ((((b[1] << 2) | ((b[2] >> 6) & 0x03)) & 0x3f) + ' ');
d[3] = ((b[2] & 0x3f) + ' ');
// Put the UUEncoded chars into their own string.
for (int i = 0; i < 4; i++)
{
UUE_Encoded_String[UUE_Encoded_String_Index] = d[i];
printf(" 0x%2x \n", UUE_Encoded_String[UUE_Encoded_String_Index]);
UUE_Encoded_String_Index++;
}
}
}
一切正常,除了在结尾0x48和0x2A处得到两个多余的字符。
您的数组太小。 您已经声明
unsigned char b[2];
unsigned char d[3];
但索引都超出范围
d[3] = ((b[2] & 0x3f) + ' ');
所以你应该声明
unsigned char b[3];
unsigned char d[4];
\\n
不是null
,而是换行符。 如果你把
b[1] = 0;
b[2] = 0;
最后两个字节将是0x20 0x20
。 但是,如果您这样编写循环,则代码将更加灵活
// Load chars or nulls
for (i = 0; i < 3; ++i)
{
if (hexDataIndex < hexDataCharCount)
b[i] = fileData_Hex_String[hexDataIndex];
else
b[i] = 0;
hexDataIndex++;
}
Weather Vane之后的工作代码对我有所帮助。
void encode2(unsigned char fileData_Hex_String[], int hexDataCharCount)
{
unsigned char UUE_Encoded_String[MAX_SIZE];
unsigned char b[3];
unsigned char d[4];
int paddedIndex = 0;
int UUE_Encoded_String_Index = 0;
for(int hexDataIndex = 0; hexDataIndex < hexDataCharCount; hexDataIndex)
{
// Load chars or nulls
for (int i = 0; i < 3; i++)
{
if (hexDataIndex < hexDataCharCount)
{
b[i] = fileData_Hex_String[hexDataIndex];
}
else
{
b[i] = 0;
paddedIndex++;
}
//printf("%i\n", (hexDataIndex-hexDataCharCount));
hexDataIndex++;
}
// UUEncode
d[0] = (((b[0] >> 2) & 0x3f) + ' ');
d[1] = ((((b[0] << 4) | ((b[1] >> 4) & 0x0f)) & 0x3f) + ' ');
d[2] = ((((b[1] << 2) | ((b[2] >> 6) & 0x03)) & 0x3f) + ' ');
d[3] = ((b[2] & 0x3f) + ' ');
// Put the UUEncoded chars into their own string.
for (int i = 0; i < 4; i++)
{
UUE_Encoded_String[UUE_Encoded_String_Index] = d[i];
UUE_Encoded_String_Index++;
}
//printf(" %i %i\n", hexDataIndex, hexDataCharCount);
}
printf("%i\n", (UUE_Encoded_String_Index-paddedIndex));
for (int i = 0; i < (UUE_Encoded_String_Index-paddedIndex); ++i)
{
printf(" 0x%2x \n", UUE_Encoded_String[i]);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.