summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJosé Ávila <linux@javila.net>2005-07-03 02:52:20 +0000
committerJosé Ávila <linux@javila.net>2005-07-03 02:52:20 +0000
commita3beebb0a5b900d70e44b96e4679621dc9fd95f5 (patch)
tree80e307a7d2c0a0963f3344495cf40bdca3cd3d3c
parent675348d7e62292ed01175b8b001c6a99b207da53 (diff)
downloadMana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.gz
Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.bz2
Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.tar.xz
Mana-a3beebb0a5b900d70e44b96e4679621dc9fd95f5.zip
Fix bug in showing links and user defined colors in chat box
-rw-r--r--src/gui/browserbox.cpp191
-rw-r--r--src/gui/browserbox.h6
-rw-r--r--src/gui/chat.cpp1
3 files changed, 113 insertions, 85 deletions
diff --git a/src/gui/browserbox.cpp b/src/gui/browserbox.cpp
index 51cc7fb3..168708ad 100644
--- a/src/gui/browserbox.cpp
+++ b/src/gui/browserbox.cpp
@@ -34,6 +34,7 @@ BrowserBox::BrowserBox(unsigned int mode):
mMode = mode;
setOpaque(true);
setHighlightMode(BOTH);
+ mUseLinksAndUserColors = true;
mSelectedLink = -1;
setFocusable(true);
addMouseListener(this);
@@ -80,6 +81,11 @@ void BrowserBox::setHighlightMode(unsigned int highMode)
{
mHighMode = highMode;
}
+
+void BrowserBox::disableLinksAndUserColors()
+{
+ mUseLinksAndUserColors = false;
+}
void BrowserBox::addRow(const std::string& row)
{
@@ -87,43 +93,55 @@ void BrowserBox::addRow(const std::string& row)
std::string newRow;
BROWSER_LINK bLink;
int idx1, idx2, idx3;
-
- // Check for links in format "@@link|Caption@@"
- idx1 = tmp.find("@@");
- while (idx1 >= 0)
- {
- idx2 = tmp.find("|", idx1);
- idx3 = tmp.find("@@", idx2);
- bLink.link = tmp.substr(idx1 + 2, idx2 - (idx1 + 2));
- 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("##");
+
+ // Use links and user defined colors
+ if (mUseLinksAndUserColors)
+ {
+ // Check for links in format "@@link|Caption@@"
+ idx1 = tmp.find("@@");
while (idx1 >= 0)
{
- tmp2.erase(idx1, 3);
+ idx2 = tmp.find("|", idx1);
+ idx3 = tmp.find("@@", idx2);
+ bLink.link = tmp.substr(idx1 + 2, idx2 - (idx1 + 2));
+ 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("##");
- }
- bLink.x1 = browserFont->getWidth(tmp2) - 1;
- bLink.x2 = bLink.x1 + browserFont->getWidth(bLink.caption) + 1;
+ while (idx1 >= 0)
+ {
+ 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);
+ mLinks.push_back(bLink);
- newRow += "##L" + bLink.caption;
+ newRow += "##L" + bLink.caption;
- tmp.erase(0, idx3 + 2);
- if(tmp != "")
- {
- newRow += "##P";
+ tmp.erase(0, idx3 + 2);
+ if(tmp != "")
+ {
+ newRow += "##P";
+ }
+ idx1 = tmp.find("@@");
}
- idx1 = tmp.find("@@");
+
+ newRow += tmp;
+ }
+
+ // Don't use links and user defined colors
+ else
+ {
+ newRow = row;
}
- newRow += tmp;
+ newRow == (newRow == "" ? " " : newRow);
mTextRows.push_back(newRow);
// Auto size mode
@@ -132,7 +150,7 @@ void BrowserBox::addRow(const std::string& row)
std::string plain = newRow;
for (idx1 = plain.find("##"); idx1 >= 0; idx1 = plain.find("##"))
plain.erase(idx1, 3);
-
+
// Adjust the BrowserBox size
int w = browserFont->getWidth(plain);
if (w > getWidth())
@@ -225,67 +243,70 @@ void BrowserBox::draw(gcn::Graphics* graphics)
for (j = 0; j < row.size(); j++)
{
- // Check for color change in format "##x", x = [L,P,0..9]
- if ((row.at(j) == '#') && (row.at(j + 1) == '#'))
+ if (mUseLinksAndUserColors || (!mUseLinksAndUserColors && (j == 0)))
{
- switch (row.at(j + 2))
+ // Check for color change in format "##x", x = [L,P,0..9]
+ if ((row.at(j) == '#') && (row.at(j + 1) == '#'))
{
- case 'L': // Link color
- prevColor = selColor;
- selColor = LINK;
- break;
- case 'P': // Previous color
- selColor = prevColor;
- break;
- case '1':
- prevColor = selColor;
- selColor = RED;
- break;
- case '2':
- prevColor = selColor;
- selColor = GREEN;
- break;
- case '3':
- prevColor = selColor;
- selColor = BLUE;
- break;
- case '4':
- prevColor = selColor;
- selColor = ORANGE;
- break;
- case '5':
- prevColor = selColor;
- selColor = YELLOW;
- break;
- case '6':
- prevColor = selColor;
- selColor = PINK;
- break;
- case '7':
- prevColor = selColor;
- selColor = PURPLE;
- break;
- case '8':
- prevColor = selColor;
- selColor = GRAY;
- break;
- case '9':
- prevColor = selColor;
- selColor = BROWN;
- break;
- case '0':
- default:
- prevColor = selColor;
- selColor = BLACK;
- }
- j += 3;
+ switch (row.at(j + 2))
+ {
+ case 'L': // Link color
+ prevColor = selColor;
+ selColor = LINK;
+ break;
+ case 'P': // Previous color
+ selColor = prevColor;
+ break;
+ case '1':
+ prevColor = selColor;
+ selColor = RED;
+ break;
+ case '2':
+ prevColor = selColor;
+ selColor = GREEN;
+ break;
+ case '3':
+ prevColor = selColor;
+ selColor = BLUE;
+ break;
+ case '4':
+ prevColor = selColor;
+ selColor = ORANGE;
+ break;
+ case '5':
+ prevColor = selColor;
+ selColor = YELLOW;
+ break;
+ case '6':
+ prevColor = selColor;
+ selColor = PINK;
+ break;
+ case '7':
+ prevColor = selColor;
+ selColor = PURPLE;
+ break;
+ case '8':
+ prevColor = selColor;
+ selColor = GRAY;
+ break;
+ case '9':
+ prevColor = selColor;
+ selColor = BROWN;
+ break;
+ case '0':
+ default:
+ prevColor = selColor;
+ selColor = BLACK;
+ }
+ j += 3;
- if (j == row.size())
- {
- break;
+ if (j == row.size())
+ {
+ break;
+ }
}
+ graphics->setColor(gcn::Color(selColor));
}
- graphics->setColor(gcn::Color(selColor));
// Check for line separators in format "---"
if ((j <= 3) && (row.at(j) == '-') && (row.at(j + 1) == '-') &&
diff --git a/src/gui/browserbox.h b/src/gui/browserbox.h
index 45f5b25f..81771289 100644
--- a/src/gui/browserbox.h
+++ b/src/gui/browserbox.h
@@ -67,6 +67,11 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener
void setHighlightMode(unsigned int highMode);
/**
+ * Disable links & user defined colors to be used in chat input.
+ */
+ void disableLinksAndUserColors();
+
+ /**
* Adds a text row to the browser.
*/
void addRow(const std::string& row);
@@ -138,6 +143,7 @@ class BrowserBox : public gcn::Widget, public gcn::MouseListener
unsigned int mMode;
unsigned int mHighMode;
bool mOpaque;
+ bool mUseLinksAndUserColors;
int mSelectedLink;
static int instances; /**< Number of Window instances */
diff --git a/src/gui/chat.cpp b/src/gui/chat.cpp
index c02f5160..b3e072a2 100644
--- a/src/gui/chat.cpp
+++ b/src/gui/chat.cpp
@@ -46,6 +46,7 @@ ChatWindow::ChatWindow(const std::string &logfile):
textOutput = new BrowserBox(BrowserBox::AUTO_WRAP);
textOutput->setOpaque(false);
+ textOutput->disableLinksAndUserColors();
scrollArea = new ScrollArea(textOutput);
scrollArea->setPosition(
scrollArea->getBorderSize(), scrollArea->getBorderSize());