Class: Twine::Runner
- Inherits:
-
Object
- Object
- Twine::Runner
- Defined in:
- lib/twine/runner.rb
Class Method Summary collapse
Instance Method Summary collapse
- #consume_all_string_files ⇒ Object
- #consume_loc_drop ⇒ Object
- #consume_string_file ⇒ Object
- #generate_all_string_files ⇒ Object
- #generate_loc_drop ⇒ Object
- #generate_string_file ⇒ Object
-
#initialize(options = {}, strings = StringsFile.new) ⇒ Runner
constructor
A new instance of Runner.
- #validate_strings_file ⇒ Object
- #write_strings_data(path) ⇒ Object
Constructor Details
#initialize(options = {}, strings = StringsFile.new) ⇒ Runner
Returns a new instance of Runner.
33 34 35 36 |
# File 'lib/twine/runner.rb', line 33 def initialize( = {}, strings = StringsFile.new) = @strings = strings end |
Class Method Details
.run(args) ⇒ Object
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# File 'lib/twine/runner.rb', line 8 def self.run(args) = CLI.parse(args) strings = StringsFile.new strings.read [:strings_file] runner = new(, strings) case [:command] when 'generate-string-file' runner.generate_string_file when 'generate-all-string-files' runner.generate_all_string_files when 'consume-string-file' runner.consume_string_file when 'consume-all-string-files' runner.consume_all_string_files when 'generate-loc-drop' runner.generate_loc_drop when 'consume-loc-drop' runner.consume_loc_drop when 'validate-strings-file' runner.validate_strings_file end end |
Instance Method Details
#consume_all_string_files ⇒ Object
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 |
# File 'lib/twine/runner.rb', line 86 def consume_all_string_files if !File.directory?([:input_path]) raise Twine::Error.new("Directory does not exist: #{@options[:output_path]}") end Dir.glob(File.join([:input_path], "**/*")) do |item| if File.file?(item) begin read_string_file(item) rescue Twine::Error => e Twine::stderr.puts "#{e.message}" end end end output_path = [:output_path] || [:strings_file] write_strings_data(output_path) end |
#consume_loc_drop ⇒ Object
132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 |
# File 'lib/twine/runner.rb', line 132 def consume_loc_drop require_rubyzip if !File.file?([:input_path]) raise Twine::Error.new("File does not exist: #{@options[:input_path]}") end Dir.mktmpdir do |dir| Zip::File.open([:input_path]) do |zipfile| zipfile.each do |entry| if !entry.name.end_with?'/' and !File.basename(entry.name).start_with?'.' real_path = File.join(dir, entry.name) FileUtils.mkdir_p(File.dirname(real_path)) zipfile.extract(entry.name, real_path) begin read_string_file(real_path) rescue Twine::Error => e Twine::stderr.puts "#{e.message}" end end end end end output_path = [:output_path] || [:strings_file] write_strings_data(output_path) end |
#consume_string_file ⇒ Object
75 76 77 78 79 80 81 82 83 84 |
# File 'lib/twine/runner.rb', line 75 def consume_string_file lang = nil if [:languages] lang = [:languages][0] end read_string_file([:input_path], lang) output_path = [:output_path] || [:strings_file] write_strings_data(output_path) end |
#generate_all_string_files ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
# File 'lib/twine/runner.rb', line 54 def generate_all_string_files validate_strings_file if [:validate] if !File.directory?([:output_path]) if [:create_folders] FileUtils.mkdir_p([:output_path]) else raise Twine::Error.new("Directory does not exist: #{@options[:output_path]}") end end formatter_for_directory = find_formatter { |f| f.can_handle_directory?([:output_path]) } formatter = formatter_for_format([:format]) || formatter_for_directory unless formatter raise Twine::Error.new "Could not determine format given the contents of #{@options[:output_path]}" end formatter.write_all_files([:output_path]) end |
#generate_loc_drop ⇒ Object
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 |
# File 'lib/twine/runner.rb', line 105 def generate_loc_drop validate_strings_file if [:validate] require_rubyzip if File.file?([:output_path]) File.delete([:output_path]) end Dir.mktmpdir do |dir| Zip::File.open([:output_path], Zip::File::CREATE) do |zipfile| zipfile.mkdir('Locales') formatter = formatter_for_format([:format]) @strings.language_codes.each do |lang| if [:languages] == nil || [:languages].length == 0 || [:languages].include?(lang) file_name = lang + formatter.extension real_path = File.join(dir, file_name) zip_path = File.join('Locales', file_name) formatter.write_file(real_path, lang) zipfile.add(zip_path, real_path) end end end end end |
#generate_string_file ⇒ Object
45 46 47 48 49 50 51 52 |
# File 'lib/twine/runner.rb', line 45 def generate_string_file validate_strings_file if [:validate] lang = nil lang = [:languages][0] if [:languages] write_string_file([:output_path], lang) end |
#validate_strings_file ⇒ Object
160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 |
# File 'lib/twine/runner.rb', line 160 def validate_strings_file total_strings = 0 all_keys = Set.new duplicate_keys = Set.new = Set.new invalid_keys = Set.new valid_key_regex = /^[A-Za-z0-9_]+$/ @strings.sections.each do |section| section.rows.each do |row| total_strings += 1 duplicate_keys.add(row.key) if all_keys.include? row.key all_keys.add(row.key) .add(row.key) if row. == nil or row..length == 0 invalid_keys << row.key unless row.key =~ valid_key_regex end end errors = [] join_keys = lambda { |set| set.map { |k| " " + k }.join("\n") } unless duplicate_keys.empty? errors << "Found duplicate string key(s):\n#{join_keys.call(duplicate_keys)}" end if [:pedantic] if .length == total_strings errors << "None of your strings have tags." elsif .length > 0 errors << "Found strings without tags:\n#{join_keys.call(keys_without_tags)}" end end unless invalid_keys.empty? errors << "Found key(s) with invalid characters:\n#{join_keys.call(invalid_keys)}" end raise Twine::Error.new errors.join("\n\n") unless errors.empty? Twine::stdout.puts "#{@options[:strings_file]} is valid." end |
#write_strings_data(path) ⇒ Object
38 39 40 41 42 43 |
# File 'lib/twine/runner.rb', line 38 def write_strings_data(path) if [:developer_language] @strings.set_developer_language_code([:developer_language]) end @strings.write(path) end |