Previous Thread
Next Thread
Print Thread
A-Shell 7.0.1770.3 Error #37870 19 Mar 25 04:47 PM
Joined: Aug 2016
Posts: 403
J
John Andreasen Online Content OP
Member
OP Online Content
Member
J
Joined: Aug 2016
Posts: 403
Hi Jack,

I am experiencing a BASIC error #17 with A-Shell 7.0.1770.3 on Debian 12. The BASIC error occurs at location counter 62F1B in the below code.
Code
062e5c  FUNCTION fn'edi_out_output'file(hndl as f8:INPUTONLY,r_file$ as s256:OUTPUTONLY,dummy=0 as b1:OUTPUTONLY) as f8
062eb4  MAP1 state'hndl	,EDI_STATE'HANDLE_STRUCT
062eb4  !>>      MAP2 state'hndl.cur'ptr,b,3
062eb4  !>>      MAP2 state'hndl.cur'doc$,s,3
062eb4  !>>      MAP2 state'hndl.hndl(9),TREE_HANDLEf,8
062eb4  !>>      MAP2 state'hndl.iter'hndl(9),TREE_HANDLEf,8
062eb4  !>>      MAP2 state'hndl.cur'key$(9),s,32
062eb4  !>>      MAP2 state'hndl.level$(9),s,32
062eb4  !>>      MAP2 state'hndl.level'key$(9),s,35
062eb4  MAP1 meta'data	,EDI_META_STRUCT
062eb4  !>>      MAP2 meta'data.hndl,TREE_HANDLEf,8
062eb4  !>>      MAP2 meta'data.edi'ent'cfg'key,EDI'ENT'CFG'KEY_STRUCT
062eb4  !>>          MAP3 meta'data.edi'ent'cfg'key.ent'type$,s,1
062eb4  !>>          MAP3 meta'data.edi'ent'cfg'key.ent'number$,s,6
062eb4  !>>          MAP3 meta'data.edi'ent'cfg'key.site$,s,3
062eb4  !>>  
062eb4  !>>      MAP2 meta'data.functional'id'code$,s,2
062eb4  !>>      MAP2 meta'data.element'sep$,s,1
062eb4  !>>      MAP2 meta'data.segment'term$,s,1
062eb4  !>>      MAP2 meta'data.repetition'sep$,s,1
062eb4  
062eb4  	IF (fn'edi_metadata'get(hndl=hndl, r_meta'data=meta'data) <> 0) THEN
062ed1  		.fn = -1
062eda  		EXITFUNCTION
062ede  	ENDIF
062ede  
062ede  	r_file$ = fn'fileunique_get_filename$(mode=0, path$="TMP:", amos'spec=1)
062f09  	ch'edifile = Fn'NextCh(2001)
062f1b  	OPEN #ch'edifile,r_file$,OUTPUT

I tried unsuccessfully to reproduce in a smaller test program thinking it might be related to the OUTPUTONLY changes, but was unsuccessful. The code works as expected on running an earlier version of A-Shell. I can try something else if you have a suggestion or send the LSX as well.

Thanks,
John Andreasen
Diversified Data Software

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37871 19 Mar 25 04:55 PM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924
I suspect the error is actually on the next line. Is it a file access operation?

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37872 19 Mar 25 05:01 PM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924
Cancel that - error 17 is file not found, so it almost certainly applies to the OPEN. The ashlog.log file should list the actual fspec, which should give us a clue. I'm guessing that the latest change to make :OUTPUTONLY inheritable may be affecting the fn'fileunique_get_filename$() function so that it isn't returning a value?

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37873 19 Mar 25 05:13 PM
Joined: Aug 2016
Posts: 403
J
John Andreasen Online Content OP
Member
OP Online Content
Member
J
Joined: Aug 2016
Posts: 403
Here is what the ashlog shows. I did add a trace and it indicates the function is returning a value, but without the ppn: r_file$=[DSK30:TSKAAB.000]
19-Mar-25 19:05:15 [p1265488-2]<CU22:EDIORDIMP:62f1b> Trapped Basic Error #17 (File not found) at location counter &h62F1B, last proc/func: Fn'NextCh<
19-Mar-25 19:05:15 [p1265488-2]<CU22:EDIORDIMP:62f1b> Call stack trace, from program CU22 :
From loc de0a, Xcall EDIORDIMP
From loc ae6b5, Call Proc() @8b9af
From loc 8ba5b, Call Proc() @9067a
From loc 909f8, Call Proc() @8d882
From loc 8d8ca, Func() @8d930
From loc 8d98c, Call Proc() @64d3e
From loc 6507f, Func() @64972
From loc 64c59, Func() @643d7
From loc 647e2, Func() @657ef
From loc 658dc, Func() @62e5c
19-Mar-25 19:05:18 [p1265488-2]<CU22:EDIORDIMP:62f1b> System Error Log: C errno:2, last instr:0x1b, cwd:DSK5:[160,1], host OS error:2, DDB error:3, mode:2, chan:2033
19-Mar-25 19:05:18 [p1265488-2]<CU22:EDIORDIMP:62f1b> >>No such file or directory (/var/data/harris/ashell/vm/miame/dsk30/160001/tskaab.000)
19-Mar-25 19:05:18 [p1265488-2]<CU22:EDIORDIMP:658db> Trapped Basic Error #17 (File not found) at location counter &h658DB, last proc/func: Fn'NextCh<
19-Mar-25 19:05:18 [p1265488-2]<CU22:EDIORDIMP:658db> Call stack trace, from program CU22 :
From loc de0a, Xcall EDIORDIMP
From loc ae6b5, Call Proc() @8b9af
From loc 8ba5b, Call Proc() @9067a
From loc 909f8, Call Proc() @8d882
From loc 8d8ca, Func() @8d930
From loc 8d98c, Call Proc() @64d3e
From loc 6507f, Func() @64972
From loc 64c59, Func() @643d7
From loc 647e2, Func() @657ef

