diff options
-rw-r--r-- | lib/csv.rb | 7 | ||||
-rw-r--r-- | test/csv/interface/test_read.rb | 22 |
2 files changed, 29 insertions, 0 deletions
diff --git a/lib/csv.rb b/lib/csv.rb index 4ffffe4056..a06c92a1b9 100644 --- a/lib/csv.rb +++ b/lib/csv.rb @@ -960,6 +960,11 @@ class CSV # open( filename, mode = "rb", **options ) # open( filename, **options ) # + # possible options elements: + # hash form: + # :undef => :replace # replace undefined conversion + # :replace => string # replacement string ("?" or "\uFFFD" if not specified) + # # This method opens an IO object, and wraps that with CSV. This is intended # as the primary interface for writing a CSV file. # @@ -1021,6 +1026,8 @@ class CSV # wrap a File opened with the remaining +args+ with no newline # decorator file_opts = {universal_newline: false}.merge(options) + options.delete(:undef) + options.delete(:replace) begin f = File.open(filename, mode, **file_opts) diff --git a/test/csv/interface/test_read.rb b/test/csv/interface/test_read.rb index 58ec188f94..4b0f5e7e96 100644 --- a/test/csv/interface/test_read.rb +++ b/test/csv/interface/test_read.rb @@ -125,6 +125,28 @@ class TestCSVInterfaceRead < Test::Unit::TestCase end end + def test_open_with_undef_replace + # U+00B7 Middle Dot + CSV.open(@input.path, "w", encoding: Encoding::CP932, undef: :replace) do |rows| + rows << ["\u00B7"] + end + CSV.open(@input.path, encoding: Encoding::CP932) do |csv| + assert_equal([["?"]], + csv.to_a) + end + end + + def test_open_with_undef_replace_and_replace_string + # U+00B7 Middle Dot + CSV.open(@input.path, "w", encoding: Encoding::CP932, undef: :replace, replace: "X") do |rows| + rows << ["\u00B7"] + end + CSV.open(@input.path, encoding: Encoding::CP932) do |csv| + assert_equal([["X"]], + csv.to_a) + end + end + def test_parse assert_equal(@rows, CSV.parse(@data, col_sep: "\t", row_sep: "\r\n")) |