|
|
|
@ -248,7 +248,7 @@ static int flv_write_header(AVFormatContext *s) |
|
|
|
|
"16-bit big-endian audio in flv is valid but most likely unplayable (hardware dependent); use s16le\n"); |
|
|
|
|
break; |
|
|
|
|
case AVMEDIA_TYPE_DATA: |
|
|
|
|
if (enc->codec_id != AV_CODEC_ID_TEXT) { |
|
|
|
|
if (enc->codec_id != AV_CODEC_ID_TEXT && enc->codec_id != AV_CODEC_ID_NONE) { |
|
|
|
|
av_log(s, AV_LOG_ERROR, "Data codec '%s' for stream %d is not compatible with FLV\n", |
|
|
|
|
avcodec_get_name(enc->codec_id), i); |
|
|
|
|
return AVERROR_INVALIDDATA; |
|
|
|
@ -556,18 +556,24 @@ static int flv_write_packet(AVFormatContext *s, AVPacket *pkt) |
|
|
|
|
if (enc->codec_type == AVMEDIA_TYPE_DATA) { |
|
|
|
|
int data_size; |
|
|
|
|
int64_t metadata_size_pos = avio_tell(pb); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, "onTextData"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_MIXEDARRAY); |
|
|
|
|
avio_wb32(pb, 2); |
|
|
|
|
put_amf_string(pb, "type"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, "Text"); |
|
|
|
|
put_amf_string(pb, "text"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, pkt->data); |
|
|
|
|
put_amf_string(pb, ""); |
|
|
|
|
avio_w8(pb, AMF_END_OF_OBJECT); |
|
|
|
|
if (enc->codec_type == AV_CODEC_ID_TEXT) { |
|
|
|
|
// legacy FFmpeg magic?
|
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, "onTextData"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_MIXEDARRAY); |
|
|
|
|
avio_wb32(pb, 2); |
|
|
|
|
put_amf_string(pb, "type"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, "Text"); |
|
|
|
|
put_amf_string(pb, "text"); |
|
|
|
|
avio_w8(pb, AMF_DATA_TYPE_STRING); |
|
|
|
|
put_amf_string(pb, pkt->data); |
|
|
|
|
put_amf_string(pb, ""); |
|
|
|
|
avio_w8(pb, AMF_END_OF_OBJECT); |
|
|
|
|
} else { |
|
|
|
|
// just pass the metadata through
|
|
|
|
|
avio_write(pb, data ? data : pkt->data, size); |
|
|
|
|
} |
|
|
|
|
/* write total size of tag */ |
|
|
|
|
data_size = avio_tell(pb) - metadata_size_pos; |
|
|
|
|
avio_seek(pb, metadata_size_pos - 10, SEEK_SET); |
|
|
|
|