X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=cpmrm.c;h=f49ed4a68b5d741b7f13fe71b9ad83c1a5b60f62;hb=1f63e0639206e2b1d2757860fcbe77a86f3aaa3a;hp=b88bdcab9f477618c245e91e73c96ad813af306d;hpb=32087c67d53a8f8058b359388f23e2dbc9436d54;p=debian%2Fcpmtools diff --git a/cpmrm.c b/cpmrm.c index b88bdca..f49ed4a 100644 --- a/cpmrm.c +++ b/cpmrm.c @@ -1,11 +1,13 @@ /* #includes */ /*{{{C}}}*//*{{{*/ +#include "config.h" + #include #include #include #include #include -#include "config.h" -#include "getopt.h" + +#include "getopt_.h" #include "cpmfs.h" /*}}}*/ @@ -16,8 +18,9 @@ int main(int argc, char *argv[]) /*{{{*/ /* variables */ /*{{{*/ const char *err; const char *image; - const char *format=FORMAT; + const char *format; const char *devopts=NULL; + int uppercase=0; int c,i,usage=0,exitcode=0; struct cpmSuperBlock drive; struct cpmInode root; @@ -26,30 +29,36 @@ int main(int argc, char *argv[]) /*{{{*/ /*}}}*/ /* parse options */ /*{{{*/ - while ((c=getopt(argc,argv,"T:f:h?"))!=EOF) switch(c) + if (!(format=getenv("CPMTOOLSFMT"))) format=FORMAT; + while ((c=getopt(argc,argv,"T:f:uh?"))!=EOF) switch(c) { case 'T': devopts=optarg; break; case 'f': format=optarg; break; + case 'u': uppercase=1; break; case 'h': case '?': usage=1; break; } if (optind>=(argc-1)) usage=1; - else image=argv[optind]; + else image=argv[optind++]; if (usage) { - fprintf(stderr,"Usage: %s [-f format] [-T dsktype] image pattern ...\n",cmd); + fprintf(stderr,"Usage: %s [-f format] [-T dsktype] [-u] image pattern ...\n",cmd); exit(1); } /*}}}*/ /* open image */ /*{{{*/ if ((err=Device_open(&drive.dev, image, O_RDWR, devopts))) { - fprintf(stderr,"%s: can not open %s (%s)\n",cmd,image,err); + fprintf(stderr,"%s: cannot open %s (%s)\n",cmd,image,err); + exit(1); + } + if (cpmReadSuper(&drive,&root,format,uppercase)==-1) + { + fprintf(stderr,"%s: cannot read superblock (%s)\n",cmd,boo); exit(1); } - cpmReadSuper(&drive,&root,format); /*}}}*/ cpmglob(optind,argc,argv,&root,&gargc,&gargv); for (i=0; i