fis-gtm/sr_port/op_zprint.c

137 lines
4.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 "gtm_string.h"
#include "gtm_stdio.h"
#include "rtnhdr.h"
#include "srcline.h"
#include "error.h"
#include "op.h"
#include "outofband.h"
#ifdef GTM_TRIGGER
# include "gtm_trigger_trc.h"
#endif
#define INFO_MSK(error) (error & ~SEV_MSK | INFO)
GBLREF int4 outofband;
GBLREF mident_fixed zlink_mname;
error_def(ERR_FILENOTFND);
error_def(ERR_TRIGNAMENF);
error_def(ERR_TXTSRCMAT);
error_def(ERR_ZPRTLABNOTFND);
error_def(ERR_ZLINKFILE);
error_def(ERR_ZLMODULE);
void op_zprint(mval *rtn, mval *start_label, int start_int_exp, mval *end_label, int end_int_exp)
/* contains label to be located or null string */
/* contains label offset or line number to reference */
/* contains routine to look in or null string */
/* NOTE: If only the first label is specified, the */
/* parser makes the second label the duplicate */
/* of the first. (not so vice versa) */
{
mval print_line, null_str;
mstr *src1, *src2;
uint4 stat1, stat2;
rhdtyp *rtn_vector;
boolean_t is_trigger;
MV_FORCE_STR(start_label);
MV_FORCE_STR(end_label);
MV_FORCE_STR(rtn);
/* This first call to get_src_line() for our entry "locks-in" the source we will be extracting. If the rtn
* in question in a trigger, it would be possible for the further get_src_line() calls we do to cause the
* trigger to be reloaded making our earlier fetches irrelevant. After this first call, all following calls
* to get_src_line() for this operation will tell get_src_line() to NOT verify or reload the triggers so
* we get a consistent (if no longer current) view of the trigger.
*/
GTMTRIG_ONLY(IS_TRIGGER_RTN(&rtn->str, is_trigger));
GTMTRIG_ONLY(if (is_trigger) DBGTRIGR((stderr, "op_zprint: Performing zprint of a trigger\n")));
stat1 = get_src_line(rtn, start_label, start_int_exp, &src1, VERIFY);
if (OBJMODMISS == stat1)
{
# ifdef GTM_TRIGGER
if (is_trigger)
rts_error(VARLSTCNT(4) ERR_TRIGNAMENF, 2, rtn->str.len, rtn->str.addr);
# endif
/* get_src_line did not find the object file to load */
rts_error(VARLSTCNT(8) ERR_ZLINKFILE, 2, rtn->str.len, rtn->str.addr,
ERR_ZLMODULE, 2, mid_len(&zlink_mname), &zlink_mname.c[0]);
}
if (NULL == (rtn_vector = find_rtn_hdr(&rtn->str)))
{
# ifdef GTM_TRIGGER
if (is_trigger)
rts_error(VARLSTCNT(4) ERR_TRIGNAMENF, 2, rtn->str.len, rtn->str.addr);
# endif
GTMASSERT; /* If couldn't find module, should have returned OBJMODMISS */
}
if (stat1 & LABELNOTFOUND)
rts_error(VARLSTCNT(1) ERR_ZPRTLABNOTFND);
if (stat1 & SRCNOTFND)
rts_error(VARLSTCNT(4) ERR_FILENOTFND, 2, rtn_vector->src_full_name.len, rtn_vector->src_full_name.addr);
if (stat1 & (SRCNOTAVAIL | AFTERLASTLINE))
return;
if (stat1 & (ZEROLINE | NEGATIVELINE))
{
null_str.mvtype = MV_STR;
null_str.str.len = 0;
stat1 = get_src_line(rtn, &null_str, 1, &src1, NOVERIFY);
if (stat1 & AFTERLASTLINE) /* the "null" file */
return;
}
if (end_int_exp == 0 && (end_label->str.len == 0 || *end_label->str.addr == 0))
stat2 = AFTERLASTLINE;
else if ((stat2 = get_src_line(rtn, end_label, end_int_exp, &src2, NOVERIFY)) & LABELNOTFOUND)
rts_error(VARLSTCNT(1) ERR_ZPRTLABNOTFND);
if (stat2 & (ZEROLINE | NEGATIVELINE))
return;
if (stat2 & AFTERLASTLINE)
{
null_str.mvtype = MV_STR;
null_str.str.len = 0;
stat2 = get_src_line(rtn, &null_str, 1, &src2, NOVERIFY);
/* number of lines less one for duplicated zero'th line and one due
to termination condition being <=
*/
assert((INTPTR_T)src2 > 0);
src2 += rtn_vector->lnrtab_len - 2;
}
if (stat1 & CHECKSUMFAIL)
{
rts_error(VARLSTCNT(1) INFO_MSK(ERR_TXTSRCMAT));
op_wteol(1);
}
print_line.mvtype = MV_STR;
for ( ; src1 <= src2 ; src1++)
{ /* Note outofband check currently disabled. This routine (op_zprint) needs to be rewritten to provide
* a TP wrapper (if not already in place) and to buffer the lines obtained from get_src_line() completely
* before outputting anything because obtaining these source lines is subject to TP restarts when we are
* accessing triggers. In addition, for the case of "normal" routine source fetches, an outofband could
* invoke a job interrupt which could relink an entry point so an out-of-band interrupt of any kind means
* the source fetches also need to be restarted. Until these issues are address, the outofband check
* remains disabled (SE - 12/2010)
*/
/* if (outofband)
outofband_action(FALSE); */
print_line.str.addr = src1->addr;
print_line.str.len = src1->len;
op_write(&print_line);
op_wteol(1);
}
return;
}