[Date Prev][Date Next][Subject Prev][Subject Next][
Date Index][
Subject Index]
Re: NotaBene S/G usage vs. U2
- Subject: Re: NotaBene S/G usage vs. U2
- From: Harry Binswanger hb@xxxxxxxx
- Date: Thu, 22 Apr 2010 00:15:12 -0400
Thanks, Carl.
I see that HIDE/UNHIDE in $H is the right way to go, for that one. I wonder
about HIDEing s/g 50 though. The point of some frames is to change 50's
value from what it had coming in.
I have only 4 non-XyWrite, AUX-calling, key assignments. The AUX files are
regular program files. The key assignments are like this:
Table=SHIFT
65=&X,X,-
NB.INI on startup does a LDPM of NBMAIN-X.AUX to &X, then &X tests for
every possible set of following keystrokes, including "X-". E.g., for "X-"
it works the following way. Near the top of the file is:
>>+>;*;
Then follows a long set of tests for what's in 90, including:
BX(VBX, 0,226);*; <== that's for ctrl-z as Win's undo.
So, what if I skip the AUX file and just assign to 65:
65=BX(,V,B,X,CO, ,0,CO,2,2,6,)
Do you know what VBX is/does?
The other AUX I use is NBMAIN-G, which uses &G, which does the curved
apostrophe and smart open and close quotes. its key assignments begin with
FF. I guess that's the screen refresh function. E.g.,
Table=
40=FF,&G,Q,1 <== that puts out the curved apostrophe
Table=SHIFT
40=FF,&G,Q,2 <=== That puts out smart quotes
In NBMAIN-G.AUX, near the top is:
>
which is followed by =="Q";*;==1 or 2
Lower down is:
;*;==1 or 2
But has a whole screenful of code, so I'd have to keep that AUX. I
Horribly, uses s/g 50.
>
Thanks for your help, Carl.
--Harry
Reply to note from Harry Binswanger Sun, 18 Apr
2010 14:02:42 -0600
Harry:
> I've solved the concrete problem, just be renumbering the ones
> in my frame to 01 and 02 instead of 90 and 91. But it's the
> general issue I'm concerned about--how to avoid Xy-NB conflicts
> if they use S/Gs in the 80s and 90s.
I'm not a regular NB user, but, in my limited experience with it, I
haven't encountered Save/Get conflicts with U2. But I load my
XyWrite KBD file, which eliminates all calls to the AUX program
files, so I'm not a good test case. And you're right, S/G usage in
the AUX files is all over the lot.
If you don't have the time or inclination to pinpoint the actual
conflicts and fix them one by one (and heaven knows I don't), then
you could take a blunderbuss approach and HIDE *all* transient S/Gs
(01-99) within your frame $H. I emphasize "all" because you want to
protect not only the S/Gs used by $H itself, but also the S/Gs used
in any frame *called* by $H -- which could be any frame at all,
because, of course, the raison d'etre of $H is to launch frames. For
these reason, you can't pick and choose S/Gs; you've got to HIDE,
then UNHIDE, them all.
If you go this route, you need to make two changes to your frame $H:
(1) Make "JM 2.HIDE:01-99Q2 " the very first statement in the frame;
and
(2) Restructure $H so that it has a single EXit point:
JM 2.UNHIDEQ2
Substitute for all the other commands in the frame.
HIDEing 01-99 should knock out 99.9% of S/G conflicts with U2 frames
(assuming, of course, that you launch U2 frames exclusively with
$H). (A conspicuous instance where this method will NOT work is when
a frame called by $H ends with , so that the flow of execution
doesn't circle back to the UNHIDE statement in $H. That's life.) The
downside to the blunderbuss is that PMs will launch and execute more
slowly (though with a fast processor you may not notice). More
important, you may encounter out-of-memory anomalies. But maybe not.
You can only try.
--
Carl Distefano
cld@xxxxxxxx
Harry Binswanger
hb@xxxxxxxx