You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
226 lines
7.0 KiB
226 lines
7.0 KiB
5 years ago
|
//========= Copyright Valve Corporation, All rights reserved. ============//
|
||
|
//
|
||
|
// Purpose:
|
||
|
//
|
||
|
// $NoKeywords: $
|
||
|
//=============================================================================
|
||
|
|
||
|
#include "VarListPropertyPage.h"
|
||
|
#include "RemoteServer.h"
|
||
|
#include "VarEditDialog.h"
|
||
|
|
||
|
#include <KeyValues.h>
|
||
|
#include <vgui/KeyCode.h>
|
||
|
|
||
|
#include <vgui_controls/ListPanel.h>
|
||
|
#include <vgui_controls/Button.h>
|
||
|
|
||
|
#include "filesystem.h"
|
||
|
|
||
|
using namespace vgui;
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Constructor
|
||
|
//-----------------------------------------------------------------------------
|
||
|
CVarListPropertyPage::CVarListPropertyPage(vgui::Panel *parent, const char *name) : vgui::PropertyPage(parent, name)
|
||
|
{
|
||
|
m_pRulesList = new ListPanel(this, "RulesList");
|
||
|
m_pRulesList->AddColumnHeader(0, "name", "Variable", 256);
|
||
|
m_pRulesList->AddColumnHeader(1, "value", "Value", 256);
|
||
|
|
||
|
m_pEditButton = new Button(this, "EditButton", "Edit...");
|
||
|
m_pEditButton->SetCommand(new KeyValues("EditVariable"));
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Destructor
|
||
|
//-----------------------------------------------------------------------------
|
||
|
CVarListPropertyPage::~CVarListPropertyPage()
|
||
|
{
|
||
|
// remove from callback list
|
||
|
RemoteServer().RemoveServerDataResponseTarget(this);
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: loads a list of variables from the file
|
||
|
//-----------------------------------------------------------------------------
|
||
|
bool CVarListPropertyPage::LoadVarList(const char *varfile)
|
||
|
{
|
||
|
bool bSuccess = false;
|
||
|
// clear the current list
|
||
|
m_pRulesList->DeleteAllItems();
|
||
|
|
||
|
// load list from file
|
||
|
KeyValues *dat = new KeyValues("VarList");
|
||
|
if (dat->LoadFromFile( g_pFullFileSystem, varfile, NULL))
|
||
|
{
|
||
|
// enter into list
|
||
|
for (KeyValues *rule = dat->GetFirstSubKey(); rule != NULL; rule = rule->GetNextKey())
|
||
|
{
|
||
|
m_pRulesList->AddItem(rule, 0, false, false);
|
||
|
}
|
||
|
bSuccess = true;
|
||
|
}
|
||
|
|
||
|
dat->deleteThis();
|
||
|
return bSuccess;
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: configures layout
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::PerformLayout()
|
||
|
{
|
||
|
BaseClass::PerformLayout();
|
||
|
OnItemSelected();
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Handles edit button press
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::EditVariable()
|
||
|
{
|
||
|
// get rule from the list
|
||
|
int itemID = m_pRulesList->GetSelectedItem(0);
|
||
|
KeyValues *rule = m_pRulesList->GetItem(itemID);
|
||
|
if (!rule)
|
||
|
return;
|
||
|
|
||
|
OnEditVariable(rule);
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Edits var
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::OnEditVariable(KeyValues *rule)
|
||
|
{
|
||
|
// open an edit box appropriate
|
||
|
CVarEditDialog *box = new CVarEditDialog(this, "VarEditDialog");
|
||
|
box->Activate(this, rule);
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: refreshes all the values of cvars in the list
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::RefreshVarList()
|
||
|
{
|
||
|
// iterate the vars
|
||
|
for (int i = 0; i < m_pRulesList->GetItemCount(); i++)
|
||
|
{
|
||
|
KeyValues *row = m_pRulesList->GetItem(i);
|
||
|
if (!row)
|
||
|
continue;
|
||
|
|
||
|
// request the info from the server on each one of them
|
||
|
RemoteServer().RequestValue(this, row->GetName());
|
||
|
}
|
||
|
|
||
|
RemoteServer().ProcessServerResponse();
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: sets the value of a variable in the list
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::SetVarString(const char *varName, const char *value)
|
||
|
{
|
||
|
// find the item by name
|
||
|
int itemID = m_pRulesList->GetItem(varName);
|
||
|
KeyValues *rule = m_pRulesList->GetItem(itemID);
|
||
|
if (!rule)
|
||
|
return;
|
||
|
|
||
|
// parse the rule
|
||
|
const char *type = rule->GetString("type");
|
||
|
if (!stricmp(type, "enumeration"))
|
||
|
{
|
||
|
// look up the value in the enumeration
|
||
|
int iValue = atoi(value);
|
||
|
const char *result = rule->FindKey("list", true)->GetString(value, "");
|
||
|
rule->SetString("value", result);
|
||
|
rule->SetInt("enum", iValue);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
// no special type, treat it as a string
|
||
|
rule->SetString("value", value);
|
||
|
}
|
||
|
|
||
|
m_pRulesList->ApplyItemChanges(itemID);
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Sets a custom string list
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::SetCustomStringList(const char *varName, const char *stringList)
|
||
|
{
|
||
|
// find the item by name
|
||
|
int itemID = m_pRulesList->GetItem(varName);
|
||
|
KeyValues *rule = m_pRulesList->GetItem(itemID);
|
||
|
if (!rule)
|
||
|
return;
|
||
|
|
||
|
rule->SetString("stringlist", stringList);
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: gets back the value of a variable
|
||
|
//-----------------------------------------------------------------------------
|
||
|
const char *CVarListPropertyPage::GetVarString(const char *varName)
|
||
|
{
|
||
|
int itemID = m_pRulesList->GetItem(varName);
|
||
|
KeyValues *rule = m_pRulesList->GetItem(itemID);
|
||
|
if (!rule)
|
||
|
return "";
|
||
|
|
||
|
return rule->GetString("value");
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Causes values to refresh on the user hitting F5
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::OnKeyCodeTyped(KeyCode code)
|
||
|
{
|
||
|
if (code == KEY_F5)
|
||
|
{
|
||
|
OnResetData();
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
BaseClass::OnKeyCodeTyped(code);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Enables the edit button if any rows in the list are selected
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::OnItemSelected()
|
||
|
{
|
||
|
if (m_pRulesList->GetSelectedItemsCount() > 0)
|
||
|
{
|
||
|
m_pEditButton->SetEnabled(true);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
m_pEditButton->SetEnabled(false);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: Called when a var gets edited
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::OnVarChanged(const char *var)
|
||
|
{
|
||
|
// request new value from server
|
||
|
RemoteServer().RequestValue(this, var);
|
||
|
// process the queue immediately, since if we're running a local server there will already be a reply
|
||
|
RemoteServer().ProcessServerResponse();
|
||
|
}
|
||
|
|
||
|
//-----------------------------------------------------------------------------
|
||
|
// Purpose: handles responses from the server
|
||
|
//-----------------------------------------------------------------------------
|
||
|
void CVarListPropertyPage::OnServerDataResponse(const char *value, const char *response)
|
||
|
{
|
||
|
SetVarString(value, response);
|
||
|
}
|