2000-07-16 Laurynas Biveinis <lauras@softhome.net>
[official-gcc.git] / libf2c / libU77 / chmod_.c
blobd482d9ed8284d6a66a32d1fea3789f40a2d1b821
1 /* Copyright (C) 1995, 1997 Free Software Foundation, Inc.
2 This file is part of GNU Fortran libU77 library.
4 This library is free software; you can redistribute it and/or modify it
5 under the terms of the GNU Library General Public License as published
6 by the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 GNU Fortran is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Library General Public License for more details.
14 You should have received a copy of the GNU Library General Public
15 License along with GNU Fortran; see the file COPYING.LIB. If
16 not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 Boston, MA 02111-1307, USA. */
20 /* This definitely shouldn't be done this way -- should canibalise
21 chmod(1) from GNU or BSD. */
23 #ifdef HAVE_CONFIG_H
24 #include "config.h"
25 #endif
26 #if HAVE_UNISTD_H
27 # include <unistd.h>
28 #endif
29 #if HAVE_STDLIB_H
30 # include <stdlib.h>
31 #else
32 # include <stdio.h>
33 #endif
34 #if STDC_HEADERS
35 # include <string.h>
36 #endif
38 #include "f2c.h"
40 #ifndef CHMOD_PATH
41 #define CHMOD_PATH "/bin/chmod"
42 #endif
44 #ifdef KR_headers
45 extern void s_cat ();
46 void g_char ();
48 integer G77_chmod_0 (name, mode, Lname, Lmode)
49 char *name, *mode;
50 ftnlen Lname, Lmode;
51 #else
52 extern void s_cat(char *lp, char *rpp[], ftnlen rnp[], ftnlen *np, ftnlen ll);
53 void g_char(const char *a, ftnlen alen, char *b);
55 integer G77_chmod_0 (/* const */ char *name, /* const */ char *mode, const ftnlen Lname, const ftnlen Lmode)
56 #endif
58 char *buff;
59 char *bp, *blast;
60 int i;
61 ftnlen l, l2;
62 ftnlen six = 6;
63 address a[6];
64 ftnlen ii[6];
65 char chmod_path [] = CHMOD_PATH;
66 l = strlen (chmod_path);
67 buff = malloc (Lname+Lmode+l+3+13+1);
68 if (!buff) return -1;
69 ii[0] = l; a[0] = chmod_path;
70 ii[1] = 1; a[1] = " ";
71 ii[2] = Lmode; a[2] = mode;
72 ii[3] = 2; a[3] = " '";
73 for (l2=Lname; (l2 > 1) && (name[l2-1] == ' '); )
74 l2--;
75 ii[4] = l2; a[4] = name;
76 ii[5] = 13; a[5] = "' 2>/dev/null";
77 s_cat (buff, a, ii, &six, Lname+Lmode+l+3+13);
78 buff[Lname+Lmode+l+3+13] = '\0';
79 i = system (buff);
80 free (buff);
81 return i;