package text import ( "io" ) // Indent inserts prefix at the beginning of each non-empty line of s. The // end-of-line marker is NL. func Indent(s, prefix string) string { return string(IndentBytes([]byte(s), []byte(prefix))) } // IndentBytes inserts prefix at the beginning of each non-empty line of b. // The end-of-line marker is NL. func IndentBytes(b, prefix []byte) []byte { var res []byte bol := true for _, c := range b { if bol && c != '\n' { res = append(res, prefix...) } res = append(res, c) bol = c == '\n' } return res } // Writer indents each line of its input. type indentWriter struct { w io.Writer bol bool pre [][]byte sel int off int } // NewIndentWriter makes a new write filter that indents the input // lines. Each line is prefixed in order with the corresponding // element of pre. If there are more lines than elements, the last // element of pre is repeated for each subsequent line. func NewIndentWriter(w io.Writer, pre ...[]byte) io.Writer { return &indentWriter{ w: w, pre: pre, bol: true, } } // The only errors returned are from the underlying indentWriter. func (w *indentWriter) Write(p []byte) (n int, err error) { for _, c := range p { if w.bol { var i int i, err = w.w.Write(w.pre[w.sel][w.off:]) w.off += i if err != nil { return n, err } } _, err = w.w.Write([]byte{c}) if err != nil { return n, err } n++ w.bol = c == '\n' if w.bol { w.off = 0 if w.sel < len(w.pre)-1 { w.sel++ } } } return n, nil }