123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- function lstinf$(a$,b$,c$)
- adra=1:adrb=1:blngt=len(b$):d$=""
- while adrb<=blngt
- if mid$ (a$,adra,1)=mid$ (b$,adrb,1) then:adrb+=1:end if
- adra=adra+1
- end while
- while mid$(a$,adra,1)<>left$(c$,1)
- d$=d$+mid$(a$,adra,1):adra=adra+1
- end while
- lstinf$=d$
- end function
- function vldc(a$)
- t0$="!"+a$+".0.0.0."
- t1$=lstinf$(t0$,"!",".")
- t2$=lstinf$(t0$,".",".")
- t3=10^(len(t2$))
- vldc=val(t1$)+(val(t2$)/t3)
- end function
- dim chfq[16],chvl[16]
- finp$="_.csv"
- if argc>2 then:finp$=argv(2):end if
- print"56676D20 FFFFFF0F 6101000000000000000000004F0A000030130800A700"
- print"0000000000003C0000000000000000000000000000008C00000000000000"
- print"000000000000000000000000000000000000000000000000000000000000"
- print"000000000000000000000000000000000000000000000000000000000000"
- print"000000000000000000000000000000000000000000000000000000000000"
- print"0000000000000000000000000000999E3600000000000000000000000000"
- print"000000000000000000000000"
- print"B901FF "
- print"B90000"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90800 B90900 "
- print"B90001"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90002"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90003"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90004"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90700"
- print"B90005"
- print"B90400 B905FF"
- print"B90600 B90601 B90602 B90603"
- print"B90604 B90605 B90606 B90607"
- print"B90608 B90609 B9060A B9060B"
- print"B9060C B9060D B9060E B9060F"
- print"B90610 B90611 B90612 B90613"
- print"B90614 B90615 B90616 B90617"
- print"B90618 B90619 B9061A B9061B"
- print"B9061C B9061D B9061E B9061F"
- print"B90700"
- print"B90000 B902FF B9030F B9049F"
- print"B90001 B902FF B9030F B9049F"
- print"B90002 B902FF B9030F B9049F"
- print"B90003 B902FF B9030F B9049F"
- print"B90004 B902FF B9030F B9049F"
- print"B90005 B902FF B9030F B9049F"
- print"B90000 B90480"
- print"B90001 B90480"
- print"B90002 B90480"
- print"B90003 B90480"
- print"B90004 B90480"
- print"B90005 B90480"
- lct=0
- open finp$ for input as #1
- while eof(1)=0
- file input #1,txrd$
- setcaption("b:"+str$(lct)):lct+=1
- if mid$(txrd$,1,1)="[" then:
- if mid$(txrd$,2,1)="f" then:
- chid=val(mid$(txrd$,3,2))
- chid=chid mod 6 'huc6280 has 6 channels
- chfqv=vldc(lstinf$(txrd$,":","]"))
- chfqv2=int(26.6984611843*2^(8-chfqv))
- if chfqv2>2047 then:chfqv2=2047:end if
- if chfqv2<0 then:chfqv2=0:end if
- chchrfq$=right$("000"+hex$(chfqv2),3)
- txrgo$="B900"+right$("00"+hex$(chid),2)
- txrgo$+=" B902"+mid$(chchrfq$,2,2)
- txrgo$+=" B9030"+mid$(chchrfq$,1,1)
- print ucase$(txrgo$)
- end if
- if mid$(txrd$,2,1)="v" then:
- chid=val(mid$(txrd$,3,2))
- chid=chid mod 6 'huc6280 has 6 channels
- chvlv=vldc(lstinf$(txrd$,":","]"))*0x10
- chchrvl$=right$("00"+hex$(chvlv),1)
- txrgo$="B900"+right$("00"+hex$(chid),2)
- txrgo$+="B9048"+chchrvl$
- print ucase$(txrgo$)
- end if
- if mid$(txrd$,2,3)="wvb" then:
- wvblv=vldc(lstinf$(txrd$,":","]"))
- wvblv2=wvblv*44100
- wvblv3a=wvblv2 mod 65536
- wvblv3b=int(wvblv2/65536)
- wvblv3as$=ucase$(right$("0000"+hex$(wvblv3a),4))
- for ii=1 to wvblv3b:print"61FFFF":next
- print "61"+mid$(wvblv3as$,3,2)+mid$(wvblv3as$,1,2)
- end if
- end if
- wend
- print:print "66":print
- close #1
|