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 |
package v2 |
||||||
|
|
||||||
//ID3v2
|
//ID3v2
|
||||||
const ID3v2IDENTIFIER string = "ID3" |
const HEADERIDENTIFIER string = "ID3" |
||||||
const ID3v2HEADERSIZE int = 10 // bytes
|
const HEADERSIZE int = 10 // bytes
|
||||||
const ID3v2MAXSIZE int = 268435456 // bytes (256 MB)
|
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