Home » Archimedes archive » Archimedes World » AW-1991-05.adf » May91 » !AWMay91/Goodies/Coconizer/Tools/AmiTrans

!AWMay91/Goodies/Coconizer/Tools/AmiTrans

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 » Archimedes World » AW-1991-05.adf » May91
Filename: !AWMay91/Goodies/Coconizer/Tools/AmiTrans
Read OK:
File size: 1E84 bytes
Load address: 0000
Exec address: 0000
File contents
   10REM --------------------------------------
   20REM
   30REM            AMIGA-TRANSFER v1.3
   40REM
   50REM  Converts an Amiga SoundTracker Song
   60REM      to 80% into a Coconizer Song
   70REM
   80REM      (c) August 1990 by Playfield
   90REM
  100REM      Latest revision - 26 Dec 1990
  110REM
  120REM --------------------------------------
  130
  140ON ERROR SYS "Hourglass_Smash":PRINT REPORT$;" @ ";ERL:END
  150
  160*RMEnsure Packit 1.50 RMLoad !Coconizer.Packit
  170
  180path$="^.Amiga.Modules"
  190f%=OPENIN path$:IF f%=0 INPUT'"AmigaSongs Pathname? "path$ ELSE CLOSE#f%
  200OSCLI "Cat "+path$
  210INPUT'"Original Amiga Song file? "z$
  220z$=path$+"."+z$
  230f=OPENIN z$
  240  len=EXT#f:b1=BGET#f:b2=BGET#f:b3=BGET#f:b4=BGET#f:b5=BGET#f
  250CLOSE#f
  260IF b4=0 AND b5>0 THEN total=b1+(b2<<8)+(b3<<16)+(b4<<24) ELSE total=len
  270
  280us=48
  290maxinst=32
  300DIM code 912, L%-1
  310DIM amiga total
  320IF total<128*1024 THEN
  330  DIM track total+16*32, Z%-1
  340ELSE
  350  DIM track 128*1024+16*32, Z%-1
  360ENDIF
  370DIM periods(856)
  380DIM instord(maxinst),names$(maxinst)
  390DIM lastper(4),flup(4),fldo(4)
  400
  410PROC_Init
  420IF b4=0 AND b5>0 THEN
  430  OSCLI "Packload "+z$+" "+STR$~amiga
  440ELSE
  450  PRINT "Len is ";total;" bytes "
  460  OSCLI "Load "+z$+" "+STR$~amiga
  470ENDIF
  480B%=track:C%=Z%-1 :CALL code
  490
  500INPUT'"Want to extract its instruments (if an Amiga module) [y] ? ";
  510SYS "OS_Confirm" TO extra:PRINT CHR$extra
  520extra=-(extra=ASC"y")
  530IF extra THEN *Cdir ram:$.Samples
  540
  550REM ==== PREPARE HEAD ===================================================
  560
  570IF amiga?&1d7=ASC"x" THEN
  580  pool=15                                               :*| 15er Format
  590  base=amiga+&1d8:hl=amiga+&258
  600ELSE
  610  pool=31                                               :*| 31er Format
  620  base=amiga+&3b8:hl=amiga+&43c
  630ENDIF
  640
  650track?0=4                                               :*| 4 Voices
  660title$=""
  670FOR i%=0 TO 18
  680  a=amiga?i%:IF a>31 THEN title$+=CHR$a ELSE title$+=" "
  690NEXT i%
  700$(track+1)=title$                                       :*| ?20 = CHR$13
  710
  720PRINT'"NAME: ";title$,"(";pool;" instrument format)"'
  730REPEAT a=INSTR(title$," "):IF a THEN MID$(title$,a,1)="/":UNTIL FALSE
  740
  750REM ==== ALLOCATE INSTRUMENT POOL =======================================
  760
  770tops=0
  780nums=base?-2
  790FOR i%=0 TO nums-1
  800  IF base?i%>tops THEN tops=base?i%                     :*| Highest Patt
  810NEXT i%
  820
  830PRINT"    Name         Volume   RepAt    RepLen    Length     [Original]"
  840PRINT"    ----------   ------   -----    ------    ------      --------"
  850
  860data=hl+(tops+1)*1024                                   :*| First Sample
  870pc=track+32                                             :*| Coco song
  880inst=0
  890
  900FOR i%=1 TO pool
  910  aminf=amiga+&14+((i%-1)*&1e)
  920  na$=""
  930  FOR j%=0 TO 19:IF aminf?j%>31 THEN na$+=CHR$(aminf?j%):NEXT
  940  a=INSTR(na$,":"):IF a THEN na$=MID$(na$,a+1)
  950  IF LENna$>10 THEN a$=LEFT$(na$,9)+RIGHT$(na$,1) ELSE a$=na$
  960  FOR j%=1 TO 10 :REM Len extra chars
  970    a=INSTR(a$,MID$(" .*#$&@^%\",j%,1)):IF a MID$(a$,a,1)="-":GOTO 970
  980  NEXT j%
  990  FOR j%=1 TO 10
 1000    a=ASC(MID$(a$,j%)):IF a>=ASC"A" AND a<=ASC"Z" MID$(a$,j%)=CHR$(a+32)
 1010  NEXT j%
 1020  IF a$="" THEN a$=LEFT$(title$,8)+STR$i%
 1030
 1040  length=((aminf?22)*256+(aminf?23))*2
 1050  volume= (aminf?24)*256+(aminf?25)
 1060  rep_at= (aminf?26)*256+(aminf?27)
 1070  replen=((aminf?28)*256+(aminf?29))*2
 1080  IF replen=2 THEN rep_at=0:replen=0 ELSE IF rep_at=0 THEN rep_at+=1
 1090  volume=FN_log(volume)
 1100
 1110  IF length>2 THEN
 1120    REPEAT
 1130      same=TRUE
 1140      FOR j%=1 TO i%
 1150      IF j%<>i% AND names$(j%)=a$ THEN RIGHT$(a$)=CHR$(ASC(RIGHT$(a$))+1):same=FALSE
 1160      NEXT j%
 1170    UNTIL same
 1180    names$(i%)=a$
 1190    IF extra OSCLI"Save ram:$.Samples."+a$+" "+STR$~data+" +"+STR$~length
 1200    inst+=1
 1210    instord(i%)=inst                                    :*| Leave no Gap!
 1220    pc!04=length
 1230    pc!08=volume
 1240    pc!12=rep_at
 1250    pc!16=replen
 1260    $(pc+20)=a$
 1270    PRINT STR$i%;" : ";a$;TAB(18);volume,rep_at,replen,length;
 1280    IF LENna$>10 THEN PRINT "  ("na$")" ELSE PRINT
 1290    pc+=32
 1300    data+=length
 1310 ENDIF
 1320NEXT i%
 1330
 1340REM ==== POKE SEQUENCY AND AMOUNT OF SEQ/PATTS ==========================
 1350
 1360track!24=pc-track                                       :*| Seq Offset
 1370FOR i%=0 TO nums-1:?pc=base?i%:pc+=1:NEXT i%
 1380?pc=&ff:pc+=1                                           :*| Set Endmark
 1390
 1400PRINT'"Patterns: ";tops+1,"Sequencies: ";nums'          :*| Incl. Patt 0
 1410
 1420REM ==== CONVERT PATTERNS (UAAHHHH...) ====
 1430
 1440IF pc MOD 4 THEN pc=(pc OR 3)+1                         :*| Align Pattern
 1450track!28=pc-track                                       :*| Patt Offset
 1460speed=6-1                                               :*| Default Speed
 1470
 1480SYS "Hourglass_On"
 1490FOR i%=0 TO tops
 1500SYS "Hourglass_Percentage",i%*100 DIV tops
 1510FOR j%=0 TO 63
 1520FOR k%=1 TO 4
 1530  CASE k% OF
 1540  WHEN 1: pat=pc+(3-1)*4           :*| Set real stereo logic!
 1550  WHEN 2: pat=pc+(2-1)*4           :*| for the four columns..
 1560  WHEN 3: pat=pc+(1-1)*4
 1570  WHEN 4: pat=pc+(4-1)*4
 1580  ENDCASE
 1590
 1600  per=hl?0*256+hl?1                :*| Get Amiga Period
 1610  IF per>856 THEN per=0
 1620  note=periods(per)                :*| Appropriate Coco note value
 1630  note+=3*12                       :*| Ami uses Note 1 as Mid C (Oct 0)
 1640  IF per THEN pat?3=note           :*| Coco has Notes from Oct -3 to +4
 1650
 1660  nib=(hl?2 AND &f0) >>4           :*| Make InstNibble to Byte
 1670  pat?2=instord(nib)               :*| Well, no empty Inst Entries!
 1680
 1690  com=(hl?2 AND &0f)               :*| Make CommandNibble to Byte
 1700  pat?1=com                        :*| Lots of main Commands are kept
 1710  inf=hl?3                         :*| Get InfoByte
 1720
 1730  CASE com OF
 1740  WHEN 1,2:
 1750    IF per=0 THEN per=lastper(k%):IF per=0 THEN per=100:PRINT "?Slide0"
 1760    f1=3575872/per:out1=(f1/(1000000/us))*65536
 1770    IF com=1 THEN new=per-speed*inf:IF new< &71 THEN new= &71
 1780    IF com=2 THEN new=per+speed*inf:IF new>&358 THEN new=&358
 1790    f2=3575872/new:out2=(f2/(1000000/us))*65536
 1800    IF com=1 THEN SWAP out1,out2
 1810    inf=((out1-out2)/speed) DIV 64
 1820    IF inf=0 THEN inf=1 ELSE IF inf>255 THEN inf=255
 1830    per=new
 1840
 1850  WHEN 3,4,5,6,7,8,9,&B,&E: pat?1=0:inf=0:PRINT "?Amiga command ";~com
 1860
 1870  WHEN &A:
 1880    IF (inf AND &f0) THEN
 1890      pat?1=3:inf=(inf AND &e0) >>8                     :*| Volume up
 1900      inf=2*inf -2*(inf=0)
 1910    ENDIF
 1920    IF (inf AND &0f) THEN
 1930      pat?1=4:inf=inf AND &0e                           :*| Volume down
 1940      inf=2*inf -2*(inf=0)
 1950    ENDIF
 1960
 1970  WHEN &c: inf=FN_log(inf) AND &fe                      :*| LSB Volumes!
 1980
 1990  WHEN &f: speed=(inf AND &0f)-1                        :*| Right Nibble
 2000
 2010  ENDCASE
 2020
 2030  IF inf=0 THEN
 2040    IF flup(k%)=1 THEN pat?1=8:flup(k%)=0 :*| Clear Auto Vol up
 2050    IF fldo(k%)=1 THEN pat?1=9:fldo(k%)=0 :*| Clear Auto Vol down
 2060  ENDIF
 2070
 2080  pat?0=inf                               :*| Write back InfoByte
 2090  IF per THEN lastper(k%)=per             :*| Save legal Periode
 2100
 2110  hl+=4
 2120NEXT k%
 2130pc+=16                                    :*| One row has 4 LWords
 2140NEXT j%,i%
 2150SYS "Hourglass_Smash"
 2160
 2170REM ==== SAVE & FINI ====================================================
 2180
 2190track?21=inst
 2200track?22=nums
 2210track?23=tops+1
 2220track!32=pc-track                         :*| SampleData Offset
 2230
 2240len=pc-track
 2250INPUT''"Destination name? "z$
 2260OSCLI "Packsave "+z$+" "+STR$~track+" "+STR$~len
 2270END
 2280
 2290  WHEN Autovolume?
 2300    IF (inf AND &f0) THEN
 2310      pat?1=8:flup(k%)=1:inf=(inf AND &e0) >>8          :*| Auto Vol up
 2320      inf=2*inf -2*(inf=0)
 2330    ENDIF
 2340    IF (inf AND &0f) THEN
 2350      pat?1=9:fldo(k%)=1:inf=inf AND &0e                :*| Auto Vol down
 2360      inf=2*inf -2*(inf=0)
 2370    ENDIF
 2380
 2390DEF FN_log(x)
 2400IF x>64 THEN PRINT "?Vol >64":x=64
 2410=181-INT(100*LOG(x+1))                    :*| Logarithm Volume -> linear
 2420
 2430DEF PROC_Init
 2440FOR p=%1000 TO %1010 STEP 2
 2450P%=code
 2460[OPT p
 2470 mov   r3,#0
 2480.clear
 2490 str   r3,[r1],#4
 2500 cmp   r1,r2
 2510 bLo   clear
 2520 mov   pc,r14
 2530]:NEXT p
 2540
 2550FOR i%=1 TO 36:READ a:periods(a)=i%:NEXT i%
 2560DATA 856,808,762,720,678,640,604,570,538,508,480,453    :*| Start at
 2570DATA 428,404,381,360,339,320,302,285,269,254,240,226    :*| internat.
 2580DATA 214,202,190,180,170,160,151,143,135,127,120,113    :*| Octave 0
 2590ENDPROC

,� --------------------------------------
�
$�            AMIGA-TRANSFER v1.3
(�
2*�  Converts an Amiga SoundTracker Song
<'�      to 80% into a Coconizer Song
F�
P'�      (c) August 1990 by Playfield
Z�
d(�      Latest revision - 26 Dec 1990
n�
x,� --------------------------------------
�
�+� � ș "Hourglass_Smash":� �$;" @ ";�:�
�
�2*RMEnsure Packit 1.50 RMLoad !Coconizer.Packit
�
�path$="^.Amiga.Modules"
�;f%=� path$:� f%=0 �'"AmigaSongs Pathname? "path$ � �#f%
�� "Cat "+path$
�$�'"Original Amiga Song file? "z$
�z$=path$+"."+z$
�
f=� z$
�0  len=�#f:b1=�#f:b2=�#f:b3=�#f:b4=�#f:b5=�#f
��#f
B� b4=0 � b5>0 � total=b1+(b2<<8)+(b3<<16)+(b4<<24) � total=len

	us=48
"maxinst=32
,� code 912, L%-1
6� amiga total
@� total<128*1024 �
J  � track total+16*32, Z%-1
T�
^"  � track 128*1024+16*32, Z%-1
h�
r� periods(856)
|&� instord(maxinst),names$(maxinst)
� � lastper(4),flup(4),fldo(4)
�
�
�_Init
�� b4=0 � b5>0 �
�"  � "Packload "+z$+" "+�~amiga
��
�!  � "Len is ";total;" bytes "
�  � "Load "+z$+" "+�~amiga
��
�B%=track:C%=Z%-1 :� code
�
�D�'"Want to extract its instruments (if an Amiga module) [y] ? ";
�$ș "OS_Confirm" � extra:� �extra
extra=-(extra=�"y")
!� extra � *Cdir ram:$.Samples

&K� ==== PREPARE HEAD ===================================================
0
:� amiga?&1d7=�"x" �
DK  pool=15                                               :*| 15er Format
N#  base=amiga+&1d8:hl=amiga+&258
X�
bK  pool=31                                               :*| 31er Format
l#  base=amiga+&3b8:hl=amiga+&43c
v�
�
�Htrack?0=4                                               :*| 4 Voices
�
title$=""
�� i%=0 � 18
�2  a=amiga?i%:� a>31 � title$+=�a � title$+=" "
�� i%
�L$(track+1)=title$                                       :*| ?20 = CHR$13
�
�5�'"NAME: ";title$,"(";pool;" instrument format)"'
�/� a=�title$," "):� a � �title$,a,1)="/":� �
�
�K� ==== ALLOCATE INSTRUMENT POOL =======================================
�

tops=0
nums=base?-2
� i%=0 � nums-1
 H  � base?i%>tops � tops=base?i%                     :*| Highest Patt
*� i%
4
>I�"    Name         Volume   RepAt    RepLen    Length     [Original]"
HH�"    ----------   ------   -----    ------    ------      --------"
R
\Ldata=hl+(tops+1)*1024                                   :*| First Sample
fIpc=track+32                                             :*| Coco song
p
inst=0
z
�� i%=1 � pool
�"  aminf=amiga+&14+((i%-1)*&1e)
�  na$=""
�4  � j%=0 � 19:� aminf?j%>31 � na$+=�(aminf?j%):�
�%  a=�na$,":"):� a � na$=�na$,a+1)
�-  � �na$>10 � a$=�na$,9)+�na$,1) � a$=na$
�$  � j%=1 � 10 :� Len extra chars
�:    a=�a$,�" .*#$&@^%\",j%,1)):� a �a$,a,1)="-":� �dJC
�
  � j%
