Commit 91e1fd66 authored by Eric_Lee's avatar Eric_Lee Committed by Eric

修复最后一个命令记录问题 (#85)

parent 028425c0
...@@ -74,6 +74,8 @@ func (p *Parser) ParseStream(userInChan, srvInChan <-chan []byte) (userOut, srvO ...@@ -74,6 +74,8 @@ func (p *Parser) ParseStream(userInChan, srvInChan <-chan []byte) (userOut, srvO
go func() { go func() {
defer func() { defer func() {
// 会话结束,结算命令结果
p.sendCommandRecord()
close(p.cmdRecordChan) close(p.cmdRecordChan)
close(p.userOutputChan) close(p.userOutputChan)
close(p.srvOutputChan) close(p.srvOutputChan)
...@@ -113,12 +115,8 @@ func (p *Parser) parseInputState(b []byte) []byte { ...@@ -113,12 +115,8 @@ func (p *Parser) parseInputState(b []byte) []byte {
p.inputPreState = p.inputState p.inputPreState = p.inputState
if bytes.Contains(b, charEnter) { if bytes.Contains(b, charEnter) {
// 连续输入enter key, 结算上一条可能存在的命令结果 // 连续输入enter key, 结算上一条可能存在的命令结果
if p.command != ""{ p.sendCommandRecord()
p.parseCmdOutput()
p.cmdRecordChan <- [2]string{p.command, p.output}
p.command = ""
p.output = ""
}
p.inputState = false p.inputState = false
// 用户输入了Enter,开始结算命令 // 用户输入了Enter,开始结算命令
p.parseCmdInput() p.parseCmdInput()
...@@ -132,10 +130,7 @@ func (p *Parser) parseInputState(b []byte) []byte { ...@@ -132,10 +130,7 @@ func (p *Parser) parseInputState(b []byte) []byte {
p.inputState = true p.inputState = true
// 用户又开始输入,并上次不处于输入状态,开始结算上次命令的结果 // 用户又开始输入,并上次不处于输入状态,开始结算上次命令的结果
if !p.inputPreState { if !p.inputPreState {
p.parseCmdOutput() p.sendCommandRecord()
p.cmdRecordChan <- [2]string{p.command, p.output}
p.command = ""
p.output = ""
} }
} }
return b return b
...@@ -258,3 +253,12 @@ func (p *Parser) Close() { ...@@ -258,3 +253,12 @@ func (p *Parser) Close() {
} }
} }
func (p *Parser) sendCommandRecord() {
if p.command != "" {
p.parseCmdOutput()
p.cmdRecordChan <- [2]string{p.command, p.output}
p.command = ""
p.output = ""
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment