helper_method_yield.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package ace
  2. import (
  3. "bytes"
  4. "fmt"
  5. "io"
  6. )
  7. // helperMethodYield represents a helper method yield.
  8. type helperMethodYield struct {
  9. elementBase
  10. templateName string
  11. }
  12. // WriteTo writes data to w.
  13. func (e *helperMethodYield) WriteTo(w io.Writer) (int64, error) {
  14. var bf bytes.Buffer
  15. inner := e.src.inner
  16. if inner == nil {
  17. return 0, fmt.Errorf("inner is not specified [file: %s][line: %d]", e.ln.fileName(), e.ln.no)
  18. }
  19. var templateExists bool
  20. for _, innerE := range e.rslt.inner {
  21. ln := innerE.Base().ln
  22. if ln.isHelperMethodOf(helperMethodNameContent) && len(ln.tokens) > 2 && ln.tokens[2] == e.templateName {
  23. templateExists = true
  24. break
  25. }
  26. }
  27. if templateExists {
  28. bf.WriteString(fmt.Sprintf(actionTemplateWithPipeline, e.opts.DelimLeft, inner.path+doubleColon+e.templateName, dot, e.opts.DelimRight))
  29. } else {
  30. // Write the children's HTML.
  31. if i, err := e.writeChildren(&bf); err != nil {
  32. return i, err
  33. }
  34. }
  35. i, err := w.Write(bf.Bytes())
  36. return int64(i), err
  37. }
  38. // newHelperMethodYield creates and returns a helper method yield.
  39. func newHelperMethodYield(ln *line, rslt *result, src *source, parent element, opts *Options) (*helperMethodYield, error) {
  40. if len(ln.tokens) < 3 {
  41. return nil, fmt.Errorf("no template name is specified [file: %s][line: %d]", ln.fileName(), ln.no)
  42. }
  43. e := &helperMethodYield{
  44. elementBase: newElementBase(ln, rslt, src, parent, opts),
  45. templateName: ln.tokens[2],
  46. }
  47. return e, nil
  48. }