Update RPi.Command and driver for it

This commit is contained in:
Terence Boldt 2022-03-03 22:23:04 -05:00
parent 707c704119
commit 55d94dd1f0
7 changed files with 236 additions and 266 deletions

View File

@ -42,6 +42,13 @@ SlotL = $fe
SlotH = $ff SlotH = $ff
ESC = $9b ESC = $9b
;macro for string with high-bit set
.macro aschi str
.repeat .strlen (str), c
.byte .strat (str, c) | $80
.endrep
.endmacro
.org $2000 .org $2000
ldx #$07 ; start at slot 7 ldx #$07 ; start at slot 7
DetectSlot: DetectSlot:
@ -78,21 +85,22 @@ nextSlot:
rts rts
Start: Start:
stx slotx + $1e01 ;set the slot for the driver stx slotx + $1e01 ;set the slot for the driver
ldy #$00
PrintString:
lda Text,y
beq copyDriver
ora #$80
jsr PrintChar
iny
bne PrintString
copyDriver:
ldx #$00 ldx #$00
copyDriver: copyDriverByte:
lda $2100,x lda $2100,x
sta $0300,x sta $0300,x
inx inx
cpx #$e6 cpx #$e6
bne copyDriver bne copyDriverByte
end:
jmp $0300
.repeat 253-<end
.byte 0
.endrepeat
.org $0300
; ;
; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T ; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND. ; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
@ -108,6 +116,18 @@ end:
STA EXTRNCMD+2 ; vector. STA EXTRNCMD+2 ; vector.
RTS RTS
; ;
Text:
aschi "RPI command v000D"
.byte $8d
end:
.byte $00
.repeat 255-<end
.byte 0
.endrepeat
.org $0300
RPI: LDX #0 ;Check for our command. RPI: LDX #0 ;Check for our command.
NXTCHR: LDA INBUF,X ;Get first character. NXTCHR: LDA INBUF,X ;Get first character.
ora #$20 ;Make it lower case ora #$20 ;Make it lower case
@ -159,18 +179,9 @@ sendNullTerminator:
jsr SendByte jsr SendByte
DumpOutput: DumpOutput:
jsr GetByte jsr GetByte
bcs skipOutput
cmp #$00 cmp #$00
beq endOutput beq endOutput
jsr PrintChar jsr PrintChar
skipOutput:
bit Keyboard ;check for keypress
bpl DumpOutput ;keep dumping output if no keypress
lda Keyboard ;send keypress to RPi
jsr PrintChar
and #$7f
jsr SendByte
bit ClearKeyboard
clc clc
bcc DumpOutput bcc DumpOutput
endOutput: endOutput:
@ -206,13 +217,7 @@ GetByte:
waitRead: waitRead:
lda InputFlags,x lda InputFlags,x
rol rol
bcc readByte bcs waitRead
bit Keyboard ;keypress will abort waiting to read
bpl waitRead
lda #$1f ;set all flags high and exit
sta OutputFlags,x
sec ;failure
rts
readByte: readByte:
lda InputByte,x lda InputByte,x
pha pha
@ -227,13 +232,6 @@ finishRead:
rts rts
;macro for string with high-bit set
.macro aschi str
.repeat .strlen (str), c
.byte .strat (str, c) | $80
.endrep
.endmacro
CMD: aschi "rpi" CMD: aschi "rpi"
CMDLEN = 3 ;Our command length CMDLEN = 3 ;Our command length
; ;

Binary file not shown.

View File

