Sha256: 69c5e2a9061f309f57d2176af5a4a6abd711a0b8a4d74db0d8c9cc7e550dffc9
Contents?: true
Size: 1.82 KB
Versions: 1
Compression:
Stored size: 1.82 KB
Contents
# -*- encoding: utf-8 -*- module Genit # Compile a single page. class PageCompiler # Public: Constructor. # # working_dir - The String working directory, where live the project. # filename - The String name of the page def initialize working_dir, filename @working_dir = working_dir @filename = filename @template = XmlDocument.open(File.join(@working_dir, 'templates/main.html')) end # Public: Compile the page. # # Returns a Nokogiri::XML document. def compile compile_body compile_head builder = ScriptBuilder.new @template builder.build_for_page @filename end private def compile_body # Pourquoi 2 fois ? # Parce que la 1ere fois, on inclus essentiellement la page au sein du # template, et la seconde fois, on s'occupe des tags restants (ceux qui # étaient dans la page). # Suivant comment la hiérarchie de tag évoluera, il est possible qu'on # ai un jour besoin de faire une boucle du genre : # "Tant qu'il reste des tags" 2.times { replace_all_genit_tags } builder = BodyLinkBuilder.new @template @template = builder.build_for_page @filename builder = ImgBuilder.new @template @template = builder.build_for_page @filename end def replace_all_genit_tags genit_tags_in_template.each do |tag| next if tag.genit_what? tp = TagProcessor.new(@working_dir, @template, @filename, tag) @template = tp.process end end def compile_head builder = HeadLinkBuilder.new @template builder.build_for_page @filename end # Returns all <genit> tags found in the template. def genit_tags_in_template HtmlDocument.genit_tags_from @template end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
genit-0.9 | lib/genit/project/page_compiler.rb |