package Data::Unixish::cat; use 5.010; use strict; use syntax 'each_on_array'; # to support perl < 5.12 use warnings; #use Log::Any '$log'; use Data::Unixish::Util qw(%common_args); our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY our $DATE = '2025-02-24'; # DATE our $DIST = 'Data-Unixish'; # DIST our $VERSION = '1.574'; # VERSION our %SPEC; $SPEC{cat} = { v => 1.1, summary => 'Pass input unchanged', args => { %common_args, }, tags => [qw/filtering itemfunc/], }; sub cat { my %args = @_; my ($in, $out) = ($args{in}, $args{out}); while (my ($index, $item) = each @$in) { push @$out, $item; } [200, "OK"]; } sub _cat_item { $_[0]; } 1; # ABSTRACT: Pass input unchanged __END__ =pod =encoding UTF-8 =head1 NAME Data::Unixish::cat - Pass input unchanged =head1 VERSION This document describes version 1.574 of Data::Unixish::cat (from Perl distribution Data-Unixish), released on 2025-02-24. =head1 SYNOPSIS In Perl: use Data::Unixish qw(lduxl); my @res = lduxl("cat", 1, 2, 3, 4); # => (1, 2, 3, 4) In command line: % echo -e "1\n2\n3" | dux cat --format=text-simple 1 2 3 =head1 FUNCTIONS =head2 cat Usage: cat(%args) -> [$status_code, $reason, $payload, \%result_meta] Pass input unchanged. This function is not exported. Arguments ('*' denotes required arguments): =over 4 =item * B => I Input stream (e.g. array or filehandle). =item * B => I Output stream (e.g. array or filehandle). =back Returns an enveloped result (an array). First element ($status_code) is an integer containing HTTP-like status code (200 means OK, 4xx caller error, 5xx function error). Second element ($reason) is a string containing error message, or something like "OK" if status is 200. Third element ($payload) is the actual result, but usually not present when enveloped result is an error response ($status_code is not 2xx). Fourth element (%result_meta) is called result metadata and is optional, a hash that contains extra information, much like how HTTP response headers provide additional metadata. Return value: (any) =head1 HOMEPAGE Please visit the project's homepage at L. =head1 SOURCE Source repository is at L. =head1 SEE ALSO cat(1) =head1 AUTHOR perlancar =head1 CONTRIBUTING To contribute, you can send patches by email/via RT, or send pull requests on GitHub. Most of the time, you don't need to build the distribution yourself. You can simply modify the code, then test via: % prove -l If you want to build the distribution (e.g. to try to install it locally on your system), you can install L, L, L, and sometimes one or two other Dist::Zilla- and/or Pod::Weaver plugins. Any additional steps required beyond that are considered a bug and can be reported to me. =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2025 by perlancar . This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =head1 BUGS Please report any bugs or feature requests on the bugtracker website L When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature. =cut