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
20806c73
Commit
20806c73
authored
Jun 07, 2005
by
Mike McCormack
Committed by
Alexandre Julliard
Jun 07, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use MSI_RecordGetString where possible.
parent
b64186ad
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
43 additions
and
77 deletions
+43
-77
action.c
dlls/msi/action.c
+43
-77
No files found.
dlls/msi/action.c
View file @
20806c73
...
@@ -787,7 +787,7 @@ static void ui_actionstart(MSIPACKAGE *package, LPCWSTR action)
...
@@ -787,7 +787,7 @@ static void ui_actionstart(MSIPACKAGE *package, LPCWSTR action)
WCHAR
message
[
1024
];
WCHAR
message
[
1024
];
WCHAR
timet
[
0x100
];
WCHAR
timet
[
0x100
];
MSIRECORD
*
row
=
0
;
MSIRECORD
*
row
=
0
;
WCHAR
*
ActionText
=
NULL
;
LPCWSTR
ActionText
;
GetTimeFormatW
(
LOCALE_USER_DEFAULT
,
0
,
NULL
,
format
,
timet
,
0x100
);
GetTimeFormatW
(
LOCALE_USER_DEFAULT
,
0
,
NULL
,
format
,
timet
,
0x100
);
...
@@ -795,17 +795,16 @@ static void ui_actionstart(MSIPACKAGE *package, LPCWSTR action)
...
@@ -795,17 +795,16 @@ static void ui_actionstart(MSIPACKAGE *package, LPCWSTR action)
if
(
!
row
)
if
(
!
row
)
return
;
return
;
ActionText
=
load_dynamic_stringW
(
row
,
2
);
ActionText
=
MSI_RecordGetString
(
row
,
2
);
msiobj_release
(
&
row
->
hdr
);
sprintfW
(
message
,
template_s
,
timet
,
action
,
ActionText
);
sprintfW
(
message
,
template_s
,
timet
,
action
,
ActionText
);
msiobj_release
(
&
row
->
hdr
);
row
=
MSI_CreateRecord
(
1
);
row
=
MSI_CreateRecord
(
1
);
MSI_RecordSetStringW
(
row
,
1
,
message
);
MSI_RecordSetStringW
(
row
,
1
,
message
);
MSI_ProcessMessage
(
package
,
INSTALLMESSAGE_ACTIONSTART
,
row
);
MSI_ProcessMessage
(
package
,
INSTALLMESSAGE_ACTIONSTART
,
row
);
msiobj_release
(
&
row
->
hdr
);
msiobj_release
(
&
row
->
hdr
);
HeapFree
(
GetProcessHeap
(),
0
,
ActionText
);
}
}
static
void
ui_actioninfo
(
MSIPACKAGE
*
package
,
LPCWSTR
action
,
BOOL
start
,
static
void
ui_actioninfo
(
MSIPACKAGE
*
package
,
LPCWSTR
action
,
BOOL
start
,
...
@@ -1062,8 +1061,6 @@ UINT ACTION_DoTopLevelINSTALL(MSIPACKAGE *package, LPCWSTR szPackagePath,
...
@@ -1062,8 +1061,6 @@ UINT ACTION_DoTopLevelINSTALL(MSIPACKAGE *package, LPCWSTR szPackagePath,
static
UINT
ACTION_PerformActionSequence
(
MSIPACKAGE
*
package
,
UINT
seq
,
BOOL
UI
)
static
UINT
ACTION_PerformActionSequence
(
MSIPACKAGE
*
package
,
UINT
seq
,
BOOL
UI
)
{
{
UINT
rc
=
ERROR_SUCCESS
;
UINT
rc
=
ERROR_SUCCESS
;
WCHAR
buffer
[
0x100
];
DWORD
sz
=
0x100
;
MSIRECORD
*
row
=
0
;
MSIRECORD
*
row
=
0
;
static
const
WCHAR
ExecSeqQuery
[]
=
static
const
WCHAR
ExecSeqQuery
[]
=
{
'S'
,
'E'
,
'L'
,
'E'
,
'C'
,
'T'
,
' '
,
'*'
,
' '
,
'F'
,
'R'
,
'O'
,
'M'
,
' '
,
{
'S'
,
'E'
,
'L'
,
'E'
,
'C'
,
'T'
,
' '
,
'*'
,
' '
,
'F'
,
'R'
,
'O'
,
'M'
,
' '
,
...
@@ -1084,40 +1081,31 @@ static UINT ACTION_PerformActionSequence(MSIPACKAGE *package, UINT seq, BOOL UI)
...
@@ -1084,40 +1081,31 @@ static UINT ACTION_PerformActionSequence(MSIPACKAGE *package, UINT seq, BOOL UI)
if
(
row
)
if
(
row
)
{
{
LPCWSTR
action
,
cond
;
TRACE
(
"Running the actions
\n
"
);
TRACE
(
"Running the actions
\n
"
);
/* check conditions */
/* check conditions */
if
(
!
MSI_RecordIsNull
(
row
,
2
))
cond
=
MSI_RecordGetString
(
row
,
2
);
if
(
cond
)
{
{
LPWSTR
cond
=
NULL
;
/* this is a hack to skip errors in the condition code */
cond
=
load_dynamic_stringW
(
row
,
2
);
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
MSICONDITION_FALSE
)
goto
end
;
if
(
cond
)
{
/* this is a hack to skip errors in the condition code */
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
MSICONDITION_FALSE
)
{
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
goto
end
;
}
else
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
}
}
}
sz
=
0x100
;
action
=
MSI_RecordGetString
(
row
,
1
);
rc
=
MSI_RecordGetStringW
(
row
,
1
,
buffer
,
&
sz
);
if
(
!
action
)
if
(
rc
!=
ERROR_SUCCESS
)
{
{
ERR
(
"
Error is %x
\n
"
,
rc
);
ERR
(
"
failed to fetch action
\n
"
);
msiobj_release
(
&
row
->
hdr
)
;
rc
=
ERROR_FUNCTION_FAILED
;
goto
end
;
goto
end
;
}
}
if
(
UI
)
if
(
UI
)
rc
=
ACTION_PerformUIAction
(
package
,
buffer
);
rc
=
ACTION_PerformUIAction
(
package
,
action
);
else
else
rc
=
ACTION_PerformAction
(
package
,
buffer
,
FALSE
);
rc
=
ACTION_PerformAction
(
package
,
action
,
FALSE
);
end:
end:
msiobj_release
(
&
row
->
hdr
);
msiobj_release
(
&
row
->
hdr
);
}
}
...
@@ -1183,8 +1171,7 @@ static UINT ACTION_ProcessExecSequence(MSIPACKAGE *package, BOOL UIran)
...
@@ -1183,8 +1171,7 @@ static UINT ACTION_ProcessExecSequence(MSIPACKAGE *package, BOOL UIran)
while
(
1
)
while
(
1
)
{
{
WCHAR
buffer
[
0x100
];
LPCWSTR
cond
,
action
;
DWORD
sz
=
0x100
;
rc
=
MSI_ViewFetch
(
view
,
&
row
);
rc
=
MSI_ViewFetch
(
view
,
&
row
);
if
(
rc
!=
ERROR_SUCCESS
)
if
(
rc
!=
ERROR_SUCCESS
)
...
@@ -1193,39 +1180,29 @@ static UINT ACTION_ProcessExecSequence(MSIPACKAGE *package, BOOL UIran)
...
@@ -1193,39 +1180,29 @@ static UINT ACTION_ProcessExecSequence(MSIPACKAGE *package, BOOL UIran)
break
;
break
;
}
}
sz
=
0x100
;
action
=
MSI_RecordGetString
(
row
,
1
);
rc
=
MSI_RecordGetStringW
(
row
,
1
,
buffer
,
&
sz
);
if
(
!
action
)
if
(
rc
!=
ERROR_SUCCESS
)
{
{
ERR
(
"Error is %x
\n
"
,
rc
)
;
rc
=
ERROR_FUNCTION_FAILED
;
msiobj_release
(
&
row
->
hdr
);
msiobj_release
(
&
row
->
hdr
);
break
;
break
;
}
}
/* check conditions */
/* check conditions */
if
(
!
MSI_RecordIsNull
(
row
,
2
))
cond
=
MSI_RecordGetString
(
row
,
2
);
if
(
cond
)
{
{
LPWSTR
cond
=
NULL
;
/* this is a hack to skip errors in the condition code */
cond
=
load_dynamic_stringW
(
row
,
2
);
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
MSICONDITION_FALSE
)
if
(
cond
)
{
{
/* this is a hack to skip errors in the condition code */
msiobj_release
(
&
row
->
hdr
);
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
TRACE
(
"Skipping action: %s (condition is false)
\n
"
,
MSICONDITION_FALSE
)
debugstr_w
(
action
));
{
continue
;
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
msiobj_release
(
&
row
->
hdr
);
TRACE
(
"Skipping action: %s (condition is false)
\n
"
,
debugstr_w
(
buffer
));
continue
;
}
else
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
}
}
}
}
rc
=
ACTION_PerformAction
(
package
,
buffer
,
FALSE
);
rc
=
ACTION_PerformAction
(
package
,
action
,
FALSE
);
if
(
rc
==
ERROR_FUNCTION_NOT_CALLED
)
if
(
rc
==
ERROR_FUNCTION_NOT_CALLED
)
rc
=
ERROR_SUCCESS
;
rc
=
ERROR_SUCCESS
;
...
@@ -1279,8 +1256,7 @@ static UINT ACTION_ProcessUISequence(MSIPACKAGE *package)
...
@@ -1279,8 +1256,7 @@ static UINT ACTION_ProcessUISequence(MSIPACKAGE *package)
while
(
1
)
while
(
1
)
{
{
WCHAR
buffer
[
0x100
];
LPCWSTR
action
,
cond
;
DWORD
sz
=
0x100
;
MSIRECORD
*
row
=
0
;
MSIRECORD
*
row
=
0
;
rc
=
MSI_ViewFetch
(
view
,
&
row
);
rc
=
MSI_ViewFetch
(
view
,
&
row
);
...
@@ -1290,40 +1266,30 @@ static UINT ACTION_ProcessUISequence(MSIPACKAGE *package)
...
@@ -1290,40 +1266,30 @@ static UINT ACTION_ProcessUISequence(MSIPACKAGE *package)
break
;
break
;
}
}
sz
=
0x100
;
action
=
MSI_RecordGetString
(
row
,
1
);
rc
=
MSI_RecordGetStringW
(
row
,
1
,
buffer
,
&
sz
);
if
(
!
action
)
if
(
rc
!=
ERROR_SUCCESS
)
{
{
ERR
(
"Error is %x
\n
"
,
rc
);
ERR
(
"failed to fetch action
\n
"
);
rc
=
ERROR_FUNCTION_FAILED
;
msiobj_release
(
&
row
->
hdr
);
msiobj_release
(
&
row
->
hdr
);
break
;
break
;
}
}
/* check conditions */
/* check conditions */
if
(
!
MSI_RecordIsNull
(
row
,
2
))
cond
=
MSI_RecordGetString
(
row
,
2
);
if
(
cond
)
{
{
LPWSTR
cond
=
NULL
;
/* this is a hack to skip errors in the condition code */
cond
=
load_dynamic_stringW
(
row
,
2
);
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
MSICONDITION_FALSE
)
if
(
cond
)
{
{
/* this is a hack to skip errors in the condition code */
msiobj_release
(
&
row
->
hdr
);
if
(
MSI_EvaluateConditionW
(
package
,
cond
)
==
TRACE
(
"Skipping action: %s (condition is false)
\n
"
,
MSICONDITION_FALSE
)
debugstr_w
(
action
));
{
continue
;
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
msiobj_release
(
&
row
->
hdr
);
TRACE
(
"Skipping action: %s (condition is false)
\n
"
,
debugstr_w
(
buffer
));
continue
;
}
else
HeapFree
(
GetProcessHeap
(),
0
,
cond
);
}
}
}
}
rc
=
ACTION_PerformUIAction
(
package
,
buffer
);
rc
=
ACTION_PerformUIAction
(
package
,
action
);
if
(
rc
==
ERROR_FUNCTION_NOT_CALLED
)
if
(
rc
==
ERROR_FUNCTION_NOT_CALLED
)
rc
=
ERROR_SUCCESS
;
rc
=
ERROR_SUCCESS
;
...
...
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