Class: Twine::Formatters::Django

Inherits:
Abstract
  • Object
show all
Defined in:
lib/twine/formatters/django.rb

Instance Attribute Summary

Attributes inherited from Abstract

#options, #strings

Instance Method Summary collapse

Methods inherited from Abstract

#escape_quotes, #format_key_value, #format_section, #format_sections, #initialize, #output_path_for_language, #set_comment_for_key, #set_translation_for_key, #should_include_row

Constructor Details

This class inherits a constructor from Twine::Formatters::Abstract

Instance Method Details

#can_handle_directory?(path) ⇒ Boolean

Returns:

  • (Boolean)


12
13
14
# File 'lib/twine/formatters/django.rb', line 12

def can_handle_directory?(path)
  Dir.entries(path).any? { |item| /^.+\.po$/.match(item) }
end

#default_file_nameObject



16
17
18
# File 'lib/twine/formatters/django.rb', line 16

def default_file_name
  return 'strings.po'
end

#determine_language_given_path(path) ⇒ Object



20
21
22
23
24
25
26
27
28
29
30
# File 'lib/twine/formatters/django.rb', line 20

def determine_language_given_path(path)
    path_arr = path.split(File::SEPARATOR)
    path_arr.each do |segment|
        match = /(..)\.po$/.match(segment)
        if match
            return match[1]
        end
    end
    
  return
end

#extensionObject



8
9
10
# File 'lib/twine/formatters/django.rb', line 8

def extension
  '.po'
end

#format_base_translation(row) ⇒ Object



84
85
86
87
# File 'lib/twine/formatters/django.rb', line 84

def format_base_translation(row)
  base_translation = row.translations[@default_lang]
  "# base translation: \"#{base_translation}\"\n" if base_translation
end

#format_comment(row, lang) ⇒ Object



94
95
96
# File 'lib/twine/formatters/django.rb', line 94

def format_comment(row, lang)
  "#. #{escape_quotes(row.comment)}\n" if row.comment
end

#format_file(lang) ⇒ Object



65
66
67
68
69
70
# File 'lib/twine/formatters/django.rb', line 65

def format_file(lang)
  @default_lang = @strings.language_codes[0]
  result = super
  @default_lang = nil
  result
end

#format_header(lang) ⇒ Object



72
73
74
# File 'lib/twine/formatters/django.rb', line 72

def format_header(lang)
  "##\n # Django Strings File\n # Generated by Twine #{Twine::VERSION}\n # Language: #{lang}\n"
end

#format_key(key) ⇒ Object



98
99
100
# File 'lib/twine/formatters/django.rb', line 98

def format_key(key)
  escape_quotes(key)
end

#format_nameObject



4
5
6
# File 'lib/twine/formatters/django.rb', line 4

def format_name
  'django'
end

#format_row(row, lang) ⇒ Object



80
81
82
# File 'lib/twine/formatters/django.rb', line 80

def format_row(row, lang)
  [format_comment(row, lang), format_base_translation(row), format_key_value(row, lang)].compact.join
end

#format_section_header(section) ⇒ Object



76
77
78
# File 'lib/twine/formatters/django.rb', line 76

def format_section_header(section)
  "#--------- #{section.name} ---------#\n"
end

#format_value(value) ⇒ Object



102
103
104
# File 'lib/twine/formatters/django.rb', line 102

def format_value(value)
  escape_quotes(value)
end

#key_value_patternObject



89
90
91
92
# File 'lib/twine/formatters/django.rb', line 89

def key_value_pattern
  "msgid \"%{key}\"\n" +
  "msgstr \"%{value}\"\n"
end

#read(io, lang) ⇒ Object



32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
# File 'lib/twine/formatters/django.rb', line 32

def read(io, lang)
  comment_regex = /#\. *"?(.*)"?$/
  key_regex = /msgid *"(.*)"$/
  value_regex = /msgstr *"(.*)"$/m

  last_comment = nil
  while line = io.gets          
    comment_match = comment_regex.match(line)
    if comment_match
      comment = comment_match[1]
    end

    key_match = key_regex.match(line)
    if key_match
      key = key_match[1].gsub('\\"', '"')
    end
    value_match = value_regex.match(line)
    if value_match
      value = value_match[1].gsub(/"\n"/, '').gsub('\\"', '"')
    end

    if key and key.length > 0 and value and value.length > 0
      set_translation_for_key(key, lang, value)
      if comment and comment.length > 0 and !comment.start_with?("--------- ")
        set_comment_for_key(key, comment)
      end
      key = nil
      value = nil
      comment = nil
    end
  end
end