go-fed-activity/streams/vocab/gen_property_forgefed_commi...

61 lines
2.6 KiB
Go

// Code generated by astool. DO NOT EDIT.
package vocab
import (
"net/url"
"time"
)
// Specifies the time that a set of changes was committed into the Repository and
// became a Commit in it. This can be different from the time the set of
// changes was produced, e.g. if one person creates a patch and sends to
// another, and the other person then applies the patch to their copy of the
// repository. We call the former event "created" and the latter event
// "committed", and this latter event is specified by the committed property.
type ForgeFedCommittedProperty interface {
// Clear ensures no value of this property is set. Calling
// IsXMLSchemaDateTime afterwards will return false.
Clear()
// Get returns the value of this property. When IsXMLSchemaDateTime
// returns false, Get will return any arbitrary value.
Get() time.Time
// GetIRI returns the IRI of this property. When IsIRI returns false,
// GetIRI will return any arbitrary value.
GetIRI() *url.URL
// HasAny returns true if the value or IRI is set.
HasAny() bool
// IsIRI returns true if this property is an IRI.
IsIRI() bool
// IsXMLSchemaDateTime returns true if this property is set and not an IRI.
IsXMLSchemaDateTime() 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 ForgeFedCommittedProperty) bool
// Name returns the name of this property: "committed".
Name() string
// 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)
// Set sets the value of this property. Calling IsXMLSchemaDateTime
// afterwards will return true.
Set(v time.Time)
// SetIRI sets the value of this property. Calling IsIRI afterwards will
// return true.
SetIRI(v *url.URL)
}