=================================================================== RCS file: /cvs/todotxt/Text-Todo/bin/dudelicious.pl,v retrieving revision 1.5 retrieving revision 1.8 diff -u -r1.5 -r1.8 --- todotxt/Text-Todo/bin/dudelicious.pl 2010/04/29 05:50:33 1.5 +++ todotxt/Text-Todo/bin/dudelicious.pl 2010/04/30 18:17:40 1.8 @@ -1,31 +1,34 @@ -#!/usr/bin/env perl +#!/usr/bin/perl package Dudelicious; +use Data::Dumper; use version; our $VERSION = qv('0.1.0'); -BEGIN { use FindBin; use lib "$FindBin::Bin/mojo/lib" } +BEGIN { + use FindBin; + use lib "$FindBin::Bin/../lib"; + use lib "$FindBin::Bin/../mojo/lib"; +} use Carp qw/ carp croak /; +use Digest::MD5 qw/ md5_hex /; +use Text::Todo; use Mojolicious::Lite; -use Text::Todo; +use Mojo::JSON; -use Data::Dumper; - -my %config = ( todo_dir => $ENV{DUDELICIOUS_HOME} || '.', ); - app->home->parse( $ENV{DUDELICIOUS_HOME} ) if $ENV{DUDELICIOUS_HOME}; -_read_config_from_file( app->home->rel_file('dudelicious.conf') ); -plugin 'default_helpers'; +plugin 'json_config' => { + file => 'dudelicious.conf', + default => { todo_dir => $ENV{DUDELICIOUS_HOME} || '.', }, +}; -my $todo = Text::Todo->new( \%config ); - get '/' => sub { my $self = shift; - my $dir = $todo->file('todo_dir'); + my $dir = _todo($self)->file('todo_dir'); opendir my $dh, $dir or croak "Unable to opendir $dir: $!"; my @files = grep {/\.te?xt$/ixms} readdir $dh; closedir $dh; @@ -34,79 +37,70 @@ } => 'index'; get '/l/:file' => sub { - my $self = shift; - my $file = $self->stash('file') . '.txt'; + my $self = shift; + my $file = $self->stash('file') . '.txt'; + my $format = $self->stash('format') || 'html'; + my $list = _get_list( $self, $file ); - $self->render( list => [ $todo->listfile($file) ], layout => 'todotxt' ); + if ( $format eq 'json' ) { + $self->render_json($list); + } + else { + $self->render( list => $list, layout => 'todotxt' ); + } } => 'list'; -get '/l/:file/e/:entry' => sub { - my $self = shift; - my $file = $self->stash('file') . '.txt'; - my $entry = $self->stash('entry') - 1; +get '/l/:file/e/:line' => sub { + my $self = shift; + my $file = $self->stash('file') . '.txt'; + my $format = $self->stash('format') || 'html'; + my $entry = _get_list( $self, $file )->[ $self->stash('line') - 1 ]; - $self->render( - entry => $todo->listfile($file)->[$entry], - layout => 'todotxt' - ); + if ( $format eq 'json' ) { + $self->render_json($entry); + } + else { + $self->render( entry => $entry, layout => 'todotxt' ); + } } => 'entry'; app->start unless caller(); -sub _read_config_from_file { - my ($conf_file) = @_; +sub _todo { + my ($c) = @_; - app->log->debug("Reading configuration from $conf_file."); - - if ( -e $conf_file ) { - if ( open FILE, "<", $conf_file ) { - my @lines = ; - close FILE; - - my $line = ''; - foreach my $l (@lines) { - next if $l =~ m/^\s*#/; - $line .= $l; - } - - my $json = Mojo::JSON->new; - my $json_config = $json->decode($line) || {}; - die $json->error if !$json_config && $json->error; - - %config = ( %config, %$json_config ); - - unshift @INC, $_ - for ( - ref $config{perl5lib} eq 'ARRAY' - ? @{ $config{perl5lib} } - : $config{perl5lib} - ); - } + if ( !$c->stash('todo') ) { + my $todo = Text::Todo->new( $c->stash('config') ); + $c->stash( 'todo' => $todo ); } - else { - app->log->debug("Configuration [$conf_file] is not available."); - } - $ENV{SCRIPT_NAME} = $config{base} if defined $config{base}; + return $c->stash('todo'); +} - # set proper templates base dir, if defined - app->renderer->root( app->home->rel_dir( $config{templatesdir} ) ) - if defined $config{templatesdir}; +sub _get_list { + my ( $c, $file ) = @_; - # set proper public base dir, if defined - app->static->root( app->home->rel_dir( $config{publicdir} ) ) - if defined $config{publicdir}; + my $line = 1; + return [ + map ( { line => $line++, + md5 => md5_hex( $_->text ), + text => $_->text, + done => $_->done, + }, + _todo($c)->listfile($file), + ) + ]; } __DATA__ @@ list.txt.ep -% foreach my $i (0..$#{ $list }) { -%== include 'entry', entry => $list->[$i], line => $i + 1; +% foreach my $entry (@{ $list }) { +%== include 'entry', entry => $entry; % } @@ entry.txt.ep -<%= $entry->text %> +<%= $entry->{text} %> @@ layouts/todotxt.txt.ep %= content @@ -119,15 +113,15 @@ @@ list.html.ep

<%= $file %>

    -% foreach my $i (0..$#{ $list }) { +% foreach my $entry (@{ $list }) {
  1. -%= include 'entry', entry => $list->[$i], line => $i + 1; +%= include 'entry', entry => $entry;
  2. % }
@@ entry.html.ep -<%= $entry->text %> +<%= $entry->{text} %> @@ layouts/todotxt.html.ep @@ -135,7 +129,6 @@ <%== content %> - __END__ =head1 NAME @@ -147,7 +140,7 @@ Since the $VERSION can't be automatically included, here is the RCS Id instead, you'll have to look up $VERSION. - $Id: dudelicious.pl,v 1.5 2010/04/29 04:50:33 andrew Exp $ + $Id: dudelicious.pl,v 1.8 2010/04/30 17:17:40 andrew Exp $ =head1 SYNOPSIS