c732d49e |
#if HAVE_CRT
#define _CRTDBG_MAP_ALLOC
#include <stdlib.h>
#include <crtdbg.h>
#endif //HAVE_CRT
/*
* Copyright (C) 2017, University of the Basque Country (UPV/EHU)
* Contact for licensing options: <licensing-mcpttclient(at)mcopenplatform(dot)com>
*
* The original file was part of Open Source Doubango Framework
* Copyright (C) 2010-2011 Mamadou Diop.
* Copyright (C) 2012 Doubango Telecom <http://doubango.org>
*
* This file is part of Open Source Doubango Framework.
*
* DOUBANGO is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* DOUBANGO 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with DOUBANGO.
*
*/
/**@file tsdp_header.c
* @brief Defines a SDP header/line (<type>=<value>).
*
* @author Mamadou Diop <diopmamadou(at)doubango[dot]org>
*
*/
#include "tinysdp/headers/tsdp_header.h"
#include "tinysdp/headers/tsdp_header_Dummy.h"
#include "tsk_string.h"
int tsdp_header_rank_cmp(const tsdp_header_t* hdr1, const tsdp_header_t* hdr2)
{
if(hdr1 && hdr2){
return (hdr1->rank - hdr2->rank);
}
else{
return -1;
}
}
tsdp_header_t* tsdp_header_clone(const tsdp_header_t* self)
{
if(self){
return self->clone(self);
}
return tsk_null;
}
/** Gets the name of the SDP header with a type equal to @a type.
* @param type The @a type of the header for which to retrieve the name.
*
* @return The name of the header.
**/
char tsdp_header_get_name(tsdp_header_type_t type)
{
switch(type)
{
case tsdp_htype_A: return 'a';
case tsdp_htype_B: return 'b';
case tsdp_htype_C: return 'c';
case tsdp_htype_E: return 'e';
case tsdp_htype_I: return 'i';
case tsdp_htype_K: return 'k';
case tsdp_htype_M: return 'm';
case tsdp_htype_O: return 'o';
case tsdp_htype_P: return 'p';
case tsdp_htype_R: return 'r';
case tsdp_htype_S: return 's';
case tsdp_htype_T: return 't';
case tsdp_htype_U: return 'u';
case tsdp_htype_V: return 'v';
case tsdp_htype_Z: return 'z';
default: return '*';
}
}
char tsdp_header_get_nameex(const tsdp_header_t *self)
{
if(self){
if(self->type == tsdp_htype_Dummy){
return ((tsdp_header_Dummy_t*)(self))->name;
}
else{
return tsdp_header_get_name(self->type);
}
}
return '*';
}
int tsdp_header_serialize(const tsdp_header_t *self, tsk_buffer_t *output)
{
static char name;
int ret = -1;
if(!self || !output){
return -1;
}
/* Name */
name = tsdp_header_get_nameex(self);
tsk_buffer_append_2(output, "%c=", name);
/* Value */
if((ret = self->tostring(self, output))){
// Abort?
}
/* CRLF*/
if(output->size>2){
if(*(TSK_BUFFER_TO_U8(output)+TSK_BUFFER_SIZE(output)-2) != '\r'
&& *(TSK_BUFFER_TO_U8(output)+TSK_BUFFER_SIZE(output)-1) != '\n'){
ret = tsk_buffer_append(output, "\r\n", 2);
}
}
else{
ret = tsk_buffer_append(output, "\r\n", 2);
}
return ret;
}
char* tsdp_header_tostring(const tsdp_header_t *self)
{
tsk_buffer_t* output = tsk_buffer_create_null();
char* str = tsk_null;
if(!(tsdp_header_serialize(self, output))){
str = tsk_strndup(TSK_BUFFER_DATA(output), TSK_BUFFER_SIZE(output));
}
TSK_OBJECT_SAFE_FREE(output);
return str;
} |