move include path options to each component.
git-svn-id: https://rt-thread.googlecode.com/svn/trunk@113 bbd45198-f89e-11dd-88c7-29a3b14d5316
This commit is contained in:
parent
830a235b47
commit
9a7ae65085
|
@ -0,0 +1,76 @@
|
|||
Import('env')
|
||||
Import('rtconfig')
|
||||
Import('RTT_ROOT')
|
||||
|
||||
dfs = Split("""
|
||||
src/dfs_cache.c
|
||||
src/dfs_fs.c
|
||||
src/dfs_init.c
|
||||
src/dfs_posix.c
|
||||
src/dfs_raw.c
|
||||
src/dfs_util.c
|
||||
""")
|
||||
|
||||
# DFS-FatFs options
|
||||
fatfs = Split("""
|
||||
filesystems/fatfs/fatfs_cache.c
|
||||
filesystems/fatfs/fatfs_direntry.c
|
||||
filesystems/fatfs/fatfs_fat.c
|
||||
filesystems/fatfs/fatfs_file.c
|
||||
filesystems/fatfs/fatfs_filename.c
|
||||
filesystems/fatfs/fatfs_init.c
|
||||
filesystems/fatfs_misc.c
|
||||
filesystems/fatfs/fatfs_mount.c""")
|
||||
|
||||
# DFS-EFSL options
|
||||
efsl = Split("""
|
||||
filesystems/efsl/src/base/efs.c
|
||||
filesystems/efsl/src/base/extract.c
|
||||
filesystems/efsl/src/base/partition.c
|
||||
filesystems/efsl/src/base/plibc.c
|
||||
filesystems/efsl/src/fs/vfat/dir.c
|
||||
filesystems/efsl/src/fs/vfat/fat.c
|
||||
filesystems/efsl/src/fs/vfat/file.c
|
||||
filesystems/efsl/src/fs/vfat/fs.c
|
||||
filesystems/efsl/src/fs/vfat/ls.c
|
||||
filesystems/efsl/src/fs/vfat/time.c
|
||||
filesystems/efsl/src/fs/vfat/ui.c
|
||||
""")
|
||||
|
||||
# DFS-YAFFS2 options
|
||||
yaffs2_main = Split("""
|
||||
filesystems/yaffs2/direct/yaffscfg.c
|
||||
filesystems/yaffs2/direct/yaffs_fileem.c
|
||||
filesystems/yaffs2/direct/yaffsfs.c
|
||||
filesystems/yaffs2/direct/dfs_yaffs2.c
|
||||
""")
|
||||
|
||||
yaffs2_comm = Split("""
|
||||
filesystems/yaffs2/yaffs_ecc.c
|
||||
filesystems/yaffs2/yaffs_guts.c
|
||||
filesystems/yaffs2/yaffs_packedtags1.c
|
||||
filesystems/yaffs2/yaffs_tagscompat.c
|
||||
filesystems/yaffs2/yaffs_packedtags2.c
|
||||
filesystems/yaffs2/yaffs_tagsvalidity.c
|
||||
filesystems/yaffs2/yaffs_nand.c
|
||||
filesystems/yaffs2/yaffs_checkptrw.c
|
||||
filesystems/yaffs2/yaffs_qsort.c
|
||||
""")
|
||||
|
||||
# The set of source files associated with this SConscript file.
|
||||
src_local = dfs
|
||||
path = [RTT_ROOT + '/filesystem/dfs', RTT_ROOT + '/filesystem/dfs/include']
|
||||
|
||||
if rtconfig.RT_USING_DFS_YAFFS2:
|
||||
src_local = src_local + yaffs2_main + yaffs2_comm
|
||||
path = path + [RTT_ROOT + '/filesystem/dfs/filesystems/yaffs2', RTT_ROOT + '/filesystem/dfs/filesystems/yaffs2/direct']
|
||||
|
||||
if rtconfig.RT_USING_DFS_EFSL:
|
||||
src_local = src_local + efsl
|
||||
path = path + [RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/include', RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/base/include', RTT_ROOT + '/filesystem/dfs/filesystems/efsl/src/fs/vfat/include']
|
||||
|
||||
env.Append(CPPPATH = path)
|
||||
|
||||
obj = env.Object(src_local)
|
||||
|
||||
Return('obj')
|
|
@ -1,7 +1,10 @@
|
|||
Import('env')
|
||||
Import('RTT_ROOT')
|
||||
|
||||
# The set of source files associated with this SConscript file.
|
||||
src_local = Glob('*.c')
|
||||
|
||||
env.Append(CPPPATH = RTT_ROOT + '/finsh')
|
||||
|
||||
obj = env.Object(src_local)
|
||||
Return('obj')
|
||||
|
|
|
@ -1,7 +1,10 @@
|
|||
Import('env')
|
||||
Import('RTT_ROOT')
|
||||
|
||||
# The set of source files associated with this SConscript file.
|
||||
src_local = Glob('*.c')
|
||||
|
||||
env.Append(CPPPATH = RTT_ROOT + '/libc/minilibc')
|
||||
|
||||
obj = env.Object(src_local)
|
||||
Return('obj')
|
||||
|
|
|
@ -0,0 +1,174 @@
|
|||
#include <time.h>
|
||||
|
||||
/* days per month -- nonleap! */
|
||||
const short __spm[13] =
|
||||
{ 0,
|
||||
(31),
|
||||
(31+28),
|
||||
(31+28+31),
|
||||
(31+28+31+30),
|
||||
(31+28+31+30+31),
|
||||
(31+28+31+30+31+30),
|
||||
(31+28+31+30+31+30+31),
|
||||
(31+28+31+30+31+30+31+31),
|
||||
(31+28+31+30+31+30+31+31+30),
|
||||
(31+28+31+30+31+30+31+31+30+31),
|
||||
(31+28+31+30+31+30+31+31+30+31+30),
|
||||
(31+28+31+30+31+30+31+31+30+31+30+31),
|
||||
};
|
||||
static long int timezone;
|
||||
static const char days[] = "Sun Mon Tue Wed Thu Fri Sat ";
|
||||
static const char months[] = "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec ";
|
||||
|
||||
/* seconds per day */
|
||||
#define SPD 24*60*60
|
||||
|
||||
int __isleap(int year) {
|
||||
/* every fourth year is a leap year except for century years that are
|
||||
* not divisible by 400. */
|
||||
/* return (year % 4 == 0 && (year % 100 != 0 || year % 400 == 0)); */
|
||||
return (!(year%4) && ((year%100) || !(year%400)));
|
||||
}
|
||||
|
||||
struct tm *gmtime_r(const time_t *timep, struct tm *r) {
|
||||
time_t i;
|
||||
register time_t work=*timep%(SPD);
|
||||
r->tm_sec=work%60; work/=60;
|
||||
r->tm_min=work%60; r->tm_hour=work/60;
|
||||
work=*timep/(SPD);
|
||||
r->tm_wday=(4+work)%7;
|
||||
for (i=1970; ; ++i) {
|
||||
register time_t k=__isleap(i)?366:365;
|
||||
if (work>=k)
|
||||
work-=k;
|
||||
else
|
||||
break;
|
||||
}
|
||||
r->tm_year=i-1900;
|
||||
r->tm_yday=work;
|
||||
|
||||
r->tm_mday=1;
|
||||
if (__isleap(i) && (work>58)) {
|
||||
if (work==59) r->tm_mday=2; /* 29.2. */
|
||||
work-=1;
|
||||
}
|
||||
|
||||
for (i=11; i && (__spm[i]>work); --i) ;
|
||||
r->tm_mon=i;
|
||||
r->tm_mday+=work-__spm[i];
|
||||
return r;
|
||||
}
|
||||
|
||||
struct tm* localtime_r(const time_t* t, struct tm* r) {
|
||||
time_t tmp;
|
||||
struct timezone tz;
|
||||
gettimeofday(0, &tz);
|
||||
timezone=tz.tz_minuteswest*60L;
|
||||
tmp=*t+timezone;
|
||||
return gmtime_r(&tmp,r);
|
||||
}
|
||||
|
||||
struct tm* localtime(const time_t* t) {
|
||||
static struct tm tmp;
|
||||
return localtime_r(t,&tmp);
|
||||
}
|
||||
|
||||
time_t timegm(struct tm *const t) {
|
||||
register time_t day;
|
||||
register time_t i;
|
||||
register time_t years = t->tm_year - 70;
|
||||
|
||||
if (t->tm_sec>60) { t->tm_min += t->tm_sec/60; t->tm_sec%=60; }
|
||||
if (t->tm_min>60) { t->tm_hour += t->tm_min/60; t->tm_min%=60; }
|
||||
if (t->tm_hour>60) { t->tm_mday += t->tm_hour/60; t->tm_hour%=60; }
|
||||
if (t->tm_mon>12) { t->tm_year += t->tm_mon/12; t->tm_mon%=12; }
|
||||
while (t->tm_mday>__spm[1+t->tm_mon]) {
|
||||
if (t->tm_mon==1 && __isleap(t->tm_year+1900)) {
|
||||
if (t->tm_mon==31+29) break;
|
||||
--t->tm_mday;
|
||||
}
|
||||
t->tm_mday-=__spm[t->tm_mon];
|
||||
++t->tm_mon;
|
||||
if (t->tm_mon>11) { t->tm_mon=0; ++t->tm_year; }
|
||||
}
|
||||
|
||||
if (t->tm_year < 70)
|
||||
return (time_t) -1;
|
||||
|
||||
/* Days since 1970 is 365 * number of years + number of leap years since 1970 */
|
||||
day = years * 365 + (years + 1) / 4;
|
||||
|
||||
/* After 2100 we have to substract 3 leap years for every 400 years
|
||||
This is not intuitive. Most mktime implementations do not support
|
||||
dates after 2059, anyway, so we might leave this out for it's
|
||||
bloat. */
|
||||
if ((years -= 131) >= 0) {
|
||||
years /= 100;
|
||||
day -= (years >> 2) * 3 + 1;
|
||||
if ((years &= 3) == 3) years--;
|
||||
day -= years;
|
||||
}
|
||||
|
||||
day += t->tm_yday = __spm [t->tm_mon] + t->tm_mday-1 + ( __isleap (t->tm_year+1900) & (t->tm_mon > 1) );
|
||||
|
||||
/* day is now the number of days since 'Jan 1 1970' */
|
||||
i = 7;
|
||||
t->tm_wday = (day + 4) % i; /* Sunday=0, Monday=1, ..., Saturday=6 */
|
||||
|
||||
i = 24;
|
||||
day *= i;
|
||||
i = 60;
|
||||
return ((day + t->tm_hour) * i + t->tm_min) * i + t->tm_sec;
|
||||
}
|
||||
|
||||
time_t mktime(register struct tm* const t) {
|
||||
time_t x=timegm(t);
|
||||
struct timezone tz;
|
||||
gettimeofday(0, &tz);
|
||||
timezone=tz.tz_minuteswest*60L;
|
||||
x+=timezone;
|
||||
return x;
|
||||
}
|
||||
|
||||
static void num2str(char *c,int i) {
|
||||
c[0]=i/10+'0';
|
||||
c[1]=i%10+'0';
|
||||
}
|
||||
|
||||
char *asctime_r(const struct tm *t, char *buf) {
|
||||
/* "Wed Jun 30 21:49:08 1993\n" */
|
||||
*(int*)buf=*(int*)(days+(t->tm_wday<<2));
|
||||
*(int*)(buf+4)=*(int*)(months+(t->tm_mon<<2));
|
||||
num2str(buf+8,t->tm_mday);
|
||||
if (buf[8]=='0') buf[8]=' ';
|
||||
buf[10]=' ';
|
||||
num2str(buf+11,t->tm_hour);
|
||||
buf[13]=':';
|
||||
num2str(buf+14,t->tm_min);
|
||||
buf[16]=':';
|
||||
num2str(buf+17,t->tm_sec);
|
||||
buf[19]=' ';
|
||||
num2str(buf+20,(t->tm_year+1900)/100);
|
||||
num2str(buf+22,(t->tm_year+1900)%100);
|
||||
buf[24]='\n';
|
||||
return buf;
|
||||
}
|
||||
|
||||
char *asctime(const struct tm *timeptr) {
|
||||
static char buf[25];
|
||||
return asctime_r(timeptr,buf);
|
||||
}
|
||||
|
||||
char *ctime(const time_t *timep) {
|
||||
return asctime(localtime(timep));
|
||||
}
|
||||
|
||||
int gettimeofday (struct timeval *tp, void *ignore)
|
||||
{
|
||||
time_t t;
|
||||
|
||||
t = time(NULL);
|
||||
tp->tv_sec = t;
|
||||
tp->tv_usec = 0;
|
||||
return 0;
|
||||
}
|
|
@ -11,5 +11,8 @@ if rtconfig.CC == 'armcc':
|
|||
if rtconfig.CC == 'gcc':
|
||||
src_local = Glob(path + '/*.c') + Glob(path + '/*_gcc.s') + Glob(comm + '/*.c')
|
||||
|
||||
if rtconfig.CC == 'iar':
|
||||
src_local = Glob(path + '/*.c') + Glob(path + '/*_iar.s') + Glob(comm + '/*.c')
|
||||
|
||||
obj = env.Object(src_local)
|
||||
Return('obj')
|
||||
|
|
|
@ -62,8 +62,8 @@ src/netif/ppp/vj.c
|
|||
# The set of source files associated with this SConscript file.
|
||||
path = [RTT_ROOT + '/net/lwip/src/include', RTT_ROOT + '/net/lwip/src/include/ipv4', RTT_ROOT + '/net/lwip/src/arch/include/arch', RTT_ROOT + '/net/lwip/src/include/netif', RTT_ROOT + '/net/lwip/src/netif/ppp']
|
||||
|
||||
lwip_env = env.Clone()
|
||||
lwip_env.Append(CPPPATH = path)
|
||||
env.Clone()
|
||||
env.Append(CPPPATH = path)
|
||||
|
||||
obj = lwip_env.Object(src_local)
|
||||
|
||||
|
|
Loading…
Reference in New Issue