--- /dev/null
+pkg regexp, method (*Regexp) MarshalText() ([]uint8, error) #46159
+pkg regexp, method (*Regexp) UnmarshalText([]uint8) error #46159
}
}
}
+
+func TestUnmarshalText(t *testing.T) {
+ unmarshaled := new(Regexp)
+ for i := range goodRe {
+ re := compileTest(t, goodRe[i], "")
+ marshaled, err := re.MarshalText()
+ if err != nil {
+ t.Errorf("regexp %#q failed to marshal: %s", re, err)
+ continue
+ }
+ if err := unmarshaled.UnmarshalText(marshaled); err != nil {
+ t.Errorf("regexp %#q failed to unmarshal: %s", re, err)
+ continue
+ }
+ if unmarshaled.String() != goodRe[i] {
+ t.Errorf("UnmarshalText returned unexpected value: %s", unmarshaled.String())
+ }
+ }
+ t.Run("invalid pattern", func(t *testing.T) {
+ re := new(Regexp)
+ err := re.UnmarshalText([]byte(`\`))
+ if err == nil {
+ t.Error("unexpected success")
+ }
+ })
+}
return strings
}
+
+// MarshalText implements the encoding.TextMarshaler interface. The output
+// matches that of calling the [Regexp.String] method.
+//
+// Note that the output is lossy in some cases: This method does not indicate
+// POSIX regular expressions (i.e. those compiled by calling CompilePOSIX), or
+// those for which the [Regexp.Longest] method has been called.
+func (re *Regexp) MarshalText() ([]byte, error) {
+ return []byte(re.String()), nil
+}
+
+// MarshalText implements the encoding.TextUnmarshaler interface by calling
+// Compile on the encoded value.
+func (re *Regexp) UnmarshalText(text []byte) error {
+ newRE, err := Compile(string(text))
+ if err != nil {
+ return err
+ }
+ *re = *newRE
+ return nil
+}