Get rid of checks when creating constructs. Check should handle this.
This commit is contained in:
		
							
								
								
									
										33
									
								
								atom.go
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								atom.go
									
									
									
									
									
								
							| @@ -2,6 +2,7 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"fmt" | 	"fmt" | ||||||
|  | 	"html" | ||||||
| 	"mime" | 	"mime" | ||||||
| 	"regexp" | 	"regexp" | ||||||
| 	"strings" | 	"strings" | ||||||
| @@ -10,6 +11,10 @@ import ( | |||||||
| 	"golang.org/x/text/language" | 	"golang.org/x/text/language" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | func Unescape(s string) string { | ||||||
|  | 	return html.UnescapeString(s) | ||||||
|  | } | ||||||
|  |  | ||||||
| // isValidIRI checks whether an IRI is valid or not. It returns a bool. | // isValidIRI checks whether an IRI is valid or not. It returns a bool. | ||||||
| // https://www.w3.org/2011/04/XMLSchema/TypeLibrary-IRI-RFC3987.xsd | // https://www.w3.org/2011/04/XMLSchema/TypeLibrary-IRI-RFC3987.xsd | ||||||
| func isValidIRI(iri string) bool { | func isValidIRI(iri string) bool { | ||||||
| @@ -17,6 +22,15 @@ func isValidIRI(iri string) bool { | |||||||
| 	return regexp.MustCompile(pattern).MatchString(iri) | 	return regexp.MustCompile(pattern).MatchString(iri) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // NewIRI creates a new IRI. It returns a string and an error. | ||||||
|  | func NewIRI(iri string) (string, error) { | ||||||
|  | 	if !isValidIRI(iri) { | ||||||
|  | 		return "", fmt.Errorf("iri %v not correctly formatted", iri) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return iri, nil | ||||||
|  | } | ||||||
|  |  | ||||||
| // isCorrectlyEscaped checks whether a string is correctly escaped as per | // isCorrectlyEscaped checks whether a string is correctly escaped as per | ||||||
| // RFC4287. It returns a bool. | // RFC4287. It returns a bool. | ||||||
| func isCorrectlyEscaped(text string) bool { | func isCorrectlyEscaped(text string) bool { | ||||||
| @@ -69,12 +83,31 @@ func isValidMediaType(m string) bool { | |||||||
| 	return true | 	return true | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // NewMediaType creates a new MediaType. It returns a string and an error. | ||||||
|  | func NewMediaType(m string) (string, error) { | ||||||
|  | 	if !isValidMediaType(m) { | ||||||
|  | 		return "", fmt.Errorf("media type %v invalid", m) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	mediaType, _, _ := mime.ParseMediaType(m) | ||||||
|  | 	return mediaType, nil | ||||||
|  | } | ||||||
|  |  | ||||||
| // isValidLanguageTag checks whether a LanguageTag is valid. It returns a bool. | // isValidLanguageTag checks whether a LanguageTag is valid. It returns a bool. | ||||||
| func isValidLanguageTag(languageTag string) bool { | func isValidLanguageTag(languageTag string) bool { | ||||||
| 	_, err := language.Parse(languageTag) | 	_, err := language.Parse(languageTag) | ||||||
| 	return err == nil | 	return err == nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // NewLanguageTag creates a new LanguageTag. It returns a string and an error. | ||||||
|  | func NewLanguageTag(l string) (string, error) { | ||||||
|  | 	if !isValidLanguageTag(l) { | ||||||
|  | 		return "", fmt.Errorf("language tag %v invalid", l) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return l, nil | ||||||
|  | } | ||||||
|  |  | ||||||
| // isValidAttribute checks whether an Attribute is valid. It returns a bool. | // isValidAttribute checks whether an Attribute is valid. It returns a bool. | ||||||
| func isValidAttribute(attribute string) bool { | func isValidAttribute(attribute string) bool { | ||||||
| 	regex := regexp.MustCompile(`^[a-zA-Z0-9_]+="[^"]*"$`) | 	regex := regexp.MustCompile(`^[a-zA-Z0-9_]+="[^"]*"$`) | ||||||
|   | |||||||
							
								
								
									
										43
									
								
								category.go
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								category.go
									
									
									
									
									
								
							| @@ -2,9 +2,7 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"html" |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type Category struct { | type Category struct { | ||||||
| @@ -15,43 +13,14 @@ type Category struct { | |||||||
| 	Label  string `xml:"label,attr,omitempty"` | 	Label  string `xml:"label,attr,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewCategory creates a new Category. It returns a *Category and an error. | // NewCategory creates a new Category. It returns a *Category. | ||||||
| func NewCategory(term string) (*Category, error) { | func NewCategory(term string) *Category { | ||||||
| 	if term == "" { | 	return &Category{Term: term} | ||||||
| 		return nil, errors.New("error creating new category: term string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Category{Term: term}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // SetTerm sets the Term attribute of the Category. It returns an error. | // SetLabel sets the Label attribute of the Category. | ||||||
| func (c *Category) SetTerm(t string) error { | func (c *Category) SetLabel(label string) { | ||||||
| 	if t == "" { | 	c.Label = Unescape(label) | ||||||
| 		return errors.New("error setting term of category: t string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	c.Term = t |  | ||||||
| 	return nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // SetScheme sets the Scheme attribute of the Category. It returns an error. |  | ||||||
| func (c *Category) SetScheme(s string) error { |  | ||||||
| 	if !isValidIRI(s) { |  | ||||||
| 		return fmt.Errorf("scheme %v not correctly formatted", s) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	c.Scheme = s |  | ||||||
| 	return nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // SetLabel sets the Label attribute of the Category. It returns an error. |  | ||||||
| func (c *Category) SetLabel(label string) error { |  | ||||||
| 	if label == "" { |  | ||||||
| 		return errors.New("error setting label of category: label string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	c.Label = html.UnescapeString(label) |  | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Category for incompatibilities with RFC4287. It returns an | // Check checks the Category for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type CommonAttributes struct { | type CommonAttributes struct { | ||||||
| @@ -17,21 +17,27 @@ func NewCommonAttributes() *CommonAttributes { | |||||||
| 	return new(CommonAttributes) | 	return new(CommonAttributes) | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddAttribute adds the Attribute to the CommonAttributes. It returns an error. | // AddAttribute adds the Attribute to the CommonAttributes. | ||||||
| func (c *CommonAttributes) AddAttribute(name, value string) error { | func (c *CommonAttributes) AddAttribute(name, value string) { | ||||||
| 	if name == "" { |  | ||||||
| 		return errors.New("error adding attribute: name string empty") |  | ||||||
| 	} |  | ||||||
| 	if value == "" { |  | ||||||
| 		return errors.New("error adding attribute: value string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if c.UndefinedAttributes == nil { | 	if c.UndefinedAttributes == nil { | ||||||
| 		c.UndefinedAttributes = make([]*xml.Attr, 1) | 		c.UndefinedAttributes = make([]*xml.Attr, 1) | ||||||
| 		c.UndefinedAttributes[0] = &xml.Attr{Name: xml.Name{Local: name}, Value: value} | 		c.UndefinedAttributes[0] = &xml.Attr{Name: xml.Name{Local: name}, Value: value} | ||||||
| 	} else { | 	} else { | ||||||
| 		c.UndefinedAttributes = append(c.UndefinedAttributes, &xml.Attr{Name: xml.Name{Local: name}, Value: value}) | 		c.UndefinedAttributes = append(c.UndefinedAttributes, &xml.Attr{Name: xml.Name{Local: name}, Value: value}) | ||||||
| 	} | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Check checks the CommonAttributes for incompatibilities with RFC4287. It | ||||||
|  | // returns an error. | ||||||
|  | func (c *CommonAttributes) Check() error { | ||||||
|  | 	for i, u := range c.UndefinedAttributes { | ||||||
|  | 		if u.Name.Local == "" { | ||||||
|  | 			return fmt.Errorf("xml name of undefined attribute %v empty", i) | ||||||
|  | 		} | ||||||
|  | 		if u.Value == "" { | ||||||
|  | 			return fmt.Errorf("value of undefined attribute %v empty", i) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								content.go
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								content.go
									
									
									
									
									
								
							| @@ -1,7 +1,5 @@ | |||||||
| package atom | package atom | ||||||
|  |  | ||||||
| import "fmt" |  | ||||||
|  |  | ||||||
| const ( | const ( | ||||||
| 	InlineText = iota | 	InlineText = iota | ||||||
| 	InlineXHTML | 	InlineXHTML | ||||||
| @@ -17,17 +15,17 @@ type Content interface { | |||||||
| } | } | ||||||
|  |  | ||||||
| // NewContent creates a new Content. It returns a Content and an error. | // NewContent creates a new Content. It returns a Content and an error. | ||||||
| func NewContent(contentType int, mediaType string, content any) (Content, error) { | func NewContent(contentType int, mediaType string, content any) Content { | ||||||
| 	switch contentType { | 	switch contentType { | ||||||
| 	case 0: | 	case 0: | ||||||
| 		return newInlineTextContent(mediaType, content) | 		return newInlineTextContent(mediaType, content.(string)) | ||||||
| 	case 1: | 	case 1: | ||||||
| 		return newInlineXHTMLContent(mediaType, content) | 		return newInlineXHTMLContent(mediaType, content.(*XHTMLDiv)) | ||||||
| 	case 2: | 	case 2: | ||||||
| 		return newInlineOtherContent(mediaType, content) | 		return newInlineOtherContent(mediaType, content) | ||||||
| 	case 3: | 	case 3: | ||||||
| 		return newOutOfLineContent(mediaType, content) | 		return newOutOfLineContent(mediaType, content.(string)) | ||||||
| 	default: | 	default: | ||||||
| 		return nil, fmt.Errorf("error creating new content: %v is not a valid text type", contentType) | 		return nil | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										67
									
								
								entry.go
									
									
									
									
									
								
							
							
						
						
									
										67
									
								
								entry.go
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"time" | 	"time" | ||||||
| @@ -57,31 +56,17 @@ func (e *Entry) checkAuthors(authorInFeed bool) error { | |||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewEntry creates a new Entry. It returns a *Entry and an error. | // NewEntry creates a new Entry. It returns a *Entry. | ||||||
| func NewEntry(title string) (*Entry, error) { | func NewEntry(title string) *Entry { | ||||||
| 	text, err := NewText("text", title) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("error creating new entry: %v", err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	id, err := NewID(NewURN()) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("error creating new entry: %v", err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Entry{ | 	return &Entry{ | ||||||
| 		ID:      id, | 		ID:      NewID(NewURN()), | ||||||
| 		Title:   text, | 		Title:   NewText("text", title), | ||||||
| 		Updated: NewDate(time.Now()), | 		Updated: NewDate(time.Now()), | ||||||
| 	}, nil | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddAuthor adds the Person as an author to the Entry. It returns an error. | // AddAuthor adds the Person as an author to the Entry. | ||||||
| func (e *Entry) AddAuthor(p *Person) error { | func (e *Entry) AddAuthor(p *Person) { | ||||||
| 	if p == nil { |  | ||||||
| 		return errors.New("error adding author element to entry: *Person is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if e.Authors == nil { | 	if e.Authors == nil { | ||||||
| 		e.Authors = make([]*Person, 1) | 		e.Authors = make([]*Person, 1) | ||||||
| 		e.Authors[0] = p | 		e.Authors[0] = p | ||||||
| @@ -90,15 +75,10 @@ func (e *Entry) AddAuthor(p *Person) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	e.Updated.DateTime = DateTime(time.Now()) | 	e.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddCategory adds the Category to the Entry. It returns an error. | // AddCategory adds the Category to the Entry. | ||||||
| func (e *Entry) AddCategory(c *Category) error { | func (e *Entry) AddCategory(c *Category) { | ||||||
| 	if c == nil { |  | ||||||
| 		return errors.New("error adding category element to entry: *Category is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if e.Categories == nil { | 	if e.Categories == nil { | ||||||
| 		e.Categories = make([]*Category, 1) | 		e.Categories = make([]*Category, 1) | ||||||
| 		e.Categories[0] = c | 		e.Categories[0] = c | ||||||
| @@ -107,16 +87,10 @@ func (e *Entry) AddCategory(c *Category) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	e.Updated.DateTime = DateTime(time.Now()) | 	e.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddContributor adds the Person as a contributor to the Entry. It returns an | // AddContributor adds the Person as a contributor to the Entry. | ||||||
| // error. | func (e *Entry) AddContributor(c *Person) { | ||||||
| func (e *Entry) AddContributor(c *Person) error { |  | ||||||
| 	if c == nil { |  | ||||||
| 		return errors.New("error adding contributor element to entry: *Person is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if e.Contributors == nil { | 	if e.Contributors == nil { | ||||||
| 		e.Contributors = make([]*Person, 1) | 		e.Contributors = make([]*Person, 1) | ||||||
| 		e.Contributors[0] = c | 		e.Contributors[0] = c | ||||||
| @@ -125,15 +99,10 @@ func (e *Entry) AddContributor(c *Person) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	e.Updated.DateTime = DateTime(time.Now()) | 	e.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddLink adds the Link to the Entry. It returns an error. | // AddLink adds the Link to the Entry. | ||||||
| func (e *Entry) AddLink(l *Link) error { | func (e *Entry) AddLink(l *Link) { | ||||||
| 	if l == nil { |  | ||||||
| 		return errors.New("error adding link element to entry: *Link is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if e.Links == nil { | 	if e.Links == nil { | ||||||
| 		e.Links = make([]*Link, 1) | 		e.Links = make([]*Link, 1) | ||||||
| 		e.Links[0] = l | 		e.Links[0] = l | ||||||
| @@ -142,15 +111,10 @@ func (e *Entry) AddLink(l *Link) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	e.Updated.DateTime = DateTime(time.Now()) | 	e.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddExtension adds the ExtensionElement to the Entry. It returns an error. | // AddExtension adds the ExtensionElement to the Entry. | ||||||
| func (e *Entry) AddExtension(x *ExtensionElement) error { | func (e *Entry) AddExtension(x *ExtensionElement) { | ||||||
| 	if x == nil { |  | ||||||
| 		return errors.New("error adding extension element to entry: *ExtensionElement is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if e.Extensions == nil { | 	if e.Extensions == nil { | ||||||
| 		e.Extensions = make([]*ExtensionElement, 1) | 		e.Extensions = make([]*ExtensionElement, 1) | ||||||
| 		e.Extensions[0] = x | 		e.Extensions[0] = x | ||||||
| @@ -159,7 +123,6 @@ func (e *Entry) AddExtension(x *ExtensionElement) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	e.Updated.DateTime = DateTime(time.Now()) | 	e.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Entry for incompatibilities with RFC4287. It returns an | // Check checks the Entry for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| type ExtensionElement struct { | type ExtensionElement struct { | ||||||
| @@ -11,27 +11,20 @@ type ExtensionElement struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| // NewExtensionElement creates a new ExtensionElement. It returns a | // NewExtensionElement creates a new ExtensionElement. It returns a | ||||||
| // *ExtensionElement and an error. | // *ExtensionElement. | ||||||
| func NewExtensionElement(name string, value any) (*ExtensionElement, error) { | func NewExtensionElement(name string, value any) *ExtensionElement { | ||||||
| 	if name == "" { | 	return &ExtensionElement{XMLName: xml.Name{Local: name}, Value: value} | ||||||
| 		return nil, errors.New("error adding extension attribute: name string empty") |  | ||||||
| 	} |  | ||||||
| 	if value == "" { |  | ||||||
| 		return nil, errors.New("error adding extension attribute: value string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &ExtensionElement{XMLName: xml.Name{Local: name}, Value: value}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the ExtensionElement for incompatibilities with RFC4287. It | // Check checks the ExtensionElement for incompatibilities with RFC4287. It | ||||||
| // returns an error. | // returns an error. | ||||||
| func (e *ExtensionElement) Check() error { | func (e *ExtensionElement) Check() error { | ||||||
| 	if e.XMLName.Local == "" { | 	if e.XMLName.Local == "" { | ||||||
| 		return errors.New("xml name of extension empty") | 		return fmt.Errorf("xml name of extension %v empty", e) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if e.Value == nil { | 	if e.Value == nil { | ||||||
| 		return errors.New("value element of extension empty") | 		return fmt.Errorf("value of extension %v empty", e) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return nil | 	return nil | ||||||
|   | |||||||
							
								
								
									
										77
									
								
								feed.go
									
									
									
									
									
								
							
							
						
						
									
										77
									
								
								feed.go
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"time" | 	"time" | ||||||
| ) | ) | ||||||
| @@ -26,31 +25,17 @@ type Feed struct { | |||||||
| 	Entries      []*Entry            `xml:",omitempty"` | 	Entries      []*Entry            `xml:",omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewFeed creates a new Feed. It returns a *Feed and an error. | // NewFeed creates a new Feed. It returns a *Feed. | ||||||
| func NewFeed(title string) (*Feed, error) { | func NewFeed(title string) *Feed { | ||||||
| 	text, err := NewText("text", title) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("error creating new feed: %v", err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	id, err := NewID(NewURN()) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("error creating new feed: %v", err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Feed{ | 	return &Feed{ | ||||||
| 		ID:      id, | 		ID:      NewID(NewURN()), | ||||||
| 		Title:   text, | 		Title:   NewText("text", title), | ||||||
| 		Updated: NewDate(time.Now()), | 		Updated: NewDate(time.Now()), | ||||||
| 	}, nil | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddAuthor adds the Person as an author to the Feed. It returns an error. | // AddAuthor adds the Person as an author to the Feed. | ||||||
| func (f *Feed) AddAuthor(p *Person) error { | func (f *Feed) AddAuthor(p *Person) { | ||||||
| 	if p == nil { |  | ||||||
| 		return errors.New("error adding author element to feed: *Person is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Authors == nil { | 	if f.Authors == nil { | ||||||
| 		f.Authors = make([]*Person, 1) | 		f.Authors = make([]*Person, 1) | ||||||
| 		f.Authors[0] = p | 		f.Authors[0] = p | ||||||
| @@ -59,15 +44,10 @@ func (f *Feed) AddAuthor(p *Person) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddCategory adds the Category to the Feed. It returns an error. | // AddCategory adds the Category to the Feed. | ||||||
| func (f *Feed) AddCategory(c *Category) error { | func (f *Feed) AddCategory(c *Category) { | ||||||
| 	if c == nil { |  | ||||||
| 		return errors.New("error adding category element to feed: *Category is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Categories == nil { | 	if f.Categories == nil { | ||||||
| 		f.Categories = make([]*Category, 1) | 		f.Categories = make([]*Category, 1) | ||||||
| 		f.Categories[0] = c | 		f.Categories[0] = c | ||||||
| @@ -76,16 +56,10 @@ func (f *Feed) AddCategory(c *Category) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddContributor adds the Person as a contributor to the Feed. It returns an | // AddContributor adds the Person as a contributor to the Feed. | ||||||
| // error. | func (f *Feed) AddContributor(c *Person) { | ||||||
| func (f *Feed) AddContributor(c *Person) error { |  | ||||||
| 	if c == nil { |  | ||||||
| 		return errors.New("error adding contributor element to feed: *Person is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Contributors == nil { | 	if f.Contributors == nil { | ||||||
| 		f.Contributors = make([]*Person, 1) | 		f.Contributors = make([]*Person, 1) | ||||||
| 		f.Contributors[0] = c | 		f.Contributors[0] = c | ||||||
| @@ -94,16 +68,10 @@ func (f *Feed) AddContributor(c *Person) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddLink adds the Link to the Feed. It returns an error. There should be one | // AddLink adds the Link to the Feed. There should be one Link with Rel "self". | ||||||
| // Link with Rel "self". | func (f *Feed) AddLink(l *Link) { | ||||||
| func (f *Feed) AddLink(l *Link) error { |  | ||||||
| 	if l == nil { |  | ||||||
| 		return errors.New("error adding link element to feed: *Link is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Links == nil { | 	if f.Links == nil { | ||||||
| 		f.Links = make([]*Link, 1) | 		f.Links = make([]*Link, 1) | ||||||
| 		f.Links[0] = l | 		f.Links[0] = l | ||||||
| @@ -112,15 +80,10 @@ func (f *Feed) AddLink(l *Link) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddExtension adds the Extension to the Feed. It returns an error. | // AddExtension adds the Extension to the Feed. | ||||||
| func (f *Feed) AddExtension(e *ExtensionElement) error { | func (f *Feed) AddExtension(e *ExtensionElement) { | ||||||
| 	if e == nil { |  | ||||||
| 		return errors.New("error adding extension element to feed: *ExtensionElement is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Extensions == nil { | 	if f.Extensions == nil { | ||||||
| 		f.Extensions = make([]*ExtensionElement, 1) | 		f.Extensions = make([]*ExtensionElement, 1) | ||||||
| 		f.Extensions[0] = e | 		f.Extensions[0] = e | ||||||
| @@ -129,15 +92,10 @@ func (f *Feed) AddExtension(e *ExtensionElement) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // AddEntry adds the Entry to the Feed. It returns an error. | // AddEntry adds the Entry to the Feed. | ||||||
| func (f *Feed) AddEntry(e *Entry) error { | func (f *Feed) AddEntry(e *Entry) { | ||||||
| 	if e == nil { |  | ||||||
| 		return errors.New("error adding entry element to feed: *Entry is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if f.Entries == nil { | 	if f.Entries == nil { | ||||||
| 		f.Entries = make([]*Entry, 1) | 		f.Entries = make([]*Entry, 1) | ||||||
| 		f.Entries[0] = e | 		f.Entries[0] = e | ||||||
| @@ -146,7 +104,6 @@ func (f *Feed) AddEntry(e *Entry) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	f.Updated.DateTime = DateTime(time.Now()) | 	f.Updated.DateTime = DateTime(time.Now()) | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Feed for incompatibilities with RFC4287. It returns an | // Check checks the Feed for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								generator.go
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								generator.go
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"html" | 	"html" | ||||||
| ) | ) | ||||||
| @@ -15,22 +14,9 @@ type Generator struct { | |||||||
| 	Text    string `xml:",chardata"` | 	Text    string `xml:",chardata"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewGenerator creates a new Generator. It returns a *Generator and an error. | // NewGenerator creates a new Generator. It returns a *Generator. | ||||||
| func NewGenerator(text string) (*Generator, error) { | func NewGenerator(text string) *Generator { | ||||||
| 	if text == "" { | 	return &Generator{Text: html.UnescapeString(text)} | ||||||
| 		return nil, errors.New("error creating new generator: text string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Generator{Text: html.UnescapeString(text)}, nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // SetURI sets the URI attribute of the Generator. It returns an error. |  | ||||||
| func (g *Generator) SetURI(uri string) error { |  | ||||||
| 	if !isValidIRI(uri) { |  | ||||||
| 		return fmt.Errorf("uri %v not correctly formatted", g) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Generator for incompatibilities with RFC4287. It returns an | // Check checks the Generator for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								icon.go
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								icon.go
									
									
									
									
									
								
							| @@ -12,13 +12,9 @@ type Icon struct { | |||||||
| 	URI string `xml:",chardata"` // IRI | 	URI string `xml:",chardata"` // IRI | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewIcon creates a new Icon. It returns a *Icon and an error. | // NewIcon creates a new Icon. It returns a *Icon. | ||||||
| func NewIcon(uri string) (*Icon, error) { | func NewIcon(uri string) *Icon { | ||||||
| 	if !isValidIRI(uri) { | 	return &Icon{URI: uri} | ||||||
| 		return nil, fmt.Errorf("uri %v not correctly formatted", uri) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Icon{URI: uri}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Icon for incompatibilities with RFC4287. It returns an | // Check checks the Icon for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								id.go
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								id.go
									
									
									
									
									
								
							| @@ -12,13 +12,9 @@ type ID struct { | |||||||
| 	URI string `xml:",chardata"` // IRI | 	URI string `xml:",chardata"` // IRI | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewID creates a new ID. It returns a *ID and an error. | // NewID creates a new ID. It returns a *ID. | ||||||
| func NewID(uri string) (*ID, error) { | func NewID(uri string) *ID { | ||||||
| 	if !isValidIRI(uri) { | 	return &ID{URI: uri} | ||||||
| 		return nil, fmt.Errorf("uri %v not correctly formatted", uri) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &ID{URI: uri}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the ID for incompatibilities with RFC4287. It returns an error. | // Check checks the ID for incompatibilities with RFC4287. It returns an error. | ||||||
|   | |||||||
| @@ -15,13 +15,9 @@ type InlineOtherContent struct { | |||||||
|  |  | ||||||
| // newInlineOtherContent creates a new InlineOtherContent. It returns a | // newInlineOtherContent creates a new InlineOtherContent. It returns a | ||||||
| // *InlineOtherContent and an error. | // *InlineOtherContent and an error. | ||||||
| func newInlineOtherContent(mediaType string, content any) (*InlineOtherContent, error) { | func newInlineOtherContent(mediaType string, content any) *InlineOtherContent { | ||||||
| 	if !isValidMediaType(mediaType) { |  | ||||||
| 		return nil, fmt.Errorf("error creating new inline other content: media type %v invalid", mediaType) |  | ||||||
| 	} |  | ||||||
| 	mediaType, _, _ = mime.ParseMediaType(mediaType) | 	mediaType, _, _ = mime.ParseMediaType(mediaType) | ||||||
|  | 	return &InlineOtherContent{Type: mediaType, AnyElement: content} | ||||||
| 	return &InlineOtherContent{Type: mediaType, AnyElement: content}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // isContent checks whether the InlineOtherContent is a Content. It returns a | // isContent checks whether the InlineOtherContent is a Content. It returns a | ||||||
|   | |||||||
| @@ -13,18 +13,9 @@ type InlineTextContent struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| // newInlineTextContent creates a new InlineTextContent. It returns a | // newInlineTextContent creates a new InlineTextContent. It returns a | ||||||
| // *InlineTextContent and an error. | // *InlineTextContent. | ||||||
| func newInlineTextContent(mediaType string, content any) (*InlineTextContent, error) { | func newInlineTextContent(mediaType, text string) *InlineTextContent { | ||||||
| 	if mediaType != "text" && mediaType != "html" && mediaType != "" { | 	return &InlineTextContent{Type: mediaType, Text: text} | ||||||
| 		return nil, fmt.Errorf("media type %v incompatible with inline text content", mediaType) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	text, ok := content.(string) |  | ||||||
| 	if !ok { |  | ||||||
| 		return nil, fmt.Errorf("content type %T incompatible with inline text content", content) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &InlineTextContent{Type: mediaType, Text: text}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // isContent checks whether the InlineTextContent is a Content. It returns a | // isContent checks whether the InlineTextContent is a Content. It returns a | ||||||
|   | |||||||
| @@ -13,18 +13,9 @@ type InlineXHTMLContent struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| // newInlineXHTMLContent creates a new InlineXHTMLContent. It returns a | // newInlineXHTMLContent creates a new InlineXHTMLContent. It returns a | ||||||
| // *InlineXHTMLContent and an error. | // *InlineXHTMLContent. | ||||||
| func newInlineXHTMLContent(mediaType string, content any) (*InlineXHTMLContent, error) { | func newInlineXHTMLContent(mediaType string, div *XHTMLDiv) *InlineXHTMLContent { | ||||||
| 	if mediaType != "xhtml" { | 	return &InlineXHTMLContent{Type: mediaType, XHTMLDiv: div} | ||||||
| 		return nil, fmt.Errorf("media type %v incompatible with inline xhtml content", mediaType) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	xhtmlDiv, ok := content.(*XHTMLDiv) |  | ||||||
| 	if !ok { |  | ||||||
| 		return nil, fmt.Errorf("content type %T incompatible with inline xhtml content", content) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &InlineXHTMLContent{Type: mediaType, XHTMLDiv: xhtmlDiv}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // isContent checks whether the InlineXHTMLContent is a Content. It returns a | // isContent checks whether the InlineXHTMLContent is a Content. It returns a | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								link.go
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								link.go
									
									
									
									
									
								
							| @@ -17,31 +17,9 @@ type Link struct { | |||||||
| 	Length   uint   `xml:"length,attr,omitempty"` | 	Length   uint   `xml:"length,attr,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewLink creates a new Link. It returns a *Link and an error. | // NewLink creates a new Link. It returns a *Link. | ||||||
| func NewLink(href string) (*Link, error) { | func NewLink(href string) *Link { | ||||||
| 	if !isValidIRI(href) { | 	return &Link{Href: href} | ||||||
| 		return nil, fmt.Errorf("href %v not correctly formatted", href) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Link{Href: href}, nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // SetType sets the Type attribute of the Link. It returns an error. |  | ||||||
| func (l *Link) SetType(t string) error { |  | ||||||
| 	if !isValidMediaType(t) { |  | ||||||
| 		return fmt.Errorf("type %v invalid media type", t) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // SetHrefLang sets the HrefLang attribute of the Link. It returns an error. |  | ||||||
| func (l *Link) SetHrefLang(h string) error { |  | ||||||
| 	if !isValidLanguageTag(h) { |  | ||||||
| 		return fmt.Errorf("hreflang %v invalid language tag", h) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Link for incompatibilities with RFC4287. It returns an | // Check checks the Link for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								logo.go
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								logo.go
									
									
									
									
									
								
							| @@ -11,13 +11,9 @@ type Logo struct { | |||||||
| 	URI string `xml:",chardata"` // IRI | 	URI string `xml:",chardata"` // IRI | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewLogo creates a new Logo. It returns a *Logo and an error. | // NewLogo creates a new Logo. It returns a *Logo. | ||||||
| func NewLogo(uri string) (*Logo, error) { | func NewLogo(uri string) *Logo { | ||||||
| 	if !isValidIRI(uri) { | 	return &Logo{URI: uri} | ||||||
| 		return nil, fmt.Errorf("uri %v not correctly formatted", uri) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Logo{URI: uri}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Logo for incompatibilities with RFC4287. It returns an | // Check checks the Logo for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
| @@ -14,23 +14,10 @@ type OutOfLineContent struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| // newOutOfLineContent creates a new OutOfLineContent. It returns a | // newOutOfLineContent creates a new OutOfLineContent. It returns a | ||||||
| // *OutOfLineContent and an error. | // *OutOfLineContent. | ||||||
| func newOutOfLineContent(mediaType string, content any) (*OutOfLineContent, error) { | func newOutOfLineContent(mediaType, src string) *OutOfLineContent { | ||||||
| 	if !isValidMediaType(mediaType) { |  | ||||||
| 		return nil, fmt.Errorf("error creating new out of line content: media type %v invalid", mediaType) |  | ||||||
| 	} |  | ||||||
| 	mediaType, _, _ = mime.ParseMediaType(mediaType) | 	mediaType, _, _ = mime.ParseMediaType(mediaType) | ||||||
|  | 	return &OutOfLineContent{Type: mediaType, SRC: src} | ||||||
| 	iri, ok := content.(string) |  | ||||||
| 	if !ok { |  | ||||||
| 		return nil, fmt.Errorf("content type %T incompatible with out of line content", content) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if !isValidIRI(iri) { |  | ||||||
| 		return nil, fmt.Errorf("content %v not a valid uri", iri) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &OutOfLineContent{Type: mediaType, SRC: iri}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // isContent checks whether the OutOfLineContent is a Content. It returns a | // isContent checks whether the OutOfLineContent is a Content. It returns a | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								person.go
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								person.go
									
									
									
									
									
								
							| @@ -1,7 +1,6 @@ | |||||||
| package atom | package atom | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"net/mail" | 	"net/mail" | ||||||
| ) | ) | ||||||
| @@ -14,38 +13,19 @@ type Person struct { | |||||||
| 	Extensions []*ExtensionElement `xml:",any,omitempty"` | 	Extensions []*ExtensionElement `xml:",any,omitempty"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewPerson creates a new Person. It returns a *Person and an error. | // NewPerson creates a new Person. It returns a *Person. | ||||||
| func NewPerson(name string) (*Person, error) { | func NewPerson(name string) *Person { | ||||||
| 	if name == "" { | 	return &Person{Name: name} | ||||||
| 		return nil, errors.New("error creating new person: name string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &Person{Name: name}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // SetURI sets the URI element of the Person. It returns an error. | // AddExtension adds the Extension to the Person. | ||||||
| func (l *Link) SetURI(uri string) error { | func (p *Person) AddExtension(e *ExtensionElement) { | ||||||
| 	if !isValidIRI(uri) { |  | ||||||
| 		return fmt.Errorf("uri %v not correctly formatted", uri) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return nil |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // AddExtension adds the Extension to the Person. It returns an error. |  | ||||||
| func (p *Person) AddExtension(e *ExtensionElement) error { |  | ||||||
| 	if e == nil { |  | ||||||
| 		return errors.New("error adding extension element to person: *ExtensionElement is nil") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if p.Extensions == nil { | 	if p.Extensions == nil { | ||||||
| 		p.Extensions = make([]*ExtensionElement, 1) | 		p.Extensions = make([]*ExtensionElement, 1) | ||||||
| 		p.Extensions[0] = e | 		p.Extensions[0] = e | ||||||
| 	} else { | 	} else { | ||||||
| 		p.Extensions = append(p.Extensions, e) | 		p.Extensions = append(p.Extensions, e) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the Person for incompatibilities with RFC4287. It returns an | // Check checks the Person for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								plainText.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								plainText.go
									
									
									
									
									
								
							| @@ -1,7 +1,6 @@ | |||||||
| package atom | package atom | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -14,13 +13,9 @@ type PlainText struct { | |||||||
| // isText checks whether the PlainText is a Text. It returns a bool. | // isText checks whether the PlainText is a Text. It returns a bool. | ||||||
| func (p *PlainText) isText() bool { return true } | func (p *PlainText) isText() bool { return true } | ||||||
|  |  | ||||||
| // newPlainText creates a new PlainText. It returns a *PlainText and an error. | // newPlainText creates a new PlainText. It returns a *PlainText. | ||||||
| func newPlainText(textType, content string) (*PlainText, error) { | func newPlainText(textType, content string) *PlainText { | ||||||
| 	if content == "" { | 	return &PlainText{Type: textType, Text: content} | ||||||
| 		return nil, errors.New("error creating new plain text: content string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &PlainText{Type: textType, Text: content}, nil |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the PlainText for incompatibilities with RFC4287. It returns an | // Check checks the PlainText for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								text.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								text.go
									
									
									
									
									
								
							| @@ -1,17 +1,14 @@ | |||||||
| package atom | package atom | ||||||
|  |  | ||||||
| import ( | import "html" | ||||||
| 	"fmt" |  | ||||||
| 	"html" |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| type Text interface { | type Text interface { | ||||||
| 	isText() bool | 	isText() bool | ||||||
| 	Check() error | 	Check() error | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewText creates a new Text. It returns a Text and an error. | // NewText creates a new Text. It returns a Text. | ||||||
| func NewText(textType, content string) (Text, error) { | func NewText(textType, content string) Text { | ||||||
| 	switch textType { | 	switch textType { | ||||||
| 	case "text", "": | 	case "text", "": | ||||||
| 		return newPlainText(textType, content) | 		return newPlainText(textType, content) | ||||||
| @@ -20,6 +17,6 @@ func NewText(textType, content string) (Text, error) { | |||||||
| 	case "xhtml": | 	case "xhtml": | ||||||
| 		return newXHTMLText(textType, content) | 		return newXHTMLText(textType, content) | ||||||
| 	default: | 	default: | ||||||
| 		return nil, fmt.Errorf("%v is not a valid text type", textType) | 		return nil | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								xhtmlDiv.go
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								xhtmlDiv.go
									
									
									
									
									
								
							| @@ -2,7 +2,6 @@ package atom | |||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"encoding/xml" | 	"encoding/xml" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -12,16 +11,12 @@ type XHTMLDiv struct { | |||||||
| 	Content string   `xml:",innerxml"` | 	Content string   `xml:",innerxml"` | ||||||
| } | } | ||||||
|  |  | ||||||
| // NewXHTMLDiv creates a new XHTMLDiv. It returns a *XHTMLDiv and an error. | // NewXHTMLDiv creates a new XHTMLDiv. It returns a *XHTMLDiv. | ||||||
| func NewXHTMLDiv(content string) (*XHTMLDiv, error) { | func NewXHTMLDiv(content string) *XHTMLDiv { | ||||||
| 	if content == "" { |  | ||||||
| 		return nil, errors.New("error creating new xhtml div: content string empty") |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &XHTMLDiv{ | 	return &XHTMLDiv{ | ||||||
| 		XMLNS:   "http://www.w3.org/1999/xhtml", | 		XMLNS:   "http://www.w3.org/1999/xhtml", | ||||||
| 		Content: content, | 		Content: content, | ||||||
| 	}, nil | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the XHTMLDiv for incompatibilities with RFC4287. It returns an | // Check checks the XHTMLDiv for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								xhtmlText.go
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								xhtmlText.go
									
									
									
									
									
								
							| @@ -13,17 +13,12 @@ type XHTMLText struct { | |||||||
| // isText checks whether the XHTMLText is a Text. It returns a bool. | // isText checks whether the XHTMLText is a Text. It returns a bool. | ||||||
| func (x *XHTMLText) isText() bool { return true } | func (x *XHTMLText) isText() bool { return true } | ||||||
|  |  | ||||||
| // newPlainText creates a new PlainText. It returns a *PlainText and an error. | // newPlainText creates a new PlainText. It returns a *PlainText. | ||||||
| func newXHTMLText(textType, content string) (*XHTMLText, error) { | func newXHTMLText(textType, content string) *XHTMLText { | ||||||
| 	xhtmlDiv, err := NewXHTMLDiv(content) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return nil, fmt.Errorf("error creating new xhtml text: %v", err) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	return &XHTMLText{ | 	return &XHTMLText{ | ||||||
| 		Type:     textType, | 		Type:     textType, | ||||||
| 		XHTMLDiv: xhtmlDiv, | 		XHTMLDiv: NewXHTMLDiv(content), | ||||||
| 	}, nil | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| // Check checks the XHTMLText for incompatibilities with RFC4287. It returns an | // Check checks the XHTMLText for incompatibilities with RFC4287. It returns an | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user