107 lines
2.9 KiB
C
107 lines
2.9 KiB
C
/****************************************************************
|
|
* *
|
|
* Copyright 2001, 2011 Fidelity Information Services, Inc *
|
|
* *
|
|
* This source code contains the intellectual property *
|
|
* of its copyright holder(s), and is made available *
|
|
* under a license. If you do not know the terms of *
|
|
* the license, please stop and do not read further. *
|
|
* *
|
|
****************************************************************/
|
|
|
|
#include "mdef.h"
|
|
#include "io.h"
|
|
#include "iosp.h"
|
|
#include "op.h"
|
|
#include "trans_log_name.h"
|
|
#ifdef __MVS__
|
|
#include "iormdef.h"
|
|
#endif
|
|
|
|
|
|
GBLREF io_log_name *io_root_log_name;
|
|
GBLREF io_pair io_curr_device;
|
|
GBLREF io_pair io_std_device;
|
|
GBLREF io_desc *active_device;
|
|
|
|
void op_close(mval *v, mval *p)
|
|
{
|
|
char buf[MAX_TRANS_NAME_LEN]; /* buffer to hold translated name */
|
|
io_desc *ciod; /* close io descriptor */
|
|
io_log_name *l;
|
|
io_log_name *prev;
|
|
io_log_name *tl; /* logical record for translated name */
|
|
int4 stat; /* status */
|
|
mstr tn; /* translated name */
|
|
ZOS_ONLY(d_rm_struct *rm_ptr;)
|
|
|
|
error_def(ERR_LOGTOOLONG);
|
|
error_def(ERR_TEXT);
|
|
|
|
MV_FORCE_STR(v);
|
|
MV_FORCE_STR(p);
|
|
stat = TRANS_LOG_NAME(&v->str, &tn, buf, SIZEOF(buf), dont_sendmsg_on_log2long);
|
|
if (SS_NORMAL == stat)
|
|
{
|
|
if (0 == (tl = get_log_name(&tn, NO_INSERT)))
|
|
return;
|
|
ciod = tl->iod;
|
|
if (0 == ciod || TRUE == ciod->perm ||
|
|
(ciod->state != dev_open && tcp != ciod->type))
|
|
return;
|
|
|
|
for (prev = io_root_log_name, l = prev->next; l != 0; prev = l, l = l->next)
|
|
{
|
|
if (l->iod == ciod && l != tl)
|
|
{
|
|
prev->next = l->next;
|
|
free(l);
|
|
l = prev;
|
|
}
|
|
}
|
|
} else if ((SS_NOLOGNAM == stat) VMS_ONLY(|| (0 == v->str.len)))
|
|
{
|
|
if (0 == (l = get_log_name(&v->str, NO_INSERT)))
|
|
return;
|
|
else if (0 == (ciod = l->iod) || TRUE == ciod->perm
|
|
|| (dev_open != ciod->state && tcp != ciod->type))
|
|
return;
|
|
}
|
|
# ifdef UNIX
|
|
else if (SS_LOG2LONG == stat)
|
|
rts_error(VARLSTCNT(5) ERR_LOGTOOLONG, 3, v->str.len, v->str.addr, SIZEOF(buf) - 1);
|
|
# endif
|
|
else
|
|
rts_error(VARLSTCNT(1) stat);
|
|
|
|
active_device = ciod;
|
|
if (io_curr_device.in == ciod)
|
|
{
|
|
io_curr_device.in = io_std_device.in;
|
|
/* On z/OS if is a fifo and it is read and write then need to set the current
|
|
device out to the std device out */
|
|
# ifdef __MVS__
|
|
if (ciod->type == rm)
|
|
{
|
|
rm_ptr = (d_rm_struct *) ciod->dev_sp;
|
|
if (rm_ptr->fifo && (ciod->pair.out != ciod))
|
|
io_curr_device.out = io_std_device.out;
|
|
}
|
|
# endif
|
|
}
|
|
if (io_curr_device.out == ciod)
|
|
io_curr_device.out = io_std_device.out;
|
|
|
|
#if defined(KEEP_zOS_EBCDIC) || defined(VMS)
|
|
if (DEFAULT_CODE_SET != ciod->in_code_set)
|
|
ICONV_CLOSE_CD(ciod->input_conv_cd);
|
|
if (DEFAULT_CODE_SET != ciod->out_code_set)
|
|
ICONV_CLOSE_CD(ciod->output_conv_cd);
|
|
#endif
|
|
|
|
(ciod->disp_ptr->close)(ciod, p);
|
|
active_device = 0;
|
|
if (ciod->type == rm)
|
|
remove_rms (ciod);
|
|
}
|