Add support for reading multi string values to wxRegKey.

Add a wxRegKey::QueryValue() overload working with REG_MULTI_SZ values.

Closes #16653.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@78136 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2014-11-11 01:03:00 +00:00
parent 69e00f892c
commit 89738ef01f
5 changed files with 97 additions and 3 deletions

View File

@ -116,6 +116,7 @@ wxMSW:
- Implement wxListBox::EnsureVisible() (RIVDSL).
- Drastically improve efficiency of selecting all items in wxDataViewCtrl.
- Fix wxMenuEvent::GetMenu() for wxEVT_MENU_{OPEN,CLOSE} in MDI frames.
- Added support for reading multi string values to wxRegKey (Carl Godkin).
wxOSX/Cocoa:

View File

@ -205,6 +205,10 @@ public:
bool SetValue(const wxString& szValue, const wxMemoryBuffer& buf);
// return the binary value
bool QueryValue(const wxString& szValue, wxMemoryBuffer& buf) const;
// return multiple strings
bool QueryValue(const wxString& szValue,
wxArrayString& names,
wxArrayString& values) const;
// query existence of a key/value
// return true if value exists

View File

@ -355,6 +355,18 @@ public:
*/
bool QueryValue(const wxString& szValue, wxMemoryBuffer& buf) const;
/**
Retrieves a multiple string value.
The @a szValue must exist and have @c REG_MULTI_SZ type. The names and
the values of the pairs present in it are returned in the @a names and
@a value arrays, which will have the same (possible 0) size.
@since 3.1.0
*/
bool QueryValue(const wxString& szValue,
wxArrayString& names,
wxArrayString& values) const;
/**
Renames the key. Returns @true if successful.
*/

View File

@ -105,6 +105,7 @@ public:
// information
bool IsKeySelected() const;
static const char *ValueTypeName(wxRegKey::ValueType type);
private:
// structure describing a registry key/value
@ -1054,7 +1055,6 @@ bool RegTreeCtrl::TreeNode::OnExpand()
{
case wxRegKey::Type_String:
case wxRegKey::Type_Expand_String:
case wxRegKey::Type_Multi_String:
{
wxString strValue;
icon = RegImageList::TextValue;
@ -1063,6 +1063,22 @@ bool RegTreeCtrl::TreeNode::OnExpand()
}
break;
case wxRegKey::Type_Multi_String:
{
wxArrayString names, values;
m_pKey->QueryValue(str, names, values);
strItem += "(multi string) ";
for ( size_t i = 0; i < names.GetCount(); i++ )
{
if ( i > 0 )
strItem += wxT (", ");
strItem += names[i] + wxT ("=") + values[i];
}
icon = RegImageList::TextValue;
}
break;
case wxRegKey::Type_None:
// @@ handle the error...
icon = RegImageList::BinaryValue;
@ -1367,6 +1383,37 @@ void RegTreeCtrl::SetRegistryView(wxRegKey::WOW64ViewMode viewMode)
m_pRoot->Refresh();
}
const char *RegTreeCtrl::ValueTypeName(wxRegKey::ValueType type)
{
switch ( type )
{
case wxRegKey::Type_None:
return "none";
case wxRegKey::Type_String:
return "string";
case wxRegKey::Type_Expand_String:
return "expand_string";
case wxRegKey::Type_Binary:
return "binary";
case wxRegKey::Type_Dword:
return "number";
case wxRegKey::Type_Dword_big_endian:
return "big endian number";
case wxRegKey::Type_Link:
return "symbolic link";
case wxRegKey::Type_Multi_String:
return "multiple strings";
case wxRegKey::Type_Resource_list:
return "resource list in the resource map";
case wxRegKey::Type_Full_resource_descriptor:
return "resource list in the hardware description";
case wxRegKey::Type_Resource_requirements_list:
return "resource requirements list";
default:
return "unrecognized";
}
}
void RegTreeCtrl::ShowProperties()
{
wxTreeItemId lCurrent = GetSelection();
@ -1405,8 +1452,7 @@ void RegTreeCtrl::ShowProperties()
value,
parent->m_strName.c_str(),
key.GetValueType(value),
key.IsNumericValue(value) ? wxT("numeric") : wxT("string"));
ValueTypeName(key.GetValueType (value)));
}
}

View File

@ -970,7 +970,38 @@ bool wxRegKey::QueryValue(const wxString& szValue, wxMemoryBuffer& buffer) const
return false;
}
bool wxRegKey::QueryValue(const wxString& szValue, wxArrayString &names,
wxArrayString &values) const
{
// Make sure value is a multistring.
wxASSERT_MSG(GetValueType (szValue) == Type_Multi_String,
wxT("Type mismatch in wxRegKey::QueryValue()."));
wxMemoryBuffer buf;
if ( !QueryValue (szValue, buf) )
return false;
wxChar * const data = static_cast<wxChar *>(buf.GetData());
// Parse the list of NUL-separated strings of the form "name=value".
size_t begin = 0;
for ( size_t i = 0; i < buf.GetDataLen() - 1; i++ )
{
if ( data[i] == 0 )
{
if ( i > begin )
{
wxString value;
names.Add(wxString(&data[begin]).BeforeFirst('=', &value));
values.Add(value);
}
begin = i + 1;
}
}
return true;
}
bool wxRegKey::QueryValue(const wxString& szValue,
wxString& strValue,