Method: ConverterBase#insert_char_separator

Defined in:
lib/converterbase.rb

#insert_char_separator(str) ⇒ Object

文字単位でzwsを挿入する



1225
1226
1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
1270
1271
# File 'lib/converterbase.rb', line 1225

def insert_char_separator(str)
  buffer = ""
  ss = StringScanner.new(str)
  before_symbol = false
  while char = ss.getch
    symbol = false
    case char
    when ""
      buffer << char
      if ss.scan(/.+?》/)
        buffer << "#{ss.matched}"
      else
        before_symbol = false
      end
      next
    when ""
      buffer << char
      if ss.scan(/^#.+?]/)
        buffer << "#{ss.matched}"
      else
        before_symbol = false
      end
      next
    when "<"
      if ss.scan(/.+?>/)
        buffer << "<#{ss.matched}"
        next
      end
      symbol = true
    when /[〔「『\((【〈《≪〝]/
      buffer << char
      before_symbol = false
      next
    when /[―…!?!?※]/
      symbol = true
    end
    if before_symbol && !symbol
      buffer << WORD_SEPARATOR
    end
    buffer << char
    unless symbol
      buffer << WORD_SEPARATOR
    end
    before_symbol = symbol
  end
  buffer
end