@ -46,6 +46,13 @@ Current file: RPi.Command.asm
000300 1 SlotH = $ff 000300 1 SlotH = $ff
000300 1 ESC = $9b 000300 1 ESC = $9b
000300 1 000300 1
000300 1 ;macro for string with high-bit set
000300 1 .macro aschi str
000300 1 .repeat .strlen (str), c
000300 1 .byte .strat (str, c) | $80
000300 1 .endrep
000300 1 .endmacro
000300 1
000300 1 .org $2000 000300 1 .org $2000
002000 1 A2 07 ldx #$07 ; start at slot 7 002000 1 A2 07 ldx #$07 ; start at slot 7
002002 1 DetectSlot: 002002 1 DetectSlot:
@ -81,171 +88,164 @@ Current file: RPi.Command.asm
00202E 1 D0 D2 bne DetectSlot 00202E 1 D0 D2 bne DetectSlot
002030 1 60 rts 002030 1 60 rts
002031 1 Start: 002031 1 Start:
002031 1 8E 48 21 stx slotx + $1e01 ;set the slot for the driver 002031 1 8E 31 21 stx slotx + $1e01 ;set the slot for the driver
002034 1 A2 00 ldx #$00 002034 1 A0 00 ldy #$00
002036 1 copyDriver: 002036 1 PrintString:
002036 1 BD 00 21 lda $2100,x 002036 1 B9 67 20 lda Text,y
002039 1 9D 00 03 sta $0300,x 002039 1 F0 08 beq copyDriver
00203C 1 E8 inx 00203B 1 09 80 ora #$80
00203D 1 E0 E6 cpx #$e6 00203D 1 20 ED FD jsr PrintChar
00203F 1 D0 F5 bne copyDriver 002040 1 C8 iny
002041 1 end: 002041 1 D0 F3 bne PrintString
002041 1 4C 00 03 jmp $0300 002043 1 copyDriver:
002044 1 002043 1 A2 00 ldx #$00
002044 1 00 00 00 00 .repeat 253-<end 002045 1 copyDriverByte:
002048 1 00 00 00 00 002045 1 BD 00 21 lda $2100,x
00204C 1 00 00 00 00 002048 1 9D 00 03 sta $0300,x
00204B 1 E8 inx
00204C 1 E0 E6 cpx #$e6
00204E 1 D0 F5 bne copyDriverByte
002050 1 ;
002050 1 ; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T
002050 1 ; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND.
002050 1 ;
002050 1 AD 07 BE LDA EXTRNCMD+1
002053 1 8D AD 03 STA NXTCMD
002056 1 AD 08 BE LDA EXTRNCMD+2
002059 1 8D AE 03 STA NXTCMD+1
00205C 1 ;
00205C 1 A9 00 LDA #<RPI ;Install the address of our
00205E 1 8D 07 BE STA EXTRNCMD+1 ; command handler in the
002061 1 A9 03 LDA #>RPI ; external command JMP
002063 1 8D 08 BE STA EXTRNCMD+2 ; vector.
002066 1 60 RTS
002067 1 ;
002067 1
002067 1 Text:
002067 1 D2 D0 C9 A0 aschi "RPI command v000D"
00206B 1 E3 EF ED ED
00206F 1 E1 EE E4 A0
002078 1 8D .byte $8d
002079 1 end:
002079 1 00 .byte $00
00207A 1
00207A 1 00 00 00 00 .repeat 255-<end
00207E 1 00 00 00 00
002082 1 00 00 00 00
002100 1 .byte 0 002100 1 .byte 0
002100 1 .endrepeat 002100 1 .endrepeat
002100 1 002100 1
002100 1 .org $0300 002100 1 .org $0300
000300 1 ; 000300 1 A2 00 RPI: LDX #0 ;Check for our command.
000300 1 ; FIRST SAVE THE EXTERNAL COMMAND ADDRESS SO YOU WON'T 000302 1 BD 00 02 NXTCHR: LDA INBUF,X ;Get first character.
000300 1 ; DISCONNECT ANY PREVIOUSLY CONNECTED COMMAND. 000305 1 09 20 ora #$20 ;Make it lower case
000300 1 ; 000307 1 DD AA 03 CMP CMD,X ;Does it match?
000300 1 AD 07 BE LDA EXTRNCMD+1 00030A 1 D0 29 BNE NOTOURS ;No, back to CI.
000303 1 8D E5 03 STA NXTCMD 00030C 1 E8 INX ;Next character
000306 1 AD 08 BE LDA EXTRNCMD+2 00030D 1 E0 03 CPX #CMDLEN ;All characters yet?
000309 1 8D E6 03 STA NXTCMD+1 00030F 1 D0 F1 BNE NXTCHR ;No, read next one.
00030C 1 ; 000311 1 ;
00030C 1 A9 17 LDA #<RPI ;Install the address of our 000311 1 A9 02 LDA #CMDLEN-1 ;Our cmd! Put cmd length-1
00030E 1 8D 07 BE STA EXTRNCMD+1 ; command handler in the 000313 1 ;lda #$8d
000311 1 A9 03 LDA #>RPI ; external command JMP 000313 1 ;sta $02ff
000313 1 8D 08 BE STA EXTRNCMD+2 ; vector. 000313 1 ;lda #$fe
000316 1 60 RTS 000313 1 8D 52 BE STA XLEN ; in CI global XLEN.
000317 1 ; 000316 1 A9 58 LDA #<XRETURN ;Point XTRNADDR to a known
000317 1 A2 00 RPI: LDX #0 ;Check for our command. 000318 1 8D 50 BE STA XTRNADDR ; RTS since we'll handle
000319 1 BD 00 02 NXTCHR: LDA INBUF,X ;Get first character. 00031B 1 A9 FF LDA #>XRETURN ; at the time we intercept
00031C 1 09 20 ora #$20 ;Make it lower case 00031D 1
00031E 1 DD E2 03 CMP CMD,X ;Does it match? 00031D 1 8D 51 BE STA XTRNADDR+1 ; our command.
000321 1 D0 29 BNE NOTOURS ;No, back to CI. 000320 1 A9 00 LDA #0 ;Mark the cmd number as
000323 1 E8 INX ;Next character 000322 1 8D 53 BE STA XCNUM ; zero (external).
000324 1 E0 03 CPX #CMDLEN ;All characters yet? 000325 1 8D 54 BE STA PBITS ;And indicate no parameters
000326 1 D0 F1 BNE NXTCHR ;No, read next one. 000328 1 8D 55 BE STA PBITS+1 ; to be parsed.
000328 1 ; 00032B 1 A9 8D lda #$8d
000328 1 A9 02 LDA #CMDLEN-1 ;Our cmd! Put cmd length-1 00032D 1 20 ED FD jsr $fded
00032A 1 ;lda #$8d 000330 1 A2 70 slotx: ldx #$70 ; set x to slot # in high nibble
00032A 1 ;sta $02ff 000332 1 18 clc
00032A 1 ;lda #$fe 000333 1 90 04 bcc SendCommand
00032A 1 8D 52 BE STA XLEN ; in CI global XLEN. 000335 1 ;
00032D 1 A9 58 LDA #<XRETURN ;Point XTRNADDR to a known 000335 1 38 NOTOURS: SEC ; ALWAYS SET CARRY IF NOT YOUR
00032F 1 8D 50 BE STA XTRNADDR ; RTS since we'll handle 000336 1 6C AD 03 JMP (NXTCMD) ; CMD AND LET NEXT COMMAND TRY
000332 1 A9 FF LDA #>XRETURN ; at the time we intercept 000339 1 ; ; TO CLAIM IT.
000334 1 000339 1
000334 1 8D 51 BE STA XTRNADDR+1 ; our command. 000339 1 SendCommand:
000337 1 A9 00 LDA #0 ;Mark the cmd number as 000339 1 2C 10 C0 bit ClearKeyboard
000339 1 8D 53 BE STA XCNUM ; zero (external). 00033C 1 A9 05 lda #$05 ;send command 5 = exec
00033C 1 8D 54 BE STA PBITS ;And indicate no parameters 00033E 1 20 6F 03 jsr SendByte
00033F 1 8D 55 BE STA PBITS+1 ; to be parsed. 000341 1 A0 03 ldy #$03 ;skip over "RPI"
000342 1 A9 8D lda #$8d 000343 1 getInput:
000344 1 20 ED FD jsr $fded 000343 1 B9 00 02 lda $0200,y
000347 1 A2 70 slotx: ldx #$70 ; set x to slot # in high nibble 000346 1 C9 8D cmp #$8d
000349 1 18 clc 000348 1 F0 08 beq sendNullTerminator
00034A 1 90 04 bcc SendCommand 00034A 1 29 7F and #$7f
00034C 1 ; 00034C 1 20 6F 03 jsr SendByte
00034C 1 38 NOTOURS: SEC ; ALWAYS SET CARRY IF NOT YOUR 00034F 1 C8 iny
00034D 1 6C E5 03 JMP (NXTCMD) ; CMD AND LET NEXT COMMAND TRY 000350 1 D0 F1 bne getInput
000350 1 ; ; TO CLAIM IT. 000352 1 sendNullTerminator:
000350 1 000352 1 A9 00 lda #$00
000350 1 SendCommand: 000354 1 20 6F 03 jsr SendByte
000350 1 2C 10 C0 bit ClearKeyboard 000357 1 DumpOutput:
000353 1 A9 05 lda #$05 ;send command 5 = exec 000357 1 20 8D 03 jsr GetByte
000355 1 20 9B 03 jsr SendByte 00035A 1 C9 00 cmp #$00
000358 1 A0 03 ldy #$03 ;skip over "RPI" 00035C 1 F0 06 beq endOutput
00035A 1 getInput: 00035E 1 20 ED FD jsr PrintChar
00035A 1 B9 00 02 lda $0200,y 000361 1 18 clc
00035D 1 C9 8D cmp #$8d 000362 1 90 F3 bcc DumpOutput
00035F 1 F0 08 beq sendNullTerminator 000364 1 endOutput:
000361 1 29 7F and #$7f 000364 1 18 clc
000363 1 20 9B 03 jsr SendByte 000365 1 6C AD 03 jmp (NXTCMD)
000366 1 C8 iny 000368 1
000367 1 D0 F1 bne getInput 000368 1 HelpCommand:
000369 1 sendNullTerminator: 000368 1 61 32 68 65 .byte "a2help",$00
000369 1 A9 00 lda #$00 00036C 1 6C 70 00
00036B 1 20 9B 03 jsr SendByte 00036F 1
00036E 1 DumpOutput: 00036F 1 SendByte:
00036E 1 20 B9 03 jsr GetByte 00036F 1 48 pha
000371 1 B0 07 bcs skipOutput 000370 1 waitWrite:
000373 1 C9 00 cmp #$00 000370 1 BD 8B C0 lda InputFlags,x
000375 1 F0 19 beq endOutput 000373 1 2A rol
000377 1 20 ED FD jsr PrintChar 000374 1 2A rol
00037A 1 skipOutput: 000375 1 B0 F9 bcs waitWrite
00037A 1 2C 00 C0 bit Keyboard ;check for keypress 000377 1 68 pla
00037D 1 10 EF bpl DumpOutput ;keep dumping output if no keypress 000378 1 9D 8D C0 sta OutputByte,x
00037F 1 AD 00 C0 lda Keyboard ;send keypress to RPi 00037B 1 A9 1E lda #$1e ; set bit 0 low to indicate write started
000382 1 20 ED FD jsr PrintChar 00037D 1 9D 87 C0 sta OutputFlags,x
000385 1 29 7F and #$7f 000380 1 finishWrite:
000387 1 20 9B 03 jsr SendByte 000380 1 BD 8B C0 lda InputFlags,x
00038A 1 2C 10 C0 bit ClearKeyboard 000383 1 2A rol
00038D 1 18 clc 000384 1 2A rol
00038E 1 90 DE bcc DumpOutput 000385 1 90 F9 bcc finishWrite
000390 1 endOutput: 000387 1 A9 1F lda #$1f
000390 1 18 clc 000389 1 9D 87 C0 sta OutputFlags,x
000391 1 6C E5 03 jmp (NXTCMD) 00038C 1 60 rts
000394 1 00038D 1
000394 1 HelpCommand: 00038D 1 GetByte:
000394 1 61 32 68 65 .byte "a2help",$00 00038D 1 A9 1D lda #$1d ;set read flag low
000398 1 6C 70 00 00038F 1 9D 87 C0 sta OutputFlags,x
00039B 1 000392 1 waitRead:
00039B 1 SendByte: 000392 1 BD 8B C0 lda InputFlags,x
000395 1 2A rol
000396 1 B0 FA bcs waitRead
000398 1 readByte:
000398 1 BD 8E C0 lda InputByte,x
00039B 1 48 pha 00039B 1 48 pha
00039C 1 waitWrite: 00039C 1 A9 1F lda #$1f ;set all flags high
00039C 1 BD 8B C0 lda InputFlags,x 00039E 1 9D 87 C0 sta OutputFlags,x
00039F 1 2A rol 0003A1 1 finishRead:
0003A0 1 2A rol 0003A1 1 BD 8B C0 lda InputFlags,x
0003A1 1 B0 F9 bcs waitWrite 0003A4 1 2A rol
0003A3 1 68 pla 0003A5 1 90 FA bcc finishRead
0003A4 1 9D 8D C0 sta OutputByte,x 0003A7 1 68 pla
0003A7 1 A9 1E lda #$1e ; set bit 0 low to indicate write started 0003A8 1 18 clc ;success
0003A9 1 9D 87 C0 sta OutputFlags,x 0003A9 1 60 rts
0003AC 1 finishWrite: 0003AA 1
0003AC 1 BD 8B C0 lda InputFlags,x 0003AA 1
0003AF 1 2A rol 0003AA 1 F2 F0 E9 CMD: aschi "rpi"
0003B0 1 2A rol 0003AD 1 CMDLEN = 3 ;Our command length
0003B1 1 90 F9 bcc finishWrite 0003AD 1 ;
0003B3 1 A9 1F lda #$1f 0003AD 1 00 00 NXTCMD: .byte 0,0 ; STORE THE NEXT EXT CMD'S
0003B5 1 9D 87 C0 sta OutputFlags,x 0003AF 1 ; ADDRESS HERE.
0003B8 1 60 rts 0003AF 1
0003B9 1 0003AF 1
0003B9 1 GetByte: 0003AF 1
0003B9 1 A9 1D lda #$1d ;set read flag low
0003BB 1 9D 87 C0 sta OutputFlags,x
0003BE 1 waitRead:
0003BE 1 BD 8B C0 lda InputFlags,x
0003C1 1 2A rol
0003C2 1 90 0C bcc readByte
0003C4 1 2C 00 C0 bit Keyboard ;keypress will abort waiting to read
0003C7 1 10 F5 bpl waitRead
0003C9 1 A9 1F lda #$1f ;set all flags high and exit
0003CB 1 9D 87 C0 sta OutputFlags,x
0003CE 1 38 sec ;failure
0003CF 1 60 rts
0003D0 1 readByte:
0003D0 1 BD 8E C0 lda InputByte,x
0003D3 1 48 pha
0003D4 1 A9 1F lda #$1f ;set all flags high
0003D6 1 9D 87 C0 sta OutputFlags,x
0003D9 1 finishRead:
0003D9 1 BD 8B C0 lda InputFlags,x
0003DC 1 2A rol
0003DD 1 90 FA bcc finishRead
0003DF 1 68 pla
0003E0 1 18 clc ;success
0003E1 1 60 rts
0003E2 1
0003E2 1
0003E2 1 ;macro for string with high-bit set
0003E2 1 .macro aschi str
0003E2 1 .repeat .strlen (str), c
0003E2 1 .byte .strat (str, c) | $80
0003E2 1 .endrep
0003E2 1 .endmacro
0003E2 1
0003E2 1 F2 F0 E9 CMD: aschi "rpi"
0003E5 1 CMDLEN = 3 ;Our command length
0003E5 1 ;
0003E5 1 00 00 NXTCMD: .byte 0,0 ; STORE THE NEXT EXT CMD'S
0003E7 1 ; ADDRESS HERE.
0003E7 1
0003E7 1
0003E7 1

