parent
a8e04f9666
commit
f8b9e11d84
|
@ -29,6 +29,9 @@ func shouldUseCTable(nextRunes []rune, curEncoding byte) bool {
|
|||
return false
|
||||
}
|
||||
for i := 0; i < requiredDigits; i++ {
|
||||
if i%2 == 0 && nextRunes[i] == FNC1 {
|
||||
continue
|
||||
}
|
||||
if nextRunes[i] < '0' || nextRunes[i] > '9' {
|
||||
return false
|
||||
}
|
||||
|
@ -40,7 +43,6 @@ func getCodeIndexList(content []rune) *utils.BitList {
|
|||
result := new(utils.BitList)
|
||||
curEncoding := byte(0)
|
||||
for i := 0; i < len(content); i++ {
|
||||
|
||||
if shouldUseCTable(content[i:], curEncoding) {
|
||||
if curEncoding != startCSymbol {
|
||||
if curEncoding == byte(0) {
|
||||
|
@ -50,11 +52,15 @@ func getCodeIndexList(content []rune) *utils.BitList {
|
|||
}
|
||||
curEncoding = startCSymbol
|
||||
}
|
||||
idx := (content[i] - '0') * 10
|
||||
i++
|
||||
idx = idx + (content[i] - '0')
|
||||
if content[i] == FNC1 {
|
||||
result.AddByte(102)
|
||||
} else {
|
||||
|
||||
result.AddByte(byte(idx))
|
||||
idx := (content[i] - '0') * 10
|
||||
i++
|
||||
idx = idx + (content[i] - '0')
|
||||
result.AddByte(byte(idx))
|
||||
}
|
||||
} else {
|
||||
if curEncoding != startBSymbol {
|
||||
if curEncoding == byte(0) {
|
||||
|
|
|
@ -13,11 +13,23 @@ func testEncode(t *testing.T, txt, testResult string) {
|
|||
if code.Bounds().Max.X != len(testResult) {
|
||||
t.Errorf("%v: length missmatch", txt)
|
||||
} else {
|
||||
encoded := ""
|
||||
failed := false
|
||||
for i, r := range testResult {
|
||||
if code.At(i, 0) == color.Black {
|
||||
encoded += "1"
|
||||
} else {
|
||||
encoded += "0"
|
||||
}
|
||||
|
||||
if (code.At(i, 0) == color.Black) != (r == '1') {
|
||||
failed = true
|
||||
t.Errorf("%v: code missmatch on position %d", txt, i)
|
||||
}
|
||||
}
|
||||
if failed {
|
||||
t.Log("Encoded: ", encoded)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -30,7 +42,8 @@ func Test_EncodeFunctionChars(t *testing.T) {
|
|||
encStartB := "11010010000"
|
||||
encStop := "1100011101011"
|
||||
|
||||
testEncode(t, string(FNC1)+"123", encStartB+encFNC1+"10011100110"+"11001110010"+"11001011100"+"11001000010"+encStop)
|
||||
// Special Case FC1 can also be encoded to C Table therefor using 123 as suffix might have unexpected results.
|
||||
testEncode(t, string(FNC1)+"A23", encStartB+encFNC1+"10100011000"+"11001110010"+"11001011100"+"10100011110"+encStop)
|
||||
testEncode(t, string(FNC2)+"123", encStartB+encFNC2+"10011100110"+"11001110010"+"11001011100"+"11100010110"+encStop)
|
||||
testEncode(t, string(FNC3)+"123", encStartB+encFNC3+"10011100110"+"11001110010"+"11001011100"+"11101000110"+encStop)
|
||||
testEncode(t, string(FNC4)+"123", encStartB+encFNC4+"10011100110"+"11001110010"+"11001011100"+"11100011010"+encStop)
|
||||
|
@ -48,4 +61,12 @@ func Test_Unencodable(t *testing.T) {
|
|||
func Test_EncodeCTable(t *testing.T) {
|
||||
testEncode(t, "HI345678H", "110100100001100010100011000100010101110111101000101100011100010110110000101001011110111011000101000111011000101100011101011")
|
||||
testEncode(t, "334455", "11010011100101000110001000110111011101000110100100111101100011101011")
|
||||
|
||||
testEncode(t, string(FNC1)+"1234",
|
||||
"11010011100"+ // Start C
|
||||
"11110101110"+ // FNC1
|
||||
"10110011100"+ // 12
|
||||
"10001011000"+ // 34
|
||||
"11101001100"+ // CheckSum == 24
|
||||
"1100011101011") // Stop
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue