mirror of
https://gitlab.com/mbunkus/mkvtoolnix.git
synced 2024-12-24 11:54:01 +00:00
Keep tags when reading Matroska files.
This commit is contained in:
parent
ff7e9fceb9
commit
346aa044b0
@ -1,5 +1,8 @@
|
|||||||
2004-03-09 Moritz Bunkus <moritz@bunkus.org>
|
2004-03-09 Moritz Bunkus <moritz@bunkus.org>
|
||||||
|
|
||||||
|
* mkvmerge: new feature: Tags are being kept when reading Matroska
|
||||||
|
files.
|
||||||
|
|
||||||
* mkvmerge: bug fix: Large values for --sync (over 2100) would
|
* mkvmerge: bug fix: Large values for --sync (over 2100) would
|
||||||
cause an integer overflow resulting in no sync being done at all.
|
cause an integer overflow resulting in no sync being done at all.
|
||||||
|
|
||||||
|
2
TODO
2
TODO
@ -6,6 +6,4 @@ In no particular order:
|
|||||||
|
|
||||||
* mvkmerge:
|
* mvkmerge:
|
||||||
|
|
||||||
- Keep tags when reading from Matroska files.
|
|
||||||
|
|
||||||
- Split packed video stuff into proper B frames.
|
- Split packed video stuff into proper B frames.
|
||||||
|
@ -1460,6 +1460,10 @@ kax_reader_c::create_packetizer(int64_t tid) {
|
|||||||
if (nti->track_name == NULL)
|
if (nti->track_name == NULL)
|
||||||
nti->track_name = safestrdup(t->track_name);
|
nti->track_name = safestrdup(t->track_name);
|
||||||
nti->id = t->tnum; // ID for this track.
|
nti->id = t->tnum; // ID for this track.
|
||||||
|
if (t->tag != NULL) {
|
||||||
|
nti->tags = new KaxTags;
|
||||||
|
nti->tags->PushElement(*t->tag);
|
||||||
|
}
|
||||||
|
|
||||||
if (hack_engaged(ENGAGE_FORCE_PASSTHROUGH_PACKETIZER)) {
|
if (hack_engaged(ENGAGE_FORCE_PASSTHROUGH_PACKETIZER)) {
|
||||||
init_passthrough_packetizer(t);
|
init_passthrough_packetizer(t);
|
||||||
@ -1655,6 +1659,8 @@ kax_reader_c::create_packetizer(int64_t tid) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
set_packetizer_headers(t);
|
set_packetizer_headers(t);
|
||||||
|
if (t->tag != NULL)
|
||||||
|
nti->tags->Remove(0);
|
||||||
delete nti;
|
delete nti;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -77,7 +77,7 @@ generic_packetizer_c::generic_packetizer_c(generic_reader_c *nreader,
|
|||||||
ti->async.linear = 1.0;
|
ti->async.linear = 1.0;
|
||||||
ti->async.displacement = 0;
|
ti->async.displacement = 0;
|
||||||
} else
|
} else
|
||||||
ti->async.displacement *= 1000000; // ms to ns
|
ti->async.displacement *= (int64_t)1000000; // ms to ns
|
||||||
initial_displacement = ti->async.displacement;
|
initial_displacement = ti->async.displacement;
|
||||||
ti->async.displacement = 0;
|
ti->async.displacement = 0;
|
||||||
|
|
||||||
@ -1155,8 +1155,10 @@ track_info_c &track_info_c::operator =(const track_info_c &src) {
|
|||||||
for (i = 0; i < src.all_tags->size(); i++)
|
for (i = 0; i < src.all_tags->size(); i++)
|
||||||
(*all_tags)[i].file_name = safestrdup((*src.all_tags)[i].file_name);
|
(*all_tags)[i].file_name = safestrdup((*src.all_tags)[i].file_name);
|
||||||
tags_ptr = src.tags_ptr;
|
tags_ptr = src.tags_ptr;
|
||||||
tags = NULL;
|
if (src.tags != NULL)
|
||||||
// tags = src.tags;
|
tags = static_cast<KaxTags *>(src.tags->Clone());
|
||||||
|
else
|
||||||
|
tags = NULL;
|
||||||
|
|
||||||
aac_is_sbr = new vector<int64_t>(*src.aac_is_sbr);
|
aac_is_sbr = new vector<int64_t>(*src.aac_is_sbr);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user