Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc
Commits
313e7a26
Commit
313e7a26
authored
Jun 03, 2014
by
Rafaël Carré
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
opus_header: remove dependency on ogg
parent
ed8daf3f
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
22 additions
and
31 deletions
+22
-31
modules/codec/opus_header.c
modules/codec/opus_header.c
+21
-29
modules/codec/opus_header.h
modules/codec/opus_header.h
+1
-2
No files found.
modules/codec/opus_header.c
View file @
313e7a26
...
@@ -74,7 +74,7 @@ typedef struct {
...
@@ -74,7 +74,7 @@ typedef struct {
int
pos
;
int
pos
;
}
ROPacket
;
}
ROPacket
;
static
int
write_uint32
(
Packet
*
p
,
ogg_
uint32_t
val
)
static
int
write_uint32
(
Packet
*
p
,
uint32_t
val
)
{
{
if
(
p
->
pos
>
p
->
maxlen
-
4
)
if
(
p
->
pos
>
p
->
maxlen
-
4
)
return
0
;
return
0
;
...
@@ -86,7 +86,7 @@ static int write_uint32(Packet *p, ogg_uint32_t val)
...
@@ -86,7 +86,7 @@ static int write_uint32(Packet *p, ogg_uint32_t val)
return
1
;
return
1
;
}
}
static
int
write_uint16
(
Packet
*
p
,
ogg_
uint16_t
val
)
static
int
write_uint16
(
Packet
*
p
,
uint16_t
val
)
{
{
if
(
p
->
pos
>
p
->
maxlen
-
2
)
if
(
p
->
pos
>
p
->
maxlen
-
2
)
return
0
;
return
0
;
...
@@ -105,24 +105,24 @@ static int write_chars(Packet *p, const unsigned char *str, int nb_chars)
...
@@ -105,24 +105,24 @@ static int write_chars(Packet *p, const unsigned char *str, int nb_chars)
return
1
;
return
1
;
}
}
static
int
read_uint32
(
ROPacket
*
p
,
ogg_
uint32_t
*
val
)
static
int
read_uint32
(
ROPacket
*
p
,
uint32_t
*
val
)
{
{
if
(
p
->
pos
>
p
->
maxlen
-
4
)
if
(
p
->
pos
>
p
->
maxlen
-
4
)
return
0
;
return
0
;
*
val
=
(
ogg_
uint32_t
)
p
->
data
[
p
->
pos
];
*
val
=
(
uint32_t
)
p
->
data
[
p
->
pos
];
*
val
|=
(
ogg_
uint32_t
)
p
->
data
[
p
->
pos
+
1
]
<<
8
;
*
val
|=
(
uint32_t
)
p
->
data
[
p
->
pos
+
1
]
<<
8
;
*
val
|=
(
ogg_
uint32_t
)
p
->
data
[
p
->
pos
+
2
]
<<
16
;
*
val
|=
(
uint32_t
)
p
->
data
[
p
->
pos
+
2
]
<<
16
;
*
val
|=
(
ogg_
uint32_t
)
p
->
data
[
p
->
pos
+
3
]
<<
24
;
*
val
|=
(
uint32_t
)
p
->
data
[
p
->
pos
+
3
]
<<
24
;
p
->
pos
+=
4
;
p
->
pos
+=
4
;
return
1
;
return
1
;
}
}
static
int
read_uint16
(
ROPacket
*
p
,
ogg_
uint16_t
*
val
)
static
int
read_uint16
(
ROPacket
*
p
,
uint16_t
*
val
)
{
{
if
(
p
->
pos
>
p
->
maxlen
-
2
)
if
(
p
->
pos
>
p
->
maxlen
-
2
)
return
0
;
return
0
;
*
val
=
(
ogg_
uint16_t
)
p
->
data
[
p
->
pos
];
*
val
=
(
uint16_t
)
p
->
data
[
p
->
pos
];
*
val
|=
(
ogg_
uint16_t
)
p
->
data
[
p
->
pos
+
1
]
<<
8
;
*
val
|=
(
uint16_t
)
p
->
data
[
p
->
pos
+
1
]
<<
8
;
p
->
pos
+=
2
;
p
->
pos
+=
2
;
return
1
;
return
1
;
}
}
...
@@ -141,7 +141,7 @@ int opus_header_parse(const unsigned char *packet, int len, OpusHeader *h)
...
@@ -141,7 +141,7 @@ int opus_header_parse(const unsigned char *packet, int len, OpusHeader *h)
char
str
[
9
];
char
str
[
9
];
ROPacket
p
;
ROPacket
p
;
unsigned
char
ch
;
unsigned
char
ch
;
ogg_
uint16_t
shortval
;
uint16_t
shortval
;
p
.
data
=
packet
;
p
.
data
=
packet
;
p
.
maxlen
=
len
;
p
.
maxlen
=
len
;
...
@@ -372,13 +372,12 @@ int opus_write_header(uint8_t **p_extra, int *i_extra, OpusHeader *header)
...
@@ -372,13 +372,12 @@ int opus_write_header(uint8_t **p_extra, int *i_extra, OpusHeader *header)
unsigned
char
header_data
[
100
];
unsigned
char
header_data
[
100
];
const
int
packet_size
=
opus_header_to_packet
(
header
,
header_data
,
const
int
packet_size
=
opus_header_to_packet
(
header
,
header_data
,
sizeof
(
header_data
));
sizeof
(
header_data
));
ogg_packet
headers
[
2
];
headers
[
0
].
packet
=
header_data
;
unsigned
char
*
data
[
2
];
headers
[
0
].
bytes
=
packet_size
;
size_t
size
[
2
];
headers
[
0
].
b_o_s
=
1
;
headers
[
0
].
e_o_s
=
0
;
data
[
0
]
=
header_data
;
headers
[
0
].
granulepos
=
0
;
size
[
0
]
=
packet_size
;
headers
[
0
].
packetno
=
0
;
size_t
comments_length
;
size_t
comments_length
;
char
*
comments
=
comment_init
(
&
comments_length
);
char
*
comments
=
comment_init
(
&
comments_length
);
...
@@ -397,22 +396,15 @@ int opus_write_header(uint8_t **p_extra, int *i_extra, OpusHeader *header)
...
@@ -397,22 +396,15 @@ int opus_write_header(uint8_t **p_extra, int *i_extra, OpusHeader *header)
return
1
;
return
1
;
}
}
headers
[
1
].
packet
=
(
unsigned
char
*
)
comments
;
data
[
1
]
=
(
unsigned
char
*
)
comments
;
headers
[
1
].
bytes
=
comments_length
;
size
[
1
]
=
comments_length
;
headers
[
1
].
b_o_s
=
0
;
headers
[
1
].
e_o_s
=
0
;
headers
[
1
].
granulepos
=
0
;
headers
[
1
].
packetno
=
1
;
for
(
unsigned
i
=
0
;
i
<
ARRAY_SIZE
(
headers
);
++
i
)
for
(
unsigned
i
=
0
;
i
<
ARRAY_SIZE
(
data
);
++
i
)
{
if
(
xiph_AppendHeaders
(
i_extra
,
(
void
**
)
p_extra
,
size
[
i
],
data
[
i
]))
if
(
xiph_AppendHeaders
(
i_extra
,
(
void
**
)
p_extra
,
headers
[
i
].
bytes
,
headers
[
i
].
packet
))
{
{
*
i_extra
=
0
;
*
i_extra
=
0
;
*
p_extra
=
NULL
;
*
p_extra
=
NULL
;
}
}
}
return
0
;
return
0
;
}
}
...
...
modules/codec/opus_header.h
View file @
313e7a26
...
@@ -28,14 +28,13 @@
...
@@ -28,14 +28,13 @@
#ifndef OPUS_HEADER_H
#ifndef OPUS_HEADER_H
#define OPUS_HEADER_H
#define OPUS_HEADER_H
#include <ogg/ogg.h>
#include <stdint.h>
#include <stdint.h>
typedef
struct
{
typedef
struct
{
int
version
;
int
version
;
int
channels
;
/* Number of channels: 1..255 */
int
channels
;
/* Number of channels: 1..255 */
int
preskip
;
int
preskip
;
ogg_
uint32_t
input_sample_rate
;
uint32_t
input_sample_rate
;
int
gain
;
/* in dB S7.8 should be zero whenever possible */
int
gain
;
/* in dB S7.8 should be zero whenever possible */
int
channel_mapping
;
int
channel_mapping
;
/* The rest is only used if channel_mapping != 0 */
/* The rest is only used if channel_mapping != 0 */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment