[AccessD] Imitating a STACK

Jim Lawrence accessd at shaw.ca
Wed Jun 24 15:31:23 CDT 2009


Hi Max:

What you have represented there is a solution to situation that could not be
handled any other way... Something like the use of a GOTO statement for
handling errors, in an Access function. 

As long as each Push is matched with a Pop no problem and the method is kept
clean and simple.

On the other hand if anything goes wrong and for some reason processes, like
a programmer makes a coding error (not something that we would ever have to
worry about), there can be some serious repercussions.

If you ever remember or run across that tool location or link, I would be
very interested.
 
Jim 


-----Original Message-----
From: accessd-bounces at databaseadvisors.com
[mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Max Wanadoo
Sent: Wednesday, June 24, 2009 12:37 PM
To: 'Access Developers discussion and problem solving'
Subject: Re: [AccessD] Imitating a STACK

Jim,
This is what I was trying to get at when I responded to Arthur's question re
CallByForm, which wasn't what I was after.

What I have to do to simulate the STACK is to provide a means to record that
every time I enter a function/sub it is recorded and every time I leave the
function/sub it is recorded.

You can only reliably PUSH the STACK and POP the STACK if you have ONE ENTRY
point and ONE EXIT point.

When an error occurs and you are using a error handling routine in a
module/class then it is easy to look at the STACK to identify how you
progressed through the program to the point of the errors. All
functions/subs you encountered on the way are available to you.

I use a Global Boolean variable called gvRecordProgress.  On each
Function/Sub I have a line which says:

Private function myfunctionname
On error goto pfMyGlobalErrorHandler
If gbRecordProgress = true the call pfPushStack("Push","myfunctionname")

Code
Code

Onexit:
If gbRecordProgress = true the call pfRecordStack("Pop","myfunctionname")
Code
Exit function

End function

Now, before you all go screaming at me, the above is taken from memory and I
do not have access to Access (!) but you will get the general concept.  The
names have been plucked out of the air.  This is just so that I can
illustrate what I mean.

You can switch it on/off by just changing the value of gbRecordProgress.

This is also a useful way to see which functions/sub are used the most - ie,
where tightening up of code would result in a big improvement overall.

NOW: To get the two lines in, if you have that little toolset (mxtools or
something like that) you can tell it to do the above for you and whilst it
is doing it, it can actually insert the function/sub name into the line, so
it only takes seconds  Apologies for not remembering the name of the tool,
but you all know it because you have mentioned it here many times.



Max
Ps. Changed subject.



-----Original Message-----
From: accessd-bounces at databaseadvisors.com
[mailto:accessd-bounces at databaseadvisors.com] On Behalf Of Jim Lawrence
Sent: 24 June 2009 20:11
To: 'Access Developers discussion and problem solving'
Subject: Re: [AccessD] Learning .Net -- PHP Instead?

Hi guys:

In the old days, some 30 years back I did a lot of assembler coding and
discovered a very neat technique for returning from a chunk of code back to
anywhere in application. You would just push the address of where you wanted
to return to, on the stack. That was great, as the stack pointer did not
have to be set to return to the caller module. I would first set the return
address to the error handler to trap any errors, in the called module and
then if code completed successfully, the stack pointer was set then set to
any position in the program you wanted to jump to, and then a return byte
was processed.

The assembler, I was using was designed to auto adjust all the changes in
module position. Of course there was no internal documentation (no memory)
other than a ref number to a code book.

This little trick sure saved a lot of code and made the modules very
flexible... 

The down side was if you ever lost the code printout and needed to make some
changes, with all its documentation, you were screwed. I ended up being
raked over the coals after someone lost my documentation manual. It took 3
people, 2 weeks to rebuild the code.

At that point, I learned my lesson about the proper methods of using RETURNS
and explicit GOTOs.

Jim      


-- 
AccessD mailing list
AccessD at databaseadvisors.com
http://databaseadvisors.com/mailman/listinfo/accessd
Website: http://www.databaseadvisors.com




More information about the AccessD mailing list