atom/inlineXHTMLContent.go

53 lines
1.5 KiB
Go
Raw Permalink Normal View History

2024-10-13 17:19:40 +02:00
package atomfeed
2024-10-15 20:53:01 +02:00
import (
"errors"
"fmt"
"reflect"
)
2024-10-13 17:19:40 +02:00
type InlineXHTMLContent struct {
*CommonAttributes
Type string `xml:"type,attr"`
XHTMLDiv string `xml:"xhtmldiv"`
}
2024-10-16 19:59:28 +02:00
// newInlineXHTMLContent creates a new InlineXHTMLContent. It returns a
// *InlineXHTMLContent and an error.
2024-10-15 20:53:01 +02:00
func newInlineXHTMLContent(mediaType string, content any) (*InlineXHTMLContent, error) {
if mediaType != "xhtml" {
return nil, fmt.Errorf("media type %v incompatible with inline xhtml content", mediaType)
}
if reflect.TypeOf(content).Kind() != reflect.String {
return nil, fmt.Errorf("content type %T incompatible with inline xhtml content", content)
}
return &InlineXHTMLContent{Type: mediaType, XHTMLDiv: content.(string)}, nil
}
2024-10-16 19:59:28 +02:00
// isContent checks whether the InlineXHTMLContent is a Content. It returns a
// bool.
2024-10-15 19:32:14 +02:00
func (i *InlineXHTMLContent) isContent() bool { return true }
2024-10-16 19:59:28 +02:00
// hasSRC checks whether the InlineXHTMLContent has a SRC attribute. It returns
// a bool.
2024-10-15 19:32:14 +02:00
func (i *InlineXHTMLContent) hasSRC() bool { return false }
2024-10-16 19:59:28 +02:00
// getType returns the Type of the InlineXHTMLContent as a string.
2024-10-15 19:32:14 +02:00
func (i *InlineXHTMLContent) getType() string { return i.Type }
2024-10-13 17:19:40 +02:00
2024-10-16 19:59:28 +02:00
// Check checks the InlineXHTMLContent for incompatibilities with RFC4287. It
// returns an error.
2024-10-13 17:19:40 +02:00
func (i *InlineXHTMLContent) Check() error {
if i.Type != "xhtml" {
return errors.New("type attribute of inline xhtml content must be xhtml")
}
if i.XHTMLDiv == "" {
return errors.New("xhtmlDiv element of inline xhtml content empty")
}
return nil
}