Tools/DiskTool - Added 'lvm' command (alias for 'mountlvm')
[tpg/acess2.git] / Tools / DiskTool / src / main.c
index 58ce6d2..687bb3b 100644 (file)
@@ -13,32 +13,32 @@ int main(int argc, char *argv[])
        // Parse arguments
        for( int i = 1; i < argc; i ++ )
        {
-               if( strcmp("--image", argv[i]) == 0 || strcmp("-i", argv[i]) == 0 ) {
+               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]);
-                               exit(-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;
                        }
 
                        i += 2;
                        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, "mountlvm 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]);
-                               exit(-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;
                        }
                        
                        i += 2;
@@ -48,7 +48,7 @@ int main(int argc, char *argv[])
                if( strcmp("ls", argv[i]) == 0 ) {
                        if( argc - i < 2 ) {
                                fprintf(stderr, "ls 1 argument (path)\n");
-                               exit(-1);
+                               break;
                        }
 
                        DiskTool_ListDirectory(argv[i+1]);
@@ -60,7 +60,7 @@ int main(int argc, char *argv[])
                        
                        if( argc - i < 3 ) {
                                fprintf(stderr, "cp takes 2 arguments (source and destination)\n");
-                               exit(-1);
+                               break;
                        }
 
                        DiskTool_Copy(argv[i+1], argv[i+2]);                    
@@ -68,10 +68,11 @@ int main(int argc, char *argv[])
                        i += 2;
                        continue ;
                }
+       
+               fprintf(stderr, "Unknown command '%s'\n", argv[i]);
        }
        
-       // Unmount all
-       // Clear LVM
+       DiskTool_Cleanup();
        
        return 0;
 }

UCC git Repository :: git.ucc.asn.au