Class: Coradoc::Html::Converters::CommentLine
- Defined in:
- lib/coradoc/html/converters/comment_line.rb
Class Method Summary collapse
-
.to_coradoc(element, _options = {}) ⇒ Object
Convert HTML comment to CoreModel.
-
.to_html(comment, options = {}) ⇒ Object
Convert CoreModel to HTML comment.
Methods inherited from Base
build_class_attribute, build_element, build_html_attributes, convert_content_to_html, convert_element_to_core, convert_node_to_core, escape_attribute, escape_html, extract_model_attributes, extract_node_attributes, extract_text_fallback, find_converter_class_by_name, find_converter_for_model, handle_unknown_content, render_core_abbreviation, render_core_annotation_block, render_core_bibliography, render_core_bibliography_entry, render_core_block, render_core_block_image, render_core_definition_item, render_core_definition_list, render_core_footnote, render_core_footnote_reference, render_core_inline_element, render_core_inline_image, render_core_list_block, render_core_list_item, render_core_span, render_core_structural_element, render_core_table_cell, render_core_table_row, render_core_term, render_core_toc, render_core_toc_entry, resolve_block_semantic_type, resolve_format_specific_semantic, transform_to_coremodel, treat_children
Class Method Details
.to_coradoc(element, _options = {}) ⇒ Object
Convert HTML comment to CoreModel
39 40 41 42 43 44 45 46 47 48 49 50 |
# File 'lib/coradoc/html/converters/comment_line.rb', line 39 def self.to_coradoc(element, = {}) return nil unless element.comment? # Extract comment text text = element.text.to_s.strip # For now, return an InlineElement with special format_type for comment Coradoc::CoreModel::InlineElement.new( format_type: 'comment', content: text ) end |
.to_html(comment, options = {}) ⇒ Object
Convert CoreModel to HTML comment
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
# File 'lib/coradoc/html/converters/comment_line.rb', line 8 def self.to_html(comment, = {}) return '' unless comment # Check if comments should be preserved return '' unless [:preserve_comments] # Get comment text - check for content or text attribute text = if comment.content comment.content elsif comment.text comment.text else '' end text = text.to_s # HTML comments cannot contain -- # Replace -- with - - to avoid breaking the comment safe_text = text.gsub('--', '- -') # Preserve newlines in comment text # Empty comments (just "//") should become newlines in HTML comments if safe_text.strip.empty? "<!--\n-->" else "<!-- #{escape_html(safe_text)} -->" end end |