View File

@ -1,4 +1,4 @@
ca65 V2.18 - N/A ca65 V2.18 - Raspbian 2.19-1
Main file : Shell.asm Main file : Shell.asm
Current file: Shell.asm Current file: Shell.asm

Binary file not shown.

View File

@ -10,15 +10,17 @@ package handlers
import ( import (
"errors" "errors"
"fmt" "fmt"
"io"
"os" "os"
"os/exec" "os/exec"
"strconv"
"strings" "strings"
"time"
"github.com/tjboldt/Apple2-IO-RPi/RaspberryPi/apple2driver/info" "github.com/tjboldt/Apple2-IO-RPi/RaspberryPi/apple2driver/info"
) )
var forceLowercase = false var forceLowercase = false
var execTimeoutSeconds = int(10)
// ExecCommand handles requests for the Apple II executing Linux commands // ExecCommand handles requests for the Apple II executing Linux commands
func ExecCommand() { func ExecCommand() {
@ -68,6 +70,10 @@ func ExecCommand() {
a2wifi() a2wifi()
return return
} }
if strings.HasPrefix(linuxCommand, "a2timeout") {
a2timeout(linuxCommand)
return
}
if linuxCommand == "a2prompt" { if linuxCommand == "a2prompt" {
prompt := fmt.Sprintf("A2IO:%s ", workingDirectory) prompt := fmt.Sprintf("A2IO:%s ", workingDirectory)
comm.WriteString(prompt) comm.WriteString(prompt)
@ -100,14 +106,7 @@ func execCommand(linuxCommand string, workingDirectory string) {
comm.WriteString("Failed to set stdout\r") comm.WriteString("Failed to set stdout\r")
return return
} }
stdin, err := cmd.StdinPipe()
if err != nil {
fmt.Printf("Failed to set stdin\n")
comm.WriteString("Failed to set stdin\r")
return
}
fmt.Printf("Command output:\n")
err = cmd.Start() err = cmd.Start()
if err != nil { if err != nil {
fmt.Printf("Failed to start command\n") fmt.Printf("Failed to start command\n")
@ -115,73 +114,26 @@ func execCommand(linuxCommand string, workingDirectory string) {
return return
} }
outputComplete := make(chan bool) timeout := time.After(time.Duration(execTimeoutSeconds) * time.Second)
inputComplete := make(chan bool)
userCancelled := make(chan bool)
go getStdin(stdin, outputComplete, inputComplete, userCancelled)
go getStdout(stdout, outputComplete, userCancelled)
for { for {
select { select {
case <-outputComplete: case <-timeout:
outputComplete <- true comm.WriteString("\rCancelled by apple2driver\r")
cmd.Wait()
comm.WriteByte(0)
return
case <-userCancelled:
userCancelled <- true
cmd.Process.Kill() cmd.Process.Kill()
return return
case <-inputComplete:
cmd.Wait()
comm.WriteByte(0)
return
}
}
}
func getStdout(stdout io.ReadCloser, outputComplete chan bool, userCancelled chan bool) {
for {
select {
case <-userCancelled:
fmt.Printf("User Cancelled stdout\n")
stdout.Close()
return
default: default:
bb := make([]byte, 1) bb := make([]byte, 1)
n, err := stdout.Read(bb) n, stdOutErr := stdout.Read(bb)
if err != nil { if stdOutErr == nil {
stdout.Close() if n > 0 {
outputComplete <- true b := bb[0]
return comm.SendCharacter(b)
}
if n > 0 {
b := bb[0]
comm.SendCharacter(b)
}
}
}
}
func getStdin(stdin io.WriteCloser, done chan bool, inputComplete chan bool, userCancelled chan bool) {
for {
select {
case <-done:
stdin.Close()
inputComplete <- true
return
default:
b, err := comm.ReadByte()
if err == nil {
if b == 0x00 || b == 0x03 {
stdin.Close()
userCancelled <- true
fmt.Printf("\nUser cancelled stdin\n")
return
} }
bb := make([]byte, 1) } else {
stdin.Write(bb) comm.WriteByte(0)
cmd.Wait()
return
} }
} }
} }
@ -195,14 +147,34 @@ func a2help() {
comm.WriteString("\r" + comm.WriteString("\r" +
"Built-in commands:\r" + "Built-in commands:\r" +
"------------------\r" + "------------------\r" +
"a2version - display version number\r" +
"a2help - display this message\r" + "a2help - display this message\r" +
"a2version - display version number\r" +
"a2wifi - set up wifi\r" + "a2wifi - set up wifi\r" +
"a2timeout - seconds to timeout commands\r" +
"A2LOWER - force lowercase for II+\r" + "A2LOWER - force lowercase for II+\r" +
"a2lower - disable force lowercase for II+\r" + "a2lower - disable force lowercase for II+\r" +
"\r") "\r")
} }
func a2timeout(linuxCommand string) {
params := strings.Fields(linuxCommand)
switch len(params) {
case 1:
comm.WriteString("\rCommand timeout: " + strconv.FormatInt(int64(execTimeoutSeconds),10) + "\r")
case 2:
timeoutSeconds, err := strconv.ParseInt(params[1], 10, 32)
if err != nil {
comm.WriteString("\rFailed to parse timeout\r")
} else {
execTimeoutSeconds = int(timeoutSeconds)
comm.WriteString("\rCommand timeout set to: " + strconv.FormatInt(int64(execTimeoutSeconds),10) + "\r")
}
default:
comm.WriteString("\rToo many parameters\n")
}
}
func a2lower(enable bool) { func a2lower(enable bool) {
forceLowercase = enable forceLowercase = enable
comm.WriteString(fmt.Sprintf("All commands will be converted to lowercase: %t\r", forceLowercase)) comm.WriteString(fmt.Sprintf("All commands will be converted to lowercase: %t\r", forceLowercase))

View File

@ -8,4 +8,4 @@ package info
// Version is the hexadecimal version number that // Version is the hexadecimal version number that
// should be incremented with each driver update // should be incremented with each driver update
const Version = "0024" const Version = "0025"