/* libs/graphics/ports/SkOSFile_stdio.cpp
**
** Copyright 2006, The Android Open Source Project
**
** 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.
*/
#include "SkOSFile.h"
#include <stdio.h>
#include <errno.h>
SkFILE* sk_fopen(const char path[], SkFILE_Flags flags)
{
char perm[4];
char* p = perm;
if (flags & kRead_SkFILE_Flag)
*p++ = 'r';
if (flags & kWrite_SkFILE_Flag)
*p++ = 'w';
*p++ = 'b';
*p = 0;
SkFILE* f = (SkFILE*)::fopen(path, perm);
#if 0
if (NULL == f)
SkDebugf("sk_fopen failed for %s (%s), errno=%s\n", path, perm, strerror(errno));
#endif
return f;
}
size_t sk_fgetsize(SkFILE* f)
{
SkASSERT(f);
size_t curr = ::ftell((FILE*)f); // remember where we are
::fseek((FILE*)f, 0, SEEK_END); // go to the end
size_t size = ::ftell((FILE*)f); // record the size
::fseek((FILE*)f, (long)curr, SEEK_SET); // go back to our prev loc
return size;
}
bool sk_frewind(SkFILE* f)
{
SkASSERT(f);
::rewind((FILE*)f);
// ::fseek((FILE*)f, 0, SEEK_SET);
return true;
}
size_t sk_fread(void* buffer, size_t byteCount, SkFILE* f)
{
SkASSERT(f);
if (buffer == NULL)
{
size_t curr = ::ftell((FILE*)f);
if ((long)curr == -1) {
SkDEBUGF(("sk_fread: ftell(%p) returned -1 feof:%d ferror:%d\n", f, feof((FILE*)f), ferror((FILE*)f)));
return 0;
}
// ::fseek((FILE*)f, (long)(curr + byteCount), SEEK_SET);
int err = ::fseek((FILE*)f, (long)byteCount, SEEK_CUR);
if (err != 0) {
SkDEBUGF(("sk_fread: fseek(%d) tell:%d failed with feof:%d ferror:%d returned:%d\n",
byteCount, curr, feof((FILE*)f), ferror((FILE*)f), err));
return 0;
}
return byteCount;
}
else
return ::fread(buffer, 1, byteCount, (FILE*)f);
}
size_t sk_fwrite(const void* buffer, size_t byteCount, SkFILE* f)
{
SkASSERT(f);
return ::fwrite(buffer, 1, byteCount, (FILE*)f);
}
void sk_fflush(SkFILE* f)
{
SkASSERT(f);
::fflush((FILE*)f);
}
void sk_fclose(SkFILE* f)
{
SkASSERT(f);
::fclose((FILE*)f);
}