diff options
-rw-r--r-- | src/CMakeLists.txt | 2 | ||||
-rw-r--r-- | src/Makefile.am | 2 | ||||
-rw-r--r-- | src/gui/fonts/font.cpp | 106 | ||||
-rw-r--r-- | src/gui/fonts/font.h | 25 | ||||
-rw-r--r-- | src/gui/fonts/textchunklist.cpp | 131 | ||||
-rw-r--r-- | src/gui/fonts/textchunklist.h | 57 |
6 files changed, 193 insertions, 130 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index e8689d753..a3dea452e 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -429,6 +429,8 @@ SET(SRCS gui/fonts/font.h gui/fonts/textchunk.cpp gui/fonts/textchunk.h + gui/fonts/textchunklist.cpp + gui/fonts/textchunklist.h gui/fonts/textchunksmall.cpp gui/fonts/textchunksmall.h gui/windows/shopwindow.cpp diff --git a/src/Makefile.am b/src/Makefile.am index 8e325261f..e2df5a905 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -526,6 +526,8 @@ manaplus_SOURCES += gui/widgets/avatarlistbox.cpp \ gui/fonts/font.h \ gui/fonts/textchunk.cpp \ gui/fonts/textchunk.h \ + gui/fonts/textchunklist.cpp \ + gui/fonts/textchunklist.h \ gui/fonts/textchunksmall.cpp \ gui/fonts/textchunksmall.h \ gui/windows/shopwindow.cpp \ diff --git a/src/gui/fonts/font.cpp b/src/gui/fonts/font.cpp index 485d1a84e..4c297793e 100644 --- a/src/gui/fonts/font.cpp +++ b/src/gui/fonts/font.cpp @@ -96,112 +96,6 @@ bool Font::mSoftMode(false); extern char *strBuf; -TextChunkList::TextChunkList() : - start(nullptr), - end(nullptr), - size(0), - search(), - searchWidth() -{ -} - -void TextChunkList::insertFirst(TextChunk *const item) -{ - TextChunk *const oldFirst = start; - if (start) - start->prev = item; - item->prev = nullptr; - if (oldFirst) - item->next = oldFirst; - else - end = item; - start = item; - size ++; - search[TextChunkSmall(item->text, item->color, item->color2)] = item; - searchWidth[item->text] = item; -} - -void TextChunkList::moveToFirst(TextChunk *const item) -{ - if (item == start) - return; - - TextChunk *oldPrev = item->prev; - if (oldPrev) - oldPrev->next = item->next; - TextChunk *oldNext = item->next; - if (oldNext) - oldNext->prev = item->prev; - else - end = oldPrev; - TextChunk *const oldFirst = start; - if (start) - start->prev = item; - item->prev = nullptr; - item->next = oldFirst; - start = item; -} - -void TextChunkList::removeBack() -{ - TextChunk *oldEnd = end; - if (oldEnd) - { - end = oldEnd->prev; - if (end) - end->next = nullptr; - else - start = nullptr; - search.erase(TextChunkSmall(oldEnd->text, - oldEnd->color, oldEnd->color2)); - searchWidth.erase(oldEnd->text); - delete oldEnd; - size --; - } -} - -void TextChunkList::removeBack(int n) -{ - TextChunk *item = end; - while (n && item) - { - n --; - TextChunk *oldEnd = item; - item = item->prev; - search.erase(TextChunkSmall(oldEnd->text, - oldEnd->color, oldEnd->color2)); - searchWidth.erase(oldEnd->text); - delete oldEnd; - size --; - } - if (item) - { - item->next = nullptr; - end = item; - } - else - { - start = nullptr; - end = nullptr; - } -} - -void TextChunkList::clear() -{ - search.clear(); - searchWidth.clear(); - TextChunk *item = start; - while (item) - { - TextChunk *item2 = item->next; - delete item; - item = item2; - } - start = nullptr; - end = nullptr; - size = 0; -} - static int fontCounter; Font::Font(std::string filename, diff --git a/src/gui/fonts/font.h b/src/gui/fonts/font.h index 7ed400ff4..6e933f7e1 100644 --- a/src/gui/fonts/font.h +++ b/src/gui/fonts/font.h @@ -69,6 +69,7 @@ #include "gui/color.h" +#include "gui/fonts/textchunklist.h" #include "gui/fonts/textchunksmall.h" #include <SDL_ttf.h> @@ -85,30 +86,6 @@ class TextChunk; const unsigned int CACHES_NUMBER = 256; -class TextChunkList final -{ - public: - TextChunkList(); - - A_DELETE_COPY(TextChunkList) - - void insertFirst(TextChunk *const item); - - void moveToFirst(TextChunk *const item); - - void removeBack(); - - void removeBack(int n); - - void clear(); - - TextChunk *start; - TextChunk *end; - uint32_t size; - std::map<TextChunkSmall, TextChunk*> search; - std::map<std::string, TextChunk*> searchWidth; -}; - /** * A wrapper around SDL_ttf for allowing the use of TrueType fonts. * diff --git a/src/gui/fonts/textchunklist.cpp b/src/gui/fonts/textchunklist.cpp new file mode 100644 index 000000000..98d90e23d --- /dev/null +++ b/src/gui/fonts/textchunklist.cpp @@ -0,0 +1,131 @@ +/* + * The ManaPlus Client + * Copyright (C) 2011-2014 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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 Free Software Foundation; either version 2 of the License, or + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#include "gui/fonts/textchunklist.h" + +#include "gui/fonts/textchunk.h" + +#include "debug.h" + +TextChunkList::TextChunkList() : + start(nullptr), + end(nullptr), + size(0), + search(), + searchWidth() +{ +} + +void TextChunkList::insertFirst(TextChunk *const item) +{ + TextChunk *const oldFirst = start; + if (start) + start->prev = item; + item->prev = nullptr; + if (oldFirst) + item->next = oldFirst; + else + end = item; + start = item; + size ++; + search[TextChunkSmall(item->text, item->color, item->color2)] = item; + searchWidth[item->text] = item; +} + +void TextChunkList::moveToFirst(TextChunk *const item) +{ + if (item == start) + return; + + TextChunk *oldPrev = item->prev; + if (oldPrev) + oldPrev->next = item->next; + TextChunk *oldNext = item->next; + if (oldNext) + oldNext->prev = item->prev; + else + end = oldPrev; + TextChunk *const oldFirst = start; + if (start) + start->prev = item; + item->prev = nullptr; + item->next = oldFirst; + start = item; +} + +void TextChunkList::removeBack() +{ + TextChunk *oldEnd = end; + if (oldEnd) + { + end = oldEnd->prev; + if (end) + end->next = nullptr; + else + start = nullptr; + search.erase(TextChunkSmall(oldEnd->text, + oldEnd->color, oldEnd->color2)); + searchWidth.erase(oldEnd->text); + delete oldEnd; + size --; + } +} + +void TextChunkList::removeBack(int n) +{ + TextChunk *item = end; + while (n && item) + { + n --; + TextChunk *oldEnd = item; + item = item->prev; + search.erase(TextChunkSmall(oldEnd->text, + oldEnd->color, oldEnd->color2)); + searchWidth.erase(oldEnd->text); + delete oldEnd; + size --; + } + if (item) + { + item->next = nullptr; + end = item; + } + else + { + start = nullptr; + end = nullptr; + } +} + +void TextChunkList::clear() +{ + search.clear(); + searchWidth.clear(); + TextChunk *item = start; + while (item) + { + TextChunk *item2 = item->next; + delete item; + item = item2; + } + start = nullptr; + end = nullptr; + size = 0; +} diff --git a/src/gui/fonts/textchunklist.h b/src/gui/fonts/textchunklist.h new file mode 100644 index 000000000..9c0240398 --- /dev/null +++ b/src/gui/fonts/textchunklist.h @@ -0,0 +1,57 @@ +/* + * The ManaPlus Client + * Copyright (C) 2011-2014 The ManaPlus Developers + * + * This file is part of The ManaPlus Client. + * + * 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 Free Software Foundation; either version 2 of the License, or + * any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef GUI_FONTS_TEXTCHUNKLIST_H +#define GUI_FONTS_TEXTCHUNKLIST_H + +#include "gui/fonts/textchunksmall.h" + +#include <map> +#include <string> + +#include "localconsts.h" + +class TextChunk; + +class TextChunkList final +{ + public: + TextChunkList(); + + A_DELETE_COPY(TextChunkList) + + void insertFirst(TextChunk *const item); + + void moveToFirst(TextChunk *const item); + + void removeBack(); + + void removeBack(int n); + + void clear(); + + TextChunk *start; + TextChunk *end; + uint32_t size; + std::map<TextChunkSmall, TextChunk*> search; + std::map<std::string, TextChunk*> searchWidth; +}; + +#endif // GUI_FONTS_TEXTCHUNKLIST_H |