2016-12-31 17:32:31 +01:00
|
|
|
package ftp
|
|
|
|
|
2017-03-04 13:01:41 +01:00
|
|
|
// A scanner for fields delimited by one or more whitespace characters
|
|
|
|
type scanner struct {
|
2016-12-31 17:32:31 +01:00
|
|
|
bytes []byte
|
|
|
|
position int
|
|
|
|
}
|
|
|
|
|
2017-03-04 13:01:41 +01:00
|
|
|
// newScanner creates a new scanner
|
|
|
|
func newScanner(str string) *scanner {
|
|
|
|
return &scanner{
|
2016-12-31 17:32:31 +01:00
|
|
|
bytes: []byte(str),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NextFields returns the next `count` fields
|
2017-03-04 13:01:41 +01:00
|
|
|
func (s *scanner) NextFields(count int) []string {
|
2016-12-31 17:32:31 +01:00
|
|
|
fields := make([]string, 0, count)
|
|
|
|
for i := 0; i < count; i++ {
|
|
|
|
if field := s.Next(); field != "" {
|
|
|
|
fields = append(fields, field)
|
|
|
|
} else {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fields
|
|
|
|
}
|
|
|
|
|
|
|
|
// Next returns the next field
|
2017-03-04 13:01:41 +01:00
|
|
|
func (s *scanner) Next() string {
|
2016-12-31 17:32:31 +01:00
|
|
|
sLen := len(s.bytes)
|
|
|
|
|
|
|
|
// skip trailing whitespace
|
|
|
|
for s.position < sLen {
|
|
|
|
if s.bytes[s.position] != ' ' {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
s.position++
|
|
|
|
}
|
|
|
|
|
|
|
|
start := s.position
|
|
|
|
|
|
|
|
// skip non-whitespace
|
|
|
|
for s.position < sLen {
|
|
|
|
if s.bytes[s.position] == ' ' {
|
|
|
|
s.position++
|
|
|
|
return string(s.bytes[start : s.position-1])
|
|
|
|
}
|
|
|
|
s.position++
|
|
|
|
}
|
|
|
|
|
|
|
|
return string(s.bytes[start:s.position])
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remaining returns the remaining string
|
2017-03-04 13:01:41 +01:00
|
|
|
func (s *scanner) Remaining() string {
|
2016-12-31 17:32:31 +01:00
|
|
|
return string(s.bytes[s.position:len(s.bytes)])
|
|
|
|
}
|