|
> From: Simon Coulter > > P bestProcDesign B > D PI 5I 0 > D ptrArray S * STATIC DIM(100) > D i S 5I 0 STATIC INZ(0) > C EVAL i = i + 1 > C ALLOC 100 ptr(i) > C RETURN i > P E > > bestProcDesign is the best of these designs because it exposes no > information about the internal design. It returns only a handle (in the > true sense) which can be used by subsequent functions. This approach > generally requires a series of support methods to accept the handle and do > something with it. For instance: > aHandle getXxxHandle() > rlsXxxHandle( aHandle ) > doStuff( aHandle, p1, p2, ... ) Precisely correct. This is in fact exactly what we did at SSA when we created the Assistant products, which were written entirely in C for OS/2. The only difference is that we used a void pointer for our handle. While the calling program could not (easily) use the pointer for anything, during debugging it made our lives a little easier than having to use the handle as an index into an array of pointers (especially if the array's address was not immediately available). We actually used a DWORD at the beginning of every structure which was initialized to a three-character constant followed by a X'00', so that when you viewed the "contents" of a properly initialized handle, you would see the appropriate three-character string. This allowed us to quickly verify that a handle held the right kind of object. A mismatch was a very primitive form of manual class cast exception. Joe
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.