File Coverage

blib/lib/Astro/SkyX/Application.pm
Criterion Covered Total %
statement 12 44 27.2
branch 0 12 0.0
condition 0 6 0.0
subroutine 4 9 44.4
pod 0 3 0.0
total 16 74 21.6


line stmt bran cond sub pod time code
1             package Astro::SkyX::Application;
2              
3 1     1   25 use 5.006001;
  1         4  
  1         34  
4 1     1   5 use strict;
  1         2  
  1         24  
5 1     1   5 use warnings;
  1         1  
  1         216  
6             require IO::Socket;
7             require Exporter;
8             require Astro::SkyX;
9              
10             #use vars qw( $SkyXConnection $_count );
11             our @ISA = qw(Exporter );
12              
13             # Items to export into callers namespace by default. Note: do not export
14             # names by default without a very good reason. Use EXPORT_OK instead.
15             # Do not simply export all your public functions/methods/constants.
16             our ($AUTOLOAD);
17             # This allows declaration use SkyX ':all';
18             # If you do not need this, moving things directly into @EXPORT or @EXPORT_OK
19             # will save memory.
20             our %EXPORT_TAGS = ( 'all' => [ qw(
21             new connect Send Get
22             ) ] );
23              
24             our @EXPORT_OK = ( @{ $EXPORT_TAGS{'all'} } );
25              
26             our @EXPORT = qw(
27             );
28              
29             our $VERSION = '0.03';
30             our @PROPERTIES = qw( );
31             our @READWRITEPROPS = qw( );
32              
33             # Preloaded methods go here.
34              
35             ##---##
36              
37             sub new {
38 0     0 0   my ($caller, %arg) = @_;
39 0           my $caller_is_obj = ref($caller);
40 0   0       my $class = $caller_is_obj || $caller;
41 0           my $self = bless {
42             _debug => $_[1],
43             }, $class;
44             # Private count increment/decrement methods
45             # $self->_incr_count();
46 0           return $self;
47             }
48             # sub _incr_count { ++$_count }
49             # sub _decr_count { --$_count }
50              
51             sub AUTOLOAD ($;$) {
52 1     1   4 no strict "refs";
  1         1  
  1         455  
53 0     0     my ($self, @newval) = @_;
54 0           my $newtext = '';
55 0           my $js = "/* Java Script */ \r\n";
56 0 0         if ($AUTOLOAD =~ /.*::(.*::.*)/) {
57 0           my $method = $1;
58             # Let's build the javascript
59             # $newtext = join ',', map{ qq/"$_"/ }@newval;
60 0 0         $newtext = join ',', map{ /^[0-9.-]*$/ ? $_ : qq/'$_'/ }@newval;
  0            
61 0           $method =~ tr/::/./s;
62              
63 0           my ($package, $propertyName) = $AUTOLOAD =~ m/^(.+::)(.+)$/;
64 0 0 0       if(haveProperty($propertyName)){
    0          
65 0           $js .= $method . "(" . $newtext . ");\r\n";
66             } elsif(haveReadWriteProp($propertyName) and length($newtext) ){
67 0           $js .= $method . ' = ' . $newtext . ";\r\n";
68             } else {
69 0           $js .= $method . ";\r\n";
70             }
71 0           Astro::SkyX::Send($self,$js);
72 0           return Astro::SkyX::Get($self);
73             }
74 0           die "No such method: $AUTOLOAD";
75             }
76              
77             sub haveReadWriteProp{
78 0     0 0   my ($value) = @_;
79 0           for my $property (@READWRITEPROPS){
80 0 0         if($property eq $value){
81 0           return "1";
82             }
83             }
84 0           return undef;
85             }
86              
87             sub haveProperty{
88 0     0 0   my ($value) = @_;
89 0           for my $property (@PROPERTIES){
90 0 0         if($property eq $value){
91 0           return "1";
92             }
93             }
94 0           return undef;
95             }
96              
97 0     0     sub DESTROY {
98             # $_[0]->_decr_count();
99             }
100              
101             1;
102             __END__