1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
/* @(#)filemopen.c 1.4 05/08/18 Copyright 1986, 1995-2005 J. Schilling */
/*
* Copyright (c) 1986, 1995-2005 J. Schilling
*/
/*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* See the file CDDL.Schily.txt in this distribution for details.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file CDDL.Schily.txt from this distribution.
*/
#include "schilyio.h"
EXPORT FILE *
#ifdef PROTOTYPES
filemopen(const char *name, const char *mode, mode_t cmode)
#else
filemopen(name, mode, cmode)
const char *name;
const char *mode;
mode_t cmode;
#endif
{
int ret;
int omode = 0;
int flag = 0;
if (!_cvmod(mode, &omode, &flag))
return ((FILE *) NULL);
if ((ret = open(name, omode, cmode)) < 0)
return ((FILE *) NULL);
return (_fcons((FILE *)0, ret, flag | FI_CLOSE));
}
|