# Author Chris "BinGOs" Williams
#
# This module may be used, modified, and distributed under the same
# terms as Perl itself. Please see the license that came with your Perl
# distribution for details.
#
package POE::Filter::CSV_XS;
$POE::Filter::CSV_XS::VERSION = '1.18';
#ABSTRACT: A POE-based parser for CSV based files.
use strict;
use warnings;
use Text::CSV_XS;
use base qw(POE::Filter);
sub new {
my $class = shift;
my %opts = @_;
$opts{lc $_} = delete $opts{$_} for keys %opts;
delete $opts{eol};
my $self = {};
$self->{BUFFER} = [];
$self->{csv_filter} = Text::CSV_XS->new( \%opts );
bless $self, $class;
}
sub get {
my ($self, $raw) = @_;
my $events = [];
foreach my $event ( @$raw ) {
my $status = $self->{csv_filter}->parse($event);
push @$events, [ $self->{csv_filter}->fields() ] if $status;
}
return $events;
}
sub get_one_start {
my ($self, $raw) = @_;
push @{ $self->{BUFFER} }, $_ for @$raw;
}
sub get_one {
my $self = shift;
my $events = [];
my $event = shift @{ $self->{BUFFER} };
if ( defined $event ) {
my $status = $self->{csv_filter}->parse($event);
push @$events, [ $self->{csv_filter}->fields() ] if $status;
}
return $events;
}
sub put {
my ($self,$events) = @_;
my $raw_lines = [];
foreach my $event ( @$events ) {
if ( ref $event eq 'ARRAY' ) {
my $status = $self->{csv_filter}->combine(@$event);
push @$raw_lines, $self->{csv_filter}->string() if $status;
}
else {
warn "non arrayref passed to put()\n";
}
}
return $raw_lines;
}
qq[let,us,csv,xs];
__END__
=pod
=encoding UTF-8
=head1 NAME
POE::Filter::CSV_XS - A POE-based parser for CSV based files.
=head1 VERSION
version 1.18
=head1 SYNOPSIS
use POE::Filter::CSV_XS;
my $filter = POE::Filter::CSV_XS->new();
my $arrayref = $filter->get( [ $line ] );
my $arrayref2 = $filter->put( $arrayref );
=head1 DESCRIPTION
POE::Filter::CSV_XS provides a convenient way to parse CSV files. It is
a wrapper for the module L<Text::CSV_XS>.
A more comprehensive demonstration of the use to which this module can be
put to is in the examples/ directory of this distribution.
=head1 CONSTRUCTOR
=over
=item C<new>
Creates a new POE::Filter::CSV_XS object. Any given arguments are passed to the constructor for
L<Text::CSV_XS>, consult the documentation for that module.
=back
=head1 METHODS
=over
=item C<get>
=item C<get_one_start>
=item C<get_one>
Takes an arrayref which is contains lines of CSV formatted input. Returns an arrayref of lists of
fields.
=item C<put>
Takes an arrayref containing arrays of fields and returns an arrayref containing CSV formatted lines.
=back
=head1 SEE ALSO
L<POE>
L<Text::CSV_XS>
L<POE::Filter>
L<POE::Filter::Line>
L<POE::Filter::Stackable>
=head1 AUTHOR
Chris Williams <chris@bingosnet.co.uk>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2017 by Chris Williams.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut