"),
- left_indent.c_str(), //Document-Wide Left Indent
- right_indent.c_str()); //Document-Wide Right Indent
-
- str << wxT(" | ");
- */
-
str << wxT("");
str << wxString::Format(wxT(""),
- currentParaStyle.GetFont().GetFaceName().c_str(), Pt_To_Size( currentParaStyle.GetFont().GetPointSize() ),
+ currentParaStyle.GetFont().GetFaceName().c_str(), PtToSize(currentParaStyle.GetFont().GetPointSize()),
currentParaStyle.GetTextColour().GetAsString(wxC2S_HTML_SYNTAX).c_str());
- //wxString align = GetAlignment( currentParaStyle.GetAlignment() );
- //str << wxString::Format(wxT(" "), align );
-
m_font = false;
m_indent = 0;
m_list = false;
@@ -99,7 +87,9 @@ bool wxRichTextHTMLHandler::DoSaveFile(wxRichTextBuffer *buffer, wxOutputStream&
if (para)
{
- OutputParagraphFormatting(currentParaStyle, para->GetAttributes(), stream);
+ wxTextAttrEx paraStyle(para->GetCombinedAttributes());
+
+ OutputParagraphFormatting(currentParaStyle, paraStyle, stream);
wxRichTextObjectList::compatibility_iterator node2 = para->GetChildren().GetFirst();
while (node2)
@@ -108,21 +98,21 @@ bool wxRichTextHTMLHandler::DoSaveFile(wxRichTextBuffer *buffer, wxOutputStream&
wxRichTextPlainText* textObj = wxDynamicCast(obj, wxRichTextPlainText);
if (textObj && !textObj->IsEmpty())
{
- BeginCharacterFormatting(currentCharStyle, obj->GetAttributes(), stream);
+ wxTextAttrEx charStyle(para->GetCombinedAttributes(obj->GetAttributes()));
+ BeginCharacterFormatting(currentCharStyle, charStyle, paraStyle, stream);
str << textObj->GetText();
- EndCharacterFormatting(currentCharStyle, obj->GetAttributes(), stream);
+ EndCharacterFormatting(currentCharStyle, charStyle, paraStyle, stream);
}
wxRichTextImage* image = wxDynamicCast(obj, wxRichTextImage);
if( image && !image->IsEmpty())
- Image_to_Base64( image, stream );
+ WriteImage( image, stream );
node2 = node2->GetNext();
}
str << wxT("\n");
- //OutputParagraphFormatting(currentParaStyle, para->GetAttributes(), stream, false);
}
node = node->GetNext();
}
@@ -132,105 +122,102 @@ bool wxRichTextHTMLHandler::DoSaveFile(wxRichTextBuffer *buffer, wxOutputStream&
return true;
}
-void wxRichTextHTMLHandler::BeginCharacterFormatting(const wxTextAttrEx& currentStyle, const wxTextAttrEx& thisStyle, wxOutputStream& stream)
+void wxRichTextHTMLHandler::BeginCharacterFormatting(const wxTextAttrEx& currentStyle, const wxTextAttrEx& thisStyle, const wxTextAttrEx& paraStyle, wxOutputStream& stream)
{
wxTextOutputStream str(stream);
- //Is the item bulleted one?
- if( thisStyle.GetBulletStyle() != wxTEXT_ATTR_BULLET_STYLE_NONE )
+ // Is the item a bulleted one?
+ if ( paraStyle.GetBulletStyle() != wxTEXT_ATTR_BULLET_STYLE_NONE )
{
- //Is there any opened list?
- if( m_list )
+ // Is there any opened list?
+ if (m_list)
{
- //Yes there is
+ // Yes there is
- //Is the item among the previous ones
- //Is the item one of the previous list tag's child items
- if( (thisStyle.GetLeftIndent() == (m_indent + 100)) || (thisStyle.GetLeftIndent() < 100) )
- str << wxT(" ");//Yes it is
+ // Is the item among the previous ones?
+ // Is the item one of the previous list tag's child items?
+ if ((paraStyle.GetLeftIndent() == (m_indent + 100)) || (paraStyle.GetLeftIndent() < 100))
+ str << wxT(""); //Yes it is
else
{
- //No it isn't
-
- //So we should close the list tag
+ // No it isn't, so we should close the list tag
str << (m_is_ul ? wxT("") : wxT(""));
- //And renavigate to new list's horizontal position
- NavigateToListPosition(thisStyle, str);
- //Ok it's done
+ // And renavigate to new list's horizontal position
+ NavigateToListPosition(paraStyle, str);
- //Get the appropriate tag, an ol for numerical values, an ul for dot, square etc.
+ // Get the appropriate tag, an ol for numerical values, an ul for dot, square etc.
wxString tag;
- TypeOfList(thisStyle, tag);
+ TypeOfList(paraStyle, tag);
str << tag << wxT("");
}
}
else
{
- //No there isn't a list
+ // No there isn't a list.
+ // navigate to new list's horizontal position(indent)
+ NavigateToListPosition(paraStyle, str);
- //navigate to new list's horizontal position(indent)
- NavigateToListPosition(thisStyle, str);
-
- //Get the appropriate tag, an ol for numerical values, an ul for dot, square etc.
+ // Get the appropriate tag, an ol for numerical values, an ul for dot, square etc.
wxString tag;
- TypeOfList(thisStyle, tag);
+ TypeOfList(paraStyle, tag);
str << tag << wxT("");
- //Now we have a list, mark it.
+ // Now we have a list, mark it.
m_list = true;
}
}
else if( m_list )
{
- //The item is not bulleted and there is a list what should be closed now.
- //So close the list
+ // The item is not bulleted and there is a list what should be closed now.
+ // So close the list
str << (m_is_ul ? wxT("") : wxT(""));
- //And mark as there is no an opened list
+
+ // And mark as there is no an opened list
m_list = false;
}
// does the item have an indentation ?
- if( thisStyle.GetLeftIndent() )
+ if( paraStyle.GetLeftIndent() )
{
- if( thisStyle.GetBulletStyle() == wxTEXT_ATTR_BULLET_STYLE_NONE )
+ if (paraStyle.GetBulletStyle() == wxTEXT_ATTR_BULLET_STYLE_NONE)
{
- if( m_indent )
+ if (m_indent)
{
- if( (thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent()) == m_indent )
+ if ((paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent()) == m_indent)
{
- if( thisStyle.GetLeftSubIndent() < 0 )
+ if (paraStyle.GetLeftSubIndent() < 0)
{
- str << SymbolicIndent(~thisStyle.GetLeftSubIndent());
+ str << SymbolicIndent(~paraStyle.GetLeftSubIndent());
}
}
else
{
- if( thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent() > m_indent )
+ if (paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent() > m_indent)
{
- Indent(thisStyle, str);
- m_indent = thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent();
+ Indent(paraStyle, str);
+ m_indent = paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent();
m_indents.Add( m_indent );
}
else
{
int i = m_indents.size() - 1;
- for(; i > -1; i--)
+ for (; i > -1; i--)
{
- if( m_indent < (thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent()) )
+ if (m_indent < (paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent()))
{
- Indent(thisStyle, str);
- m_indent = thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent();
+ Indent(paraStyle, str);
+ m_indent = paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent();
m_indents.Add( m_indent );
break;
}
- else if( m_indent == (thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent()) )
+ else if (m_indent == (paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent()))
{
- if( thisStyle.GetLeftSubIndent() < 0 )
+ if (paraStyle.GetLeftSubIndent() < 0)
{
- str << SymbolicIndent(~thisStyle.GetLeftSubIndent());
+ str << SymbolicIndent(~paraStyle.GetLeftSubIndent());
}
break;
}
@@ -240,7 +227,10 @@ void wxRichTextHTMLHandler::BeginCharacterFormatting(const wxTextAttrEx& current
m_indents.RemoveAt(i);
- if( i < 1 ){m_indent=0; break;}
+ if(i < 1)
+ {
+ m_indent=0; break;
+ }
m_indent = m_indents[i-1];
}
}
@@ -249,18 +239,17 @@ void wxRichTextHTMLHandler::BeginCharacterFormatting(const wxTextAttrEx& current
}
else
{
- Indent(thisStyle, str);
- m_indent = thisStyle.GetLeftIndent() + thisStyle.GetLeftSubIndent();
+ Indent(paraStyle, str);
+ m_indent = paraStyle.GetLeftIndent() + paraStyle.GetLeftSubIndent();
m_indents.Add( m_indent );
}
}
}
- else if( m_indent )
+ else if (m_indent)
{
- //The item is not indented and there is a table(s) what should be closed now.
+ // The item is not indented and there is a table(s) that should be closed now.
- //So close them
- for(unsigned int i = 0; i < m_indents.size(); i++ )
+ for (unsigned int i = 0; i < m_indents.size(); i++)
str << wxT(" | ");
m_indent = 0;
@@ -270,40 +259,52 @@ void wxRichTextHTMLHandler::BeginCharacterFormatting(const wxTextAttrEx& current
wxString style;
- //Is there any change on the font properties of the item
- if( thisStyle.GetFont().GetFaceName() != currentStyle.GetFont().GetFaceName() )
- style += wxString::Format(wxT(" face=\"%s\""), thisStyle.GetFont().GetFaceName().c_str());
- if( thisStyle.GetFont().GetPointSize() != currentStyle.GetFont().GetPointSize() )
- style += wxString::Format(wxT(" size=\"%ld\""), Pt_To_Size(thisStyle.GetFont().GetPointSize()) );
- if( thisStyle.GetTextColour() != currentStyle.GetTextColour() )
- style += wxString::Format(wxT(" color=\"%s\""), thisStyle.GetTextColour().GetAsString(wxC2S_HTML_SYNTAX).c_str());
+ // Is there any change in the font properties of the item?
+ if (thisStyle.GetFont().GetFaceName() != currentStyle.GetFont().GetFaceName())
+ {
+ wxString faceName(thisStyle.GetFont().GetFaceName());
+ style += wxString::Format(wxT(" face=\"%s\""), faceName.c_str());
+ }
+ if (thisStyle.GetFont().GetPointSize() != currentStyle.GetFont().GetPointSize())
+ style += wxString::Format(wxT(" size=\"%ld\""), PtToSize(thisStyle.GetFont().GetPointSize()));
+ if (thisStyle.GetTextColour() != currentStyle.GetTextColour() )
+ {
+ wxString color(thisStyle.GetTextColour().GetAsString(wxC2S_HTML_SYNTAX));
+ style += wxString::Format(wxT(" color=\"%s\""), color.c_str());
+ }
- if( style.size() )
+ if (style.size())
{
str << wxString::Format(wxT(""), style.c_str());
m_font = true;
}
- if( thisStyle.GetFont().GetWeight() == wxBOLD )
+ if (thisStyle.GetFont().GetWeight() == wxBOLD)
str << wxT("");
- if( thisStyle.GetFont().GetStyle() == wxITALIC )
+ if (thisStyle.GetFont().GetStyle() == wxITALIC)
str << wxT("");
- if( thisStyle.GetFont().GetUnderlined() )
+ if (thisStyle.GetFont().GetUnderlined())
str << wxT("");
+
+ if (thisStyle.HasURL())
+ str << wxT("");
}
-void wxRichTextHTMLHandler::EndCharacterFormatting(const wxTextAttrEx& WXUNUSED(currentStyle), const wxTextAttrEx& thisStyle, wxOutputStream& stream)
+void wxRichTextHTMLHandler::EndCharacterFormatting(const wxTextAttrEx& WXUNUSED(currentStyle), const wxTextAttrEx& thisStyle, const wxTextAttrEx& WXUNUSED(paraStyle), wxOutputStream& stream)
{
wxTextOutputStream str(stream);
- if( thisStyle.GetFont().GetUnderlined() )
+ if (thisStyle.HasURL())
+ str << wxT("");
+
+ if (thisStyle.GetFont().GetUnderlined())
str << wxT("");
- if( thisStyle.GetFont().GetStyle() == wxITALIC )
+ if (thisStyle.GetFont().GetStyle() == wxITALIC)
str << wxT("");
- if( thisStyle.GetFont().GetWeight() == wxBOLD )
+ if (thisStyle.GetFont().GetWeight() == wxBOLD)
str << wxT("");
- if( m_font )
+ if (m_font)
{
m_font = false;
str << wxT("");
@@ -313,83 +314,83 @@ void wxRichTextHTMLHandler::EndCharacterFormatting(const wxTextAttrEx& WXUNUSED(
/// Output paragraph formatting
void wxRichTextHTMLHandler::OutputParagraphFormatting(const wxTextAttrEx& WXUNUSED(currentStyle), const wxTextAttrEx& thisStyle, wxOutputStream& stream)
{
- //If there is no opened list currently, insert a after every paragraph
- if(!m_list)
+ // If there is no opened list currently, insert a after every paragraph
+ if (!m_list)
{
wxTextOutputStream str(stream);
- wxString align = GetAlignment( thisStyle );
+ wxString align = GetAlignment(thisStyle);
str << wxString::Format(wxT(" "), align.c_str());
}
}
void wxRichTextHTMLHandler::NavigateToListPosition(const wxTextAttrEx& thisStyle, wxTextOutputStream& str)
{
- //indenting an item using an ul/ol tag is equal to inserting 5 x on its left side.
- //so we should start from 100 point left
+ // indenting an item using an ul/ol tag is equal to inserting 5 x on its left side.
+ // so we should start from 100 point left
- //Is the second td's left wall of the current indentaion table at the 100+ point-left-side
- //of the item, horizontally?
- if( m_indent + 100 < thisStyle.GetLeftIndent() )
+ // Is the second td's left wall of the current indentaion table at the 100+ point-left-side
+ // of the item, horizontally?
+ if (m_indent + 100 < thisStyle.GetLeftIndent())
{
- //yes it is
+ // yes it is
LIndent(thisStyle, str);
m_indent = thisStyle.GetLeftIndent() - 100;
m_indents.Add( m_indent );
return;
}
- //No it isn't
+ // No it isn't
int i = m_indents.size() - 1;
- for(; i > -1; i--)
+ for (; i > -1; i--)
{
//Is the second td's left wall of the current indentaion table at the 100+ point-left-side
//of the item ?
- if( m_indent + 100 < thisStyle.GetLeftIndent() )
+ if (m_indent + 100 < thisStyle.GetLeftIndent())
{
- //Yes it is
+ // Yes it is
LIndent(thisStyle, str);
m_indent = thisStyle.GetLeftIndent() - 100;
m_indents.Add( m_indent );
break;
}
- else if( m_indent + 100 == thisStyle.GetLeftIndent() )
- break;//exact match
+ else if (m_indent + 100 == thisStyle.GetLeftIndent())
+ break; //exact match
else
{
- //No it is not, the second td's left wall of the current indentaion table is at the
+ // No it is not, the second td's left wall of the current indentaion table is at the
//right side of the current item horizontally, so close it.
str << wxT(" |