提交 131b5be2 编写于 作者: R Rich Felker

more header cleanup and conformance fixes - locale.h, time.h

上级 1322cb82
...@@ -53,7 +53,8 @@ char *setlocale (int, const char *); ...@@ -53,7 +53,8 @@ char *setlocale (int, const char *);
struct lconv *localeconv(void); struct lconv *localeconv(void);
#if 1 #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
#define __NEED_locale_t #define __NEED_locale_t
......
...@@ -14,16 +14,19 @@ extern "C" { ...@@ -14,16 +14,19 @@ extern "C" {
#define __NEED_time_t #define __NEED_time_t
#define __NEED_struct_timespec
#define __NEED_clock_t #define __NEED_clock_t
#if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
#define __NEED_struct_timespec
#define __NEED_clockid_t #define __NEED_clockid_t
#define __NEED_timer_t #define __NEED_timer_t
#define __NEED_size_t #define __NEED_size_t
#define __NEED_pid_t #define __NEED_pid_t
#endif
#include <bits/alltypes.h> #include <bits/alltypes.h>
struct tm struct tm
{ {
int tm_sec; int tm_sec;
...@@ -39,71 +42,69 @@ struct tm ...@@ -39,71 +42,69 @@ struct tm
const char *__tm_zone; const char *__tm_zone;
}; };
struct itimerspec
{
struct timespec it_interval;
struct timespec it_value;
};
#define CLOCKS_PER_SEC 1000000UL
#define CLOCK_REALTIME 0
#define CLOCK_MONOTONIC 1
#define CLOCK_PROCESS_CPUTIME_ID 2
#define CLOCK_THREAD_CPUTIME_ID 3
#define TIMER_ABSTIME 1
clock_t clock (void); clock_t clock (void);
time_t time (time_t *); time_t time (time_t *);
double difftime (time_t, time_t); double difftime (time_t, time_t);
time_t mktime (struct tm *); time_t mktime (struct tm *);
size_t strftime (char *, size_t, const char *, const struct tm *); size_t strftime (char *, size_t, const char *, const struct tm *);
char *strptime (const char *, const char *, struct tm *);
struct tm *gmtime (const time_t *); struct tm *gmtime (const time_t *);
struct tm *gmtime_r (const time_t *, struct tm *);
struct tm *localtime (const time_t *); struct tm *localtime (const time_t *);
struct tm *localtime_r (const time_t *, struct tm *);
char *asctime (const struct tm *); char *asctime (const struct tm *);
char *asctime_r (const struct tm *, char *);
char *ctime (const time_t *); char *ctime (const time_t *);
char *ctime_r (const time_t *, char *);
#define CLOCKS_PER_SEC 1000000UL
extern int daylight;
extern long timezone;
extern char *tzname[2];
void tzset (void); #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \
|| defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
struct tm *gmtime_r (const time_t *, struct tm *);
struct tm *localtime_r (const time_t *, struct tm *);
char *asctime_r (const struct tm *, char *);
char *ctime_r (const time_t *, char *);
void tzset (void);
int nanosleep (const struct timespec *, struct timespec *); struct itimerspec
{
struct timespec it_interval;
struct timespec it_value;
};
#define CLOCK_REALTIME 0
#define CLOCK_MONOTONIC 1
#define CLOCK_PROCESS_CPUTIME_ID 2
#define CLOCK_THREAD_CPUTIME_ID 3
#define TIMER_ABSTIME 1
int nanosleep (const struct timespec *, struct timespec *);
int clock_getres (clockid_t, struct timespec *); int clock_getres (clockid_t, struct timespec *);
int clock_gettime (clockid_t, struct timespec *); int clock_gettime (clockid_t, struct timespec *);
int clock_settime (clockid_t, const struct timespec *); int clock_settime (clockid_t, const struct timespec *);
int clock_nanosleep (clockid_t, int, const struct timespec *, struct timespec *); int clock_nanosleep (clockid_t, int, const struct timespec *, struct timespec *);
int clock_getcpuclockid (pid_t, clockid_t *); int clock_getcpuclockid (pid_t, clockid_t *);
/* FIXME */ /* FIXME..?? */
struct sigevent; struct sigevent;
int timer_create (clockid_t, struct sigevent *, timer_t *); int timer_create (clockid_t, struct sigevent *, timer_t *);
int timer_delete (timer_t); int timer_delete (timer_t);
int timer_settime (timer_t, int, const struct itimerspec *, struct itimerspec *); int timer_settime (timer_t, int, const struct itimerspec *, struct itimerspec *);
int timer_gettime (timer_t, struct itimerspec *); int timer_gettime (timer_t, struct itimerspec *);
int timer_getoverrun (timer_t); int timer_getoverrun (timer_t);
#endif
#if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE)
char *strptime (const char *, const char *, struct tm *);
extern int daylight;
extern long timezone;
extern char *tzname[2];
extern int getdate_err; extern int getdate_err;
extern struct tm *getdate (const char *); extern struct tm *getdate (const char *);
#endif
#ifdef __cplusplus #ifdef __cplusplus
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册