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
ad6f9674
Commit
ad6f9674
authored
Feb 13, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Store mapping for global hotkeys as well as normal ones
parent
6c46174d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
58 additions
and
39 deletions
+58
-39
src/config/keys.c
src/config/keys.c
+58
-39
No files found.
src/config/keys.c
View file @
ad6f9674
...
@@ -358,23 +358,61 @@ static int keycmp (const void *a, const void *b)
...
@@ -358,23 +358,61 @@ static int keycmp (const void *a, const void *b)
struct
vlc_actions
struct
vlc_actions
{
{
void
*
map
;
/* Key map */
void
*
map
;
/* Key map */
void
*
global_map
;
/* Grabbed/global key map */
struct
hotkey
keys
[
0
];
struct
hotkey
keys
[
0
];
};
};
static
int
vlc_key_to_action
(
vlc_object_t
*
libvlc
,
const
char
*
varname
,
static
int
vlc_key_to_action
(
vlc_object_t
*
obj
,
const
char
*
varname
,
vlc_value_t
prevkey
,
vlc_value_t
curkey
,
void
*
d
)
vlc_value_t
prevkey
,
vlc_value_t
curkey
,
void
*
d
)
{
{
const
struct
vlc_actions
*
as
=
d
;
void
*
const
*
map
=
d
;
const
struct
mapping
**
pent
;
const
struct
mapping
**
pent
;
uint32_t
keycode
=
curkey
.
i_int
;
uint32_t
keycode
=
curkey
.
i_int
;
pent
=
tfind
(
&
keycode
,
&
as
->
map
,
keycmp
);
pent
=
tfind
(
&
keycode
,
map
,
keycmp
);
if
(
pent
==
NULL
)
if
(
pent
==
NULL
)
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
(
void
)
varname
;
(
void
)
varname
;
(
void
)
prevkey
;
(
void
)
prevkey
;
return
var_SetInteger
(
libvlc
,
"key-action"
,
(
*
pent
)
->
action
);
return
var_SetInteger
(
obj
,
"key-action"
,
(
*
pent
)
->
action
);
}
static
void
vlc_MapAction
(
vlc_object_t
*
obj
,
void
**
map
,
const
char
*
confname
,
vlc_key_t
action
)
{
char
*
keys
=
var_InheritString
(
obj
,
confname
);
if
(
keys
==
NULL
)
return
;
for
(
char
*
buf
,
*
key
=
strtok_r
(
keys
,
"
\t
"
,
&
buf
);
key
!=
NULL
;
key
=
strtok_r
(
NULL
,
"
\t
"
,
&
buf
))
{
uint32_t
code
=
vlc_str2keycode
(
key
);
if
(
code
==
KEY_UNSET
)
{
msg_Warn
(
obj
,
"Key
\"
%s
\"
unrecognized"
,
key
);
continue
;
}
struct
mapping
*
entry
=
malloc
(
sizeof
(
*
entry
));
if
(
entry
==
NULL
)
continue
;
entry
->
key
=
code
;
entry
->
action
=
action
;
struct
mapping
**
pent
=
tsearch
(
entry
,
map
,
keycmp
);
if
(
unlikely
(
pent
==
NULL
))
continue
;
if
(
*
pent
!=
entry
)
{
free
(
entry
);
msg_Warn
(
obj
,
"Key
\"
%s
\"
bound to multiple actions"
,
key
);
}
}
free
(
keys
);
}
}
...
@@ -390,10 +428,12 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
...
@@ -390,10 +428,12 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
if
(
unlikely
(
as
==
NULL
))
if
(
unlikely
(
as
==
NULL
))
return
NULL
;
return
NULL
;
as
->
map
=
NULL
;
as
->
map
=
NULL
;
as
->
global_map
=
NULL
;
keys
=
as
->
keys
;
keys
=
as
->
keys
;
var_Create
(
libvlc
,
"key-pressed"
,
VLC_VAR_INTEGER
);
var_Create
(
obj
,
"key-pressed"
,
VLC_VAR_INTEGER
);
var_Create
(
libvlc
,
"key-action"
,
VLC_VAR_INTEGER
);
var_Create
(
obj
,
"global-key-pressed"
,
VLC_VAR_INTEGER
);
var_Create
(
obj
,
"key-action"
,
VLC_VAR_INTEGER
);
/* Initialize from configuration */
/* Initialize from configuration */
for
(
size_t
i
=
0
;
i
<
ACTIONS_COUNT
;
i
++
)
for
(
size_t
i
=
0
;
i
<
ACTIONS_COUNT
;
i
++
)
...
@@ -411,45 +451,20 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
...
@@ -411,45 +451,20 @@ struct vlc_actions *vlc_InitActions (libvlc_int_t *libvlc)
keys
->
i_action
=
actions
[
i
].
value
;
keys
->
i_action
=
actions
[
i
].
value
;
keys
++
;
keys
++
;
char
*
str
=
var_InheritString
(
obj
,
actions
[
i
].
name
);
char
name
[
32
];
if
(
str
==
NULL
)
continue
;
for
(
char
*
buf
,
*
key
=
strtok_r
(
str
,
"
\t
"
,
&
buf
);
snprintf
(
name
,
sizeof
(
name
),
"global-%s"
,
actions
[
i
].
name
);
key
!=
NULL
;
vlc_MapAction
(
obj
,
&
as
->
map
,
name
+
7
,
actions
[
i
].
value
);
key
=
strtok_r
(
NULL
,
"
\t
"
,
&
buf
))
vlc_MapAction
(
obj
,
&
as
->
global_map
,
name
,
actions
[
i
].
value
);
{
uint32_t
code
=
vlc_str2keycode
(
key
);
if
(
code
==
KEY_UNSET
)
{
msg_Warn
(
obj
,
"Key
\"
%s
\"
unrecognized"
,
key
);
continue
;
}
struct
mapping
*
entry
=
malloc
(
sizeof
(
*
entry
));
if
(
entry
==
NULL
)
continue
;
entry
->
key
=
code
;
entry
->
action
=
actions
[
i
].
value
;
struct
mapping
**
pent
=
tsearch
(
entry
,
&
as
->
map
,
keycmp
);
if
(
unlikely
(
pent
==
NULL
))
continue
;
if
(
*
pent
!=
entry
)
{
free
(
entry
);
msg_Warn
(
obj
,
"Key
\"
%s
\"
bound to multiple actions"
,
key
);
}
}
free
(
str
);
}
}
keys
->
psz_action
=
NULL
;
keys
->
psz_action
=
NULL
;
keys
->
i_action
=
0
;
keys
->
i_action
=
0
;
libvlc
->
p_hotkeys
=
as
->
keys
;
libvlc
->
p_hotkeys
=
as
->
keys
;
var_AddCallback
(
libvlc
,
"key-pressed"
,
vlc_key_to_action
,
as
);
var_AddCallback
(
obj
,
"key-pressed"
,
vlc_key_to_action
,
&
as
->
map
);
var_AddCallback
(
obj
,
"global-key-pressed"
,
vlc_key_to_action
,
&
as
->
global_map
);
return
as
;
return
as
;
}
}
...
@@ -461,7 +476,11 @@ void vlc_DeinitActions (libvlc_int_t *libvlc, struct vlc_actions *as)
...
@@ -461,7 +476,11 @@ void vlc_DeinitActions (libvlc_int_t *libvlc, struct vlc_actions *as)
if
(
unlikely
(
as
==
NULL
))
if
(
unlikely
(
as
==
NULL
))
return
;
return
;
var_DelCallback
(
libvlc
,
"key-pressed"
,
vlc_key_to_action
,
as
);
var_DelCallback
(
libvlc
,
"global-key-pressed"
,
vlc_key_to_action
,
&
as
->
global_map
);
var_DelCallback
(
libvlc
,
"key-pressed"
,
vlc_key_to_action
,
&
as
->
map
);
tdestroy
(
as
->
global_map
,
free
);
tdestroy
(
as
->
map
,
free
);
tdestroy
(
as
->
map
,
free
);
free
(
as
);
free
(
as
);
libvlc
->
p_hotkeys
=
NULL
;
libvlc
->
p_hotkeys
=
NULL
;
...
...
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