mirror of
https://github.com/reactos/reactos.git
synced 2025-02-25 01:39:30 +00:00

Without any parameters, it mostly works the same as our current solution, but all in a standalone application. Adding the /w parameter will submit all results to the web service committed in my previous commit. The application would also make it possible to run Wine Tests regularly on a Windows machine and submitting the results. This would make sure that all Wine tests also pass under Windows. svn path=/trunk/; revision=38580
57 lines
1.5 KiB
C
57 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);
|
|
}
|