Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-gpu
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-gpu
Commits
8693bcb2
Commit
8693bcb2
authored
Sep 25, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Simplify parsing of title/chapter in MRL
parent
453764f6
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
72 deletions
+45
-72
src/input/input.c
src/input/input.c
+45
-72
No files found.
src/input/input.c
View file @
8693bcb2
...
@@ -85,7 +85,7 @@ static void UpdateGenericFromAccess( input_thread_t * );
...
@@ -85,7 +85,7 @@ static void UpdateGenericFromAccess( input_thread_t * );
static
int
UpdateTitleSeekpointFromDemux
(
input_thread_t
*
);
static
int
UpdateTitleSeekpointFromDemux
(
input_thread_t
*
);
static
void
UpdateGenericFromDemux
(
input_thread_t
*
);
static
void
UpdateGenericFromDemux
(
input_thread_t
*
);
static
void
MRLSections
(
input_thread_t
*
,
char
*
,
int
*
,
int
*
,
int
*
,
int
*
);
static
void
MRLSections
(
char
*
,
int
*
,
int
*
,
int
*
,
int
*
);
static
input_source_t
*
InputSourceNew
(
input_thread_t
*
);
static
input_source_t
*
InputSourceNew
(
input_thread_t
*
);
static
int
InputSourceInit
(
input_thread_t
*
,
input_source_t
*
,
static
int
InputSourceInit
(
input_thread_t
*
,
input_source_t
*
,
...
@@ -2381,7 +2381,7 @@ static int InputSourceInit( input_thread_t *p_input,
...
@@ -2381,7 +2381,7 @@ static int InputSourceInit( input_thread_t *p_input,
strncmp
(
psz_access
,
"rtp"
,
3
))
)
strncmp
(
psz_access
,
"rtp"
,
3
))
)
{
{
/* Find optional titles and seekpoints */
/* Find optional titles and seekpoints */
MRLSections
(
p
_input
,
p
sz_path
,
&
in
->
i_title_start
,
&
in
->
i_title_end
,
MRLSections
(
psz_path
,
&
in
->
i_title_start
,
&
in
->
i_title_end
,
&
in
->
i_seekpoint_start
,
&
in
->
i_seekpoint_end
);
&
in
->
i_seekpoint_start
,
&
in
->
i_seekpoint_end
);
}
}
...
@@ -3080,96 +3080,69 @@ void input_SplitMRL( const char **ppsz_access, const char **ppsz_demux,
...
@@ -3080,96 +3080,69 @@ void input_SplitMRL( const char **ppsz_access, const char **ppsz_demux,
*
ppsz_access
=
p
;
*
ppsz_access
=
p
;
}
}
static
inline
bool
next
(
char
**
src
)
static
const
char
*
MRLSeekPoint
(
const
char
*
str
,
int
*
title
,
int
*
chapter
)
{
{
char
*
end
;
char
*
end
;
errno
=
0
;
unsigned
long
u
;
long
result
=
strtol
(
*
src
,
&
end
,
0
);
if
(
errno
!=
0
||
result
>=
LONG_MAX
||
result
<=
LONG_MIN
||
/* Look for the title */
end
==
*
src
)
u
=
strtoul
(
str
,
&
end
,
0
);
*
title
=
(
str
==
end
||
u
>
(
unsigned
long
)
INT_MAX
)
?
-
1
:
(
int
)
u
;
str
=
end
;
/* Look for the chapter */
if
(
*
str
==
':'
)
{
{
return
false
;
str
++
;
u
=
strtoul
(
str
,
&
end
,
0
);
*
chapter
=
(
str
==
end
||
u
>
(
unsigned
long
)
INT_MAX
)
?
-
1
:
(
int
)
u
;
str
=
end
;
}
}
*
src
=
end
;
else
return
true
;
*
chapter
=
-
1
;
return
str
;
}
}
/*****************************************************************************
/*****************************************************************************
* MRLSections: parse title and seekpoint info from the Media Resource Locator.
* MRLSections: parse title and seekpoint info from the Media Resource Locator.
*
*
* Syntax:
* Syntax:
* [url][@[title
-start][:chapter-start][-[title-end][:chapter-
end]]]
* [url][@[title
_start][:chapter_start][-[title_end][:chapter_
end]]]
*****************************************************************************/
*****************************************************************************/
static
void
MRLSections
(
input_thread_t
*
p_input
,
char
*
psz_source
,
static
void
MRLSections
(
char
*
psz_source
,
int
*
pi_title_start
,
int
*
pi_title_end
,
int
*
pi_title_start
,
int
*
pi_title_end
,
int
*
pi_chapter_start
,
int
*
pi_chapter_end
)
int
*
pi_chapter_start
,
int
*
pi_chapter_end
)
{
{
char
*
psz
,
*
psz_end
,
*
psz_next
,
*
psz_check
;
*
pi_title_start
=
*
pi_title_end
=
*
pi_chapter_start
=
*
pi_chapter_end
=
-
1
;
*
pi_title_start
=
*
pi_title_end
=
-
1
;
*
pi_chapter_start
=
*
pi_chapter_end
=
-
1
;
/* Start by parsing titles and chapters */
/* Start by parsing titles and chapters */
if
(
!
psz_source
||
!
(
psz
=
strrchr
(
psz_source
,
'@'
)
)
)
return
;
char
*
psz
=
strrchr
(
psz_source
,
'@'
);
if
(
psz
==
NULL
)
return
;
/* Check we are really dealing with a title/chapter section */
psz_check
=
psz
+
1
;
if
(
!*
psz_check
)
return
;
if
(
isdigit
((
unsigned
char
)
*
psz_check
)
)
if
(
!
next
(
&
psz_check
))
return
;
if
(
*
psz_check
!=
':'
&&
*
psz_check
!=
'-'
&&
*
psz_check
)
return
;
if
(
*
psz_check
==
':'
&&
++
psz_check
)
{
if
(
isdigit
((
unsigned
char
)
*
psz_check
)
)
if
(
!
next
(
&
psz_check
))
return
;
}
if
(
*
psz_check
!=
'-'
&&
*
psz_check
)
return
;
if
(
*
psz_check
==
'-'
&&
++
psz_check
)
{
if
(
isdigit
((
unsigned
char
)
*
psz_check
)
)
if
(
!
next
(
&
psz_check
))
return
;
}
if
(
*
psz_check
!=
':'
&&
*
psz_check
)
return
;
if
(
*
psz_check
==
':'
&&
++
psz_check
)
{
if
(
isdigit
((
unsigned
char
)
*
psz_check
)
)
if
(
!
next
(
&
psz_check
))
return
;
}
if
(
*
psz_check
)
return
;
/* Separate start and end */
*
psz
++
=
0
;
if
(
(
psz_end
=
strchr
(
psz
,
'-'
)
)
)
*
psz_end
++
=
0
;
/* Look for the start title */
const
char
*
p
=
psz
+
1
;
*
pi_title_start
=
strtol
(
psz
,
&
psz_next
,
0
);
int
title_start
,
chapter_start
,
title_end
,
chapter_end
;
if
(
!*
pi_title_start
&&
psz
==
psz_next
)
*
pi_title_start
=
-
1
;
*
pi_title_end
=
*
pi_title_start
;
psz
=
psz_next
;
/* Look for the start chapter */
if
(
*
p
!=
'-'
)
if
(
*
psz
)
psz
++
;
p
=
MRLSeekPoint
(
p
,
&
title_start
,
&
chapter_start
);
*
pi_chapter_start
=
strtol
(
psz
,
&
psz_next
,
0
);
else
if
(
!*
pi_chapter_start
&&
psz
==
psz_next
)
*
pi_chapter_start
=
-
1
;
title_start
=
chapter_start
=
-
1
;
*
pi_chapter_end
=
*
pi_chapter_start
;
if
(
psz_end
)
if
(
*
p
==
'-'
)
{
p
=
MRLSeekPoint
(
p
+
1
,
&
title_end
,
&
chapter_end
);
/* Look for the end title */
else
*
pi_title_end
=
strtol
(
psz_end
,
&
psz_next
,
0
);
title_end
=
chapter_end
=
-
1
;
if
(
!*
pi_title_end
&&
psz_end
==
psz_next
)
*
pi_title_end
=
-
1
;
psz_end
=
psz_next
;
/* Look for the end chapter */
if
(
*
p
)
/* syntax error */
if
(
*
psz_end
)
psz_end
++
;
return
;
*
pi_chapter_end
=
strtol
(
psz_end
,
&
psz_next
,
0
);
if
(
!*
pi_chapter_end
&&
psz_end
==
psz_next
)
*
pi_chapter_end
=
-
1
;
}
msg_Dbg
(
p_input
,
"source=`%s' title=%d/%d seekpoint=%d/%d"
,
*
pi_title_start
=
title_start
;
psz_source
,
*
pi_title_start
,
*
pi_chapter_start
,
*
pi_title_end
=
title_end
;
*
pi_title_end
,
*
pi_chapter_end
);
*
pi_chapter_start
=
chapter_start
;
*
pi_chapter_end
=
chapter_end
;
*
psz
=
'\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