Class: Id3Taginator::Frames::Lyrics::UnsyncLyricsFrame

Inherits:
Id3v2Frame
  • Object
show all
Includes:
HasId
Defined in:
lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb

Constant Summary

Constants inherited from Id3v2Frame

Id3v2Frame::HEADER_SIZE_V_2, Id3v2Frame::HEADER_SIZE_V_3_4

Constants included from Extensions::Encodable

Extensions::Encodable::ISO8859_1, Extensions::Encodable::UNICODE_ZERO, Extensions::Encodable::UTF_16, Extensions::Encodable::UTF_16BE, Extensions::Encodable::UTF_8, Extensions::Encodable::ZERO

Instance Attribute Summary collapse

Attributes inherited from Id3v2Frame

#frame_id, #options

Class Method Summary collapse

Instance Method Summary collapse

Methods included from HasId

#frame_info, included, #supported?

Methods inherited from Id3v2Frame

build_id3_flags, build_v2_frame, build_v3_frame, build_v4_frame, #compression?, #encryption?, #file_alter_preservation?, #frame_size, #group_identity?, #initialize, #re_calc_payload_size, #read_only?, #tag_alter_preservation?, #to_bytes

Methods included from Extensions::ArgumentCheck

#argument_between_num, #argument_boolean, #argument_exactly_chars, #argument_less_than_chars, #argument_more_than_chars, #argument_not_empty, #argument_not_nil, #argument_sym, included

Methods included from Extensions::Encodable

#decode, #decode_using_encoding_byte, #default_encoding_destination_byte, #encode, #encode_and_add_encoding_byte, #encode_string, #find_encoding, #find_encoding_byte, included, #merge, #pad_left, #pad_right, #read_stream_until, #remove_trailing_zeros, #zero_byte

Constructor Details

This class inherits a constructor from Id3Taginator::Frames::Id3v2Frame

Instance Attribute Details

#descriptorObject

Returns the value of attribute descriptor.



11
12
13
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 11

def descriptor
  @descriptor
end

#languageObject

Returns the value of attribute language.



11
12
13
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 11

def language
  @language
end

#lyricsObject

Returns the value of attribute lyrics.



11
12
13
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 11

def lyrics
  @lyrics
end

Class Method Details

.build_frame(language, descriptor, lyrics, options = nil, id3_version: 3) ⇒ Id3v2Frame

builds the unsync lyrics frame

Parameters:

  • language (String)

    the lyrics language as 3 character language

  • descriptor (String)

    the description

  • lyrics (String)

    the lyrics text

  • options (Options::Options) (defaults to: nil)

    options to use

  • id3_version (Integer) (defaults to: 3)

    the id3 version to build the frame for

Returns:



22
23
24
25
26
27
28
29
30
31
32
33
34
35
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 22

def self.build_frame(language, descriptor, lyrics, options = nil, id3_version: 3)
  supported?('USLT', id3_version, options)

  argument_not_nil(language, 'language')
  argument_exactly_chars(language, 'language', 3)
  argument_not_nil(lyrics, 'lyrics')
  descriptor ||= ''

  frame = new(frame_id(id3_version, options), 0, build_id3_flags(id3_version), '')
  frame.language = language
  frame.descriptor = descriptor
  frame.lyrics = lyrics
  frame
end

Instance Method Details

#content_to_bytesObject



48
49
50
51
52
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 48

def content_to_bytes
  encrypted_descriptor = encode(@descriptor, null_terminated: true)
  encrypted_lyrics = encode(@lyrics)
  merge(default_encoding_destination_byte, @language, encrypted_descriptor, encrypted_lyrics)
end

#process_content(content) ⇒ Object



37
38
39
40
41
42
43
44
45
46
# File 'lib/id3taginator/frames/lyrics/uslt_unsync_lyrics_frame.rb', line 37

def process_content(content)
  stream = StringIO.new(content)
  encoding = find_encoding(stream.readbyte)

  @language = stream.read(3)
  encoded_descriptor = read_stream_until(stream, zero_byte(encoding))
  @descriptor = decode(encoded_descriptor, encoding)
  encoded_lyrics = stream.read
  @lyrics = decode(encoded_lyrics, encoding)
end