use strict;
use warnings;
-use Data::Dumper ();
use Test::More;
-use File::Slurp 'read_file';
+use String::CamelCase 'wordsplit';
+use Carp::Clan qw/^DBIx::Class/;
+use Scalar::Util 'looks_like_number';
use namespace::clean;
use Exporter 'import';
+use Data::Dumper ();
-our @EXPORT_OK = qw/split_name dumper dumper_squashed eval_package_without_redefine_warnings class_path no_warnings warnings_exist warnings_exist_silent slurp_file/;
+our @EXPORT_OK = qw/split_name dumper dumper_squashed eval_package_without_redefine_warnings class_path no_warnings warnings_exist warnings_exist_silent slurp_file write_file array_eq/;
-use constant BY_CASE_TRANSITION =>
+use constant BY_CASE_TRANSITION_V7 =>
qr/(?<=[[:lower:]\d])[\W_]*(?=[[:upper:]])|[\W_]+/;
use constant BY_NON_ALPHANUM =>
my $LF = "\x0a";
my $CRLF = "\x0d\x0a";
-sub split_name($) {
- my $name = shift;
+sub split_name($;$) {
+ my ($name, $v) = @_;
+
+ my $is_camel_case = $name =~ /[[:upper:]]/ && $name =~ /[[:lower:]]/;
+
+ if ((not $v) || $v >= 8) {
+ return map split(BY_NON_ALPHANUM, $_), wordsplit($name);
+ }
- split $name =~ /[[:upper:]]/ && $name =~ /[[:lower:]]/ ? BY_CASE_TRANSITION : BY_NON_ALPHANUM, $name;
+ return split $is_camel_case ? BY_CASE_TRANSITION_V7 : BY_NON_ALPHANUM, $name;
}
sub dumper($) {
}
sub slurp_file($) {
- my $data = read_file(shift, binmode => ':encoding(UTF-8)');
+ my $file_name = shift;
+
+ open my $fh, '<:encoding(UTF-8)', $file_name,
+ or croak "Can't open '$file_name' for reading: $!";
+
+ my $data = do { local $/; <$fh> };
+
+ close $fh;
$data =~ s/$CRLF|$LF/\n/g;
return $data;
}
+sub write_file($$) {
+ my $file_name = shift;
+
+ open my $fh, '>:encoding(UTF-8)', $file_name,
+ or croak "Can't open '$file_name' for writing: $!";
+
+ print $fh shift;
+ close $fh;
+}
+
+sub array_eq($$) {
+ no warnings 'uninitialized';
+ my ($a, $b) = @_;
+
+ return unless @$a == @$b;
+
+ for (my $i = 0; $i < @$a; $i++) {
+ if (looks_like_number $a->[$i]) {
+ return unless $a->[$i] == $b->[$i];
+ }
+ else {
+ return unless $a->[$i] eq $b->[$i];
+ }
+ }
+ return 1;
+}
+
1;
# vim:et sts=4 sw=4 tw=0: