compleatang/legal-markdown

View on GitHub
lib/legal_markdown/legal_to_markdown/load_source.rb

Summary

Maintainability
A
2 hrs
Test Coverage
module LegalToMarkdown
  extend self

  class FileToParse

    attr_accessor :headers, :content, :mixins, :leaders, :docinfo, :writer

    def initialize(file, output)
      @input_file = file; @headers = nil; @content = ""; @writer = output
      load; get_the_partials; parse; set_the_parsers
      @orig_headers = @headers.clone if @headers
    end

    private

    def load
      if @input_file != "-"
        @content = get_file(@input_file)
      elsif @input_file == "-"
        @content = STDIN.read
      end
      if @content == nil
        puts "No input file or stdin specified. Please specify a file or \"-\" for stdin."
        exit 0
      end
    end

    def get_the_partials
      if @content[/^@include/]
        @content.scan(/^(@include (.+)$)/).each do |set|
          partial_file = set[1]
          to_replace = set[0]
          partial_contents = get_file partial_file
          @content.gsub!(to_replace, partial_contents)
        end
      end
    end

    def parse
      require 'yaml'
      today_is_the_day if @content[/@today/]
      yaml_pattern = /\A(---\s*\n.*?\n?)^(---\s*$\n?)/m
      parts = @content.partition yaml_pattern
      if parts[1] != ""
        parts[1] = string_guard parts[1]
        @headers = YAML.load parts[1]
        @content = parts[2]
      end
    end

    def set_the_parsers
      if @content[/\{\{/] && @headers
        self.extend LegalToMarkdown::Mixins
        @mixins = true
      end
      if @content[/^```/] && @headers
        self.extend LegalToMarkdown::Leaders
        @leaders = true
      end
      if @headers && ! @headers.keys.select{|k| k.to_s[/meta/] }.empty?
        self.extend LegalToMarkdown::Meta
        @docinfo = true
      end
      if @writer == :jason
        self.extend LegalToMarkdown::JasonBuilder
      end
    end

    def get_file( file )
      begin
        f = File::read(file)
        if f[1] == "\u0000" then f = f.force_encoding('utf-16le').encode('utf-8') end
        f.gsub!("\xEF\xBB\xBF".force_encoding("UTF-8"), '')
        f.gsub!("\xC3\xAF\xC2\xBB\xC2\xBF".force_encoding("UTF-8"), '')
        f.gsub!("\r", '')
        f.force_encoding("UTF-8")
        f
      rescue => e
        puts "Sorry, I could not read the file #{file}: #{e.message}."
        exit 0
      end
    end

    def today_is_the_day
      require 'date'
      d = Date.today.strftime("%-d %B, %Y")
      @content.gsub!(/@today/, d)
    end

    def string_guard strings
      strings.scan(/\:(\S.*)$/){ |m| strings = strings.gsub( m[0], " " + m[0] ) }
      strings.scan(/^((level-\d+:)(.+)\"*)$/) do |m|
        line = m[0]; level = m[1]; field = m[2].strip.delete "\""
        if field =~ /[^\.\)]\z/
          strings = strings.gsub(line, level + " \"" + field + ".\"")
        else
          strings = strings.gsub(line, level + " \"" + field + "\"")
        end
      end
      strings
    end
  end
end