[logaling-commit] logaling/logaling-command [refactor-structure] Change to be able to specify the output of the renderer

Back to archive index

null+****@clear***** null+****@clear*****
Thu Jun 7 16:19:42 JST 2012


SHIMADA Koji	2012-06-07 16:19:42 +0900 (Thu, 07 Jun 2012)

  New Revision: 9b6efa1979c3ea20ec9a90763ca9ebdd68811813

  Log:
    Change to be able to specify the output of the renderer

  Modified files:
    lib/logaling/command/application.rb
    lib/logaling/command/renderers.rb

  Modified: lib/logaling/command/application.rb (+3 -3)
===================================================================
--- lib/logaling/command/application.rb    2012-06-06 22:27:50 +0900 (457e0f1)
+++ lib/logaling/command/application.rb    2012-06-07 16:19:42 +0900 (4ee72c5)
@@ -241,15 +241,15 @@ module Logaling::Command
           when "terminal"
             term_renderer = Logaling::Command::Renderers::TermDefaultRenderer.new(term, @repository, @config, options)
             term_renderer.max_str_size = max_str_size
-            term_renderer.render
+            term_renderer.render($stdout)
           when "csv"
             term_renderer = Logaling::Command::Renderers::TermCsvRenderer.new(term, @repository, @config, options)
-            term_renderer.render
+            term_renderer.render($stdout)
           when "json"
             term_renderer = Logaling::Command::Renderers::TermJsonRenderer.new(term, @repository, @config, options)
             term_renderer.index = i
             term_renderer.last_index = terms.length
-            term_renderer.render
+            term_renderer.render($stdout)
           end
         end
       else

  Modified: lib/logaling/command/renderers.rb (+9 -9)
===================================================================
--- lib/logaling/command/renderers.rb    2012-06-06 22:27:50 +0900 (8750238)
+++ lib/logaling/command/renderers.rb    2012-06-07 16:19:42 +0900 (84e27ec)
@@ -8,7 +8,7 @@ module Logaling::Command
         @options = options
       end
 
-      def render; end
+      def render(out); end
 
       def glossary_name
         if****@repos*****_counts > 1
@@ -61,9 +61,9 @@ module Logaling::Command
         @max_str_size = 0
       end
 
-      def render
+      def render(out)
         format = [target_term, note, glossary_name].compact.join("\t")
-        printf("  %-#{@max_str_size+10}s %s\n", source_term, format)
+        out.printf("  %-#{@max_str_size+10}s %s\n", source_term, format)
       end
 
       def note
@@ -73,10 +73,10 @@ module Logaling::Command
     end
 
     class TermCsvRenderer < TermRenderer
-      def render
+      def render(out)
         items = [source_term, target_term, note,
                  @config.source_language, @config.target_language]
-        print(CSV.generate {|csv| csv << items})
+        out.print(CSV.generate {|csv| csv << items})
       end
     end
 
@@ -89,15 +89,15 @@ module Logaling::Command
         @last_index = 0
       end
 
-      def render
-        first_line? ? puts("[") : puts(",")
+      def render(out)
+        first_line? ? out.puts("[") : out.puts(",")
         record = {
           :source => source_term, :target => target_term, :note => note,
           :source_language => @config.source_language,
           :target_language => @config.target_language
         }
-        print JSON.pretty_generate(record)
-        puts("\n]") if last_line?
+        out.print JSON.pretty_generate(record)
+        out.puts("\n]") if last_line?
       end
 
       private




More information about the logaling-commit mailing list
Back to archive index