|
|
@ -21,7 +21,7 @@ namespace MWGui
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* BookTextParser */
|
|
|
|
/* BookTextParser */
|
|
|
|
BookTextParser::BookTextParser(const std::string & text)
|
|
|
|
BookTextParser::BookTextParser(const std::string & text)
|
|
|
|
: mIndex(0), mText(text), mIgnoreNewlineTags(true), mIgnoreLineEndings(true)
|
|
|
|
: mIndex(0), mText(text), mIgnoreNewlineTags(true), mIgnoreLineEndings(true), mClosingTag(false)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWScript::InterpreterContext interpreterContext(NULL, MWWorld::Ptr()); // empty arguments, because there is no locals or actor
|
|
|
|
MWScript::InterpreterContext interpreterContext(NULL, MWWorld::Ptr()); // empty arguments, because there is no locals or actor
|
|
|
|
mText = Interpreter::fixDefinesBook(mText, interpreterContext);
|
|
|
|
mText = Interpreter::fixDefinesBook(mText, interpreterContext);
|
|
|
@ -40,7 +40,7 @@ namespace MWGui
|
|
|
|
mTagTypes[tag] = type;
|
|
|
|
mTagTypes[tag] = type;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string BookTextParser::getReadyText()
|
|
|
|
std::string BookTextParser::getReadyText() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return mReadyText;
|
|
|
|
return mReadyText;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -117,12 +117,27 @@ namespace MWGui
|
|
|
|
return mAttributes;
|
|
|
|
return mAttributes;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool BookTextParser::isClosingTag() const
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return mClosingTag;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void BookTextParser::parseTag(std::string tag)
|
|
|
|
void BookTextParser::parseTag(std::string tag)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
size_t tagNameEndPos = tag.find(' ');
|
|
|
|
size_t tagNameEndPos = tag.find(' ');
|
|
|
|
|
|
|
|
mAttributes.clear();
|
|
|
|
mTag = tag.substr(0, tagNameEndPos);
|
|
|
|
mTag = tag.substr(0, tagNameEndPos);
|
|
|
|
Misc::StringUtils::toLower(mTag);
|
|
|
|
Misc::StringUtils::toLower(mTag);
|
|
|
|
mAttributes.clear();
|
|
|
|
if (mTag.empty())
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mClosingTag = (mTag[0] == '/');
|
|
|
|
|
|
|
|
if (mClosingTag)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mTag.erase(mTag.begin());
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (tagNameEndPos == std::string::npos)
|
|
|
|
if (tagNameEndPos == std::string::npos)
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
tag.erase(0, tagNameEndPos+1);
|
|
|
|
tag.erase(0, tagNameEndPos+1);
|
|
|
@ -232,7 +247,10 @@ namespace MWGui
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case BookTextParser::Event_FontTag:
|
|
|
|
case BookTextParser::Event_FontTag:
|
|
|
|
handleFont(parser.getAttributes());
|
|
|
|
if (parser.isClosingTag())
|
|
|
|
|
|
|
|
resetFontProperties();
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
handleFont(parser.getAttributes());
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case BookTextParser::Event_DivTag:
|
|
|
|
case BookTextParser::Event_DivTag:
|
|
|
|
handleDiv(parser.getAttributes());
|
|
|
|
handleDiv(parser.getAttributes());
|
|
|
@ -256,6 +274,13 @@ namespace MWGui
|
|
|
|
return markupToWidget(parent, markup, parent->getWidth(), parent->getHeight());
|
|
|
|
return markupToWidget(parent, markup, parent->getWidth(), parent->getHeight());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void BookFormatter::resetFontProperties()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
MyGUI::Align align = mTextStyle.mTextAlign;
|
|
|
|
|
|
|
|
mTextStyle = TextStyle();
|
|
|
|
|
|
|
|
mTextStyle.mTextAlign = align;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void BookFormatter::handleDiv(const BookTextParser::Attributes & attr)
|
|
|
|
void BookFormatter::handleDiv(const BookTextParser::Attributes & attr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (attr.find("align") == attr.end())
|
|
|
|
if (attr.find("align") == attr.end())
|
|
|
|