# test_lib_src2md.rb require_relative '../lib/lib_src2md.rb' # Many kinds of file types are supported. # .c => C, .h => C, .rb => ruby, Rakefile, => ruby, .xml => xml, .ui => xml, .y => bison, .lex => lex, .build => meson, .md => markdown, Makefile => makefile sample_c = <<'EOS' /* This comment is very long, longer than 100. It must be folded if this file is converted to latex. Because latex doesn't care about verbatim lines. The lines are printed as they are. */ #include void printf_something (char *something) { printf ("%s\n", something); } int main (int argc, char **argv) { printf_something ("Hello world."); } EOS sample_h = <<'EOS' #include EOS sample_rb = <<'EOS' print "Hello ruby.\n" EOS rakefile = <<'EOS' task default: "a.out" file "a.out" => "sample.c" do sh "gcc sample.c" end EOS sample_xml = <<'EOS'
Fatal error!!
EOS sample_ui = <<'EOS' EOS sample_y = <<'EOS' program: statement | program statement ; EOS sample_lex = <<'EOS' [a-zA-Z0-9] return ALNUM; EOS sample_build = <<'EOS' project('sampe', 'c') EOS sample0_md = <<'EOS' # Sample text in maridown language EOS makefile = <<'EOS' a.out: sample.c cc sample.c EOS sample_src_md = <<'EOS' # Sample.src.md This .src.md file is made for the test for lib_src2md.rb. Sample.c with line number is: @@@include sample.c @@@ The following is also Sample.c with line number. @@@include -n sample.c @@@ The following is Sample.c without line number. @@@include -N sample.c @@@ The following prints only `printf_something`. @@@include sample.c printf_something @@@ The following prints `printf_something` and `main`. @@@include sample.c printf_something main @@@ Check info string. @@@include sample.c sample.h sample.rb Rakefile sample.xml sample.ui sample.y sample.lex sample.build sample0.md @@@ Compile sample.c with rake like this: @@@shell rake @@@ @@@shell echo "This text is very long, longer than 100. It must be folded if this file is converted to latex. Because latex doesn't care about verbatim lines. The lines are printed as they are." @@@ The target type is: @@@if gfm gfm @@@elif html html @@@elif latex latex @@@end [Relative link](sample.c) will be converted when the target type is gfm or html. Otherwise (latex) the link will be removed. Another [relative link](../../Rakefile). [Absolute link](https://github.com/ToshioCP) is kept as it is. Image link. If the target type is gfm or html, the size will be removed. Otherwise (latex) it remains. ![Screenshot of the box](../../image/screenshot_lb4.png){width=6.3cm height=5.325cm} EOS sample_md = < gtm\n" print " Original link => #{s}\n" print " Relative link temp/sample.c => #{t}\n" print " ** Correct new link must be [sample.c](../test/temp/sample.c) **\n" end # link to a section # srcdir/secXX.src.md is converted to dstdir/secXX.md. # Therefore, secXX.src.md must be changed tp secXX.md. s = "[Section 3](sec3.src.md)" t = change_rel_link s, "test", "gfm" if t != "[Section 3](sec3.md)" print "Relative link change according to base directory change didn't work.\n" print " Base directory test => gtm\n" print " Original link => #{s}\n" print " Relative link temp/sample.c => #{t}\n" print " ** Correct new link must be [Section 2](sec3) **\n" end # --- test src2md dst_dirs = ["gfm", "html", "latex"] dst_dirs.each do |d| Dir.mkdir d unless Dir.exist? d n = d == "latex" ? 86 : -1 src2md "temp/sample.src.md", "#{d}/sample.md", n dst_md = File.read "#{d}/sample.md" if d == "gfm" print "Gfm result didn't match !!\n" if dst_md != sample_md.gsub(/!\[Screenshot of the box\]\(\.\.\/\.\.\/image\/screenshot_lb4\.png\){width=6\.3cm height=5\.325cm}/,"![Screenshot of the box](../../image/screenshot_lb4.png)") elsif d == "html" print "Html result didn't match !!\n" if dst_md != sample_md.gsub(/^gfm$/, "html").gsub(/!\[Screenshot of the box\]\(\.\.\/\.\.\/image\/screenshot_lb4\.png\){width=6\.3cm height=5\.325cm}/,"![Screenshot of the box](../../image/screenshot_lb4.png)") elsif d == "latex" sample_md.gsub!(" 1 /* This comment is very long, longer than 100. It must be folded if this file is converted to latex. Because latex doesn't care about verbatim lines. The lines are printed as they are. */", " 1 /* This comment is very long, longer than 100. It must be folded if this file is co\nnverted to latex. Because latex doesn't care about verbatim lines. The lines are print\ned as they are. */") sample_md.gsub!(/^\/\* This comment is very long, longer than 100\. It must be folded if this file is converted to latex\. Because latex doesn't care about verbatim lines\. The lines are printed as they are\. \*\//, "/* This comment is very long, longer than 100. It must be folded if this file is conve\nrted to latex. Because latex doesn't care about verbatim lines. The lines are printed \nas they are. */") sample_md.gsub!(/\$ echo "This text is very long, longer than 100\. It must be folded if this file is converted to latex\. Because latex doesn't care about verbatim lines\. The lines are printed as they are\."/,"$ echo \"This text is very long, longer than 100. It must be folded if this file is con\nverted to latex. Because latex doesn't care about verbatim lines. The lines are printe\nd as they are.\"") sample_md.gsub!(/^This text is very long, longer than 100\. It must be folded if this file is converted to latex\. Because latex doesn't care about verbatim lines\. The lines are printed as they are\./, "This text is very long, longer than 100. It must be folded if this file is converted t\no latex. Because latex doesn't care about verbatim lines. The lines are printed as the\ny are.") sample_md.gsub!(/^gfm/,"latex") sample_md.gsub!(/\[((R|r)elative link)\]\([^)]+\)/, "\\1") if dst_md != sample_md print "Latex result didn't match !!\n" end else print "Unexpected error.\n" end end # --- clean the temorary files dst_dirs.each do |d| if Dir.exist? d pathname = "#{d}/sample.md" File.delete pathname if File.exist? pathname Dir.rmdir d if Dir.empty? d end end system "rm", "-rf", "temp"