Sha256: b6095e606abfe27e97e0ef522474767f9bfbb12aeacdd0447f4bbe646a34a6af

Contents?: true

Size: 1.7 KB

Versions: 22

Compression:

Stored size: 1.7 KB

Contents

module IOStreams
  module Line
    class Writer < IOStreams::Writer
      attr_reader :delimiter

      # Write a line at a time to a stream.
      def self.stream(output_stream, **args)
        # Pass-through if already a line writer
        return yield(output_stream) if output_stream.is_a?(self.class)

        yield new(output_stream, **args)
      end

      # A delimited stream writer that will write to the supplied output stream.
      #
      # The output stream will have the encoding of data written to it.
      # To change the output encoding, use IOStreams::Encode::Writer.
      #
      # Parameters
      #   output_stream
      #     The output stream that implements #write
      #
      #   delimiter: [String]
      #     Add the specified delimiter after every record when writing it
      #     to the output stream
      #     Default: OS Specific. Linux: "\n"
      def initialize(output_stream, delimiter: $/, original_file_name: nil)
        super(output_stream)
        @delimiter = delimiter
      end

      # Write a line to the output stream
      #
      # Example:
      #   IOStreams.path('a.txt').writer(:line) do |stream|
      #     stream << 'first line' << 'second line'
      #   end
      def <<(data)
        write(data)
        self
      end

      # Write a line to the output stream followed by the delimiter.
      # Returns [Integer] the number of bytes written.
      #
      # Example:
      #   IOStreams.path('a.txt').writer(:line) do |stream|
      #     count = stream.write('first line')
      #     puts "Wrote #{count} bytes to the output file, including the delimiter"
      #   end
      def write(data)
        output_stream.write(data.to_s + delimiter)
      end
    end
  end
end

Version data entries

22 entries across 22 versions & 1 rubygems

Version Path
iostreams-1.10.3 lib/io_streams/line/writer.rb
iostreams-1.10.2 lib/io_streams/line/writer.rb
iostreams-1.10.1 lib/io_streams/line/writer.rb
iostreams-1.10.0 lib/io_streams/line/writer.rb
iostreams-1.9.0 lib/io_streams/line/writer.rb
iostreams-1.8.0 lib/io_streams/line/writer.rb
iostreams-1.7.0 lib/io_streams/line/writer.rb
iostreams-1.6.2 lib/io_streams/line/writer.rb
iostreams-1.6.1 lib/io_streams/line/writer.rb
iostreams-1.6.0 lib/io_streams/line/writer.rb
iostreams-1.5.1 lib/io_streams/line/writer.rb
iostreams-1.5.0 lib/io_streams/line/writer.rb
iostreams-1.4.0 lib/io_streams/line/writer.rb
iostreams-1.3.3 lib/io_streams/line/writer.rb
iostreams-1.3.2 lib/io_streams/line/writer.rb
iostreams-1.3.1 lib/io_streams/line/writer.rb
iostreams-1.3.0 lib/io_streams/line/writer.rb
iostreams-1.2.1 lib/io_streams/line/writer.rb
iostreams-1.2.0 lib/io_streams/line/writer.rb
iostreams-1.1.1 lib/io_streams/line/writer.rb