/* silcargument.h Author: Pekka Riikonen Copyright (C) 2001 - 2002 Pekka Riikonen The contents of this file are subject to one of the Licenses specified in the COPYING file; You may not use this file except in compliance with the License. The software distributed under the License is distributed on an "AS IS" basis, in the hope that it will be useful, but WITHOUT WARRANTY OF ANY KIND, either expressed or implied. See the COPYING file for more information. */ /****h* silccore/SILC Argument Interface * * DESCRIPTION * * Implementation of the Argument Payload, that is used to include * argument to other payload that needs arguments. * ***/ #ifndef SILCPAYLOAD_H #define SILCPAYLOAD_H /****s* silccore/SilcArgumentAPI/SilcArgumentPayload * * NAME * * typedef struct SilcArgumentPayloadStruct *SilcArgumentPayload; * * DESCRIPTION * * This context is the actual Argument Payload and is allocated * by silc_argument_payload_parse and given as argument usually to * all silc_argument_payload_* functions. It is freed by the * silc_argument_payload_free function. * ***/ typedef struct SilcArgumentPayloadStruct *SilcArgumentPayload; /****f* silccore/SilcArgumentAPI/silc_argument_payload_parse * * SYNOPSIS * * SilcArgumentPayload * silc_argument_payload_parse(const unsigned char *payload, * SilcUInt32 payload_len, * SilcUInt32 argc); * * DESCRIPTION * * Parses arguments and returns them into Argument Payload structure. * the `buffer' is raw Argument Payload data buffer. The `argc' is * the number of arguments in the Argument Payload. The caller must * know the number of the arguments. This is always known as the * Argument payload is associated with other payloads which defines * the number of the arguments. * ***/ SilcArgumentPayload silc_argument_payload_parse(const unsigned char *payload, SilcUInt32 payload_len, SilcUInt32 argc); /****f* silccore/SilcArgumentAPI/silc_argument_payload_encode * * SYNOPSIS * * SilcBuffer silc_argument_payload_encode(SilcUInt32 argc, * unsigned char **argv, * SilcUInt32 *argv_lens, * SilcUInt32 *argv_types); * * DESCRIPTION * * Encodes arguments in to Argument Paylods returning them to SilcBuffer. * The `argv' is the array of the arguments, the `argv_lens' array of * the length of the `argv' arguments and the `argv_types' array of * the argument types of the `argv' arguments. The `argc' is the * number of arguments. * ***/ SilcBuffer silc_argument_payload_encode(SilcUInt32 argc, unsigned char **argv, SilcUInt32 *argv_lens, SilcUInt32 *argv_types); /****f* silccore/SilcArgumentAPI/silc_argument_payload_encode_one * * SYNOPSIS * * SilcBuffer silc_argument_payload_encode_one(SilcBuffer args, * unsigned char *arg, * SilcUInt32 arg_len, * SilcUInt32 arg_type); * * DESCRIPTION * * Same as silc_argument_payload_encode but encodes one argument to * the buffer `args' and returns the buffer. The returned buffer * may be different than the `args'. If `args' is NULL for the first * argument this allocates the buffer and returns it. * ***/ SilcBuffer silc_argument_payload_encode_one(SilcBuffer args, unsigned char *arg, SilcUInt32 arg_len, SilcUInt32 arg_type); /****f* silccore/SilcArgumentAPI/silc_argument_payload_encode_payload * * SYNOPSIS * * SilcBuffer * silc_argument_payload_encode_payload(SilcArgumentPayload payload); * * DESCRIPTION * * Same as silc_argument_payload_encode but encodes the payload from * already allocated SilcArgumentPayload structure instead of raw data. * ***/ SilcBuffer silc_argument_payload_encode_payload(SilcArgumentPayload payload); /****f* silccore/SilcArgumentAPI/silc_argument_payload_free * * SYNOPSIS * * void silc_argument_payload_free(SilcArgumentPayload payload); * * DESCRIPTION * * Frees the Argument Payload and all data in it. * ***/ void silc_argument_payload_free(SilcArgumentPayload payload); /****f* silccore/SilcArgumentAPI/silc_argument_get_arg_num * * SYNOPSIS * * SilcUInt32 silc_argument_get_arg_num(SilcArgumentPayload payload); * * DESCRIPTION * * Returns the number of argument in the Argument Payload. * ***/ SilcUInt32 silc_argument_get_arg_num(SilcArgumentPayload payload); /****f* silccore/SilcArgumentAPI/silc_argument_get_first_arg * * SYNOPSIS * * unsigned char *silc_argument_get_first_arg(SilcArgumentPayload payload, * SilcUInt32 *type, * SilcUInt32 *ret_len); * * DESCRIPTION * * Returns the first argument in the Argument Payload. The lenght * of the argument is returned to `ret_len'. The caller must not * free the returned argument. Returns NULL on error. * ***/ unsigned char *silc_argument_get_first_arg(SilcArgumentPayload payload, SilcUInt32 *type, SilcUInt32 *ret_len); /****f* silccore/SilcArgumentAPI/silc_argument_get_next_arg * * SYNOPSIS * * unsigned char *silc_argument_get_next_arg(SilcArgumentPayload payload, * SilcUInt32 *ret_len); * * DESCRIPTION * * Returns next argument from the Argument Payload. The length of * the argument is returned to `ret_len'. The caller must not free * the returned argument. This returns NULL when there are no more * arguments in the payload. * ***/ unsigned char *silc_argument_get_next_arg(SilcArgumentPayload payload, SilcUInt32 *type, SilcUInt32 *ret_len); /****f* silccore/SilcArgumentAPI/silc_argument_get_arg_type * * SYNOPSIS * * unsigned char *silc_argument_get_arg_type(SilcArgumentPayload payload, * SilcUInt32 type, * SilcUInt32 *ret_len); * * DESCRIPTION * * Returns argument by type. The returned argument has type `type' * in the Argument Payload. Each argument has their own type (or zero * if no specific type is set). The length of the argument is returned * to the `ret_len'. The caller must not free the returned argument. * Returns NULL on error. * ***/ unsigned char *silc_argument_get_arg_type(SilcArgumentPayload payload, SilcUInt32 type, SilcUInt32 *ret_len); #endif