Toggle navigation
Toggle navigation
此项目
正在载入...
Sign in
胡斌
/
srs
转到一个项目
Toggle navigation
项目
群组
代码片段
帮助
Toggle navigation pinning
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Network
Create a new issue
Builds
Commits
Authored by
winlin
2014-05-14 09:58:42 +0800
Browse Files
Options
Browse Files
Download
Email Patches
Plain Diff
Commit
3ebda1380230cb5bab1bd03bed725823814ee869
3ebda138
1 parent
dc66c525
refine the ptr array free, 0.9.96
隐藏空白字符变更
内嵌
并排对比
正在显示
5 个修改的文件
包含
58 行增加
和
49 行删除
trunk/src/app/srs_app_edge.cpp
trunk/src/app/srs_app_forward.cpp
trunk/src/app/srs_app_rtmp_conn.cpp
trunk/src/core/srs_core.hpp
trunk/src/core/srs_core_autofree.hpp
trunk/src/app/srs_app_edge.cpp
查看文件 @
3ebda13
...
...
@@ -474,6 +474,7 @@ int SrsEdgeForwarder::cycle()
srs_verbose
(
"no packets to forward."
);
continue
;
}
SrsAutoFreeArray
(
SrsSharedPtrMessage
,
msgs
,
count
);
// all msgs to forward to origin.
// @remark, becareful, all msgs must be free explicitly,
...
...
@@ -484,23 +485,11 @@ int SrsEdgeForwarder::cycle()
srs_assert
(
msg
);
msgs
[
i
]
=
NULL
;
// never use free msgs array, for it will memory leak.
// if error, directly free msgs.
if
(
ret
!=
ERROR_SUCCESS
)
{
srs_freep
(
msg
);
continue
;
}
if
((
ret
=
client
->
send_and_free_message
(
msg
))
!=
ERROR_SUCCESS
)
{
srs_error
(
"edge publish forwarder send message to server failed. ret=%d"
,
ret
);
continue
;
return
ret
;
}
}
// free the array itself.
srs_freep
(
msgs
);
if
(
ret
!=
ERROR_SUCCESS
)
{
return
ret
;
}
}
return
ret
;
...
...
trunk/src/app/srs_app_forward.cpp
查看文件 @
3ebda13
...
...
@@ -352,6 +352,7 @@ int SrsForwarder::forward()
srs_verbose
(
"no packets to forward."
);
continue
;
}
SrsAutoFreeArray
(
SrsSharedPtrMessage
,
msgs
,
count
);
// all msgs to forward.
// @remark, becareful, all msgs must be free explicitly,
...
...
@@ -362,23 +363,11 @@ int SrsForwarder::forward()
srs_assert
(
msg
);
msgs
[
i
]
=
NULL
;
// never use free msgs array, for it will memory leak.
// if error, directly free msgs.
if
(
ret
!=
ERROR_SUCCESS
)
{
srs_freep
(
msg
);
continue
;
}
if
((
ret
=
client
->
send_and_free_message
(
msg
))
!=
ERROR_SUCCESS
)
{
srs_error
(
"forwarder send message to server failed. ret=%d"
,
ret
);
continue
;
return
ret
;
}
}
// free the array itself.
srs_freep
(
msgs
);
if
(
ret
!=
ERROR_SUCCESS
)
{
return
ret
;
}
}
return
ret
;
...
...
trunk/src/app/srs_app_rtmp_conn.cpp
查看文件 @
3ebda13
...
...
@@ -513,6 +513,7 @@ int SrsRtmpConn::playing(SrsSource* source)
srs_verbose
(
"no packets in queue."
);
continue
;
}
SrsAutoFreeArray
(
SrsSharedPtrMessage
,
msgs
,
count
);
// sendout messages
// @remark, becareful, all msgs must be free explicitly,
...
...
@@ -526,13 +527,6 @@ int SrsRtmpConn::playing(SrsSource* source)
srs_assert
(
msg
);
// never use free msgs array, for it will memory leak.
// if error, directly free msgs.
if
(
ret
!=
ERROR_SUCCESS
)
{
srs_freep
(
msg
);
continue
;
}
// foreach msg, collect the duration.
// @remark: never use msg when sent it, for the protocol sdk will free it.
if
(
starttime
<
0
||
starttime
>
msg
->
header
.
timestamp
)
{
...
...
@@ -543,14 +537,9 @@ int SrsRtmpConn::playing(SrsSource* source)
if
((
ret
=
rtmp
->
send_and_free_message
(
msg
))
!=
ERROR_SUCCESS
)
{
srs_error
(
"send message to client failed. ret=%d"
,
ret
);
continue
;
return
ret
;
}
}
// free the array itself.
srs_freep
(
msgs
);
if
(
ret
!=
ERROR_SUCCESS
)
{
return
ret
;
}
// if duration specified, and exceed it, stop play live.
// @see: https://github.com/winlinvip/simple-rtmp-server/issues/45
...
...
trunk/src/core/srs_core.hpp
查看文件 @
3ebda13
...
...
@@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
// current release version
#define VERSION_MAJOR "0"
#define VERSION_MINOR "9"
#define VERSION_REVISION "9
5
"
#define VERSION_REVISION "9
6
"
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
// server info.
#define RTMP_SIG_SRS_KEY "srs"
...
...
trunk/src/core/srs_core_autofree.hpp
查看文件 @
3ebda13
...
...
@@ -31,11 +31,17 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include <srs_core.hpp>
/**
* auto free the instance in the current scope.
* auto free the instance in the current scope, for instance, MyClass* ptr,
* which is a ptr and this class will:
* 1. free the ptr.
* 2. set ptr to NULL.
* Usage:
* MyClass* po = new MyClass();
* // ...... use po
* SrsAutoFree(MyClass, po);
*/
#define SrsAutoFree(className, instance) \
__SrsAutoFree<className> _auto_free_##instance((className**)&instance)
__SrsAutoFree<className> _auto_free_##instance(&instance)
template
<
class
T
>
class
__SrsAutoFree
{
...
...
@@ -44,13 +50,12 @@ private:
public
:
/**
* auto delete the ptr.
* @is_array a bool value indicates whether the ptr is a array.
*/
__SrsAutoFree
(
T
**
_ptr
){
__SrsAutoFree
(
T
**
_ptr
)
{
ptr
=
_ptr
;
}
virtual
~
__SrsAutoFree
(){
virtual
~
__SrsAutoFree
()
{
if
(
ptr
==
NULL
||
*
ptr
==
NULL
)
{
return
;
}
...
...
@@ -64,13 +69,50 @@ public:
/**
* auto free the array ptrs, for example, MyClass* msgs[10],
* which stores 10 MyClass* objects, this class will:
* 1. free each MyClass* in array.
* 2. free the msgs itself.
* 1. free each MyClass* in array.
* 2. free the msgs itself.
* 3. set msgs to NULL.
* @remark, MyClass* msgs[] equals to MyClass**, the ptr array equals ptr to ptr.
* Usage:
* MyClass* msgs[10];
* // ...... use msgs.
* SrsAutoFreeArray(MyClass, msgs, 10);
*/
#define SrsAutoFreeArray(className, instance, size) \
__SrsAutoFreeArray<className> _auto_free_array_##instance(&instance, size)
template
<
class
T
>
class
SrsObjectPtrArrayAutoFree
class
__SrsAutoFreeArray
{
private
:
T
***
ptr
;
int
size
;
public
:
/**
* auto delete the ptr array.
*/
__SrsAutoFreeArray
(
T
***
_ptr
,
int
_size
)
{
ptr
=
_ptr
;
size
=
_size
;
}
virtual
~
__SrsAutoFreeArray
()
{
if
(
ptr
==
NULL
||
*
ptr
==
NULL
)
{
return
;
}
T
**
arr
=
*
ptr
;
for
(
int
i
=
0
;
i
<
size
;
i
++
)
{
T
*
pobj
=
arr
[
i
];
if
(
pobj
)
{
delete
pobj
;
arr
[
i
]
=
NULL
;
}
}
delete
arr
;
*
ptr
=
NULL
;
}
};
#endif
\ No newline at end of file
...
...
请
注册
或
登录
后发表评论