Home » Archimedes archive » Acorn User » AU 1997-06 B.adf » Regulars » RTR/!freq/RunFreq

RTR/!freq/RunFreq

This website contains an archive of files for the Acorn Electron, BBC Micro, Acorn Archimedes, Commodore 16 and Commodore 64 computers, which Dominic Ford has rescued from his private collection of floppy disks and cassettes.

Some of these files were originally commercial releases in the 1980s and 1990s, but they are now widely available online. I assume that copyright over them is no longer being asserted. If you own the copyright and would like files to be removed, please contact me.

Tape/disk: Home » Archimedes archive » Acorn User » AU 1997-06 B.adf » Regulars
Filename: RTR/!freq/RunFreq
Read OK:
File size: 3496 bytes
Load address: 0000
Exec address: 0000
File contents
   10REM>Develop.FreqResp.!Freq.RunFereq
   20REM Frequency Response of an audio circuit
   30REM Version 1.0 By Mike Cook
   40REM All rights reserved 1997
   50ON ERROR PROCerrorbox
   60
   70DIM taskid%4:$taskid%="TASK"
   80DIM intmess% 20
   90intmess%!0=1:intmess%!4=2:intmess%!8=3:intmess%!12=&502:intmess%!16=0
  100SYS "Wimp_Initialise",300,!taskid%,"FreqResp",intmess% TO version%,taskhand%
  110DIM q% &300,qc% 80, Wn% &300,temp% 256,buffers% 512,menu% 512,SW% 256,cb% 18
  120DIM IsName% 256, Wmenu% 512, TextWarn% 100, ww% 256, Tkey%(7), Cmenu% 256
  130DIM keymenu% 512,smenu% 512,Stab%(7,7)
  140DIM Res%(320),u% 256,sef$(4)
  150DIM WT% 511
  160DIM Code% 4096,PBK% 5,PBA% 4,PBD% 3,Gain%(5),Scale%(6)
  170NoI%=8
  180DIM SPoint%(NoI%),IX%(NoI%),IY%(NoI%),IX1%(NoI%),IY1%(NoI%)
  190SYS "Wimp_OpenTemplate",,"<Freq$Dir>.Templates"
  200ON ERROR SYS "Wimp_CloseTemplate":PROCerrorbox
  210SYS "Wimp_LoadTemplate",,q%,temp%,temp%+256,-1,"Info",0
  220SYS "Wimp_CreateWindow",,q% TO info%
  230SYS "Wimp_LoadTemplate",,Wn%+4,SW%,SW%+256,-1,"Pallette",0
  240Wn%!28=-1
  250FOR A%=0 TO NoI%
  260SPoint%(A%)=!(Wn%+4+88+20+32*A%)
  270IX%(A%)=!(Wn%+4+88+32*A%):IY%(A%)=!(Wn%+4+88+4+32*A%)
  280IX1%(A%)=!(Wn%+4+88+8+32*A%):IY1%(A%)=!(Wn%+4+88+12+32*A%)
  290NEXT
  300SYS "Wimp_CreateWindow",,Wn%+4 TO monW%
  310Wn%!0=monW%:Wn%!28=-1
  320
  330SYS "Wimp_LoadTemplate",,q%,ww%,ww%+256,-1,"Warning",0
  340q%!108=TextWarn%:q%!112=-1:q%!116=300
  350XQ%=q%!8-q%!0:YQ%=q%!12-q%!4
  360SYS "Wimp_CreateWindow",,q% TO warningW%
  370SYS "Wimp_CloseTemplate"
  380Log2=LN(2):ref%=0
  390cpL%=0:cpR%=0
  400smpicon%=FNicon
  410wopen%=FALSE:warnOn%=FALSE
  420InWin%=FALSE
  430GRID%=TRUE:Log%=TRUE
  440Block%=4:Vdelay%=1
  450ON ERROR PROCerrorbox
  460Button%=0:StartN%=0:EndN%=3
  470PROCsetupmenu
  480SYS"Sound_Configure",1,208,48,0,0 TO Nc%,Sl%,Sp%,Pc%,Ps%
  490SYS"Sound_Configure",Nc%,Sl%,Sp%,Pc%,Ps%
  500
  510PROCinit
  520
  530REPEAT
  540 SYS "Wimp_Poll",0,q% TO A%
  550  CASE A% OF
  560   WHEN 0:PROC_Null
  570   WHEN 1:PROC_doWindow
  580   WHEN 2:SYS"OS_ReadModeVariable",-1,3 TO ,,Ncolours%: SYS "Wimp_OpenWindow",,q%
  590   WHEN 3:PROC_close
  600   WHEN 4:InWin%=FALSE:LX%=-1:LY%=-1
  610   WHEN 5:InWin%=TRUE
  620   WHEN 6:PROC_do_click(q%)
  630   WHEN 7:
  640   WHEN 8:PROC_KeyPress
  650   WHEN 9:PROC_SORT_Menu
  660   WHEN 17,18:PROCreceive(q%)
  670   ENDCASE
  680 UNTIL FALSE
  690
  700END
  710
  720DEF PROC_Null
  730IF Button%<>0 THEN PROCrelease
  740ENDPROC
  750
  760DEF PROCrelease
  770LOCAL x%,y%,b%
  780MOUSE x%,y%,b%
  790IF b%=0 THEN
  800CASE Button% OF
  810WHEN 1 : $SPoint%(1)="frup":PROCrfi(Button%)
  820WHEN 2 : $SPoint%(2)="frdown":PROCrfi(Button%)
  830WHEN 3 : $SPoint%(3)="frup":PROCrfi(Button%)
  840WHEN 4 : $SPoint%(4)="frdown":PROCrfi(Button%)
  850ENDCASE
  860Button%=0
  870ENDIF
  880ENDPROC
  890
  900DEF FN_spath(n$)
  910WHILE INSTR(n$,".")
  920n$=RIGHT$(n$,LEN(n$)-1)
  930ENDWHILE
  940IF LEN(n$)>10 THEN n$=RIGHT$(n$,10)
  950=n$
  960
  970DEF PROC_SORT_Menu
  980LOCAL A%
  990IF !q%=4 THEN PROCdie
 1000IF !q%=2 THEN menu%!76=menu%!76 OR 1:menu%!52=menu%!52 AND &FE:Log%=TRUE
 1010
 1020IF !q%=1 THEN menu%!52=menu%!52 OR 1:menu%!76=menu%!76 AND &FE:Log%=FALSE
 1090
 1100IF !q%=3 THEN
 1110CASE q%!4 OF
 1120WHEN 0 :Block%=1
 1130WHEN 1 :Block%=2
 1140WHEN 2 :Block%=4
 1150WHEN 4 :Block%=8
 1160ENDCASE
 1161FOR A%=0 TO 4
 1162keymenu%?(28+24*A%)=keymenu%?(28+24*A%) AND &FE
 1163NEXT
 1164keymenu%?(28+24*q%!4)=keymenu%?(28+24*q%!4) OR 1
 1170ENDIF
 1180
 1190SYS"Wimp_GetPointerInfo",,q%
 1200IF q%!8=1 THEN SYS"Wimp_CreateMenu",,menu%,q%!0-94,q%!4
 1210ENDPROC
 1220
 1230DEF PROC_close
 1240IF q%!0=monW% THEN SYS"Wimp_GetWindowInfo",,Wn%:wopen%=FALSE
 1250IF q%!0=warningW% THEN warnOn%=FALSE
 1260SYS "Wimp_CloseWindow",,q%
 1270ENDPROC
 1280
 1290DEF PROC_do_click(q%)
 1300i%=q%!16
 1310CASE q%!12 OF
 1320WHEN warningW%: q%!0=warningW% :PROC_close
 1330
 1340WHEN -2: REM Look first at Icon Bar Click
 1350        IF q%!16=smpicon% THEN
 1360        IF q%!8=2 THEN IconMenu%=TRUE: SYS"Wimp_CreateMenu",,menu%,q%!0-94,300
 1370        IF q%!8=4 THEN PROC_Open
 1380        ENDIF
 1390
 1400WHEN monW%:  
 1410              IF q%!8=4 THEN PROC_MonClick
 1420              IF q%!8=2 THEN SYS"Wimp_CreateMenu",,menu%,q%!0-94,q%!4
 1430ENDCASE
 1440ENDPROC
 1450
 1460
 1470DEF PROC_MonClick
 1480LOCAL X%,Y%,D%,V%,B%
 1490REM Do the action for a window click
 1500PROC_Trans(monW%)
 1510SYS"Wimp_GetPointerInfo",,q%
 1520X%=q%!0-xo%
 1530Y%=q%!4-yo%
 1540CASE i% OF
 1550WHEN 0 : PROC_Scan
 1560WHEN 1 : $SPoint%(1)="frpup":PROCrfi(i%)
 1570         IF StartN%+1<>EndN% THEN StartN%+=1:$SPoint%(7)=sef$(StartN%):SYS"Wimp_ForceRedraw",monW%,IX%(7),IY%(7),IX1%(7),IY1%(7)
 1580WHEN 2 : $SPoint%(2)="frpdown":PROCrfi(i%)
 1590         IF StartN%-1<>-1 THEN StartN%-=1:$SPoint%(7)=sef$(StartN%):SYS"Wimp_ForceRedraw",monW%,IX%(7),IY%(7),IX1%(7),IY1%(7)
 1600WHEN 3 : $SPoint%(3)="frpup":PROCrfi(i%)
 1610         IF EndN%+1<>4 THEN EndN%+=1:$SPoint%(8)=sef$(EndN%):SYS"Wimp_ForceRedraw",monW%,IX%(8),IY%(8),IX1%(8),IY1%(8)
 1620WHEN 4 : $SPoint%(4)="frpdown":PROCrfi(i%)
 1630         IF EndN%-1<>StartN% THEN EndN%-=1:$SPoint%(8)=sef$(EndN%):SYS"Wimp_ForceRedraw",monW%,IX%(8),IY%(8),IX1%(8),IY1%(8)
 1640ENDCASE
 1650ENDPROC
 1660
 1670DEF PROCrfi(i%)
 1680SYS"Wimp_ForceRedraw",monW%,IX%(i%),IY%(i%),IX1%(i%),IY1%(i%)
 1690Button%=i%
 1700ENDPROC
 1710
 1720DEF PROC_Open
 1730SYS"OS_ReadModeVariable",-1,3 TO ,,Ncolours%
 1740REM OPEN UP WINDOW HERE
 1750IF wopen% THEN
 1760q%!0=monW%
 1770SYS"Wimp_GetWindowState",,q%
 1780  IF q%!28<>-1 THEN q%!28=-1: SYS "Wimp_OpenWindow",,q%
 1790ELSE
 1800SYS "Wimp_OpenWindow",,Wn%
 1810wopen%=TRUE
 1820ENDIF
 1830ENDPROC
 1840
 1850DEF PROC_doWindow
 1860  LOCAL A%,I%,L%
 1870
 1880   PROC_Trans(monW%)
 1890   SYS "Wimp_RedrawWindow",,q% TO flag%
 1900     WHILE flag%
 1910
 1920     PROCdrawframe
 1930     PROCplotRes
 1940     SYS "Wimp_GetRectangle",,q% TO flag%
 1950     ENDWHILE
 1960  
 1970  ENDPROC
 1980  
 1990
 2000DEF PROCdrawframe
 2010LOCAL W%,L%,A%,H%,Os%,G%,D%,L2
 2020L%=640:W%=10:A%=64:Os%=50:H%=340
 2030SYS"Wimp_SetColour",1
 2040RECTANGLEFILL xo%+Os%,yo%+A%,L%,H%
 2050
 2060SYS"Wimp_SetColour",7
 2070RECTANGLEFILL xo%+Os%,yo%+A%,L%,W%
 2080RECTANGLEFILL xo%+Os%,yo%+A%-W%+H%,L%,W%
 2090RECTANGLEFILL xo%+Os%,yo%+A%,W%,H%
 2100RECTANGLEFILL xo%+Os%+L%,yo%+A%,W%,H%
 2110IF GRID% THEN
 2120FOR B%=0 TO 7
 2130LINE xo%+Os%,yo%+A%+14+306-B%*42.5,xo%+Os%+L%,yo%+A%+14+306-B%*42.5
 2140NEXT
 2150L2=L%/(EndN%-StartN%)
 2160FOR D%=0 TO EndN%-StartN%-1
 2170FOR B%=1 TO 9
 2180G%=LOG(B%)*L2+L2*D%
 2190LINE xo%+12+Os%+G%,yo%+A%,xo%+12+Os%+G%,yo%+A%+H%
 2200NEXT
 2210NEXT
 2220ENDIF
 2230ENDPROC
 2240
 2250DEF PROCplotRes
 2260LOCAL A%,B%,Os%,Y%
 2270SYS"Wimp_SetColour",10
 2280A%=76:Os%=62
 2290IF Block%=1 THEN
 2300Y%=Res%(0)
 2310MOVE xo%+Os%+B%,yo%+Y%+A%
 2320FOR B%=1 TO 313
 2330Y%=Res%(B%)
 2340DRAW xo%+Os%+B%*2,yo%+Y%+A%
 2350NEXT
 2360ELSE
 2370 FOR B%=1 TO 312 STEP Block%
 2380 IF Res%(B%)<>0 THEN RECTANGLEFILL xo%+62+B%*2,yo%+Res%(B%)+76,Block%*2,Block%*2
 2390 NEXT
 2400ENDIF
 2410ENDPROC
 2420
 2430DEF PROC_Trans(wh%)
 2440!q%=wh%
 2450SYS "Wimp_GetWindowState",,q%
 2460xo%=q%!4-q%!20:yo%=q%!16-q%!24-440
 2470XO%=q%!4:YO%=q%!16
 2480ENDPROC
 2490
 2500DEFPROCsetupmenu
 2510LOCAL m%
 2520
 2530$keymenu%="Key"
 2540keymenu%?12=7
 2550keymenu%?13=2
 2560keymenu%?14=7
 2570keymenu%?15=0
 2580keymenu%!16=128
 2590keymenu%!20=40
 2600keymenu%!24=0
 2610m%=keymenu%+28
 2620
 2630m%!0=0
 2640m%!4=0
 2650m%!8=(7<<24)OR %10001
 2660$(m%+12)="Best"
 2670
 2680m%+=24
 2690m%!0=0
 2700m%!4=0
 2710m%!8=(7<<24)OR %10001
 2720$(m%+12)="Fine"
 2730m%+=24
 2740m%!0=1
 2750m%!4=0
 2760m%!8=(7<<24)OR %10001
 2770$(m%+12)="Medium"
 2780m%+=24
 2790m%!0=0
 2800m%!4=0
 2810m%!8=(7<<24)OR %10001
 2820$(m%+12)="Corse"
 2830m%+=24
 2840m%!0=&80
 2850m%!4=0
 2860m%!8=(7<<24)OR %10001
 2870$(m%+12)="Quick"
 2880
 2890
 2900$menu%="Sound"
 2910menu%?12=7
 2920menu%?13=2
 2930menu%?14=7
 2940menu%?15=0
 2950menu%!16=128
 2960menu%!20=40
 2970menu%!24=0
 2980m%=menu%+28
 2990m%!0=0
 3000m%!4=info%
 3010m%!8=(7<<24)OR %10001
 3020$(m%+12)="Info"
 3030
 3040m%+=24
 3050m%!0=0
 3060m%!4=0
 3070m%!8=(7<<24)OR %10001
 3080$(m%+12)="Liner"
 3090
 3100m%+=24
 3110m%!0=1
 3120m%!4=0
 3130m%!8=(7<<24)OR %10001
 3140$(m%+12)="Log"
 3150
 3160m%+=24
 3170m%!0=0
 3180m%!4=keymenu%
 3190m%!8=(7<<24)OR %10001
 3200$(m%+12)="Resoloution"
 3220
 3230m%+=24
 3240m%!0=&80
 3250m%!4=0
 3260m%!8=(7<<24)OR %10001
 3270$(m%+12)="Quit"
 3280
 3290ENDPROC
 3300
 3310DEF PROCreceive(q%)
 3320LOCAL A%
 3330A%=q%!16
 3340CASE A% OF
 3350WHEN 0:PROCdie
 3360WHEN &502:   CASE TRUE OF
 3370             WHEN q%!32=-2 AND q%!36=smpicon%:mes$="This is the Frequncy Responce icon.|MPlot the frequncy responce of a circuit."
 3380             OTHERWISE:mes$=""
 3390             ENDCASE
 3400    IF mes$<>"" THEN
 3410    q%!12=q%!8
 3420    $(q%+20)=mes$+CHR$0
 3430    q%!0=(20+LENmes$+4)AND NOT 3
 3440    q%!16=&503
 3450    SYS "Wimp_SendMessage",18,q%,q%!4
 3460ENDCASE
 3470ENDPROC
 3480
 3490DEF PROC_Dack
 3500sendth%=q%!4
 3510myref%=q%!8
 3520SYS "Wimp_GetPointerInfo",,q%+8
 3530q%!28=q%!8
 3540q%!32=q%!12
 3550q%!0=(44+LENn$+4)AND NOT 3
 3560q%!12=myref%
 3570q%!16=4
 3580q%!36=-1
 3590q%!40=&FF9
 3600$(q%+44)=n$+CHR$0
 3610SYS "Wimp_SendMessage",17,q%,sendth%
 3620ENDIF
 3630ENDPROC
 3640
 3650DEFFNsget(x%)
 3660LOCAL x$
 3670WHILE ?x% x$+=CHR$(?x%):x%+=1:ENDWHILE
 3680=x$
 3690
 3700DEFFNicon
 3710q%!0=-1
 3720q%!4=0
 3730q%!8=0 : REM Y DIRECTION
 3740q%!12=70 : REM X DIRECTION
 3750q%!16=96
 3760q%!20=&2002
 3770$(q%+24)="!Freq"
 3780SYS "Wimp_CreateIcon",,q% TO icon%
 3790=icon%
 3800
 3810DEF PROC_setupW(t$)
 3820!q%=warningW%:q%!4=200:q%!8=200:q%!12=200+XQ%:q%!16=200+YQ%:q%!20=0:q%!24=0:q%!28=-1
 3830$TextWarn%=t$
 3840TextWarn%?LEN(t$)=0
 3850VDU 7
 3860warnOn%=TRUE
 3870SYS "Wimp_OpenWindow",,q%
 3880ENDPROC
 3890
 3900DEF PROCerrorbox
 3910SYS "Wimp_DragBox",,-1
 3920!buffers%=ERR:$(buffers%+4)=REPORT$+" at line "+STR$ERL+CHR$0
 3930SYS "Wimp_ReportError",buffers%,1,"Frequncy Responce"
 3940PROCdie
 3950ENDPROC
 3960
 3970DEFPROCdie
 3980ON ERROR OFF
 3990SYS "Wimp_CloseDown",taskhand%,!taskid%
 4000END
 4010ENDPROC
 4020
 4030DEF PROCgetw(handle%)
 4040!q%=handle%:SYS "Wimp_GetWindowState",,q%:PROCinfo(q%+4)
 4050ENDPROC
 4060DEF PROCgeti(h%,i%)
 4070!q%=h%:q%!4=i%:SYS "Wimp_GetIconState",,q%
 4080ix0%=q%!8:iy0%=q%!12:ix1%=q%!16:iy1%=q%!20
 4090iflags%=q%!24:idata%=q%+28
 4100ENDPROC
 4110
 4120DEF PROCinfo(p%)
 4130LOCAL x0%,y0%
 4140x0%=!p%:y0%=p%!4:x1%=p%!8:y1%=p%!12
 4150scx%=p%!16:scy%=p%!20:bhandle%=p%!24:flags%=p%!28
 4160bx%=x0%-scx%:by%=y1%-scy%
 4170ENDPROC
 4180
 4190DEF PROC_KeyPress
 4200CASE q%!0 OF
 4210REM OTHERWISE: SYS"Wimp_ProcessKey",q%!24
 4220ENDCASE
 4230ENDPROC
 4240
 4250DEF PROCinit
 4260*Audio ON
 4270SYS"Sound_Volume",127 TO UserVol
 4280FOR s%=0 TO 255
 4290 SYS"Sound_SoundLog",&7FFFFFFF*SIN(2*PI*s%/256) TO WT%?s%
 4300NEXT
 4310FOR s%=256 TO 511
 4320 SYS"Sound_SoundLog",&7FFFFFFF*SIN(2*PI*s%/64) TO WT%?s%
 4330NEXT
 4340
 4350REM SYS"Sound_Volume",UserVol TO UserVol
 4360
 4370FOR C% = 0 TO 2 STEP 2
 4380P%=Code%
 4390[ OPT C%
 4400.VoiceBase
 4410B       Fill
 4420B       Fill
 4430B       GateOn
 4440B       GateOff
 4450B       Instance
 4460LDMFD   R13!,{PC}
 4470LDMFD   R13!,{PC}
 4480EQUD    VoiceName - VoiceBase
 4490.VoiceName      EQUS "SinMax"
 4500                EQUB 0
 4510ALIGN
 4520.LogAmpPtr      EQUD 0
 4530.WaveBase       EQUD WT%
 4540
 4550.Instance
 4560STMFD   R13!,{R0-R4}
 4570MOV     R0,#0
 4580MOV     R1,#0
 4590MOV     R2,#0
 4600MOV     R3,#0
 4610MOV     R4,#0
 4620SWI     "XSound_Configure"
 4630LDRVC   R0,[R3,#12]
 4640STRVC   R0,LogAmpPtr
 4650STRVS   R0,[R13]
 4660LDMFD   R13!,{R0-R4,PC}
 4670
 4680.GateOn
 4690LDR     R0,WaveBase
 4700STR     R0,[R9,#16]
 4710LDR     R0,LogAmpPtr
 4720STR     R0,[R9,#20]
 4730
 4740.Fill
 4750LDMIA   R9,{R1-R6}
 4760AND     R1,R1,#&7F
 4770LDRB    R1,[R6,R1,LSL #1]
 4780MOV     R1,R1,LSR #1
 4790RSB     R1,R1,#127
 4800.FillLoop
 4810ADD R2,R2,R2,LSL #16
 4820LDRB    R0,[R5,R2,LSR #24]
 4830STRB    R0,[R12],R11
 4840
 4850ADD R2,R2,R2,LSL #16
 4860LDRB    R0,[R5,R2,LSR #24]
 4870STRB    R0,[R12],R11
 4880
 4890ADD R2,R2,R2,LSL #16
 4900LDRB    R0,[R5,R2,LSR #24]
 4910STRB    R0,[R12],R11
 4920
 4930ADD R2,R2,R2,LSL #16
 4940LDRB    R0,[R5,R2,LSR #24]
 4950STRB    R0,[R12],R11
 4960
 4970CMP     R12,R10
 4980BLT     FillLoop
 4990
 5000SUBS    R4,R4,#1
 5010STMIB   R9,{R2-R5}
 5020MOVPL   R0,#%00001000
 5030MOVMI   R0,#%00000010
 5040LDMFD   R13!,{PC}
 5050
 5060.GateOff
 5070MOV     R0,#0
 5080.FlushLoop
 5090STRB    R0,[R12],R11
 5100STRB    R0,[R12],R11
 5110STRB    R0,[R12],R11
 5120STRB    R0,[R12],R11
 5130CMP     R12,R10
 5140BLT     FlushLoop
 5150MOV     R0,#%00000001
 5160LDMFD   R13!,{PC}
 5170]
 5180NEXT
 5190
 5200DIM OldVoice%(8)
 5210
 5220FOR A%=0 TO 3
 5230READ sef$(A%)
 5240NEXT
 5250DATA 10 Hz,100 Hz,1 KHz,10 KHz
 5260Scale%(0)=16 : REM X factor for gain of 1
 5270Scale%(1)=8 : REM X factor for gain of 2
 5280Scale%(2)=4 : REM X factor for gain of 4
 5290Scale%(3)=2 : REM X factor for gain of 8
 5300Scale%(4)=1 : REM X factor for gain of 16
 5310Offset%=25 : REM The measured DC offset
 5320REM Set up the control register
 5330REM read only Channel 0
 5340?PBA%=0
 5350SYS "XIIC_Control",&90,PBA%,1 TO ;Fl
 5360IF (Fl AND 1) =1 THEN PROC_setupW("No IIC device found"):Device%=FALSE ELSE Device%=TRUE
 5370ENDPROC
 5380
 5390DEF PROC_Scan
 5400LOCAL A%,Dec%,ST%,F
 5410REM First store the current sound setup
 5420SYS "Sound_InstallVoice",VoiceBase,0 TO a%,Voice%
 5430FOR v%=1 TO 1
 5440SYS"Sound_AttachVoice",v%,0 TO z%,OldVoice%(v%)
 5450VOICE v%,"SinMax"
 5460NEXT
 5470VOICES 1
 5480
 5490REM Now draw grid
 5500ST%=314
 5510Dec%=EndN%-StartN%
 5520PROC_Trans(monW%)
 5530u%!0=monW%:u%!4=0:u%!8=-440:u%!12=740:u%!16=0
 5540  SYS"Wimp_UpdateWindow",,u% TO More%
 5550 WHILE More%
 5560  PROCdrawframe
 5570  SYS"Wimp_GetRectangle",,u% TO More%
 5580 ENDWHILE
 5590 
 5600Res%()=0
 5610FOR A%=1 TO ST% STEP Block%
 5620F=10^((A%*Dec%)/ST%)*10^(StartN%+1)
 5630PROCtone(F)
 5640IF Tone% THEN
 5650Res%(A%)=FNres:PROC_UpP(A%)
 5660ELSE
 5670Res%(A%)=0
 5680ENDIF
 5690NEXT
 5700PROCdel
 5710
 5720SYS "Sound_RemoveVoice",0,Voice%
 5730FOR v%=1 TO 1
 5740 SYS"Sound_AttachVoice",v%,OldVoice%(v%)
 5750NEXT
 5760
 5770ENDPROC
 5780
 5790DEFFNres
 5800LOCAL G%,Read,Val
 5810G%=0
 5811IF Device%=FALSE THEN =306
 5820 REPEAT
 5830PBD%?0=&80 OR G%
 5840PBD%?1=G%
 5850 
 5860REM Discharge Capacitor
 5870SYS "XIIC_Control",&70,PBD%,1
 5880REM Remove the short
 5890SYS "XIIC_Control",&70,PBD%+1,1
 5900PROCdel2
 5910REPEAT
 5920REM Read the A/D
 5930SYS "XIIC_Control",&91,PBK%,3
 5940UNTIL ABS(PBK%?1-PBK%?2)<4
 5950Read=(PBK%?1+PBK%?2)/2
 5960G%+=1
 5970UNTIL Read>&80 OR G%=5
 5980G%-=1
 5990Val=(Read-Offset%) * Scale%(G%)
 6000IF Val<1 THEN Val=1
 6001IF Log% THEN
 6010Val=(10.2*(30+20*(LOG(Val/4080))))
 6011ELSE
 6012Val=(Val*306)/4080
 6013ENDIF
 6020IF Val<0 THEN Val=0
 6030=Val
 6040
 6050DEF PROCdel2
 6060LOCAL T%
 6070T%=TIME+Vdelay%
 6080REPEAT UNTIL TIME>T%
 6090ENDPROC
 6100
 6110DEF PROC_UpP(A%)
 6120LOCAL T%,Y%,More%
 6130T%=Res%(A%-1)
 6140Y%=Res%(A%)
 6150PROC_Trans(monW%)
 6160u%!0=monW%:u%!4=60:u%!8=-366:u%!12=740:u%!16=0
 6170  SYS"Wimp_UpdateWindow",,u% TO More%
 6180 WHILE More%
 6190SYS"Wimp_SetColour",10
 6200IF Block%=1 THEN
 6210   MOVE xo%+62+(A%-1)*2,yo%+T%+76
 6220   DRAW xo%+62+A%*2,yo%+Y%+76
 6230ELSE
 6240  RECTANGLEFILL xo%+62+A%*2,yo%+Y%+76,Block%*2,Block%*2
 6250ENDIF
 6260  SYS"Wimp_GetRectangle",,u% TO More%
 6270 ENDWHILE
 6280ENDPROC
 6290
 6300DEF PROCtone(F)
 6310LOCAL R,Oc,octive%,Fr%,S%,P%
 6320R=F/16.351875
 6330Oc=(LN(R)/Log2)
 6340octive%=INT(Oc)
 6350Fr%=(Oc-octive%)*4096
 6360S%=(Fr% OR (octive%<<12))
 6370IF octive%<9 AND S%> &100 THEN
 6380
 6390IF S%>&7FFF THEN P%=S%-&2000: !WaveBase=WT%+256 ELSE P%=S%:!WaveBase=WT%
 6400 SOUND 1,-15,P%,10
 6410 Tone%=TRUE
 6420 REM Vdelay%=10-(S%>>12)
 6430 IF S%>&2000 Vdelay%=1 ELSE Vdelay%=6
 6440 ELSE
 6450 Tone%=FALSE
 6460ENDIF
 6470
 6480PROCdel
 6490ENDPROC
 6500
 6510DEF PROCdel
 6520LOCAL T%
 6530T%=TIME + 20
 6540REPEAT UNTIL TIME>T%
 6550ENDPROC

%�>Develop.FreqResp.!Freq.RunFereq
,� Frequency Response of an audio circuit
� Version 1.0 By Mike Cook
(� All rights reserved 1997
2� � �errorbox
<
F� taskid%4:$taskid%="TASK"
P� intmess% 20
ZIintmess%!0=1:intmess%!4=2:intmess%!8=3:intmess%!12=&502:intmess%!16=0
dNș "Wimp_Initialise",300,!taskid%,"FreqResp",intmess% � version%,taskhand%
nN� q% &300,qc% 80, Wn% &300,temp% 256,buffers% 512,menu% 512,SW% 256,cb% 18
xK� IsName% 256, Wmenu% 512, TextWarn% 100, ww% 256, Tkey%(7), Cmenu% 256
�(� keymenu% 512,smenu% 512,Stab%(7,7)
�� Res%(320),u% 256,sef$(4)
�
� WT% 511
�8� Code% 4096,PBK% 5,PBA% 4,PBD% 3,Gain%(5),Scale%(6)
�
NoI%=8
�=� SPoint%(NoI%),IX%(NoI%),IY%(NoI%),IX1%(NoI%),IY1%(NoI%)
�2ș "Wimp_OpenTemplate",,"<Freq$Dir>.Templates"
�)� � ș "Wimp_CloseTemplate":�errorbox
�:ș "Wimp_LoadTemplate",,q%,temp%,temp%+256,-1,"Info",0
�&ș "Wimp_CreateWindow",,q% � info%
�=ș "Wimp_LoadTemplate",,Wn%+4,SW%,SW%+256,-1,"Pallette",0
�
Wn%!28=-1
�� A%=0 � NoI%
$SPoint%(A%)=!(Wn%+4+88+20+32*A%)
9IX%(A%)=!(Wn%+4+88+32*A%):IY%(A%)=!(Wn%+4+88+4+32*A%)
>IX1%(A%)=!(Wn%+4+88+8+32*A%):IY1%(A%)=!(Wn%+4+88+12+32*A%)
"�
,)ș "Wimp_CreateWindow",,Wn%+4 � monW%
6Wn%!0=monW%:Wn%!28=-1
@
J9ș "Wimp_LoadTemplate",,q%,ww%,ww%+256,-1,"Warning",0
T)q%!108=TextWarn%:q%!112=-1:q%!116=300
^ XQ%=q%!8-q%!0:YQ%=q%!12-q%!4
h*ș "Wimp_CreateWindow",,q% � warningW%
rș "Wimp_CloseTemplate"
|Log2=�(2):ref%=0
�cpL%=0:cpR%=0
�smpicon%=�icon
�wopen%=�:warnOn%=�
�InWin%=�
�GRID%=�:Log%=�
�Block%=4:Vdelay%=1
�� � �errorbox
�Button%=0:StartN%=0:EndN%=3
��setupmenu
�:ș"Sound_Configure",1,208,48,0,0 � Nc%,Sl%,Sp%,Pc%,Ps%
�+ș"Sound_Configure",Nc%,Sl%,Sp%,Pc%,Ps%
�
�	�init

�
 ș "Wimp_Poll",0,q% � A%
&
  Ȏ A% �
0   � 0:�_Null
:   � 1:�_doWindow
DO   � 2:ș"OS_ReadModeVariable",-1,3 � ,,Ncolours%: ș "Wimp_OpenWindow",,q%
N   � 3:�_close
X!   � 4:InWin%=�:LX%=-1:LY%=-1
b   � 5:InWin%=�
l   � 6:�_do_click(q%)
v   � 7:
�   � 8:�_KeyPress
�   � 9:�_SORT_Menu
�   � 17,18:�receive(q%)
�   �
� � �
�
��
�
�� �_Null
�� Button%<>0 � �release
��
�
�� �release
� x%,y%,b%
ȗ x%,y%,b%
� b%=0 �
 Ȏ Button% �
**� 1 : $SPoint%(1)="frup":�rfi(Button%)
4,� 2 : $SPoint%(2)="frdown":�rfi(Button%)
>*� 3 : $SPoint%(3)="frup":�rfi(Button%)
H,� 4 : $SPoint%(4)="frdown":�rfi(Button%)
R�
\
Button%=0
f�
p�
z
�� �_spath(n$)
�ȕ �n$,".")
�n$=�n$,�(n$)-1)
��
�� �(n$)>10 � n$=�n$,10)
�=n$
�
�� �_SORT_Menu
�� A%
�� !q%=4 � �die
�B� !q%=2 � menu%!76=menu%!76 � 1:menu%!52=menu%!52 � &FE:Log%=�
�
�B� !q%=1 � menu%!52=menu%!52 � 1:menu%!76=menu%!76 � &FE:Log%=�
B
L
� !q%=3 �
V
Ȏ q%!4 �
`� 0 :Block%=1
j� 1 :Block%=2
t� 2 :Block%=4
~� 4 :Block%=8
��
�� A%=0 � 4
�1keymenu%?(28+24*A%)=keymenu%?(28+24*A%) � &FE
��
�3keymenu%?(28+24*q%!4)=keymenu%?(28+24*q%!4) � 1
��
�
�ș"Wimp_GetPointerInfo",,q%
�6� q%!8=1 � ș"Wimp_CreateMenu",,menu%,q%!0-94,q%!4
��
�
�
� �_close
�7� q%!0=monW% � ș"Wimp_GetWindowInfo",,Wn%:wopen%=�
� � q%!0=warningW% � warnOn%=�
�ș "Wimp_CloseWindow",,q%
��


� �_do_click(q%)
i%=q%!16
Ȏ q%!12 �
((� warningW%: q%!0=warningW% :�_close
2
<(� -2: � Look first at Icon Bar Click
F        � q%!16=smpicon% �
PJ        � q%!8=2 � IconMenu%=�: ș"Wimp_CreateMenu",,menu%,q%!0-94,300
Z        � q%!8=4 � �_Open
d
        �
n
x� monW%:  
�'              � q%!8=4 � �_MonClick
�D              � q%!8=2 � ș"Wimp_CreateMenu",,menu%,q%!0-94,q%!4
��
��
�
�
�� �_MonClick
�� X%,Y%,D%,V%,B%
�&� Do the action for a window click
��_Trans(monW%)
�ș"Wimp_GetPointerInfo",,q%
�X%=q%!0-xo%
�Y%=q%!4-yo%
Ȏ i% �
� 0 : �_Scan
&� 1 : $SPoint%(1)="frpup":�rfi(i%)
"         � StartN%+1<>EndN% � StartN%+=1:$SPoint%(7)=sef$(StartN%):ș"Wimp_ForceRedraw",monW%,IX%(7),IY%(7),IX1%(7),IY1%(7)
,(� 2 : $SPoint%(2)="frpdown":�rfi(i%)
6|         � StartN%-1<>-1 � StartN%-=1:$SPoint%(7)=sef$(StartN%):ș"Wimp_ForceRedraw",monW%,IX%(7),IY%(7),IX1%(7),IY1%(7)
@&� 3 : $SPoint%(3)="frpup":�rfi(i%)
Ju         � EndN%+1<>4 � EndN%+=1:$SPoint%(8)=sef$(EndN%):ș"Wimp_ForceRedraw",monW%,IX%(8),IY%(8),IX1%(8),IY1%(8)
T(� 4 : $SPoint%(4)="frpdown":�rfi(i%)
^{         � EndN%-1<>StartN% � EndN%-=1:$SPoint%(8)=sef$(EndN%):ș"Wimp_ForceRedraw",monW%,IX%(8),IY%(8),IX1%(8),IY1%(8)
h�
r�
|
�� �rfi(i%)
�@ș"Wimp_ForceRedraw",monW%,IX%(i%),IY%(i%),IX1%(i%),IY1%(i%)
�Button%=i%
��
�
�� �_Open
�.ș"OS_ReadModeVariable",-1,3 � ,,Ncolours%
�� OPEN UP WINDOW HERE
�� wopen% �
�q%!0=monW%
�ș"Wimp_GetWindowState",,q%
�6  � q%!28<>-1 � q%!28=-1: ș "Wimp_OpenWindow",,q%
��
ș "Wimp_OpenWindow",,Wn%
wopen%=�
�
&�
0
:� �_doWindow
D  � A%,I%,L%
N
X   �_Trans(monW%)
b)   ș "Wimp_RedrawWindow",,q% � flag%
l     ȕ flag%
v
�     �drawframe
�     �plotRes
�+     ș "Wimp_GetRectangle",,q% � flag%
�
     �
�  
�  �
�  
�
�� �drawframe
�� W%,L%,A%,H%,Os%,G%,D%,L2
�$L%=640:W%=10:A%=64:Os%=50:H%=340
�ș"Wimp_SetColour",1
�ȓȐ xo%+Os%,yo%+A%,L%,H%

ș"Wimp_SetColour",7
ȓȐ xo%+Os%,yo%+A%,L%,W%
 #ȓȐ xo%+Os%,yo%+A%-W%+H%,L%,W%
*ȓȐ xo%+Os%,yo%+A%,W%,H%
4 ȓȐ xo%+Os%+L%,yo%+A%,W%,H%
>
� GRID% �
H� B%=0 � 7
RD� xo%+Os%,yo%+A%+14+306-B%*42.5,xo%+Os%+L%,yo%+A%+14+306-B%*42.5
\�
fL2=L%/(EndN%-StartN%)
p� D%=0 � EndN%-StartN%-1
z� B%=1 � 9
�G%=�(B%)*L2+L2*D%
�2� xo%+12+Os%+G%,yo%+A%,xo%+12+Os%+G%,yo%+A%+H%
��
��
��
��
�
�� �plotRes
�� A%,B%,Os%,Y%
�ș"Wimp_SetColour",10
�A%=76:Os%=62
�� Block%=1 �
�Y%=Res%(0)
	� xo%+Os%+B%,yo%+Y%+A%
	� B%=1 � 313
	Y%=Res%(B%)
	$� xo%+Os%+B%*2,yo%+Y%+A%
	.�
	8�
	B � B%=1 � 312 � Block%
	LG � Res%(B%)<>0 � ȓȐ xo%+62+B%*2,yo%+Res%(B%)+76,Block%*2,Block%*2
	V �
	`�
	j�
	t
	~� �_Trans(wh%)
	�!q%=wh%
	� ș "Wimp_GetWindowState",,q%
	�&xo%=q%!4-q%!20:yo%=q%!16-q%!24-440
	�XO%=q%!4:YO%=q%!16
	��
	�
	���setupmenu
	�� m%
	�
	�$keymenu%="Key"
	�keymenu%?12=7
	�keymenu%?13=2
keymenu%?14=7

keymenu%?15=0
keymenu%!16=128
keymenu%!20=40
(keymenu%!24=0
2m%=keymenu%+28
<
F
m%!0=0
P
m%!4=0
Zm%!8=(7<<24)� %10001
d$(m%+12)="Best"
n
x
m%+=24
�
m%!0=0
�
m%!4=0
�m%!8=(7<<24)� %10001
�$(m%+12)="Fine"
�
m%+=24
�
m%!0=1
�
m%!4=0
�m%!8=(7<<24)� %10001
�$(m%+12)="Medium"
�
m%+=24
�
m%!0=0
�
m%!4=0
�m%!8=(7<<24)� %10001
$(m%+12)="Corse"

m%+=24
m%!0=&80
"
m%!4=0
,m%!8=(7<<24)� %10001
6$(m%+12)="Quick"
@
J
T$menu%="Sound"
^menu%?12=7
hmenu%?13=2
rmenu%?14=7
|menu%?15=0
�menu%!16=128
�menu%!20=40
�menu%!24=0
�m%=menu%+28
�
m%!0=0
�m%!4=info%
�m%!8=(7<<24)� %10001
�$(m%+12)="Info"
�
�
m%+=24
�
m%!0=0
�
m%!4=0
�m%!8=(7<<24)� %10001
$(m%+12)="Liner"


m%+=24
&
m%!0=1
0
m%!4=0
:m%!8=(7<<24)� %10001
D$(m%+12)="Log"
N
X
m%+=24
b
m%!0=0
lm%!4=keymenu%
vm%!8=(7<<24)� %10001
�$(m%+12)="Resoloution"
�
�
m%+=24
�m%!0=&80
�
m%!4=0
�m%!8=(7<<24)� %10001
�$(m%+12)="Quit"
�
��
�
�� �receive(q%)
�� A%

A%=q%!16

Ȏ A% �

� 0:�die

 � &502:   Ȏ � �

*�             � q%!32=-2 � q%!36=smpicon%:mes$="This is the Frequncy Responce icon.|MPlot the frequncy responce of a circuit."

4             :mes$=""

>             �

H    � mes$<>"" �

R    q%!12=q%!8

\    $(q%+20)=mes$+�0

f    q%!0=(20+�mes$+4)� � 3

p    q%!16=&503

z(    ș "Wimp_SendMessage",18,q%,q%!4

��

��

�

�� �_Dack

�sendth%=q%!4

�myref%=q%!8

�"ș "Wimp_GetPointerInfo",,q%+8

�q%!28=q%!8

�q%!32=q%!12

�q%!0=(44+�n$+4)� � 3

�q%!12=myref%

�q%!16=4

�q%!36=-1
q%!40=&FF9
$(q%+44)=n$+�0
'ș "Wimp_SendMessage",17,q%,sendth%
$�
.�
8
Bݤsget(x%)
L� x$
Vȕ ?x% x$+=�(?x%):x%+=1:�
`=x$
j
t
ݤicon
~q%!0=-1
�
q%!4=0
�q%!8=0 : � Y DIRECTION
�q%!12=70 : � X DIRECTION
�q%!16=96
�q%!20=&2002
�$(q%+24)="!Freq"
�$ș "Wimp_CreateIcon",,q% � icon%
�
=icon%
�
�� �_setupW(t$)
�X!q%=warningW%:q%!4=200:q%!8=200:q%!12=200+XQ%:q%!16=200+YQ%:q%!20=0:q%!24=0:q%!28=-1
�$TextWarn%=t$
TextWarn%?�(t$)=0

� 7

warnOn%=�
ș "Wimp_OpenWindow",,q%
(�
2
<� �errorbox
Fș "Wimp_DragBox",,-1
P2!buffers%=�:$(buffers%+4)=�$+" at line "+Þ+�0
Z8ș "Wimp_ReportError",buffers%,1,"Frequncy Responce"
d�die
n�
x
�	��die
�	� � �
�*ș "Wimp_CloseDown",taskhand%,!taskid%
��
��
�
�� �getw(handle%)
�8!q%=handle%:ș "Wimp_GetWindowState",,q%:�info(q%+4)
��
�� �geti(h%,i%)
�-!q%=h%:q%!4=i%:ș "Wimp_GetIconState",,q%
�.ix0%=q%!8:iy0%=q%!12:ix1%=q%!16:iy1%=q%!20
�iflags%=q%!24:idata%=q%+28
�

� �info(p%)
"
� x0%,y0%
,'x0%=!p%:y0%=p%!4:x1%=p%!8:y1%=p%!12
65scx%=p%!16:scy%=p%!20:bhandle%=p%!24:flags%=p%!28
@bx%=x0%-scx%:by%=y1%-scy%
J�
T
^� �_KeyPress
h
Ȏ q%!0 �
r+� OTHERWISE: SYS"Wimp_ProcessKey",q%!24
|�
��
�
�� �init
�
*Audio ON
�"ș"Sound_Volume",127 � UserVol
�� s%=0 � 255
�8 ș"Sound_SoundLog",&7FFFFFFF*�(2*�*s%/256) � WT%?s%
��
�� s%=256 � 511
�7 ș"Sound_SoundLog",&7FFFFFFF*�(2*�*s%/64) � WT%?s%
��
�
�*� SYS"Sound_Volume",UserVol TO UserVol

� C% = 0 � 2 � 2
P%=Code%
&[ OPT C%
0.VoiceBase
:B       Fill
DB       Fill
NB       GateOn
XB       GateOff
bB       Instance
lLDMFD   R13!,{PC}
vLDMFD   R13!,{PC}
�!EQUD    VoiceName - VoiceBase
�!.VoiceName      EQUS "SinMax"
�                EQUB 0
�	ALIGN
�.LogAmpPtr      EQUD 0
�.WaveBase       EQUD WT%
�
�
.Instance
�STMFD   R13!,{R0-R4}
�MOV     R0,#0
�MOV     R1,#0
�MOV     R2,#0
�MOV     R3,#0
MOV     R4,#0
SWI     "XSound_Configure"
LDRVC   R0,[R3,#12]
 STRVC   R0,LogAmpPtr
*STRVS   R0,[R13]
4LDMFD   R13!,{R0-R4,PC}
>
H.GateOn
RLDR     R0,WaveBase
\STR     R0,[R9,#16]
fLDR     R0,LogAmpPtr
pSTR     R0,[R9,#20]
z
�	.Fill
�LDMIA   R9,{R1-R6}
��     R1,R1,#&7F
�LDRB    R1,[R6,R1,LSL #1]
�MOV     R1,R1,LSR #1
�RSB     R1,R1,#127
�
.FillLoop
�ADD R2,R2,R2,LSL #16
�LDRB    R0,[R5,R2,LSR #24]
�STRB    R0,[R12],R11
�
�ADD R2,R2,R2,LSL #16
�LDRB    R0,[R5,R2,LSR #24]
STRB    R0,[R12],R11

ADD R2,R2,R2,LSL #16
$LDRB    R0,[R5,R2,LSR #24]
.STRB    R0,[R12],R11
8
BADD R2,R2,R2,LSL #16
LLDRB    R0,[R5,R2,LSR #24]
VSTRB    R0,[R12],R11
`
jCMP     R12,R10
tBLT     FillLoop
~
�SUBS    R4,R4,#1
�STMIB   R9,{R2-R5}
�MOVPL   R0,#%00001000
�MOVMI   R0,#%00000010
�LDMFD   R13!,{PC}
�
�.GateOff
�MOV     R0,#0
�.FlushLoop
�STRB    R0,[R12],R11
�STRB    R0,[R12],R11
�STRB    R0,[R12],R11
STRB    R0,[R12],R11

CMP     R12,R10
BLT     FlushLoop
MOV     R0,#%00000001
(LDMFD   R13!,{PC}
2]
<�
F
P� OldVoice%(8)
Z
d� A%=0 � 3
n� sef$(A%)
x�
�� 10 Hz,100 Hz,1 KHz,10 KHz
�+Scale%(0)=16 : � X factor for gain of 1
�*Scale%(1)=8 : � X factor for gain of 2
�*Scale%(2)=4 : � X factor for gain of 4
�*Scale%(3)=2 : � X factor for gain of 8
�+Scale%(4)=1 : � X factor for gain of 16
�)Offset%=25 : � The measured DC offset
�!� Set up the control register
�� read only Channel 0
�?PBA%=0
�&ș "XIIC_Control",&90,PBA%,1 � ;Fl
�I� (Fl � 1) =1 � �_setupW("No IIC device found"):Device%=� � Device%=�
��

� �_Scan
� A%,Dec%,ST%,F
")� First store the current sound setup
,3ș "Sound_InstallVoice",VoiceBase,0 � a%,Voice%
6� v%=1 � 1
@1ș"Sound_AttachVoice",v%,0 � z%,OldVoice%(v%)
Jȡ v%,"SinMax"
T�
^Ƞ 1
h
r� Now draw grid
|ST%=314
�Dec%=EndN%-StartN%
��_Trans(monW%)
�1u%!0=monW%:u%!4=0:u%!8=-440:u%!12=740:u%!16=0
�'  ș"Wimp_UpdateWindow",,u% � More%
�
 ȕ More%
�  �drawframe
�'  ș"Wimp_GetRectangle",,u% � More%
� �
� 
�Res%()=0
�� A%=1 � ST% � Block%
�'F=10^((A%*Dec%)/ST%)*10^(StartN%+1)
��tone(F)

� Tone% �
Res%(A%)=�res:�_UpP(A%)
�
&Res%(A%)=0
0�
:�
D�del
N
X#ș "Sound_RemoveVoice",0,Voice%
b� v%=1 � 1
l+ ș"Sound_AttachVoice",v%,OldVoice%(v%)
v�
�
��
�
�	ݤres
�� G%,Read,Val
�G%=0
�� Device%=� � =306
� �
�PBD%?0=&80 � G%
�
PBD%?1=G%
� 
�� Discharge Capacitor
� ș "XIIC_Control",&70,PBD%,1
�� Remove the short
"ș "XIIC_Control",&70,PBD%+1,1
	�del2
�
 � Read the A/D
* ș "XIIC_Control",&91,PBK%,3
4� �(PBK%?1-PBK%?2)<4
>Read=(PBK%?1+PBK%?2)/2
H	G%+=1
R� Read>&80 � G%=5
\	G%-=1
f#Val=(Read-Offset%) * Scale%(G%)
p� Val<1 � Val=1
q� Log% �
z$Val=(10.2*(30+20*(�(Val/4080))))
{�
|Val=(Val*306)/4080
}�
�� Val<0 � Val=0
�=Val
�
�� �del2
�� T%
�T%=�+Vdelay%
�� � �>T%
��
�
�� �_UpP(A%)
�� T%,Y%,More%
�T%=Res%(A%-1)
�Y%=Res%(A%)
�_Trans(monW%)
2u%!0=monW%:u%!4=60:u%!8=-366:u%!12=740:u%!16=0
'  ș"Wimp_UpdateWindow",,u% � More%
$
 ȕ More%
.ș"Wimp_SetColour",10
8� Block%=1 �
B"   � xo%+62+(A%-1)*2,yo%+T%+76
L   � xo%+62+A%*2,yo%+Y%+76
V�
`2  ȓȐ xo%+62+A%*2,yo%+Y%+76,Block%*2,Block%*2
j�
t'  ș"Wimp_GetRectangle",,u% � More%
~ �
��
�
�� �tone(F)
�� R,Oc,octive%,Fr%,S%,P%
�R=F/16.351875
�Oc=(�(R)/Log2)
�octive%=�(Oc)
�Fr%=(Oc-octive%)*4096
�S%=(Fr% � (octive%<<12))
�� octive%<9 � S%> &100 �
�
�E� S%>&7FFF � P%=S%-&2000: !WaveBase=WT%+256 � P%=S%:!WaveBase=WT%
 � 1,-15,P%,10

 Tone%=�
 � Vdelay%=10-(S%>>12)
% � S%>&2000 Vdelay%=1 � Vdelay%=6
( �
2 Tone%=�
<�
F
P�del
Z�
d
n
� �del
x� T%
�
T%=� + 20
�� � �>T%
��
�
00000000  0d 00 0a 25 f4 3e 44 65  76 65 6c 6f 70 2e 46 72  |...%.>Develop.Fr|
00000010  65 71 52 65 73 70 2e 21  46 72 65 71 2e 52 75 6e  |eqResp.!Freq.Run|
00000020  46 65 72 65 71 0d 00 14  2c f4 20 46 72 65 71 75  |Fereq...,. Frequ|
00000030  65 6e 63 79 20 52 65 73  70 6f 6e 73 65 20 6f 66  |ency Response of|
00000040  20 61 6e 20 61 75 64 69  6f 20 63 69 72 63 75 69  | an audio circui|
00000050  74 0d 00 1e 1e f4 20 56  65 72 73 69 6f 6e 20 31  |t..... Version 1|
00000060  2e 30 20 42 79 20 4d 69  6b 65 20 43 6f 6f 6b 0d  |.0 By Mike Cook.|
00000070  00 28 1e f4 20 41 6c 6c  20 72 69 67 68 74 73 20  |.(.. All rights |
00000080  72 65 73 65 72 76 65 64  20 31 39 39 37 0d 00 32  |reserved 1997..2|
00000090  11 ee 20 85 20 f2 65 72  72 6f 72 62 6f 78 0d 00  |.. . .errorbox..|
000000a0  3c 04 0d 00 46 1e de 20  74 61 73 6b 69 64 25 34  |<...F.. taskid%4|
000000b0  3a 24 74 61 73 6b 69 64  25 3d 22 54 41 53 4b 22  |:$taskid%="TASK"|
000000c0  0d 00 50 11 de 20 69 6e  74 6d 65 73 73 25 20 32  |..P.. intmess% 2|
000000d0  30 0d 00 5a 49 69 6e 74  6d 65 73 73 25 21 30 3d  |0..ZIintmess%!0=|
000000e0  31 3a 69 6e 74 6d 65 73  73 25 21 34 3d 32 3a 69  |1:intmess%!4=2:i|
000000f0  6e 74 6d 65 73 73 25 21  38 3d 33 3a 69 6e 74 6d  |ntmess%!8=3:intm|
00000100  65 73 73 25 21 31 32 3d  26 35 30 32 3a 69 6e 74  |ess%!12=&502:int|
00000110  6d 65 73 73 25 21 31 36  3d 30 0d 00 64 4e c8 99  |mess%!16=0..dN..|
00000120  20 22 57 69 6d 70 5f 49  6e 69 74 69 61 6c 69 73  | "Wimp_Initialis|
00000130  65 22 2c 33 30 30 2c 21  74 61 73 6b 69 64 25 2c  |e",300,!taskid%,|
00000140  22 46 72 65 71 52 65 73  70 22 2c 69 6e 74 6d 65  |"FreqResp",intme|
00000150  73 73 25 20 b8 20 76 65  72 73 69 6f 6e 25 2c 74  |ss% . version%,t|
00000160  61 73 6b 68 61 6e 64 25  0d 00 6e 4e de 20 71 25  |askhand%..nN. q%|
00000170  20 26 33 30 30 2c 71 63  25 20 38 30 2c 20 57 6e  | &300,qc% 80, Wn|
00000180  25 20 26 33 30 30 2c 74  65 6d 70 25 20 32 35 36  |% &300,temp% 256|
00000190  2c 62 75 66 66 65 72 73  25 20 35 31 32 2c 6d 65  |,buffers% 512,me|
000001a0  6e 75 25 20 35 31 32 2c  53 57 25 20 32 35 36 2c  |nu% 512,SW% 256,|
000001b0  63 62 25 20 31 38 0d 00  78 4b de 20 49 73 4e 61  |cb% 18..xK. IsNa|
000001c0  6d 65 25 20 32 35 36 2c  20 57 6d 65 6e 75 25 20  |me% 256, Wmenu% |
000001d0  35 31 32 2c 20 54 65 78  74 57 61 72 6e 25 20 31  |512, TextWarn% 1|
000001e0  30 30 2c 20 77 77 25 20  32 35 36 2c 20 54 6b 65  |00, ww% 256, Tke|
000001f0  79 25 28 37 29 2c 20 43  6d 65 6e 75 25 20 32 35  |y%(7), Cmenu% 25|
00000200  36 0d 00 82 28 de 20 6b  65 79 6d 65 6e 75 25 20  |6...(. keymenu% |
00000210  35 31 32 2c 73 6d 65 6e  75 25 20 35 31 32 2c 53  |512,smenu% 512,S|
00000220  74 61 62 25 28 37 2c 37  29 0d 00 8c 1e de 20 52  |tab%(7,7)..... R|
00000230  65 73 25 28 33 32 30 29  2c 75 25 20 32 35 36 2c  |es%(320),u% 256,|
00000240  73 65 66 24 28 34 29 0d  00 96 0d de 20 57 54 25  |sef$(4)..... WT%|
00000250  20 35 31 31 0d 00 a0 38  de 20 43 6f 64 65 25 20  | 511...8. Code% |
00000260  34 30 39 36 2c 50 42 4b  25 20 35 2c 50 42 41 25  |4096,PBK% 5,PBA%|
00000270  20 34 2c 50 42 44 25 20  33 2c 47 61 69 6e 25 28  | 4,PBD% 3,Gain%(|
00000280  35 29 2c 53 63 61 6c 65  25 28 36 29 0d 00 aa 0a  |5),Scale%(6)....|
00000290  4e 6f 49 25 3d 38 0d 00  b4 3d de 20 53 50 6f 69  |NoI%=8...=. SPoi|
000002a0  6e 74 25 28 4e 6f 49 25  29 2c 49 58 25 28 4e 6f  |nt%(NoI%),IX%(No|
000002b0  49 25 29 2c 49 59 25 28  4e 6f 49 25 29 2c 49 58  |I%),IY%(NoI%),IX|
000002c0  31 25 28 4e 6f 49 25 29  2c 49 59 31 25 28 4e 6f  |1%(NoI%),IY1%(No|
000002d0  49 25 29 0d 00 be 32 c8  99 20 22 57 69 6d 70 5f  |I%)...2.. "Wimp_|
000002e0  4f 70 65 6e 54 65 6d 70  6c 61 74 65 22 2c 2c 22  |OpenTemplate",,"|
000002f0  3c 46 72 65 71 24 44 69  72 3e 2e 54 65 6d 70 6c  |<Freq$Dir>.Templ|
00000300  61 74 65 73 22 0d 00 c8  29 ee 20 85 20 c8 99 20  |ates"...). . .. |
00000310  22 57 69 6d 70 5f 43 6c  6f 73 65 54 65 6d 70 6c  |"Wimp_CloseTempl|
00000320  61 74 65 22 3a f2 65 72  72 6f 72 62 6f 78 0d 00  |ate":.errorbox..|
00000330  d2 3a c8 99 20 22 57 69  6d 70 5f 4c 6f 61 64 54  |.:.. "Wimp_LoadT|
00000340  65 6d 70 6c 61 74 65 22  2c 2c 71 25 2c 74 65 6d  |emplate",,q%,tem|
00000350  70 25 2c 74 65 6d 70 25  2b 32 35 36 2c 2d 31 2c  |p%,temp%+256,-1,|
00000360  22 49 6e 66 6f 22 2c 30  0d 00 dc 26 c8 99 20 22  |"Info",0...&.. "|
00000370  57 69 6d 70 5f 43 72 65  61 74 65 57 69 6e 64 6f  |Wimp_CreateWindo|
00000380  77 22 2c 2c 71 25 20 b8  20 69 6e 66 6f 25 0d 00  |w",,q% . info%..|
00000390  e6 3d c8 99 20 22 57 69  6d 70 5f 4c 6f 61 64 54  |.=.. "Wimp_LoadT|
000003a0  65 6d 70 6c 61 74 65 22  2c 2c 57 6e 25 2b 34 2c  |emplate",,Wn%+4,|
000003b0  53 57 25 2c 53 57 25 2b  32 35 36 2c 2d 31 2c 22  |SW%,SW%+256,-1,"|
000003c0  50 61 6c 6c 65 74 74 65  22 2c 30 0d 00 f0 0d 57  |Pallette",0....W|
000003d0  6e 25 21 32 38 3d 2d 31  0d 00 fa 11 e3 20 41 25  |n%!28=-1..... A%|
000003e0  3d 30 20 b8 20 4e 6f 49  25 0d 01 04 24 53 50 6f  |=0 . NoI%...$SPo|
000003f0  69 6e 74 25 28 41 25 29  3d 21 28 57 6e 25 2b 34  |int%(A%)=!(Wn%+4|
00000400  2b 38 38 2b 32 30 2b 33  32 2a 41 25 29 0d 01 0e  |+88+20+32*A%)...|
00000410  39 49 58 25 28 41 25 29  3d 21 28 57 6e 25 2b 34  |9IX%(A%)=!(Wn%+4|
00000420  2b 38 38 2b 33 32 2a 41  25 29 3a 49 59 25 28 41  |+88+32*A%):IY%(A|
00000430  25 29 3d 21 28 57 6e 25  2b 34 2b 38 38 2b 34 2b  |%)=!(Wn%+4+88+4+|
00000440  33 32 2a 41 25 29 0d 01  18 3e 49 58 31 25 28 41  |32*A%)...>IX1%(A|
00000450  25 29 3d 21 28 57 6e 25  2b 34 2b 38 38 2b 38 2b  |%)=!(Wn%+4+88+8+|
00000460  33 32 2a 41 25 29 3a 49  59 31 25 28 41 25 29 3d  |32*A%):IY1%(A%)=|
00000470  21 28 57 6e 25 2b 34 2b  38 38 2b 31 32 2b 33 32  |!(Wn%+4+88+12+32|
00000480  2a 41 25 29 0d 01 22 05  ed 0d 01 2c 29 c8 99 20  |*A%).."....,).. |
00000490  22 57 69 6d 70 5f 43 72  65 61 74 65 57 69 6e 64  |"Wimp_CreateWind|
000004a0  6f 77 22 2c 2c 57 6e 25  2b 34 20 b8 20 6d 6f 6e  |ow",,Wn%+4 . mon|
000004b0  57 25 0d 01 36 19 57 6e  25 21 30 3d 6d 6f 6e 57  |W%..6.Wn%!0=monW|
000004c0  25 3a 57 6e 25 21 32 38  3d 2d 31 0d 01 40 04 0d  |%:Wn%!28=-1..@..|
000004d0  01 4a 39 c8 99 20 22 57  69 6d 70 5f 4c 6f 61 64  |.J9.. "Wimp_Load|
000004e0  54 65 6d 70 6c 61 74 65  22 2c 2c 71 25 2c 77 77  |Template",,q%,ww|
000004f0  25 2c 77 77 25 2b 32 35  36 2c 2d 31 2c 22 57 61  |%,ww%+256,-1,"Wa|
00000500  72 6e 69 6e 67 22 2c 30  0d 01 54 29 71 25 21 31  |rning",0..T)q%!1|
00000510  30 38 3d 54 65 78 74 57  61 72 6e 25 3a 71 25 21  |08=TextWarn%:q%!|
00000520  31 31 32 3d 2d 31 3a 71  25 21 31 31 36 3d 33 30  |112=-1:q%!116=30|
00000530  30 0d 01 5e 20 58 51 25  3d 71 25 21 38 2d 71 25  |0..^ XQ%=q%!8-q%|
00000540  21 30 3a 59 51 25 3d 71  25 21 31 32 2d 71 25 21  |!0:YQ%=q%!12-q%!|
00000550  34 0d 01 68 2a c8 99 20  22 57 69 6d 70 5f 43 72  |4..h*.. "Wimp_Cr|
00000560  65 61 74 65 57 69 6e 64  6f 77 22 2c 2c 71 25 20  |eateWindow",,q% |
00000570  b8 20 77 61 72 6e 69 6e  67 57 25 0d 01 72 1b c8  |. warningW%..r..|
00000580  99 20 22 57 69 6d 70 5f  43 6c 6f 73 65 54 65 6d  |. "Wimp_CloseTem|
00000590  70 6c 61 74 65 22 0d 01  7c 14 4c 6f 67 32 3d aa  |plate"..|.Log2=.|
000005a0  28 32 29 3a 72 65 66 25  3d 30 0d 01 86 11 63 70  |(2):ref%=0....cp|
000005b0  4c 25 3d 30 3a 63 70 52  25 3d 30 0d 01 90 12 73  |L%=0:cpR%=0....s|
000005c0  6d 70 69 63 6f 6e 25 3d  a4 69 63 6f 6e 0d 01 9a  |mpicon%=.icon...|
000005d0  16 77 6f 70 65 6e 25 3d  a3 3a 77 61 72 6e 4f 6e  |.wopen%=.:warnOn|
000005e0  25 3d a3 0d 01 a4 0c 49  6e 57 69 6e 25 3d a3 0d  |%=.....InWin%=..|
000005f0  01 ae 12 47 52 49 44 25  3d b9 3a 4c 6f 67 25 3d  |...GRID%=.:Log%=|
00000600  b9 0d 01 b8 16 42 6c 6f  63 6b 25 3d 34 3a 56 64  |.....Block%=4:Vd|
00000610  65 6c 61 79 25 3d 31 0d  01 c2 11 ee 20 85 20 f2  |elay%=1..... . .|
00000620  65 72 72 6f 72 62 6f 78  0d 01 cc 1f 42 75 74 74  |errorbox....Butt|
00000630  6f 6e 25 3d 30 3a 53 74  61 72 74 4e 25 3d 30 3a  |on%=0:StartN%=0:|
00000640  45 6e 64 4e 25 3d 33 0d  01 d6 0e f2 73 65 74 75  |EndN%=3.....setu|
00000650  70 6d 65 6e 75 0d 01 e0  3a c8 99 22 53 6f 75 6e  |pmenu...:.."Soun|
00000660  64 5f 43 6f 6e 66 69 67  75 72 65 22 2c 31 2c 32  |d_Configure",1,2|
00000670  30 38 2c 34 38 2c 30 2c  30 20 b8 20 4e 63 25 2c  |08,48,0,0 . Nc%,|
00000680  53 6c 25 2c 53 70 25 2c  50 63 25 2c 50 73 25 0d  |Sl%,Sp%,Pc%,Ps%.|
00000690  01 ea 2b c8 99 22 53 6f  75 6e 64 5f 43 6f 6e 66  |..+.."Sound_Conf|
000006a0  69 67 75 72 65 22 2c 4e  63 25 2c 53 6c 25 2c 53  |igure",Nc%,Sl%,S|
000006b0  70 25 2c 50 63 25 2c 50  73 25 0d 01 f4 04 0d 01  |p%,Pc%,Ps%......|
000006c0  fe 09 f2 69 6e 69 74 0d  02 08 04 0d 02 12 05 f5  |...init.........|
000006d0  0d 02 1c 1d 20 c8 99 20  22 57 69 6d 70 5f 50 6f  |.... .. "Wimp_Po|
000006e0  6c 6c 22 2c 30 2c 71 25  20 b8 20 41 25 0d 02 26  |ll",0,q% . A%..&|
000006f0  0d 20 20 c8 8e 20 41 25  20 ca 0d 02 30 11 20 20  |.  .. A% ...0.  |
00000700  20 c9 20 30 3a f2 5f 4e  75 6c 6c 0d 02 3a 15 20  | . 0:._Null..:. |
00000710  20 20 c9 20 31 3a f2 5f  64 6f 57 69 6e 64 6f 77  |  . 1:._doWindow|
00000720  0d 02 44 4f 20 20 20 c9  20 32 3a c8 99 22 4f 53  |..DO   . 2:.."OS|
00000730  5f 52 65 61 64 4d 6f 64  65 56 61 72 69 61 62 6c  |_ReadModeVariabl|
00000740  65 22 2c 2d 31 2c 33 20  b8 20 2c 2c 4e 63 6f 6c  |e",-1,3 . ,,Ncol|
00000750  6f 75 72 73 25 3a 20 c8  99 20 22 57 69 6d 70 5f  |ours%: .. "Wimp_|
00000760  4f 70 65 6e 57 69 6e 64  6f 77 22 2c 2c 71 25 0d  |OpenWindow",,q%.|
00000770  02 4e 12 20 20 20 c9 20  33 3a f2 5f 63 6c 6f 73  |.N.   . 3:._clos|
00000780  65 0d 02 58 21 20 20 20  c9 20 34 3a 49 6e 57 69  |e..X!   . 4:InWi|
00000790  6e 25 3d a3 3a 4c 58 25  3d 2d 31 3a 4c 59 25 3d  |n%=.:LX%=-1:LY%=|
000007a0  2d 31 0d 02 62 13 20 20  20 c9 20 35 3a 49 6e 57  |-1..b.   . 5:InW|
000007b0  69 6e 25 3d b9 0d 02 6c  19 20 20 20 c9 20 36 3a  |in%=...l.   . 6:|
000007c0  f2 5f 64 6f 5f 63 6c 69  63 6b 28 71 25 29 0d 02  |._do_click(q%)..|
000007d0  76 0b 20 20 20 c9 20 37  3a 0d 02 80 15 20 20 20  |v.   . 7:....   |
000007e0  c9 20 38 3a f2 5f 4b 65  79 50 72 65 73 73 0d 02  |. 8:._KeyPress..|
000007f0  8a 16 20 20 20 c9 20 39  3a f2 5f 53 4f 52 54 5f  |..   . 9:._SORT_|
00000800  4d 65 6e 75 0d 02 94 1b  20 20 20 c9 20 31 37 2c  |Menu....   . 17,|
00000810  31 38 3a f2 72 65 63 65  69 76 65 28 71 25 29 0d  |18:.receive(q%).|
00000820  02 9e 08 20 20 20 cb 0d  02 a8 08 20 fd 20 a3 0d  |...   ..... . ..|
00000830  02 b2 04 0d 02 bc 05 e0  0d 02 c6 04 0d 02 d0 0c  |................|
00000840  dd 20 f2 5f 4e 75 6c 6c  0d 02 da 1b e7 20 42 75  |. ._Null..... Bu|
00000850  74 74 6f 6e 25 3c 3e 30  20 8c 20 f2 72 65 6c 65  |tton%<>0 . .rele|
00000860  61 73 65 0d 02 e4 05 e1  0d 02 ee 04 0d 02 f8 0e  |ase.............|
00000870  dd 20 f2 72 65 6c 65 61  73 65 0d 03 02 0e ea 20  |. .release..... |
00000880  78 25 2c 79 25 2c 62 25  0d 03 0c 0f c8 97 20 78  |x%,y%,b%...... x|
00000890  25 2c 79 25 2c 62 25 0d  03 16 0c e7 20 62 25 3d  |%,y%,b%..... b%=|
000008a0  30 20 8c 0d 03 20 10 c8  8e 20 42 75 74 74 6f 6e  |0 ... ... Button|
000008b0  25 20 ca 0d 03 2a 2a c9  20 31 20 3a 20 24 53 50  |% ...**. 1 : $SP|
000008c0  6f 69 6e 74 25 28 31 29  3d 22 66 72 75 70 22 3a  |oint%(1)="frup":|
000008d0  f2 72 66 69 28 42 75 74  74 6f 6e 25 29 0d 03 34  |.rfi(Button%)..4|
000008e0  2c c9 20 32 20 3a 20 24  53 50 6f 69 6e 74 25 28  |,. 2 : $SPoint%(|
000008f0  32 29 3d 22 66 72 64 6f  77 6e 22 3a f2 72 66 69  |2)="frdown":.rfi|
00000900  28 42 75 74 74 6f 6e 25  29 0d 03 3e 2a c9 20 33  |(Button%)..>*. 3|
00000910  20 3a 20 24 53 50 6f 69  6e 74 25 28 33 29 3d 22  | : $SPoint%(3)="|
00000920  66 72 75 70 22 3a f2 72  66 69 28 42 75 74 74 6f  |frup":.rfi(Butto|
00000930  6e 25 29 0d 03 48 2c c9  20 34 20 3a 20 24 53 50  |n%)..H,. 4 : $SP|
00000940  6f 69 6e 74 25 28 34 29  3d 22 66 72 64 6f 77 6e  |oint%(4)="frdown|
00000950  22 3a f2 72 66 69 28 42  75 74 74 6f 6e 25 29 0d  |":.rfi(Button%).|
00000960  03 52 05 cb 0d 03 5c 0d  42 75 74 74 6f 6e 25 3d  |.R....\.Button%=|
00000970  30 0d 03 66 05 cd 0d 03  70 05 e1 0d 03 7a 04 0d  |0..f....p....z..|
00000980  03 84 11 dd 20 a4 5f 73  70 61 74 68 28 6e 24 29  |.... ._spath(n$)|
00000990  0d 03 8e 0f c8 95 20 a7  6e 24 2c 22 2e 22 29 0d  |...... .n$,".").|
000009a0  03 98 13 6e 24 3d c2 6e  24 2c a9 28 6e 24 29 2d  |...n$=.n$,.(n$)-|
000009b0  31 29 0d 03 a2 05 ce 0d  03 ac 1b e7 20 a9 28 6e  |1).......... .(n|
000009c0  24 29 3e 31 30 20 8c 20  6e 24 3d c2 6e 24 2c 31  |$)>10 . n$=.n$,1|
000009d0  30 29 0d 03 b6 07 3d 6e  24 0d 03 c0 04 0d 03 ca  |0)....=n$.......|
000009e0  11 dd 20 f2 5f 53 4f 52  54 5f 4d 65 6e 75 0d 03  |.. ._SORT_Menu..|
000009f0  d4 08 ea 20 41 25 0d 03  de 12 e7 20 21 71 25 3d  |... A%..... !q%=|
00000a00  34 20 8c 20 f2 64 69 65  0d 03 e8 42 e7 20 21 71  |4 . .die...B. !q|
00000a10  25 3d 32 20 8c 20 6d 65  6e 75 25 21 37 36 3d 6d  |%=2 . menu%!76=m|
00000a20  65 6e 75 25 21 37 36 20  84 20 31 3a 6d 65 6e 75  |enu%!76 . 1:menu|
00000a30  25 21 35 32 3d 6d 65 6e  75 25 21 35 32 20 80 20  |%!52=menu%!52 . |
00000a40  26 46 45 3a 4c 6f 67 25  3d b9 0d 03 f2 04 0d 03  |&FE:Log%=.......|
00000a50  fc 42 e7 20 21 71 25 3d  31 20 8c 20 6d 65 6e 75  |.B. !q%=1 . menu|
00000a60  25 21 35 32 3d 6d 65 6e  75 25 21 35 32 20 84 20  |%!52=menu%!52 . |
00000a70  31 3a 6d 65 6e 75 25 21  37 36 3d 6d 65 6e 75 25  |1:menu%!76=menu%|
00000a80  21 37 36 20 80 20 26 46  45 3a 4c 6f 67 25 3d a3  |!76 . &FE:Log%=.|
00000a90  0d 04 42 04 0d 04 4c 0d  e7 20 21 71 25 3d 33 20  |..B...L.. !q%=3 |
00000aa0  8c 0d 04 56 0d c8 8e 20  71 25 21 34 20 ca 0d 04  |...V... q%!4 ...|
00000ab0  60 11 c9 20 30 20 3a 42  6c 6f 63 6b 25 3d 31 0d  |`.. 0 :Block%=1.|
00000ac0  04 6a 11 c9 20 31 20 3a  42 6c 6f 63 6b 25 3d 32  |.j.. 1 :Block%=2|
00000ad0  0d 04 74 11 c9 20 32 20  3a 42 6c 6f 63 6b 25 3d  |..t.. 2 :Block%=|
00000ae0  34 0d 04 7e 11 c9 20 34  20 3a 42 6c 6f 63 6b 25  |4..~.. 4 :Block%|
00000af0  3d 38 0d 04 88 05 cb 0d  04 89 0e e3 20 41 25 3d  |=8.......... A%=|
00000b00  30 20 b8 20 34 0d 04 8a  31 6b 65 79 6d 65 6e 75  |0 . 4...1keymenu|
00000b10  25 3f 28 32 38 2b 32 34  2a 41 25 29 3d 6b 65 79  |%?(28+24*A%)=key|
00000b20  6d 65 6e 75 25 3f 28 32  38 2b 32 34 2a 41 25 29  |menu%?(28+24*A%)|
00000b30  20 80 20 26 46 45 0d 04  8b 05 ed 0d 04 8c 33 6b  | . &FE........3k|
00000b40  65 79 6d 65 6e 75 25 3f  28 32 38 2b 32 34 2a 71  |eymenu%?(28+24*q|
00000b50  25 21 34 29 3d 6b 65 79  6d 65 6e 75 25 3f 28 32  |%!4)=keymenu%?(2|
00000b60  38 2b 32 34 2a 71 25 21  34 29 20 84 20 31 0d 04  |8+24*q%!4) . 1..|
00000b70  92 05 cd 0d 04 9c 04 0d  04 a6 1f c8 99 22 57 69  |............."Wi|
00000b80  6d 70 5f 47 65 74 50 6f  69 6e 74 65 72 49 6e 66  |mp_GetPointerInf|
00000b90  6f 22 2c 2c 71 25 0d 04  b0 36 e7 20 71 25 21 38  |o",,q%...6. q%!8|
00000ba0  3d 31 20 8c 20 c8 99 22  57 69 6d 70 5f 43 72 65  |=1 . .."Wimp_Cre|
00000bb0  61 74 65 4d 65 6e 75 22  2c 2c 6d 65 6e 75 25 2c  |ateMenu",,menu%,|
00000bc0  71 25 21 30 2d 39 34 2c  71 25 21 34 0d 04 ba 05  |q%!0-94,q%!4....|
00000bd0  e1 0d 04 c4 04 0d 04 ce  0d dd 20 f2 5f 63 6c 6f  |.......... ._clo|
00000be0  73 65 0d 04 d8 37 e7 20  71 25 21 30 3d 6d 6f 6e  |se...7. q%!0=mon|
00000bf0  57 25 20 8c 20 c8 99 22  57 69 6d 70 5f 47 65 74  |W% . .."Wimp_Get|
00000c00  57 69 6e 64 6f 77 49 6e  66 6f 22 2c 2c 57 6e 25  |WindowInfo",,Wn%|
00000c10  3a 77 6f 70 65 6e 25 3d  a3 0d 04 e2 20 e7 20 71  |:wopen%=.... . q|
00000c20  25 21 30 3d 77 61 72 6e  69 6e 67 57 25 20 8c 20  |%!0=warningW% . |
00000c30  77 61 72 6e 4f 6e 25 3d  a3 0d 04 ec 1d c8 99 20  |warnOn%=....... |
00000c40  22 57 69 6d 70 5f 43 6c  6f 73 65 57 69 6e 64 6f  |"Wimp_CloseWindo|
00000c50  77 22 2c 2c 71 25 0d 04  f6 05 e1 0d 05 00 04 0d  |w",,q%..........|
00000c60  05 0a 14 dd 20 f2 5f 64  6f 5f 63 6c 69 63 6b 28  |.... ._do_click(|
00000c70  71 25 29 0d 05 14 0c 69  25 3d 71 25 21 31 36 0d  |q%)....i%=q%!16.|
00000c80  05 1e 0e c8 8e 20 71 25  21 31 32 20 ca 0d 05 28  |..... q%!12 ...(|
00000c90  28 c9 20 77 61 72 6e 69  6e 67 57 25 3a 20 71 25  |(. warningW%: q%|
00000ca0  21 30 3d 77 61 72 6e 69  6e 67 57 25 20 3a f2 5f  |!0=warningW% :._|
00000cb0  63 6c 6f 73 65 0d 05 32  04 0d 05 3c 28 c9 20 2d  |close..2...<(. -|
00000cc0  32 3a 20 f4 20 4c 6f 6f  6b 20 66 69 72 73 74 20  |2: . Look first |
00000cd0  61 74 20 49 63 6f 6e 20  42 61 72 20 43 6c 69 63  |at Icon Bar Clic|
00000ce0  6b 0d 05 46 1e 20 20 20  20 20 20 20 20 e7 20 71  |k..F.        . q|
00000cf0  25 21 31 36 3d 73 6d 70  69 63 6f 6e 25 20 8c 0d  |%!16=smpicon% ..|
00000d00  05 50 4a 20 20 20 20 20  20 20 20 e7 20 71 25 21  |.PJ        . q%!|
00000d10  38 3d 32 20 8c 20 49 63  6f 6e 4d 65 6e 75 25 3d  |8=2 . IconMenu%=|
00000d20  b9 3a 20 c8 99 22 57 69  6d 70 5f 43 72 65 61 74  |.: .."Wimp_Creat|
00000d30  65 4d 65 6e 75 22 2c 2c  6d 65 6e 75 25 2c 71 25  |eMenu",,menu%,q%|
00000d40  21 30 2d 39 34 2c 33 30  30 0d 05 5a 1d 20 20 20  |!0-94,300..Z.   |
00000d50  20 20 20 20 20 e7 20 71  25 21 38 3d 34 20 8c 20  |     . q%!8=4 . |
00000d60  f2 5f 4f 70 65 6e 0d 05  64 0d 20 20 20 20 20 20  |._Open..d.      |
00000d70  20 20 cd 0d 05 6e 04 0d  05 78 0e c9 20 6d 6f 6e  |  ...n...x.. mon|
00000d80  57 25 3a 20 20 0d 05 82  27 20 20 20 20 20 20 20  |W%:  ...'       |
00000d90  20 20 20 20 20 20 20 e7  20 71 25 21 38 3d 34 20  |       . q%!8=4 |
00000da0  8c 20 f2 5f 4d 6f 6e 43  6c 69 63 6b 0d 05 8c 44  |. ._MonClick...D|
00000db0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 e7 20  |              . |
00000dc0  71 25 21 38 3d 32 20 8c  20 c8 99 22 57 69 6d 70  |q%!8=2 . .."Wimp|
00000dd0  5f 43 72 65 61 74 65 4d  65 6e 75 22 2c 2c 6d 65  |_CreateMenu",,me|
00000de0  6e 75 25 2c 71 25 21 30  2d 39 34 2c 71 25 21 34  |nu%,q%!0-94,q%!4|
00000df0  0d 05 96 05 cb 0d 05 a0  05 e1 0d 05 aa 04 0d 05  |................|
00000e00  b4 04 0d 05 be 10 dd 20  f2 5f 4d 6f 6e 43 6c 69  |....... ._MonCli|
00000e10  63 6b 0d 05 c8 14 ea 20  58 25 2c 59 25 2c 44 25  |ck..... X%,Y%,D%|
00000e20  2c 56 25 2c 42 25 0d 05  d2 26 f4 20 44 6f 20 74  |,V%,B%...&. Do t|
00000e30  68 65 20 61 63 74 69 6f  6e 20 66 6f 72 20 61 20  |he action for a |
00000e40  77 69 6e 64 6f 77 20 63  6c 69 63 6b 0d 05 dc 12  |window click....|
00000e50  f2 5f 54 72 61 6e 73 28  6d 6f 6e 57 25 29 0d 05  |._Trans(monW%)..|
00000e60  e6 1f c8 99 22 57 69 6d  70 5f 47 65 74 50 6f 69  |...."Wimp_GetPoi|
00000e70  6e 74 65 72 49 6e 66 6f  22 2c 2c 71 25 0d 05 f0  |nterInfo",,q%...|
00000e80  0f 58 25 3d 71 25 21 30  2d 78 6f 25 0d 05 fa 0f  |.X%=q%!0-xo%....|
00000e90  59 25 3d 71 25 21 34 2d  79 6f 25 0d 06 04 0b c8  |Y%=q%!4-yo%.....|
00000ea0  8e 20 69 25 20 ca 0d 06  0e 10 c9 20 30 20 3a 20  |. i% ...... 0 : |
00000eb0  f2 5f 53 63 61 6e 0d 06  18 26 c9 20 31 20 3a 20  |._Scan...&. 1 : |
00000ec0  24 53 50 6f 69 6e 74 25  28 31 29 3d 22 66 72 70  |$SPoint%(1)="frp|
00000ed0  75 70 22 3a f2 72 66 69  28 69 25 29 0d 06 22 7f  |up":.rfi(i%)..".|
00000ee0  20 20 20 20 20 20 20 20  20 e7 20 53 74 61 72 74  |         . Start|
00000ef0  4e 25 2b 31 3c 3e 45 6e  64 4e 25 20 8c 20 53 74  |N%+1<>EndN% . St|
00000f00  61 72 74 4e 25 2b 3d 31  3a 24 53 50 6f 69 6e 74  |artN%+=1:$SPoint|
00000f10  25 28 37 29 3d 73 65 66  24 28 53 74 61 72 74 4e  |%(7)=sef$(StartN|
00000f20  25 29 3a c8 99 22 57 69  6d 70 5f 46 6f 72 63 65  |%):.."Wimp_Force|
00000f30  52 65 64 72 61 77 22 2c  6d 6f 6e 57 25 2c 49 58  |Redraw",monW%,IX|
00000f40  25 28 37 29 2c 49 59 25  28 37 29 2c 49 58 31 25  |%(7),IY%(7),IX1%|
00000f50  28 37 29 2c 49 59 31 25  28 37 29 0d 06 2c 28 c9  |(7),IY1%(7)..,(.|
00000f60  20 32 20 3a 20 24 53 50  6f 69 6e 74 25 28 32 29  | 2 : $SPoint%(2)|
00000f70  3d 22 66 72 70 64 6f 77  6e 22 3a f2 72 66 69 28  |="frpdown":.rfi(|
00000f80  69 25 29 0d 06 36 7c 20  20 20 20 20 20 20 20 20  |i%)..6|         |
00000f90  e7 20 53 74 61 72 74 4e  25 2d 31 3c 3e 2d 31 20  |. StartN%-1<>-1 |
00000fa0  8c 20 53 74 61 72 74 4e  25 2d 3d 31 3a 24 53 50  |. StartN%-=1:$SP|
00000fb0  6f 69 6e 74 25 28 37 29  3d 73 65 66 24 28 53 74  |oint%(7)=sef$(St|
00000fc0  61 72 74 4e 25 29 3a c8  99 22 57 69 6d 70 5f 46  |artN%):.."Wimp_F|
00000fd0  6f 72 63 65 52 65 64 72  61 77 22 2c 6d 6f 6e 57  |orceRedraw",monW|
00000fe0  25 2c 49 58 25 28 37 29  2c 49 59 25 28 37 29 2c  |%,IX%(7),IY%(7),|
00000ff0  49 58 31 25 28 37 29 2c  49 59 31 25 28 37 29 0d  |IX1%(7),IY1%(7).|
00001000  06 40 26 c9 20 33 20 3a  20 24 53 50 6f 69 6e 74  |.@&. 3 : $SPoint|
00001010  25 28 33 29 3d 22 66 72  70 75 70 22 3a f2 72 66  |%(3)="frpup":.rf|
00001020  69 28 69 25 29 0d 06 4a  75 20 20 20 20 20 20 20  |i(i%)..Ju       |
00001030  20 20 e7 20 45 6e 64 4e  25 2b 31 3c 3e 34 20 8c  |  . EndN%+1<>4 .|
00001040  20 45 6e 64 4e 25 2b 3d  31 3a 24 53 50 6f 69 6e  | EndN%+=1:$SPoin|
00001050  74 25 28 38 29 3d 73 65  66 24 28 45 6e 64 4e 25  |t%(8)=sef$(EndN%|
00001060  29 3a c8 99 22 57 69 6d  70 5f 46 6f 72 63 65 52  |):.."Wimp_ForceR|
00001070  65 64 72 61 77 22 2c 6d  6f 6e 57 25 2c 49 58 25  |edraw",monW%,IX%|
00001080  28 38 29 2c 49 59 25 28  38 29 2c 49 58 31 25 28  |(8),IY%(8),IX1%(|
00001090  38 29 2c 49 59 31 25 28  38 29 0d 06 54 28 c9 20  |8),IY1%(8)..T(. |
000010a0  34 20 3a 20 24 53 50 6f  69 6e 74 25 28 34 29 3d  |4 : $SPoint%(4)=|
000010b0  22 66 72 70 64 6f 77 6e  22 3a f2 72 66 69 28 69  |"frpdown":.rfi(i|
000010c0  25 29 0d 06 5e 7b 20 20  20 20 20 20 20 20 20 e7  |%)..^{         .|
000010d0  20 45 6e 64 4e 25 2d 31  3c 3e 53 74 61 72 74 4e  | EndN%-1<>StartN|
000010e0  25 20 8c 20 45 6e 64 4e  25 2d 3d 31 3a 24 53 50  |% . EndN%-=1:$SP|
000010f0  6f 69 6e 74 25 28 38 29  3d 73 65 66 24 28 45 6e  |oint%(8)=sef$(En|
00001100  64 4e 25 29 3a c8 99 22  57 69 6d 70 5f 46 6f 72  |dN%):.."Wimp_For|
00001110  63 65 52 65 64 72 61 77  22 2c 6d 6f 6e 57 25 2c  |ceRedraw",monW%,|
00001120  49 58 25 28 38 29 2c 49  59 25 28 38 29 2c 49 58  |IX%(8),IY%(8),IX|
00001130  31 25 28 38 29 2c 49 59  31 25 28 38 29 0d 06 68  |1%(8),IY1%(8)..h|
00001140  05 cb 0d 06 72 05 e1 0d  06 7c 04 0d 06 86 0e dd  |....r....|......|
00001150  20 f2 72 66 69 28 69 25  29 0d 06 90 40 c8 99 22  | .rfi(i%)...@.."|
00001160  57 69 6d 70 5f 46 6f 72  63 65 52 65 64 72 61 77  |Wimp_ForceRedraw|
00001170  22 2c 6d 6f 6e 57 25 2c  49 58 25 28 69 25 29 2c  |",monW%,IX%(i%),|
00001180  49 59 25 28 69 25 29 2c  49 58 31 25 28 69 25 29  |IY%(i%),IX1%(i%)|
00001190  2c 49 59 31 25 28 69 25  29 0d 06 9a 0e 42 75 74  |,IY1%(i%)....But|
000011a0  74 6f 6e 25 3d 69 25 0d  06 a4 05 e1 0d 06 ae 04  |ton%=i%.........|
000011b0  0d 06 b8 0c dd 20 f2 5f  4f 70 65 6e 0d 06 c2 2e  |..... ._Open....|
000011c0  c8 99 22 4f 53 5f 52 65  61 64 4d 6f 64 65 56 61  |.."OS_ReadModeVa|
000011d0  72 69 61 62 6c 65 22 2c  2d 31 2c 33 20 b8 20 2c  |riable",-1,3 . ,|
000011e0  2c 4e 63 6f 6c 6f 75 72  73 25 0d 06 cc 19 f4 20  |,Ncolours%..... |
000011f0  4f 50 45 4e 20 55 50 20  57 49 4e 44 4f 57 20 48  |OPEN UP WINDOW H|
00001200  45 52 45 0d 06 d6 0e e7  20 77 6f 70 65 6e 25 20  |ERE..... wopen% |
00001210  8c 0d 06 e0 0e 71 25 21  30 3d 6d 6f 6e 57 25 0d  |.....q%!0=monW%.|
00001220  06 ea 1f c8 99 22 57 69  6d 70 5f 47 65 74 57 69  |....."Wimp_GetWi|
00001230  6e 64 6f 77 53 74 61 74  65 22 2c 2c 71 25 0d 06  |ndowState",,q%..|
00001240  f4 36 20 20 e7 20 71 25  21 32 38 3c 3e 2d 31 20  |.6  . q%!28<>-1 |
00001250  8c 20 71 25 21 32 38 3d  2d 31 3a 20 c8 99 20 22  |. q%!28=-1: .. "|
00001260  57 69 6d 70 5f 4f 70 65  6e 57 69 6e 64 6f 77 22  |Wimp_OpenWindow"|
00001270  2c 2c 71 25 0d 06 fe 05  cc 0d 07 08 1d c8 99 20  |,,q%........... |
00001280  22 57 69 6d 70 5f 4f 70  65 6e 57 69 6e 64 6f 77  |"Wimp_OpenWindow|
00001290  22 2c 2c 57 6e 25 0d 07  12 0c 77 6f 70 65 6e 25  |",,Wn%....wopen%|
000012a0  3d b9 0d 07 1c 05 cd 0d  07 26 05 e1 0d 07 30 04  |=........&....0.|
000012b0  0d 07 3a 10 dd 20 f2 5f  64 6f 57 69 6e 64 6f 77  |..:.. ._doWindow|
000012c0  0d 07 44 10 20 20 ea 20  41 25 2c 49 25 2c 4c 25  |..D.  . A%,I%,L%|
000012d0  0d 07 4e 04 0d 07 58 15  20 20 20 f2 5f 54 72 61  |..N...X.   ._Tra|
000012e0  6e 73 28 6d 6f 6e 57 25  29 0d 07 62 29 20 20 20  |ns(monW%)..b)   |
000012f0  c8 99 20 22 57 69 6d 70  5f 52 65 64 72 61 77 57  |.. "Wimp_RedrawW|
00001300  69 6e 64 6f 77 22 2c 2c  71 25 20 b8 20 66 6c 61  |indow",,q% . fla|
00001310  67 25 0d 07 6c 11 20 20  20 20 20 c8 95 20 66 6c  |g%..l.     .. fl|
00001320  61 67 25 0d 07 76 04 0d  07 80 13 20 20 20 20 20  |ag%..v.....     |
00001330  f2 64 72 61 77 66 72 61  6d 65 0d 07 8a 11 20 20  |.drawframe....  |
00001340  20 20 20 f2 70 6c 6f 74  52 65 73 0d 07 94 2b 20  |   .plotRes...+ |
00001350  20 20 20 20 c8 99 20 22  57 69 6d 70 5f 47 65 74  |    .. "Wimp_Get|
00001360  52 65 63 74 61 6e 67 6c  65 22 2c 2c 71 25 20 b8  |Rectangle",,q% .|
00001370  20 66 6c 61 67 25 0d 07  9e 0a 20 20 20 20 20 ce  | flag%....     .|
00001380  0d 07 a8 06 20 20 0d 07  b2 07 20 20 e1 0d 07 bc  |....  ....  ....|
00001390  06 20 20 0d 07 c6 04 0d  07 d0 10 dd 20 f2 64 72  |.  ......... .dr|
000013a0  61 77 66 72 61 6d 65 0d  07 da 1e ea 20 57 25 2c  |awframe..... W%,|
000013b0  4c 25 2c 41 25 2c 48 25  2c 4f 73 25 2c 47 25 2c  |L%,A%,H%,Os%,G%,|
000013c0  44 25 2c 4c 32 0d 07 e4  24 4c 25 3d 36 34 30 3a  |D%,L2...$L%=640:|
000013d0  57 25 3d 31 30 3a 41 25  3d 36 34 3a 4f 73 25 3d  |W%=10:A%=64:Os%=|
000013e0  35 30 3a 48 25 3d 33 34  30 0d 07 ee 18 c8 99 22  |50:H%=340......"|
000013f0  57 69 6d 70 5f 53 65 74  43 6f 6c 6f 75 72 22 2c  |Wimp_SetColour",|
00001400  31 0d 07 f8 1d c8 93 c8  90 20 78 6f 25 2b 4f 73  |1........ xo%+Os|
00001410  25 2c 79 6f 25 2b 41 25  2c 4c 25 2c 48 25 0d 08  |%,yo%+A%,L%,H%..|
00001420  02 04 0d 08 0c 18 c8 99  22 57 69 6d 70 5f 53 65  |........"Wimp_Se|
00001430  74 43 6f 6c 6f 75 72 22  2c 37 0d 08 16 1d c8 93  |tColour",7......|
00001440  c8 90 20 78 6f 25 2b 4f  73 25 2c 79 6f 25 2b 41  |.. xo%+Os%,yo%+A|
00001450  25 2c 4c 25 2c 57 25 0d  08 20 23 c8 93 c8 90 20  |%,L%,W%.. #.... |
00001460  78 6f 25 2b 4f 73 25 2c  79 6f 25 2b 41 25 2d 57  |xo%+Os%,yo%+A%-W|
00001470  25 2b 48 25 2c 4c 25 2c  57 25 0d 08 2a 1d c8 93  |%+H%,L%,W%..*...|
00001480  c8 90 20 78 6f 25 2b 4f  73 25 2c 79 6f 25 2b 41  |.. xo%+Os%,yo%+A|
00001490  25 2c 57 25 2c 48 25 0d  08 34 20 c8 93 c8 90 20  |%,W%,H%..4 .... |
000014a0  78 6f 25 2b 4f 73 25 2b  4c 25 2c 79 6f 25 2b 41  |xo%+Os%+L%,yo%+A|
000014b0  25 2c 57 25 2c 48 25 0d  08 3e 0d e7 20 47 52 49  |%,W%,H%..>.. GRI|
000014c0  44 25 20 8c 0d 08 48 0e  e3 20 42 25 3d 30 20 b8  |D% ...H.. B%=0 .|
000014d0  20 37 0d 08 52 44 86 20  78 6f 25 2b 4f 73 25 2c  | 7..RD. xo%+Os%,|
000014e0  79 6f 25 2b 41 25 2b 31  34 2b 33 30 36 2d 42 25  |yo%+A%+14+306-B%|
000014f0  2a 34 32 2e 35 2c 78 6f  25 2b 4f 73 25 2b 4c 25  |*42.5,xo%+Os%+L%|
00001500  2c 79 6f 25 2b 41 25 2b  31 34 2b 33 30 36 2d 42  |,yo%+A%+14+306-B|
00001510  25 2a 34 32 2e 35 0d 08  5c 05 ed 0d 08 66 19 4c  |%*42.5..\....f.L|
00001520  32 3d 4c 25 2f 28 45 6e  64 4e 25 2d 53 74 61 72  |2=L%/(EndN%-Star|
00001530  74 4e 25 29 0d 08 70 1c  e3 20 44 25 3d 30 20 b8  |tN%)..p.. D%=0 .|
00001540  20 45 6e 64 4e 25 2d 53  74 61 72 74 4e 25 2d 31  | EndN%-StartN%-1|
00001550  0d 08 7a 0e e3 20 42 25  3d 31 20 b8 20 39 0d 08  |..z.. B%=1 . 9..|
00001560  84 15 47 25 3d ab 28 42  25 29 2a 4c 32 2b 4c 32  |..G%=.(B%)*L2+L2|
00001570  2a 44 25 0d 08 8e 32 86  20 78 6f 25 2b 31 32 2b  |*D%...2. xo%+12+|
00001580  4f 73 25 2b 47 25 2c 79  6f 25 2b 41 25 2c 78 6f  |Os%+G%,yo%+A%,xo|
00001590  25 2b 31 32 2b 4f 73 25  2b 47 25 2c 79 6f 25 2b  |%+12+Os%+G%,yo%+|
000015a0  41 25 2b 48 25 0d 08 98  05 ed 0d 08 a2 05 ed 0d  |A%+H%...........|
000015b0  08 ac 05 cd 0d 08 b6 05  e1 0d 08 c0 04 0d 08 ca  |................|
000015c0  0e dd 20 f2 70 6c 6f 74  52 65 73 0d 08 d4 12 ea  |.. .plotRes.....|
000015d0  20 41 25 2c 42 25 2c 4f  73 25 2c 59 25 0d 08 de  | A%,B%,Os%,Y%...|
000015e0  19 c8 99 22 57 69 6d 70  5f 53 65 74 43 6f 6c 6f  |..."Wimp_SetColo|
000015f0  75 72 22 2c 31 30 0d 08  e8 10 41 25 3d 37 36 3a  |ur",10....A%=76:|
00001600  4f 73 25 3d 36 32 0d 08  f2 10 e7 20 42 6c 6f 63  |Os%=62..... Bloc|
00001610  6b 25 3d 31 20 8c 0d 08  fc 0e 59 25 3d 52 65 73  |k%=1 .....Y%=Res|
00001620  25 28 30 29 0d 09 06 1a  ec 20 78 6f 25 2b 4f 73  |%(0)..... xo%+Os|
00001630  25 2b 42 25 2c 79 6f 25  2b 59 25 2b 41 25 0d 09  |%+B%,yo%+Y%+A%..|
00001640  10 10 e3 20 42 25 3d 31  20 b8 20 33 31 33 0d 09  |... B%=1 . 313..|
00001650  1a 0f 59 25 3d 52 65 73  25 28 42 25 29 0d 09 24  |..Y%=Res%(B%)..$|
00001660  1c df 20 78 6f 25 2b 4f  73 25 2b 42 25 2a 32 2c  |.. xo%+Os%+B%*2,|
00001670  79 6f 25 2b 59 25 2b 41  25 0d 09 2e 05 ed 0d 09  |yo%+Y%+A%.......|
00001680  38 05 cc 0d 09 42 1a 20  e3 20 42 25 3d 31 20 b8  |8....B. . B%=1 .|
00001690  20 33 31 32 20 88 20 42  6c 6f 63 6b 25 0d 09 4c  | 312 . Block%..L|
000016a0  47 20 e7 20 52 65 73 25  28 42 25 29 3c 3e 30 20  |G . Res%(B%)<>0 |
000016b0  8c 20 c8 93 c8 90 20 78  6f 25 2b 36 32 2b 42 25  |. .... xo%+62+B%|
000016c0  2a 32 2c 79 6f 25 2b 52  65 73 25 28 42 25 29 2b  |*2,yo%+Res%(B%)+|
000016d0  37 36 2c 42 6c 6f 63 6b  25 2a 32 2c 42 6c 6f 63  |76,Block%*2,Bloc|
000016e0  6b 25 2a 32 0d 09 56 06  20 ed 0d 09 60 05 cd 0d  |k%*2..V. ...`...|
000016f0  09 6a 05 e1 0d 09 74 04  0d 09 7e 12 dd 20 f2 5f  |.j....t...~.. ._|
00001700  54 72 61 6e 73 28 77 68  25 29 0d 09 88 0b 21 71  |Trans(wh%)....!q|
00001710  25 3d 77 68 25 0d 09 92  20 c8 99 20 22 57 69 6d  |%=wh%... .. "Wim|
00001720  70 5f 47 65 74 57 69 6e  64 6f 77 53 74 61 74 65  |p_GetWindowState|
00001730  22 2c 2c 71 25 0d 09 9c  26 78 6f 25 3d 71 25 21  |",,q%...&xo%=q%!|
00001740  34 2d 71 25 21 32 30 3a  79 6f 25 3d 71 25 21 31  |4-q%!20:yo%=q%!1|
00001750  36 2d 71 25 21 32 34 2d  34 34 30 0d 09 a6 16 58  |6-q%!24-440....X|
00001760  4f 25 3d 71 25 21 34 3a  59 4f 25 3d 71 25 21 31  |O%=q%!4:YO%=q%!1|
00001770  36 0d 09 b0 05 e1 0d 09  ba 04 0d 09 c4 0f dd f2  |6...............|
00001780  73 65 74 75 70 6d 65 6e  75 0d 09 ce 08 ea 20 6d  |setupmenu..... m|
00001790  25 0d 09 d8 04 0d 09 e2  13 24 6b 65 79 6d 65 6e  |%........$keymen|
000017a0  75 25 3d 22 4b 65 79 22  0d 09 ec 11 6b 65 79 6d  |u%="Key"....keym|
000017b0  65 6e 75 25 3f 31 32 3d  37 0d 09 f6 11 6b 65 79  |enu%?12=7....key|
000017c0  6d 65 6e 75 25 3f 31 33  3d 32 0d 0a 00 11 6b 65  |menu%?13=2....ke|
000017d0  79 6d 65 6e 75 25 3f 31  34 3d 37 0d 0a 0a 11 6b  |ymenu%?14=7....k|
000017e0  65 79 6d 65 6e 75 25 3f  31 35 3d 30 0d 0a 14 13  |eymenu%?15=0....|
000017f0  6b 65 79 6d 65 6e 75 25  21 31 36 3d 31 32 38 0d  |keymenu%!16=128.|
00001800  0a 1e 12 6b 65 79 6d 65  6e 75 25 21 32 30 3d 34  |...keymenu%!20=4|
00001810  30 0d 0a 28 11 6b 65 79  6d 65 6e 75 25 21 32 34  |0..(.keymenu%!24|
00001820  3d 30 0d 0a 32 12 6d 25  3d 6b 65 79 6d 65 6e 75  |=0..2.m%=keymenu|
00001830  25 2b 32 38 0d 0a 3c 04  0d 0a 46 0a 6d 25 21 30  |%+28..<...F.m%!0|
00001840  3d 30 0d 0a 50 0a 6d 25  21 34 3d 30 0d 0a 5a 18  |=0..P.m%!4=0..Z.|
00001850  6d 25 21 38 3d 28 37 3c  3c 32 34 29 84 20 25 31  |m%!8=(7<<24). %1|
00001860  30 30 30 31 0d 0a 64 13  24 28 6d 25 2b 31 32 29  |0001..d.$(m%+12)|
00001870  3d 22 42 65 73 74 22 0d  0a 6e 04 0d 0a 78 0a 6d  |="Best"..n...x.m|
00001880  25 2b 3d 32 34 0d 0a 82  0a 6d 25 21 30 3d 30 0d  |%+=24....m%!0=0.|
00001890  0a 8c 0a 6d 25 21 34 3d  30 0d 0a 96 18 6d 25 21  |...m%!4=0....m%!|
000018a0  38 3d 28 37 3c 3c 32 34  29 84 20 25 31 30 30 30  |8=(7<<24). %1000|
000018b0  31 0d 0a a0 13 24 28 6d  25 2b 31 32 29 3d 22 46  |1....$(m%+12)="F|
000018c0  69 6e 65 22 0d 0a aa 0a  6d 25 2b 3d 32 34 0d 0a  |ine"....m%+=24..|
000018d0  b4 0a 6d 25 21 30 3d 31  0d 0a be 0a 6d 25 21 34  |..m%!0=1....m%!4|
000018e0  3d 30 0d 0a c8 18 6d 25  21 38 3d 28 37 3c 3c 32  |=0....m%!8=(7<<2|
000018f0  34 29 84 20 25 31 30 30  30 31 0d 0a d2 15 24 28  |4). %10001....$(|
00001900  6d 25 2b 31 32 29 3d 22  4d 65 64 69 75 6d 22 0d  |m%+12)="Medium".|
00001910  0a dc 0a 6d 25 2b 3d 32  34 0d 0a e6 0a 6d 25 21  |...m%+=24....m%!|
00001920  30 3d 30 0d 0a f0 0a 6d  25 21 34 3d 30 0d 0a fa  |0=0....m%!4=0...|
00001930  18 6d 25 21 38 3d 28 37  3c 3c 32 34 29 84 20 25  |.m%!8=(7<<24). %|
00001940  31 30 30 30 31 0d 0b 04  14 24 28 6d 25 2b 31 32  |10001....$(m%+12|
00001950  29 3d 22 43 6f 72 73 65  22 0d 0b 0e 0a 6d 25 2b  |)="Corse"....m%+|
00001960  3d 32 34 0d 0b 18 0c 6d  25 21 30 3d 26 38 30 0d  |=24....m%!0=&80.|
00001970  0b 22 0a 6d 25 21 34 3d  30 0d 0b 2c 18 6d 25 21  |.".m%!4=0..,.m%!|
00001980  38 3d 28 37 3c 3c 32 34  29 84 20 25 31 30 30 30  |8=(7<<24). %1000|
00001990  31 0d 0b 36 14 24 28 6d  25 2b 31 32 29 3d 22 51  |1..6.$(m%+12)="Q|
000019a0  75 69 63 6b 22 0d 0b 40  04 0d 0b 4a 04 0d 0b 54  |uick"..@...J...T|
000019b0  12 24 6d 65 6e 75 25 3d  22 53 6f 75 6e 64 22 0d  |.$menu%="Sound".|
000019c0  0b 5e 0e 6d 65 6e 75 25  3f 31 32 3d 37 0d 0b 68  |.^.menu%?12=7..h|
000019d0  0e 6d 65 6e 75 25 3f 31  33 3d 32 0d 0b 72 0e 6d  |.menu%?13=2..r.m|
000019e0  65 6e 75 25 3f 31 34 3d  37 0d 0b 7c 0e 6d 65 6e  |enu%?14=7..|.men|
000019f0  75 25 3f 31 35 3d 30 0d  0b 86 10 6d 65 6e 75 25  |u%?15=0....menu%|
00001a00  21 31 36 3d 31 32 38 0d  0b 90 0f 6d 65 6e 75 25  |!16=128....menu%|
00001a10  21 32 30 3d 34 30 0d 0b  9a 0e 6d 65 6e 75 25 21  |!20=40....menu%!|
00001a20  32 34 3d 30 0d 0b a4 0f  6d 25 3d 6d 65 6e 75 25  |24=0....m%=menu%|
00001a30  2b 32 38 0d 0b ae 0a 6d  25 21 30 3d 30 0d 0b b8  |+28....m%!0=0...|
00001a40  0e 6d 25 21 34 3d 69 6e  66 6f 25 0d 0b c2 18 6d  |.m%!4=info%....m|
00001a50  25 21 38 3d 28 37 3c 3c  32 34 29 84 20 25 31 30  |%!8=(7<<24). %10|
00001a60  30 30 31 0d 0b cc 13 24  28 6d 25 2b 31 32 29 3d  |001....$(m%+12)=|
00001a70  22 49 6e 66 6f 22 0d 0b  d6 04 0d 0b e0 0a 6d 25  |"Info"........m%|
00001a80  2b 3d 32 34 0d 0b ea 0a  6d 25 21 30 3d 30 0d 0b  |+=24....m%!0=0..|
00001a90  f4 0a 6d 25 21 34 3d 30  0d 0b fe 18 6d 25 21 38  |..m%!4=0....m%!8|
00001aa0  3d 28 37 3c 3c 32 34 29  84 20 25 31 30 30 30 31  |=(7<<24). %10001|
00001ab0  0d 0c 08 14 24 28 6d 25  2b 31 32 29 3d 22 4c 69  |....$(m%+12)="Li|
00001ac0  6e 65 72 22 0d 0c 12 04  0d 0c 1c 0a 6d 25 2b 3d  |ner"........m%+=|
00001ad0  32 34 0d 0c 26 0a 6d 25  21 30 3d 31 0d 0c 30 0a  |24..&.m%!0=1..0.|
00001ae0  6d 25 21 34 3d 30 0d 0c  3a 18 6d 25 21 38 3d 28  |m%!4=0..:.m%!8=(|
00001af0  37 3c 3c 32 34 29 84 20  25 31 30 30 30 31 0d 0c  |7<<24). %10001..|
00001b00  44 12 24 28 6d 25 2b 31  32 29 3d 22 4c 6f 67 22  |D.$(m%+12)="Log"|
00001b10  0d 0c 4e 04 0d 0c 58 0a  6d 25 2b 3d 32 34 0d 0c  |..N...X.m%+=24..|
00001b20  62 0a 6d 25 21 30 3d 30  0d 0c 6c 11 6d 25 21 34  |b.m%!0=0..l.m%!4|
00001b30  3d 6b 65 79 6d 65 6e 75  25 0d 0c 76 18 6d 25 21  |=keymenu%..v.m%!|
00001b40  38 3d 28 37 3c 3c 32 34  29 84 20 25 31 30 30 30  |8=(7<<24). %1000|
00001b50  31 0d 0c 80 1a 24 28 6d  25 2b 31 32 29 3d 22 52  |1....$(m%+12)="R|
00001b60  65 73 6f 6c 6f 75 74 69  6f 6e 22 0d 0c 94 04 0d  |esoloution".....|
00001b70  0c 9e 0a 6d 25 2b 3d 32  34 0d 0c a8 0c 6d 25 21  |...m%+=24....m%!|
00001b80  30 3d 26 38 30 0d 0c b2  0a 6d 25 21 34 3d 30 0d  |0=&80....m%!4=0.|
00001b90  0c bc 18 6d 25 21 38 3d  28 37 3c 3c 32 34 29 84  |...m%!8=(7<<24).|
00001ba0  20 25 31 30 30 30 31 0d  0c c6 13 24 28 6d 25 2b  | %10001....$(m%+|
00001bb0  31 32 29 3d 22 51 75 69  74 22 0d 0c d0 04 0d 0c  |12)="Quit"......|
00001bc0  da 05 e1 0d 0c e4 04 0d  0c ee 12 dd 20 f2 72 65  |............ .re|
00001bd0  63 65 69 76 65 28 71 25  29 0d 0c f8 08 ea 20 41  |ceive(q%)..... A|
00001be0  25 0d 0d 02 0c 41 25 3d  71 25 21 31 36 0d 0d 0c  |%....A%=q%!16...|
00001bf0  0b c8 8e 20 41 25 20 ca  0d 0d 16 0c c9 20 30 3a  |... A% ...... 0:|
00001c00  f2 64 69 65 0d 0d 20 14  c9 20 26 35 30 32 3a 20  |.die.. .. &502: |
00001c10  20 20 c8 8e 20 b9 20 ca  0d 0d 2a 81 20 20 20 20  |  .. . ...*.    |
00001c20  20 20 20 20 20 20 20 20  20 c9 20 71 25 21 33 32  |         . q%!32|
00001c30  3d 2d 32 20 80 20 71 25  21 33 36 3d 73 6d 70 69  |=-2 . q%!36=smpi|
00001c40  63 6f 6e 25 3a 6d 65 73  24 3d 22 54 68 69 73 20  |con%:mes$="This |
00001c50  69 73 20 74 68 65 20 46  72 65 71 75 6e 63 79 20  |is the Frequncy |
00001c60  52 65 73 70 6f 6e 63 65  20 69 63 6f 6e 2e 7c 4d  |Responce icon.|M|
00001c70  50 6c 6f 74 20 74 68 65  20 66 72 65 71 75 6e 63  |Plot the frequnc|
00001c80  79 20 72 65 73 70 6f 6e  63 65 20 6f 66 20 61 20  |y responce of a |
00001c90  63 69 72 63 75 69 74 2e  22 0d 0d 34 1a 20 20 20  |circuit."..4.   |
00001ca0  20 20 20 20 20 20 20 20  20 20 7f 3a 6d 65 73 24  |          .:mes$|
00001cb0  3d 22 22 0d 0d 3e 12 20  20 20 20 20 20 20 20 20  |=""..>.         |
00001cc0  20 20 20 20 cb 0d 0d 48  14 20 20 20 20 e7 20 6d  |    ...H.    . m|
00001cd0  65 73 24 3c 3e 22 22 20  8c 0d 0d 52 12 20 20 20  |es$<>"" ...R.   |
00001ce0  20 71 25 21 31 32 3d 71  25 21 38 0d 0d 5c 18 20  | q%!12=q%!8..\. |
00001cf0  20 20 20 24 28 71 25 2b  32 30 29 3d 6d 65 73 24  |   $(q%+20)=mes$|
00001d00  2b bd 30 0d 0d 66 1e 20  20 20 20 71 25 21 30 3d  |+.0..f.    q%!0=|
00001d10  28 32 30 2b a9 6d 65 73  24 2b 34 29 80 20 ac 20  |(20+.mes$+4). . |
00001d20  33 0d 0d 70 12 20 20 20  20 71 25 21 31 36 3d 26  |3..p.    q%!16=&|
00001d30  35 30 33 0d 0d 7a 28 20  20 20 20 c8 99 20 22 57  |503..z(    .. "W|
00001d40  69 6d 70 5f 53 65 6e 64  4d 65 73 73 61 67 65 22  |imp_SendMessage"|
00001d50  2c 31 38 2c 71 25 2c 71  25 21 34 0d 0d 84 05 cb  |,18,q%,q%!4.....|
00001d60  0d 0d 8e 05 e1 0d 0d 98  04 0d 0d a2 0c dd 20 f2  |.............. .|
00001d70  5f 44 61 63 6b 0d 0d ac  10 73 65 6e 64 74 68 25  |_Dack....sendth%|
00001d80  3d 71 25 21 34 0d 0d b6  0f 6d 79 72 65 66 25 3d  |=q%!4....myref%=|
00001d90  71 25 21 38 0d 0d c0 22  c8 99 20 22 57 69 6d 70  |q%!8...".. "Wimp|
00001da0  5f 47 65 74 50 6f 69 6e  74 65 72 49 6e 66 6f 22  |_GetPointerInfo"|
00001db0  2c 2c 71 25 2b 38 0d 0d  ca 0e 71 25 21 32 38 3d  |,,q%+8....q%!28=|
00001dc0  71 25 21 38 0d 0d d4 0f  71 25 21 33 32 3d 71 25  |q%!8....q%!32=q%|
00001dd0  21 31 32 0d 0d de 18 71  25 21 30 3d 28 34 34 2b  |!12....q%!0=(44+|
00001de0  a9 6e 24 2b 34 29 80 20  ac 20 33 0d 0d e8 10 71  |.n$+4). . 3....q|
00001df0  25 21 31 32 3d 6d 79 72  65 66 25 0d 0d f2 0b 71  |%!12=myref%....q|
00001e00  25 21 31 36 3d 34 0d 0d  fc 0c 71 25 21 33 36 3d  |%!16=4....q%!36=|
00001e10  2d 31 0d 0e 06 0e 71 25  21 34 30 3d 26 46 46 39  |-1....q%!40=&FF9|
00001e20  0d 0e 10 12 24 28 71 25  2b 34 34 29 3d 6e 24 2b  |....$(q%+44)=n$+|
00001e30  bd 30 0d 0e 1a 27 c8 99  20 22 57 69 6d 70 5f 53  |.0...'.. "Wimp_S|
00001e40  65 6e 64 4d 65 73 73 61  67 65 22 2c 31 37 2c 71  |endMessage",17,q|
00001e50  25 2c 73 65 6e 64 74 68  25 0d 0e 24 05 cd 0d 0e  |%,sendth%..$....|
00001e60  2e 05 e1 0d 0e 38 04 0d  0e 42 0e dd a4 73 67 65  |.....8...B...sge|
00001e70  74 28 78 25 29 0d 0e 4c  08 ea 20 78 24 0d 0e 56  |t(x%)..L.. x$..V|
00001e80  1d c8 95 20 3f 78 25 20  78 24 2b 3d bd 28 3f 78  |... ?x% x$+=.(?x|
00001e90  25 29 3a 78 25 2b 3d 31  3a ce 0d 0e 60 07 3d 78  |%):x%+=1:...`.=x|
00001ea0  24 0d 0e 6a 04 0d 0e 74  0a dd a4 69 63 6f 6e 0d  |$..j...t...icon.|
00001eb0  0e 7e 0b 71 25 21 30 3d  2d 31 0d 0e 88 0a 71 25  |.~.q%!0=-1....q%|
00001ec0  21 34 3d 30 0d 0e 92 1a  71 25 21 38 3d 30 20 3a  |!4=0....q%!8=0 :|
00001ed0  20 f4 20 59 20 44 49 52  45 43 54 49 4f 4e 0d 0e  | . Y DIRECTION..|
00001ee0  9c 1c 71 25 21 31 32 3d  37 30 20 3a 20 f4 20 58  |..q%!12=70 : . X|
00001ef0  20 44 49 52 45 43 54 49  4f 4e 0d 0e a6 0c 71 25  | DIRECTION....q%|
00001f00  21 31 36 3d 39 36 0d 0e  b0 0f 71 25 21 32 30 3d  |!16=96....q%!20=|
00001f10  26 32 30 30 32 0d 0e ba  14 24 28 71 25 2b 32 34  |&2002....$(q%+24|
00001f20  29 3d 22 21 46 72 65 71  22 0d 0e c4 24 c8 99 20  |)="!Freq"...$.. |
00001f30  22 57 69 6d 70 5f 43 72  65 61 74 65 49 63 6f 6e  |"Wimp_CreateIcon|
00001f40  22 2c 2c 71 25 20 b8 20  69 63 6f 6e 25 0d 0e ce  |",,q% . icon%...|
00001f50  0a 3d 69 63 6f 6e 25 0d  0e d8 04 0d 0e e2 12 dd  |.=icon%.........|
00001f60  20 f2 5f 73 65 74 75 70  57 28 74 24 29 0d 0e ec  | ._setupW(t$)...|
00001f70  58 21 71 25 3d 77 61 72  6e 69 6e 67 57 25 3a 71  |X!q%=warningW%:q|
00001f80  25 21 34 3d 32 30 30 3a  71 25 21 38 3d 32 30 30  |%!4=200:q%!8=200|
00001f90  3a 71 25 21 31 32 3d 32  30 30 2b 58 51 25 3a 71  |:q%!12=200+XQ%:q|
00001fa0  25 21 31 36 3d 32 30 30  2b 59 51 25 3a 71 25 21  |%!16=200+YQ%:q%!|
00001fb0  32 30 3d 30 3a 71 25 21  32 34 3d 30 3a 71 25 21  |20=0:q%!24=0:q%!|
00001fc0  32 38 3d 2d 31 0d 0e f6  11 24 54 65 78 74 57 61  |28=-1....$TextWa|
00001fd0  72 6e 25 3d 74 24 0d 0f  00 15 54 65 78 74 57 61  |rn%=t$....TextWa|
00001fe0  72 6e 25 3f a9 28 74 24  29 3d 30 0d 0f 0a 07 ef  |rn%?.(t$)=0.....|
00001ff0  20 37 0d 0f 14 0d 77 61  72 6e 4f 6e 25 3d b9 0d  | 7....warnOn%=..|
00002000  0f 1e 1c c8 99 20 22 57  69 6d 70 5f 4f 70 65 6e  |..... "Wimp_Open|
00002010  57 69 6e 64 6f 77 22 2c  2c 71 25 0d 0f 28 05 e1  |Window",,q%..(..|
00002020  0d 0f 32 04 0d 0f 3c 0f  dd 20 f2 65 72 72 6f 72  |..2...<.. .error|
00002030  62 6f 78 0d 0f 46 19 c8  99 20 22 57 69 6d 70 5f  |box..F... "Wimp_|
00002040  44 72 61 67 42 6f 78 22  2c 2c 2d 31 0d 0f 50 32  |DragBox",,-1..P2|
00002050  21 62 75 66 66 65 72 73  25 3d 9f 3a 24 28 62 75  |!buffers%=.:$(bu|
00002060  66 66 65 72 73 25 2b 34  29 3d f6 24 2b 22 20 61  |ffers%+4)=.$+" a|
00002070  74 20 6c 69 6e 65 20 22  2b c3 9e 2b bd 30 0d 0f  |t line "+..+.0..|
00002080  5a 38 c8 99 20 22 57 69  6d 70 5f 52 65 70 6f 72  |Z8.. "Wimp_Repor|
00002090  74 45 72 72 6f 72 22 2c  62 75 66 66 65 72 73 25  |tError",buffers%|
000020a0  2c 31 2c 22 46 72 65 71  75 6e 63 79 20 52 65 73  |,1,"Frequncy Res|
000020b0  70 6f 6e 63 65 22 0d 0f  64 08 f2 64 69 65 0d 0f  |ponce"..d..die..|
000020c0  6e 05 e1 0d 0f 78 04 0d  0f 82 09 dd f2 64 69 65  |n....x.......die|
000020d0  0d 0f 8c 09 ee 20 85 20  87 0d 0f 96 2a c8 99 20  |..... . ....*.. |
000020e0  22 57 69 6d 70 5f 43 6c  6f 73 65 44 6f 77 6e 22  |"Wimp_CloseDown"|
000020f0  2c 74 61 73 6b 68 61 6e  64 25 2c 21 74 61 73 6b  |,taskhand%,!task|
00002100  69 64 25 0d 0f a0 05 e0  0d 0f aa 05 e1 0d 0f b4  |id%.............|
00002110  04 0d 0f be 14 dd 20 f2  67 65 74 77 28 68 61 6e  |...... .getw(han|
00002120  64 6c 65 25 29 0d 0f c8  38 21 71 25 3d 68 61 6e  |dle%)...8!q%=han|
00002130  64 6c 65 25 3a c8 99 20  22 57 69 6d 70 5f 47 65  |dle%:.. "Wimp_Ge|
00002140  74 57 69 6e 64 6f 77 53  74 61 74 65 22 2c 2c 71  |tWindowState",,q|
00002150  25 3a f2 69 6e 66 6f 28  71 25 2b 34 29 0d 0f d2  |%:.info(q%+4)...|
00002160  05 e1 0d 0f dc 12 dd 20  f2 67 65 74 69 28 68 25  |....... .geti(h%|
00002170  2c 69 25 29 0d 0f e6 2d  21 71 25 3d 68 25 3a 71  |,i%)...-!q%=h%:q|
00002180  25 21 34 3d 69 25 3a c8  99 20 22 57 69 6d 70 5f  |%!4=i%:.. "Wimp_|
00002190  47 65 74 49 63 6f 6e 53  74 61 74 65 22 2c 2c 71  |GetIconState",,q|
000021a0  25 0d 0f f0 2e 69 78 30  25 3d 71 25 21 38 3a 69  |%....ix0%=q%!8:i|
000021b0  79 30 25 3d 71 25 21 31  32 3a 69 78 31 25 3d 71  |y0%=q%!12:ix1%=q|
000021c0  25 21 31 36 3a 69 79 31  25 3d 71 25 21 32 30 0d  |%!16:iy1%=q%!20.|
000021d0  0f fa 1e 69 66 6c 61 67  73 25 3d 71 25 21 32 34  |...iflags%=q%!24|
000021e0  3a 69 64 61 74 61 25 3d  71 25 2b 32 38 0d 10 04  |:idata%=q%+28...|
000021f0  05 e1 0d 10 0e 04 0d 10  18 0f dd 20 f2 69 6e 66  |........... .inf|
00002200  6f 28 70 25 29 0d 10 22  0d ea 20 78 30 25 2c 79  |o(p%)..".. x0%,y|
00002210  30 25 0d 10 2c 27 78 30  25 3d 21 70 25 3a 79 30  |0%..,'x0%=!p%:y0|
00002220  25 3d 70 25 21 34 3a 78  31 25 3d 70 25 21 38 3a  |%=p%!4:x1%=p%!8:|
00002230  79 31 25 3d 70 25 21 31  32 0d 10 36 35 73 63 78  |y1%=p%!12..65scx|
00002240  25 3d 70 25 21 31 36 3a  73 63 79 25 3d 70 25 21  |%=p%!16:scy%=p%!|
00002250  32 30 3a 62 68 61 6e 64  6c 65 25 3d 70 25 21 32  |20:bhandle%=p%!2|
00002260  34 3a 66 6c 61 67 73 25  3d 70 25 21 32 38 0d 10  |4:flags%=p%!28..|
00002270  40 1d 62 78 25 3d 78 30  25 2d 73 63 78 25 3a 62  |@.bx%=x0%-scx%:b|
00002280  79 25 3d 79 31 25 2d 73  63 79 25 0d 10 4a 05 e1  |y%=y1%-scy%..J..|
00002290  0d 10 54 04 0d 10 5e 10  dd 20 f2 5f 4b 65 79 50  |..T...^.. ._KeyP|
000022a0  72 65 73 73 0d 10 68 0d  c8 8e 20 71 25 21 30 20  |ress..h... q%!0 |
000022b0  ca 0d 10 72 2b f4 20 4f  54 48 45 52 57 49 53 45  |...r+. OTHERWISE|
000022c0  3a 20 53 59 53 22 57 69  6d 70 5f 50 72 6f 63 65  |: SYS"Wimp_Proce|
000022d0  73 73 4b 65 79 22 2c 71  25 21 32 34 0d 10 7c 05  |ssKey",q%!24..|.|
000022e0  cb 0d 10 86 05 e1 0d 10  90 04 0d 10 9a 0b dd 20  |............... |
000022f0  f2 69 6e 69 74 0d 10 a4  0d 2a 41 75 64 69 6f 20  |.init....*Audio |
00002300  4f 4e 0d 10 ae 22 c8 99  22 53 6f 75 6e 64 5f 56  |ON...".."Sound_V|
00002310  6f 6c 75 6d 65 22 2c 31  32 37 20 b8 20 55 73 65  |olume",127 . Use|
00002320  72 56 6f 6c 0d 10 b8 10  e3 20 73 25 3d 30 20 b8  |rVol..... s%=0 .|
00002330  20 32 35 35 0d 10 c2 38  20 c8 99 22 53 6f 75 6e  | 255...8 .."Soun|
00002340  64 5f 53 6f 75 6e 64 4c  6f 67 22 2c 26 37 46 46  |d_SoundLog",&7FF|
00002350  46 46 46 46 46 2a b5 28  32 2a af 2a 73 25 2f 32  |FFFFF*.(2*.*s%/2|
00002360  35 36 29 20 b8 20 57 54  25 3f 73 25 0d 10 cc 05  |56) . WT%?s%....|
00002370  ed 0d 10 d6 12 e3 20 73  25 3d 32 35 36 20 b8 20  |...... s%=256 . |
00002380  35 31 31 0d 10 e0 37 20  c8 99 22 53 6f 75 6e 64  |511...7 .."Sound|
00002390  5f 53 6f 75 6e 64 4c 6f  67 22 2c 26 37 46 46 46  |_SoundLog",&7FFF|
000023a0  46 46 46 46 2a b5 28 32  2a af 2a 73 25 2f 36 34  |FFFF*.(2*.*s%/64|
000023b0  29 20 b8 20 57 54 25 3f  73 25 0d 10 ea 05 ed 0d  |) . WT%?s%......|
000023c0  10 f4 04 0d 10 fe 2a f4  20 53 59 53 22 53 6f 75  |......*. SYS"Sou|
000023d0  6e 64 5f 56 6f 6c 75 6d  65 22 2c 55 73 65 72 56  |nd_Volume",UserV|
000023e0  6f 6c 20 54 4f 20 55 73  65 72 56 6f 6c 0d 11 08  |ol TO UserVol...|
000023f0  04 0d 11 12 14 e3 20 43  25 20 3d 20 30 20 b8 20  |...... C% = 0 . |
00002400  32 20 88 20 32 0d 11 1c  0c 50 25 3d 43 6f 64 65  |2 . 2....P%=Code|
00002410  25 0d 11 26 0c 5b 20 4f  50 54 20 43 25 0d 11 30  |%..&.[ OPT C%..0|
00002420  0e 2e 56 6f 69 63 65 42  61 73 65 0d 11 3a 10 42  |..VoiceBase..:.B|
00002430  20 20 20 20 20 20 20 46  69 6c 6c 0d 11 44 10 42  |       Fill..D.B|
00002440  20 20 20 20 20 20 20 46  69 6c 6c 0d 11 4e 12 42  |       Fill..N.B|
00002450  20 20 20 20 20 20 20 47  61 74 65 4f 6e 0d 11 58  |       GateOn..X|
00002460  13 42 20 20 20 20 20 20  20 47 61 74 65 4f 66 66  |.B       GateOff|
00002470  0d 11 62 14 42 20 20 20  20 20 20 20 49 6e 73 74  |..b.B       Inst|
00002480  61 6e 63 65 0d 11 6c 15  4c 44 4d 46 44 20 20 20  |ance..l.LDMFD   |
00002490  52 31 33 21 2c 7b 50 43  7d 0d 11 76 15 4c 44 4d  |R13!,{PC}..v.LDM|
000024a0  46 44 20 20 20 52 31 33  21 2c 7b 50 43 7d 0d 11  |FD   R13!,{PC}..|
000024b0  80 21 45 51 55 44 20 20  20 20 56 6f 69 63 65 4e  |.!EQUD    VoiceN|
000024c0  61 6d 65 20 2d 20 56 6f  69 63 65 42 61 73 65 0d  |ame - VoiceBase.|
000024d0  11 8a 21 2e 56 6f 69 63  65 4e 61 6d 65 20 20 20  |..!.VoiceName   |
000024e0  20 20 20 45 51 55 53 20  22 53 69 6e 4d 61 78 22  |   EQUS "SinMax"|
000024f0  0d 11 94 1a 20 20 20 20  20 20 20 20 20 20 20 20  |....            |
00002500  20 20 20 20 45 51 55 42  20 30 0d 11 9e 09 41 4c  |    EQUB 0....AL|
00002510  49 47 4e 0d 11 a8 1a 2e  4c 6f 67 41 6d 70 50 74  |IGN.....LogAmpPt|
00002520  72 20 20 20 20 20 20 45  51 55 44 20 30 0d 11 b2  |r      EQUD 0...|
00002530  1c 2e 57 61 76 65 42 61  73 65 20 20 20 20 20 20  |..WaveBase      |
00002540  20 45 51 55 44 20 57 54  25 0d 11 bc 04 0d 11 c6  | EQUD WT%.......|
00002550  0d 2e 49 6e 73 74 61 6e  63 65 0d 11 d0 18 53 54  |..Instance....ST|
00002560  4d 46 44 20 20 20 52 31  33 21 2c 7b 52 30 2d 52  |MFD   R13!,{R0-R|
00002570  34 7d 0d 11 da 11 4d 4f  56 20 20 20 20 20 52 30  |4}....MOV     R0|
00002580  2c 23 30 0d 11 e4 11 4d  4f 56 20 20 20 20 20 52  |,#0....MOV     R|
00002590  31 2c 23 30 0d 11 ee 11  4d 4f 56 20 20 20 20 20  |1,#0....MOV     |
000025a0  52 32 2c 23 30 0d 11 f8  11 4d 4f 56 20 20 20 20  |R2,#0....MOV    |
000025b0  20 52 33 2c 23 30 0d 12  02 11 4d 4f 56 20 20 20  | R3,#0....MOV   |
000025c0  20 20 52 34 2c 23 30 0d  12 0c 1e 53 57 49 20 20  |  R4,#0....SWI  |
000025d0  20 20 20 22 58 53 6f 75  6e 64 5f 43 6f 6e 66 69  |   "XSound_Confi|
000025e0  67 75 72 65 22 0d 12 16  17 4c 44 52 56 43 20 20  |gure"....LDRVC  |
000025f0  20 52 30 2c 5b 52 33 2c  23 31 32 5d 0d 12 20 18  | R0,[R3,#12].. .|
00002600  53 54 52 56 43 20 20 20  52 30 2c 4c 6f 67 41 6d  |STRVC   R0,LogAm|
00002610  70 50 74 72 0d 12 2a 14  53 54 52 56 53 20 20 20  |pPtr..*.STRVS   |
00002620  52 30 2c 5b 52 31 33 5d  0d 12 34 1b 4c 44 4d 46  |R0,[R13]..4.LDMF|
00002630  44 20 20 20 52 31 33 21  2c 7b 52 30 2d 52 34 2c  |D   R13!,{R0-R4,|
00002640  50 43 7d 0d 12 3e 04 0d  12 48 0b 2e 47 61 74 65  |PC}..>...H..Gate|
00002650  4f 6e 0d 12 52 17 4c 44  52 20 20 20 20 20 52 30  |On..R.LDR     R0|
00002660  2c 57 61 76 65 42 61 73  65 0d 12 5c 17 53 54 52  |,WaveBase..\.STR|
00002670  20 20 20 20 20 52 30 2c  5b 52 39 2c 23 31 36 5d  |     R0,[R9,#16]|
00002680  0d 12 66 18 4c 44 52 20  20 20 20 20 52 30 2c 4c  |..f.LDR     R0,L|
00002690  6f 67 41 6d 70 50 74 72  0d 12 70 17 53 54 52 20  |ogAmpPtr..p.STR |
000026a0  20 20 20 20 52 30 2c 5b  52 39 2c 23 32 30 5d 0d  |    R0,[R9,#20].|
000026b0  12 7a 04 0d 12 84 09 2e  46 69 6c 6c 0d 12 8e 16  |.z......Fill....|
000026c0  4c 44 4d 49 41 20 20 20  52 39 2c 7b 52 31 2d 52  |LDMIA   R9,{R1-R|
000026d0  36 7d 0d 12 98 14 80 20  20 20 20 20 52 31 2c 52  |6}.....     R1,R|
000026e0  31 2c 23 26 37 46 0d 12  a2 1d 4c 44 52 42 20 20  |1,#&7F....LDRB  |
000026f0  20 20 52 31 2c 5b 52 36  2c 52 31 2c 4c 53 4c 20  |  R1,[R6,R1,LSL |
00002700  23 31 5d 0d 12 ac 18 4d  4f 56 20 20 20 20 20 52  |#1]....MOV     R|
00002710  31 2c 52 31 2c 4c 53 52  20 23 31 0d 12 b6 16 52  |1,R1,LSR #1....R|
00002720  53 42 20 20 20 20 20 52  31 2c 52 31 2c 23 31 32  |SB     R1,R1,#12|
00002730  37 0d 12 c0 0d 2e 46 69  6c 6c 4c 6f 6f 70 0d 12  |7.....FillLoop..|
00002740  ca 18 41 44 44 20 52 32  2c 52 32 2c 52 32 2c 4c  |..ADD R2,R2,R2,L|
00002750  53 4c 20 23 31 36 0d 12  d4 1e 4c 44 52 42 20 20  |SL #16....LDRB  |
00002760  20 20 52 30 2c 5b 52 35  2c 52 32 2c 4c 53 52 20  |  R0,[R5,R2,LSR |
00002770  23 32 34 5d 0d 12 de 18  53 54 52 42 20 20 20 20  |#24]....STRB    |
00002780  52 30 2c 5b 52 31 32 5d  2c 52 31 31 0d 12 e8 04  |R0,[R12],R11....|
00002790  0d 12 f2 18 41 44 44 20  52 32 2c 52 32 2c 52 32  |....ADD R2,R2,R2|
000027a0  2c 4c 53 4c 20 23 31 36  0d 12 fc 1e 4c 44 52 42  |,LSL #16....LDRB|
000027b0  20 20 20 20 52 30 2c 5b  52 35 2c 52 32 2c 4c 53  |    R0,[R5,R2,LS|
000027c0  52 20 23 32 34 5d 0d 13  06 18 53 54 52 42 20 20  |R #24]....STRB  |
000027d0  20 20 52 30 2c 5b 52 31  32 5d 2c 52 31 31 0d 13  |  R0,[R12],R11..|
000027e0  10 04 0d 13 1a 18 41 44  44 20 52 32 2c 52 32 2c  |......ADD R2,R2,|
000027f0  52 32 2c 4c 53 4c 20 23  31 36 0d 13 24 1e 4c 44  |R2,LSL #16..$.LD|
00002800  52 42 20 20 20 20 52 30  2c 5b 52 35 2c 52 32 2c  |RB    R0,[R5,R2,|
00002810  4c 53 52 20 23 32 34 5d  0d 13 2e 18 53 54 52 42  |LSR #24]....STRB|
00002820  20 20 20 20 52 30 2c 5b  52 31 32 5d 2c 52 31 31  |    R0,[R12],R11|
00002830  0d 13 38 04 0d 13 42 18  41 44 44 20 52 32 2c 52  |..8...B.ADD R2,R|
00002840  32 2c 52 32 2c 4c 53 4c  20 23 31 36 0d 13 4c 1e  |2,R2,LSL #16..L.|
00002850  4c 44 52 42 20 20 20 20  52 30 2c 5b 52 35 2c 52  |LDRB    R0,[R5,R|
00002860  32 2c 4c 53 52 20 23 32  34 5d 0d 13 56 18 53 54  |2,LSR #24]..V.ST|
00002870  52 42 20 20 20 20 52 30  2c 5b 52 31 32 5d 2c 52  |RB    R0,[R12],R|
00002880  31 31 0d 13 60 04 0d 13  6a 13 43 4d 50 20 20 20  |11..`...j.CMP   |
00002890  20 20 52 31 32 2c 52 31  30 0d 13 74 14 42 4c 54  |  R12,R10..t.BLT|
000028a0  20 20 20 20 20 46 69 6c  6c 4c 6f 6f 70 0d 13 7e  |     FillLoop..~|
000028b0  04 0d 13 88 14 53 55 42  53 20 20 20 20 52 34 2c  |.....SUBS    R4,|
000028c0  52 34 2c 23 31 0d 13 92  16 53 54 4d 49 42 20 20  |R4,#1....STMIB  |
000028d0  20 52 39 2c 7b 52 32 2d  52 35 7d 0d 13 9c 19 4d  | R9,{R2-R5}....M|
000028e0  4f 56 50 4c 20 20 20 52  30 2c 23 25 30 30 30 30  |OVPL   R0,#%0000|
000028f0  31 30 30 30 0d 13 a6 19  4d 4f 56 4d 49 20 20 20  |1000....MOVMI   |
00002900  52 30 2c 23 25 30 30 30  30 30 30 31 30 0d 13 b0  |R0,#%00000010...|
00002910  15 4c 44 4d 46 44 20 20  20 52 31 33 21 2c 7b 50  |.LDMFD   R13!,{P|
00002920  43 7d 0d 13 ba 04 0d 13  c4 0c 2e 47 61 74 65 4f  |C}.........GateO|
00002930  66 66 0d 13 ce 11 4d 4f  56 20 20 20 20 20 52 30  |ff....MOV     R0|
00002940  2c 23 30 0d 13 d8 0e 2e  46 6c 75 73 68 4c 6f 6f  |,#0.....FlushLoo|
00002950  70 0d 13 e2 18 53 54 52  42 20 20 20 20 52 30 2c  |p....STRB    R0,|
00002960  5b 52 31 32 5d 2c 52 31  31 0d 13 ec 18 53 54 52  |[R12],R11....STR|
00002970  42 20 20 20 20 52 30 2c  5b 52 31 32 5d 2c 52 31  |B    R0,[R12],R1|
00002980  31 0d 13 f6 18 53 54 52  42 20 20 20 20 52 30 2c  |1....STRB    R0,|
00002990  5b 52 31 32 5d 2c 52 31  31 0d 14 00 18 53 54 52  |[R12],R11....STR|
000029a0  42 20 20 20 20 52 30 2c  5b 52 31 32 5d 2c 52 31  |B    R0,[R12],R1|
000029b0  31 0d 14 0a 13 43 4d 50  20 20 20 20 20 52 31 32  |1....CMP     R12|
000029c0  2c 52 31 30 0d 14 14 15  42 4c 54 20 20 20 20 20  |,R10....BLT     |
000029d0  46 6c 75 73 68 4c 6f 6f  70 0d 14 1e 19 4d 4f 56  |FlushLoop....MOV|
000029e0  20 20 20 20 20 52 30 2c  23 25 30 30 30 30 30 30  |     R0,#%000000|
000029f0  30 31 0d 14 28 15 4c 44  4d 46 44 20 20 20 52 31  |01..(.LDMFD   R1|
00002a00  33 21 2c 7b 50 43 7d 0d  14 32 05 5d 0d 14 3c 05  |3!,{PC}..2.]..<.|
00002a10  ed 0d 14 46 04 0d 14 50  12 de 20 4f 6c 64 56 6f  |...F...P.. OldVo|
00002a20  69 63 65 25 28 38 29 0d  14 5a 04 0d 14 64 0e e3  |ice%(8)..Z...d..|
00002a30  20 41 25 3d 30 20 b8 20  33 0d 14 6e 0e f3 20 73  | A%=0 . 3..n.. s|
00002a40  65 66 24 28 41 25 29 0d  14 78 05 ed 0d 14 82 1f  |ef$(A%)..x......|
00002a50  dc 20 31 30 20 48 7a 2c  31 30 30 20 48 7a 2c 31  |. 10 Hz,100 Hz,1|
00002a60  20 4b 48 7a 2c 31 30 20  4b 48 7a 0d 14 8c 2b 53  | KHz,10 KHz...+S|
00002a70  63 61 6c 65 25 28 30 29  3d 31 36 20 3a 20 f4 20  |cale%(0)=16 : . |
00002a80  58 20 66 61 63 74 6f 72  20 66 6f 72 20 67 61 69  |X factor for gai|
00002a90  6e 20 6f 66 20 31 0d 14  96 2a 53 63 61 6c 65 25  |n of 1...*Scale%|
00002aa0  28 31 29 3d 38 20 3a 20  f4 20 58 20 66 61 63 74  |(1)=8 : . X fact|
00002ab0  6f 72 20 66 6f 72 20 67  61 69 6e 20 6f 66 20 32  |or for gain of 2|
00002ac0  0d 14 a0 2a 53 63 61 6c  65 25 28 32 29 3d 34 20  |...*Scale%(2)=4 |
00002ad0  3a 20 f4 20 58 20 66 61  63 74 6f 72 20 66 6f 72  |: . X factor for|
00002ae0  20 67 61 69 6e 20 6f 66  20 34 0d 14 aa 2a 53 63  | gain of 4...*Sc|
00002af0  61 6c 65 25 28 33 29 3d  32 20 3a 20 f4 20 58 20  |ale%(3)=2 : . X |
00002b00  66 61 63 74 6f 72 20 66  6f 72 20 67 61 69 6e 20  |factor for gain |
00002b10  6f 66 20 38 0d 14 b4 2b  53 63 61 6c 65 25 28 34  |of 8...+Scale%(4|
00002b20  29 3d 31 20 3a 20 f4 20  58 20 66 61 63 74 6f 72  |)=1 : . X factor|
00002b30  20 66 6f 72 20 67 61 69  6e 20 6f 66 20 31 36 0d  | for gain of 16.|
00002b40  14 be 29 4f 66 66 73 65  74 25 3d 32 35 20 3a 20  |..)Offset%=25 : |
00002b50  f4 20 54 68 65 20 6d 65  61 73 75 72 65 64 20 44  |. The measured D|
00002b60  43 20 6f 66 66 73 65 74  0d 14 c8 21 f4 20 53 65  |C offset...!. Se|
00002b70  74 20 75 70 20 74 68 65  20 63 6f 6e 74 72 6f 6c  |t up the control|
00002b80  20 72 65 67 69 73 74 65  72 0d 14 d2 19 f4 20 72  | register..... r|
00002b90  65 61 64 20 6f 6e 6c 79  20 43 68 61 6e 6e 65 6c  |ead only Channel|
00002ba0  20 30 0d 14 dc 0b 3f 50  42 41 25 3d 30 0d 14 e6  | 0....?PBA%=0...|
00002bb0  26 c8 99 20 22 58 49 49  43 5f 43 6f 6e 74 72 6f  |&.. "XIIC_Contro|
00002bc0  6c 22 2c 26 39 30 2c 50  42 41 25 2c 31 20 b8 20  |l",&90,PBA%,1 . |
00002bd0  3b 46 6c 0d 14 f0 49 e7  20 28 46 6c 20 80 20 31  |;Fl...I. (Fl . 1|
00002be0  29 20 3d 31 20 8c 20 f2  5f 73 65 74 75 70 57 28  |) =1 . ._setupW(|
00002bf0  22 4e 6f 20 49 49 43 20  64 65 76 69 63 65 20 66  |"No IIC device f|
00002c00  6f 75 6e 64 22 29 3a 44  65 76 69 63 65 25 3d a3  |ound"):Device%=.|
00002c10  20 8b 20 44 65 76 69 63  65 25 3d b9 0d 14 fa 05  | . Device%=.....|
00002c20  e1 0d 15 04 04 0d 15 0e  0c dd 20 f2 5f 53 63 61  |.......... ._Sca|
00002c30  6e 0d 15 18 13 ea 20 41  25 2c 44 65 63 25 2c 53  |n..... A%,Dec%,S|
00002c40  54 25 2c 46 0d 15 22 29  f4 20 46 69 72 73 74 20  |T%,F.."). First |
00002c50  73 74 6f 72 65 20 74 68  65 20 63 75 72 72 65 6e  |store the curren|
00002c60  74 20 73 6f 75 6e 64 20  73 65 74 75 70 0d 15 2c  |t sound setup..,|
00002c70  33 c8 99 20 22 53 6f 75  6e 64 5f 49 6e 73 74 61  |3.. "Sound_Insta|
00002c80  6c 6c 56 6f 69 63 65 22  2c 56 6f 69 63 65 42 61  |llVoice",VoiceBa|
00002c90  73 65 2c 30 20 b8 20 61  25 2c 56 6f 69 63 65 25  |se,0 . a%,Voice%|
00002ca0  0d 15 36 0e e3 20 76 25  3d 31 20 b8 20 31 0d 15  |..6.. v%=1 . 1..|
00002cb0  40 31 c8 99 22 53 6f 75  6e 64 5f 41 74 74 61 63  |@1.."Sound_Attac|
00002cc0  68 56 6f 69 63 65 22 2c  76 25 2c 30 20 b8 20 7a  |hVoice",v%,0 . z|
00002cd0  25 2c 4f 6c 64 56 6f 69  63 65 25 28 76 25 29 0d  |%,OldVoice%(v%).|
00002ce0  15 4a 12 c8 a1 20 76 25  2c 22 53 69 6e 4d 61 78  |.J... v%,"SinMax|
00002cf0  22 0d 15 54 05 ed 0d 15  5e 08 c8 a0 20 31 0d 15  |"..T....^... 1..|
00002d00  68 04 0d 15 72 13 f4 20  4e 6f 77 20 64 72 61 77  |h...r.. Now draw|
00002d10  20 67 72 69 64 0d 15 7c  0b 53 54 25 3d 33 31 34  | grid..|.ST%=314|
00002d20  0d 15 86 16 44 65 63 25  3d 45 6e 64 4e 25 2d 53  |....Dec%=EndN%-S|
00002d30  74 61 72 74 4e 25 0d 15  90 12 f2 5f 54 72 61 6e  |tartN%....._Tran|
00002d40  73 28 6d 6f 6e 57 25 29  0d 15 9a 31 75 25 21 30  |s(monW%)...1u%!0|
00002d50  3d 6d 6f 6e 57 25 3a 75  25 21 34 3d 30 3a 75 25  |=monW%:u%!4=0:u%|
00002d60  21 38 3d 2d 34 34 30 3a  75 25 21 31 32 3d 37 34  |!8=-440:u%!12=74|
00002d70  30 3a 75 25 21 31 36 3d  30 0d 15 a4 27 20 20 c8  |0:u%!16=0...'  .|
00002d80  99 22 57 69 6d 70 5f 55  70 64 61 74 65 57 69 6e  |."Wimp_UpdateWin|
00002d90  64 6f 77 22 2c 2c 75 25  20 b8 20 4d 6f 72 65 25  |dow",,u% . More%|
00002da0  0d 15 ae 0d 20 c8 95 20  4d 6f 72 65 25 0d 15 b8  |.... .. More%...|
00002db0  10 20 20 f2 64 72 61 77  66 72 61 6d 65 0d 15 c2  |.  .drawframe...|
00002dc0  27 20 20 c8 99 22 57 69  6d 70 5f 47 65 74 52 65  |'  .."Wimp_GetRe|
00002dd0  63 74 61 6e 67 6c 65 22  2c 2c 75 25 20 b8 20 4d  |ctangle",,u% . M|
00002de0  6f 72 65 25 0d 15 cc 06  20 ce 0d 15 d6 05 20 0d  |ore%.... ..... .|
00002df0  15 e0 0c 52 65 73 25 28  29 3d 30 0d 15 ea 19 e3  |...Res%()=0.....|
00002e00  20 41 25 3d 31 20 b8 20  53 54 25 20 88 20 42 6c  | A%=1 . ST% . Bl|
00002e10  6f 63 6b 25 0d 15 f4 27  46 3d 31 30 5e 28 28 41  |ock%...'F=10^((A|
00002e20  25 2a 44 65 63 25 29 2f  53 54 25 29 2a 31 30 5e  |%*Dec%)/ST%)*10^|
00002e30  28 53 74 61 72 74 4e 25  2b 31 29 0d 15 fe 0c f2  |(StartN%+1).....|
00002e40  74 6f 6e 65 28 46 29 0d  16 08 0d e7 20 54 6f 6e  |tone(F)..... Ton|
00002e50  65 25 20 8c 0d 16 12 1b  52 65 73 25 28 41 25 29  |e% .....Res%(A%)|
00002e60  3d a4 72 65 73 3a f2 5f  55 70 50 28 41 25 29 0d  |=.res:._UpP(A%).|
00002e70  16 1c 05 cc 0d 16 26 0e  52 65 73 25 28 41 25 29  |......&.Res%(A%)|
00002e80  3d 30 0d 16 30 05 cd 0d  16 3a 05 ed 0d 16 44 08  |=0..0....:....D.|
00002e90  f2 64 65 6c 0d 16 4e 04  0d 16 58 23 c8 99 20 22  |.del..N...X#.. "|
00002ea0  53 6f 75 6e 64 5f 52 65  6d 6f 76 65 56 6f 69 63  |Sound_RemoveVoic|
00002eb0  65 22 2c 30 2c 56 6f 69  63 65 25 0d 16 62 0e e3  |e",0,Voice%..b..|
00002ec0  20 76 25 3d 31 20 b8 20  31 0d 16 6c 2b 20 c8 99  | v%=1 . 1..l+ ..|
00002ed0  22 53 6f 75 6e 64 5f 41  74 74 61 63 68 56 6f 69  |"Sound_AttachVoi|
00002ee0  63 65 22 2c 76 25 2c 4f  6c 64 56 6f 69 63 65 25  |ce",v%,OldVoice%|
00002ef0  28 76 25 29 0d 16 76 05  ed 0d 16 80 04 0d 16 8a  |(v%)..v.........|
00002f00  05 e1 0d 16 94 04 0d 16  9e 09 dd a4 72 65 73 0d  |............res.|
00002f10  16 a8 11 ea 20 47 25 2c  52 65 61 64 2c 56 61 6c  |.... G%,Read,Val|
00002f20  0d 16 b2 08 47 25 3d 30  0d 16 b3 16 e7 20 44 65  |....G%=0..... De|
00002f30  76 69 63 65 25 3d a3 20  8c 20 3d 33 30 36 0d 16  |vice%=. . =306..|
00002f40  bc 06 20 f5 0d 16 c6 13  50 42 44 25 3f 30 3d 26  |.. .....PBD%?0=&|
00002f50  38 30 20 84 20 47 25 0d  16 d0 0d 50 42 44 25 3f  |80 . G%....PBD%?|
00002f60  31 3d 47 25 0d 16 da 05  20 0d 16 e4 19 f4 20 44  |1=G%.... ..... D|
00002f70  69 73 63 68 61 72 67 65  20 43 61 70 61 63 69 74  |ischarge Capacit|
00002f80  6f 72 0d 16 ee 20 c8 99  20 22 58 49 49 43 5f 43  |or... .. "XIIC_C|
00002f90  6f 6e 74 72 6f 6c 22 2c  26 37 30 2c 50 42 44 25  |ontrol",&70,PBD%|
00002fa0  2c 31 0d 16 f8 16 f4 20  52 65 6d 6f 76 65 20 74  |,1..... Remove t|
00002fb0  68 65 20 73 68 6f 72 74  0d 17 02 22 c8 99 20 22  |he short...".. "|
00002fc0  58 49 49 43 5f 43 6f 6e  74 72 6f 6c 22 2c 26 37  |XIIC_Control",&7|
00002fd0  30 2c 50 42 44 25 2b 31  2c 31 0d 17 0c 09 f2 64  |0,PBD%+1,1.....d|
00002fe0  65 6c 32 0d 17 16 05 f5  0d 17 20 12 f4 20 52 65  |el2....... .. Re|
00002ff0  61 64 20 74 68 65 20 41  2f 44 0d 17 2a 20 c8 99  |ad the A/D..* ..|
00003000  20 22 58 49 49 43 5f 43  6f 6e 74 72 6f 6c 22 2c  | "XIIC_Control",|
00003010  26 39 31 2c 50 42 4b 25  2c 33 0d 17 34 18 fd 20  |&91,PBK%,3..4.. |
00003020  94 28 50 42 4b 25 3f 31  2d 50 42 4b 25 3f 32 29  |.(PBK%?1-PBK%?2)|
00003030  3c 34 0d 17 3e 1a 52 65  61 64 3d 28 50 42 4b 25  |<4..>.Read=(PBK%|
00003040  3f 31 2b 50 42 4b 25 3f  32 29 2f 32 0d 17 48 09  |?1+PBK%?2)/2..H.|
00003050  47 25 2b 3d 31 0d 17 52  15 fd 20 52 65 61 64 3e  |G%+=1..R.. Read>|
00003060  26 38 30 20 84 20 47 25  3d 35 0d 17 5c 09 47 25  |&80 . G%=5..\.G%|
00003070  2d 3d 31 0d 17 66 23 56  61 6c 3d 28 52 65 61 64  |-=1..f#Val=(Read|
00003080  2d 4f 66 66 73 65 74 25  29 20 2a 20 53 63 61 6c  |-Offset%) * Scal|
00003090  65 25 28 47 25 29 0d 17  70 13 e7 20 56 61 6c 3c  |e%(G%)..p.. Val<|
000030a0  31 20 8c 20 56 61 6c 3d  31 0d 17 71 0c e7 20 4c  |1 . Val=1..q.. L|
000030b0  6f 67 25 20 8c 0d 17 7a  24 56 61 6c 3d 28 31 30  |og% ...z$Val=(10|
000030c0  2e 32 2a 28 33 30 2b 32  30 2a 28 ab 28 56 61 6c  |.2*(30+20*(.(Val|
000030d0  2f 34 30 38 30 29 29 29  29 0d 17 7b 05 cc 0d 17  |/4080))))..{....|
000030e0  7c 16 56 61 6c 3d 28 56  61 6c 2a 33 30 36 29 2f  ||.Val=(Val*306)/|
000030f0  34 30 38 30 0d 17 7d 05  cd 0d 17 84 13 e7 20 56  |4080..}....... V|
00003100  61 6c 3c 30 20 8c 20 56  61 6c 3d 30 0d 17 8e 08  |al<0 . Val=0....|
00003110  3d 56 61 6c 0d 17 98 04  0d 17 a2 0b dd 20 f2 64  |=Val......... .d|
00003120  65 6c 32 0d 17 ac 08 ea  20 54 25 0d 17 b6 10 54  |el2..... T%....T|
00003130  25 3d 91 2b 56 64 65 6c  61 79 25 0d 17 c0 0c f5  |%=.+Vdelay%.....|
00003140  20 fd 20 91 3e 54 25 0d  17 ca 05 e1 0d 17 d4 04  | . .>T%.........|
00003150  0d 17 de 0f dd 20 f2 5f  55 70 50 28 41 25 29 0d  |..... ._UpP(A%).|
00003160  17 e8 11 ea 20 54 25 2c  59 25 2c 4d 6f 72 65 25  |.... T%,Y%,More%|
00003170  0d 17 f2 11 54 25 3d 52  65 73 25 28 41 25 2d 31  |....T%=Res%(A%-1|
00003180  29 0d 17 fc 0f 59 25 3d  52 65 73 25 28 41 25 29  |)....Y%=Res%(A%)|
00003190  0d 18 06 12 f2 5f 54 72  61 6e 73 28 6d 6f 6e 57  |....._Trans(monW|
000031a0  25 29 0d 18 10 32 75 25  21 30 3d 6d 6f 6e 57 25  |%)...2u%!0=monW%|
000031b0  3a 75 25 21 34 3d 36 30  3a 75 25 21 38 3d 2d 33  |:u%!4=60:u%!8=-3|
000031c0  36 36 3a 75 25 21 31 32  3d 37 34 30 3a 75 25 21  |66:u%!12=740:u%!|
000031d0  31 36 3d 30 0d 18 1a 27  20 20 c8 99 22 57 69 6d  |16=0...'  .."Wim|
000031e0  70 5f 55 70 64 61 74 65  57 69 6e 64 6f 77 22 2c  |p_UpdateWindow",|
000031f0  2c 75 25 20 b8 20 4d 6f  72 65 25 0d 18 24 0d 20  |,u% . More%..$. |
00003200  c8 95 20 4d 6f 72 65 25  0d 18 2e 19 c8 99 22 57  |.. More%......"W|
00003210  69 6d 70 5f 53 65 74 43  6f 6c 6f 75 72 22 2c 31  |imp_SetColour",1|
00003220  30 0d 18 38 10 e7 20 42  6c 6f 63 6b 25 3d 31 20  |0..8.. Block%=1 |
00003230  8c 0d 18 42 22 20 20 20  ec 20 78 6f 25 2b 36 32  |...B"   . xo%+62|
00003240  2b 28 41 25 2d 31 29 2a  32 2c 79 6f 25 2b 54 25  |+(A%-1)*2,yo%+T%|
00003250  2b 37 36 0d 18 4c 1e 20  20 20 df 20 78 6f 25 2b  |+76..L.   . xo%+|
00003260  36 32 2b 41 25 2a 32 2c  79 6f 25 2b 59 25 2b 37  |62+A%*2,yo%+Y%+7|
00003270  36 0d 18 56 05 cc 0d 18  60 32 20 20 c8 93 c8 90  |6..V....`2  ....|
00003280  20 78 6f 25 2b 36 32 2b  41 25 2a 32 2c 79 6f 25  | xo%+62+A%*2,yo%|
00003290  2b 59 25 2b 37 36 2c 42  6c 6f 63 6b 25 2a 32 2c  |+Y%+76,Block%*2,|
000032a0  42 6c 6f 63 6b 25 2a 32  0d 18 6a 05 cd 0d 18 74  |Block%*2..j....t|
000032b0  27 20 20 c8 99 22 57 69  6d 70 5f 47 65 74 52 65  |'  .."Wimp_GetRe|
000032c0  63 74 61 6e 67 6c 65 22  2c 2c 75 25 20 b8 20 4d  |ctangle",,u% . M|
000032d0  6f 72 65 25 0d 18 7e 06  20 ce 0d 18 88 05 e1 0d  |ore%..~. .......|
000032e0  18 92 04 0d 18 9c 0e dd  20 f2 74 6f 6e 65 28 46  |........ .tone(F|
000032f0  29 0d 18 a6 1c ea 20 52  2c 4f 63 2c 6f 63 74 69  |)..... R,Oc,octi|
00003300  76 65 25 2c 46 72 25 2c  53 25 2c 50 25 0d 18 b0  |ve%,Fr%,S%,P%...|
00003310  11 52 3d 46 2f 31 36 2e  33 35 31 38 37 35 0d 18  |.R=F/16.351875..|
00003320  ba 12 4f 63 3d 28 aa 28  52 29 2f 4c 6f 67 32 29  |..Oc=(.(R)/Log2)|
00003330  0d 18 c4 11 6f 63 74 69  76 65 25 3d a8 28 4f 63  |....octive%=.(Oc|
00003340  29 0d 18 ce 19 46 72 25  3d 28 4f 63 2d 6f 63 74  |)....Fr%=(Oc-oct|
00003350  69 76 65 25 29 2a 34 30  39 36 0d 18 d8 1c 53 25  |ive%)*4096....S%|
00003360  3d 28 46 72 25 20 84 20  28 6f 63 74 69 76 65 25  |=(Fr% . (octive%|
00003370  3c 3c 31 32 29 29 0d 18  e2 1c e7 20 6f 63 74 69  |<<12))..... octi|
00003380  76 65 25 3c 39 20 80 20  53 25 3e 20 26 31 30 30  |ve%<9 . S%> &100|
00003390  20 8c 0d 18 ec 04 0d 18  f6 45 e7 20 53 25 3e 26  | ........E. S%>&|
000033a0  37 46 46 46 20 8c 20 50  25 3d 53 25 2d 26 32 30  |7FFF . P%=S%-&20|
000033b0  30 30 3a 20 21 57 61 76  65 42 61 73 65 3d 57 54  |00: !WaveBase=WT|
000033c0  25 2b 32 35 36 20 8b 20  50 25 3d 53 25 3a 21 57  |%+256 . P%=S%:!W|
000033d0  61 76 65 42 61 73 65 3d  57 54 25 0d 19 00 12 20  |aveBase=WT%.... |
000033e0  d4 20 31 2c 2d 31 35 2c  50 25 2c 31 30 0d 19 0a  |. 1,-15,P%,10...|
000033f0  0c 20 54 6f 6e 65 25 3d  b9 0d 19 14 1a 20 f4 20  |. Tone%=..... . |
00003400  56 64 65 6c 61 79 25 3d  31 30 2d 28 53 25 3e 3e  |Vdelay%=10-(S%>>|
00003410  31 32 29 0d 19 1e 25 20  e7 20 53 25 3e 26 32 30  |12)...% . S%>&20|
00003420  30 30 20 56 64 65 6c 61  79 25 3d 31 20 8b 20 56  |00 Vdelay%=1 . V|
00003430  64 65 6c 61 79 25 3d 36  0d 19 28 06 20 cc 0d 19  |delay%=6..(. ...|
00003440  32 0c 20 54 6f 6e 65 25  3d a3 0d 19 3c 05 cd 0d  |2. Tone%=...<...|
00003450  19 46 04 0d 19 50 08 f2  64 65 6c 0d 19 5a 05 e1  |.F...P..del..Z..|
00003460  0d 19 64 04 0d 19 6e 0a  dd 20 f2 64 65 6c 0d 19  |..d...n.. .del..|
00003470  78 08 ea 20 54 25 0d 19  82 0d 54 25 3d 91 20 2b  |x.. T%....T%=. +|
00003480  20 32 30 0d 19 8c 0c f5  20 fd 20 91 3e 54 25 0d  | 20..... . .>T%.|
00003490  19 96 05 e1 0d ff                                 |......|
00003496