65 m_errorGrid( nullptr ),
69 m_heightBeforeHelp( 400 )
79 wxGridCellAttr* attr =
new wxGridCellAttr;
87 [
this]( wxCommandEvent& aEvent )
92 m_EnvVars->SetSelectionMode( wxGrid::wxGridSelectionModes::wxGridSelectRows );
98 m_EnvVars->Connect( wxEVT_GRID_CELL_CHANGING,
109 GetSizer()->SetSizeHints(
this );
119 m_EnvVars->Disconnect( wxEVT_GRID_CELL_CHANGING,
127 if( !wxDialog::TransferDataToWindow() )
132 for(
auto it = envVars.begin(); it != envVars.end(); ++it )
134 const wxString&
path = it->second.GetValue();
137 if(
m_curdir.IsEmpty() && !
path.StartsWith(
"${" ) && !
path.StartsWith(
"$(" ) )
157 nameCellAttr->SetEditor( nameTextEditor );
159 nameCellAttr->DecRef();
164 wxSystemColour c = isExternal ? wxSYS_COLOUR_MENU : wxSYS_COLOUR_LISTBOX;
165 pathCellAttr->SetBackgroundColour( wxSystemSettings::GetColour( c ) );
166 pathCellAttr->DecRef();
177 if( !wxDialog::TransferDataFromWindow() )
183 for(
int row = 0; row <
m_EnvVars->GetNumberRows(); ++row )
193 else if(
name.empty() &&
path.empty() )
198 else if(
name.IsEmpty() )
203 m_errorMsg =
_(
"Environment variable name cannot be empty." );
206 else if(
path.IsEmpty() )
211 m_errorMsg =
_(
"Environment variable path cannot be empty." );
215 if( envVarMap.count(
name ) )
216 envVarMap.at(
name ).SetValue(
path );
222 for(
auto it = envVarMap.begin(); it != envVarMap.end(); )
226 for(
int row = 0; row <
m_EnvVars->GetNumberRows(); ++row )
230 if( it->first ==
name )
240 it = envVarMap.erase( it );
251 wxGrid*
grid =
dynamic_cast<wxGrid*
>(
event.GetEventObject() );
252 int row =
event.GetRow();
253 int col =
event.GetCol();
254 wxString
text =
event.GetString();
261 m_errorMsg =
_(
"Environment variable name cannot be empty." );
263 m_errorMsg =
_(
"Environment variable path cannot be empty." );
268 m_errorMsg =
_(
"3D search path alias cannot be empty." );
270 m_errorMsg =
_(
"3D search path cannot be empty." );
273 m_errorGrid =
dynamic_cast<wxGrid*
>(
event.GetEventObject() );
285 wxString msg1 =
_(
"This path was defined externally to the running process and\n"
286 "will only be temporarily overwritten." );
287 wxString msg2 =
_(
"The next time KiCad is launched, any paths that have already\n"
288 "been defined are honored and any settings defined in the path\n"
289 "configuration dialog are ignored. If you did not intend for\n"
290 "this behavior, either rename any conflicting entries or remove\n"
291 "the external environment variable(s) from your system." );
293 dlg.ShowDetailedText( msg2 );
305 wxMessageBox( wxString::Format(
_(
"The name %s is reserved, and cannot be used." ),
328 m_EnvVars->EnableCellEditControl(
true );
335 int curRow =
m_EnvVars->GetGridCursorRow();
337 if( curRow < 0 || m_EnvVars->GetNumberRows() <= curRow )
372 grid->EnableCellEditControl(
true );
373 grid->ShowCellEditControl();
380 wxSizer* sizerMain = GetSizer();
385 wxHW_SCROLLBAR_AUTO );
387 wxString msg =
_(
"Enter the name and value for each environment variable. Grey entries "
388 "are names that have been defined externally at the system or user "
389 "level. Environment variables defined at the system or user level "
390 "take precedence over the ones defined in this table. This means the "
391 "values in this table are ignored." );
392 msg <<
"<br><br><b>";
393 msg <<
_(
"To ensure environment variable names are valid on all platforms, the name field "
394 "will only accept upper case letters, digits, and the underscore characters." );
399 msg <<
"<br><br><b>" << var <<
"</b>";
403 if( desc.size() > 0 )
411 sizerMain->Insert( sizerMain->GetItemCount() - 1,
m_helpBox, 1, wxALL|wxEXPAND, 10 );
424 int minHelpBoxHeight = GetTextExtent( wxT(
"T" ) ).y * 20;
426 if( GetClientSize().y < minHelpBoxHeight * 2 )
427 SetClientSize( wxSize( GetClientSize().x, GetClientSize().y + minHelpBoxHeight ) );
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap)
DO_NOT_SHOW_AGAIN m_DoNotShowAgain
void SetInitialFocus(wxWindow *aWindow)
Sets the window (usually a wxTextCtrl) that should be focused when the dialog is shown.
void SetupStandardButtons(std::map< int, wxString > aLabels={})
KiCad uses environment variables internally for determining the base paths for libraries,...
Provide a custom wxValidator object for limiting the allowable characters when defining an environmen...
Editor for wxGrid cells that adds a file/folder browser to the grid input field.
This class works around a bug in wxGrid where the first keystroke doesn't get sent through the valida...
Add mouse and command handling (such as cut, copy, and paste) to a WX_GRID instance.
Add dark theme support to wxHtmlWindow.
bool SetPage(const wxString &aSource) override
Helper class to create more flexible dialogs, including 'do not show again' checkbox handling.
bool DoNotShowAgain() const
Checks the 'do not show again' setting for the dialog.
void DoNotShowCheckbox(wxString file, int line)
Shows the 'do not show again' checkbox.
virtual COMMON_SETTINGS * GetCommonSettings() const
virtual ENV_VAR_MAP & GetLocalEnvVariables() const
virtual void SetLocalEnvVariables()
Update the local environment with the contents of the current ENV_VAR_MAP stored in the COMMON_SETTIN...
std::map< int, int > COL_MIN_WIDTHS
Map of column indices to minimum widths.
void ClearRows()
wxWidgets recently added an ASSERT which fires if the position is greater than or equal to the number...
bool CommitPendingChanges(bool aQuietMode=false)
Close any open cell edit controls.
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
Functions related to environment variables, including help functions.
std::map< wxString, ENV_VAR_ITEM > ENV_VAR_MAP
This file is part of the common library.
KICOMMON_API wxString LookUpEnvVarHelp(const wxString &aEnvVar)
Look up long-form help text for a given environment variable.
KICOMMON_API const ENV_VAR_LIST & GetPredefinedEnvVars()
Get the list of pre-defined environment variables.
KICOMMON_API bool IsEnvVarImmutable(const wxString &aEnvVar)
Determine if an environment variable is "predefined", i.e.
PGM_BASE & Pgm()
The global program "get" accessor.
#define PROJECT_VAR_NAME
A variable name whose value holds the current project directory.
bool env_var_overwrite_warning
Custom text control validator definitions.