2012-05-10 18:10:03 +04:00
|
|
|
/*
|
2012-10-09 07:02:04 +04:00
|
|
|
* FreeRDP: A Remote Desktop Protocol Implementation
|
2011-07-01 02:24:37 +04:00
|
|
|
* Memory Utils
|
|
|
|
*
|
|
|
|
* Copyright 2009-2011 Jay Sorg
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2012-08-15 01:09:01 +04:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2011-07-01 02:24:37 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include <freerdp/utils/memory.h>
|
|
|
|
|
2011-07-03 20:42:35 +04:00
|
|
|
/**
|
|
|
|
* Allocate memory initialized to zero.
|
2012-05-10 18:10:03 +04:00
|
|
|
* This function is used to secure a calloc call.
|
|
|
|
* It verifies its return value, and logs an error if the allocation failed.
|
|
|
|
*
|
|
|
|
* @param size - number of bytes to allocate. If the size is < 1, it will default to 1.
|
|
|
|
*
|
|
|
|
* @return a pointer to the allocated and zeroed buffer. NULL if the allocation failed.
|
2011-07-03 20:42:35 +04:00
|
|
|
*/
|
2011-07-13 18:13:00 +04:00
|
|
|
void* xzalloc(size_t size)
|
2011-07-03 20:42:35 +04:00
|
|
|
{
|
2011-07-13 18:13:00 +04:00
|
|
|
void* mem;
|
2011-07-03 20:42:35 +04:00
|
|
|
|
|
|
|
if (size < 1)
|
|
|
|
size = 1;
|
|
|
|
|
|
|
|
mem = calloc(1, size);
|
|
|
|
|
|
|
|
if (mem == NULL)
|
2012-01-31 07:46:02 +04:00
|
|
|
{
|
2011-07-03 20:42:35 +04:00
|
|
|
perror("xzalloc");
|
2012-02-10 05:32:08 +04:00
|
|
|
printf("xzalloc: failed to allocate memory of size: %d\n", (int) size);
|
2012-01-31 07:46:02 +04:00
|
|
|
}
|
2011-07-03 20:42:35 +04:00
|
|
|
|
2011-07-01 02:24:37 +04:00
|
|
|
return mem;
|
|
|
|
}
|
|
|
|
|
2011-07-03 20:42:35 +04:00
|
|
|
/**
|
|
|
|
* Duplicate a string in memory.
|
2012-05-10 18:10:03 +04:00
|
|
|
* This function is used to secure the strdup function.
|
|
|
|
* It will allocate a new memory buffer and copy the string content in it.
|
|
|
|
* If allocation fails, it will log an error.
|
|
|
|
*
|
|
|
|
* @param str - pointer to the character string to copy. If str is NULL, nothing is done.
|
|
|
|
*
|
|
|
|
* @return a pointer to a newly allocated character string containing the same bytes as str.
|
|
|
|
* NULL if an allocation error occurred, or if the str parameter was NULL.
|
2011-07-03 20:42:35 +04:00
|
|
|
*/
|
|
|
|
|
2011-07-13 18:13:00 +04:00
|
|
|
char* xstrdup(const char* str)
|
2011-07-01 02:24:37 +04:00
|
|
|
{
|
2011-07-13 18:13:00 +04:00
|
|
|
char* mem;
|
2011-07-01 02:24:37 +04:00
|
|
|
|
2011-09-25 07:49:09 +04:00
|
|
|
if (str == NULL)
|
|
|
|
return NULL;
|
|
|
|
|
2011-07-01 02:24:37 +04:00
|
|
|
#ifdef _WIN32
|
2011-07-03 20:42:35 +04:00
|
|
|
mem = _strdup(str);
|
2011-07-01 02:24:37 +04:00
|
|
|
#else
|
2011-07-03 20:42:35 +04:00
|
|
|
mem = strdup(str);
|
2011-07-01 02:24:37 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
if (mem == NULL)
|
|
|
|
perror("strdup");
|
|
|
|
|
|
|
|
return mem;
|
|
|
|
}
|
2012-03-06 01:57:25 +04:00
|
|
|
|
2012-03-25 00:02:58 +04:00
|
|
|
/**
|
2012-05-10 18:10:03 +04:00
|
|
|
* Duplicate a wide string in memory.
|
|
|
|
* This function is used to secure a call to wcsdup.
|
|
|
|
* It verifies the return value, and logs a message if an allocation error occurred.
|
|
|
|
*
|
|
|
|
* @param wstr - pointer to the wide-character string to duplicate. If wstr is NULL, nothing will be done.
|
|
|
|
*
|
|
|
|
* @return a pointer to the newly allocated string, containing the same data as wstr.
|
|
|
|
* NULL if an allocation error occurred (or if wstr was NULL).
|
2012-03-25 00:02:58 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
wchar_t* xwcsdup(const wchar_t* wstr)
|
|
|
|
{
|
|
|
|
wchar_t* mem;
|
|
|
|
|
|
|
|
if (wstr == NULL)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
mem = _wcsdup(wstr);
|
2012-05-05 00:11:30 +04:00
|
|
|
#elif sun
|
|
|
|
mem = wsdup(wstr);
|
2012-05-24 12:40:44 +04:00
|
|
|
#elif (defined(__APPLE__) && defined(__MACH__)) || defined(ANDROID)
|
2012-10-09 07:21:26 +04:00
|
|
|
mem = malloc(wcslen(wstr) * sizeof(wchar_t));
|
2012-05-22 02:25:22 +04:00
|
|
|
if (mem != NULL)
|
|
|
|
wcscpy(mem, wstr);
|
2012-03-25 00:02:58 +04:00
|
|
|
#else
|
|
|
|
mem = wcsdup(wstr);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (mem == NULL)
|
|
|
|
perror("wstrdup");
|
|
|
|
|
|
|
|
return mem;
|
|
|
|
}
|
|
|
|
|
2012-05-10 18:10:03 +04:00
|
|
|
/**
|
2012-05-21 15:59:46 +04:00
|
|
|
* Create an uppercase version of the given string.
|
2012-05-10 18:10:03 +04:00
|
|
|
* This function will duplicate the string (using xstrdup()) and change its content to all uppercase.
|
|
|
|
* The original string is untouched.
|
|
|
|
*
|
|
|
|
* @param str - pointer to the character string to convert. This content is untouched by the function.
|
|
|
|
*
|
|
|
|
* @return pointer to a newly allocated character string, containing the same content as str, converted to uppercase.
|
|
|
|
* NULL if an allocation error occured.
|
|
|
|
*/
|
2012-03-06 01:57:25 +04:00
|
|
|
char* xstrtoup(const char* str)
|
|
|
|
{
|
|
|
|
char* out;
|
|
|
|
char* p;
|
|
|
|
int c;
|
|
|
|
out = xstrdup(str);
|
|
|
|
if(out != NULL)
|
|
|
|
{
|
|
|
|
p = out;
|
|
|
|
while(*p != '\0')
|
|
|
|
{
|
|
|
|
c = toupper((unsigned char)*p);
|
|
|
|
*p++ = (char)c;
|
|
|
|
}
|
|
|
|
}
|
2012-05-10 18:10:03 +04:00
|
|
|
return out;
|
2012-03-06 01:57:25 +04:00
|
|
|
}
|