2013-07-16 14:53:51 +00:00
|
|
|
/*
|
|
|
|
This file is part of libpsyc.
|
|
|
|
Copyright (C) 2011,2012 Carlo v. Loesch, Gabor X Toth, Mathias L. Baumann,
|
|
|
|
and other contributing authors.
|
|
|
|
|
|
|
|
libpsyc is free software: you can redistribute it and/or modify it under the
|
|
|
|
terms of the GNU Affero General Public License as published by the Free
|
|
|
|
Software Foundation, either version 3 of the License, or (at your option) any
|
|
|
|
later version. As a special exception, libpsyc is distributed with additional
|
|
|
|
permissions to link libpsyc libraries with non-AGPL works.
|
|
|
|
|
|
|
|
libpsyc is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
|
|
|
details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License and
|
|
|
|
the linking exception along with libpsyc in a COPYING file.
|
|
|
|
*/
|
|
|
|
|
2011-05-14 19:16:11 +00:00
|
|
|
#include <ctype.h>
|
2011-05-14 00:18:01 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2011-05-15 09:51:30 +00:00
|
|
|
#include <stdint.h>
|
2011-05-14 00:18:01 +00:00
|
|
|
#include <assert.h>
|
|
|
|
#include <unistd.h>
|
2011-05-14 19:16:11 +00:00
|
|
|
#include <getopt.h>
|
2011-05-14 00:18:01 +00:00
|
|
|
#include <sys/socket.h>
|
|
|
|
|
|
|
|
#include <psyc.h>
|
|
|
|
|
2011-05-16 18:13:10 +00:00
|
|
|
#include "test.c"
|
2011-05-14 00:18:01 +00:00
|
|
|
|
|
|
|
// max size for routing & entity header
|
|
|
|
#define ROUTING_LINES 16
|
|
|
|
#define ENTITY_LINES 32
|
|
|
|
|
2011-05-14 16:21:00 +00:00
|
|
|
// cmd line args
|
2011-05-14 19:16:11 +00:00
|
|
|
char *filename, *port = "4440";
|
2011-05-15 19:12:17 +00:00
|
|
|
uint8_t verbose, stats;
|
|
|
|
uint8_t multiple, single, routing_only, no_render, quiet, progress;
|
2011-05-18 20:00:28 +00:00
|
|
|
size_t count = 1, recv_buf_size;
|
2011-05-14 16:21:00 +00:00
|
|
|
|
2011-10-31 19:26:47 +00:00
|
|
|
PsycParseState parsers[NUM_PARSERS];
|
|
|
|
PsycPacket packets[NUM_PARSERS];
|
|
|
|
PsycModifier routing[NUM_PARSERS][ROUTING_LINES];
|
|
|
|
PsycModifier entity[NUM_PARSERS][ENTITY_LINES];
|
2011-05-14 16:21:00 +00:00
|
|
|
|
2011-05-15 19:12:17 +00:00
|
|
|
int contbytes, exit_code;
|
2011-05-14 00:18:01 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
static inline void
|
|
|
|
resetString (PsycString *s, uint8_t freeptr);
|
2011-05-16 18:13:10 +00:00
|
|
|
|
2011-05-15 20:48:51 +00:00
|
|
|
// initialize parser & packet variables
|
2011-11-11 21:18:24 +00:00
|
|
|
void
|
|
|
|
test_init (int i)
|
|
|
|
{
|
|
|
|
// reset parser state & packet
|
|
|
|
psyc_parse_state_init(&parsers[i],
|
|
|
|
routing_only ? PSYC_PARSE_ROUTING_ONLY : PSYC_PARSE_ALL);
|
|
|
|
|
|
|
|
memset(&packets[i], 0, sizeof(PsycPacket));
|
|
|
|
memset(&routing[i], 0, sizeof(PsycModifier) * ROUTING_LINES);
|
|
|
|
memset(&entity[i], 0, sizeof(PsycModifier) * ENTITY_LINES);
|
|
|
|
packets[i].routing.modifiers = routing[i];
|
|
|
|
packets[i].entity.modifiers = entity[i];
|
2011-05-14 00:18:01 +00:00
|
|
|
}
|
|
|
|
|
2011-05-15 20:48:51 +00:00
|
|
|
// parse & render input
|
2011-11-11 21:18:24 +00:00
|
|
|
int
|
|
|
|
test_input (int i, char *recvbuf, size_t nbytes)
|
|
|
|
{
|
1984-04-04 00:44:05 +00:00
|
|
|
int j, ret, retl;
|
2011-11-11 21:18:24 +00:00
|
|
|
char sendbuf[SEND_BUF_SIZE];
|
|
|
|
char *parsebuf = recvbuf - contbytes;
|
|
|
|
/* We have a buffer with pointers pointing to various parts of it:
|
|
|
|
* *contbuf-vv
|
|
|
|
* buffer: [ ccrrrr]
|
|
|
|
* *recvbuf---^^^^
|
|
|
|
* *parsebuf-^^^^^^
|
|
|
|
*
|
|
|
|
* New data is in recvbuf, if it contains an incomplete packet then remaining
|
|
|
|
* unparsed data is copied to contbuf that will be parsed during the next call
|
|
|
|
* to this function together with the new data.
|
|
|
|
*/
|
|
|
|
|
|
|
|
PsycParseState *parser = &parsers[i];
|
|
|
|
PsycPacket *packet = &packets[i];
|
|
|
|
|
|
|
|
char oper;
|
2012-02-06 14:05:08 +00:00
|
|
|
PsycString name, value, type;
|
2011-11-11 21:18:24 +00:00
|
|
|
PsycString *pname = NULL, *pvalue = NULL;
|
|
|
|
PsycModifier *mod = NULL;
|
2012-02-06 14:05:08 +00:00
|
|
|
PsycParseListState lstate;
|
|
|
|
PsycParseDictState dstate;
|
2011-11-11 21:18:24 +00:00
|
|
|
size_t len;
|
|
|
|
|
|
|
|
// Set buffer with data for the parser.
|
|
|
|
psyc_parse_buffer_set(parser, parsebuf, contbytes + nbytes);
|
|
|
|
contbytes = 0;
|
|
|
|
oper = 0;
|
|
|
|
name.length = 0;
|
|
|
|
value.length = 0;
|
|
|
|
|
|
|
|
do {
|
|
|
|
if (verbose >= 3)
|
|
|
|
printf("\n# buffer = [%.*s]\n# part = %d\n",
|
|
|
|
(int)parser->buffer.length, parser->buffer.data, parser->part);
|
|
|
|
// Parse the next part of the packet (a routing/entity modifier or the body)
|
|
|
|
ret = exit_code = psyc_parse(parser, &oper, &name, &value);
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("# ret = %d\n", ret);
|
|
|
|
|
|
|
|
switch (ret) {
|
|
|
|
case PSYC_PARSE_ROUTING:
|
|
|
|
assert(packet->routing.lines < ROUTING_LINES);
|
|
|
|
mod = &(packet->routing.modifiers[packet->routing.lines]);
|
|
|
|
pname = &mod->name;
|
|
|
|
pvalue = &mod->value;
|
|
|
|
mod->flag = PSYC_MODIFIER_ROUTING;
|
|
|
|
packet->routing.lines++;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PSYC_PARSE_STATE_RESYNC:
|
|
|
|
case PSYC_PARSE_STATE_RESET:
|
|
|
|
packet->stateop = oper;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PSYC_PARSE_ENTITY_START:
|
|
|
|
case PSYC_PARSE_ENTITY_CONT:
|
|
|
|
case PSYC_PARSE_ENTITY_END:
|
|
|
|
case PSYC_PARSE_ENTITY:
|
|
|
|
assert(packet->entity.lines < ENTITY_LINES);
|
|
|
|
mod = &(packet->entity.modifiers[packet->entity.lines]);
|
|
|
|
pname = &mod->name;
|
|
|
|
pvalue = &mod->value;
|
|
|
|
|
|
|
|
if (ret == PSYC_PARSE_ENTITY || ret == PSYC_PARSE_ENTITY_END) {
|
|
|
|
packet->entity.lines++;
|
|
|
|
mod->flag = psyc_parse_value_length_found(parser) ?
|
|
|
|
PSYC_MODIFIER_NEED_LENGTH : PSYC_MODIFIER_NO_LENGTH;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PSYC_PARSE_BODY_START:
|
|
|
|
case PSYC_PARSE_BODY_CONT:
|
|
|
|
case PSYC_PARSE_BODY_END:
|
|
|
|
case PSYC_PARSE_BODY:
|
|
|
|
pname = &(packet->method);
|
|
|
|
pvalue = &(packet->data);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PSYC_PARSE_COMPLETE:
|
|
|
|
if (verbose)
|
|
|
|
printf("# Done parsing.\n");
|
|
|
|
else if (progress)
|
1984-04-04 00:44:05 +00:00
|
|
|
(void) write(1, ".", 1);
|
2011-11-11 21:18:24 +00:00
|
|
|
if ((filename && !multiple) || (!filename && single))
|
|
|
|
ret = -1;
|
|
|
|
|
|
|
|
if (!no_render) {
|
|
|
|
packet->flag = psyc_parse_content_length_found(parser) ?
|
|
|
|
PSYC_PACKET_NEED_LENGTH : PSYC_PACKET_NO_LENGTH;
|
|
|
|
|
|
|
|
if (routing_only) {
|
|
|
|
packet->content = packet->data;
|
|
|
|
resetString(&(packet->data), 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
psyc_packet_length_set(packet);
|
|
|
|
|
|
|
|
if (PSYC_RENDER_SUCCESS == psyc_render(packet, sendbuf,
|
|
|
|
SEND_BUF_SIZE)) {
|
|
|
|
if (!quiet) {
|
|
|
|
if (filename && write(1, sendbuf, packet->length) == -1) {
|
|
|
|
perror("write");
|
|
|
|
ret = -1;
|
|
|
|
} else if (!filename && -1 == send(i, sendbuf,
|
|
|
|
packet->length, 0)) {
|
|
|
|
perror("send");
|
|
|
|
ret = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
printf("# Render error");
|
|
|
|
ret = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// reset packet
|
2011-11-26 14:03:10 +00:00
|
|
|
packet->routinglen = 0;
|
|
|
|
packet->contentlen = 0;
|
2011-11-11 21:18:24 +00:00
|
|
|
packet->length = 0;
|
|
|
|
packet->flag = 0;
|
|
|
|
|
|
|
|
for (j = 0; j < packet->routing.lines; j++) {
|
|
|
|
resetString(&(packet->routing.modifiers[j].name), 1);
|
|
|
|
resetString(&(packet->routing.modifiers[j].value), 1);
|
|
|
|
}
|
|
|
|
packet->routing.lines = 0;
|
|
|
|
|
|
|
|
if (routing_only) {
|
|
|
|
resetString(&(packet->content), 1);
|
|
|
|
} else {
|
|
|
|
for (j = 0; j < packet->entity.lines; j++) {
|
|
|
|
resetString(&(packet->entity.modifiers[j].name), 1);
|
|
|
|
resetString(&(packet->entity.modifiers[j].value), 1);
|
|
|
|
}
|
|
|
|
packet->entity.lines = 0;
|
|
|
|
|
|
|
|
resetString(&(packet->method), 1);
|
|
|
|
resetString(&(packet->data), 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case PSYC_PARSE_INSUFFICIENT:
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("# Insufficient data.\n");
|
|
|
|
|
|
|
|
contbytes = psyc_parse_remaining_length(parser);
|
|
|
|
|
|
|
|
if (contbytes > 0) { // copy end of parsebuf before start of recvbuf
|
2011-06-02 11:25:48 +00:00
|
|
|
if (verbose >= 3)
|
2011-11-11 21:18:24 +00:00
|
|
|
printf("# remaining = [%.*s]\n",
|
|
|
|
(int)contbytes, psyc_parse_remaining_buffer(parser));
|
|
|
|
assert(contbytes <= CONT_BUF_SIZE); // make sure it fits in the buffer
|
|
|
|
memmove(recvbuf - contbytes,
|
|
|
|
psyc_parse_remaining_buffer(parser), contbytes);
|
|
|
|
}
|
|
|
|
ret = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
printf("# Error while parsing: %i\n", ret);
|
|
|
|
ret = -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (ret) {
|
|
|
|
case PSYC_PARSE_ENTITY_START:
|
|
|
|
case PSYC_PARSE_ENTITY_CONT:
|
|
|
|
case PSYC_PARSE_BODY_START:
|
|
|
|
case PSYC_PARSE_BODY_CONT:
|
|
|
|
ret = 0;
|
|
|
|
case PSYC_PARSE_ENTITY:
|
|
|
|
case PSYC_PARSE_ENTITY_END:
|
|
|
|
case PSYC_PARSE_ROUTING:
|
|
|
|
case PSYC_PARSE_BODY:
|
|
|
|
case PSYC_PARSE_BODY_END:
|
|
|
|
if (oper) {
|
|
|
|
mod->oper = oper;
|
2011-05-14 00:18:01 +00:00
|
|
|
if (verbose >= 2)
|
2011-11-11 21:18:24 +00:00
|
|
|
printf("%c", oper);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (name.length) {
|
|
|
|
pname->data = malloc(name.length);
|
|
|
|
pname->length = name.length;
|
2011-05-14 00:18:01 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
assert(pname->data != NULL);
|
|
|
|
memcpy((void*)pname->data, name.data, name.length);
|
|
|
|
name.length = 0;
|
|
|
|
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("%.*s = ", (int)pname->length, pname->data);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (value.length) {
|
|
|
|
if (!pvalue->length) {
|
|
|
|
if (psyc_parse_value_length_found(parser))
|
|
|
|
len = psyc_parse_value_length(parser);
|
|
|
|
else
|
|
|
|
len = value.length;
|
|
|
|
pvalue->data = malloc(len);
|
|
|
|
}
|
|
|
|
assert(pvalue->data != NULL);
|
|
|
|
memcpy((void*)pvalue->data + pvalue->length, value.data, value.length);
|
|
|
|
pvalue->length += value.length;
|
|
|
|
value.length = 0;
|
|
|
|
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("[%.*s]", (int)pvalue->length, pvalue->data);
|
2011-11-26 14:03:10 +00:00
|
|
|
if (parser->valuelen > pvalue->length)
|
2011-11-11 21:18:24 +00:00
|
|
|
printf("...");
|
|
|
|
printf("\n");
|
2011-05-14 00:18:01 +00:00
|
|
|
}
|
2011-11-11 21:18:24 +00:00
|
|
|
}
|
|
|
|
else if (verbose)
|
|
|
|
printf("\n");
|
|
|
|
|
|
|
|
if (verbose >= 3)
|
|
|
|
printf("\t\t\t\t\t\t\t\t# n:%ld v:%ld c:%ld r:%ld\n",
|
|
|
|
pname->length, pvalue->length,
|
2011-11-26 14:03:10 +00:00
|
|
|
parser->content_parsed, parser->routinglen);
|
2011-11-11 21:18:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (ret) {
|
|
|
|
case PSYC_PARSE_ROUTING:
|
|
|
|
case PSYC_PARSE_ENTITY:
|
|
|
|
case PSYC_PARSE_ENTITY_END:
|
|
|
|
oper = 0;
|
|
|
|
name.length = 0;
|
|
|
|
value.length = 0;
|
2012-02-06 14:05:08 +00:00
|
|
|
type.length = 0;
|
2011-05-14 00:18:01 +00:00
|
|
|
|
2012-02-06 14:05:08 +00:00
|
|
|
switch (psyc_var_type(PSYC_S2ARG(*pname))) {
|
|
|
|
case PSYC_TYPE_LIST:
|
2011-11-11 21:18:24 +00:00
|
|
|
if (verbose >= 2)
|
|
|
|
printf("## LIST START\n");
|
|
|
|
|
2012-02-06 14:05:08 +00:00
|
|
|
psyc_parse_list_state_init(&lstate);
|
|
|
|
psyc_parse_list_buffer_set(&lstate, PSYC_S2ARG(*pvalue));
|
2011-11-11 21:18:24 +00:00
|
|
|
|
|
|
|
do {
|
2012-02-06 14:05:08 +00:00
|
|
|
retl = psyc_parse_list(&lstate, &type, &value);
|
2011-11-11 21:18:24 +00:00
|
|
|
switch (retl) {
|
2012-02-06 14:05:08 +00:00
|
|
|
case PSYC_PARSE_LIST_TYPE:
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("## LIST TYPE: %.*s\n", (int)type.length, type.data);
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_LIST_ELEM_START:
|
|
|
|
case PSYC_PARSE_LIST_ELEM_LAST:
|
2011-11-11 21:18:24 +00:00
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_LIST_ELEM:
|
|
|
|
if (verbose >= 2) {
|
2012-02-06 14:05:08 +00:00
|
|
|
printf("|%.*s [%.*s]", (int)type.length, type.data,
|
|
|
|
(int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_LIST_ELEM_START)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
if (ret == PSYC_PARSE_LIST_ELEM_LAST)
|
|
|
|
printf("## LAST ELEM\n");
|
2011-11-11 21:18:24 +00:00
|
|
|
}
|
|
|
|
break;
|
2012-02-06 14:05:08 +00:00
|
|
|
case PSYC_PARSE_LIST_ELEM_CONT:
|
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_LIST_ELEM_END:
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("... [%.*s]", (int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_LIST_ELEM_CONT)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_LIST_END:
|
|
|
|
retl = 0;
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("## LIST END\n");
|
|
|
|
break;
|
2011-11-11 21:18:24 +00:00
|
|
|
default:
|
|
|
|
printf("# Error while parsing list: %i\n", retl);
|
|
|
|
ret = retl = -1;
|
|
|
|
}
|
2012-02-06 14:05:08 +00:00
|
|
|
} while (retl > 0);
|
|
|
|
break;
|
|
|
|
case PSYC_TYPE_DICT:
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("## DICT START\n");
|
|
|
|
|
|
|
|
psyc_parse_dict_state_init(&dstate);
|
|
|
|
psyc_parse_dict_buffer_set(&dstate, PSYC_S2ARG(*pvalue));
|
|
|
|
|
|
|
|
do {
|
|
|
|
retl = psyc_parse_dict(&dstate, &type, &value);
|
|
|
|
switch (retl) {
|
|
|
|
case PSYC_PARSE_DICT_TYPE:
|
|
|
|
if (verbose >= 2)
|
|
|
|
printf("## DICT TYPE: %.*s\n", (int)type.length, type.data);
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_DICT_KEY_START:
|
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_DICT_KEY:
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("{[%.*s]", (int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_DICT_KEY_START)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_DICT_KEY_CONT:
|
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_DICT_KEY_END:
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("... [%.*s]", (int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_DICT_KEY_CONT)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_DICT_VALUE_START:
|
|
|
|
case PSYC_PARSE_DICT_VALUE_LAST:
|
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_DICT_VALUE:
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("}%.*s [%.*s]", (int)type.length, type.data,
|
|
|
|
(int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_DICT_VALUE_START)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
if (ret == PSYC_PARSE_DICT_VALUE_LAST)
|
|
|
|
printf("## LAST VALUE\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_DICT_VALUE_CONT:
|
|
|
|
retl = 0;
|
|
|
|
case PSYC_PARSE_DICT_VALUE_END:
|
|
|
|
if (verbose >= 2) {
|
|
|
|
printf("... [%.*s]", (int)value.length, value.data);
|
|
|
|
if (retl == PSYC_PARSE_DICT_VALUE_CONT)
|
|
|
|
printf(" ...");
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PSYC_PARSE_DICT_END:
|
|
|
|
retl = 0;
|
|
|
|
printf("## DICT END\n");
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
printf("# Error while parsing dict: %i\n", retl);
|
|
|
|
ret = retl = -1;
|
|
|
|
}
|
|
|
|
} while (retl > 0);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2011-11-11 21:18:24 +00:00
|
|
|
}
|
2011-05-14 00:18:01 +00:00
|
|
|
}
|
2012-02-06 14:05:08 +00:00
|
|
|
} while (ret > 0);
|
2011-05-14 16:21:00 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
if (progress)
|
1984-04-04 00:44:05 +00:00
|
|
|
(void) write(1, " ", 1);
|
2011-05-14 16:21:00 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
return ret;
|
2011-05-14 00:18:01 +00:00
|
|
|
}
|
2011-05-15 20:48:51 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
static inline void
|
|
|
|
resetString (PsycString *s, uint8_t freeptr)
|
2011-05-15 20:48:51 +00:00
|
|
|
{
|
2011-11-11 21:18:24 +00:00
|
|
|
if (freeptr && s->length)
|
|
|
|
free((void*)s->data);
|
2011-05-15 20:48:51 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
s->data = NULL;
|
|
|
|
s->length = 0;
|
2011-05-15 20:48:51 +00:00
|
|
|
}
|
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
int
|
|
|
|
main (int argc, char **argv)
|
|
|
|
{
|
|
|
|
int c;
|
|
|
|
while ((c = getopt (argc, argv, "f:p:b:c:mnqrsvPSh")) != -1) {
|
|
|
|
switch (c) {
|
|
|
|
CASE_f CASE_p CASE_b CASE_c
|
|
|
|
CASE_m CASE_n CASE_q CASE_r
|
|
|
|
CASE_s CASE_v CASE_S CASE_P
|
|
|
|
case 'h':
|
|
|
|
printf(HELP_FILE("test_psyc", "mnqrSsvP")
|
|
|
|
HELP_PORT("test_psyc", "nqrsvP")
|
|
|
|
HELP_f HELP_p HELP_b HELP_c
|
|
|
|
HELP_m HELP_n HELP_r
|
|
|
|
HELP_q HELP_S HELP_s
|
|
|
|
HELP_v HELP_P HELP_h,
|
|
|
|
port, RECV_BUF_SIZE);
|
|
|
|
exit(0);
|
|
|
|
case '?': exit(-1);
|
|
|
|
default: abort();
|
2011-05-15 20:48:51 +00:00
|
|
|
}
|
2011-11-11 21:18:24 +00:00
|
|
|
}
|
2011-05-15 20:48:51 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
if (filename)
|
|
|
|
test_file(filename, count, recv_buf_size);
|
|
|
|
else
|
|
|
|
test_server(port, count, recv_buf_size);
|
2011-05-15 20:48:51 +00:00
|
|
|
|
2011-11-11 21:18:24 +00:00
|
|
|
return exit_code;
|
2011-05-15 20:48:51 +00:00
|
|
|
}
|