X-Git-Url: http://www.git.cypherpunks.ru/?p=gorecfile.git;a=blobdiff_plain;f=w.go;h=2bd06df5a06fc5bde056b21f9fad48441287242a;hp=32ee966c1e22e14454866f5366c08ff3ac304d25;hb=ac9b31f3dfa1dbdf5c4571cfaf3c5b498faa0c0b;hpb=a24ce24d791284ed7ded63fc824c1c4e239d6d6d diff --git a/w.go b/w.go index 32ee966..2bd06df 100644 --- a/w.go +++ b/w.go @@ -26,19 +26,22 @@ 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.TrimRight(strings.TrimLeft(f.Value, " "), "\\") + "\n", + f.Name + ": " + backslashSpace(strings.TrimLeft(f.Value, " ")) + "\n", ) written += n if err != nil { @@ -51,14 +54,14 @@ 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.TrimRight(strings.TrimLeft(lines[0], " "), "\\") + "\n", + name + ": " + backslashSpace(strings.TrimLeft(lines[0], " ")) + "\n", ) written += n if err != nil { return } for _, l := range lines[1:] { - n, err = w.w.WriteString("+ " + strings.TrimRight(l, "\\") + "\n") + n, err = w.w.WriteString("+ " + backslashSpace(l) + "\n") written += n if err != nil { return