]> git.gag.com Git - debian/cpmtools/blob - cpmchattr.c
fix up control and rules file issues identified by lintian
[debian/cpmtools] / cpmchattr.c
1 /* #includes */ /*{{{C}}}*//*{{{*/
2 #include "config.h"
3
4 #include <ctype.h>
5 #include <stdio.h>
6 #include <string.h>
7 #include <stdlib.h>
8
9 #include "getopt.h"
10 #include "cpmfs.h"
11
12 #ifdef USE_DMALLOC
13 #include <dmalloc.h>
14 #endif
15 /*}}}*/
16
17 const char cmd[]="cpmchattr";
18
19 int main(int argc, char *argv[]) /*{{{*/
20 {
21   /* variables */ /*{{{*/
22   const char *err;
23   const char *image;
24   const char *format=FORMAT;
25   const char *devopts=NULL;
26   int c,i,usage=0,exitcode=0;
27   struct cpmSuperBlock drive;
28   struct cpmInode root;
29   int gargc;
30   char **gargv;
31   const char *attrs; 
32   /*}}}*/
33
34   /* parse options */ /*{{{*/
35   while ((c=getopt(argc,argv,"T:f:h?"))!=EOF) switch(c)
36   {
37     case 'T': devopts=optarg; break;
38     case 'f': format=optarg; break;
39     case 'h':
40     case '?': usage=1; break;
41   }
42
43   if (optind>=(argc-2)) usage=1;
44   else 
45   {
46     image=argv[optind];
47     attrs = argv[optind+1];
48   }    
49
50   if (usage)
51   {
52     fprintf(stderr,"Usage: %s [-f format] [-T dsktype] image [NMrsa1234] pattern ...\n",cmd);
53     exit(1);
54   }
55   /*}}}*/
56   /* open image */ /*{{{*/
57   if ((err=Device_open(&drive.dev, image, O_RDWR, devopts)))
58   {
59     fprintf(stderr,"%s: can not open %s (%s)\n",cmd,image,err);
60     exit(1);
61   }
62   cpmReadSuper(&drive,&root,format);
63   /*}}}*/
64   cpmglob(optind,argc,argv,&root,&gargc,&gargv);
65   for (i=0; i<gargc; ++i)
66   {
67     struct cpmInode ino;
68     int rc;
69     cpm_attr_t attrib;
70
71     rc = cpmNamei(&root,gargv[i], &ino)==-1;
72     if (!rc) rc = cpmAttrGet(&ino, &attrib);
73     if (!rc)
74     {
75         int n, m;
76         m = 0;
77         for (n = 0; n < strlen(attrs); n++)
78         {
79           int mask = 0;
80           switch (attrs[n])
81           {
82             case 'n':
83             case 'N': mask = 0; attrib = 0; break;
84             case 'm':
85             case 'M': mask = 0; m = !m;   break;
86             case '1': mask = CPM_ATTR_F1; break;
87             case '2': mask = CPM_ATTR_F2; break;
88             case '3': mask = CPM_ATTR_F3; break;
89             case '4': mask = CPM_ATTR_F4; break;
90             case 'r': 
91             case 'R': mask = CPM_ATTR_RO; break;
92             case 's':
93             case 'S': mask = CPM_ATTR_SYS; break;
94             case 'a':
95             case 'A': mask = CPM_ATTR_ARCV; break;
96             default: fprintf(stderr, "%s: Unknown attribute %c\n", cmd, attrs[n]);
97                      exit(1);
98           } 
99           if (m) attrib &= ~mask; else attrib |= mask;
100         }
101         rc = cpmAttrSet(&ino, attrib);
102     }
103     if (rc)
104     {
105       fprintf(stderr,"%s: can not set attributes for %s: %s\n",cmd,gargv[i],boo);
106       exitcode=1;
107     }
108   }
109   exit(exitcode);
110 }
111 /*}}}*/