Sync: Add some argument parsing to sync(1)
You can specify --block to make the program wait until sync is complete.
This commit is contained in:
parent
a69e5fb288
commit
b573701625
|
@ -1,6 +1,29 @@
|
|||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <unistd.h>
|
||||
|
||||
int main()
|
||||
void usage(int ret, char* cmd)
|
||||
{
|
||||
sync();
|
||||
FILE* fout = (ret == 0) ? stdout : stderr;
|
||||
fprintf(fout, "usage: %s [OPTION]...\n", cmd);
|
||||
fprintf(fout, "Tells the kernel to start a disk sync as soon as possible\n");
|
||||
fprintf(fout, " -b, --block return only after sync is complete\n");
|
||||
fprintf(fout, " -h, --help show this message and exit\n");
|
||||
exit(ret);
|
||||
}
|
||||
|
||||
int main(int argc, char** argv)
|
||||
{
|
||||
bool block = false;
|
||||
for (int i = 1; i < argc; i++)
|
||||
{
|
||||
if (strcmp(argv[i], "-b") == 0 || strcmp(argv[i], "--block") == 0)
|
||||
block = true;
|
||||
else if (strcmp(argv[i], "-h") == 0 || strcmp(argv[i], "--help") == 0)
|
||||
usage(0, argv[0]);
|
||||
else
|
||||
usage(1, argv[0]);
|
||||
}
|
||||
syncsync(block);
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue