--- loncom/homework/cleanxml/post_xml.pm 2015/12/15 15:33:30 1.3 +++ loncom/homework/cleanxml/post_xml.pm 2016/01/08 20:32:42 1.6 @@ -1,7 +1,7 @@ # The LearningOnline Network # Third step to clean a file. # -# $Id: post_xml.pm,v 1.3 2015/12/15 15:33:30 damieng Exp $ +# $Id: post_xml.pm,v 1.6 2016/01/08 20:32:42 damieng Exp $ # # Copyright Michigan State University Board of Trustees # @@ -45,12 +45,12 @@ use Tie::IxHash; # for ordered hashes no warnings 'recursion'; # yes, fix_paragraph is using heavy recursion, I know # these are constants -my @block_elements = ('parameter','location','answer','foil','image','polygon','rectangle','text','conceptgroup','itemgroup','item','label','data','function','array','unit','answergroup','functionplotresponse','functionplotruleset','functionplotelements','functionplotcustomrule','essayresponse','hintpart','formulahint','numericalhint','reactionhint','organichint','optionhint','radiobuttonhint','stringhint','customhint','mathhint','formulahintcondition','numericalhintcondition','reactionhintcondition','organichintcondition','optionhintcondition','radiobuttonhintcondition','stringhintcondition','customhintcondition','mathhintcondition','imageresponse','foilgroup','datasubmission','textfield','hiddensubmission','radiobuttonresponse','rankresponse','matchresponse','import','style','script','window','block','library','notsolved','part','postanswerdate','preduedate','problem','problemtype','randomlabel','bgimg','labelgroup','randomlist','solved','while','tex','print','web','gnuplot','curve','Task','IntroParagraph','ClosingParagraph','Question','QuestionText','Setup','Instance','InstanceText','Criteria','CriteriaText','GraderNote','languageblock','translated','lang','instructorcomment','dataresponse','togglebox','standalone','comment','drawimage','allow','displayduedate','displaytitle','responseparam','organicstructure','scriptlib','parserlib','drawoptionlist','spline','backgroundplot','plotobject','plotvector','drawvectorsum','functionplotrule','functionplotvectorrule','functionplotvectorsumrule','axis','key','xtics','ytics','title','xlabel','ylabel','hiddenline','dtm'); -my @inline_like_block = ('stringresponse','optionresponse','numericalresponse','formularesponse','mathresponse','organicresponse','reactionresponse','customresponse','externalresponse', 'hint', 'hintgroup'); # inline elements treated like blocks for pretty print and some other things +my @block_elements = ('parameter','location','answer','foil','image','polygon','rectangle','text','conceptgroup','itemgroup','item','label','data','function','array','unit','answergroup','functionplotresponse','functionplotruleset','functionplotelements','functionplotcustomrule','essayresponse','hintpart','formulahint','numericalhint','reactionhint','organichint','optionhint','radiobuttonhint','stringhint','customhint','mathhint','formulahintcondition','numericalhintcondition','reactionhintcondition','organichintcondition','optionhintcondition','radiobuttonhintcondition','stringhintcondition','customhintcondition','mathhintcondition','imageresponse','foilgroup','datasubmission','textfield','hiddensubmission','radiobuttonresponse','rankresponse','matchresponse','import','style','script','window','block','library','notsolved','part','postanswerdate','preduedate','problem','problemtype','randomlabel','bgimg','labelgroup','randomlist','solved','while','tex','print','web','gnuplot','curve','Task','IntroParagraph','ClosingParagraph','Question','QuestionText','Setup','Instance','InstanceText','Criteria','CriteriaText','GraderNote','languageblock','instructorcomment','dataresponse','togglebox','standalone','comment','drawimage','allow','displayduedate','displaytitle','responseparam','organicstructure','scriptlib','parserlib','drawoptionlist','spline','backgroundplot','plotobject','plotvector','drawvectorsum','functionplotrule','functionplotvectorrule','functionplotvectorsumrule','axis','key','xtics','ytics','title','xlabel','ylabel','hiddenline','dtm'); +my @inline_like_block = ('stringresponse','optionresponse','numericalresponse','formularesponse','mathresponse','organicresponse','reactionresponse','customresponse','externalresponse', 'hint', 'hintgroup','translated','lang'); # inline elements treated like blocks for pretty print and some other things my @responses = ('stringresponse','optionresponse','numericalresponse','formularesponse','mathresponse','organicresponse','reactionresponse','customresponse','externalresponse','essayresponse','radiobuttonresponse','matchresponse','rankresponse','imageresponse','functionplotresponse'); my @block_html = ('html','head','body','section','h1','h2','h3','h4','h5','h6','div','p','ul','ol','li','table','tbody','tr','td','th','dl','dt','dd','pre','noscript','hr','address','blockquote','object','applet','embed','map','form','fieldset','iframe','center','frameset'); my @no_newline_inside = ('import','parserlib','scriptlib','data','function','label','xlabel','ylabel','tic','text','rectangle','image','title','h1','h2','h3','h4','h5','h6','li','td','p'); -my @preserve_elements = ('script','answer','pre'); +my @preserve_elements = ('script','answer','pre','style'); my @accepting_style = ('section','h1','h2','h3','h4','h5','h6','div','p','li','td','th','dt','dd','pre','blockquote'); my @latex_math = ('\alpha', '\theta', '\omicron', '\tau', '\beta', '\vartheta', '\pi', '\upsilon', '\gamma', '\gamma', '\varpi', '\phi', '\delta', '\kappa', '\rho', '\varphi', '\epsilon', '\lambda', '\varrho', '\chi', '\varepsilon', '\mu', '\sigma', '\psi', '\zeta', '\nu', '\varsigma', '\omega', '\eta', '\xi', '\Gamma', '\Lambda', '\Sigma', '\Psi', '\Delta', '\Xi', '\Upsilon', '\Omega', '\Theta', '\Pi', '\Phi', @@ -150,7 +150,7 @@ sub fix_structure { # the root element has already been added in pre_xml my $root = $doc->documentElement; # inside the root, replace html, problem and library elements by their content - my @toreplace = ('html','problem','library'); + my @toreplace = ('html','problem','library','Task'); foreach my $name (@toreplace) { my @elements = $root->getElementsByTagName($name); foreach my $element (@elements) { @@ -1812,7 +1812,7 @@ sub remove_useless_notsolved { sub fix_paragraphs_inside { my ($node, $all_block) = @_; # blocks in which paragrahs will be added: - my @blocks_with_p = ('loncapa','library','problem','part','problemtype','window','block','while','postanswerdate','preduedate','solved','notsolved','languageblock','translated','lang','instructorcomment','togglebox','standalone','form'); + my @blocks_with_p = ('loncapa','library','problem','part','problemtype','window','block','while','postanswerdate','preduedate','solved','notsolved','languageblock','instructorcomment','togglebox','standalone','body','form'); my @fix_p_if_br_or_p = (@responses,'foil','item','text','label','hintgroup','hintpart','hint','web','windowlink','div','li','dd','td','th','blockquote'); if ((string_in_array(\@blocks_with_p, $node->nodeName) && paragraph_needed($node)) || (string_in_array(\@fix_p_if_br_or_p, $node->nodeName) && paragraph_inside($node))) { @@ -2394,8 +2394,29 @@ sub pretty { my $type = $node->nodeType; if ($type == XML_ELEMENT_NODE) { my $name = $node->nodeName; - if ((string_in_array($all_block, $name) || string_in_array(\@inline_like_block, $name)) && - !string_in_array(\@preserve_elements, $name)) { + if (string_in_array(\@preserve_elements, $name)) { + # remove newlines at the beginning and the end of preserve elements + if (defined $node->firstChild && ($node->firstChild->nodeType == XML_TEXT_NODE || + $node->firstChild->nodeType == XML_CDATA_SECTION_NODE)) { + my $text = $node->firstChild->nodeValue; + $text =~ s/^\n+//; + if ($text eq '') { + $node->removeChild($node->firstChild); + } else { + $node->firstChild->setData($text); + } + } + if (defined $node->lastChild && ($node->lastChild->nodeType == XML_TEXT_NODE || + $node->lastChild->nodeType == XML_CDATA_SECTION_NODE)) { + my $text = $node->lastChild->nodeValue; + $text =~ s/\n+$//; + if ($text eq '') { + $node->removeChild($node->lastChild); + } else { + $node->lastChild->setData($text); + } + } + } elsif (string_in_array($all_block, $name) || string_in_array(\@inline_like_block, $name)) { # make sure there is a newline at the beginning and at the end if there is anything inside if (defined $node->firstChild && !string_in_array(\@no_newline_inside, $name)) { my $first = $node->firstChild; @@ -2478,26 +2499,6 @@ sub pretty { if ($text eq '') { $node->removeChild($node->lastChild); } else { - $node->lastChild->setData($text); - } - } - } elsif (string_in_array(\@preserve_elements, $name)) { - # collapse newlines at the beginning and the end of scripts - if (defined $node->firstChild && $node->firstChild->nodeType == XML_TEXT_NODE) { - my $text = $node->firstChild->nodeValue; - $text =~ s/^\n( *\n)+/\n/; - if ($text eq '') { - $node->removeChild($node->firstChild); - } else { - $node->firstChild->setData($text); - } - } - if (defined $node->lastChild && $node->lastChild->nodeType == XML_TEXT_NODE) { - my $text = $node->lastChild->nodeValue; - $text =~ s/\n( *\n)+$/\n/; - if ($text eq '') { - $node->removeChild($node->lastChild); - } else { $node->lastChild->setData($text); } }