186 行
8.6 KiB
Go
186 行
8.6 KiB
Go
package vocab
|
|
|
|
import "net/url"
|
|
|
|
// NamePropertyIteratorInterface represents a single value for the "name" property.
|
|
type NamePropertyIteratorInterface interface {
|
|
// GetIRI returns the IRI of this property. When IsIRI returns false,
|
|
// GetIRI will return an arbitrary value.
|
|
GetIRI() *url.URL
|
|
// GetLangString returns the value of this property. When IsLangString
|
|
// returns false, GetLangString will return an arbitrary value.
|
|
GetLangString() map[string]string
|
|
// GetLanguage returns the value for the specified BCP47 language code, or
|
|
// an empty string if it is either not a language map or no value is
|
|
// present.
|
|
GetLanguage(bcp47 string) string
|
|
// GetString returns the value of this property. When IsString returns
|
|
// false, GetString will return an arbitrary value.
|
|
GetString() string
|
|
// HasAny returns true if any of the values are set, except for the
|
|
// natural language map. When true, the specific has, getter, and
|
|
// setter methods may be used to determine what kind of value there is
|
|
// to access and set this property. To determine if the property was
|
|
// set as a natural language map, use the IsLanguageMap method instead.
|
|
HasAny() bool
|
|
// HasLanguage returns true if the natural language map has an entry for
|
|
// the specified BCP47 language code.
|
|
HasLanguage(bcp47 string) bool
|
|
// IsIRI returns true if this property is an IRI. When true, use GetIRI
|
|
// and SetIRI to access and set this property
|
|
IsIRI() bool
|
|
// IsLangString returns true if this property has a type of "langString".
|
|
// When true, use the GetLangString and SetLangString methods to
|
|
// access and set this property.. To determine if the property was set
|
|
// as a natural language map, use the IsLanguageMap method instead.
|
|
IsLangString() bool
|
|
// IsLanguageMap determines if this property is represented by a natural
|
|
// language map. When true, use HasLanguage, GetLanguage, and
|
|
// SetLanguage methods to access and mutate the natural language map.
|
|
// The clear method can be used to clear the natural language map.
|
|
// Note that this method is only used for natural language
|
|
// representations, and does not determine the presence nor absence of
|
|
// other values for this property.
|
|
IsLanguageMap() bool
|
|
// IsString returns true if this property has a type of "string". When
|
|
// true, use the GetString and SetString methods to access and set
|
|
// this property.. To determine if the property was set as a natural
|
|
// language map, use the IsLanguageMap method instead.
|
|
IsString() bool
|
|
// JSONLDContext returns the JSONLD URIs required in the context string
|
|
// for this property and the specific values that are set. The value
|
|
// in the map is the alias used to import the property's value or
|
|
// values.
|
|
JSONLDContext() map[string]string
|
|
// KindIndex computes an arbitrary value for indexing this kind of value.
|
|
// This is a leaky API detail only for folks looking to replace the
|
|
// go-fed implementation. Applications should not use this method.
|
|
KindIndex() int
|
|
// LessThan compares two instances of this property with an arbitrary but
|
|
// stable comparison. Applications should not use this because it is
|
|
// only meant to help alternative implementations to go-fed to be able
|
|
// to normalize nonfunctional properties.
|
|
LessThan(o NamePropertyIteratorInterface) bool
|
|
// Name returns the name of this property: "name".
|
|
Name() string
|
|
// Next returns the next iterator, or nil if there is no next iterator.
|
|
Next() NamePropertyIteratorInterface
|
|
// Prev returns the previous iterator, or nil if there is no previous
|
|
// iterator.
|
|
Prev() NamePropertyIteratorInterface
|
|
// SetIRI sets the value of this property. Calling IsIRI afterwards
|
|
// returns true.
|
|
SetIRI(v *url.URL)
|
|
// SetLangString sets the value of this property and clears the natural
|
|
// language map. Calling IsLangString afterwards will return true.
|
|
// Calling IsLanguageMap afterwards returns false.
|
|
SetLangString(v map[string]string)
|
|
// SetLanguage sets the value for the specified BCP47 language code.
|
|
SetLanguage(bcp47, value string)
|
|
// SetString sets the value of this property and clears the natural
|
|
// language map. Calling IsString afterwards will return true. Calling
|
|
// IsLanguageMap afterwards returns false.
|
|
SetString(v string)
|
|
}
|
|
|
|
// A simple, human-readable, plain-text name for the object. HTML markup MUST NOT
|
|
// be included. The name MAY be expressed using multiple language-tagged
|
|
// values.
|
|
//
|
|
// Example 117 (https://www.w3.org/TR/activitystreams-vocabulary/#ex132-jsonld):
|
|
// {
|
|
// "name": "A simple note",
|
|
// "type": "Note"
|
|
// }
|
|
//
|
|
// Example 118 (https://www.w3.org/TR/activitystreams-vocabulary/#ex133-jsonld):
|
|
// {
|
|
// "nameMap": {
|
|
// "en": "A simple note",
|
|
// "es": "Una nota sencilla",
|
|
// "zh-hans": "一段简单的笔记"
|
|
// },
|
|
// "type": "Note"
|
|
// }
|
|
type NamePropertyInterface interface {
|
|
// AppendIRI appends an IRI value to the back of a list of the property
|
|
// "name"
|
|
AppendIRI(v *url.URL)
|
|
// AppendLangString appends a langString value to the back of a list of
|
|
// the property "name". Invalidates iterators that are traversing
|
|
// using Prev.
|
|
AppendLangString(v map[string]string)
|
|
// AppendString appends a string value to the back of a list of the
|
|
// property "name". Invalidates iterators that are traversing using
|
|
// Prev.
|
|
AppendString(v string)
|
|
// At returns the property value for the specified index. Panics if the
|
|
// index is out of bounds.
|
|
At(index int) NamePropertyIteratorInterface
|
|
// Begin returns the first iterator, or nil if empty. Can be used with the
|
|
// iterator's Next method and this property's End method to iterate
|
|
// from front to back through all values.
|
|
Begin() NamePropertyIteratorInterface
|
|
// Empty returns returns true if there are no elements.
|
|
Empty() bool
|
|
// End returns beyond-the-last iterator, which is nil. Can be used with
|
|
// the iterator's Next method and this property's Begin method to
|
|
// iterate from front to back through all values.
|
|
End() NamePropertyIteratorInterface
|
|
// JSONLDContext returns the JSONLD URIs required in the context string
|
|
// for this property and the specific values that are set. The value
|
|
// in the map is the alias used to import the property's value or
|
|
// values.
|
|
JSONLDContext() map[string]string
|
|
// KindIndex computes an arbitrary value for indexing this kind of value.
|
|
// This is a leaky API method specifically needed only for alternate
|
|
// implementations for go-fed. Applications should not use this
|
|
// method. Panics if the index is out of bounds.
|
|
KindIndex(idx int) int
|
|
// Len returns the number of values that exist for the "name" property.
|
|
Len() (length int)
|
|
// Less computes whether another property is less than this one. Mixing
|
|
// types results in a consistent but arbitrary ordering
|
|
Less(i, j int) bool
|
|
// LessThan compares two instances of this property with an arbitrary but
|
|
// stable comparison. Applications should not use this because it is
|
|
// only meant to help alternative implementations to go-fed to be able
|
|
// to normalize nonfunctional properties.
|
|
LessThan(o NamePropertyInterface) bool
|
|
// Name returns the name of this property: "name".
|
|
Name() string
|
|
// PrependIRI prepends an IRI value to the front of a list of the property
|
|
// "name".
|
|
PrependIRI(v *url.URL)
|
|
// PrependLangString prepends a langString value to the front of a list of
|
|
// the property "name". Invalidates all iterators.
|
|
PrependLangString(v map[string]string)
|
|
// PrependString prepends a string value to the front of a list of the
|
|
// property "name". Invalidates all iterators.
|
|
PrependString(v string)
|
|
// Remove deletes an element at the specified index from a list of the
|
|
// property "name", regardless of its type. Panics if the index is out
|
|
// of bounds. Invalidates all iterators.
|
|
Remove(idx int)
|
|
// Serialize converts this into an interface representation suitable for
|
|
// marshalling into a text or binary format. Applications should not
|
|
// need this function as most typical use cases serialize types
|
|
// instead of individual properties. It is exposed for alternatives to
|
|
// go-fed implementations to use.
|
|
Serialize() (interface{}, error)
|
|
// SetIRI sets an IRI value to be at the specified index for the property
|
|
// "name". Panics if the index is out of bounds.
|
|
SetIRI(idx int, v *url.URL)
|
|
// SetLangString sets a langString value to be at the specified index for
|
|
// the property "name". Panics if the index is out of bounds.
|
|
// Invalidates all iterators.
|
|
SetLangString(idx int, v map[string]string)
|
|
// SetString sets a string value to be at the specified index for the
|
|
// property "name". Panics if the index is out of bounds. Invalidates
|
|
// all iterators.
|
|
SetString(idx int, v string)
|
|
// Swap swaps the location of values at two indices for the "name"
|
|
// property.
|
|
Swap(i, j int)
|
|
}
|