From 2502e10592925e8d9ce0885685506fdc9be4a0dd Mon Sep 17 00:00:00 2001 From: kervala Date: Wed, 3 Jan 2018 18:04:00 +0100 Subject: [PATCH 1/4] Fixed: Warnings with VC++ 2017 --HG-- branch : develop --- code/nel/tools/3d/object_viewer/object_viewer.cpp | 2 +- .../3d/plugin_max/nel_export/nel_export_filetools.cpp | 2 +- code/nel/tools/3d/tile_edit/SelectionTerritoire.cpp | 4 ++-- code/nel/tools/misc/branch_patcher/branch_patcherDlg.cpp | 7 ++----- 4 files changed, 6 insertions(+), 9 deletions(-) diff --git a/code/nel/tools/3d/object_viewer/object_viewer.cpp b/code/nel/tools/3d/object_viewer/object_viewer.cpp index 2835b9b42..f1f663e38 100644 --- a/code/nel/tools/3d/object_viewer/object_viewer.cpp +++ b/code/nel/tools/3d/object_viewer/object_viewer.cpp @@ -3897,7 +3897,7 @@ bool browseFolder(const CString &caption, CString &destFolder, HWND parent) bi.lpfn = NULL; bi.lParam = NULL; bi.iImage = 0; - LPITEMIDLIST result = SHBrowseForFolder(&bi); + PIDLIST_ABSOLUTE result = SHBrowseForFolder(&bi); if (result != NULL && SHGetPathFromIDList(result, chosenPath)) { destFolder = chosenPath; diff --git a/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp b/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp index 7ecb61efe..cbc1ef88d 100644 --- a/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp +++ b/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp @@ -91,7 +91,7 @@ ULONG CNelExport::SelectDir(HWND Parent, TCHAR* Title, std::string &Path) bi.lParam=0; bi.iImage=0; - ITEMIDLIST* pidl = SHBrowseForFolder(&bi); + PIDLIST_ABSOLUTE pidl = SHBrowseForFolder(&bi); if (!SHGetPathFromIDList(pidl,str) ) { diff --git a/code/nel/tools/3d/tile_edit/SelectionTerritoire.cpp b/code/nel/tools/3d/tile_edit/SelectionTerritoire.cpp index 400b388d7..c76b9d03a 100644 --- a/code/nel/tools/3d/tile_edit/SelectionTerritoire.cpp +++ b/code/nel/tools/3d/tile_edit/SelectionTerritoire.cpp @@ -517,8 +517,8 @@ void SelectionTerritoire::OnPath() info.ulFlags=BIF_RETURNONLYFSDIRS; // Select the path - LPITEMIDLIST list; - if (list=SHBrowseForFolder (&info)) + PIDLIST_ABSOLUTE list = SHBrowseForFolder(&info); + if (list) { // Convert item into path string BOOL bRet=SHGetPathFromIDList(list, path); diff --git a/code/nel/tools/misc/branch_patcher/branch_patcherDlg.cpp b/code/nel/tools/misc/branch_patcher/branch_patcherDlg.cpp index c27111935..134eddebf 100644 --- a/code/nel/tools/misc/branch_patcher/branch_patcherDlg.cpp +++ b/code/nel/tools/misc/branch_patcher/branch_patcherDlg.cpp @@ -208,7 +208,6 @@ int CDirDialog::DoBrowse() } BROWSEINFO bInfo; - LPITEMIDLIST pidl; ZeroMemory((PVOID)&bInfo, sizeof(BROWSEINFO)); if (!m_strInitDir.IsEmpty()) @@ -258,10 +257,8 @@ int CDirDialog::DoBrowse() bInfo.lpszTitle = (m_strTitle.IsEmpty()) ? "Open" : m_strTitle; bInfo.ulFlags = BIF_RETURNFSANCESTORS | BIF_RETURNONLYFSDIRS; - if ((pidl = ::SHBrowseForFolder(&bInfo)) == NULL) - { - return 0; - } + PIDLIST_ABSOLUTE pidl = ::SHBrowseForFolder(&bInfo); + if (!pidl) return 0; m_strPath.ReleaseBuffer(); m_iImageIndex = bInfo.iImage; From c41b20c9e94e1186c16254d6f70d53bf8dfcd444 Mon Sep 17 00:00:00 2001 From: kervala Date: Wed, 3 Jan 2018 18:05:54 +0100 Subject: [PATCH 2/4] Fixed: Compilation of Tiles Editor MFC version --HG-- branch : develop --- code/nel/tools/3d/tile_edit/GetVal.cpp | 4 +- code/nel/tools/3d/tile_edit/GetVal.h | 2 +- .../3d/tile_edit/SelectionTerritoire.cpp | 89 ++++++++++--------- .../tools/3d/tile_edit/SelectionTerritoire.h | 2 +- code/nel/tools/3d/tile_edit/View.cpp | 73 ++++++++------- code/nel/tools/3d/tile_edit/ViewColumn.cpp | 50 ++++++++--- code/nel/tools/3d/tile_edit/ViewColumn.h | 2 +- code/nel/tools/3d/tile_edit/custom.cpp | 2 +- 8 files changed, 130 insertions(+), 94 deletions(-) diff --git a/code/nel/tools/3d/tile_edit/GetVal.cpp b/code/nel/tools/3d/tile_edit/GetVal.cpp index 13128feb5..ff9bcf660 100644 --- a/code/nel/tools/3d/tile_edit/GetVal.cpp +++ b/code/nel/tools/3d/tile_edit/GetVal.cpp @@ -64,8 +64,8 @@ void GetVal::OnOK() CString rString; EditStr->GetWindowText( rString ); int size = rString.GetLength(); - name = new char[size+1]; - strcpy (name, rString); + name = new TCHAR[size+1]; + _tcscpy(name, rString); /**((short*)name)=size; EditStr->GetLine(0,name,size); for (int i=0;iFindStringExact(0,GetStr.name)!=LB_ERR) { - MessageBox(_T("Ce nom existe deja","Error"), MB_ICONERROR); + MessageBox(_T("Ce nom existe deja"), _T("Error"), MB_ICONERROR); } else { list->InsertString(-1, GetStr.name); - tileBank.addLand (GetStr.name); + tileBank.addLand (tStrToUtf8(GetStr.name)); } } } @@ -119,14 +119,14 @@ private: virtual void OnInit () { UpdateData (); - char sTitle[512]; - sprintf (sTitle, "Tile sets use by %s", tileBank.getLand(_land)->getName().c_str()); + TCHAR sTitle[512]; + _stprintf(sTitle, _T("Tile sets use by %s"), utf8ToTStr(tileBank.getLand(_land)->getName())); SetWindowText (sTitle); for (int i=0; igetName().c_str()); + m_ctrlCombo.InsertString (-1, utf8ToTStr(tileBank.getTileSet(i)->getName())); if (tileBank.getLand(_land)->isTileSet (tileBank.getTileSet(i)->getName())) - m_ctrlList.InsertString (-1, tileBank.getTileSet(i)->getName().c_str()); + m_ctrlList.InsertString (-1, utf8ToTStr(tileBank.getTileSet(i)->getName())); } UpdateData (FALSE); } @@ -143,7 +143,7 @@ private: { CString rString; m_ctrlList.GetText(i, rString); - tileBank.getLand(_land)->addTileSet ((const char*)rString); + tileBank.getLand(_land)->addTileSet (tStrToUtf8(rString)); } UpdateData (FALSE); } @@ -202,7 +202,7 @@ void SelectionTerritoire::OnAddTileSet() else { list->InsertString(-1, GetStr.name); - tileBank.addTileSet (GetStr.name); + tileBank.addTileSet (tStrToUtf8(GetStr.name)); } } } @@ -218,16 +218,18 @@ private: virtual void OnInit () { UpdateData (); - char sTitle[512]; - sprintf (sTitle, "Children of the tile set %s", tileBank.getTileSet(_tileSet)->getName().c_str()); + TCHAR sTitle[512]; + _stprintf(sTitle, _T("Children of the tile set %s"), utf8ToTStr(tileBank.getTileSet(_tileSet)->getName())); SetWindowText (sTitle); for (int i=0; igetName().c_str()); + m_ctrlCombo.InsertString (-1, utf8ToTStr(tileBank.getTileSet(i)->getName())); + if (tileBank.getTileSet(_tileSet)->isChild (tileBank.getTileSet(i)->getName())) - m_ctrlList.InsertString (-1, tileBank.getTileSet(i)->getName().c_str()); + m_ctrlList.InsertString (-1, utf8ToTStr(tileBank.getTileSet(i)->getName())); } + UpdateData (FALSE); } virtual void OnOk () @@ -243,7 +245,7 @@ private: { CString rString; m_ctrlList.GetText(i, rString); - tileBank.getTileSet(_tileSet)->addChild ((const char*)rString); + tileBank.getTileSet(_tileSet)->addChild (tStrToUtf8(rString)); } UpdateData (FALSE); } @@ -433,12 +435,12 @@ void SelectionTerritoire::OnSave() Save (str, tileBank); } -void SelectionTerritoire::Save(const char* path, CTileBank &toSave) +void SelectionTerritoire::Save(const TCHAR* path, CTileBank &toSave) { // TODO: Add extra validation here { COFile stream; - if (stream.open ((const char*)path)) + if (stream.open (tStrToUtf8(path))) { toSave.serial (stream); } @@ -452,7 +454,7 @@ void SelectionTerritoire::OnSaveAs() CFileDialog sFile(false, _T("bank"), DefautPath+MainFileName, 0, szFilter, this); if (sFile.DoModal()==IDOK) { - Save (tStrToUtf8(sFile.GetPathName()).c_str(), tileBank); + Save (sFile.GetPathName(), tileBank); MainFileOk = 1; CButton *button = (CButton*)GetDlgItem(IDC_ADD_TERRITOIRE); button->EnableWindow(true); @@ -480,27 +482,26 @@ void SelectionTerritoire::OnCancel() } } -bool CheckPath (const std::string& path, const char* absolutePathToRemplace) +bool CheckPath (const std::string& path, const std::string &absolutePathToRemplace) { // Look for absolute path in path - if (strnicmp (path.c_str(), absolutePathToRemplace, strlen (absolutePathToRemplace))==0) + if (strnicmp(path.c_str(), absolutePathToRemplace.c_str(), absolutePathToRemplace.length()) == 0) return true; - else - return false; + + return false; } -bool RemovePath (std::string& path, const char* absolutePathToRemplace) +bool RemovePath (std::string& path, const std::string &absolutePathToRemplace) { // Look for absolute path in path - if (strnicmp (path.c_str(), absolutePathToRemplace, strlen (absolutePathToRemplace))==0) + if (strnicmp(path.c_str(), absolutePathToRemplace.c_str(), absolutePathToRemplace.length())==0) { // New path - std::string toto=path; - path=toto.c_str()+strlen (absolutePathToRemplace); + path = path.substr(absolutePathToRemplace.length()); return true; } - else - return false; + + return false; } void SelectionTerritoire::OnPath() @@ -508,12 +509,12 @@ void SelectionTerritoire::OnPath() // TODO: Add your control notification handler code here // Select a directory. - char path[MAX_PATH]; + TCHAR path[MAX_PATH]; // Build the struct BROWSEINFO info; memset (&info, 0, sizeof (BROWSEINFO)); - info.lpszTitle="Select the absolute base path of the bank"; + info.lpszTitle = _T("Select the absolute base path of the bank"); info.ulFlags=BIF_RETURNONLYFSDIRS; // Select the path @@ -525,16 +526,17 @@ void SelectionTerritoire::OnPath() nlassert (bRet); // Add a final back slash - if (strcmp (path, "")!=0) + if (_tcscmp(path, _T("")) != 0) { // Add a '\' at the end - if (path[strlen (path)-1]!='\\') - strcat (path, "\\"); + if (path[_tcslen(path)-1] != _T('\\')) + _tcscat(path, _T("\\")); } // Last check - char msg[512]; - sprintf (msg, "Do you really want to set %s as base path of the bank ?", path); + TCHAR msg[512]; + _stprintf(msg, _T("Do you really want to set %s as base path of the bank ?"), path); + if (MessageBox (msg, _T("TileEdit"), MB_YESNO|MB_ICONQUESTION)==IDYES) { // Set as default path.. @@ -574,13 +576,13 @@ void SelectionTerritoire::OnPath() if (!bitmapPath.empty()) { // Check the path - if (CheckPath (bitmapPath, path)==false) + if (CheckPath (bitmapPath, tStrToUtf8(path))==false) { // Bad path goodPath=false; // Make a message - sprintf (msg, "Path '%s' can't be found in bitmap '%s'. Continue ?", path, bitmapPath.c_str()); + _stprintf(msg, _T("Path '%s' can't be found in bitmap '%s'. Continue ?"), path, utf8ToTStr(bitmapPath)); // Message if (MessageBox (msg, _T("TileEdit"), MB_YESNO|MB_ICONQUESTION)==IDNO) @@ -603,13 +605,13 @@ void SelectionTerritoire::OnPath() if (strcmp (bitmapPath, "")!=0) { // Check the path - if (CheckPath (bitmapPath, path)==false) + if (CheckPath (bitmapPath, tStrToUtf8(path))==false) { // Bad path goodPath=false; // Make a message - sprintf (msg, "Path '%s' can't be found in bitmap '%s'. Continue ?", path, bitmapPath); + _stprintf(msg, _T("Path '%s' can't be found in bitmap '%s'. Continue ?"), path, utf8ToTStr(bitmapPath)); // Message if (MessageBox (msg, _T("TileEdit"), MB_YESNO|MB_ICONQUESTION)==IDNO) @@ -645,7 +647,7 @@ void SelectionTerritoire::OnPath() if (!bitmapPath.empty()) { // Remove the absolute path - bool res=RemovePath (bitmapPath, path); + bool res=RemovePath (bitmapPath, tStrToUtf8(path)); nlassert (res); // Set the bitmap @@ -665,7 +667,7 @@ void SelectionTerritoire::OnPath() if (!bitmapPath.empty()) { // Remove the absolute path - bool res=RemovePath (bitmapPath, path); + bool res=RemovePath (bitmapPath, tStrToUtf8(path)); nlassert (res); // Set the bitmap @@ -683,7 +685,7 @@ void SelectionTerritoire::OnPath() if (goodPath) { // Change the abs path of the bank - tileBank.setAbsPath (path); + tileBank.setAbsPath (tStrToUtf8(path)); // Change the bouton text GetDlgItem (IDC_PATH)->SetWindowText (path); @@ -698,9 +700,10 @@ void SelectionTerritoire::OnPath() void SelectionTerritoire::OnExport() { // TODO: Add your control notification handler code here - static TCHAR BASED_CODE szFilter[] = - _T("NeL tile bank files (*.smallbank)|*.smallbank|All Files (*.*)|*.*||"); - CFileDialog sFile(false, _T("*.smallbank"), DefautPath+ _T("*.smallbank"), 0, szFilter, this); + static TCHAR BASED_CODE szFilter[] = _T("NeL tile bank files (*.smallbank)|*.smallbank|All Files (*.*)|*.*||"); + + CFileDialog sFile(false, _T("*.smallbank"), DefautPath+ _T("*.smallbank"), 0, szFilter, this); + if (sFile.DoModal()==IDOK) { // Copy the bank diff --git a/code/nel/tools/3d/tile_edit/SelectionTerritoire.h b/code/nel/tools/3d/tile_edit/SelectionTerritoire.h index 600fd9cdb..f38f264d4 100644 --- a/code/nel/tools/3d/tile_edit/SelectionTerritoire.h +++ b/code/nel/tools/3d/tile_edit/SelectionTerritoire.h @@ -86,7 +86,7 @@ protected: afx_msg void OnSelchangeTileSet(); virtual BOOL OnInitDialog(); //}}AFX_MSG - void Save(const char* path, NL3D::CTileBank &toSave); + void Save(const TCHAR* path, NL3D::CTileBank &toSave); DECLARE_MESSAGE_MAP() }; diff --git a/code/nel/tools/3d/tile_edit/View.cpp b/code/nel/tools/3d/tile_edit/View.cpp index 5427f5c2f..cf65a527d 100644 --- a/code/nel/tools/3d/tile_edit/View.cpp +++ b/code/nel/tools/3d/tile_edit/View.cpp @@ -227,7 +227,7 @@ int TileList::addTile256 () return index; } -bool RemovePath (std::string& path, const char* absolutePathToRemplace); +bool RemovePath (std::string& path, const std::string &absolutePathToRemplace); int TileList::setTile128 (int tile, const std::string& name, NL3D::CTile::TBitmap type) { @@ -240,7 +240,9 @@ int TileList::setTile128 (int tile, const std::string& name, NL3D::CTile::TBitma uint Height; if (!loadPic(tileBank2.getAbsPath ()+troncated, tampon, Width, Height)) { - return (int)(MessageBox (NULL, ((tileBank2.getAbsPath ()+troncated)+"\nContinue ?").c_str(), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = tileBank2.getAbsPath() + troncated + "\nContinue ?"; + + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } else { @@ -256,10 +258,10 @@ int TileList::setTile128 (int tile, const std::string& name, NL3D::CTile::TBitma error=tileBank2.getTileSet(_tileSet)->checkTile128 (type, border, pixel, composante); if ((error!=CTileSet::ok)&&(error!=CTileSet::addFirstA128128)&&!zouille ()) { - char sTmp[512]; static const char* comp[]={"Red", "Green", "Blue", "Alpha", ""}; - sprintf (sTmp, "%s\nPixel: %d (%s)", CTileSet::getErrorMessage (error), pixel, comp[composante]); - return (int)(MessageBox (NULL, (std::string(sTmp)+"\nContinue ?").c_str(), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = NLMISC::toString("%s\nPixel: %d (%s)\nContinue ?", CTileSet::getErrorMessage (error), pixel, comp[composante]); + + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } else { @@ -286,9 +288,8 @@ int TileList::setTile128 (int tile, const std::string& name, NL3D::CTile::TBitma else { // Error: bitmap not in the absolute path.. - char msg[512]; - sprintf (msg, "The bitmap %s is not in the absolute path %s.", name.c_str(), tileBank2.getAbsPath ().c_str()); - return (int)(MessageBox (NULL, (std::string (msg)+"\nContinue ?").c_str(), _T("Load error"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = NLMISC::toString("The bitmap %s is not in the absolute path %s.\nContinue ?", name.c_str(), tileBank2.getAbsPath ().c_str()); + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Load error"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } return 1; @@ -305,7 +306,8 @@ int TileList::setTile256 (int tile, const std::string& name, NL3D::CTile::TBitma uint Height; if (!loadPic(tileBank2.getAbsPath ()+troncated, tampon, Width, Height)) { - return (int)(MessageBox (NULL, ((tileBank2.getAbsPath ()+troncated)+"\nContinue ?").c_str(), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = tileBank2.getAbsPath() + troncated + "\nContinue ?"; + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } else { @@ -322,10 +324,9 @@ int TileList::setTile256 (int tile, const std::string& name, NL3D::CTile::TBitma error=tileBank2.getTileSet(_tileSet)->checkTile256 (type, border, pixel, composante); if ((error!=CTileSet::ok)&&!zouille()) { - char sTmp[512]; - static const char* comp[]={"Red", "Green", "Blue", "Alpha", ""}; - sprintf (sTmp, "%s\nPixel: %d (%s)", CTileSet::getErrorMessage (error), pixel, comp[composante]); - return (int)(MessageBox (NULL, (std::string(sTmp)+"\nContinue ?").c_str(), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + static const char* comp[] = { "Red", "Green", "Blue", "Alpha", "" }; + std::string msg = NLMISC::toString("%s\nPixel: %d (%s)\nContinue ?", CTileSet::getErrorMessage (error), pixel, comp[composante]); + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } else { @@ -349,9 +350,8 @@ int TileList::setTile256 (int tile, const std::string& name, NL3D::CTile::TBitma else { // Error: bitmap not in the absolute path.. - char msg[512]; - sprintf (msg, "The bitmap %s is not in the absolute path %s.", name.c_str(), tileBank2.getAbsPath ().c_str()); - return (int)(MessageBox (NULL, (std::string (msg)+"\nContinue ?").c_str(), _T("Load error"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = NLMISC::toString("The bitmap %s is not in the absolute path %s.\nContinue ?", name.c_str(), tileBank2.getAbsPath ().c_str()); + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Load error"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } return 1; @@ -371,7 +371,8 @@ int TileList::setTileTransition (int tile, const std::string& name, NL3D::CTile: uint Height; if (!loadPic(tileBank2.getAbsPath ()+troncated, tampon, Width, Height)) { - return (int)(MessageBox (NULL, ((tileBank2.getAbsPath ()+troncated)+"\nContinue ?").c_str(), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); + std::string msg = tileBank2.getAbsPath() + troncated + "\nContinue ?"; + return (int)(MessageBox (NULL, utf8ToTStr(msg), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES); } else { @@ -387,10 +388,9 @@ int TileList::setTileTransition (int tile, const std::string& name, NL3D::CTile: error=tileBank2.getTileSet(_tileSet)->checkTile128 (type, border, pixel, composante); if ((error!=CTileSet::ok)&&(error!=CTileSet::addFirstA128128)&&!zouille ()) { - char sTmp[512]; static const char* comp[]={"Red", "Green", "Blue", "Alpha", ""}; - sprintf (sTmp, "%s\nPixel: %d (%s)", CTileSet::getErrorMessage (error), pixel, comp[composante]); - return MessageBox (NULL, (std::string(sTmp)+"\nContinue ?").c_str(), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; + std::string msg = NLMISC::toString("%s\nPixel: %d (%s)\nContinue ?", CTileSet::getErrorMessage(error), pixel, comp[composante]); + return MessageBox (NULL, utf8ToTStr(msg), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; } else { @@ -437,14 +437,17 @@ int TileList::setDisplacement (int tile, const std::string& name) theListDisplacement[tile].loaded=0; if (!_LoadBitmap(tileBank2.getAbsPath() + troncated, &theListDisplacement[tile].BmpInfo, theListDisplacement[tile].Bits, NULL, 0)) - MessageBox (NULL, (tileBank2.getAbsPath() + troncated).c_str(), _T("Can't load file"), MB_OK|MB_ICONEXCLAMATION); + { + std::string msg = tileBank2.getAbsPath() + troncated; + MessageBox(NULL, utf8ToTStr(msg), _T("Can't load file"), MB_OK | MB_ICONEXCLAMATION); + } else { // Check the size if ((theListDisplacement[tile].BmpInfo.bmiHeader.biWidth!=32)||(-theListDisplacement[tile].BmpInfo.bmiHeader.biHeight!=32)) { // Error message - MessageBox (NULL, _T("Invalid size: displacement map must be 32x32 8 bits."), troncated.c_str(), + MessageBox (NULL, _T("Invalid size: displacement map must be 32x32 8 bits."), utf8ToTStr(troncated), MB_OK|MB_ICONEXCLAMATION); // Free the bitmap @@ -464,9 +467,8 @@ int TileList::setDisplacement (int tile, const std::string& name) else { // Error: bitmap not in the absolute path.. - char msg[512]; - sprintf (msg, "The bitmap %s is not in the absolute path %s.", name.c_str(), tileBank2.getAbsPath ().c_str()); - MessageBox (NULL, msg, _T("Load error"), MB_OK|MB_ICONEXCLAMATION); + std::string msg = NLMISC::toString("The bitmap %s is not in the absolute path %s.", name.c_str(), tileBank2.getAbsPath ().c_str()); + MessageBox (NULL, utf8ToTStr(msg), _T("Load error"), MB_OK|MB_ICONEXCLAMATION); } return 1; @@ -483,7 +485,8 @@ int TileList::setTileTransitionAlpha (int tile, const std::string& name, int rot uint Height; if (!loadPic(tileBank2.getAbsPath ()+troncated, tampon, Width, Height)) { - return MessageBox (NULL, ((tileBank2.getAbsPath ()+troncated)+"\nContinue ?").c_str(), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; + std::string msg = tileBank2.getAbsPath() + troncated + "\nContinue ?"; + return MessageBox (NULL, utf8ToTStr(msg), _T("Can't load bitmap."), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; } else { @@ -505,23 +508,27 @@ int TileList::setTileTransitionAlpha (int tile, const std::string& name, int rot if (((error=tileBank2.getTileSet(_tileSet)->checkTileTransition ((CTileSet::TTransition)tile, CTile::alpha, border, indexError, pixel, composante))!=CTileSet::ok)&&!zouille ()) { - char sMsg[512]; + std::string msg; if ((error==CTileSet::topInterfaceProblem)||(error==CTileSet::bottomInterfaceProblem)||(error==CTileSet::leftInterfaceProblem) ||(error==CTileSet::rightInterfaceProblem)||(error==CTileSet::topBottomNotTheSame)||(error==CTileSet::rightLeftNotTheSame) ||(error==CTileSet::topInterfaceProblem)) { static const char* comp[]={"Red", "Green", "Blue", "Alpha", ""}; if (indexError!=-1) - sprintf (sMsg, "%s\nIncompatible with tile nb %d\nPixel: %d (%s)", CTileSet::getErrorMessage (error), indexError, + msg = NLMISC::toString("%s\nIncompatible with tile nb %d\nPixel: %d (%s)", CTileSet::getErrorMessage (error), indexError, pixel, comp[composante]); else - sprintf (sMsg, "%s\nIncompatible with the 128x128 tile\nPixel: %d (%s)", CTileSet::getErrorMessage (error), + msg = NLMISC::toString("%s\nIncompatible with the 128x128 tile\nPixel: %d (%s)", CTileSet::getErrorMessage (error), pixel, comp[composante]); } else - sprintf (sMsg, "%s\nIncompatible filled tile", CTileSet::getErrorMessage (error)); + { + msg = NLMISC::toString("%s\nIncompatible filled tile", CTileSet::getErrorMessage(error)); + } + + msg += "\nContinue ?"; - return MessageBox (NULL, (std::string(sMsg)+"\nContinue ?").c_str(), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; + return MessageBox (NULL, utf8ToTStr(msg), _T("Can't add tile"), MB_YESNO|MB_ICONEXCLAMATION)==IDYES; } else { @@ -534,8 +541,8 @@ int TileList::setTileTransitionAlpha (int tile, const std::string& name, int rot else { // Error: bitmap not in the absolute path.. - char msg[512]; - sprintf (msg, "The bitmap %s is not in the absolute path %s.", name.c_str(), tileBank2.getAbsPath ().c_str()); + TCHAR msg[512]; + _stprintf(msg, _T("The bitmap %s is not in the absolute path %s."), utf8ToTStr(name), utf8ToTStr(tileBank2.getAbsPath ())); MessageBox (NULL, msg, _T("Load error"), MB_OK|MB_ICONEXCLAMATION); } diff --git a/code/nel/tools/3d/tile_edit/ViewColumn.cpp b/code/nel/tools/3d/tile_edit/ViewColumn.cpp index d060b6788..db69b11dc 100644 --- a/code/nel/tools/3d/tile_edit/ViewColumn.cpp +++ b/code/nel/tools/3d/tile_edit/ViewColumn.cpp @@ -19,10 +19,36 @@ #include "ViewColumn.h" #include "Browse.h" -char *WndRegKeys[4][5] = {{"POPUP BOTTOM RX","POPUP BOTTOM RY","POPUP BOTTOM CX","POPUP BOTTOM CY","POPUP BOTTOM N"}, - {"POPUP TOP RX","POPUP TOP RY","POPUP TOP CX","POPUP TOP CY","POPUP TOP N"}, - {"POPUP LEFT RX","POPUP LEFT RY","POPUP LEFT CX","POPUP LEFT CY","POPUP LEFT N"}, - {"POPUP RIGHT RX","POPUP RIGHT RY","POPUP RIGHT CX","POPUP RIGHT CY","POPUP RIGHT N"}}; +TCHAR *WndRegKeys[4][5] = { + { + _T("POPUP BOTTOM RX"), + _T("POPUP BOTTOM RY"), + _T("POPUP BOTTOM CX"), + _T("POPUP BOTTOM CY"), + _T("POPUP BOTTOM N") + }, + { + _T("POPUP TOP RX"), + _T("POPUP TOP RY"), + _T("POPUP TOP CX"), + _T("POPUP TOP CY"), + _T("POPUP TOP N") + }, + { + _T("POPUP LEFT RX"), + _T("POPUP LEFT RY"), + _T("POPUP LEFT CX"), + _T("POPUP LEFT CY"), + _T("POPUP LEFT N") + }, + { + _T("POPUP RIGHT RX"), + _T("POPUP RIGHT RY"), + _T("POPUP RIGHT CX"), + _T("POPUP RIGHT CY"), + _T("POPUP RIGHT N") + } +}; ///////////////////////////////////////////////////////////////////////////// // ViewColumn dialog @@ -164,11 +190,11 @@ BOOL ViewColumn::OnInitDialog() if (RegOpenKey(HKEY_CURRENT_USER,REGKEY_TILEDIT,®key)==ERROR_SUCCESS) { unsigned long value; - RegQueryValueEx(regkey,WndRegKeys[pos&3][0],0,&value,(unsigned char *)&rx,&value); - RegQueryValueEx(regkey,WndRegKeys[pos&3][1],0,&value,(unsigned char *)&ry,&value); - RegQueryValueEx(regkey,WndRegKeys[pos&3][2],0,&value,(unsigned char *)&cx,&value); - RegQueryValueEx(regkey,WndRegKeys[pos&3][3],0,&value,(unsigned char *)&cy,&value); - RegQueryValueEx(regkey,WndRegKeys[pos&3][4],0,&value,(unsigned char *)&nTileInWnd,&value); + RegQueryValueEx(regkey, WndRegKeys[pos&3][0], 0, &value, (LPBYTE)&rx, &value); + RegQueryValueEx(regkey, WndRegKeys[pos&3][1], 0, &value, (LPBYTE)&ry, &value); + RegQueryValueEx(regkey, WndRegKeys[pos&3][2], 0, &value, (LPBYTE)&cx, &value); + RegQueryValueEx(regkey, WndRegKeys[pos&3][3], 0, &value, (LPBYTE)&cy, &value); + RegQueryValueEx(regkey, WndRegKeys[pos&3][4], 0, &value, (LPBYTE)&nTileInWnd, &value); RegCloseKey(regkey); } EnableScrollBar(SB_VERT); @@ -378,9 +404,9 @@ void ViewColumn::OnRButtonDown(UINT nFlags, CPoint point) // TODO: Add your message handler code here and/or call default CMenu popup; popup.CreatePopupMenu(); - popup.AppendMenu(MF_STRING | (nTileInWnd==1?MF_CHECKED:0),10,"*1"); - popup.AppendMenu(MF_STRING | (nTileInWnd==4?MF_CHECKED:0),12,"*4"); - popup.AppendMenu(MF_STRING,13,"Replace window"); + popup.AppendMenu(MF_STRING | (nTileInWnd == 1 ? MF_CHECKED:0), 10, _T("*1")); + popup.AppendMenu(MF_STRING | (nTileInWnd == 4 ? MF_CHECKED:0), 12, _T("*4")); + popup.AppendMenu(MF_STRING, 13, _T("Replace window")); RECT rect; GetWindowRect(&rect); popup.TrackPopupMenu(TPM_LEFTALIGN,MousePos.x+rect.left,MousePos.y+rect.top,this,NULL); diff --git a/code/nel/tools/3d/tile_edit/ViewColumn.h b/code/nel/tools/3d/tile_edit/ViewColumn.h index 78455fce2..e079c8fc0 100644 --- a/code/nel/tools/3d/tile_edit/ViewColumn.h +++ b/code/nel/tools/3d/tile_edit/ViewColumn.h @@ -23,7 +23,7 @@ // ViewColumn.h : header file // -extern char *WndRegKeys[4][5]; +extern TCHAR *WndRegKeys[4][5]; #include "View.h" diff --git a/code/nel/tools/3d/tile_edit/custom.cpp b/code/nel/tools/3d/tile_edit/custom.cpp index e33ac3b0f..d7b4f8173 100644 --- a/code/nel/tools/3d/tile_edit/custom.cpp +++ b/code/nel/tools/3d/tile_edit/custom.cpp @@ -97,7 +97,7 @@ LRESULT Custom::WindowProc(UINT message, WPARAM wParam, LPARAM lParam) { CString str; clist->GetLBText(i+2,str); - buttonList[i].Create((LPCSTR)str,BS_CHECKBOX,button,this,i+10); + buttonList[i].Create(str,BS_CHECKBOX,button,this,i+10); buttonList[i].SetFont(&font,1); buttonList[i].ModifyStyle(0,WS_VISIBLE); /* RECT st = button; st.left+=20; st.right = client.right - 90; st.top -= 3; From 31a7e3a90d7b4c441c77d3c4c58aa34d49ce2b95 Mon Sep 17 00:00:00 2001 From: kervala Date: Wed, 3 Jan 2018 18:07:08 +0100 Subject: [PATCH 3/4] Changed: CNelExport destructor now virtual like parent's one --HG-- branch : develop --- code/nel/tools/3d/plugin_max/nel_export/nel_export.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/code/nel/tools/3d/plugin_max/nel_export/nel_export.h b/code/nel/tools/3d/plugin_max/nel_export/nel_export.h index eabc05a09..75b9807d9 100644 --- a/code/nel/tools/3d/plugin_max/nel_export/nel_export.h +++ b/code/nel/tools/3d/plugin_max/nel_export/nel_export.h @@ -49,7 +49,7 @@ public: CNelExport (); - ~CNelExport(); + virtual ~CNelExport(); void init (bool view, bool errorInDialog, Interface *ip, bool loadStruct); From 56d17e27292650c2020b3f2fc96eb60aa8eb8dc1 Mon Sep 17 00:00:00 2001 From: kervala Date: Wed, 3 Jan 2018 18:07:47 +0100 Subject: [PATCH 4/4] Changed: Constify parameters --HG-- branch : develop --- code/nel/tools/3d/plugin_max/nel_export/nel_export.h | 4 ++-- .../tools/3d/plugin_max/nel_export/nel_export_filetools.cpp | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/code/nel/tools/3d/plugin_max/nel_export/nel_export.h b/code/nel/tools/3d/plugin_max/nel_export/nel_export.h index 75b9807d9..3cf20cf47 100644 --- a/code/nel/tools/3d/plugin_max/nel_export/nel_export.h +++ b/code/nel/tools/3d/plugin_max/nel_export/nel_export.h @@ -81,8 +81,8 @@ public: static void deleteLM(INode& ZeNode); // the export scene struct MUST be initialized before calling this fn void OnNodeProperties (const std::set &listNode); - ULONG SelectFileForSave(HWND Parent, TCHAR* Title, const TCHAR* Mask, std::string &FileName); - ULONG SelectDir(HWND Parent, TCHAR* Title, std::string &Path); + ULONG SelectFileForSave(HWND Parent, const TCHAR* Title, const TCHAR* Mask, std::string &FileName); + ULONG SelectDir(HWND Parent, const TCHAR* Title, std::string &Path); // The nel export objtect CExportNel *_ExportNel; diff --git a/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp b/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp index cbc1ef88d..11020e4fc 100644 --- a/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp +++ b/code/nel/tools/3d/plugin_max/nel_export/nel_export_filetools.cpp @@ -26,7 +26,7 @@ //-------------------------------------------------------------------------------------------------------------- -ULONG CNelExport::SelectFileForSave(HWND Parent, TCHAR* Title, const TCHAR* Mask, std::string &FileName) +ULONG CNelExport::SelectFileForSave(HWND Parent, const TCHAR* Title, const TCHAR* Mask, std::string &FileName) { TCHAR curdir[MAX_PATH]; TCHAR fname[MAX_PATH]; @@ -76,7 +76,7 @@ ULONG CNelExport::SelectFileForSave(HWND Parent, TCHAR* Title, const TCHAR* Mask //-------------------------------------------------------------------------------------------------------------- -ULONG CNelExport::SelectDir(HWND Parent, TCHAR* Title, std::string &Path) +ULONG CNelExport::SelectDir(HWND Parent, const TCHAR* Title, std::string &Path) { TCHAR str[MAX_PATH]; _tcscpy_s(str, MAX_PATH, utf8ToTStr(Path));