diff --git a/3d-viewer/3d_cache/3d_cache.cpp b/3d-viewer/3d_cache/3d_cache.cpp index ddce2ffe23..e251136b6b 100644 --- a/3d-viewer/3d_cache/3d_cache.cpp +++ b/3d-viewer/3d_cache/3d_cache.cpp @@ -2,7 +2,7 @@ * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2015-2016 Cirilo Bernardo - * Copyright (C) 2018-2020 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2018-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -29,7 +29,6 @@ #include #include -#include #include #include @@ -55,6 +54,7 @@ #include #include #include +#include #define MASK_3D_CACHE "3D_CACHE" @@ -514,7 +514,7 @@ bool S3D_CACHE::Set3DConfigDir( const wxString& aConfigDir ) wxFileName cfgdir( ExpandEnvVarSubstitutions( aConfigDir, m_project ), wxEmptyString ); - cfgdir.Normalize(); + cfgdir.Normalize( FN_NORMALIZE_FLAGS ); if( !cfgdir.DirExists() ) { diff --git a/3d-viewer/3d_cache/3d_plugin_manager.cpp b/3d-viewer/3d_cache/3d_plugin_manager.cpp index 09f4f557a1..8aa4fe3473 100644 --- a/3d-viewer/3d_cache/3d_plugin_manager.cpp +++ b/3d-viewer/3d_cache/3d_plugin_manager.cpp @@ -2,7 +2,7 @@ * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2015-2016 Cirilo Bernardo - * Copyright (C) 2020 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2020-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -29,13 +29,13 @@ #include #include -#include #include #include #include #include #include +#include #include "3d_plugin_manager.h" #include "plugins/3d/3d_plugin.h" #include "3d_cache/sg/scenegraph.h" @@ -288,7 +288,7 @@ void S3D_PLUGIN_MANAGER::checkPluginName( const wxString& aPath, wxFileName path( ExpandEnvVarSubstitutions( aPath, nullptr ) ); - path.Normalize(); + path.Normalize( FN_NORMALIZE_FLAGS ); // determine if the path is already in the list wxString wxpath = path.GetFullPath(); @@ -326,7 +326,7 @@ void S3D_PLUGIN_MANAGER::checkPluginPath( const wxString& aPath, else path.Assign( aPath, wxEmptyString ); - path.Normalize(); + path.Normalize( FN_NORMALIZE_FLAGS ); if( !wxFileName::DirExists( path.GetFullPath() ) ) return; diff --git a/3d-viewer/dialogs/dialog_select_3d_model.cpp b/3d-viewer/dialogs/dialog_select_3d_model.cpp index 900181853a..c1a1452c40 100644 --- a/3d-viewer/dialogs/dialog_select_3d_model.cpp +++ b/3d-viewer/dialogs/dialog_select_3d_model.cpp @@ -3,7 +3,7 @@ * * Copyright (C) 2016 Mario Luzeiro * Copyright (C) 2016 Cirilo Bernardo - * Copyright (C) 2017-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2017-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -34,6 +34,7 @@ #include #include #include +#include #include @@ -164,7 +165,7 @@ bool DIALOG_SELECT_3DMODEL::TransferDataFromWindow() // file selection mode: retrieve the filename and specify a // path relative to one of the config paths wxFileName fname = m_FileTree->GetFilePath(); - fname.Normalize(); + fname.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); m_model->m_Filename = m_resolver->ShortenPath( fname.GetFullPath() ); return true; diff --git a/common/filename_resolver.cpp b/common/filename_resolver.cpp index dc68059f82..514d6ac72a 100644 --- a/common/filename_resolver.cpp +++ b/common/filename_resolver.cpp @@ -26,7 +26,6 @@ #include #include -#include #include #include #include @@ -34,6 +33,7 @@ #include "common.h" #include "filename_resolver.h" +#include // configuration file version #define CFGFILE_VERSION 1 @@ -66,7 +66,7 @@ bool FILENAME_RESOLVER::Set3DConfigDir( const wxString& aConfigDir ) wxFileName cfgdir( ExpandEnvVarSubstitutions( aConfigDir, m_project ), wxEmptyString ); - cfgdir.Normalize(); + cfgdir.Normalize( FN_NORMALIZE_FLAGS ); if( !cfgdir.DirExists() ) return false; @@ -87,7 +87,7 @@ bool FILENAME_RESOLVER::SetProject( PROJECT* aProject, bool* flgChanged ) wxFileName projdir( ExpandEnvVarSubstitutions( aProject->GetProjectPath(), aProject ), wxEmptyString ); - projdir.Normalize(); + projdir.Normalize( FN_NORMALIZE_FLAGS ); if( !projdir.DirExists() ) return false; @@ -188,8 +188,8 @@ bool FILENAME_RESOLVER::createPathList() } else { - fndummy.Assign( pathVal, wxEmptyString ); - fndummy.Normalize(); + fndummy.Assign( pathVal, "" ); + fndummy.Normalize( FN_NORMALIZE_FLAGS ); lpath.m_Pathexp = fndummy.GetFullPath(); } @@ -269,7 +269,7 @@ wxString FILENAME_RESOLVER::ResolvePath( const wxString& aFileName ) // working directory (which is not necessarily the current project directory) if( tmpFN.FileExists() ) { - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); tname = tmpFN.GetFullPath(); // special case: if a path begins with ${ENV_VAR} but is not in the resolver's path list @@ -316,7 +316,7 @@ wxString FILENAME_RESOLVER::ResolvePath( const wxString& aFileName ) if( wxFileName::FileExists( fullPath ) ) { tmpFN.Assign( fullPath ); - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); tname = tmpFN.GetFullPath(); return tname; } @@ -333,7 +333,7 @@ wxString FILENAME_RESOLVER::ResolvePath( const wxString& aFileName ) fullPath = ExpandEnvVarSubstitutions( fullPath, m_project ); fpath.Assign( fullPath ); - if( fpath.Normalize() && fpath.FileExists() ) + if( fpath.Normalize( FN_NORMALIZE_FLAGS ) && fpath.FileExists() ) { tname = fpath.GetFullPath(); return tname; @@ -381,7 +381,7 @@ wxString FILENAME_RESOLVER::ResolvePath( const wxString& aFileName ) wxFileName tmp( fullPath ); - if( tmp.Normalize() ) + if( tmp.Normalize( FN_NORMALIZE_FLAGS ) ) tname = tmp.GetFullPath(); return tname; @@ -422,7 +422,7 @@ bool FILENAME_RESOLVER::addPath( const SEARCH_PATH& aPath ) wxFileName path( ExpandEnvVarSubstitutions( tpath.m_Pathvar, m_project ), wxEmptyString ); - path.Normalize(); + path.Normalize( FN_NORMALIZE_FLAGS ); if( !path.DirExists() ) { @@ -496,7 +496,11 @@ bool FILENAME_RESOLVER::readPathList() } wxFileName cfgpath( m_configDir, RESOLVER_CONFIG ); - cfgpath.Normalize(); + + // This should be the same as wxWidgets 3.0 wxPATH_NORM_ALL which is deprecated in 3.1. + // There are known issues with environment variable expansion so maybe we should be using + // our own ExpandEnvVarSubstitutions() here instead. + cfgpath.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); wxString cfgname = cfgpath.GetFullPath(); size_t nitems = m_paths.size(); @@ -716,7 +720,7 @@ void FILENAME_RESOLVER::checkEnvVarPath( const wxString& aPath ) wxFileName tmpFN( ExpandEnvVarSubstitutions( lpath.m_Alias, m_project ), wxEmptyString ); wxUniChar psep = tmpFN.GetPathSeparator(); - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); if( !tmpFN.DirExists() ) return; diff --git a/common/project.cpp b/common/project.cpp index 4be0dedce4..5f7e3c4b90 100644 --- a/common/project.cpp +++ b/common/project.cpp @@ -1,7 +1,7 @@ /* * This program source code file is part of KiCad, a free EDA CAD application. * - * Copyright (C) 2014-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2014-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -273,7 +273,7 @@ const wxString PROJECT::AbsolutePath( const wxString& aFileName ) const if( !fn.IsAbsolute() ) { wxString pro_dir = wxPathOnly( GetProjectFullName() ); - fn.Normalize( wxPATH_NORM_ALL, pro_dir ); + fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS, pro_dir ); } return fn.GetFullPath(); diff --git a/eeschema/dialogs/dialog_plot_schematic.cpp b/eeschema/dialogs/dialog_plot_schematic.cpp index fd3a1af653..4ce15f9aa3 100644 --- a/eeschema/dialogs/dialog_plot_schematic.cpp +++ b/eeschema/dialogs/dialog_plot_schematic.cpp @@ -4,7 +4,7 @@ * Copyright (C) 1992-2018 Jean-Pierre Charras jp.charras at wanadoo.fr * Copyright (C) 1992-2010 Lorenzo Marcantonio * Copyright (C) 2011 Wayne Stambaugh - * Copyright (C) 1992-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 1992-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -38,6 +38,7 @@ #include #include #include +#include #include #include @@ -1283,7 +1284,7 @@ wxString DIALOG_PLOT_SCHEMATIC::getOutputPath() fn.SetName( wxEmptyString ); fn.SetExt( wxEmptyString ); - if( fn.Normalize() ) + if( fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ) ) { path = fn.GetPath(); } @@ -1318,7 +1319,7 @@ wxString DIALOG_PLOT_SCHEMATIC::getOutputPath() // Build the absolute path of current output directory and the project path. fn.SetPath( Prj().GetProjectPath() + path ); - if( fn.Normalize() ) + if( fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ) ) { path = fn.GetPath(); } diff --git a/eeschema/dialogs/dialog_sheet_properties.cpp b/eeschema/dialogs/dialog_sheet_properties.cpp index eacb981995..ae1a807ff4 100644 --- a/eeschema/dialogs/dialog_sheet_properties.cpp +++ b/eeschema/dialogs/dialog_sheet_properties.cpp @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include @@ -425,7 +426,8 @@ bool DIALOG_SHEET_PROPERTIES::onSheetFilenameChanged( const wxString& aNewFilena // SCH_SCREEN file names are always absolute. wxFileName currentScreenFileName = currentScreen->GetFileName(); - if( !screenFileName.Normalize( wxPATH_NORM_ALL, currentScreenFileName.GetPath() ) ) + if( !screenFileName.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS, + currentScreenFileName.GetPath() ) ) { msg = wxString::Format( _( "Cannot normalize new sheet schematic file path:\n" "'%s'\n" diff --git a/eeschema/dialogs/dialog_symbol_remap.cpp b/eeschema/dialogs/dialog_symbol_remap.cpp index 63db8e360a..d6e291d2c4 100644 --- a/eeschema/dialogs/dialog_symbol_remap.cpp +++ b/eeschema/dialogs/dialog_symbol_remap.cpp @@ -6,7 +6,7 @@ * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2017 Wayne Stambaugh - * Copyright (C) 2017-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2017-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the @@ -29,6 +29,7 @@ #include #include #include +#include #include #include @@ -201,7 +202,7 @@ void DIALOG_SYMBOL_REMAP::createProjectSymbolLibTable( REPORTER& aReporter ) wxFileName tmpFn = fullFileName; // Don't add symbol libraries that do not exist. - if( tmpFn.Normalize() && tmpFn.FileExists() ) + if( tmpFn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ) && tmpFn.FileExists() ) { msg.Printf( _( "Adding library '%s', file '%s' to project symbol library table." ), libName, diff --git a/eeschema/sim/sim_plot_frame.cpp b/eeschema/sim/sim_plot_frame.cpp index e53c5c36d9..a8f3ac5fca 100644 --- a/eeschema/sim/sim_plot_frame.cpp +++ b/eeschema/sim/sim_plot_frame.cpp @@ -2,7 +2,7 @@ * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2016 CERN - * Copyright (C) 2016-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2016-2022 KiCad Developers, see AUTHORS.txt for contributors. * @author Tomasz Wlostowski * @author Maciej Suminski * @@ -52,6 +52,7 @@ #include #include #include +#include SIM_PLOT_TYPE operator|( SIM_PLOT_TYPE aFirst, SIM_PLOT_TYPE aSecond ) @@ -1123,7 +1124,7 @@ wxString SIM_PLOT_FRAME::getDefaultPath() { wxFileName path = m_simulator->Settings()->GetWorkbookFilename(); - path.Normalize( wxPATH_NORM_ALL, Prj().GetProjectPath() ); + path.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS, Prj().GetProjectPath() ); return path.GetPath(); } diff --git a/eeschema/symbol_editor/symbol_library_manager.cpp b/eeschema/symbol_editor/symbol_library_manager.cpp index 00791ec327..3bbcb1ad0a 100644 --- a/eeschema/symbol_editor/symbol_library_manager.cpp +++ b/eeschema/symbol_editor/symbol_library_manager.cpp @@ -31,6 +31,7 @@ #include #include #include +#include #include #include #include @@ -210,10 +211,10 @@ bool SYMBOL_LIBRARY_MANAGER::SaveLibrary( const wxString& aLibrary, const wxStri if( row ) { original = row->GetFullURI( true ); - original.Normalize(); + original.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); } - destination.Normalize(); + destination.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); if( res && original == destination ) libBuf.ClearDeletedBuffer(); diff --git a/eeschema/tools/sch_editor_control.cpp b/eeschema/tools/sch_editor_control.cpp index b851350713..bd8ebcd238 100644 --- a/eeschema/tools/sch_editor_control.cpp +++ b/eeschema/tools/sch_editor_control.cpp @@ -62,6 +62,7 @@ #include #include +#include #include #include @@ -1842,7 +1843,8 @@ int SCH_EDITOR_CONTROL::Paste( const TOOL_EVENT& aEvent ) if( !fn.IsAbsolute() ) { wxFileName currentSheetFileName = pasteRoot.LastScreen()->GetFileName(); - fn.Normalize( wxPATH_NORM_ALL, currentSheetFileName.GetPath() ); + fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS, + currentSheetFileName.GetPath() ); } // Try to find the screen for the pasted sheet by several means diff --git a/include/project.h b/include/project.h index 5954aa38ff..7ddefa361e 100644 --- a/include/project.h +++ b/include/project.h @@ -1,7 +1,7 @@ /* * This program source code file is part of KiCad, a free EDA CAD application. * - * Copyright (C) 2014-2021 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 2014-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -29,8 +29,8 @@ #include #include #include +#include #include -#include #include /// A variable name whose value holds the current project directory. diff --git a/include/wx_filename.h b/include/wx_filename.h index d8961f70e5..a66f60cd91 100644 --- a/include/wx_filename.h +++ b/include/wx_filename.h @@ -1,7 +1,7 @@ /* * This program source code file is part of KiCad, a free EDA CAD application. * - * Copyright (C) 1992-2020 KiCad Developers, see AUTHORS.txt for contributors. + * Copyright (C) 1992-2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -26,6 +26,18 @@ #include +/** + * Default flags to pass to wxFileName::Normalize(). + * + * @note wxPATH_NORM_ALL is deprecated in wxWidgets 3.1 and later. wxPATH_NORM_ENV_VARS + * is not included because it has some known issues and we typically use our own + * ExpandEnvVarSubstitutions() for handling environment variable expansion. If + * ExpandEnvVarSubstitutions() is not used, logically or wxPATH_NORM_ENV_VARS to + * this. + */ +#define FN_NORMALIZE_FLAGS ( wxPATH_NORM_DOTS | wxPATH_NORM_TILDE | wxPATH_NORM_ABSOLUTE | \ + wxPATH_NORM_LONG | wxPATH_NORM_SHORTCUT ) + /** * A wrapper around a wxFileName which is much more performant with a subset of the API. * diff --git a/kicad/dialogs/dialog_template_selector.cpp b/kicad/dialogs/dialog_template_selector.cpp index 71e12c8dc5..99f6ac3bd1 100644 --- a/kicad/dialogs/dialog_template_selector.cpp +++ b/kicad/dialogs/dialog_template_selector.cpp @@ -24,6 +24,7 @@ #include "dialog_template_selector.h" #include +#include #include #include #include @@ -178,7 +179,7 @@ void DIALOG_TEMPLATE_SELECTOR::AddTemplatesPage( const wxString& aTitle, wxFileN { wxNotebookPage* newPage = new wxNotebookPage( m_notebook, wxID_ANY ); - aPath.Normalize(); + aPath.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); wxString path = aPath.GetFullPath(); // caller ensures this ends with file separator. TEMPLATE_SELECTION_PANEL* tpanel = new TEMPLATE_SELECTION_PANEL( newPage, path ); @@ -239,7 +240,7 @@ void DIALOG_TEMPLATE_SELECTOR::onDirectoryBrowseClicked( wxCommandEvent& event ) { wxFileName fn; fn.AssignDir( m_tcTemplatePath->GetValue() ); - fn.Normalize(); + fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); wxString currPath = fn.GetFullPath(); wxDirDialog dirDialog( this, _( "Select Templates Directory" ), currPath, @@ -268,7 +269,7 @@ void DIALOG_TEMPLATE_SELECTOR::onReload( wxCommandEvent& event ) wxFileName fn; fn.AssignDir( m_tcTemplatePath->GetValue() ); - fn.Normalize(); + fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); currPath = fn.GetFullPath(); m_tcTemplatePath->SetValue( currPath ); diff --git a/kicad/pcm/pcm.cpp b/kicad/pcm/pcm.cpp index 5b0b5f09ed..f72ab31ec2 100644 --- a/kicad/pcm/pcm.cpp +++ b/kicad/pcm/pcm.cpp @@ -30,6 +30,7 @@ #include "pgm_base.h" #include "picosha2.h" #include "settings/settings_manager.h" +#include #include #include @@ -73,8 +74,8 @@ PLUGIN_CONTENT_MANAGER::PLUGIN_CONTENT_MANAGER( wxWindow* aParent ) : m_dialog( // Read and store pcm schema wxFileName schema_file( PATHS::GetStockDataPath( true ), wxT( "pcm.v1.schema.json" ) ); - schema_file.Normalize(); - schema_file.AppendDir( wxT( "schemas" ) ); + schema_file.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); + schema_file.AppendDir( "schemas" ); std::ifstream schema_stream( schema_file.GetFullPath().ToUTF8() ); nlohmann::json schema; diff --git a/plugins/3d/vrml/v2/vrml2_base.cpp b/plugins/3d/vrml/v2/vrml2_base.cpp index 0c2b380b49..675807fe3a 100644 --- a/plugins/3d/vrml/v2/vrml2_base.cpp +++ b/plugins/3d/vrml/v2/vrml2_base.cpp @@ -26,9 +26,10 @@ #include #include #include -#include #include +#include + #include "vrml2_base.h" #include "vrml2_transform.h" #include "vrml2_shape.h" @@ -128,7 +129,7 @@ SGNODE* WRL2BASE::GetInlineData( const std::string& aName ) fn.Assign( fname ); } - if( !fn.Normalize() ) + if( !fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ) ) { m_inlineModels.insert( std::pair< std::string, SGNODE* >( aName, nullptr ) ); return nullptr; diff --git a/plugins/3d/vrml/wrlproc.cpp b/plugins/3d/vrml/wrlproc.cpp index 5a2ff0dbe3..9b06b61490 100644 --- a/plugins/3d/vrml/wrlproc.cpp +++ b/plugins/3d/vrml/wrlproc.cpp @@ -24,10 +24,10 @@ #include #include -#include #include #include #include "wrlproc.h" +#include #define GETLINE \ do \ @@ -78,7 +78,7 @@ WRLPROC::WRLPROC( LINE_READER* aLineReader ) wxFileName fn( tname ); if( fn.IsRelative() ) - fn.Normalize(); + fn.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); m_filedir = fn.GetPathWithSep().ToUTF8(); diff --git a/utils/idftools/idf2vrml.cpp b/utils/idftools/idf2vrml.cpp index 678d8613b1..79f7d905d3 100644 --- a/utils/idftools/idf2vrml.cpp +++ b/utils/idftools/idf2vrml.cpp @@ -1,7 +1,8 @@ /* * This program source code file is part of KiCad, a free EDA CAD application. * - * Copyright (C) 2014-2017 Cirilo Bernardo + * Copyright (C) 2014-2017 Cirilo Bernardo + * Copyright (C) 2022 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -35,7 +36,6 @@ #include #include #include -#include #include #include @@ -53,6 +53,8 @@ #include #include +#include + #include "idf_helpers.h" #include "idf_common.h" #include "idf_parser.h" @@ -259,7 +261,7 @@ int IDF2VRML::OnRun() // Create the VRML file and write the header wxFileName fname( m_filename ); fname.SetExt( wxT( "wrl" ) ); - fname.Normalize(); + fname.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); wxLogMessage( wxT( "Writing file: '%s'" ), fname.GetFullName() ); OPEN_OSTREAM( ofile, fname.GetFullPath().ToUTF8() ); diff --git a/utils/kicad2step/pcb/3d_resolver.cpp b/utils/kicad2step/pcb/3d_resolver.cpp index ba43db1e2e..84abe969fc 100644 --- a/utils/kicad2step/pcb/3d_resolver.cpp +++ b/utils/kicad2step/pcb/3d_resolver.cpp @@ -30,12 +30,13 @@ #include #include -#include #include #include #include #include +#include + #include "3d_resolver.h" // configuration file version @@ -138,7 +139,7 @@ wxString S3D_RESOLVER::ResolvePath( const wxString& aFileName, { if( tmpFN.FileExists() ) { - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); return tmpFN.GetFullPath(); } else @@ -149,7 +150,7 @@ wxString S3D_RESOLVER::ResolvePath( const wxString& aFileName, // this case covers full paths, leading expanded vars, and paths relative to the current // working directory (which is not necessarily the current project directory) - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); if( tmpFN.FileExists() ) { @@ -194,7 +195,7 @@ wxString S3D_RESOLVER::ResolvePath( const wxString& aFileName, fullPath = expandVars( fullPath ); tmpFN.Assign( fullPath ); - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS ); if( tmpFN.FileExists() ) { @@ -217,7 +218,7 @@ wxString S3D_RESOLVER::ResolvePath( const wxString& aFileName, fullPath.Append( tname ); fullPath = expandVars( fullPath ); fpath.Assign( fullPath ); - fpath.Normalize(); + fpath.Normalize( FN_NORMALIZE_FLAGS ); if( fpath.FileExists() ) { @@ -258,7 +259,7 @@ wxString S3D_RESOLVER::ResolvePath( const wxString& aFileName, fullPath = expandVars( fullPath ); wxFileName tmp( fullPath ); - tmp.Normalize(); + tmp.Normalize( FN_NORMALIZE_FLAGS ); if( tmp.FileExists() ) { @@ -295,8 +296,8 @@ bool S3D_RESOLVER::addPath( const SEARCH_PATH& aPath ) tpath.m_Pathvar.erase( tpath.m_Pathvar.length() - 1 ); #endif - wxFileName path( tpath.m_Pathvar, wxEmptyString ); - path.Normalize(); + wxFileName path( tpath.m_Pathvar, wxT( "" ) ); + path.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); if( !path.DirExists() ) { @@ -364,7 +365,7 @@ bool S3D_RESOLVER::addPath( const SEARCH_PATH& aPath ) bool S3D_RESOLVER::readPathList( void ) { wxFileName cfgpath( wxStandardPaths::Get().GetTempDir(), S3D_RESOLVER_CONFIG ); - cfgpath.Normalize(); + cfgpath.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); wxString cfgname = cfgpath.GetFullPath(); size_t nitems = m_Paths.size(); @@ -487,7 +488,7 @@ void S3D_RESOLVER::checkEnvVarPath( const wxString& aPath ) lpath.m_Pathvar = lpath.m_Alias; wxFileName tmpFN( lpath.m_Alias, wxEmptyString ); wxUniChar psep = tmpFN.GetPathSeparator(); - tmpFN.Normalize(); + tmpFN.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); if( !tmpFN.DirExists() ) return; diff --git a/utils/kicad2step/pcb/kicadpcb.cpp b/utils/kicad2step/pcb/kicadpcb.cpp index 2e0216c68d..b54463cbc4 100644 --- a/utils/kicad2step/pcb/kicadpcb.cpp +++ b/utils/kicad2step/pcb/kicadpcb.cpp @@ -31,13 +31,12 @@ #include #include -#include #include #include #include - +#include KICADPCB::KICADPCB( const wxString& aPcbName ) @@ -92,7 +91,7 @@ bool KICADPCB::ReadFile( const wxString& aFileName ) return false; } - fname.Normalize(); + fname.Normalize( FN_NORMALIZE_FLAGS | wxPATH_NORM_ENV_VARS ); m_filename = fname.GetFullPath(); try