Fix bug where saving document would cause folding to be lost

git-svn-id: svn://svn.tuxfamily.org/svnroot/notepadplus/repository@220 f5eea248-9336-0410-98b8-ebc06183d4e3
This commit is contained in:
harrybharry 2008-06-07 15:59:25 +00:00
parent 47194d114d
commit 3e551ff84b
1 changed files with 13 additions and 8 deletions

View File

@ -100,7 +100,7 @@ void Buffer::setFileName(const char *fn, LangType defaultLang)
_fileName = PathFindFileName(_fullPathName); _fileName = PathFindFileName(_fullPathName);
// for _lang // for _lang
_lang = defaultLang; LangType newLang = defaultLang;
char *ext = PathFindExtension(_fullPathName); char *ext = PathFindExtension(_fullPathName);
if (*ext == '.') { //extension found if (*ext == '.') { //extension found
ext += 1; ext += 1;
@ -109,27 +109,32 @@ void Buffer::setFileName(const char *fn, LangType defaultLang)
const char *langName = NULL; const char *langName = NULL;
if ((langName = pNppParamInst->getUserDefinedLangNameFromExt(ext))) if ((langName = pNppParamInst->getUserDefinedLangNameFromExt(ext)))
{ {
_lang = L_USER; newLang = L_USER;
strcpy(_userLangExt, langName); strcpy(_userLangExt, langName);
} }
else // if it's not user lang, then check if it's supported lang else // if it's not user lang, then check if it's supported lang
{ {
_userLangExt[0] = '\0'; _userLangExt[0] = '\0';
_lang = getLangFromExt(ext); newLang = getLangFromExt(ext);
} }
} }
if (_lang == defaultLang || _lang == L_TXT) //language can probably be refined if (newLang == defaultLang || newLang == L_TXT) //language can probably be refined
{ {
if ((!_stricmp(_fileName, "makefile")) || (!_stricmp(_fileName, "GNUmakefile"))) if ((!_stricmp(_fileName, "makefile")) || (!_stricmp(_fileName, "GNUmakefile")))
_lang = L_MAKEFILE; newLang = L_MAKEFILE;
else if (!_stricmp(_fileName, "CmakeLists.txt")) else if (!_stricmp(_fileName, "CmakeLists.txt"))
_lang = L_CMAKE; newLang = L_CMAKE;
} }
updateTimeStamp(); updateTimeStamp();
if (newLang != _lang) {
_lang = newLang;
doNotify(BufferChangeFilename | BufferChangeLanguage | BufferChangeTimestamp);
return;
}
doNotify(BufferChangeFilename | BufferChangeLanguage | BufferChangeTimestamp); doNotify(BufferChangeFilename | BufferChangeTimestamp);
} }
bool Buffer::checkFileState() { //returns true if the status has been changed (it can change into DOC_REGULAR too). false otherwise bool Buffer::checkFileState() { //returns true if the status has been changed (it can change into DOC_REGULAR too). false otherwise
@ -455,7 +460,7 @@ bool FileManager::saveBuffer(BufferID id, const char * filename, bool isCopy) {
buffer->setFileName(filename); buffer->setFileName(filename);
buffer->setDirty(false); buffer->setDirty(false);
buffer->setStatus(DOC_REGULAR); buffer->setStatus(DOC_REGULAR);
_pscratchTilla->execute(SCI_SETSAVEPOINT); _pscratchTilla->execute(SCI_SETSAVEPOINT);
_pscratchTilla->execute(SCI_SETDOCPOINTER, 0, _scratchDocDefault); _pscratchTilla->execute(SCI_SETDOCPOINTER, 0, _scratchDocDefault);
return true; return true;