Commit 9024a88d authored by James Hawkins's avatar James Hawkins Committed by Alexandre Julliard

msi: Make msi_dialog_dup_property return a copy of the property if the property is empty.

parent 1a922b6a
...@@ -217,13 +217,18 @@ static LPWSTR msi_get_deformatted_field( MSIPACKAGE *package, MSIRECORD *rec, in ...@@ -217,13 +217,18 @@ static LPWSTR msi_get_deformatted_field( MSIPACKAGE *package, MSIRECORD *rec, in
static LPWSTR msi_dialog_dup_property( msi_dialog *dialog, LPCWSTR property, BOOL indirect ) static LPWSTR msi_dialog_dup_property( msi_dialog *dialog, LPCWSTR property, BOOL indirect )
{ {
LPWSTR prop = NULL;
if (!property) if (!property)
return NULL; return NULL;
if (indirect) if (indirect)
return msi_dup_property( dialog->package, property ); prop = msi_dup_property( dialog->package, property );
if (!prop)
prop = strdupW( property );
return strdupW( property ); return prop;
} }
msi_dialog *msi_dialog_get_parent( msi_dialog *dialog ) msi_dialog *msi_dialog_get_parent( msi_dialog *dialog )
...@@ -1469,10 +1474,7 @@ static void msi_dialog_update_pathedit( msi_dialog *dialog, msi_control *control ...@@ -1469,10 +1474,7 @@ static void msi_dialog_update_pathedit( msi_dialog *dialog, msi_control *control
indirect = control->attributes & msidbControlAttributesIndirect; indirect = control->attributes & msidbControlAttributesIndirect;
prop = msi_dialog_dup_property( dialog, control->property, indirect ); prop = msi_dialog_dup_property( dialog, control->property, indirect );
path = msi_dialog_dup_property( dialog, prop, TRUE );
path = msi_dup_property( dialog->package, prop );
if (!path)
path = prop;
SetWindowTextW( control->hwnd, path ); SetWindowTextW( control->hwnd, path );
SendMessageW( control->hwnd, EM_SETSEL, 0, -1 ); SendMessageW( control->hwnd, EM_SETSEL, 0, -1 );
...@@ -2171,10 +2173,7 @@ static void msi_dialog_update_directory_combo( msi_dialog *dialog, msi_control * ...@@ -2171,10 +2173,7 @@ static void msi_dialog_update_directory_combo( msi_dialog *dialog, msi_control *
indirect = control->attributes & msidbControlAttributesIndirect; indirect = control->attributes & msidbControlAttributesIndirect;
prop = msi_dialog_dup_property( dialog, control->property, indirect ); prop = msi_dialog_dup_property( dialog, control->property, indirect );
path = msi_dialog_dup_property( dialog, prop, TRUE );
path = msi_dup_property( dialog->package, prop );
if (!path)
path = prop;
PathStripPathW( path ); PathStripPathW( path );
PathRemoveBackslashW( path ); PathRemoveBackslashW( path );
...@@ -2231,10 +2230,7 @@ static void msi_dialog_update_directory_list( msi_dialog *dialog, msi_control *c ...@@ -2231,10 +2230,7 @@ static void msi_dialog_update_directory_list( msi_dialog *dialog, msi_control *c
indirect = control->attributes & msidbControlAttributesIndirect; indirect = control->attributes & msidbControlAttributesIndirect;
prop = msi_dialog_dup_property( dialog, control->property, indirect ); prop = msi_dialog_dup_property( dialog, control->property, indirect );
path = msi_dialog_dup_property( dialog, prop, TRUE );
path = msi_dup_property( dialog->package, prop );
if (!path)
path = prop;
lstrcpyW( dir_spec, path ); lstrcpyW( dir_spec, path );
lstrcatW( dir_spec, asterisk ); lstrcatW( dir_spec, asterisk );
...@@ -2274,10 +2270,7 @@ UINT msi_dialog_directorylist_up( msi_dialog *dialog ) ...@@ -2274,10 +2270,7 @@ UINT msi_dialog_directorylist_up( msi_dialog *dialog )
control = msi_dialog_find_control_by_type( dialog, szDirectoryList ); control = msi_dialog_find_control_by_type( dialog, szDirectoryList );
indirect = control->attributes & msidbControlAttributesIndirect; indirect = control->attributes & msidbControlAttributesIndirect;
prop = msi_dialog_dup_property( dialog, control->property, indirect ); prop = msi_dialog_dup_property( dialog, control->property, indirect );
path = msi_dialog_dup_property( dialog, prop, TRUE );
path = msi_dup_property( dialog->package, prop );
if (!path)
path = prop;
/* strip off the last directory */ /* strip off the last directory */
ptr = PathFindFileNameW( path ); ptr = PathFindFileNameW( path );
...@@ -2326,10 +2319,7 @@ static UINT msi_dialog_dirlist_handler( msi_dialog *dialog, ...@@ -2326,10 +2319,7 @@ static UINT msi_dialog_dirlist_handler( msi_dialog *dialog,
indirect = control->attributes & msidbControlAttributesIndirect; indirect = control->attributes & msidbControlAttributesIndirect;
prop = msi_dialog_dup_property( dialog, control->property, indirect ); prop = msi_dialog_dup_property( dialog, control->property, indirect );
path = msi_dialog_dup_property( dialog, prop, TRUE );
path = msi_dup_property( dialog->package, prop );
if (!path)
path = prop;
lstrcpyW( new_path, path ); lstrcpyW( new_path, path );
lstrcatW( new_path, text ); lstrcatW( new_path, text );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment