summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBjørn Lindeijer <bjorn@lindeijer.nl>2005-06-19 20:20:10 +0000
committerBjørn Lindeijer <bjorn@lindeijer.nl>2005-06-19 20:20:10 +0000
commit9db14810dd0387f1fa63a4e3bba9b05947bd5d9f (patch)
tree24d38c81819003aaebc631d13828db29ecf591d6
parentcc8d54427a4c4ebfdd403219403c381df27647dd (diff)
downloadmana-9db14810dd0387f1fa63a4e3bba9b05947bd5d9f.tar.gz
mana-9db14810dd0387f1fa63a4e3bba9b05947bd5d9f.tar.bz2
mana-9db14810dd0387f1fa63a4e3bba9b05947bd5d9f.tar.xz
mana-9db14810dd0387f1fa63a4e3bba9b05947bd5d9f.zip
Prevent deleting guiFont twice in non-OpenGL mode.
-rw-r--r--src/gui/browserbox.cpp24
-rw-r--r--src/gui/browserbox.h10
2 files changed, 19 insertions, 15 deletions
diff --git a/src/gui/browserbox.cpp b/src/gui/browserbox.cpp
index 96747fd5..7a8d8588 100644
--- a/src/gui/browserbox.cpp
+++ b/src/gui/browserbox.cpp
@@ -36,7 +36,7 @@ BrowserBox::BrowserBox(unsigned int mode):
mSelectedLink = -1;
setFocusable(true);
addMouseListener(this);
-
+
if (instances == 0)
{
#ifdef USE_OPENGL
@@ -48,16 +48,20 @@ BrowserBox::BrowserBox(unsigned int mode):
browserFont = gui->getFont();
#endif
}
+
instances++;
}
BrowserBox::~BrowserBox()
{
instances--;
+
if (instances == 0)
{
+#ifdef USE_OPENGL
// Clean up static resource font
delete browserFont;
+#endif
}
}
@@ -93,34 +97,34 @@ void BrowserBox::addRow(const std::string& row)
bLink.caption = tmp.substr(idx2 + 1, idx3 - (idx2 + 1));
bLink.y1 = mTextRows.size() * browserFont->getHeight();
bLink.y2 = bLink.y1 + browserFont->getHeight();
-
+
newRow += tmp.substr(0, idx1);
std::string tmp2 = newRow;
idx1 = tmp2.find("##");
while (idx1 >= 0)
{
- tmp2.erase(idx1, 3);
+ tmp2.erase(idx1, 3);
idx1 = tmp2.find("##");
}
bLink.x1 = browserFont->getWidth(tmp2) - 1;
bLink.x2 = bLink.x1 + browserFont->getWidth(bLink.caption) + 1;
-
+
mLinks.push_back(bLink);
-
+
newRow += "##L" + bLink.caption;
tmp.erase(0, idx3 + 2);
if(tmp != "")
{
newRow += "##P";
- }
+ }
idx1 = tmp.find("@@");
}
newRow += tmp;
mTextRows.push_back(newRow);
-
+
// Auto size mode
if (mMode == AUTO_SIZE)
{
@@ -147,7 +151,7 @@ void BrowserBox::clearRows()
void BrowserBox::mousePress(int mx, int my, int button)
{
if ((button == gcn::MouseInput::LEFT) && mLinkHandler)
- {
+ {
for (unsigned int i = 0; i < mLinks.size(); i++)
{
if ((mx >= mLinks[i].x1) && (mx < mLinks[i].x2) &&
@@ -184,7 +188,7 @@ void BrowserBox::draw(gcn::Graphics* graphics)
graphics->setColor(gcn::Color(BGCOLOR));
graphics->fillRectangle(gcn::Rectangle(0, 0, getWidth(), getHeight()));
}
-
+
if (mSelectedLink >= 0)
{
if ((mHighMode == BACKGROUND) || (mHighMode == BOTH))
@@ -199,7 +203,7 @@ void BrowserBox::draw(gcn::Graphics* graphics)
if ((mHighMode == UNDERLINE) || (mHighMode == BOTH))
{
- graphics->setColor(gcn::Color(LINK));
+ graphics->setColor(gcn::Color(LINK));
graphics->drawLine(
mLinks[mSelectedLink].x1,
mLinks[mSelectedLink].y2,
diff --git a/src/gui/browserbox.h b/src/gui/browserbox.h
index 8ac5a54c..45f5b25f 100644
--- a/src/gui/browserbox.h
+++ b/src/gui/browserbox.h
@@ -65,17 +65,17 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener
* Sets the Highlight mode for links.
*/
void setHighlightMode(unsigned int highMode);
-
+
/**
* Adds a text row to the browser.
*/
void addRow(const std::string& row);
-
+
/**
* Remove all rows.
*/
void clearRows();
-
+
/**
* Handles mouse actions.
*/
@@ -131,7 +131,7 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener
BOTH
};
- private:
+ private:
std::vector<std::string> mTextRows;
std::vector<BROWSER_LINK> mLinks;
LinkHandler *mLinkHandler;
@@ -139,7 +139,7 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener
unsigned int mHighMode;
bool mOpaque;
int mSelectedLink;
-
+
static int instances; /**< Number of Window instances */
static gcn::ImageFont* browserFont;
};