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-07-06 17:04:59 +0800
Browse Files
Options
Browse Files
Download
Email Patches
Plain Diff
Commit
c31c607ad336a9b14a20554d29befcde877dd9c9
c31c607a
1 parent
d22e7cab
refine amf0, move declarations from cpp to hpp, use namespace _srs_internal
显示空白字符变更
内嵌
并排对比
正在显示
2 个修改的文件
包含
268 行增加
和
251 行删除
trunk/src/rtmp/srs_protocol_amf0.cpp
trunk/src/rtmp/srs_protocol_amf0.hpp
trunk/src/rtmp/srs_protocol_amf0.cpp
查看文件 @
c31c607
...
...
@@ -32,6 +32,8 @@ using namespace std;
#include <srs_kernel_error.hpp>
#include <srs_kernel_stream.hpp>
using
namespace
_srs_internal
;
// AMF0 marker
#define RTMP_AMF0_Number 0x00
#define RTMP_AMF0_Boolean 0x01
...
...
@@ -58,164 +60,6 @@ using namespace std;
// User defined
#define RTMP_AMF0_Invalid 0x3F
/**
* read amf0 string from stream.
* 2.4 String Type
* string-type = string-marker UTF-8
* @return default value is empty string.
* @remark: use SrsAmf0Any::str() to create it.
*/
class
__SrsAmf0String
:
public
SrsAmf0Any
{
public
:
std
::
string
value
;
__SrsAmf0String
(
const
char
*
_value
);
virtual
~
__SrsAmf0String
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 boolean from stream.
* 2.4 String Type
* boolean-type = boolean-marker U8
* 0 is false, <> 0 is true
* @return default value is false.
*/
class
__SrsAmf0Boolean
:
public
SrsAmf0Any
{
public
:
bool
value
;
__SrsAmf0Boolean
(
bool
_value
);
virtual
~
__SrsAmf0Boolean
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 number from stream.
* 2.2 Number Type
* number-type = number-marker DOUBLE
* @return default value is 0.
*/
class
__SrsAmf0Number
:
public
SrsAmf0Any
{
public
:
double
value
;
__SrsAmf0Number
(
double
_value
);
virtual
~
__SrsAmf0Number
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 null from stream.
* 2.7 null Type
* null-type = null-marker
*/
class
__SrsAmf0Null
:
public
SrsAmf0Any
{
public
:
__SrsAmf0Null
();
virtual
~
__SrsAmf0Null
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 undefined from stream.
* 2.8 undefined Type
* undefined-type = undefined-marker
*/
class
__SrsAmf0Undefined
:
public
SrsAmf0Any
{
public
:
__SrsAmf0Undefined
();
virtual
~
__SrsAmf0Undefined
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* to ensure in inserted order.
* for the FMLE will crash when AMF0Object is not ordered by inserted,
* if ordered in map, the string compare order, the FMLE will creash when
* get the response of connect app.
*/
class
__SrsUnSortedHashtable
{
private
:
typedef
std
::
pair
<
std
::
string
,
SrsAmf0Any
*>
SrsAmf0ObjectPropertyType
;
std
::
vector
<
SrsAmf0ObjectPropertyType
>
properties
;
public
:
__SrsUnSortedHashtable
();
virtual
~
__SrsUnSortedHashtable
();
virtual
int
count
();
virtual
void
clear
();
virtual
std
::
string
key_at
(
int
index
);
virtual
const
char
*
key_raw_at
(
int
index
);
virtual
SrsAmf0Any
*
value_at
(
int
index
);
virtual
void
set
(
std
::
string
key
,
SrsAmf0Any
*
value
);
virtual
SrsAmf0Any
*
get_property
(
std
::
string
name
);
virtual
SrsAmf0Any
*
ensure_property_string
(
std
::
string
name
);
virtual
SrsAmf0Any
*
ensure_property_number
(
std
::
string
name
);
virtual
void
copy
(
__SrsUnSortedHashtable
*
src
);
};
/**
* 2.11 Object End Type
* object-end-type = UTF-8-empty object-end-marker
* 0x00 0x00 0x09
*/
class
__SrsAmf0ObjectEOF
:
public
SrsAmf0Any
{
public
:
int16_t
utf8_empty
;
__SrsAmf0ObjectEOF
();
virtual
~
__SrsAmf0ObjectEOF
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 utf8 string from stream.
* 1.3.1 Strings and UTF-8
* UTF-8 = U16 *(UTF8-char)
* UTF8-char = UTF8-1 | UTF8-2 | UTF8-3 | UTF8-4
* UTF8-1 = %x00-7F
* @remark only support UTF8-1 char.
*/
extern
int
srs_amf0_read_utf8
(
SrsStream
*
stream
,
std
::
string
&
value
);
extern
int
srs_amf0_write_utf8
(
SrsStream
*
stream
,
std
::
string
value
);
bool
srs_amf0_is_object_eof
(
SrsStream
*
stream
);
int
srs_amf0_write_any
(
SrsStream
*
stream
,
SrsAmf0Any
*
value
);
SrsAmf0Any
::
SrsAmf0Any
()
{
marker
=
RTMP_AMF0_Invalid
;
...
...
@@ -804,7 +648,7 @@ int SrsAmf0Object::read(SrsStream* stream)
// property-name: utf8 string
std
::
string
property_name
;
if
((
ret
=
srs_amf0_read_utf8
(
stream
,
property_name
))
!=
ERROR_SUCCESS
)
{
if
((
ret
=
srs_amf0_read_utf8
(
stream
,
property_name
))
!=
ERROR_SUCCESS
)
{
srs_error
(
"amf0 object read property name failed. ret=%d"
,
ret
);
return
ret
;
}
...
...
@@ -1517,88 +1361,6 @@ int srs_amf0_read_any(SrsStream* stream, SrsAmf0Any** ppvalue)
return
ret
;
}
int
srs_amf0_write_any
(
SrsStream
*
stream
,
SrsAmf0Any
*
value
)
{
srs_assert
(
value
!=
NULL
);
return
value
->
write
(
stream
);
}
int
srs_amf0_read_utf8
(
SrsStream
*
stream
,
string
&
value
)
{
int
ret
=
ERROR_SUCCESS
;
// len
if
(
!
stream
->
require
(
2
))
{
ret
=
ERROR_RTMP_AMF0_DECODE
;
srs_error
(
"amf0 read string length failed. ret=%d"
,
ret
);
return
ret
;
}
int16_t
len
=
stream
->
read_2bytes
();
srs_verbose
(
"amf0 read string length success. len=%d"
,
len
);
// empty string
if
(
len
<=
0
)
{
srs_verbose
(
"amf0 read empty string. ret=%d"
,
ret
);
return
ret
;
}
// data
if
(
!
stream
->
require
(
len
))
{
ret
=
ERROR_RTMP_AMF0_DECODE
;
srs_error
(
"amf0 read string data failed. ret=%d"
,
ret
);
return
ret
;
}
std
::
string
str
=
stream
->
read_string
(
len
);
// support utf8-1 only
// 1.3.1 Strings and UTF-8
// UTF8-1 = %x00-7F
// TODO: support other utf-8 strings
/*for (int i = 0; i < len; i++) {
char ch = *(str.data() + i);
if ((ch & 0x80) != 0) {
ret = ERROR_RTMP_AMF0_DECODE;
srs_error("ignored. only support utf8-1, 0x00-0x7F, actual is %#x. ret=%d", (int)ch, ret);
ret = ERROR_SUCCESS;
}
}*/
value
=
str
;
srs_verbose
(
"amf0 read string data success. str=%s"
,
str
.
c_str
());
return
ret
;
}
int
srs_amf0_write_utf8
(
SrsStream
*
stream
,
string
value
)
{
int
ret
=
ERROR_SUCCESS
;
// len
if
(
!
stream
->
require
(
2
))
{
ret
=
ERROR_RTMP_AMF0_ENCODE
;
srs_error
(
"amf0 write string length failed. ret=%d"
,
ret
);
return
ret
;
}
stream
->
write_2bytes
(
value
.
length
());
srs_verbose
(
"amf0 write string length success. len=%d"
,
(
int
)
value
.
length
());
// empty string
if
(
value
.
length
()
<=
0
)
{
srs_verbose
(
"amf0 write empty string. ret=%d"
,
ret
);
return
ret
;
}
// data
if
(
!
stream
->
require
(
value
.
length
()))
{
ret
=
ERROR_RTMP_AMF0_ENCODE
;
srs_error
(
"amf0 write string data failed. ret=%d"
,
ret
);
return
ret
;
}
stream
->
write_string
(
value
);
srs_verbose
(
"amf0 write string data success. str=%s"
,
value
.
c_str
());
return
ret
;
}
int
srs_amf0_read_string
(
SrsStream
*
stream
,
string
&
value
)
{
int
ret
=
ERROR_SUCCESS
;
...
...
@@ -1849,8 +1611,87 @@ int srs_amf0_write_undefined(SrsStream* stream)
return
ret
;
}
bool
srs_amf0_is_object_eof
(
SrsStream
*
stream
)
namespace
_srs_internal
{
int
srs_amf0_read_utf8
(
SrsStream
*
stream
,
string
&
value
)
{
int
ret
=
ERROR_SUCCESS
;
// len
if
(
!
stream
->
require
(
2
))
{
ret
=
ERROR_RTMP_AMF0_DECODE
;
srs_error
(
"amf0 read string length failed. ret=%d"
,
ret
);
return
ret
;
}
int16_t
len
=
stream
->
read_2bytes
();
srs_verbose
(
"amf0 read string length success. len=%d"
,
len
);
// empty string
if
(
len
<=
0
)
{
srs_verbose
(
"amf0 read empty string. ret=%d"
,
ret
);
return
ret
;
}
// data
if
(
!
stream
->
require
(
len
))
{
ret
=
ERROR_RTMP_AMF0_DECODE
;
srs_error
(
"amf0 read string data failed. ret=%d"
,
ret
);
return
ret
;
}
std
::
string
str
=
stream
->
read_string
(
len
);
// support utf8-1 only
// 1.3.1 Strings and UTF-8
// UTF8-1 = %x00-7F
// TODO: support other utf-8 strings
/*for (int i = 0; i < len; i++) {
char ch = *(str.data() + i);
if ((ch & 0x80) != 0) {
ret = ERROR_RTMP_AMF0_DECODE;
srs_error("ignored. only support utf8-1, 0x00-0x7F, actual is %#x. ret=%d", (int)ch, ret);
ret = ERROR_SUCCESS;
}
}*/
value
=
str
;
srs_verbose
(
"amf0 read string data success. str=%s"
,
str
.
c_str
());
return
ret
;
}
int
srs_amf0_write_utf8
(
SrsStream
*
stream
,
string
value
)
{
int
ret
=
ERROR_SUCCESS
;
// len
if
(
!
stream
->
require
(
2
))
{
ret
=
ERROR_RTMP_AMF0_ENCODE
;
srs_error
(
"amf0 write string length failed. ret=%d"
,
ret
);
return
ret
;
}
stream
->
write_2bytes
(
value
.
length
());
srs_verbose
(
"amf0 write string length success. len=%d"
,
(
int
)
value
.
length
());
// empty string
if
(
value
.
length
()
<=
0
)
{
srs_verbose
(
"amf0 write empty string. ret=%d"
,
ret
);
return
ret
;
}
// data
if
(
!
stream
->
require
(
value
.
length
()))
{
ret
=
ERROR_RTMP_AMF0_ENCODE
;
srs_error
(
"amf0 write string data failed. ret=%d"
,
ret
);
return
ret
;
}
stream
->
write_string
(
value
);
srs_verbose
(
"amf0 write string data success. str=%s"
,
value
.
c_str
());
return
ret
;
}
bool
srs_amf0_is_object_eof
(
SrsStream
*
stream
)
{
// detect the object-eof specially
if
(
stream
->
require
(
3
))
{
int32_t
flag
=
stream
->
read_3bytes
();
...
...
@@ -1860,10 +1701,10 @@ bool srs_amf0_is_object_eof(SrsStream* stream)
}
return
false
;
}
}
int
srs_amf0_write_object_eof
(
SrsStream
*
stream
,
__SrsAmf0ObjectEOF
*
value
)
{
int
srs_amf0_write_object_eof
(
SrsStream
*
stream
,
__SrsAmf0ObjectEOF
*
value
)
{
int
ret
=
ERROR_SUCCESS
;
srs_assert
(
value
!=
NULL
);
...
...
@@ -1889,4 +1730,11 @@ int srs_amf0_write_object_eof(SrsStream* stream, __SrsAmf0ObjectEOF* value)
srs_verbose
(
"amf0 read object eof success"
);
return
ret
;
}
int
srs_amf0_write_any
(
SrsStream
*
stream
,
SrsAmf0Any
*
value
)
{
srs_assert
(
value
!=
NULL
);
return
value
->
write
(
stream
);
}
}
...
...
trunk/src/rtmp/srs_protocol_amf0.hpp
查看文件 @
c31c607
...
...
@@ -37,8 +37,13 @@ class SrsStream;
class
SrsAmf0Object
;
class
SrsAmf0EcmaArray
;
class
SrsAmf0StrictArray
;
class
__SrsUnSortedHashtable
;
class
__SrsAmf0ObjectEOF
;
// internal objects, user should never use it.
namespace
_srs_internal
{
class
__SrsUnSortedHashtable
;
class
__SrsAmf0ObjectEOF
;
}
/*
////////////////////////////////////////////////////////////////////////
...
...
@@ -312,8 +317,8 @@ public:
class
SrsAmf0Object
:
public
SrsAmf0Any
{
private
:
__SrsUnSortedHashtable
*
properties
;
__SrsAmf0ObjectEOF
*
eof
;
_srs_internal
::
__SrsUnSortedHashtable
*
properties
;
_srs_internal
::
__SrsAmf0ObjectEOF
*
eof
;
private
:
friend
class
SrsAmf0Any
;
/**
...
...
@@ -394,8 +399,8 @@ public:
class
SrsAmf0EcmaArray
:
public
SrsAmf0Any
{
private
:
__SrsUnSortedHashtable
*
properties
;
__SrsAmf0ObjectEOF
*
eof
;
_srs_internal
::
__SrsUnSortedHashtable
*
properties
;
_srs_internal
::
__SrsAmf0ObjectEOF
*
eof
;
int32_t
_count
;
private
:
friend
class
SrsAmf0Any
;
...
...
@@ -585,4 +590,168 @@ extern int srs_amf0_write_null(SrsStream* stream);
extern
int
srs_amf0_read_undefined
(
SrsStream
*
stream
);
extern
int
srs_amf0_write_undefined
(
SrsStream
*
stream
);
// internal objects, user should never use it.
namespace
_srs_internal
{
/**
* read amf0 string from stream.
* 2.4 String Type
* string-type = string-marker UTF-8
* @return default value is empty string.
* @remark: use SrsAmf0Any::str() to create it.
*/
class
__SrsAmf0String
:
public
SrsAmf0Any
{
public
:
std
::
string
value
;
public
:
__SrsAmf0String
(
const
char
*
_value
);
virtual
~
__SrsAmf0String
();
public
:
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 boolean from stream.
* 2.4 String Type
* boolean-type = boolean-marker U8
* 0 is false, <> 0 is true
* @return default value is false.
*/
class
__SrsAmf0Boolean
:
public
SrsAmf0Any
{
public
:
bool
value
;
public
:
__SrsAmf0Boolean
(
bool
_value
);
virtual
~
__SrsAmf0Boolean
();
public
:
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 number from stream.
* 2.2 Number Type
* number-type = number-marker DOUBLE
* @return default value is 0.
*/
class
__SrsAmf0Number
:
public
SrsAmf0Any
{
public
:
double
value
;
public
:
__SrsAmf0Number
(
double
_value
);
virtual
~
__SrsAmf0Number
();
public
:
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 null from stream.
* 2.7 null Type
* null-type = null-marker
*/
class
__SrsAmf0Null
:
public
SrsAmf0Any
{
public
:
__SrsAmf0Null
();
virtual
~
__SrsAmf0Null
();
public
:
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 undefined from stream.
* 2.8 undefined Type
* undefined-type = undefined-marker
*/
class
__SrsAmf0Undefined
:
public
SrsAmf0Any
{
public
:
__SrsAmf0Undefined
();
virtual
~
__SrsAmf0Undefined
();
public
:
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* to ensure in inserted order.
* for the FMLE will crash when AMF0Object is not ordered by inserted,
* if ordered in map, the string compare order, the FMLE will creash when
* get the response of connect app.
*/
class
__SrsUnSortedHashtable
{
private
:
typedef
std
::
pair
<
std
::
string
,
SrsAmf0Any
*>
SrsAmf0ObjectPropertyType
;
std
::
vector
<
SrsAmf0ObjectPropertyType
>
properties
;
public
:
__SrsUnSortedHashtable
();
virtual
~
__SrsUnSortedHashtable
();
public
:
virtual
int
count
();
virtual
void
clear
();
virtual
std
::
string
key_at
(
int
index
);
virtual
const
char
*
key_raw_at
(
int
index
);
virtual
SrsAmf0Any
*
value_at
(
int
index
);
virtual
void
set
(
std
::
string
key
,
SrsAmf0Any
*
value
);
public
:
virtual
SrsAmf0Any
*
get_property
(
std
::
string
name
);
virtual
SrsAmf0Any
*
ensure_property_string
(
std
::
string
name
);
virtual
SrsAmf0Any
*
ensure_property_number
(
std
::
string
name
);
public
:
virtual
void
copy
(
__SrsUnSortedHashtable
*
src
);
};
/**
* 2.11 Object End Type
* object-end-type = UTF-8-empty object-end-marker
* 0x00 0x00 0x09
*/
class
__SrsAmf0ObjectEOF
:
public
SrsAmf0Any
{
public
:
int16_t
utf8_empty
;
__SrsAmf0ObjectEOF
();
virtual
~
__SrsAmf0ObjectEOF
();
virtual
int
total_size
();
virtual
int
read
(
SrsStream
*
stream
);
virtual
int
write
(
SrsStream
*
stream
);
virtual
SrsAmf0Any
*
copy
();
};
/**
* read amf0 utf8 string from stream.
* 1.3.1 Strings and UTF-8
* UTF-8 = U16 *(UTF8-char)
* UTF8-char = UTF8-1 | UTF8-2 | UTF8-3 | UTF8-4
* UTF8-1 = %x00-7F
* @remark only support UTF8-1 char.
*/
extern
int
srs_amf0_read_utf8
(
SrsStream
*
stream
,
std
::
string
&
value
);
extern
int
srs_amf0_write_utf8
(
SrsStream
*
stream
,
std
::
string
value
);
extern
bool
srs_amf0_is_object_eof
(
SrsStream
*
stream
);
extern
int
srs_amf0_write_object_eof
(
SrsStream
*
stream
,
__SrsAmf0ObjectEOF
*
value
);
extern
int
srs_amf0_write_any
(
SrsStream
*
stream
,
SrsAmf0Any
*
value
);
};
#endif
\ No newline at end of file
...
...
请
注册
或
登录
后发表评论