1
0
Fork 0
forked from len0rd/rockbox

android/ypr0: Merge fs-*.c to generic filesystem-unix.c.

Change-Id: I52e2c29346baf0d282243880477cd149311ce3d1
This commit is contained in:
Thomas Martitz 2012-01-19 07:59:28 +01:00
parent 954cd771fb
commit 5d13ecc4a8
6 changed files with 9 additions and 168 deletions

View file

@ -78,10 +78,10 @@ drivers/rtc/rtc_as3514.c
target/hosted/rtc.c
#endif
target/hosted/kernel-unix.c
target/hosted/filesystem-unix.c
target/hosted/ypr0/button-ypr0.c
target/hosted/ypr0/lcd-ypr0.c
target/hosted/ypr0/system-ypr0.c
target/hosted/ypr0/fs-ypr0.c
target/hosted/ypr0/lc-ypr0.c
thread.c
#ifdef HAVE_BACKLIGHT
@ -1693,7 +1693,7 @@ target/arm/rk27xx/hm801/power-hm801.c
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
target/hosted/kernel-unix.c
target/hosted/android/fs-android.c
target/hosted/filesystem-unix.c
target/hosted/android/lcd-android.c
target/hosted/android/lc-android.c
target/hosted/android/button-android.c

View file

@ -40,17 +40,13 @@
#undef rmdir
#if (CONFIG_PLATFORM & PLATFORM_ANDROID) || defined(SAMSUNG_YPR0)
#include "dir-target.h"
#define opendir _opendir
#define mkdir _mkdir
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
#include "dir-target.h"
#define opendir opendir_android
#define mkdir mkdir_android
#define rmdir rmdir_android
static const char rbhome[] = "/sdcard";
#elif defined(SAMSUNG_YPR0)
#include "dir-target.h"
#define opendir opendir_ypr0
#define mkdir mkdir_ypr0
#define rmdir rmdir_ypr0
#endif
#elif (CONFIG_PLATFORM & (PLATFORM_SDL|PLATFORM_MAEMO|PLATFORM_PANDORA))
#define open sim_open
#define remove sim_remove

View file

@ -32,16 +32,9 @@
#define mkdir_uncached _mkdir
#define rmdir_uncached rmdir
#define dirent_android dirent
#define DIR_android DIR
#define opendir_android _opendir
#define readdir_android _readdir
#define closedir_android _closedir
#define mkdir_android _mkdir
#define rmdir_android rmdir
extern DIR* _opendir(const char* name);
extern int _mkdir(const char* name);
extern int rmdir(const char* name);
extern int _closedir(DIR* dir);
extern struct dirent *_readdir(DIR* dir);
extern void fat_size(unsigned long *size, unsigned long *free);

View file

@ -1,141 +0,0 @@
/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Copyright (C) 2010 by Thomas Martitz
*
* 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 software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#include <stdlib.h>
#include <sys/stat.h> /* stat() */
#include <stdio.h> /* snprintf */
#include <string.h> /* size_t */
#include <dirent.h>
#include <time.h> /* localtime() */
#include "system-target.h"
#include "dir-target.h"
#include "file.h"
#include "dir.h"
#include "rbpaths.h"
long filesize(int fd)
{
struct stat buf;
if (!fstat(fd, &buf))
return buf.st_size;
else
return -1;
}
/* do we really need this in the app? */
void fat_size(unsigned long* size, unsigned long* free)
{
*size = *free = 0;
}
#undef opendir
#undef closedir
#undef mkdir
#undef readdir
/* need to wrap around DIR* because we need to save the parent's
* directory path in order to determine dirinfo */
struct __dir {
DIR *dir;
char *path;
};
DIR* _opendir(const char *name)
{
char *buf = malloc(sizeof(struct __dir) + strlen(name)+1);
if (!buf)
return NULL;
struct __dir *this = (struct __dir*)buf;
this->path = buf+sizeof(struct __dir);
/* definitely fits due to strlen() */
strcpy(this->path, name);
this->dir = opendir(name);
if (!this->dir)
{
free(buf);
return NULL;
}
return (DIR*)this;
}
int _mkdir(const char *name)
{
return mkdir(name, 0777);
}
int _closedir(DIR *dir)
{
struct __dir *this = (struct __dir*)dir;
int ret = closedir(this->dir);
free(this);
return ret;
}
struct dirent* _readdir(DIR* dir)
{
struct __dir *d = (struct __dir*)dir;
return readdir(d->dir);
}
struct dirinfo dir_get_info(struct DIR* _parent, struct dirent *dir)
{
struct __dir *parent = (struct __dir*)_parent;
struct stat s;
struct tm *tm = NULL;
struct dirinfo ret;
char path[MAX_PATH];
snprintf(path, sizeof(path), "%s/%s", parent->path, dir->d_name);
memset(&ret, 0, sizeof(ret));
if (!stat(path, &s))
{
if (S_ISDIR(s.st_mode))
{
ret.attribute = ATTR_DIRECTORY;
}
ret.size = s.st_size;
tm = localtime(&(s.st_mtime));
}
if (!lstat(path, &s) && S_ISLNK(s.st_mode))
{
ret.attribute |= ATTR_LINK;
}
if (tm)
{
ret.wrtdate = ((tm->tm_year - 80) << 9) |
((tm->tm_mon + 1) << 5) |
tm->tm_mday;
ret.wrttime = (tm->tm_hour << 11) |
(tm->tm_min << 5) |
(tm->tm_sec >> 1);
}
return ret;
}

View file

@ -35,16 +35,9 @@ extern int rmdir(const char* name);
#define mkdir_uncached _mkdir
#define rmdir_uncached rmdir
#define dirent_ypr0 dirent
#define DIR_ypr0 DIR
#define opendir_ypr0 _opendir
#define readdir_ypr0 _readdir
#define closedir_ypr0 _closedir
#define mkdir_ypr0 _mkdir
#define rmdir_ypr0 rmdir
extern DIR* _opendir(const char* name);
extern int _mkdir(const char* name);
extern int _rmdir(const char* name);
extern int _closedir(DIR* dir);
extern struct dirent *_readdir(DIR* dir);
extern void fat_size(unsigned long *size, unsigned long *free);