fixed
This commit is contained in:
parent
bfb3d3b2fb
commit
04ff3cf8e7
@ -1 +0,0 @@
|
||||
nameserver 192.168.0.1
|
@ -22,4 +22,3 @@ char *mu_humansize(off_t n, int block) {
|
||||
|
||||
return mu_hs_buf;
|
||||
}
|
||||
|
||||
|
41
libmu/parse_date.c
Normal file
41
libmu/parse_date.c
Normal file
@ -0,0 +1,41 @@
|
||||
#define _XOPEN_SOURCE
|
||||
#define _POSIX_C_SOURCE 1999309L
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include "parse_date.h"
|
||||
|
||||
time_t mu_parse_date(const char *prog_name, const char *str) {
|
||||
time_t local = time(NULL);
|
||||
struct tm *tm = localtime(&local);
|
||||
|
||||
char flag = 0;
|
||||
for (size_t i = 0; i < sizeof(mu_date_fmts) / sizeof(char *); i++) {
|
||||
char *res = strptime(str, mu_date_fmts[i], tm);
|
||||
if (res && *res == '\0') {
|
||||
flag = 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (flag == 0 && prog_name) {
|
||||
fprintf(stderr, "%s: parsing: invalid format\n", prog_name);
|
||||
return -1;
|
||||
}
|
||||
|
||||
time_t rt = mktime(tm);
|
||||
if (rt < 0) {
|
||||
if (rt == -1 && prog_name)
|
||||
fprintf(stderr, "%s: parsing: %s\n", prog_name, strerror(errno));
|
||||
|
||||
else if (prog_name)
|
||||
fprintf(stderr, "%s: parsing: invalid date\n", prog_name);
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
return rt;
|
||||
}
|
18
libmu/parse_date.h
Normal file
18
libmu/parse_date.h
Normal file
@ -0,0 +1,18 @@
|
||||
#ifndef _PARSE_DATE_H
|
||||
#define _PARSE_DATE_H
|
||||
|
||||
static const char *mu_date_fmts[] = {
|
||||
"%R",
|
||||
"%T",
|
||||
"%d-%m",
|
||||
"%d-%m %H",
|
||||
"%d-%m %R",
|
||||
"%d-%m %T",
|
||||
"%d-%m-%Y",
|
||||
"%d-%m-%Y %H",
|
||||
"%d-%m-%Y %R",
|
||||
"%d-%m-%Y %T"
|
||||
};
|
||||
|
||||
time_t mu_parse_date(const char *prog_name, const char *str);
|
||||
#endif
|
83
src/date.c
83
src/date.c
@ -1,69 +1,29 @@
|
||||
#define _XOPEN_SOURCE
|
||||
#define _POSIX_C_SOURCE 1999309L
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
|
||||
static const char *fmts[] = {
|
||||
"%R",
|
||||
"%T",
|
||||
"%d-%m",
|
||||
"%d-%m %H",
|
||||
"%d-%m %R",
|
||||
"%d-%m %T",
|
||||
"%d-%m-%Y",
|
||||
"%d-%m-%Y %H",
|
||||
"%d-%m-%Y %R",
|
||||
"%d-%m-%Y %T"
|
||||
};
|
||||
|
||||
static time_t parse_date(char *str) {
|
||||
time_t local = time(NULL);
|
||||
struct tm *tm = localtime(&local);
|
||||
|
||||
char flag = 0;
|
||||
for (size_t i = 0; i < sizeof(fmts) / sizeof(char *); i++) {
|
||||
char *res = strptime(str, fmts[i], tm);
|
||||
if (res && *res == '\0') {
|
||||
flag = 1;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (flag == 0) {
|
||||
fprintf(stderr, "date: parsing: invalid format\n");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
time_t rt = mktime(tm);
|
||||
if (rt < 0) {
|
||||
if (rt == -1)
|
||||
fprintf(stderr, "date: parsing: %s\n", strerror(errno));
|
||||
|
||||
else
|
||||
fprintf(stderr, "date: parsing: invalid date\n");
|
||||
|
||||
exit(1);
|
||||
}
|
||||
|
||||
return rt;
|
||||
}
|
||||
#include "get_stat.h"
|
||||
#include "parse_date.h"
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
time_t t = time(NULL);
|
||||
char *fmt = "%a %b %e %H:%M:%S %Z %Y";
|
||||
|
||||
/* For -s flag */
|
||||
/* For -s/-r flag */
|
||||
struct timespec ts;
|
||||
|
||||
char *r_flag = NULL;
|
||||
|
||||
int opt;
|
||||
while ((opt = getopt(argc, argv, "s:d:u")) != -1) {
|
||||
while ((opt = getopt(argc, argv, "s:d:ur:")) != -1) {
|
||||
switch (opt) {
|
||||
case 's':
|
||||
ts.tv_sec = parse_date(optarg);
|
||||
ts.tv_sec = mu_parse_date("date", optarg);
|
||||
if (ts.tv_sec == -1)
|
||||
return 1;
|
||||
|
||||
if (clock_settime(CLOCK_REALTIME, &ts) < 0) {
|
||||
fprintf(stderr, "date: settime: %s\n", strerror(errno));
|
||||
return 1;
|
||||
@ -72,7 +32,10 @@ int main(int argc, char **argv) {
|
||||
return 0;
|
||||
|
||||
case 'd':
|
||||
t = parse_date(optarg);
|
||||
t = mu_parse_date("date", optarg);
|
||||
if (t == -1)
|
||||
return 1;
|
||||
|
||||
break;
|
||||
|
||||
case 'u':
|
||||
@ -83,10 +46,14 @@ int main(int argc, char **argv) {
|
||||
|
||||
break;
|
||||
|
||||
case 'r':
|
||||
r_flag = optarg;
|
||||
break;
|
||||
|
||||
default:
|
||||
puts("date [sdu] [+\"fmt\"]\n\t-s TIME Set new date\n\t-d TIME Print new date\n\t-u Work in UTC\n\nRecognized TIME formats:");
|
||||
for (size_t i = 0; i < sizeof(fmts) / sizeof(char *); i++)
|
||||
puts(fmts[i]);
|
||||
puts("date [sdur] [+\"fmt\"]\n\t-s TIME Set new date\n\t-d TIME Print new date\n\t-u Work in UTC\n\t-r FILE Display last modification time of FILE\n\nRecognized TIME formats:");
|
||||
for (size_t i = 0; i < sizeof(mu_date_fmts) / sizeof(char *); i++)
|
||||
puts(mu_date_fmts[i]);
|
||||
|
||||
return 0;
|
||||
}
|
||||
@ -99,6 +66,14 @@ int main(int argc, char **argv) {
|
||||
if (argv[0][0] == '+')
|
||||
fmt = argv[0] + 1;
|
||||
|
||||
if (r_flag) {
|
||||
struct stat sb;
|
||||
if (mu_get_lstat("date", r_flag, &sb))
|
||||
return 1;
|
||||
|
||||
t = sb.st_mtime;
|
||||
}
|
||||
|
||||
struct tm *tm = localtime(&t);
|
||||
|
||||
char buf[256];
|
||||
|
@ -90,7 +90,7 @@ int main(int argc, char **argv) {
|
||||
break;
|
||||
|
||||
default:
|
||||
printf("mount [ato] [DEVICE] [NODE]\n\t-t Fs type, default %s\n\t-o Options\n\t-a Mount all fs in /etc/fstab\n\nOptions:", MOUNT_DEF_FS);
|
||||
printf("mount [ato] [DEVICE] [NODE]\n\t-t Fs type, default %s\n\t-o Options\n\t-a Mount all fs in /etc/fstab\n\nOptions:\n", MOUNT_DEF_FS);
|
||||
print_opts();
|
||||
return 0;
|
||||
}
|
||||
|
62
src/ps.c
62
src/ps.c
@ -13,11 +13,14 @@
|
||||
|
||||
static char c_flag;
|
||||
|
||||
static int pscan(const pid_t pid) {
|
||||
static int pscan(const pid_t pid, const char *prog_name) {
|
||||
struct mu_proc proc;
|
||||
if (mu_proc_parser("ps", pid, &proc))
|
||||
return 1;
|
||||
|
||||
if (prog_name != NULL && strncmp(proc.cmd, prog_name, strlen(prog_name)))
|
||||
return 1;
|
||||
|
||||
/* Uid */
|
||||
char *name = "unknow";
|
||||
struct passwd *pw = getpwuid(proc.uid);
|
||||
@ -42,6 +45,26 @@ static int pscan(const pid_t pid) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static char name_2_pid(const char *prog_name) {
|
||||
DIR *dp = opendir("/proc");
|
||||
if (dp == NULL) {
|
||||
fprintf(stderr, "ps: /proc: %s\n", strerror(errno));
|
||||
return 1;
|
||||
}
|
||||
|
||||
int ret = 0;
|
||||
struct dirent *ep;
|
||||
while ((ep = readdir(dp)) != NULL) {
|
||||
pid_t pid = strtoul(ep->d_name, 0L, 10);
|
||||
if (pid)
|
||||
if (pscan(pid, prog_name))
|
||||
ret = 1;
|
||||
}
|
||||
|
||||
closedir(dp);
|
||||
return ret;
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
int opt;
|
||||
while ((opt = getopt(argc, argv, "c")) != -1) {
|
||||
@ -51,7 +74,7 @@ int main(int argc, char **argv) {
|
||||
break;
|
||||
|
||||
default:
|
||||
puts("ps [c] [PID]\n\t-c Print cmdline instead of program name");
|
||||
puts("ps [c] [PID]\n\t-c Print cmdline instead of program name\n");
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
@ -60,34 +83,23 @@ int main(int argc, char **argv) {
|
||||
argc -= optind;
|
||||
|
||||
puts(" PID USER PRI NICE VIRT RSS S RTIME CMD");
|
||||
|
||||
int ret = 0;
|
||||
if (argc == 0) {
|
||||
DIR *dp = opendir("/proc");
|
||||
if (dp == NULL) {
|
||||
fprintf(stderr, "ps: /proc: %s\n", strerror(errno));
|
||||
return 1;
|
||||
}
|
||||
|
||||
struct dirent *ep;
|
||||
while ((ep = readdir(dp)) != NULL) {
|
||||
pid_t pid = strtoul(ep->d_name, 0L, 10);
|
||||
if (pid)
|
||||
if (pscan(pid))
|
||||
ret = 1;
|
||||
}
|
||||
|
||||
closedir(dp);
|
||||
}
|
||||
if (argc == 0)
|
||||
return name_2_pid(NULL);
|
||||
|
||||
else {
|
||||
int ret = 0;
|
||||
for (int i = 0; i < argc; i++) {
|
||||
pid_t pid = strtoul(argv[i], 0L, 10);
|
||||
if (pid)
|
||||
if (pscan(pid))
|
||||
if (pid) {
|
||||
if (pscan(pid, NULL))
|
||||
ret = 1;
|
||||
}
|
||||
|
||||
else
|
||||
if (name_2_pid(argv[i]))
|
||||
ret = 1;
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
59
src/touch.c
59
src/touch.c
@ -7,6 +7,7 @@
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <time.h>
|
||||
#include "parse_date.h"
|
||||
|
||||
static char c_flag;
|
||||
static char m_flag;
|
||||
@ -30,7 +31,6 @@ static int setdate(const char *path, const time_t date, char flag) {
|
||||
}
|
||||
|
||||
static int touch(const char *path, const time_t date) {
|
||||
|
||||
if (!c_flag) {
|
||||
int fd = open(path, O_CREAT | O_RDONLY, 0666);
|
||||
if (fd < 0) {
|
||||
@ -56,53 +56,6 @@ static int touch(const char *path, const time_t date) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static time_t parse_date(char *str) {
|
||||
char *fmt = NULL;
|
||||
switch (strlen(str)) {
|
||||
case 8:
|
||||
fmt = "%m%d%H%M";
|
||||
break;
|
||||
|
||||
case 10:
|
||||
fmt = "%y%m%d%H%M";
|
||||
break;
|
||||
|
||||
case 11:
|
||||
fmt = "%m%d%H%M.%S";
|
||||
break;
|
||||
|
||||
case 12:
|
||||
fmt = "%Y%m%d%H%M";
|
||||
break;
|
||||
|
||||
case 13:
|
||||
fmt = "%y%m%d%H%M.%S";
|
||||
break;
|
||||
|
||||
case 15:
|
||||
fmt = "%Y%m%d%H%M.%S";
|
||||
break;
|
||||
|
||||
case 19:
|
||||
fmt = "%Y-%m-%dT%H:%M:%S";
|
||||
break;
|
||||
|
||||
default:
|
||||
fprintf(stderr, "touch: invalid date format\n");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
time_t now = time(NULL);
|
||||
struct tm tm = *localtime(&now);
|
||||
|
||||
if (!strptime(str, fmt, &tm)) {
|
||||
fprintf(stderr, "touch: %s\n", strerror(errno));
|
||||
exit(1);
|
||||
}
|
||||
|
||||
return mktime(&tm);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
time_t date = -1;
|
||||
|
||||
@ -123,11 +76,17 @@ int main(int argc, char **argv) {
|
||||
|
||||
case 't':
|
||||
case 'd':
|
||||
date = parse_date(optarg);
|
||||
date = mu_parse_date("touch", optarg);
|
||||
if (date == -1)
|
||||
return 1;
|
||||
|
||||
break;
|
||||
|
||||
default:
|
||||
puts("touch [cmad] [file1 file2...]\n\t-c Don't create files\n\t-a Change only atime\n\t-m Change only mtime\n\t-d Date/time to use");
|
||||
puts("touch [cmad] [file1 file2...]\n\t-c Don't create files\n\t-a Change only atime\n\t-m Change only mtime\n\t-d Date/time to use\n\nRecognized TIME formats:");
|
||||
for (size_t i = 0; i < sizeof(mu_date_fmts) / sizeof(char *); i++)
|
||||
puts(mu_date_fmts[i]);
|
||||
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user