�  � j%=1 � 10
�8    a=�(�a$,j%)):� a>=�"A" � a<=�"Z" �a$,j%)=�(a+32)
�
  � j%
�!  � a$="" � a$=�title$,8)+�i%

*  length=((aminf?22)*256+(aminf?23))*2
'  volume= (aminf?24)*256+(aminf?25)
$'  rep_at= (aminf?26)*256+(aminf?27)
.*  replen=((aminf?28)*256+(aminf?29))*2
8=  � replen=2 � rep_at=0:replen=0 � � rep_at=0 � rep_at+=1
B  volume=�_log(volume)
L
V  � length>2 �
`	    �
j      same=�
t      � j%=1 � i%
~=      � j%<>i% � names$(j%)=a$ � �a$)=�(�(�a$))+1):same=�
�      � j%
�    � same
�    names$(i%)=a$
�B    � extra �"Save ram:$.Samples."+a$+" "+�~data+" +"+�~length
�    inst+=1
�M    instord(i%)=inst                                    :*| Leave no Gap!
�    pc!04=length
�    pc!08=volume
�    pc!12=rep_at
�    pc!16=replen
�    $(pc+20)=a$
�8    � �i%;" : ";a$;�18);volume,rep_at,replen,length;
%    � �na$>10 � � "  ("na$")" � �

    pc+=32
    data+=length
 �
(� i%
2
<K� ==== POKE SEQUENCY AND AMOUNT OF SEQ/PATTS ==========================
F
PJtrack!24=pc-track                                       :*| Seq Offset
Z*� i%=0 � nums-1:?pc=base?i%:pc+=1:� i%
dK?pc=&ff:pc+=1                                           :*| Set Endmark
n
xH�'"Patterns: ";tops+1,"Sequencies: ";nums'          :*| Incl. Patt 0
�
�-� ==== CONVERT PATTERNS (UAAHHHH...) ====
�
�F� pc � 4 � pc=(pc � 3)+1                         :*| Align Pattern
�Ktrack!28=pc-track                                       :*| Patt Offset
�Mspeed=6-1                                               :*| Default Speed
�
�ș "Hourglass_On"
�� i%=0 � tops
�+ș "Hourglass_Percentage",i%*100 � tops
�� j%=0 � 63
�� k%=1 � 4
�
  Ȏ k% �
>  � 1: pat=pc+(3-1)*4           :*| Set real stereo logic!
>  � 2: pat=pc+(2-1)*4           :*| for the four columns..
  � 3: pat=pc+(1-1)*4
"  � 4: pat=pc+(4-1)*4
,  �
6
@;  per=hl?0*256+hl?1                :*| Get Amiga Period
J  � per>856 � per=0
TF  note=periods(per)                :*| Appropriate Coco note value
^K  note+=3*12                       :*| Ami uses Note 1 as Mid C (Oct 0)
hG  � per � pat?3=note           :*| Coco has Notes from Oct -3 to +4
r
|@  nib=(hl?2 � &f0) >>4           :*| Make InstNibble to Byte
�G  pat?2=instord(nib)               :*| Well, no empty Inst Entries!
�
�C  com=(hl?2 � &0f)               :*| Make CommandNibble to Byte
�I  pat?1=com                        :*| Lots of main Commands are kept
�7  inf=hl?3                         :*| Get InfoByte
�
�  Ȏ com �
�  � 1,2:
�?    � per=0 � per=lastper(k%):� per=0 � per=100:� "?Slide0"
�3    f1=3575872/per:out1=(f1/(1000000/us))*65536
�9    � com=1 � new=per-speed*inf:� new< &71 � new= &71
�9    � com=2 � new=per+speed*inf:� new>&358 � new=&358
�3    f2=3575872/new:out2=(f2/(1000000/us))*65536
    � com=1 � Ȕ out1,out2
$    inf=((out1-out2)/speed) � 64
-    � inf=0 � inf=1 � � inf>255 � inf=255
&    per=new
0
:C  � 3,4,5,6,7,8,9,&B,&E: pat?1=0:inf=0:� "?Amiga command ";~com
D
N  � &A:
X    � (inf � &f0) �
bG      pat?1=3:inf=(inf � &e0) >>8                     :*| Volume up
l      inf=2*inf -2*(inf=0)
v	    �
�    � (inf � &0f) �
�I      pat?1=4:inf=inf � &0e                           :*| Volume down
�      inf=2*inf -2*(inf=0)
�	    �
�
�F  � &c: inf=�_log(inf) � &fe                      :*| LSB Volumes!
�
�G  � &f: speed=(inf � &0f)-1                        :*| Right Nibble
�
�  �
�
�  � inf=0 �
�?    � flup(k%)=1 � pat?1=8:flup(k%)=0 :*| Clear Auto Vol up
A    � fldo(k%)=1 � pat?1=9:fldo(k%)=0 :*| Clear Auto Vol down
  �

 E  pat?0=inf                               :*| Write back InfoByte
*@  � per � lastper(k%)=per             :*| Save legal Periode
4
>  hl+=4
H� k%
RFpc+=16                                    :*| One row has 4 LWords
\� j%,i%
fș "Hourglass_Smash"
p
zK� ==== SAVE & FINI ====================================================
�
�track?21=inst
�track?22=nums
�track?23=tops+1
�Ctrack!32=pc-track                         :*| SampleData Offset
�
�len=pc-track
��''"Destination name? "z$
�*� "Packsave "+z$+" "+�~track+" "+�~len
��
�
�  � Autovolume?
�    � (inf � &f0) �
	I      pat?1=8:flup(k%)=1:inf=(inf � &e0) >>8          :*| Auto Vol up
	      inf=2*inf -2*(inf=0)
		    �
	$    � (inf � &0f) �
	.K      pat?1=9:fldo(k%)=1:inf=inf � &0e                :*| Auto Vol down
	8      inf=2*inf -2*(inf=0)
	B	    �
	L
	V� �_log(x)
	`� x>64 � � "?Vol >64":x=64
	jH=181-�(100*�(x+1))                    :*| Logarithm Volume -> linear
	t
	~� �_Init
	�� p=%1000 � %1010 � 2
	�P%=code
	�
