(file) Return to io.c CVS log (file) (dir) Up to [OMI] / omi / base

File: [OMI] / omi / base / Attic / io.c (download)
Revision: 1.1.1.1 (vendor branch), Wed May 30 21:47:49 2012 UTC (12 years ago) by mike
Branch: TOG
CVS Tags: OMI_1_0_2_Branch, OMI_1_0_2, OMI_1_0_1_PRE, OMI_1_0_1, OMI_1_0_0
Changes since 1.1: +0 -0 lines
Initial Import

/*
**==============================================================================
**
** Open Management Infrastructure (OMI)
**
** Copyright (c) Microsoft Corporation
** 
** 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 
**
** THIS CODE IS PROVIDED *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
** KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED 
** WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, 
** MERCHANTABLITY OR NON-INFRINGEMENT. 
**
** See the Apache 2 License for the specific language governing permissions 
** and limitations under the License.
**
**==============================================================================
*/

#include "io.h"

#if defined(__GNUC__)
extern int vfwprintf(FILE*, const wchar_t*, va_list);
extern int vwprintf(const wchar_t*, va_list);
extern int vswprintf(wchar_t*, size_t, const wchar_t*, va_list);
#endif

FILE* Fopen(const char* path, const char* mode)
{
#if defined(_MSC_VER)
    FILE* fp;
    return fopen_s(&fp, path, mode) == 0 ? fp : NULL;
#else
    return fopen(path, mode);
#endif
}

int Snprintf(char* buf, size_t size, const char* fmt, ...)
{
    va_list ap;
    int r;

    memset(&ap, 0, sizeof(ap));

    va_start(ap, fmt);
#if defined(_MSC_VER)
    r = _vsnprintf_s(buf, size, size, fmt, ap);
#else
    r = vsnprintf(buf, size, fmt, ap);
#endif
    va_end(ap);

    return r;
}

int Vsnprintf(char* buf, size_t size, const char* fmt, va_list ap)
{
#if defined(_MSC_VER)
    return _vsnprintf_s(buf, size, size, fmt, ap);
#else
    return vsnprintf(buf, size, fmt, ap);
#endif
}

void Fzprintf(FILE* os, const MI_Char* format, ...)
{
    va_list ap;
    memset(&ap, 0, sizeof(ap));
    va_start(ap, format);

#if (MI_CHAR_TYPE == 1)
    vfprintf(os, format, ap);
#else
    vfwprintf(os, format, ap);
#endif

    va_end(ap);
}

void Zprintf(const MI_Char* format, ...)
{
    va_list ap;
    memset(&ap, 0, sizeof(ap));

    va_start(ap, format);
#if (MI_CHAR_TYPE == 1)
    vprintf(format, ap);
#else
    vwprintf(format, ap);
#endif
    va_end(ap);
}

int Szprintf(MI_Char* buffer, size_t count, const MI_Char* format, ...)
{
    int result;
    va_list ap;
    memset(&ap, 0, sizeof(ap));

    va_start(ap, format);
#if (MI_CHAR_TYPE == 1)
# if defined(_MSC_VER)
    result = _vsnprintf_s(buffer, count, _TRUNCATE, format, ap);
# else
    result = vsnprintf(buffer, count, format, ap);
# endif
#else
# if defined(_MSC_VER)
    result = _vsnwprintf_s(buffer, count, _TRUNCATE, format, ap);
# else
    result = vswprintf(buffer, count, format, ap);
# endif
#endif
    va_end(ap);

    return result;
}

ViewCVS 0.9.2