I will do some further testing with the function.

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37884 20 Mar 25 11:18 AM
Joined: Aug 2016
Posts: 403
J
John Andreasen Online Content OP
Member
OP Online Content
Member
J
Joined: Aug 2016
Posts: 403
I have been able to reproduce the issue in a smaller program. It looks like it is an issue related to an XCALL REGEX in Fn'To'Amos(). The way the parameters are specified to Fn'To'Amos() makes a difference. Our version is slightly different than the SOS library version. Is it alright if I send you a LSX to look at?

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37885 20 Mar 25 11:22 AM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924
Yes please. I was going to suggest that it was probably due to some detail in your Fn'To'Amos() function, which is the only logical place where it seems possible that the device and PPN parts of the path translation could be handled separately.

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37886 20 Mar 25 01:00 PM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924
I'm unable (as yet) to explain why this seems to be new, as none of the related logic seems to have been changed recently. The issue has to do with dynamic string parameters (which have always been a bit complicated to handle as parameters due to a legacy attribute of the way parameter passing involves pointers to data, which in the case of dynamic strings, may move during assignments.)

Until I can figure it out, the simple fix is to change the parameters to your Fn'To'Amos() function to be fixed strings (s260 or T_NATIVEPATH) would be sufficient, e.g.
Code
FUNCTION Fn'To'Amos(nat'spec$ as s260:INPUTONLY,amos'spec$ as s260:OUTPUTONLY) as b1

Although switching to fixed length strings does require more stack space, it is more CPU efficient (not that either one will be noticeable in this case!)

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37902 21 Mar 25 05:31 PM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924
After some further analysis, I realized that the dynamic strings aren't really the cause of the problem -- they were actually obscuring the problem! The real problem is here:
Code
XCALL REGEX, "(.*)[\/\\](\d{6})$", sts, dir$, 0, 0, "", 0, dir$, ppn$

The dir$ variable is being used for both the subject and the first sub-match return parameter. The problem there is that the internal procedure for retrieving the sub-matches works by copying them from the subject variable using offsets that are returned by the core regex function. So once the first sub-match gets copied to the dir$ parameter, that parameter gets truncated, resulting in the second sub-match not returning anything.

It might not be a problem if the sub-matches weren't immediately adjacent to each other, but in this case, truncating the output for the dir$ match clobbered the memory that was subsequently referenced to get the ppn$ sub-match.

In the case of dynamic strings, the memory handling of the strings will depend on a variety of factors relating to the prior activity with other dynamic string variables in the same scope. So my suggested workaround only worked by chance. And changing the dir$ parameter from a dynamic string to a static string only makes it worse.

I'm going to add a fail-safe to XCALL REGEX to check for this scenario and if found, to make a second copy of the subject string so that it can't be modified by returning sub-matches in to the same variable. Short of that, the real fix for this problem is to use a separate variable for the sub-matches, i.e. don't use dir$ for both the subject and a sub-match.

Note that this restriction probably doesn't apply to many (or even any) other XCALLs; it's just a quirk of the REGEX algorithm.

Re: A-Shell 7.0.1770.3 Error [Re: John Andreasen] #37905 24 Mar 25 05:52 PM
Joined: Jun 2001
Posts: 11,924
J
Jack McGregor Offline
Member
Offline
Member
J
Joined: Jun 2001
Posts: 11,924


Moderated by  Jack McGregor, Ty Griffin 

Powered by UBB.threads™ PHP Forum Software 7.7.3