[OPT p
	� mov   r3,#0
	�
.clear
	� str   r3,[r1],#4
	� cmp   r1,r2
	� bLo   clear
	� mov   pc,r14
	�	]:� p
	�
	�&� i%=1 � 36:� a:periods(a)=i%:� i%
E� 856,808,762,720,678,640,604,570,538,508,480,453    :*| Start at

F� 428,404,381,360,339,320,302,285,269,254,240,226    :*| internat.
E� 214,202,190,180,170,160,151,143,135,127,120,113    :*| Octave 0
�
�
00000000  0d 00 0a 2c f4 20 2d 2d  2d 2d 2d 2d 2d 2d 2d 2d  |...,. ----------|
00000010  2d 2d 2d 2d 2d 2d 2d 2d  2d 2d 2d 2d 2d 2d 2d 2d  |----------------|
00000020  2d 2d 2d 2d 2d 2d 2d 2d  2d 2d 2d 2d 0d 00 14 05  |------------....|
00000030  f4 0d 00 1e 24 f4 20 20  20 20 20 20 20 20 20 20  |....$.          |
00000040  20 20 41 4d 49 47 41 2d  54 52 41 4e 53 46 45 52  |  AMIGA-TRANSFER|
00000050  20 76 31 2e 33 0d 00 28  05 f4 0d 00 32 2a f4 20  | v1.3..(....2*. |
00000060  20 43 6f 6e 76 65 72 74  73 20 61 6e 20 41 6d 69  | Converts an Ami|
00000070  67 61 20 53 6f 75 6e 64  54 72 61 63 6b 65 72 20  |ga SoundTracker |
00000080  53 6f 6e 67 0d 00 3c 27  f4 20 20 20 20 20 20 74  |Song..<'.      t|
00000090  6f 20 38 30 25 20 69 6e  74 6f 20 61 20 43 6f 63  |o 80% into a Coc|
000000a0  6f 6e 69 7a 65 72 20 53  6f 6e 67 0d 00 46 05 f4  |onizer Song..F..|
000000b0  0d 00 50 27 f4 20 20 20  20 20 20 28 63 29 20 41  |..P'.      (c) A|
000000c0  75 67 75 73 74 20 31 39  39 30 20 62 79 20 50 6c  |ugust 1990 by Pl|
000000d0  61 79 66 69 65 6c 64 0d  00 5a 05 f4 0d 00 64 28  |ayfield..Z....d(|
000000e0  f4 20 20 20 20 20 20 4c  61 74 65 73 74 20 72 65  |.      Latest re|
000000f0  76 69 73 69 6f 6e 20 2d  20 32 36 20 44 65 63 20  |vision - 26 Dec |
00000100  31 39 39 30 0d 00 6e 05  f4 0d 00 78 2c f4 20 2d  |1990..n....x,. -|
00000110  2d 2d 2d 2d 2d 2d 2d 2d  2d 2d 2d 2d 2d 2d 2d 2d  |----------------|
*
00000130  2d 2d 2d 2d 2d 0d 00 82  04 0d 00 8c 2b ee 20 85  |-----.......+. .|
00000140  20 c8 99 20 22 48 6f 75  72 67 6c 61 73 73 5f 53  | .. "Hourglass_S|
00000150  6d 61 73 68 22 3a f1 20  f6 24 3b 22 20 40 20 22  |mash":. .$;" @ "|
00000160  3b 9e 3a e0 0d 00 96 04  0d 00 a0 32 2a 52 4d 45  |;.:........2*RME|
00000170  6e 73 75 72 65 20 50 61  63 6b 69 74 20 31 2e 35  |nsure Packit 1.5|
00000180  30 20 52 4d 4c 6f 61 64  20 21 43 6f 63 6f 6e 69  |0 RMLoad !Coconi|
00000190  7a 65 72 2e 50 61 63 6b  69 74 0d 00 aa 04 0d 00  |zer.Packit......|
000001a0  b4 1b 70 61 74 68 24 3d  22 5e 2e 41 6d 69 67 61  |..path$="^.Amiga|
000001b0  2e 4d 6f 64 75 6c 65 73  22 0d 00 be 3b 66 25 3d  |.Modules"...;f%=|
000001c0  8e 20 70 61 74 68 24 3a  e7 20 66 25 3d 30 20 e8  |. path$:. f%=0 .|
000001d0  27 22 41 6d 69 67 61 53  6f 6e 67 73 20 50 61 74  |'"AmigaSongs Pat|
000001e0  68 6e 61 6d 65 3f 20 22  70 61 74 68 24 20 8b 20  |hname? "path$ . |
000001f0  d9 23 66 25 0d 00 c8 12  ff 20 22 43 61 74 20 22  |.#f%..... "Cat "|
00000200  2b 70 61 74 68 24 0d 00  d2 24 e8 27 22 4f 72 69  |+path$...$.'"Ori|
00000210  67 69 6e 61 6c 20 41 6d  69 67 61 20 53 6f 6e 67  |ginal Amiga Song|
00000220  20 66 69 6c 65 3f 20 22  7a 24 0d 00 dc 13 7a 24  | file? "z$....z$|
00000230  3d 70 61 74 68 24 2b 22  2e 22 2b 7a 24 0d 00 e6  |=path$+"."+z$...|
00000240  0a 66 3d 8e 20 7a 24 0d  00 f0 30 20 20 6c 65 6e  |.f=. z$...0  len|
00000250  3d a2 23 66 3a 62 31 3d  9a 23 66 3a 62 32 3d 9a  |=.#f:b1=.#f:b2=.|
00000260  23 66 3a 62 33 3d 9a 23  66 3a 62 34 3d 9a 23 66  |#f:b3=.#f:b4=.#f|
00000270  3a 62 35 3d 9a 23 66 0d  00 fa 07 d9 23 66 0d 01  |:b5=.#f.....#f..|
00000280  04 42 e7 20 62 34 3d 30  20 80 20 62 35 3e 30 20  |.B. b4=0 . b5>0 |
00000290  8c 20 74 6f 74 61 6c 3d  62 31 2b 28 62 32 3c 3c  |. total=b1+(b2<<|
000002a0  38 29 2b 28 62 33 3c 3c  31 36 29 2b 28 62 34 3c  |8)+(b3<<16)+(b4<|
000002b0  3c 32 34 29 20 8b 20 74  6f 74 61 6c 3d 6c 65 6e  |<24) . total=len|
000002c0  0d 01 0e 04 0d 01 18 09  75 73 3d 34 38 0d 01 22  |........us=48.."|
000002d0  0e 6d 61 78 69 6e 73 74  3d 33 32 0d 01 2c 14 de  |.maxinst=32..,..|
000002e0  20 63 6f 64 65 20 39 31  32 2c 20 4c 25 2d 31 0d  | code 912, L%-1.|
000002f0  01 36 11 de 20 61 6d 69  67 61 20 74 6f 74 61 6c  |.6.. amiga total|
00000300  0d 01 40 16 e7 20 74 6f  74 61 6c 3c 31 32 38 2a  |..@.. total<128*|
00000310  31 30 32 34 20 8c 0d 01  4a 1f 20 20 de 20 74 72  |1024 ...J.  . tr|
00000320  61 63 6b 20 74 6f 74 61  6c 2b 31 36 2a 33 32 2c  |ack total+16*32,|
00000330  20 5a 25 2d 31 0d 01 54  05 cc 0d 01 5e 22 20 20  | Z%-1..T....^"  |
00000340  de 20 74 72 61 63 6b 20  31 32 38 2a 31 30 32 34  |. track 128*1024|
00000350  2b 31 36 2a 33 32 2c 20  5a 25 2d 31 0d 01 68 05  |+16*32, Z%-1..h.|
00000360  cd 0d 01 72 12 de 20 70  65 72 69 6f 64 73 28 38  |...r.. periods(8|
00000370  35 36 29 0d 01 7c 26 de  20 69 6e 73 74 6f 72 64  |56)..|&. instord|
00000380  28 6d 61 78 69 6e 73 74  29 2c 6e 61 6d 65 73 24  |(maxinst),names$|
00000390  28 6d 61 78 69 6e 73 74  29 0d 01 86 20 de 20 6c  |(maxinst)... . l|
000003a0  61 73 74 70 65 72 28 34  29 2c 66 6c 75 70 28 34  |astper(4),flup(4|
000003b0  29 2c 66 6c 64 6f 28 34  29 0d 01 90 04 0d 01 9a  |),fldo(4).......|
000003c0  0a f2 5f 49 6e 69 74 0d  01 a4 13 e7 20 62 34 3d  |.._Init..... b4=|
000003d0  30 20 80 20 62 35 3e 30  20 8c 0d 01 ae 22 20 20  |0 . b5>0 ...."  |
000003e0  ff 20 22 50 61 63 6b 6c  6f 61 64 20 22 2b 7a 24  |. "Packload "+z$|
000003f0  2b 22 20 22 2b c3 7e 61  6d 69 67 61 0d 01 b8 05  |+" "+.~amiga....|
00000400  cc 0d 01 c2 21 20 20 f1  20 22 4c 65 6e 20 69 73  |....!  . "Len is|
00000410  20 22 3b 74 6f 74 61 6c  3b 22 20 62 79 74 65 73  | ";total;" bytes|
00000420  20 22 0d 01 cc 1e 20 20  ff 20 22 4c 6f 61 64 20  | "....  . "Load |
00000430  22 2b 7a 24 2b 22 20 22  2b c3 7e 61 6d 69 67 61  |"+z$+" "+.~amiga|
00000440  0d 01 d6 05 cd 0d 01 e0  1c 42 25 3d 74 72 61 63  |.........B%=trac|
00000450  6b 3a 43 25 3d 5a 25 2d  31 20 3a d6 20 63 6f 64  |k:C%=Z%-1 :. cod|
00000460  65 0d 01 ea 04 0d 01 f4  44 e8 27 22 57 61 6e 74  |e.......D.'"Want|
00000470  20 74 6f 20 65 78 74 72  61 63 74 20 69 74 73 20  | to extract its |
00000480  69 6e 73 74 72 75 6d 65  6e 74 73 20 28 69 66 20  |instruments (if |
00000490  61 6e 20 41 6d 69 67 61  20 6d 6f 64 75 6c 65 29  |an Amiga module)|
000004a0  20 5b 79 5d 20 3f 20 22  3b 0d 01 fe 24 c8 99 20  | [y] ? ";...$.. |
000004b0  22 4f 53 5f 43 6f 6e 66  69 72 6d 22 20 b8 20 65  |"OS_Confirm" . e|
000004c0  78 74 72 61 3a f1 20 bd  65 78 74 72 61 0d 02 08  |xtra:. .extra...|
000004d0  17 65 78 74 72 61 3d 2d  28 65 78 74 72 61 3d 97  |.extra=-(extra=.|
000004e0  22 79 22 29 0d 02 12 21  e7 20 65 78 74 72 61 20  |"y")...!. extra |
000004f0  8c 20 2a 43 64 69 72 20  72 61 6d 3a 24 2e 53 61  |. *Cdir ram:$.Sa|
00000500  6d 70 6c 65 73 0d 02 1c  04 0d 02 26 4b f4 20 3d  |mples......&K. =|
00000510  3d 3d 3d 20 50 52 45 50  41 52 45 20 48 45 41 44  |=== PREPARE HEAD|
00000520  20 3d 3d 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  | ===============|
00000530  3d 3d 3d 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  |================|
*
00000550  3d 3d 3d 3d 0d 02 30 04  0d 02 3a 17 e7 20 61 6d  |====..0...:.. am|
00000560  69 67 61 3f 26 31 64 37  3d 97 22 78 22 20 8c 0d  |iga?&1d7=."x" ..|
00000570  02 44 4b 20 20 70 6f 6f  6c 3d 31 35 20 20 20 20  |.DK  pool=15    |
00000580  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
000005a0  20 20 20 20 20 20 20 20  20 20 20 3a 2a 7c 20 31  |           :*| 1|
000005b0  35 65 72 20 46 6f 72 6d  61 74 0d 02 4e 23 20 20  |5er Format..N#  |
000005c0  62 61 73 65 3d 61 6d 69  67 61 2b 26 31 64 38 3a  |base=amiga+&1d8:|
000005d0  68 6c 3d 61 6d 69 67 61  2b 26 32 35 38 0d 02 58  |hl=amiga+&258..X|
000005e0  05 cc 0d 02 62 4b 20 20  70 6f 6f 6c 3d 33 31 20  |....bK  pool=31 |
000005f0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000610  20 20 20 20 20 20 20 20  20 20 20 20 20 20 3a 2a  |              :*|
00000620  7c 20 33 31 65 72 20 46  6f 72 6d 61 74 0d 02 6c  || 31er Format..l|
00000630  23 20 20 62 61 73 65 3d  61 6d 69 67 61 2b 26 33  |#  base=amiga+&3|
00000640  62 38 3a 68 6c 3d 61 6d  69 67 61 2b 26 34 33 63  |b8:hl=amiga+&43c|
00000650  0d 02 76 05 cd 0d 02 80  04 0d 02 8a 48 74 72 61  |..v.........Htra|
00000660  63 6b 3f 30 3d 34 20 20  20 20 20 20 20 20 20 20  |ck?0=4          |
00000670  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000690  20 20 20 20 20 3a 2a 7c  20 34 20 56 6f 69 63 65  |     :*| 4 Voice|
000006a0  73 0d 02 94 0d 74 69 74  6c 65 24 3d 22 22 0d 02  |s....title$=""..|
000006b0  9e 0f e3 20 69 25 3d 30  20 b8 20 31 38 0d 02 a8  |... i%=0 . 18...|
000006c0  32 20 20 61 3d 61 6d 69  67 61 3f 69 25 3a e7 20  |2  a=amiga?i%:. |
000006d0  61 3e 33 31 20 8c 20 74  69 74 6c 65 24 2b 3d bd  |a>31 . title$+=.|
000006e0  61 20 8b 20 74 69 74 6c  65 24 2b 3d 22 20 22 0d  |a . title$+=" ".|
000006f0  02 b2 08 ed 20 69 25 0d  02 bc 4c 24 28 74 72 61  |.... i%...L$(tra|
00000700  63 6b 2b 31 29 3d 74 69  74 6c 65 24 20 20 20 20  |ck+1)=title$    |
00000710  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000730  20 20 20 3a 2a 7c 20 3f  32 30 20 3d 20 43 48 52  |   :*| ?20 = CHR|
00000740  24 31 33 0d 02 c6 04 0d  02 d0 35 f1 27 22 4e 41  |$13.......5.'"NA|
00000750  4d 45 3a 20 22 3b 74 69  74 6c 65 24 2c 22 28 22  |ME: ";title$,"("|
00000760  3b 70 6f 6f 6c 3b 22 20  69 6e 73 74 72 75 6d 65  |;pool;" instrume|
00000770  6e 74 20 66 6f 72 6d 61  74 29 22 27 0d 02 da 2f  |nt format)"'.../|
00000780  f5 20 61 3d a7 74 69 74  6c 65 24 2c 22 20 22 29  |. a=.title$," ")|
00000790  3a e7 20 61 20 8c 20 c1  74 69 74 6c 65 24 2c 61  |:. a . .title$,a|
000007a0  2c 31 29 3d 22 2f 22 3a  fd 20 a3 0d 02 e4 04 0d  |,1)="/":. ......|
000007b0  02 ee 4b f4 20 3d 3d 3d  3d 20 41 4c 4c 4f 43 41  |..K. ==== ALLOCA|
000007c0  54 45 20 49 4e 53 54 52  55 4d 45 4e 54 20 50 4f  |TE INSTRUMENT PO|
000007d0  4f 4c 20 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  |OL =============|
000007e0  3d 3d 3d 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  |================|
000007f0  3d 3d 3d 3d 3d 3d 3d 3d  3d 3d 0d 02 f8 04 0d 03  |==========......|
00000800  02 0a 74 6f 70 73 3d 30  0d 03 0c 10 6e 75 6d 73  |..tops=0....nums|
00000810  3d 62 61 73 65 3f 2d 32  0d 03 16 13 e3 20 69 25  |=base?-2..... i%|
00000820  3d 30 20 b8 20 6e 75 6d  73 2d 31 0d 03 20 48 20  |=0 . nums-1.. H |
00000830  20 e7 20 62 61 73 65 3f  69 25 3e 74 6f 70 73 20  | . base?i%>tops |
00000840  8c 20 74 6f 70 73 3d 62  61 73 65 3f 69 25 20 20  |. tops=base?i%  |
00000850  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00000860  20 20 20 3a 2a 7c 20 48  69 67 68 65 73 74 20 50  |   :*| Highest P|
00000870  61 74 74 0d 03 2a 08 ed  20 69 25 0d 03 34 04 0d  |att..*.. i%..4..|
00000880  03 3e 49 f1 22 20 20 20  20 4e 61 6d 65 20 20 20  |.>I."    Name   |
00000890  20 20 20 20 20 20 56 6f  6c 75 6d 65 20 20 20 52  |      Volume   R|
000008a0  65 70 41 74 20 20 20 20  52 65 70 4c 65 6e 20 20  |epAt    RepLen  |
000008b0  20 20 4c 65 6e 67 74 68  20 20 20 20 20 5b 4f 72  |  Length     [Or|
000008c0  69 67 69 6e 61 6c 5d 22  0d 03 48 48 f1 22 20 20  |iginal]"..HH."  |
000008d0  20 20 2d 2d 2d 2d 2d 2d  2d 2d 2d 2d 20 20 20 2d  |  ----------   -|
000008e0  2d 2d 2d 2d 2d 20 20 20  2d 2d 2d 2d 2d 20 20 20  |-----   -----   |
000008f0  20 2d 2d 2d 2d 2d 2d 20  20 20 20 2d 2d 2d 2d 2d  | ------    -----|
00000900  2d 20 20 20 20 20 20 2d  2d 2d 2d 2d 2d 2d 2d 22  |-      --------"|
00000910  0d 03 52 04 0d 03 5c 4c  64 61 74 61 3d 68 6c 2b  |..R...\Ldata=hl+|
00000920  28 74 6f 70 73 2b 31 29  2a 31 30 32 34 20 20 20  |(tops+1)*1024   |
00000930  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000950  3a 2a 7c 20 46 69 72 73  74 20 53 61 6d 70 6c 65  |:*| First Sample|
00000960  0d 03 66 49 70 63 3d 74  72 61 63 6b 2b 33 32 20  |..fIpc=track+32 |
00000970  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000990  20 20 20 20 20 20 20 20  20 20 20 20 3a 2a 7c 20  |            :*| |
000009a0  43 6f 63 6f 20 73 6f 6e  67 0d 03 70 0a 69 6e 73  |Coco song..p.ins|
000009b0  74 3d 30 0d 03 7a 04 0d  03 84 11 e3 20 69 25 3d  |t=0..z...... i%=|
000009c0  31 20 b8 20 70 6f 6f 6c  0d 03 8e 22 20 20 61 6d  |1 . pool..."  am|
000009d0  69 6e 66 3d 61 6d 69 67  61 2b 26 31 34 2b 28 28  |inf=amiga+&14+((|
000009e0  69 25 2d 31 29 2a 26 31  65 29 0d 03 98 0c 20 20  |i%-1)*&1e)....  |
000009f0  6e 61 24 3d 22 22 0d 03  a2 34 20 20 e3 20 6a 25  |na$=""...4  . j%|
00000a00  3d 30 20 b8 20 31 39 3a  e7 20 61 6d 69 6e 66 3f  |=0 . 19:. aminf?|
00000a10  6a 25 3e 33 31 20 8c 20  6e 61 24 2b 3d bd 28 61  |j%>31 . na$+=.(a|
00000a20  6d 69 6e 66 3f 6a 25 29  3a ed 0d 03 ac 25 20 20  |minf?j%):....%  |
00000a30  61 3d a7 6e 61 24 2c 22  3a 22 29 3a e7 20 61 20  |a=.na$,":"):. a |
00000a40  8c 20 6e 61 24 3d c1 6e  61 24 2c 61 2b 31 29 0d  |. na$=.na$,a+1).|
00000a50  03 b6 2d 20 20 e7 20 a9  6e 61 24 3e 31 30 20 8c  |..-  . .na$>10 .|
00000a60  20 61 24 3d c0 6e 61 24  2c 39 29 2b c2 6e 61 24  | a$=.na$,9)+.na$|
00000a70  2c 31 29 20 8b 20 61 24  3d 6e 61 24 0d 03 c0 24  |,1) . a$=na$...$|
00000a80  20 20 e3 20 6a 25 3d 31  20 b8 20 31 30 20 3a f4  |  . j%=1 . 10 :.|
00000a90  20 4c 65 6e 20 65 78 74  72 61 20 63 68 61 72 73  | Len extra chars|
00000aa0  0d 03 ca 3a 20 20 20 20  61 3d a7 61 24 2c c1 22  |...:    a=.a$,."|
00000ab0  20 2e 2a 23 24 26 40 5e  25 5c 22 2c 6a 25 2c 31  | .*#$&@^%\",j%,1|
00000ac0  29 29 3a e7 20 61 20 c1  61 24 2c 61 2c 31 29 3d  |)):. a .a$,a,1)=|
00000ad0  22 2d 22 3a e5 20 8d 64  4a 43 0d 03 d4 0a 20 20  |"-":. .dJC....  |
00000ae0  ed 20 6a 25 0d 03 de 11  20 20 e3 20 6a 25 3d 31  |. j%....  . j%=1|
00000af0  20 b8 20 31 30 0d 03 e8  38 20 20 20 20 61 3d 97  | . 10...8    a=.|
00000b00  28 c1 61 24 2c 6a 25 29  29 3a e7 20 61 3e 3d 97  |(.a$,j%)):. a>=.|
00000b10  22 41 22 20 80 20 61 3c  3d 97 22 5a 22 20 c1 61  |"A" . a<=."Z" .a|
00000b20  24 2c 6a 25 29 3d bd 28  61 2b 33 32 29 0d 03 f2  |$,j%)=.(a+32)...|
00000b30  0a 20 20 ed 20 6a 25 0d  03 fc 21 20 20 e7 20 61  |.  . j%...!  . a|
00000b40  24 3d 22 22 20 8c 20 61  24 3d c0 74 69 74 6c 65  |$="" . a$=.title|
00000b50  24 2c 38 29 2b c3 69 25  0d 04 06 04 0d 04 10 2a  |$,8)+.i%.......*|
00000b60  20 20 6c 65 6e 67 74 68  3d 28 28 61 6d 69 6e 66  |  length=((aminf|
00000b70  3f 32 32 29 2a 32 35 36  2b 28 61 6d 69 6e 66 3f  |?22)*256+(aminf?|
00000b80  32 33 29 29 2a 32 0d 04  1a 27 20 20 76 6f 6c 75  |23))*2...'  volu|
00000b90  6d 65 3d 20 28 61 6d 69  6e 66 3f 32 34 29 2a 32  |me= (aminf?24)*2|
00000ba0  35 36 2b 28 61 6d 69 6e  66 3f 32 35 29 0d 04 24  |56+(aminf?25)..$|
00000bb0  27 20 20 72 65 70 5f 61  74 3d 20 28 61 6d 69 6e  |'  rep_at= (amin|
00000bc0  66 3f 32 36 29 2a 32 35  36 2b 28 61 6d 69 6e 66  |f?26)*256+(aminf|
00000bd0  3f 32 37 29 0d 04 2e 2a  20 20 72 65 70 6c 65 6e  |?27)...*  replen|
00000be0  3d 28 28 61 6d 69 6e 66  3f 32 38 29 2a 32 35 36  |=((aminf?28)*256|
00000bf0  2b 28 61 6d 69 6e 66 3f  32 39 29 29 2a 32 0d 04  |+(aminf?29))*2..|
00000c00  38 3d 20 20 e7 20 72 65  70 6c 65 6e 3d 32 20 8c  |8=  . replen=2 .|
00000c10  20 72 65 70 5f 61 74 3d  30 3a 72 65 70 6c 65 6e  | rep_at=0:replen|
00000c20  3d 30 20 8b 20 e7 20 72  65 70 5f 61 74 3d 30 20  |=0 . . rep_at=0 |
00000c30  8c 20 72 65 70 5f 61 74  2b 3d 31 0d 04 42 1a 20  |. rep_at+=1..B. |
00000c40  20 76 6f 6c 75 6d 65 3d  a4 5f 6c 6f 67 28 76 6f  | volume=._log(vo|
00000c50  6c 75 6d 65 29 0d 04 4c  04 0d 04 56 12 20 20 e7  |lume)..L...V.  .|
00000c60  20 6c 65 6e 67 74 68 3e  32 20 8c 0d 04 60 09 20  | length>2 ...`. |
00000c70  20 20 20 f5 0d 04 6a 10  20 20 20 20 20 20 73 61  |   ...j.      sa|
00000c80  6d 65 3d b9 0d 04 74 15  20 20 20 20 20 20 e3 20  |me=...t.      . |
00000c90  6a 25 3d 31 20 b8 20 69  25 0d 04 7e 3d 20 20 20  |j%=1 . i%..~=   |
00000ca0  20 20 20 e7 20 6a 25 3c  3e 69 25 20 80 20 6e 61  |   . j%<>i% . na|
00000cb0  6d 65 73 24 28 6a 25 29  3d 61 24 20 8c 20 c2 61  |mes$(j%)=a$ . .a|
00000cc0  24 29 3d bd 28 97 28 c2  61 24 29 29 2b 31 29 3a  |$)=.(.(.a$))+1):|
00000cd0  73 61 6d 65 3d a3 0d 04  88 0e 20 20 20 20 20 20  |same=.....      |
00000ce0  ed 20 6a 25 0d 04 92 0e  20 20 20 20 fd 20 73 61  |. j%....    . sa|
00000cf0  6d 65 0d 04 9c 15 20 20  20 20 6e 61 6d 65 73 24  |me....    names$|
00000d00  28 69 25 29 3d 61 24 0d  04 a6 42 20 20 20 20 e7  |(i%)=a$...B    .|
00000d10  20 65 78 74 72 61 20 ff  22 53 61 76 65 20 72 61  | extra ."Save ra|
00000d20  6d 3a 24 2e 53 61 6d 70  6c 65 73 2e 22 2b 61 24  |m:$.Samples."+a$|
00000d30  2b 22 20 22 2b c3 7e 64  61 74 61 2b 22 20 2b 22  |+" "+.~data+" +"|
00000d40  2b c3 7e 6c 65 6e 67 74  68 0d 04 b0 0f 20 20 20  |+.~length....   |
00000d50  20 69 6e 73 74 2b 3d 31  0d 04 ba 4d 20 20 20 20  | inst+=1...M    |
00000d60  69 6e 73 74 6f 72 64 28  69 25 29 3d 69 6e 73 74  |instord(i%)=inst|
00000d70  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000d90  20 20 20 20 3a 2a 7c 20  4c 65 61 76 65 20 6e 6f  |    :*| Leave no|
00000da0  20 47 61 70 21 0d 04 c4  14 20 20 20 20 70 63 21  | Gap!....    pc!|
00000db0  30 34 3d 6c 65 6e 67 74  68 0d 04 ce 14 20 20 20  |04=length....   |
00000dc0  20 70 63 21 30 38 3d 76  6f 6c 75 6d 65 0d 04 d8  | pc!08=volume...|
00000dd0  14 20 20 20 20 70 63 21  31 32 3d 72 65 70 5f 61  |.    pc!12=rep_a|
00000de0  74 0d 04 e2 14 20 20 20  20 70 63 21 31 36 3d 72  |t....    pc!16=r|
00000df0  65 70 6c 65 6e 0d 04 ec  13 20 20 20 20 24 28 70  |eplen....    $(p|
00000e00  63 2b 32 30 29 3d 61 24  0d 04 f6 38 20 20 20 20  |c+20)=a$...8    |
00000e10  f1 20 c3 69 25 3b 22 20  3a 20 22 3b 61 24 3b 8a  |. .i%;" : ";a$;.|
00000e20  31 38 29 3b 76 6f 6c 75  6d 65 2c 72 65 70 5f 61  |18);volume,rep_a|
00000e30  74 2c 72 65 70 6c 65 6e  2c 6c 65 6e 67 74 68 3b  |t,replen,length;|
00000e40  0d 05 00 25 20 20 20 20  e7 20 a9 6e 61 24 3e 31  |...%    . .na$>1|
00000e50  30 20 8c 20 f1 20 22 20  20 28 22 6e 61 24 22 29  |0 . . "  ("na$")|
00000e60  22 20 8b 20 f1 0d 05 0a  0e 20 20 20 20 70 63 2b  |" . .....    pc+|
00000e70  3d 33 32 0d 05 14 14 20  20 20 20 64 61 74 61 2b  |=32....    data+|
00000e80  3d 6c 65 6e 67 74 68 0d  05 1e 06 20 cd 0d 05 28  |=length.... ...(|
00000e90  08 ed 20 69 25 0d 05 32  04 0d 05 3c 4b f4 20 3d  |.. i%..2...<K. =|
00000ea0  3d 3d 3d 20 50 4f 4b 45  20 53 45 51 55 45 4e 43  |=== POKE SEQUENC|
00000eb0  59 20 41 4e 44 20 41 4d  4f 55 4e 54 20 4f 46 20  |Y AND AMOUNT OF |
00000ec0  53 45 51 2f 50 41 54 54  53 20 3d 3d 3d 3d 3d 3d  |SEQ/PATTS ======|
00000ed0  3d 3d 3d 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  |================|
00000ee0  3d 3d 3d 3d 0d 05 46 04  0d 05 50 4a 74 72 61 63  |====..F...PJtrac|
00000ef0  6b 21 32 34 3d 70 63 2d  74 72 61 63 6b 20 20 20  |k!24=pc-track   |
00000f00  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000f20  20 20 20 20 3a 2a 7c 20  53 65 71 20 4f 66 66 73  |    :*| Seq Offs|
00000f30  65 74 0d 05 5a 2a e3 20  69 25 3d 30 20 b8 20 6e  |et..Z*. i%=0 . n|
00000f40  75 6d 73 2d 31 3a 3f 70  63 3d 62 61 73 65 3f 69  |ums-1:?pc=base?i|
00000f50  25 3a 70 63 2b 3d 31 3a  ed 20 69 25 0d 05 64 4b  |%:pc+=1:. i%..dK|
00000f60  3f 70 63 3d 26 66 66 3a  70 63 2b 3d 31 20 20 20  |?pc=&ff:pc+=1   |
00000f70  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
00000f90  20 20 20 20 20 20 20 20  3a 2a 7c 20 53 65 74 20  |        :*| Set |
00000fa0  45 6e 64 6d 61 72 6b 0d  05 6e 04 0d 05 78 48 f1  |Endmark..n...xH.|
00000fb0  27 22 50 61 74 74 65 72  6e 73 3a 20 22 3b 74 6f  |'"Patterns: ";to|
00000fc0  70 73 2b 31 2c 22 53 65  71 75 65 6e 63 69 65 73  |ps+1,"Sequencies|
00000fd0  3a 20 22 3b 6e 75 6d 73  27 20 20 20 20 20 20 20  |: ";nums'       |
00000fe0  20 20 20 3a 2a 7c 20 49  6e 63 6c 2e 20 50 61 74  |   :*| Incl. Pat|
00000ff0  74 20 30 0d 05 82 04 0d  05 8c 2d f4 20 3d 3d 3d  |t 0.......-. ===|
00001000  3d 20 43 4f 4e 56 45 52  54 20 50 41 54 54 45 52  |= CONVERT PATTER|
00001010  4e 53 20 28 55 41 41 48  48 48 48 2e 2e 2e 29 20  |NS (UAAHHHH...) |
00001020  3d 3d 3d 3d 0d 05 96 04  0d 05 a0 46 e7 20 70 63  |====.......F. pc|
00001030  20 83 20 34 20 8c 20 70  63 3d 28 70 63 20 84 20  | . 4 . pc=(pc . |
00001040  33 29 2b 31 20 20 20 20  20 20 20 20 20 20 20 20  |3)+1            |
00001050  20 20 20 20 20 20 20 20  20 20 20 20 20 3a 2a 7c  |             :*||
00001060  20 41 6c 69 67 6e 20 50  61 74 74 65 72 6e 0d 05  | Align Pattern..|
00001070  aa 4b 74 72 61 63 6b 21  32 38 3d 70 63 2d 74 72  |.Ktrack!28=pc-tr|
00001080  61 63 6b 20 20 20 20 20  20 20 20 20 20 20 20 20  |ack             |
00001090  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
000010a0  20 20 20 20 20 20 20 20  20 20 3a 2a 7c 20 50 61  |          :*| Pa|
000010b0  74 74 20 4f 66 66 73 65  74 0d 05 b4 4d 73 70 65  |tt Offset...Mspe|
000010c0  65 64 3d 36 2d 31 20 20  20 20 20 20 20 20 20 20  |ed=6-1          |
000010d0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
*
000010f0  20 20 20 20 20 3a 2a 7c  20 44 65 66 61 75 6c 74  |     :*| Default|
00001100  20 53 70 65 65 64 0d 05  be 04 0d 05 c8 15 c8 99  | Speed..........|
00001110  20 22 48 6f 75 72 67 6c  61 73 73 5f 4f 6e 22 0d  | "Hourglass_On".|
00001120  05 d2 11 e3 20 69 25 3d  30 20 b8 20 74 6f 70 73  |.... i%=0 . tops|
00001130  0d 05 dc 2b c8 99 20 22  48 6f 75 72 67 6c 61 73  |...+.. "Hourglas|
00001140  73 5f 50 65 72 63 65 6e  74 61 67 65 22 2c 69 25  |s_Percentage",i%|
00001150  2a 31 30 30 20 81 20 74  6f 70 73 0d 05 e6 0f e3  |*100 . tops.....|
00001160  20 6a 25 3d 30 20 b8 20  36 33 0d 05 f0 0e e3 20  | j%=0 . 63..... |
00001170  6b 25 3d 31 20 b8 20 34  0d 05 fa 0d 20 20 c8 8e  |k%=1 . 4....  ..|
00001180  20 6b 25 20 ca 0d 06 04  3e 20 20 c9 20 31 3a 20  | k% ....>  . 1: |
00001190  70 61 74 3d 70 63 2b 28  33 2d 31 29 2a 34 20 20  |pat=pc+(3-1)*4  |
000011a0  20 20 20 20 20 20 20 20  20 3a 2a 7c 20 53 65 74  |         :*| Set|
000011b0  20 72 65 61 6c 20 73 74  65 72 65 6f 20 6c 6f 67  | real stereo log|
000011c0  69 63 21 0d 06 0e 3e 20  20 c9 20 32 3a 20 70 61  |ic!...>  . 2: pa|
000011d0  74 3d 70 63 2b 28 32 2d  31 29 2a 34 20 20 20 20  |t=pc+(2-1)*4    |
000011e0  20 20 20 20 20 20 20 3a  2a 7c 20 66 6f 72 20 74  |       :*| for t|
000011f0  68 65 20 66 6f 75 72 20  63 6f 6c 75 6d 6e 73 2e  |he four columns.|
00001200  2e 0d 06 18 19 20 20 c9  20 33 3a 20 70 61 74 3d  |.....  . 3: pat=|
00001210  70 63 2b 28 31 2d 31 29  2a 34 0d 06 22 19 20 20  |pc+(1-1)*4..".  |
00001220  c9 20 34 3a 20 70 61 74  3d 70 63 2b 28 34 2d 31  |. 4: pat=pc+(4-1|
00001230  29 2a 34 0d 06 2c 07 20  20 cb 0d 06 36 04 0d 06  |)*4..,.  ...6...|
00001240  40 3b 20 20 70 65 72 3d  68 6c 3f 30 2a 32 35 36  |@;  per=hl?0*256|
00001250  2b 68 6c 3f 31 20 20 20  20 20 20 20 20 20 20 20  |+hl?1           |
00001260  20 20 20 20 20 3a 2a 7c  20 47 65 74 20 41 6d 69  |     :*| Get Ami|
00001270  67 61 20 50 65 72 69 6f  64 0d 06 4a 17 20 20 e7  |ga Period..J.  .|
00001280  20 70 65 72 3e 38 35 36  20 8c 20 70 65 72 3d 30  | per>856 . per=0|
00001290  0d 06 54 46 20 20 6e 6f  74 65 3d 70 65 72 69 6f  |..TF  note=perio|
000012a0  64 73 28 70 65 72 29 20  20 20 20 20 20 20 20 20  |ds(per)         |
000012b0  20 20 20 20 20 20 20 3a  2a 7c 20 41 70 70 72 6f  |       :*| Appro|
000012c0  70 72 69 61 74 65 20 43  6f 63 6f 20 6e 6f 74 65  |priate Coco note|
000012d0  20 76 61 6c 75 65 0d 06  5e 4b 20 20 6e 6f 74 65  | value..^K  note|
000012e0  2b 3d 33 2a 31 32 20 20  20 20 20 20 20 20 20 20  |+=3*12          |
000012f0  20 20 20 20 20 20 20 20  20 20 20 20 20 3a 2a 7c  |             :*||
00001300  20 41 6d 69 20 75 73 65  73 20 4e 6f 74 65 20 31  | Ami uses Note 1|
00001310  20 61 73 20 4d 69 64 20  43 20 28 4f 63 74 20 30  | as Mid C (Oct 0|
00001320  29 0d 06 68 47 20 20 e7  20 70 65 72 20 8c 20 70  |)..hG  . per . p|
00001330  61 74 3f 33 3d 6e 6f 74  65 20 20 20 20 20 20 20  |at?3=note       |
00001340  20 20 20 20 3a 2a 7c 20  43 6f 63 6f 20 68 61 73  |    :*| Coco has|
00001350  20 4e 6f 74 65 73 20 66  72 6f 6d 20 4f 63 74 20  | Notes from Oct |
00001360  2d 33 20 74 6f 20 2b 34  0d 06 72 04 0d 06 7c 40  |-3 to +4..r...|@|
00001370  20 20 6e 69 62 3d 28 68  6c 3f 32 20 80 20 26 66  |  nib=(hl?2 . &f|
00001380  30 29 20 3e 3e 34 20 20  20 20 20 20 20 20 20 20  |0) >>4          |
00001390  20 3a 2a 7c 20 4d 61 6b  65 20 49 6e 73 74 4e 69  | :*| Make InstNi|
000013a0  62 62 6c 65 20 74 6f 20  42 79 74 65 0d 06 86 47  |bble to Byte...G|
000013b0  20 20 70 61 74 3f 32 3d  69 6e 73 74 6f 72 64 28  |  pat?2=instord(|
000013c0  6e 69 62 29 20 20 20 20  20 20 20 20 20 20 20 20  |nib)            |
000013d0  20 20 20 3a 2a 7c 20 57  65 6c 6c 2c 20 6e 6f 20  |   :*| Well, no |
000013e0  65 6d 70 74 79 20 49 6e  73 74 20 45 6e 74 72 69  |empty Inst Entri|
000013f0  65 73 21 0d 06 90 04 0d  06 9a 43 20 20 63 6f 6d  |es!.......C  com|
00001400  3d 28 68 6c 3f 32 20 80  20 26 30 66 29 20 20 20  |=(hl?2 . &0f)   |
00001410  20 20 20 20 20 20 20 20  20 20 20 20 3a 2a 7c 20  |            :*| |
00001420  4d 61 6b 65 20 43 6f 6d  6d 61 6e 64 4e 69 62 62  |Make CommandNibb|
00001430  6c 65 20 74 6f 20 42 79  74 65 0d 06 a4 49 20 20  |le to Byte...I  |
00001440  70 61 74 3f 31 3d 63 6f  6d 20 20 20 20 20 20 20  |pat?1=com       |
00001450  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001460  20 3a 2a 7c 20 4c 6f 74  73 20 6f 66 20 6d 61 69  | :*| Lots of mai|
00001470  6e 20 43 6f 6d 6d 61 6e  64 73 20 61 72 65 20 6b  |n Commands are k|
00001480  65 70 74 0d 06 ae 37 20  20 69 6e 66 3d 68 6c 3f  |ept...7  inf=hl?|
00001490  33 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |3               |
000014a0  20 20 20 20 20 20 20 20  20 20 3a 2a 7c 20 47 65  |          :*| Ge|
000014b0  74 20 49 6e 66 6f 42 79  74 65 0d 06 b8 04 0d 06  |t InfoByte......|
000014c0  c2 0e 20 20 c8 8e 20 63  6f 6d 20 ca 0d 06 cc 0c  |..  .. com .....|
000014d0  20 20 c9 20 31 2c 32 3a  0d 06 d6 3f 20 20 20 20  |  . 1,2:...?    |
000014e0  e7 20 70 65 72 3d 30 20  8c 20 70 65 72 3d 6c 61  |. per=0 . per=la|
000014f0  73 74 70 65 72 28 6b 25  29 3a e7 20 70 65 72 3d  |stper(k%):. per=|
00001500  30 20 8c 20 70 65 72 3d  31 30 30 3a f1 20 22 3f  |0 . per=100:. "?|
00001510  53 6c 69 64 65 30 22 0d  06 e0 33 20 20 20 20 66  |Slide0"...3    f|
00001520  31 3d 33 35 37 35 38 37  32 2f 70 65 72 3a 6f 75  |1=3575872/per:ou|
00001530  74 31 3d 28 66 31 2f 28  31 30 30 30 30 30 30 2f  |t1=(f1/(1000000/|
00001540  75 73 29 29 2a 36 35 35  33 36 0d 06 ea 39 20 20  |us))*65536...9  |
00001550  20 20 e7 20 63 6f 6d 3d  31 20 8c 20 6e 65 77 3d  |  . com=1 . new=|
00001560  70 65 72 2d 73 70 65 65  64 2a 69 6e 66 3a e7 20  |per-speed*inf:. |
00001570  6e 65 77 3c 20 26 37 31  20 8c 20 6e 65 77 3d 20  |new< &71 . new= |
00001580  26 37 31 0d 06 f4 39 20  20 20 20 e7 20 63 6f 6d  |&71...9    . com|
00001590  3d 32 20 8c 20 6e 65 77  3d 70 65 72 2b 73 70 65  |=2 . new=per+spe|
000015a0  65 64 2a 69 6e 66 3a e7  20 6e 65 77 3e 26 33 35  |ed*inf:. new>&35|
000015b0  38 20 8c 20 6e 65 77 3d  26 33 35 38 0d 06 fe 33  |8 . new=&358...3|
000015c0  20 20 20 20 66 32 3d 33  35 37 35 38 37 32 2f 6e  |    f2=3575872/n|
000015d0  65 77 3a 6f 75 74 32 3d  28 66 32 2f 28 31 30 30  |ew:out2=(f2/(100|
000015e0  30 30 30 30 2f 75 73 29  29 2a 36 35 35 33 36 0d  |0000/us))*65536.|
000015f0  07 08 1e 20 20 20 20 e7  20 63 6f 6d 3d 31 20 8c  |...    . com=1 .|
00001600  20 c8 94 20 6f 75 74 31  2c 6f 75 74 32 0d 07 12  | .. out1,out2...|
00001610  24 20 20 20 20 69 6e 66  3d 28 28 6f 75 74 31 2d  |$    inf=((out1-|
00001620  6f 75 74 32 29 2f 73 70  65 65 64 29 20 81 20 36  |out2)/speed) . 6|
00001630  34 0d 07 1c 2d 20 20 20  20 e7 20 69 6e 66 3d 30  |4...-    . inf=0|
00001640  20 8c 20 69 6e 66 3d 31  20 8b 20 e7 20 69 6e 66  | . inf=1 . . inf|
00001650  3e 32 35 35 20 8c 20 69  6e 66 3d 32 35 35 0d 07  |>255 . inf=255..|
00001660  26 0f 20 20 20 20 70 65  72 3d 6e 65 77 0d 07 30  |&.    per=new..0|
00001670  04 0d 07 3a 43 20 20 c9  20 33 2c 34 2c 35 2c 36  |...:C  . 3,4,5,6|
00001680  2c 37 2c 38 2c 39 2c 26  42 2c 26 45 3a 20 70 61  |,7,8,9,&B,&E: pa|
00001690  74 3f 31 3d 30 3a 69 6e  66 3d 30 3a f1 20 22 3f  |t?1=0:inf=0:. "?|
000016a0  41 6d 69 67 61 20 63 6f  6d 6d 61 6e 64 20 22 3b  |Amiga command ";|
000016b0  7e 63 6f 6d 0d 07 44 04  0d 07 4e 0b 20 20 c9 20  |~com..D...N.  . |
000016c0  26 41 3a 0d 07 58 17 20  20 20 20 e7 20 28 69 6e  |&A:..X.    . (in|
000016d0  66 20 80 20 26 66 30 29  20 8c 0d 07 62 47 20 20  |f . &f0) ...bG  |
000016e0  20 20 20 20 70 61 74 3f  31 3d 33 3a 69 6e 66 3d  |    pat?1=3:inf=|
000016f0  28 69 6e 66 20 80 20 26  65 30 29 20 3e 3e 38 20  |(inf . &e0) >>8 |
00001700  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001710  20 20 20 20 3a 2a 7c 20  56 6f 6c 75 6d 65 20 75  |    :*| Volume u|
00001720  70 0d 07 6c 1e 20 20 20  20 20 20 69 6e 66 3d 32  |p..l.      inf=2|
00001730  2a 69 6e 66 20 2d 32 2a  28 69 6e 66 3d 30 29 0d  |*inf -2*(inf=0).|
00001740  07 76 09 20 20 20 20 cd  0d 07 80 17 20 20 20 20  |.v.    .....    |
00001750  e7 20 28 69 6e 66 20 80  20 26 30 66 29 20 8c 0d  |. (inf . &0f) ..|
00001760  07 8a 49 20 20 20 20 20  20 70 61 74 3f 31 3d 34  |..I      pat?1=4|
00001770  3a 69 6e 66 3d 69 6e 66  20 80 20 26 30 65 20 20  |:inf=inf . &0e  |
00001780  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001790  20 20 20 20 20 20 20 20  20 3a 2a 7c 20 56 6f 6c  |         :*| Vol|
000017a0  75 6d 65 20 64 6f 77 6e  0d 07 94 1e 20 20 20 20  |ume down....    |
000017b0  20 20 69 6e 66 3d 32 2a  69 6e 66 20 2d 32 2a 28  |  inf=2*inf -2*(|
000017c0  69 6e 66 3d 30 29 0d 07  9e 09 20 20 20 20 cd 0d  |inf=0)....    ..|
000017d0  07 a8 04 0d 07 b2 46 20  20 c9 20 26 63 3a 20 69  |......F  . &c: i|
000017e0  6e 66 3d a4 5f 6c 6f 67  28 69 6e 66 29 20 80 20  |nf=._log(inf) . |
000017f0  26 66 65 20 20 20 20 20  20 20 20 20 20 20 20 20  |&fe             |
00001800  20 20 20 20 20 20 20 20  20 3a 2a 7c 20 4c 53 42  |         :*| LSB|
00001810  20 56 6f 6c 75 6d 65 73  21 0d 07 bc 04 0d 07 c6  | Volumes!.......|
00001820  47 20 20 c9 20 26 66 3a  20 73 70 65 65 64 3d 28  |G  . &f: speed=(|
00001830  69 6e 66 20 80 20 26 30  66 29 2d 31 20 20 20 20  |inf . &0f)-1    |
00001840  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001850  20 20 20 20 3a 2a 7c 20  52 69 67 68 74 20 4e 69  |    :*| Right Ni|
00001860  62 62 6c 65 0d 07 d0 04  0d 07 da 07 20 20 cb 0d  |bble........  ..|
00001870  07 e4 04 0d 07 ee 0f 20  20 e7 20 69 6e 66 3d 30  |.......  . inf=0|
00001880  20 8c 0d 07 f8 3f 20 20  20 20 e7 20 66 6c 75 70  | ....?    . flup|
00001890  28 6b 25 29 3d 31 20 8c  20 70 61 74 3f 31 3d 38  |(k%)=1 . pat?1=8|
000018a0  3a 66 6c 75 70 28 6b 25  29 3d 30 20 3a 2a 7c 20  |:flup(k%)=0 :*| |
000018b0  43 6c 65 61 72 20 41 75  74 6f 20 56 6f 6c 20 75  |Clear Auto Vol u|
000018c0  70 0d 08 02 41 20 20 20  20 e7 20 66 6c 64 6f 28  |p...A    . fldo(|
000018d0  6b 25 29 3d 31 20 8c 20  70 61 74 3f 31 3d 39 3a  |k%)=1 . pat?1=9:|
000018e0  66 6c 64 6f 28 6b 25 29  3d 30 20 3a 2a 7c 20 43  |fldo(k%)=0 :*| C|
000018f0  6c 65 61 72 20 41 75 74  6f 20 56 6f 6c 20 64 6f  |lear Auto Vol do|
00001900  77 6e 0d 08 0c 07 20 20  cd 0d 08 16 04 0d 08 20  |wn....  ....... |
00001910  45 20 20 70 61 74 3f 30  3d 69 6e 66 20 20 20 20  |E  pat?0=inf    |
00001920  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001930  20 20 20 20 20 20 20 20  20 20 20 3a 2a 7c 20 57  |           :*| W|
00001940  72 69 74 65 20 62 61 63  6b 20 49 6e 66 6f 42 79  |rite back InfoBy|
00001950  74 65 0d 08 2a 40 20 20  e7 20 70 65 72 20 8c 20  |te..*@  . per . |
00001960  6c 61 73 74 70 65 72 28  6b 25 29 3d 70 65 72 20  |lastper(k%)=per |
00001970  20 20 20 20 20 20 20 20  20 20 20 20 3a 2a 7c 20  |            :*| |
00001980  53 61 76 65 20 6c 65 67  61 6c 20 50 65 72 69 6f  |Save legal Perio|
00001990  64 65 0d 08 34 04 0d 08  3e 0b 20 20 68 6c 2b 3d  |de..4...>.  hl+=|
000019a0  34 0d 08 48 08 ed 20 6b  25 0d 08 52 46 70 63 2b  |4..H.. k%..RFpc+|
000019b0  3d 31 36 20 20 20 20 20  20 20 20 20 20 20 20 20  |=16             |
000019c0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
000019d0  20 20 20 20 20 20 20 3a  2a 7c 20 4f 6e 65 20 72  |       :*| One r|
000019e0  6f 77 20 68 61 73 20 34  20 4c 57 6f 72 64 73 0d  |ow has 4 LWords.|
000019f0  08 5c 0b ed 20 6a 25 2c  69 25 0d 08 66 18 c8 99  |.\.. j%,i%..f...|
00001a00  20 22 48 6f 75 72 67 6c  61 73 73 5f 53 6d 61 73  | "Hourglass_Smas|
00001a10  68 22 0d 08 70 04 0d 08  7a 4b f4 20 3d 3d 3d 3d  |h"..p...zK. ====|
00001a20  20 53 41 56 45 20 26 20  46 49 4e 49 20 3d 3d 3d  | SAVE & FINI ===|
00001a30  3d 3d 3d 3d 3d 3d 3d 3d  3d 3d 3d 3d 3d 3d 3d 3d  |================|
*
00001a60  3d 0d 08 84 04 0d 08 8e  11 74 72 61 63 6b 3f 32  |=........track?2|
00001a70  31 3d 69 6e 73 74 0d 08  98 11 74 72 61 63 6b 3f  |1=inst....track?|
00001a80  32 32 3d 6e 75 6d 73 0d  08 a2 13 74 72 61 63 6b  |22=nums....track|
00001a90  3f 32 33 3d 74 6f 70 73  2b 31 0d 08 ac 43 74 72  |?23=tops+1...Ctr|
00001aa0  61 63 6b 21 33 32 3d 70  63 2d 74 72 61 63 6b 20  |ack!32=pc-track |
00001ab0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 20 20  |                |
00001ac0  20 20 20 20 20 20 20 20  3a 2a 7c 20 53 61 6d 70  |        :*| Samp|
00001ad0  6c 65 44 61 74 61 20 4f  66 66 73 65 74 0d 08 b6  |leData Offset...|
00001ae0  04 0d 08 c0 10 6c 65 6e  3d 70 63 2d 74 72 61 63  |.....len=pc-trac|
00001af0  6b 0d 08 ca 1d e8 27 27  22 44 65 73 74 69 6e 61  |k.....''"Destina|
00001b00  74 69 6f 6e 20 6e 61 6d  65 3f 20 22 7a 24 0d 08  |tion name? "z$..|
00001b10  d4 2a ff 20 22 50 61 63  6b 73 61 76 65 20 22 2b  |.*. "Packsave "+|
00001b20  7a 24 2b 22 20 22 2b c3  7e 74 72 61 63 6b 2b 22  |z$+" "+.~track+"|
00001b30  20 22 2b c3 7e 6c 65 6e  0d 08 de 05 e0 0d 08 e8  | "+.~len........|
00001b40  04 0d 08 f2 13 20 20 c9  20 41 75 74 6f 76 6f 6c  |.....  . Autovol|
00001b50  75 6d 65 3f 0d 08 fc 17  20 20 20 20 e7 20 28 69  |ume?....    . (i|
00001b60  6e 66 20 80 20 26 66 30  29 20 8c 0d 09 06 49 20  |nf . &f0) ....I |
00001b70  20 20 20 20 20 70 61 74  3f 31 3d 38 3a 66 6c 75  |     pat?1=8:flu|
00001b80  70 28 6b 25 29 3d 31 3a  69 6e 66 3d 28 69 6e 66  |p(k%)=1:inf=(inf|
00001b90  20 80 20 26 65 30 29 20  3e 3e 38 20 20 20 20 20  | . &e0) >>8     |
00001ba0  20 20 20 20 20 3a 2a 7c  20 41 75 74 6f 20 56 6f  |     :*| Auto Vo|
00001bb0  6c 20 75 70 0d 09 10 1e  20 20 20 20 20 20 69 6e  |l up....      in|
00001bc0  66 3d 32 2a 69 6e 66 20  2d 32 2a 28 69 6e 66 3d  |f=2*inf -2*(inf=|
00001bd0  30 29 0d 09 1a 09 20 20  20 20 cd 0d 09 24 17 20  |0)....    ...$. |
00001be0  20 20 20 e7 20 28 69 6e  66 20 80 20 26 30 66 29  |   . (inf . &0f)|
00001bf0  20 8c 0d 09 2e 4b 20 20  20 20 20 20 70 61 74 3f  | ....K      pat?|
00001c00  31 3d 39 3a 66 6c 64 6f  28 6b 25 29 3d 31 3a 69  |1=9:fldo(k%)=1:i|
00001c10  6e 66 3d 69 6e 66 20 80  20 26 30 65 20 20 20 20  |nf=inf . &0e    |
00001c20  20 20 20 20 20 20 20 20  20 20 20 20 3a 2a 7c 20  |            :*| |
00001c30  41 75 74 6f 20 56 6f 6c  20 64 6f 77 6e 0d 09 38  |Auto Vol down..8|
00001c40  1e 20 20 20 20 20 20 69  6e 66 3d 32 2a 69 6e 66  |.      inf=2*inf|
00001c50  20 2d 32 2a 28 69 6e 66  3d 30 29 0d 09 42 09 20  | -2*(inf=0)..B. |
00001c60  20 20 20 cd 0d 09 4c 04  0d 09 56 0e dd 20 a4 5f  |   ...L...V.. ._|
00001c70  6c 6f 67 28 78 29 0d 09  60 1e e7 20 78 3e 36 34  |log(x)..`.. x>64|
00001c80  20 8c 20 f1 20 22 3f 56  6f 6c 20 3e 36 34 22 3a  | . . "?Vol >64":|
00001c90  78 3d 36 34 0d 09 6a 48  3d 31 38 31 2d a8 28 31  |x=64..jH=181-.(1|
00001ca0  30 30 2a ab 28 78 2b 31  29 29 20 20 20 20 20 20  |00*.(x+1))      |
00001cb0  20 20 20 20 20 20 20 20  20 20 20 20 20 20 3a 2a  |              :*|
00001cc0  7c 20 4c 6f 67 61 72 69  74 68 6d 20 56 6f 6c 75  || Logarithm Volu|
00001cd0  6d 65 20 2d 3e 20 6c 69  6e 65 61 72 0d 09 74 04  |me -> linear..t.|
00001ce0  0d 09 7e 0c dd 20 f2 5f  49 6e 69 74 0d 09 88 19  |..~.. ._Init....|
00001cf0  e3 20 70 3d 25 31 30 30  30 20 b8 20 25 31 30 31  |. p=%1000 . %101|
00001d00  30 20 88 20 32 0d 09 92  0b 50 25 3d 63 6f 64 65  |0 . 2....P%=code|
00001d10  0d 09 9c 0a 5b 4f 50 54  20 70 0d 09 a6 10 20 6d  |....[OPT p.... m|
00001d20  6f 76 20 20 20 72 33 2c  23 30 0d 09 b0 0a 2e 63  |ov   r3,#0.....c|
00001d30  6c 65 61 72 0d 09 ba 15  20 73 74 72 20 20 20 72  |lear.... str   r|
00001d40  33 2c 5b 72 31 5d 2c 23  34 0d 09 c4 10 20 63 6d  |3,[r1],#4.... cm|
00001d50  70 20 20 20 72 31 2c 72  32 0d 09 ce 10 20 62 4c  |p   r1,r2.... bL|
00001d60  6f 20 20 20 63 6c 65 61  72 0d 09 d8 11 20 6d 6f  |o   clear.... mo|
00001d70  76 20 20 20 70 63 2c 72  31 34 0d 09 e2 09 5d 3a  |v   pc,r14....]:|
00001d80  ed 20 70 0d 09 ec 04 0d  09 f6 26 e3 20 69 25 3d  |. p.......&. i%=|
00001d90  31 20 b8 20 33 36 3a f3  20 61 3a 70 65 72 69 6f  |1 . 36:. a:perio|
00001da0  64 73 28 61 29 3d 69 25  3a ed 20 69 25 0d 0a 00  |ds(a)=i%:. i%...|
00001db0  45 dc 20 38 35 36 2c 38  30 38 2c 37 36 32 2c 37  |E. 856,808,762,7|
00001dc0  32 30 2c 36 37 38 2c 36  34 30 2c 36 30 34 2c 35  |20,678,640,604,5|
00001dd0  37 30 2c 35 33 38 2c 35  30 38 2c 34 38 30 2c 34  |70,538,508,480,4|
00001de0  35 33 20 20 20 20 3a 2a  7c 20 53 74 61 72 74 20  |53    :*| Start |
00001df0  61 74 0d 0a 0a 46 dc 20  34 32 38 2c 34 30 34 2c  |at...F. 428,404,|
00001e00  33 38 31 2c 33 36 30 2c  33 33 39 2c 33 32 30 2c  |381,360,339,320,|
00001e10  33 30 32 2c 32 38 35 2c  32 36 39 2c 32 35 34 2c  |302,285,269,254,|
00001e20  32 34 30 2c 32 32 36 20  20 20 20 3a 2a 7c 20 69  |240,226    :*| i|
00001e30  6e 74 65 72 6e 61 74 2e  0d 0a 14 45 dc 20 32 31  |nternat....E. 21|
00001e40  34 2c 32 30 32 2c 31 39  30 2c 31 38 30 2c 31 37  |4,202,190,180,17|
00001e50  30 2c 31 36 30 2c 31 35  31 2c 31 34 33 2c 31 33  |0,160,151,143,13|
00001e60  35 2c 31 32 37 2c 31 32  30 2c 31 31 33 20 20 20  |5,127,120,113   |
00001e70  20 3a 2a 7c 20 4f 63 74  61 76 65 20 30 0d 0a 1e  | :*| Octave 0...|
00001e80  05 e1 0d ff                                       |....|
00001e84