From 69fe21d6e2262d6fb2b14278b7a20364468cbdcf Mon Sep 17 00:00:00 2001 From: Vadim Dashevskiy Date: Fri, 12 Oct 2012 09:56:01 +0000 Subject: Dbx_tree: folders restructurization git-svn-id: http://svn.miranda-ng.org/main/trunk@1883 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- plugins/Dbx_tree/src/savestrings_gcc.h | 127 +++++++++++++++++++++++++++++++++ 1 file changed, 127 insertions(+) create mode 100644 plugins/Dbx_tree/src/savestrings_gcc.h (limited to 'plugins/Dbx_tree/src/savestrings_gcc.h') diff --git a/plugins/Dbx_tree/src/savestrings_gcc.h b/plugins/Dbx_tree/src/savestrings_gcc.h new file mode 100644 index 0000000000..9da680874d --- /dev/null +++ b/plugins/Dbx_tree/src/savestrings_gcc.h @@ -0,0 +1,127 @@ +/* + +dbx_tree: tree database driver for Miranda IM + +Copyright 2007-2010 Michael "Protogenes" Kunz, + +This program 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 2 +of the License, or (at your option) any later version. + +This program 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 this program; if not, write to the Free Software +Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +*/ + +#pragma once + +inline int strcpy_s( + char *strDestination, + size_t numberOfElements, + const char *strSource +) +{ + if (!strDestination) return EINVAL; + if (!strSource) {strDestination[0] = 0; return EINVAL;} + size_t l = strlen(strSource); + if (numberOfElements < l + 1) {strDestination[0] = 0; return ERANGE;} + memcpy(strDestination, strSource, l + 1); + return 0; +} + +template +inline int strcpy_s( + char (&strDestination)[size], + const char *strSource +) +{ + if (!strDestination) return EINVAL; + if (!strSource) {strDestination[0] = 0; return EINVAL;} + size_t l = strlen(strSource); + if (size < l + 1) {strDestination[0] = 0; return ERANGE;} + + memcpy(strDestination, strSource, l + 1); + return 0; +} + + +inline int strcat_s( + char *strDestination, + size_t numberOfElements, + const char *strSource +) +{ + if (!strDestination) return EINVAL; + if (!strSource) {strDestination[0] = 0; return EINVAL;} + size_t l = strlen(strSource); + size_t m = strlen(strDestination); + if (numberOfElements < l + m + 1) {strDestination[0] = 0; return ERANGE;} + + memcpy(&strDestination[m], strSource, l + 1); + return 0; +} + +template +inline int strcat_s( + char (&strDestination)[size], + const char *strSource +) +{ + if (!strDestination) return EINVAL; + if (!strSource) {strDestination[0] = 0; return EINVAL;} + size_t l = strlen(strSource); + size_t m = strlen(strDestination); + if (size < l + m + 1) {strDestination[0] = 0; return ERANGE;} + + memcpy(&strDestination[m], strSource, l + 1); + return 0; +} + +inline int strncpy_s( + char *strDest, + size_t numberOfElements, + const char *strSource, + size_t count +) +{ + if (count > numberOfElements) + return strcpy_s(strDest, numberOfElements, strSource); + else + return strcpy_s(strDest, count + 1, strSource); +} + + +template +inline int sprintf_s( + char (&buffer)[size], + const char *format, + ... +) +{ + va_list va; + va_start(va, format); + vsnprintf(buffer, size, format, va); + va_end(va); +} + +template +inline int swprintf_s( + wchar_t (&buffer)[size], + const wchar_t *format, + ... +) +{ + va_list va; + va_start(va, format); + vsnwprintf(buffer, size, format, va); + va_end(va); +} + +#define vsprintf_s vsnprintf -- cgit v1.2.3