mirror of
https://github.com/reactos/reactos.git
synced 2025-05-07 02:41:22 +00:00
58 lines
1.5 KiB
C
58 lines
1.5 KiB
C
![]() |
/*
|
||
|
* PROJECT: ReactOS Automatic Testing Utility
|
||
|
* LICENSE: GNU GPLv2 or any later version as published by the Free Software Foundation
|
||
|
* PURPOSE: Various helper functions
|
||
|
* COPYRIGHT: Copyright 2008-2009 Colin Finck <colin@reactos.org>
|
||
|
*/
|
||
|
|
||
|
#include "precomp.h"
|
||
|
|
||
|
/**
|
||
|
* Escapes a string according to RFC 1738.
|
||
|
* Required for passing parameters to the web service.
|
||
|
*
|
||
|
* @param Output
|
||
|
* Pointer to a CHAR array, which will receive the escaped string.
|
||
|
* The output buffer must be large enough to hold the full escaped string. You're on the safe side
|
||
|
* if you make the output buffer three times as large as the input buffer.
|
||
|
*
|
||
|
* @param Input
|
||
|
* Pointer to a CHAR array, which contains the input buffer to escape.
|
||
|
*/
|
||
|
VOID
|
||
|
EscapeString(PCHAR Output, PCHAR Input)
|
||
|
{
|
||
|
const CHAR HexCharacters[] = "0123456789ABCDEF";
|
||
|
|
||
|
do
|
||
|
{
|
||
|
if(strchr("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.~", *Input) )
|
||
|
{
|
||
|
/* It's a character we don't need to escape, just add it to the output string */
|
||
|
*Output++ = *Input;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
/* We need to escape this character */
|
||
|
*Output++ = '%';
|
||
|
*Output++ = HexCharacters[((UCHAR)*Input >> 4) % 16];
|
||
|
*Output++ = HexCharacters[(UCHAR)*Input % 16];
|
||
|
}
|
||
|
} while(*++Input);
|
||
|
|
||
|
*Output = 0;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Outputs a string through the standard output and the debug output.
|
||
|
*
|
||
|
* @param String
|
||
|
* The string to output
|
||
|
*/
|
||
|
VOID
|
||
|
StringOut(PCHAR String)
|
||
|
{
|
||
|
printf(String);
|
||
|
OutputDebugStringA(String);
|
||
|
}
|