App-CSE
view release on metacpan or search on metacpan
use strict;
use warnings;
## Make that compatible with dev in code
BEGIN{
my $code_dir = __FILE__;
$code_dir =~ s|bin/.+|lib|;
unshift ( @INC , $code_dir );
}
binmode STDOUT , ':utf8';
binmode STDERR , ':utf8';
use App::CSE;
exit(App::CSE->new()->main());
lib/App/CSE.pm view on Meta::CPAN
sub _build_index_dirty_file{
my ($self) = @_;
return $self->index_dir()->file('cse_dirty.js');
}
sub _build_index_meta{
my ($self) = @_;
unless( -r $self->index_meta_file() ){
return { version => '-unknown-' };
}
return JSON::decode_json(File::Slurp::read_file($self->index_meta_file().'' , { binmode => ':raw' }));
}
sub _build_dirty_files{
my ($self) = @_;
unless( -r $self->index_dirty_file() ){
return {};
}
return JSON::decode_json(File::Slurp::read_file($self->index_dirty_file().'' , { binmode => ':raw' }));
}
sub _build_index_mtime{
my ($self) = @_;
my $st = File::stat::stat($self->index_dir());
return DateTime->from_epoch( epoch => $st->mtime() );
}
sub _build_max_size{
my ($self) = @_;
lib/App/CSE.pm view on Meta::CPAN
log4perl.appender.Screen.layout = Log::Log4perl::Layout::PatternLayout
log4perl.appender.Screen.layout.ConversionPattern = %d [%p] %m%n
|;
sub main{
my ($self) = @_;
unless( Log::Log4perl->initialized() ){
binmode STDOUT , ':utf8';
binmode STDERR , ':utf8';
if( $self->options()->{verbose} ){
Log::Log4perl::init(\$verbose_log);
}else{
Log::Log4perl::init(\$standard_log);
}
}
return $self->command()->execute();
}
sub save_index_meta{
my ($self) = @_;
File::Slurp::write_file($self->index_meta_file().'' , { binmode => ':raw' }, JSON::encode_json($self->index_meta));
return 1;
}
sub save_dirty_files{
my ($self) = @_;
File::Slurp::write_file($self->index_dirty_file().'' , { binmode => ':raw' }, JSON::encode_json($self->dirty_files));
return 1;
}
sub version{
my ($self) = @_;
return $App::CSE::VERSION || 'dev';
}
# Performs very basic checks on a filename, see if its valid
lib/App/CSE/File.pm view on Meta::CPAN
my ($self) = @_;
## This is the default. Override that in specific file types
return 'UTF-8';
}
sub _build_raw_content{
my ($self) = @_;
if( $self->stat()->size() > $self->cse()->max_size() ){
return undef;
}
return scalar( File::Slurp::read_file($self->file_path(), binmode => ':raw') );
}
sub _build_content{
my ($self) = @_;
my $raw_content = $self->raw_content();
unless( defined($raw_content) ){ return undef; }
my $decoded = eval{ Encode::decode($self->encoding(), $raw_content, Encode::FB_CROAK ); };
unless( $decoded ){
$LOGGER->debug("File ".$self->file_path()." failed to be decoded as ".$self->encoding().": ".$@);
t/05-more-search.t view on Meta::CPAN
#! perl -T
use Test::More;
use Log::Log4perl qw/:easy/;
# Log::Log4perl->easy_init($TRACE);
binmode STDOUT , ':utf8';
binmode STDERR , ':utf8';
use App::CSE;
use Carp::Always;
use File::Temp;
use Path::Class::Dir;
use File::BaseDir qw//;
t/07-decl.t view on Meta::CPAN
#! perl -T
use Test::More;
use Log::Log4perl qw/:easy/;
# Log::Log4perl->easy_init($TRACE);
binmode STDOUT , ':utf8';
binmode STDERR , ':utf8';
use App::CSE;
use Carp::Always;
use File::Temp;
use Path::Class::Dir;
use File::BaseDir qw//;
t/08-meta.t view on Meta::CPAN
#! perl -T
use Test::More;
use Log::Log4perl qw/:easy/;
# Log::Log4perl->easy_init($TRACE);
binmode STDOUT , ':utf8';
binmode STDERR , ':utf8';
use App::CSE;
use Carp::Always;
use File::Temp;
use Path::Class::Dir;
use File::BaseDir qw//;
( run in 0.636 second using v1.01-cache-2.11-cpan-3cd7ad12f66 )