X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;f=w.go;h=2bd06df5a06fc5bde056b21f9fad48441287242a;hb=ac9b31f3dfa1dbdf5c4571cfaf3c5b498faa0c0b;hp=4525222c1f2b69cd4c8d8d8b64d95b3fadb7ed32;hpb=9395de748e74e117bcc36d22e4223952d35bdc33;p=gorecfile.git diff --git a/w.go b/w.go index 4525222..2bd06df 100644 --- a/w.go +++ b/w.go @@ -26,18 +26,23 @@ type Writer struct { w io.StringWriter } -func NewWriter(w io.StringWriter) *Writer { - return &Writer{w} -} +func NewWriter(w io.StringWriter) *Writer { return &Writer{w} } + +func (w *Writer) RecordStart() (written int, err error) { return w.w.WriteString("\n") } -func (w *Writer) RecordStart() (written int, err error) { - return w.w.WriteString("\n") +func backslashSpace(s string) string { + if strings.HasSuffix(s, "\\") { + return s + " " + } + return s } func (w *Writer) WriteFields(fs ...Field) (written int, err error) { var n int for _, f := range fs { - n, err = w.w.WriteString(f.Name + ": " + strings.TrimLeft(f.Value, " ") + "\n") + n, err = w.w.WriteString( + f.Name + ": " + backslashSpace(strings.TrimLeft(f.Value, " ")) + "\n", + ) written += n if err != nil { return @@ -48,13 +53,15 @@ func (w *Writer) WriteFields(fs ...Field) (written int, err error) { func (w *Writer) WriteFieldMultiline(name string, lines []string) (written int, err error) { var n int - n, err = w.w.WriteString(name + ": " + strings.TrimLeft(lines[0], " ") + "\n") + n, err = w.w.WriteString( + name + ": " + backslashSpace(strings.TrimLeft(lines[0], " ")) + "\n", + ) written += n if err != nil { return } for _, l := range lines[1:] { - n, err = w.w.WriteString("+ " + l + "\n") + n, err = w.w.WriteString("+ " + backslashSpace(l) + "\n") written += n if err != nil { return