Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
2a378676
Commit
2a378676
authored
Feb 16, 2010
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
server: Save and load the registry class names to/from disk files.
parent
a504867a
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
3 deletions
+32
-3
registry.c
server/registry.c
+32
-3
No files found.
server/registry.c
View file @
2a378676
...
@@ -246,13 +246,19 @@ static void save_subkeys( const struct key *key, const struct key *base, FILE *f
...
@@ -246,13 +246,19 @@ static void save_subkeys( const struct key *key, const struct key *base, FILE *f
int
i
;
int
i
;
if
(
key
->
flags
&
KEY_VOLATILE
)
return
;
if
(
key
->
flags
&
KEY_VOLATILE
)
return
;
/* save key if it has either some values or no subkeys */
/* save key if it has either some values or no subkeys
, or needs special options
*/
/* keys with no values but subkeys are saved implicitly by saving the subkeys */
/* keys with no values but subkeys are saved implicitly by saving the subkeys */
if
((
key
->
last_value
>=
0
)
||
(
key
->
last_subkey
==
-
1
))
if
((
key
->
last_value
>=
0
)
||
(
key
->
last_subkey
==
-
1
)
||
key
->
class
)
{
{
fprintf
(
f
,
"
\n
["
);
fprintf
(
f
,
"
\n
["
);
if
(
key
!=
base
)
dump_path
(
key
,
base
,
f
);
if
(
key
!=
base
)
dump_path
(
key
,
base
,
f
);
fprintf
(
f
,
"] %u
\n
"
,
(
unsigned
int
)((
key
->
modif
-
ticks_1601_to_1970
)
/
TICKS_PER_SEC
)
);
fprintf
(
f
,
"] %u
\n
"
,
(
unsigned
int
)((
key
->
modif
-
ticks_1601_to_1970
)
/
TICKS_PER_SEC
)
);
if
(
key
->
class
)
{
fprintf
(
f
,
"#class=
\"
"
);
dump_strW
(
key
->
class
,
key
->
classlen
/
sizeof
(
WCHAR
),
f
,
"
\"\"
"
);
fprintf
(
f
,
"
\"\n
"
);
}
for
(
i
=
0
;
i
<=
key
->
last_value
;
i
++
)
dump_value
(
&
key
->
values
[
i
],
f
);
for
(
i
=
0
;
i
<=
key
->
last_value
;
i
++
)
dump_value
(
&
key
->
values
[
i
],
f
);
}
}
for
(
i
=
0
;
i
<=
key
->
last_subkey
;
i
++
)
save_subkeys
(
key
->
subkeys
[
i
],
base
,
f
);
for
(
i
=
0
;
i
<=
key
->
last_subkey
;
i
++
)
save_subkeys
(
key
->
subkeys
[
i
],
base
,
f
);
...
@@ -1224,6 +1230,27 @@ static struct key *load_key( struct key *base, const char *buffer, int flags,
...
@@ -1224,6 +1230,27 @@ static struct key *load_key( struct key *base, const char *buffer, int flags,
return
create_key
(
base
,
&
name
,
NULL
,
flags
,
0
,
0
,
modif
,
&
res
);
return
create_key
(
base
,
&
name
,
NULL
,
flags
,
0
,
0
,
modif
,
&
res
);
}
}
/* load a key option from the input file */
static
int
load_key_option
(
struct
key
*
key
,
const
char
*
buffer
,
struct
file_load_info
*
info
)
{
const
char
*
p
;
data_size_t
len
;
if
(
!
strncmp
(
buffer
,
"#class="
,
7
))
{
p
=
buffer
+
7
;
if
(
*
p
++
!=
'"'
)
return
0
;
if
(
!
get_file_tmp_space
(
info
,
strlen
(
p
)
*
sizeof
(
WCHAR
)
))
return
0
;
len
=
info
->
tmplen
;
if
(
parse_strW
(
info
->
tmp
,
&
len
,
p
,
'\"'
)
==
-
1
)
return
0
;
free
(
key
->
class
);
if
(
!
(
key
->
class
=
memdup
(
info
->
tmp
,
len
)))
len
=
0
;
key
->
classlen
=
len
;
}
/* ignore unknown options */
return
1
;
}
/* parse a comma-separated list of hex digits */
/* parse a comma-separated list of hex digits */
static
int
parse_hex
(
unsigned
char
*
dest
,
data_size_t
*
len
,
const
char
*
buffer
)
static
int
parse_hex
(
unsigned
char
*
dest
,
data_size_t
*
len
,
const
char
*
buffer
)
{
{
...
@@ -1420,7 +1447,9 @@ static void load_keys( struct key *key, const char *filename, FILE *f, int prefi
...
@@ -1420,7 +1447,9 @@ static void load_keys( struct key *key, const char *filename, FILE *f, int prefi
if
(
subkey
)
load_value
(
subkey
,
p
,
&
info
);
if
(
subkey
)
load_value
(
subkey
,
p
,
&
info
);
else
file_read_error
(
"Value without key"
,
&
info
);
else
file_read_error
(
"Value without key"
,
&
info
);
break
;
break
;
case
'#'
:
/* comment */
case
'#'
:
/* option */
if
(
subkey
)
load_key_option
(
subkey
,
p
,
&
info
);
break
;
case
';'
:
/* comment */
case
';'
:
/* comment */
case
0
:
/* empty line */
case
0
:
/* empty line */
break
;
break
;
...
...
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