Eliminating the getopt disgrace.
This commit is contained in:
		
							
								
								
									
										27
									
								
								mv.c
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								mv.c
									
									
									
									
									
								
							| @@ -9,26 +9,36 @@ | ||||
|  | ||||
| int mv(const char *, const char *); | ||||
|  | ||||
| static void | ||||
| usage(void) | ||||
| { | ||||
| 	eprintf("usage: %s source... dest\n", argv0); | ||||
| 	exit(1); | ||||
| } | ||||
|  | ||||
| int | ||||
| main(int argc, char *argv[]) | ||||
| { | ||||
| 	struct stat st; | ||||
| 	 | ||||
| 	if(getopt(argc, argv, "") != -1) | ||||
| 		exit(EXIT_FAILURE); | ||||
|  | ||||
| 	ARGBEGIN { | ||||
| 	default: | ||||
| 		usage(); | ||||
| 	} ARGEND; | ||||
|  | ||||
| 	if(argc > 3 && !(stat(argv[argc-1], &st) == 0 && S_ISDIR(st.st_mode))) | ||||
| 		eprintf("%s: not a directory\n", argv[argc-1]); | ||||
| 	enmasse(argc - optind, &argv[optind], mv); | ||||
| 	return EXIT_SUCCESS; | ||||
| 	enmasse(argc, &argv[0], mv); | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| int | ||||
| mv (const char *s1, const char *s2) | ||||
| mv(const char *s1, const char *s2) | ||||
| { | ||||
| 	if (rename(s1, s2) == 0) | ||||
| 		return 0; | ||||
| 	if (errno == EXDEV) | ||||
| 	{ | ||||
| 	if (errno == EXDEV) { | ||||
| 		cp_rflag = true; | ||||
| 		rm_rflag = true; | ||||
| 		cp(s1, s2); | ||||
| @@ -37,3 +47,4 @@ mv (const char *s1, const char *s2) | ||||
| 	} | ||||
| 	return -1; | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user