You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

csv.rb 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006-2019 Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. require 'csv'
  19. module Redmine
  20. module Export
  21. module CSV
  22. def self.generate(*args, &block)
  23. Base.generate(*args, &block)
  24. end
  25. class Base < ::CSV
  26. include Redmine::I18n
  27. class << self
  28. def generate(options = {}, &block)
  29. col_sep = l(:general_csv_separator)
  30. encoding = Encoding.find(options[:encoding]) rescue Encoding.find(l(:general_csv_encoding))
  31. str =
  32. if encoding == Encoding::UTF_8
  33. +"\xEF\xBB\xBF" # BOM
  34. else
  35. (+'').force_encoding(encoding)
  36. end
  37. super(str, :col_sep => col_sep, :encoding => encoding, &block)
  38. end
  39. end
  40. def <<(row)
  41. row = row.map do |field|
  42. case field
  43. when String
  44. Redmine::CodesetUtil.from_utf8(field, self.encoding.name)
  45. when Float
  46. @decimal_separator ||= l(:general_csv_decimal_separator)
  47. ("%.2f" % field).gsub('.', @decimal_separator)
  48. else
  49. field
  50. end
  51. end
  52. super row
  53. end
  54. end
  55. end
  56. end
  57. end