Mover Fix
Volume Number: | | 4
|
Issue Number: | | 12
|
Column Tag: | | ßasic School
|
QuickBasic's Statement Mover Fix 
By Dave Kelly, Editorial Board
Statement Mover Fix
During the past month, Ive been looking at the demo programs included with MS QuickBASIC 1.0. The programs exercise most of (but certainly not all) the syntax of QuickBASIC. Also utility programs are provided which can be used to help your development are:
AlertMover For copying Alert/Dialog resources
Cursor Editor For defining your own cursors
Demo Resources containing Alert resources
extra MBLC Remover removes unnecessary library resources from your application programs.
Pattern Editor For defining your own patterns
Print Listing File Print listings created at compile time.
renumber CODEs avoids code id conflicts
SortSub moves sub programs to the end of a Basic source code file
Statement Mover moves resources especially Library resources.
Missing from this list is a variable cross reference program and a program to compare the differences between two text files. Comparing differences between files is somewhat complex when programs dont have line numbers to compare with.
The new version of Statement Mover is much improved over the version included with MS BASIC 3.0 and the CLR Libraries. You can now copy most any kind of resource that has a resource name attached. But, dont open up an open resource file or you get a bomb! That means you cant open the System File or the Statement Mover application. I havent worked on a fix for that one yet, but I have made a minor improvement to Statement Mover which uses a dialog resource.
The routine I have written replaces the NewTypeDialog subprogram in Statement Mover. First the programs volume reference number is retrieved and the dialog is displayed. Then a loop is set up to retrieve changes in the modal dialog. When a radio button is pressed the routine responds to it and updates the other buttons. The buttons represent a set of resource types which might be moved from one program or file to another. The edit field is updated with the resource type so that it will be passed when the routine is exited.

