pub struct Work {
Show 15 fields pub id: String, pub title: String, pub type_id: Option<String>, pub work_type: Option<WorkType>, pub language: Option<String>, pub languages: Option<Vec<String>>, pub iswcs: Option<Vec<String>>, pub attributes: Option<Vec<WorkAttribute>>, pub disambiguation: Option<String>, pub relations: Option<Vec<Relation>>, pub tags: Option<Vec<Tag>>, pub rating: Option<Rating>, pub aliases: Option<Vec<Alias>>, pub genres: Option<Vec<Genre>>, pub annotation: Option<String>,
}
Expand description

In MusicBrainz terminology, a work is a distinct intellectual or artistic creation, which can be expressed in the form of one or more audio recordings. While a work in MusicBrainz is usually musical in nature, it is not necessarily so. For example, a work could be a novel, play, poem or essay, later recorded as an oratory or audiobook.

Fields§

§id: String§title: String§type_id: Option<String>§work_type: Option<WorkType>

Works are represented predominantly at two levels: Discrete works, Aggregate works.

§language: Option<String>§languages: Option<Vec<String>>§iswcs: Option<Vec<String>>§attributes: Option<Vec<WorkAttribute>>§disambiguation: Option<String>

The disambiguation comments are fields in the database used to help distinguish identically named artists, labels and other entities.

§relations: Option<Vec<Relation>>§tags: Option<Vec<Tag>>§rating: Option<Rating>§aliases: Option<Vec<Alias>>

If a discrete work is known by name(s) or in language(s) other than its canonical name, these are specified in the work’s aliases.

§genres: Option<Vec<Genre>>

Genres are currently supported in MusicBrainz as part of the tag system.

§annotation: Option<String>

Annotations are text fields, functioning like a miniature wiki, that can be added to any existing artists, labels, recordings, releases, release groups and works.

Trait Implementations§

Returns a copy of the value. Read more
Performs copy-assignment from source. Read more
Formats the value using the given formatter. Read more
Deserialize this value from the given Serde deserializer. Read more
This method tests for self and other values to be equal, and is used by ==.
This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

Gets the TypeId of self. Read more
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Instruments this type with the current Span, returning an Instrumented wrapper. Read more

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The resulting type after obtaining ownership.
Creates owned data from borrowed data, usually by cloning. Read more
Uses borrowed data to replace owned data, usually by cloning. Read more
The type returned in the event of a conversion error.
Performs the conversion.
The type returned in the event of a conversion error.
Performs the conversion.
Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more