Files
BuildTools
Qt
Src
Agave
Components
Elevator
Mastering
Plugins
ReplayGainAnalysis
WAT
Wasabi
Wasabi2
Winamp
aacPlus
aacdec
aacdec-mft
adpcm
alac
albumart
apev2
auth
bmp
burnlib
codesign
config
devices
external_dependencies
f263
filereader
freetypewac
gif
gracenote
h264
h264dec
id3v2
ie_plugin
installer
jpeg
libvp6
libvpShared
mp3-mpg123
mp4v
mpeg4dec
nde
nprt_plugin
ns-eel
ns-eel2
nsavi
nsmkv
Attachments.cpp
Attachments.h
Chapters.cpp
Chapters.h
Cluster.cpp
Cluster.h
Cues.cpp
Cues.h
Lacing.cpp
Lacing.h
SeekTable.cpp
SeekTable.h
SegmentInfo.cpp
SegmentInfo.h
Tags.cpp
Tags.h
Tracks.cpp
Tracks.h
ebml_float.cpp
ebml_float.h
ebml_signed.cpp
ebml_signed.h
ebml_unsigned.cpp
ebml_unsigned.h
file_mkv_reader.cpp
file_mkv_reader.h
global_elements.cpp
global_elements.h
header.cpp
header.h
main.cpp
mkv_date.cpp
mkv_date.h
mkv_reader.h
nsmkv.h
nsmkv.sln
nsmkv.vcxproj
nsmkv.vcxproj.filters
read.cpp
read.h
segment.h
vint.cpp
vint.h
nsutil
nsv
nsvdec_vp3
nsvdec_vp5
nsvdec_vp6
nswasabi
nu
omBrowser
pcm
pfc
playlist
plist
png
replicant
resources
tagz
tataki
theora
timer
vlb
vp32
vp6
vp8x
wbm
winampAll
winampa
xml
xspf
vcpkg-ports
.gitignore
LICENSE.md
README.md
automate-git.py
cef_x86.bat
install-packages.cmd
vcpkg_version_finder.py
winampAll_2019.sln
winamp/Src/nsmkv/read.cpp
2024-09-24 14:54:57 +02:00

155 lines
2.8 KiB
C++

#include "read.h"
#include "vint.h"
#include "ebml_float.h"
#include "ebml_unsigned.h"
#include "ebml_signed.h"
#include <limits.h>
#ifdef WA_VALIDATE
extern uint64_t max_id_length;
extern uint64_t max_size_length;
#endif
// returns bytes read. 0 means EOF
uint64_t read_vint(nsmkv::MKVReader *reader, uint64_t *val)
{
uint8_t data[9] = {0};
size_t bytes_read = 0;
reader->Read(data, 1, &bytes_read);
if (bytes_read != 1)
return 0;
uint8_t length = vint_get_number_bytes(data[0]);
reader->Read(data+1, length, &bytes_read);
if (bytes_read != length)
return 0;
*val = vint_read_ptr(data);
return bytes_read+1;
}
// returns bytes read. 0 means EOF
uint64_t read_ebml_node(nsmkv::MKVReader *reader, ebml_node *node)
{
uint64_t bytes_read = read_vint(reader, &node->id);
if (!bytes_read)
return 0;
bytes_read += read_vint(reader, &node->size);
return bytes_read;
}
uint64_t read_utf8(nsmkv::MKVReader *reader, uint64_t size, char **utf8)
{
if (utf8)
{
if (size == SIZE_MAX) // prevent integer overflow
return 0;
char *&val = *utf8;
val = (char *)calloc((size_t)size + 1, sizeof(char));
if (val)
{
val[size]=0;
size_t bytes_read;
reader->Read(val, (size_t)size, &bytes_read);
if (bytes_read != (size_t)size)
{
free(val);
return 0;
}
return size;
}
return 0; // actually, out of memory and not EOF, but still we should abort ASAP
}
else
{
reader->Skip(size);
return size;
}
}
#if 0
int fseek64(nsmkv::MKVReader *reader, int64_t pos, int whence)
{
switch(whence)
{
case SEEK_SET:
return fsetpos(f, &pos);
case SEEK_CUR:
{
fpos_t curpos=0;
int ret = fgetpos(f, &curpos);
if (ret != 0)
return ret;
pos+=curpos;
return fsetpos(f, &pos);
}
case SEEK_END:
{
return _fseeki64(f, pos, SEEK_END);
}
}
return 1;
}
int64_t ftell64(nsmkv::MKVReader *reader)
{
fpos_t pos;
if (fgetpos(f, &pos) == 0)
return pos;
else
return -1L;
}
#endif
uint64_t read_unsigned(nsmkv::MKVReader *reader, uint64_t size, uint64_t *val)
{
uint8_t data[8] = {0};
if (size == 0 || size > 8)
return 0;
size_t bytes_read = 0;
reader->Read(data, (size_t)size, &bytes_read);
if (bytes_read != size)
{
return 0;
}
*val = unsigned_read_ptr_len(size, data);
return size;
}
uint64_t read_float(nsmkv::MKVReader *reader, uint64_t size, double *val)
{
uint8_t data[10] = {0};
if (size == 0 || size > 10)
return 0;
size_t bytes_read = 0;
reader->Read(data, (size_t)size, &bytes_read);
if (bytes_read != size)
{
return 0;
}
*val = float_read_ptr_len(size, data);
return size;
}
uint64_t read_signed(nsmkv::MKVReader *reader, uint64_t size, int64_t *val)
{
uint8_t data[8] = {0};
if (size == 0 || size > 8)
return 0;
size_t bytes_read = 0;
reader->Read(data, (size_t)size, &bytes_read);
if (bytes_read != size)
{
return 0;
}
*val = signed_read_ptr_len(size, data);
return size;
}