The dialog resource may be created with ResEdit or any other program that allows you to create dialogs. I used ProtoTyper to create the dialog so that I could try it out before I copied it into my QuickBASIC program. Because I had so many buttons in my dialog I used ResEdit to adjust the order of the buttons so that the OK button would be the first one (ProtoTyper sets them up in the order that they were drawn and you cant change the order without starting over).
Another thing that this dialog resource shows is a way to create the bold default buttons. Normally in Pascal or C you can draw the bold with the FrameRoundRect statement after defining the dialog item as a user item. A method that works is to define a PICT resource that looks like the bold roundrect and position it around the button which will be the default (usually the OK button). I believe that you can do it this way from other languages too, although Inside Macintosh vol. 1 says to use the user items.
{1}
NewTypeDialog Subprogram
Replaces NewTypeDialog in Statement Mover Program
Subprogram by Dave Kelly
Portions derived from Prototyper.
Use these lines to test the program
cancel%=0
NewType$=
CALL NewTypeDialog(NewType$,cancel%)
PRINT NewType$
END
SUB NewTypeDialog(NewType$,cancel%) STATIC
False=0:True=NOT False
ExitDialog =False Flag used TO EXIT the DIALOG
Selection&=0 : DialogPtr;NAME of DIALOG
index%=0 : FOR looping
EditString$= : GET Text entered, temp holding
itemHit%=0 : GET selection
Start of DIALOG handler
vref%=SYSTEM(7): Get programs volume reference number.
NewType$=
GetNewDialog vref%,10000,Selection& Bring in the DIALOG resource
ExitDialog=False Do NOT EXIT DIALOG Handle loop yet
itemHit%=0
WHILE ExitDialog=False Start of DIALOG Handle loop
ModalDialog Selection&, itemHit% : WAIT until an item IS
hit
SELECT CASE itemHit%
CASE 1 Handle the OK BUTTON being pressed
ExitDialog=True {EXIT the DIALOG when This selection
IS made}
cancel%=False
CASE 2 Handle the Cancel BUTTON being pressed
ExitDialog=True {EXIT the DIALOG when This selection
IS made}
SetDialogText Selection&,4,
cancel%=True
CASE 5 TO 27
FOR index%=5 TO 27 CLEAR ALL other radios
IF index%<>itemHit% THEN SetDialogBut Selection&,index%,1
NEXT index%
Setup the Dialog selections
SetDialogBut Selection&,itemHit%,2
IF itemHit%=5 THEN EditString$=ALRT
IF itemHit%=6 THEN EditString$=APPL
IF itemHit%=7 THEN EditString$=BNDL
IF itemHit%=8 THEN EditString$=CNTL
IF itemHit%=9 THEN EditString$=CURS
IF itemHit%=10 THEN EditString$=DITL
IF itemHit%=11 THEN EditString$=DLOG
IF itemHit%=12 THEN EditString$=DRVR
IF itemHit%=13 THEN EditString$=FOND
IF itemHit%=14 THEN EditString$=FONT
IF itemHit%=15 THEN EditString$=FREF
IF itemHit%=16 THEN EditString$=GNRL
IF itemHit%=17 THEN EditString$=ICN#
IF itemHit%=18 THEN EditString$=ICON
IF itemHit%=19 THEN EditString$=MBAR
IF itemHit%=20 THEN EditString$=MENU
IF itemHit%=21 THEN EditString$=PAT
IF itemHit%=22 THEN EditString$=PAT#
IF itemHit%=23 THEN EditString$=PICT
IF itemHit%=24 THEN EditString$=SIZE
IF itemHit%=25 THEN EditString$=STR#
IF itemHit%=26 THEN EditString$=STR
IF itemHit%=27 THEN EditString$=WIND
SetDialogText Selection&,4,EditString$
CASE ELSE
FOR index%=5 TO 27 CLEAR ALL radio buttons
SetDialogBut Selection&,index%,1
NEXT index%
END SELECT
WEND Handle DIALOG items until EXIT selected
GetDialogText Selection&,4,NewType$
DisposeDialog Selection& Flush the DIALOG out of memory
END SUB END of unit
The following Dialog resource file should either be created with Compiled with a resource compiler or recreated with ResEdit or Prototyper.
{2}
resource PICT (600, purgeable)
{
49,
{-1, -1, 35, 70},
{17; 1; 160; 0; 130; 1; 0; 10; 255; 255; 255; 255; 0
; 35; 0; 70; 7; 0; 3; 0; 3; 11; 0; 21; 0
; 21; 64; 0; 1; 0; 1; 0; 35; 0; 70; 160; 0
; 131; 255}
};
resource DITL (10000 , NewTypeDialog)
{
{
{130, 146, 156, 207},
Button {enabled, OK};
{130, 26, 155, 88},
Button {enabled, Cancel};
{120, 246, 136, 297},
StaticText {enabled, Other:};
{120, 306, 136, 357},
EditText {enabled, };
{20, 26, 42, 90},
RadioButton {enabled, ALRT};
{40, 26, 60, 81},
RadioButton {enabled, APPL};
{60, 26, 82, 90},
RadioButton {enabled, BNDL};
{80, 26, 102, 90},
RadioButton {enabled, CNTL};
{100, 26, 120, 81},
RadioButton {enabled, CURS};
{20, 96, 42, 160},
RadioButton {enabled, DITL};
{40, 96, 62, 160},
RadioButton {enabled, DLOG};
{60, 96, 82, 160},
RadioButton {enabled, DRVR};
{80, 96, 102, 160},
RadioButton {enabled, FOND};
{100, 96, 122, 160},
RadioButton {enabled, FONT};
{20, 166, 40, 221},
RadioButton {enabled, FREF};
{40, 166, 62, 230},
RadioButton {enabled, GNRL};
{60, 166, 80, 221},
RadioButton {enabled, ICN#};
{80, 166, 100, 221},
RadioButton {enabled, ICON};
{100, 166, 120, 221},
RadioButton {enabled, MBAR};
{20, 236, 40, 296},
RadioButton {enabled, MENU};
{40, 236, 62, 300},
RadioButton {enabled, PAT };
{60, 236, 80, 291},
RadioButton {enabled, PAT#};
{80, 236, 102, 300},
RadioButton {enabled, PICT};
{100, 236, 120, 291},
RadioButton {enabled, SIZE};
{20, 306, 40, 361},
RadioButton {enabled, STR#};
{40, 306, 62, 370},
RadioButton {enabled, STR };
{60, 306, 80, 361},
RadioButton {enabled, WIND};
{123, 139, 161, 212},
Picture {enabled, 600}
}
};
resource DLOG (10000 , NewTypeDialog)
{
{50, 120, 223, 504},
1,
invisible,
noGoAway,
0x1,
10000,
NewTypeDialog
};
I came across a bug in the AlertMover program which I include a fix here. The problem was that AlertMover would not save to an existing file. There are some fundamental problems with some of the sample programs on the QuickBASIC examples disk which are related to finding the filename of the application program. Microsoft added the SYSTEM(7) function after the manual was printed and so was probably not known or available at the time the demo programs were written. Changes could be made to the other programs in a similar manner. Here is the fix:
WAS:
AlertMover
© Sharon Zardetto Aker
© 1988 by Microsoft Corp.
Modified from Sharon Zardetto Akers original to take
advantage of new QB features.
------------------------------------------------------------
CLEAR,100000&
OPTION BASE 1
SH=SYSTEM(6) Get screen height
SW=SYSTEM(5) Get screen width
IS:
AlertMover
© Sharon Zardetto Aker
© 1988 by Microsoft Corp.
Modified from Sharon Zardetto Akers original to take
advantage of new QB features.
Modified again so that it would create new files properly
by Dave Kelly 9/17/88
------------------------------------------------------------
CLEAR,100000&
OPTION BASE 1
DIM SHARED IOPB%(60),fil$ :used by new subprogram ***************
SH=SYSTEM(6) Get screen height
SW=SYSTEM(5) Get screen width
WAS:
IF SYSTEM(4) THEN If compiled...
openResFile Demo Resources,ref%
ELSE if interpreted, get File reference number of this source
ref%=PEEKW(&HA5A)
END IF
ON BREAK GOSUB quit :BREAK ON
MENU 1,0,1,File
IS:
IF SYSTEM(4) THEN If compiled...
PgmPath$=
ref%= SYSTEM(7)
GetPathName ref%, PgmName$
parse PgmName$,path$ separate file name from the path
OpenResFile PgmName$,ref%
ELSE if interpreted, get File reference number of this source
ref%=PEEKW(&HA5A)
END IF
ON BREAK GOSUB quit :BREAK ON
MENU 1,0,1,File
Then add the following subprograms to the end: (These routines were taken from the GetPathNames demo program which is included with MS QuickBASIC version 1.0). This is a great way to find the pathnames of files you are using.
----------------------------------------------------------------
Gets the full path name of a file given the file reference
number of file. The file reference may be obtained from
OpenResfile, SYSTEM(7), GetChanRefNum, or various low
memory locations.
SUB GetPathName(ref%,path$) STATIC
fil$= : Folder$=
GetFCBInfo IOPB%(0),fil$,ref%
path$=fil$
DirID&=IOPB%(29)*65536&+IOPB%(30)
VRefNum%=IOPB%(26)
WHILE DirID&<>1
GetCatInfo IOPB%(0),Folder$,DirID&,VRefNum%
path$=Folder$+:+path$
DirID&=IOPB%(50)*65536&+IOPB%(51)
WEND
END SUB
----------------------------------------------------------------
SUB parse(filename$,path$) STATIC
index%=1
WHILE index% <>0
last%=index%
index%=INSTR(index%+1,filename$,:)
WEND
IF last%=1 THEN there was no path
path$=
ELSE divide filenamein$ into path$ and filename$
path$=LEFT$(filename$,last%)
filename$=RIGHT$(filename$,LEN(filename$)-last%)
END IF
END SUB