1 /* $Id: open.c,v 1.1.1.1 2008/08/24 05:34:47 gmcgarry Exp $ */
3 * Copyright(C) Caldera International Inc. 2001-2002. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
9 * Redistributions of source code and documentation must retain the above
10 * copyright notice, this list of conditions and the following disclaimer.
11 * Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditionsand the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * All advertising materials mentioning features or use of this software
15 * must display the following acknowledgement:
16 * This product includes software developed or owned by Caldera
18 * Neither the name of Caldera International, Inc. nor the names of other
19 * contributors may be used to endorse or promote products derived from
20 * this software without specific prior written permission.
22 * USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
23 * INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
24 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26 * DISCLAIMED. IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE LIABLE
27 * FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OFLIABILITY, WHETHER IN CONTRACT,
31 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
32 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33 * POSSIBILITY OF SUCH DAMAGE.
35 #include <sys/types.h>
45 static int isdev(char *s
);
55 if(a
->ounit
>=MXUNIT
|| a
->ounit
<0)
56 err(a
->oerr
,101,"open")
58 if(b
->ufd
!=0) goto connected
;
61 if(a
->oblnk
&& *a
->oblnk
=='b') b
->ublnk
=1;
64 { if(b
->url
>0) b
->ufmt
=0;
67 else if(*a
->ofm
=='f') b
->ufmt
=1;
69 if(a
->osta
==0) goto unknown
;
75 if(a
->ofnm
==0) err(a
->oerr
,107,"open")
76 g_char(a
->ofnm
,a
->ofnmlen
,buf
);
78 if(a
->osta
&& *a
->osta
=='o' && access(buf
,0))
79 err(a
->oerr
,errno
,"open")
81 b
->ufnm
=(char *) calloc(strlen(buf
)+1,sizeof(char));
82 if(b
->ufnm
==NULL
) err(a
->oerr
,113,"no space");
86 { b
->ufd
= fopen(buf
,"r");
87 if(b
->ufd
==NULL
) err(a
->oerr
,errno
,buf
)
91 { b
->ufd
= fopen(buf
, "a");
92 if(b
->ufd
!= NULL
) b
->uwrt
= 1;
93 else if((b
->ufd
= fopen(buf
, "r")) != NULL
)
94 { fseek(b
->ufd
, 0L, 2);
97 else err(a
->oerr
, errno
, buf
)
99 b
->useek
=canseek(b
->ufd
);
100 if((b
->uinode
=inode(buf
))==-1)
101 err(a
->oerr
,108,"open")
102 if(a
->orl
&& b
->useek
) rewind(b
->ufd
);
106 strcpy(buf
,"tmp.FXXXXXX");
111 if(a
->ofnm
==0) err(a
->oerr
,107,"open")
112 g_char(a
->ofnm
,a
->ofnmlen
,buf
);
114 if(access(buf
, 0) == 0) creat(buf
, 0666);
120 same
: if(a
->oblnk
!= 0) b
->ublnk
= *a
->oblnk
== 'b'?0:1;
123 g_char(a
->ofnm
,a
->ofnmlen
,buf
);
124 if(inode(buf
)==b
->uinode
) goto same
;
128 if((n
=f_clos(&x
))!=0) return(n
);
133 fk_open(int rd
,int seq
,int fmt
, ftnint n
)
137 sprintf(nbuf
,"fort.%ld",n
);
141 a
.ofnmlen
=strlen(nbuf
);
143 a
.oacc
= seq
==SEQ
?"s":"d";
144 a
.ofm
= fmt
==FMT
?"f":"u";
145 a
.orl
= seq
==DIR?1:0;
154 if(stat(s
, &x
) == -1) return(0);
155 if((j
= (x
.st_mode
&S_IFMT
)) == S_IFREG
|| j
== S_IFDIR
) return(0);