diff options
| author | xuri <xuri.me@gmail.com> | 2021-08-28 09:23:44 +0800 | 
|---|---|---|
| committer | xuri <xuri.me@gmail.com> | 2021-08-28 09:23:44 +0800 | 
| commit | c3d1d7ddddd02d9d8d39204dd891250222bb9ee4 (patch) | |
| tree | b98929deef6a8f2b23049209c218c8aa224bd6ac | |
| parent | 7d9b9275bd14556bfcaab7f1d3690b1e54ab75e8 (diff) | |
Preserve XML control character in bstrUnmarshal result
| -rw-r--r-- | lib.go | 15 | ||||
| -rw-r--r-- | lib_test.go | 18 | 
2 files changed, 10 insertions, 23 deletions
| @@ -21,7 +21,6 @@ import (  	"regexp"  	"strconv"  	"strings" -	"unicode"  )  // ReadZipReader can be used to read the spreadsheet in memory without touching the @@ -588,10 +587,6 @@ func bstrUnmarshal(s string) (result string) {  		subStr := s[match[0]:match[1]]  		if subStr == "_x005F_" {  			cursor = match[1] -			if l > match[1]+6 && !bstrEscapeExp.MatchString(s[match[1]:match[1]+6]) { -				result += subStr -				continue -			}  			result += "_"  			continue  		} @@ -607,15 +602,7 @@ func bstrUnmarshal(s string) (result string) {  				result += subStr  				continue  			} -			hasRune := false -			for _, c := range v { -				if unicode.IsControl(c) { -					hasRune = true -				} -			} -			if !hasRune { -				result += v -			} +			result += v  		}  	}  	if cursor < l { diff --git a/lib_test.go b/lib_test.go index 025bc85..556ed91 100644 --- a/lib_test.go +++ b/lib_test.go @@ -263,21 +263,21 @@ func TestGenXMLNamespace(t *testing.T) {  func TestBstrUnmarshal(t *testing.T) {  	bstrs := map[string]string{  		"*":                           "*", -		"*_x0000_":                    "*", -		"*_x0008_":                    "*", -		"_x0008_*":                    "*", -		"*_x0008_*":                   "**", +		"*_x0000_":                    "*\x00", +		"*_x0008_":                    "*\b", +		"_x0008_*":                    "\b*", +		"*_x0008_*":                   "*\b*",  		"*_x4F60__x597D_":             "*你好",  		"*_xG000_":                    "*_xG000_",  		"*_xG05F_x0001_*":             "*_xG05F*", -		"*_x005F__x0008_*":            "*_x005F_*", +		"*_x005F__x0008_*":            "*_\b*",  		"*_x005F_x0001_*":             "*_x0001_*", -		"*_x005f_x005F__x0008_*":      "*_x005F_*", +		"*_x005f_x005F__x0008_*":      "*_x005F_\b*",  		"*_x005F_x005F_xG05F_x0006_*": "*_x005F_xG05F*",  		"*_x005F_x005F_x005F_x0006_*": "*_x005F_x0006_*", -		"_x005F__x0008_******":        "_x005F_******", -		"******_x005F__x0008_":        "******_x005F_", -		"******_x005F__x0008_******":  "******_x005F_******", +		"_x005F__x0008_******":        "_\b******", +		"******_x005F__x0008_":        "******_\b", +		"******_x005F__x0008_******":  "******_\b******",  	}  	for bstr, expected := range bstrs {  		assert.Equal(t, expected, bstrUnmarshal(bstr)) | 
