Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
0a80b397
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
0a80b397
编写于
11月 30, 2018
作者:
K
Karthick J
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
avformat/dashenc: Added proper logging when io_open fails for write
上级
416dc9a5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
13 addition
and
6 deletion
+13
-6
libavformat/dashenc.c
libavformat/dashenc.c
+13
-6
未找到文件。
libavformat/dashenc.c
浏览文件 @
0a80b397
...
...
@@ -209,6 +209,15 @@ static const char *get_format_str(SegmentType segment_type) {
return
NULL
;
}
static
int
handle_io_open_error
(
AVFormatContext
*
s
,
int
err
,
char
*
url
)
{
DASHContext
*
c
=
s
->
priv_data
;
char
errbuf
[
AV_ERROR_MAX_STRING_SIZE
];
av_strerror
(
err
,
errbuf
,
sizeof
(
errbuf
));
av_log
(
s
,
c
->
ignore_io_errors
?
AV_LOG_WARNING
:
AV_LOG_ERROR
,
"Unable to open %s for writing: %s
\n
"
,
url
,
errbuf
);
return
c
->
ignore_io_errors
?
0
:
err
;
}
static
inline
SegmentType
select_segment_type
(
SegmentType
segment_type
,
enum
AVCodecID
codec_id
)
{
if
(
segment_type
==
SEGMENT_TYPE_AUTO
)
{
...
...
@@ -538,7 +547,7 @@ static void output_segment_list(OutputStream *os, AVIOContext *out, AVFormatCont
ret
=
dashenc_io_open
(
s
,
&
c
->
m3u8_out
,
temp_filename_hls
,
&
http_opts
);
av_dict_free
(
&
http_opts
);
if
(
ret
<
0
)
{
av_log
(
s
,
AV_LOG_ERROR
,
"Unable to open %s for writing
\n
"
,
temp_filename_hls
);
handle_io_open_error
(
s
,
ret
,
temp_filename_hls
);
return
;
}
for
(
i
=
start_index
;
i
<
os
->
nb_segments
;
i
++
)
{
...
...
@@ -853,8 +862,7 @@ static int write_manifest(AVFormatContext *s, int final)
ret
=
dashenc_io_open
(
s
,
&
c
->
mpd_out
,
temp_filename
,
&
opts
);
av_dict_free
(
&
opts
);
if
(
ret
<
0
)
{
av_log
(
s
,
AV_LOG_ERROR
,
"Unable to open %s for writing
\n
"
,
temp_filename
);
return
c
->
ignore_io_errors
?
0
:
ret
;
return
handle_io_open_error
(
s
,
ret
,
temp_filename
);
}
out
=
c
->
mpd_out
;
avio_printf
(
out
,
"<?xml version=
\"
1.0
\"
encoding=
\"
utf-8
\"
?>
\n
"
);
...
...
@@ -944,8 +952,7 @@ static int write_manifest(AVFormatContext *s, int final)
ret
=
dashenc_io_open
(
s
,
&
c
->
m3u8_out
,
temp_filename
,
&
opts
);
av_dict_free
(
&
opts
);
if
(
ret
<
0
)
{
av_log
(
s
,
AV_LOG_ERROR
,
"Unable to open %s for writing
\n
"
,
temp_filename
);
return
c
->
ignore_io_errors
?
0
:
ret
;
return
handle_io_open_error
(
s
,
ret
,
temp_filename
);
}
ff_hls_write_playlist_version
(
c
->
m3u8_out
,
7
);
...
...
@@ -1578,7 +1585,7 @@ static int dash_write_packet(AVFormatContext *s, AVPacket *pkt)
ret
=
dashenc_io_open
(
s
,
&
os
->
out
,
os
->
temp_path
,
&
opts
);
av_dict_free
(
&
opts
);
if
(
ret
<
0
)
{
return
c
->
ignore_io_errors
?
0
:
ret
;
return
handle_io_open_error
(
s
,
ret
,
os
->
temp_path
)
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录