1da2e3ebdSchin /***********************************************************************
2da2e3ebdSchin *                                                                      *
3da2e3ebdSchin *               This software is part of the ast package               *
4*b30d1939SAndy Fiddaman *          Copyright (c) 1982-2012 AT&T Intellectual Property          *
5da2e3ebdSchin *                      and is licensed under the                       *
6*b30d1939SAndy Fiddaman *                 Eclipse Public License, Version 1.0                  *
77c2fbfb3SApril Chin *                    by AT&T Intellectual Property                     *
8da2e3ebdSchin *                                                                      *
9da2e3ebdSchin *                A copy of the License is available at                 *
10*b30d1939SAndy Fiddaman *          http://www.eclipse.org/org/documents/epl-v10.html           *
11*b30d1939SAndy Fiddaman *         (with md5 checksum b35adb5213ca9657e911e9befb180842)         *
12da2e3ebdSchin *                                                                      *
13da2e3ebdSchin *              Information and Software Systems Research               *
14da2e3ebdSchin *                            AT&T Research                             *
15da2e3ebdSchin *                           Florham Park NJ                            *
16da2e3ebdSchin *                                                                      *
17da2e3ebdSchin *                  David Korn <dgk@research.att.com>                   *
18da2e3ebdSchin *                                                                      *
19da2e3ebdSchin ***********************************************************************/
20da2e3ebdSchin #pragma prototyped
21da2e3ebdSchin /*
22da2e3ebdSchin  * umask [-S] [mask]
23da2e3ebdSchin  *
24da2e3ebdSchin  *   David Korn
25da2e3ebdSchin  *   AT&T Labs
26da2e3ebdSchin  *   research!dgk
27da2e3ebdSchin  *
28da2e3ebdSchin  */
29da2e3ebdSchin 
30da2e3ebdSchin #include	<ast.h>
31da2e3ebdSchin #include	<sfio.h>
32da2e3ebdSchin #include	<error.h>
33da2e3ebdSchin #include	<ctype.h>
34da2e3ebdSchin #include	<ls.h>
35da2e3ebdSchin #include	<shell.h>
36da2e3ebdSchin #include	"builtins.h"
37da2e3ebdSchin #ifndef SH_DICT
38da2e3ebdSchin #   define SH_DICT	"libshell"
39da2e3ebdSchin #endif
40da2e3ebdSchin 
b_umask(int argc,char * argv[],Shbltin_t * context)41*b30d1939SAndy Fiddaman int	b_umask(int argc,char *argv[],Shbltin_t *context)
42da2e3ebdSchin {
43da2e3ebdSchin 	register char *mask;
44da2e3ebdSchin 	register int flag = 0, sflag = 0;
45*b30d1939SAndy Fiddaman 	NOT_USED(context);
46da2e3ebdSchin 	while((argc = optget(argv,sh_optumask))) switch(argc)
47da2e3ebdSchin 	{
48da2e3ebdSchin 		case 'S':
49da2e3ebdSchin 			sflag++;
50da2e3ebdSchin 			break;
51da2e3ebdSchin 		case ':':
52da2e3ebdSchin 			errormsg(SH_DICT,2, "%s", opt_info.arg);
53da2e3ebdSchin 			break;
54da2e3ebdSchin 		case '?':
55da2e3ebdSchin 			errormsg(SH_DICT,ERROR_usage(2), "%s",opt_info.arg);
56da2e3ebdSchin 			break;
57da2e3ebdSchin 	}
58da2e3ebdSchin 	if(error_info.errors)
59da2e3ebdSchin 		errormsg(SH_DICT,ERROR_usage(2),"%s",optusage((char*)0));
60da2e3ebdSchin 	argv += opt_info.index;
61da2e3ebdSchin 	if(mask = *argv)
62da2e3ebdSchin 	{
63da2e3ebdSchin 		register int c;
64da2e3ebdSchin 		if(isdigit(*mask))
65da2e3ebdSchin 		{
66da2e3ebdSchin 			while(c = *mask++)
67da2e3ebdSchin 			{
68da2e3ebdSchin 				if (c>='0' && c<='7')
69da2e3ebdSchin 					flag = (flag<<3) + (c-'0');
70da2e3ebdSchin 				else
71da2e3ebdSchin 					errormsg(SH_DICT,ERROR_exit(1),e_number,*argv);
72da2e3ebdSchin 			}
73da2e3ebdSchin 		}
74da2e3ebdSchin 		else
75da2e3ebdSchin 		{
76da2e3ebdSchin 			char *cp = mask;
77da2e3ebdSchin 			flag = umask(0);
787c2fbfb3SApril Chin 			c = strperm(cp,&cp,~flag&0777);
79da2e3ebdSchin 			if(*cp)
80da2e3ebdSchin 			{
81da2e3ebdSchin 				umask(flag);
82da2e3ebdSchin 				errormsg(SH_DICT,ERROR_exit(1),e_format,mask);
83da2e3ebdSchin 			}
84da2e3ebdSchin 			flag = (~c&0777);
85da2e3ebdSchin 		}
86da2e3ebdSchin 		umask(flag);
87da2e3ebdSchin 	}
88da2e3ebdSchin 	else
89da2e3ebdSchin 	{
90da2e3ebdSchin 		umask(flag=umask(0));
91da2e3ebdSchin 		if(sflag)
92da2e3ebdSchin 			sfprintf(sfstdout,"%s\n",fmtperm(~flag&0777));
93da2e3ebdSchin 		else
94da2e3ebdSchin 			sfprintf(sfstdout,"%0#4o\n",flag);
95da2e3ebdSchin 	}
96da2e3ebdSchin 	return(0);
97da2e3ebdSchin }
98da2e3ebdSchin 
99