Compare commits
No commits in common. "3172a4865a2d7939ca6d17c5e6bad4dfc454dc2f" and "9c38048bd265f02d97b5cc045e025e4fea75ffa6" have entirely different histories.
3172a4865a
...
9c38048bd2
@ -1,3 +1,4 @@
|
|||||||
# atom
|
# atom-feed
|
||||||
|
|
||||||
An extensible implementation of an Atom feed that aims to be very close to RFC4287.
|
An extensible implementation of an Atom feed that aims to be very close to RFC4287.
|
||||||
|
|
||||||
|
@ -8,22 +8,6 @@ type CommonAttributes struct {
|
|||||||
UndefinedAttributes []*ExtensionAttribute `xml:",any"`
|
UndefinedAttributes []*ExtensionAttribute `xml:",any"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewCommonAttributes creates a new set of CommonAttributes. It returns a
|
|
||||||
// *CommonAttributes.
|
|
||||||
func NewCommonAttributes() *CommonAttributes {
|
|
||||||
return new(CommonAttributes)
|
|
||||||
}
|
|
||||||
|
|
||||||
// AddExtensionAttribute adds the ExtensionAttribute to the CommonAttributes.
|
|
||||||
func (c *CommonAttributes) AddExtensionAttribute(e *ExtensionAttribute) {
|
|
||||||
if c.UndefinedAttributes == nil {
|
|
||||||
c.UndefinedAttributes = make([]*ExtensionAttribute, 1)
|
|
||||||
c.UndefinedAttributes[0] = e
|
|
||||||
} else {
|
|
||||||
c.UndefinedAttributes = append(c.UndefinedAttributes, e)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check checks the CommonAttributes for incompatibilities with RFC4287. It
|
// Check checks the CommonAttributes for incompatibilities with RFC4287. It
|
||||||
// returns an error.
|
// returns an error.
|
||||||
func (c *CommonAttributes) Check() error {
|
func (c *CommonAttributes) Check() error {
|
||||||
|
@ -1,24 +1,20 @@
|
|||||||
package atom
|
package atom
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/xml"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// TODO: Is this really correct?
|
||||||
type ExtensionAttribute struct {
|
type ExtensionAttribute struct {
|
||||||
Attr string `xml:",attr"`
|
Value any `xml:",attr"`
|
||||||
}
|
XMLName xml.Name
|
||||||
|
|
||||||
// NewExtensionAttribute creates a new ExtensionAttribute. It returns a
|
|
||||||
// *ExtensionAttribute.
|
|
||||||
func NewExtensionAttribute(name, value string) *ExtensionAttribute {
|
|
||||||
return &ExtensionAttribute{Attr: fmt.Sprint(name, `="`, value, `"`)}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check checks the ExtensionAttribute for incompatibilities with RFC4287. It
|
// Check checks the ExtensionAttribute for incompatibilities with RFC4287. It
|
||||||
// returns an error.
|
// returns an error.
|
||||||
func (e *ExtensionAttribute) Check() error {
|
func (e *ExtensionAttribute) Check() error {
|
||||||
if e.Attr == "" {
|
if e.Value == nil {
|
||||||
return errors.New("value element of extension attribute empty")
|
return errors.New("value element of extension attribute empty")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// TODO: Is this really correct?
|
||||||
type ExtensionElement struct {
|
type ExtensionElement struct {
|
||||||
Value any `xml:",innerxml"`
|
Value any `xml:",innerxml"`
|
||||||
XMLName xml.Name
|
XMLName xml.Name
|
||||||
|
Loading…
x
Reference in New Issue
Block a user