File Coverage

blib/lib/App/Maisha.pm
Criterion Covered Total %
statement 70 75 93.3
branch 11 20 55.0
condition 5 11 45.4
subroutine 12 13 92.3
pod 4 4 100.0
total 102 123 82.9


line stmt bran cond sub pod time code
1             package App::Maisha;
2              
3 7     7   175200 use strict;
  7         17  
  7         268  
4 7     7   38 use warnings;
  7         13  
  7         386  
5              
6             our $VERSION = '0.19';
7              
8             #----------------------------------------------------------------------------
9              
10             =encoding utf8
11              
12             =head1 NAME
13              
14             App::Maisha - A command line social micro-blog networking tool.
15              
16             =head1 SYNOPSIS
17              
18             use App::Maisha;
19             my $maisha = App::Maisha->new(config => $file)->run;
20              
21             =head1 DESCRIPTION
22              
23             This distribution provides the ability to micro-blog via social networking
24             websites and services, such as Identica and Twitter.
25              
26             For further information regarding the commands and configuration, please see
27             the 'maisha' script included with this distribution.
28              
29             =cut
30              
31             #----------------------------------------------------------------------------
32             # Library Modules
33              
34 7     7   39 use base qw(Class::Accessor::Fast);
  7         18  
  7         7333  
35              
36 7     7   43979 use Carp qw(croak);
  7         18  
  7         420  
37 7     7   7428 use Config::Any;
  7         94586  
  7         277  
38 7     7   6192 use App::Maisha::Shell;
  7         27  
  7         397  
39 7     7   86 use File::Basename;
  7         12  
  7         730  
40 7     7   8045 use File::HomeDir;
  7         55445  
  7         6219  
41              
42             #----------------------------------------------------------------------------
43             # Accessors
44              
45             __PACKAGE__->mk_accessors($_) for qw(shell config);
46              
47             #----------------------------------------------------------------------------
48             # Public API
49              
50             sub new {
51 1     1 1 14 my $class = shift;
52 1         17 my $self = $class->SUPER::new();
53 1         19 my $config = $self->load_config(@_);
54 1         7 $self->config($config);
55 1         12 $self->setup();
56 1         28101 $self;
57             }
58              
59             sub load_config {
60 1     1 1 6 my ($self,%hash) = @_;
61 1         3 my $config = $hash{config};
62              
63 1 50 33     10 if ($config && ! ref $config) {
64 1         2 my $filename = $config;
65             # In the future, we may support multiple configs, but for now
66             # just load a single file via Config::Any
67 1         17 my $list = Config::Any->load_files( { files => [ $filename ], use_ext => 1 } );
68 1         59 ($config) = $list->[0]->{$filename};
69             }
70              
71 1 50       12 croak("Could not load configuration file") if(!$config);
72 1 50       7 croak("Maisha expectes a config file that can be decoded to a HASH") if(ref $config ne 'HASH');
73              
74             # some systems use a broken pager, so force the internal parser to be used
75 1         18 $self->{pager} = $ENV{PAGER};
76 1         11 $ENV{PAGER} = '';
77              
78 1         5 return $config;
79             }
80              
81             sub setup {
82 1     1 1 2 my $self = shift;
83 1         4 my $config = $self->config;
84 1         30 my $shell = $self->shell(App::Maisha::Shell->new);
85              
86 1   50     41404 my $debug = $config->{CONFIG}{debug} || 0;
87 1   50     19 my $history = $config->{CONFIG}{history} || '';
88              
89 1         3 my $tag = $config->{CONFIG}{tag};
90 1   50     7 $tag ||= '[from maisha]';
91 1 50       5 $tag = '' if($tag eq '.');
92              
93 1         7 my $prompt = $config->{CONFIG}{prompt};
94 1   50     395 $prompt ||= 'maisha>';
95 1         58 $prompt =~ s/\s*$/ /;
96              
97              
98 1         24 $shell->debug($debug);
99 1         15 $shell->history($history);
100 1         12 $shell->prompt_str($prompt);
101 1         7 $shell->tag_str($tag);
102 1 50       18 $shell->pager( defined $config->{CONFIG}{pager} ? $config->{CONFIG}{pager} : 1 );
103 1 50       14 $shell->order( defined $config->{CONFIG}{order} ? $config->{CONFIG}{order} : 'descending');
104 1 50       13 $shell->limit( defined $config->{CONFIG}{limit} ? $config->{CONFIG}{limit} : 0);
105 1 50       10 $shell->chars( defined $config->{CONFIG}{chars} ? $config->{CONFIG}{chars} : 80);
106 1 50       9 $shell->format(defined $config->{CONFIG}{format} ? $config->{CONFIG}{format} : '[%U] %M');
107              
108 1         35 my $home = File::HomeDir->my_home();
109              
110             # connect to the available sites
111 1         108 for my $plugin (keys %$config) {
112 3 100       14 next if($plugin eq 'CONFIG');
113 2         11 $config->{$plugin}{home} = $home;
114 2         103 $self->shell->connect($plugin,$config->{$plugin});
115             }
116              
117             # in some environments 'Wide Character' warnings are emited where unicode
118             # strings are seen in status messages. This suppresses them.
119 1     1   47 binmode STDOUT, ":encoding(UTF-8)";
  1         11  
  1         2  
  1         21  
120             }
121              
122             sub run {
123 0     0 1 0 my $self = shift;
124 0         0 my $shell = $self->shell;
125 0         0 $shell->postcmd();
126 0         0 $shell->cmdloop();
127              
128 0         0 $ENV{PAGER} = $self->{pager};
129             }
130              
131             1;
132              
133             __END__
134              
135             =head1 METHODS
136              
137             =head2 Constructor
138              
139             =over 4
140              
141             =item * new
142              
143             =back
144              
145             =head2 Process Methods
146              
147             =over 4
148              
149             =item * load_config
150              
151             Loads the configuration file. See the 'maisha' script to see a fuller
152             description of the configuration options.
153              
154             =item * setup
155              
156             Prepares the interface and internal environment.
157              
158             =item * run
159              
160             Starts the command loop shell, and awaits your command.
161              
162             =back
163              
164             =head1 WEBSITES
165              
166             =over 4
167              
168             =item * Main Site: L<http://maisha.grango.org>
169              
170             =item * Git Repo: L<http://github.com/barbie/maisha/tree/master>
171              
172             =item * RT Queue: L<RT: http://rt.cpan.org/Public/Dist/Display.html?Name=App-Maisha>
173              
174             =back
175              
176             =head1 THANKS TO
177              
178             My thanks go to the following people for suggestions and help when putting this
179             application together.
180              
181             Dave Cross, Robert Rothenberg and Steffen Müller.
182              
183             =head1 AUTHOR
184              
185             Barbie, <barbie@cpan.org>
186             for Miss Barbell Productions <http://www.missbarbell.co.uk>.
187              
188             =head1 COPYRIGHT AND LICENSE
189              
190             Copyright (C) 2009-2014 by Barbie
191              
192             This distribution is free software; you can redistribute it and/or
193             modify it under the Artistic License v2.
194              
195             =cut