X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;ds=sidebyside;f=Tools%2FDiskTool%2Fsrc%2Fmain.c;h=2de26a6db1d50f81cbe262478d6944a3e849a16c;hb=d0b4559f2936f6d9f06be0f7c3c51527a480ec0d;hp=823bb2b188de1d7367b0e0eb038bfe736af2fd3a;hpb=11dbd684e9a3d907d43d71a3145205f1a86992fb;p=tpg%2Facess2.git diff --git a/Tools/DiskTool/src/main.c b/Tools/DiskTool/src/main.c index 823bb2b1..2de26a6d 100644 --- a/Tools/DiskTool/src/main.c +++ b/Tools/DiskTool/src/main.c @@ -16,12 +16,12 @@ int main(int argc, char *argv[]) if( strcmp("mount", argv[i]) == 0 || strcmp("-i", argv[i]) == 0 ) { // Mount an image if( argc - i < 3 ) { - fprintf(stderr, "--image/-i takes 2 arguments (ident and path)\n"); + fprintf(stderr, "mount takes 2 arguments (image and mountpoint)\n"); exit(-1); } - if( DiskTool_MountImage(argv[i+1], argv[i+2]) ) { - fprintf(stderr, "Unable to mount '%s' as '%s'\n", argv[i+2], argv[i+1]); + if( DiskTool_MountImage(argv[i+2], argv[i+1]) ) { + fprintf(stderr, "Unable to mount '%s' as '%s'\n", argv[i+1], argv[i+2]); break; } @@ -29,15 +29,15 @@ int main(int argc, char *argv[]) continue ; } - if( strcmp("mountlvm", argv[i]) == 0 ) { + if( strcmp("mountlvm", argv[i]) == 0 || strcmp("lvm", argv[i]) == 0 ) { if( argc - i < 3 ) { - fprintf(stderr, "mountlvm takes 2 arguments (ident and path)\n"); + fprintf(stderr, "lvm takes 2 arguments (iamge and ident)\n"); exit(-1); } - if( DiskTool_RegisterLVM(argv[i+1], argv[i+2]) ) { - fprintf(stderr, "Unable to register '%s' as LVM '%s'\n", argv[i+2], argv[i+1]); + if( DiskTool_RegisterLVM(argv[i+2], argv[i+1]) ) { + fprintf(stderr, "Unable to register '%s' as LVM '%s'\n", argv[i+1], argv[i+2]); break; } @@ -47,7 +47,7 @@ int main(int argc, char *argv[]) if( strcmp("ls", argv[i]) == 0 ) { if( argc - i < 2 ) { - fprintf(stderr, "ls 1 argument (path)\n"); + fprintf(stderr, "ls takes 1 argument (path)\n"); break; } @@ -68,6 +68,21 @@ int main(int argc, char *argv[]) i += 2; continue ; } + + if( strcmp("cat", argv[i]) == 0 ) { + + if( argc - 1 < 2 ) { + fprintf(stderr, "cat takes 1 argument (path)\n"); + break; + } + + DiskTool_Cat(argv[i+1]); + + i += 1; + continue; + } + + fprintf(stderr, "Unknown command '%s'\n", argv[i]); } DiskTool_Cleanup(); @@ -119,3 +134,7 @@ uint64_t DivMod64U(uint64_t value, uint64_t divisor, uint64_t *remainder) return value / divisor; } +size_t _fwrite_stdout(size_t bytes, const void *data) +{ + return fwrite(data, bytes, 1, stdout); +}