[logaling-commit] logaling/logaling-command [master] Add 'loga copy' command

Back to archive index

SUZUKI Miho null+****@clear*****
Mon Aug 13 20:29:50 JST 2012


SUZUKI Miho	2012-08-13 20:29:50 +0900 (Mon, 13 Aug 2012)

  New Revision: ede385b990db7386156a2addc5b8728c4d2b6798
  https://github.com/logaling/logaling-command/commit/ede385b990db7386156a2addc5b8728c4d2b6798

  Merged 0b973f2: Merge pull request #76 from logaling/add-loga-copy

  Log:
    Add 'loga copy' command

  Modified files:
    lib/logaling/command/application.rb
    spec/logaling/command_spec.rb

  Modified: lib/logaling/command/application.rb (+19 -1)
===================================================================
--- lib/logaling/command/application.rb    2012-08-13 13:48:12 +0900 (3dc4ed6)
+++ lib/logaling/command/application.rb    2012-08-13 20:29:50 +0900 (c03cf1c)
@@ -54,7 +54,8 @@ module Logaling::Command
         '-U' => :unregister,
         '-L' => :list,
         '-s' => :show,
-        '-v' => :version
+        '-v' => :version,
+        '-c' => :copy
 
     class_option "glossary",        type: :string, aliases: "-g"
     class_option "source-language", type: :string, aliases: "-S"
@@ -356,6 +357,23 @@ module Logaling::Command
       say e.message
     end
 
+    desc 'copy [GLOSSARY NAME] [SOURCE LANGUAGE] [TARGET LANGUAGE] [NEW GLOSSARY NAME] [NEW SOURCE LANGUAGE] [NEW TARGET LANGUAGE]', 'Copy personal glossary'
+    def copy(project_name, source_language, target_language, new_project_name, new_source_language, new_target_language)
+      check_logaling_home_exists
+      project_original =****@repos*****_project(project_name)
+      glossary_original = project_original.glossary(source_language, target_language)
+      glossary_source_path_original = glossary_original.glossary_source.source_path
+
+      project_new =****@repos*****_personal_project(new_project_name, new_source_language, new_target_language)
+      glossary_new = project_new.glossary(new_source_language, new_target_language)
+      glossary_source_path_new = glossary_new.glossary_source.source_path
+
+      FileUtils.copy(glossary_source_path_original, glossary_source_path_new)
+
+    rescue Logaling::CommandFailed, Logaling::GlossaryAlreadyRegistered => e
+      say e.message
+    end
+
     private
     def error(msg)
       STDERR.puts(msg)

  Modified: spec/logaling/command_spec.rb (+30 -0)
===================================================================
--- spec/logaling/command_spec.rb    2012-08-13 13:48:12 +0900 (4aaec17)
+++ spec/logaling/command_spec.rb    2012-08-13 20:29:50 +0900 (02b0733)
@@ -508,8 +508,38 @@ describe Logaling::Command::Application do
     end
   end
 
+  describe '#copy' do
+    let(:copied_glossary_path) { File.join(logaling_home, 'personal', 'spec.en.fr.yml') }
+    before do
+      command.new('spec', 'en', 'ja')
+      command.add('spec logaling', 'すぺっくろがりん')
+    end
+
+    context 'when new glossary does not exist' do
+      before do
+        command.copy('spec', 'en', 'ja', 'spec', 'en', 'fr')
+        @yaml = YAML::load_file(copied_glossary_path).find{|h| h["source_term"] == "spec logaling" }
+      end
+
+      it 'should copy from original glossary' do
+        @yaml.should == {"source_term"=>"spec logaling", "target_term"=>"すぺっくろがりん", "note"=>""}
+      end
+    end
+
+    context 'when same glossary exists in glossary list' do
+      before do
+        @stdout = capture(:stdout) {command.copy('spec', 'en', 'ja', 'spec', 'en', 'ja')}
+      end
+
+      it 'should not copy glossary' do
+        @stdout.should include "already exists"
+      end
+    end
+  end
+
   after do
     FileUtils.rm_rf(logaling_config)
     FileUtils.rm_rf(File.join(logaling_home, 'projects', 'spec'))
+    FileUtils.rm_rf(File.join(logaling_home, 'personal'))
   end
 end
-------------- next part --------------
An HTML attachment was scrubbed...
Download 



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