Unbewohnte
3 years ago
14 changed files with 190 additions and 108 deletions
Binary file not shown.
@ -0,0 +1,28 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"bytes" |
||||
"encoding/binary" |
||||
) |
||||
|
||||
// Returns found key (int) in provided map by value (string);
|
||||
// If key does not exist in map - returns -1
|
||||
func GetKey(mp map[int]string, givenValue string) int { |
||||
for key, value := range mp { |
||||
if value == givenValue { |
||||
return key |
||||
} |
||||
} |
||||
return -1 |
||||
} |
||||
|
||||
// Decodes given integer bytes into integer
|
||||
func BytesToInt(gBytes []byte) (int64, error) { |
||||
buff := bytes.NewBuffer(gBytes) |
||||
integer, err := binary.ReadVarint(buff) |
||||
if err != nil { |
||||
return 0, err |
||||
} |
||||
buff = nil |
||||
return integer, nil |
||||
} |
@ -0,0 +1,37 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"fmt" |
||||
"io" |
||||
) |
||||
|
||||
// Shortcut function to read n bytes from reader. The general idea peeked from here: https://github.com/dhowden/tag/blob/master/util.go
|
||||
func Read(rs io.Reader, n uint64) ([]byte, error) { |
||||
read := make([]byte, n) |
||||
_, err := rs.Read(read) |
||||
if err != nil { |
||||
return nil, fmt.Errorf("could not read from reader: %s", err) |
||||
} |
||||
|
||||
return read, nil |
||||
} |
||||
|
||||
// Shortcut function to read n bytes and convert them into string.
|
||||
// If encountered zero-byte - converts to string only previously read bytes
|
||||
func ReadToString(rs io.Reader, n int) (string, error) { |
||||
read := make([]byte, n) |
||||
_, err := rs.Read(read) |
||||
if err != nil { |
||||
return "", fmt.Errorf("could not read from reader: %s", err) |
||||
} |
||||
|
||||
var readString string |
||||
for _, b := range read { |
||||
if b == 0 { |
||||
break |
||||
} |
||||
readString += string(b) |
||||
} |
||||
|
||||
return readString, nil |
||||
} |
@ -1,90 +0,0 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"bytes" |
||||
"encoding/binary" |
||||
"fmt" |
||||
"io" |
||||
) |
||||
|
||||
// Shortcut function to read n bytes from reader. Peeked from here: https://github.com/dhowden/tag/blob/master/util.go
|
||||
func Read(rs io.Reader, n int) ([]byte, error) { |
||||
read := make([]byte, n) |
||||
_, err := rs.Read(read) |
||||
if err != nil { |
||||
return nil, fmt.Errorf("could not read from reader: %s", err) |
||||
} |
||||
|
||||
return read, nil |
||||
} |
||||
|
||||
// Shortcut function to read n bytes and convert them into string.
|
||||
// If encountered zero-byte - converts to string only previously read bytes
|
||||
func ReadToString(rs io.Reader, n int) (string, error) { |
||||
read := make([]byte, n) |
||||
_, err := rs.Read(read) |
||||
if err != nil { |
||||
return "", fmt.Errorf("could not read from reader: %s", err) |
||||
} |
||||
|
||||
var readString string |
||||
for _, b := range read { |
||||
if b == 0 { |
||||
break |
||||
} |
||||
readString += string(b) |
||||
} |
||||
|
||||
return readString, nil |
||||
} |
||||
|
||||
// Writes data to wr, if len(data) is less than lenNeeded - adds null bytes until written lenNeeded bytes
|
||||
func WriteToExtent(wr io.Writer, data []byte, lenNeeded int) error { |
||||
if len(data) > lenNeeded { |
||||
return fmt.Errorf("length of given data bytes is bigger than length needed") |
||||
} |
||||
|
||||
buff := new(bytes.Buffer) |
||||
for i := 0; i < lenNeeded; i++ { |
||||
if i < len(data) { |
||||
err := buff.WriteByte(data[i]) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} else { |
||||
err := buff.WriteByte(0) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} |
||||
} |
||||
|
||||
_, err := wr.Write(buff.Bytes()) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
|
||||
return nil |
||||
} |
||||
|
||||
// Returns found key (int) in provided map by value (string);
|
||||
// If key does not exist in map - returns -1
|
||||
func GetKey(mp map[int]string, givenValue string) int { |
||||
for key, value := range mp { |
||||
if value == givenValue { |
||||
return key |
||||
} |
||||
} |
||||
return -1 |
||||
} |
||||
|
||||
// Decodes given integer bytes into integer
|
||||
func BytesToInt(gBytes []byte) (int64, error) { |
||||
buff := bytes.NewBuffer(gBytes) |
||||
integer, err := binary.ReadVarint(buff) |
||||
if err != nil { |
||||
return 0, err |
||||
} |
||||
buff = nil |
||||
return integer, nil |
||||
} |
@ -0,0 +1,36 @@
|
||||
package util |
||||
|
||||
import ( |
||||
"bytes" |
||||
"fmt" |
||||
"io" |
||||
) |
||||
|
||||
// Writes data to wr, if len(data) is less than lenNeeded - adds null bytes until written lenNeeded bytes
|
||||
func WriteToExtent(wr io.Writer, data []byte, lenNeeded int) error { |
||||
if len(data) > lenNeeded { |
||||
return fmt.Errorf("length of given data bytes is bigger than length needed") |
||||
} |
||||
|
||||
buff := new(bytes.Buffer) |
||||
for i := 0; i < lenNeeded; i++ { |
||||
if i < len(data) { |
||||
err := buff.WriteByte(data[i]) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} else { |
||||
err := buff.WriteByte(0) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} |
||||
} |
||||
|
||||
_, err := wr.Write(buff.Bytes()) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
|
||||
return nil |
||||
} |
@ -1,6 +1,6 @@
|
||||
package v2 |
||||
|
||||
//ID3v2
|
||||
const ID3v2IDENTIFIER string = "ID3" |
||||
const ID3v2HEADERSIZE int = 10 // bytes
|
||||
const ID3v2MAXSIZE int = 268435456 // bytes (256 MB)
|
||||
const HEADERIDENTIFIER string = "ID3" |
||||
const HEADERSIZE int = 10 // bytes
|
||||
const HEADERMAXSIZE int = 268435456 // bytes (256 MB)
|
||||
|
@ -0,0 +1,59 @@
|
||||
package v2 |
||||
|
||||
import ( |
||||
"io" |
||||
|
||||
"github.com/Unbewohnte/id3ed/util" |
||||
) |
||||
|
||||
////////////////////////////////////////////////////////////////////////////
|
||||
//(ᗜˬᗜ)~⭐//Under construction//Please don`t use it in this verison//(ᗜ‸ᗜ)///
|
||||
////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
type FrameHeader struct { |
||||
Identifier string |
||||
FrameSize int64 |
||||
} |
||||
|
||||
type Frame struct { |
||||
Header *FrameHeader |
||||
Contents string |
||||
} |
||||
|
||||
// NOT TESTED !
|
||||
func Readv2Frame(rs io.Reader) (*Frame, error) { |
||||
var frameHeader *FrameHeader |
||||
var frame Frame |
||||
|
||||
identifier, err := util.ReadToString(rs, 3) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
frameHeader.Identifier = identifier |
||||
|
||||
framesizeBytes, err := util.Read(rs, 3) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
framesize, err := util.BytesToInt(framesizeBytes) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
frameHeader.FrameSize = framesize |
||||
|
||||
frameContents, err := util.ReadToString(rs, int(framesize)) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
frame.Header = frameHeader |
||||
frame.Contents = frameContents |
||||
|
||||
return &frame, nil |
||||
} |
||||
|
||||
// func ReadFrame(rs io.Reader, version string) error {
|
||||
// return nil
|
||||
// }
|
@ -0,0 +1,16 @@
|
||||
package v2 |
||||
|
||||
// func TestReadFrame(t *testing.T) {
|
||||
// f, err := os.Open(filepath.Join(TESTDATAPATH, "testreadv2.mp3"))
|
||||
// if err != nil {
|
||||
// t.Errorf("%s", err)
|
||||
// }
|
||||
|
||||
// // read right after header`s bytes
|
||||
// f.Seek(int64(HEADERSIZE), io.SeekStart)
|
||||
|
||||
// _, err = Readv2Frame(f)
|
||||
// if err != nil {
|
||||
// t.Errorf("ReadFrame failed: %s", err)
|
||||
// }
|
||||
// }
|
Loading…
Reference in new issue