Massive bugfixes, improvements to darwin/win32 compatibility, some groundwork for linux compatibility

This commit is contained in:
Matthew Connelly 2015-09-05 01:56:01 +01:00
parent 5b724a838c
commit 0c545e7904
2 changed files with 48 additions and 38 deletions

View File

@ -9,16 +9,20 @@ use Net::SSH2; use Try::Tiny;
use POE; use POE::Component::DirWatch::WithCaller; use POE; use POE::Component::DirWatch::WithCaller;
use Unix::PID; use YAML; use Unix::PID; use YAML;
#thank you cpan-senpai if($^O eq 'darwin') {
use Speech::Synthesis; #Needed because Clipboard's use of Mac::Pasteboard is subpar.
require Mac::Pasteboard;
require Win32::Clipboard if $^O eq 'MSWin32'; } else {
require Mac::Pasteboard if $^O eq 'darwin'; require Clipboard;
#Mac::Speech does not build on modern OSX installations, so we can't use Speech::Synthesis on darwin
require Speech::Synthesis;
}
my $ME = "ayudante-lobo"; my $ME = __PACKAGE__;
#will bump to 1.0 once i'm satisfied with notif banner methods & xplat compat #will bump to v1.0 upon full cross-platform compatibility and submission to CPAN.
my $VERSION = "0.10"; #version number reflective of how close the module is to 'complete'
my $VERSION = "0.7";
my $HOSTNAME = `hostname`; chomp $HOSTNAME; my $HOSTNAME = `hostname`; chomp $HOSTNAME;
my ($base, $Conf); my ($base, $Conf);
@ -43,59 +47,60 @@ sub scp_upload {
sub timefmt2str { sub timefmt2str {
return Date::Format::time2str(shift,time()); return Date::Format::time2str(shift,time());
} }
sub clipb_copy_w32 { sub clipb_copy {
my $t = shift;
Win32::Clipboard::Empty();
Win32::Clipboard::Set($t);
}
sub clipb_copy_osx {
my $t = shift; my $t = shift;
Clipboard->copy($t) and return unless $^O eq 'darwin';
my $p = Mac::Pasteboard->new(); my $p = Mac::Pasteboard->new();
$p->clear();
$p->copy($t); $p->copy($t);
$p->copy($t, "public.utf8-plain-text"); $p->copy($t, "public.utf8-plain-text");
$p->copy($t, "public.utf16-plain-text"); $p->copy($t, "public.utf16-plain-text");
$p->copy($t, "public.utf16-external-plain-text"); $p->copy($t, "public.utf16-external-plain-text");
} }
sub clipb_copy {
clipb_copy_w32(@_) if $^O eq 'MSWin32';
clipb_copy_osx(@_) if $^O eq 'darwin';
}
sub banner_w32 {
my ($title,$text) = @_;
#TODO either figure out how to do toasts without a shim, or make this less ghetto
system("C:/Users/Maff/Documents/Other/toast.exe \"$title\" \"$text\" \"\"");
}
sub banner_osx {
my ($title,$text) = @_;
#TODO ditto as above, osascript isn't a shim per-se but it's still ghetto
system("/usr/bin/osascript -e 'display notification \"$text\" with title \"$title\"' &");
}
sub banner { sub banner {
banner_w32(@_) if $^O eq 'MSWin32'; #TODO make these less ghetto.
banner_osx(@_) if $^O eq 'darwin'; my ($title,$text) = @_;
system($Conf->{general}->{'notify'}->{toast_exe}." \"$title\" \"$text\" \"\"") if $^O eq 'MSWin32';
system("/usr/bin/osascript -e 'display notification \"$text\" with title \"$title\"' &") if $^O eq 'darwin';
#TODO some form of notification banner on *nix
} }
sub speak { sub speak_osx {
my ($r,$v);
my $t=shift;
#We have to use `say` here because Mac::Speech is old and busted.
$v = "-v".$Conf->{general}->{'notify'}->{speech_voice} if length $Conf->{general}->{'notify'}->{speech_voice};
$r = "-r".$Conf->{general}->{'notify'}->{speech_rate} if length $Conf->{general}->{'notify'}->{speech_rate};
system("/usr/bin/say $v $r '$t' &");
}
sub speak_w32 {
my $t=shift; my $t=shift;
my %args=( my %args=(
engine => '', engine => 'SAPI5',
voice => '' voice => ''
); );
$args{engine}='SAPI5' if $^O eq 'MSWin32';
$args{engine}='MacSpeech' if $^O eq 'darwin';
$args{voice}=$Conf->{general}->{'notify'}->{speech_voice} if length $Conf->{general}->{'notify'}->{speech_voice}; $args{voice}=$Conf->{general}->{'notify'}->{speech_voice} if length $Conf->{general}->{'notify'}->{speech_voice};
my $synth=Speech::Synthesis->new(%args); my $synth=Speech::Synthesis->new(%args);
$synth->speak($t); $synth->speak($t);
} }
sub speak {
speak_osx(@_) if $^O eq 'darwin';
speak_w32(@_) if $^O eq 'MSWin32';
#TODO festival support on *nix
}
# Functions # Functions
sub init { sub init {
#if $HOME ('nix) or $HOMEDRIVE/$HOMEPATH (win32) exist, use those for our basedir, else use cwd #if $HOME ('nix) or $HOMEDRIVE/$HOMEPATH (win32) exist, use those for our basedir, else use cwd
$base = $ENV{HOME} || cwd(); $base = $ENV{HOME};
$base = $ENV{HOMEDRIVE}.$ENV{HOMEPATH} if $^O eq 'MSWin32'; if($^O eq 'MSWin32') {
$base =~ s/\\/\//g if $^O eq 'MSWin32'; $base = $ENV{HOMEDRIVE}.$ENV{HOMEPATH};
$base =~ s/\\/\//g;
}
$base = cwd() unless length $base and -d $base;
#chdir to avoid fucking up relative paths when launched outside of $base #chdir to avoid fucking up relative paths when launched outside of $base
chdir $base; chdir $base;
my $confp = $ENV{LOBORC} || "$base/.${ME}rc"; my $loaded = 0; my $confp = $ENV{LOBORC} || "$base/.ayudante-loborc"; my $loaded = 0;
$loaded = init_conf($confp) if -e $confp and -f $confp and -r $confp and not -z $confp; $loaded = init_conf($confp) if -e $confp and -f $confp and -r $confp and not -z $confp;
if ($Conf->{general}->{storelogs} or not $loaded) { if ($Conf->{general}->{storelogs} or not $loaded) {
open(STDOUT, ">>".$Conf->{general}->{logfile}) if length $Conf->{general}->{logfile}; open(STDOUT, ">>".$Conf->{general}->{logfile}) if length $Conf->{general}->{logfile};
@ -127,6 +132,7 @@ sub init {
sub init_conf { sub init_conf {
$Conf = YAML::LoadFile(shift) or return -1; $Conf = YAML::LoadFile(shift) or return -1;
$base = $Conf->{general}->{home} if defined $Conf->{general}->{home} and length $Conf->{general}->{home}; $base = $Conf->{general}->{home} if defined $Conf->{general}->{home} and length $Conf->{general}->{home};
chdir $base;
return -3 unless defined $Conf->{general}->{tmp} and length $Conf->{general}->{tmp}; return -3 unless defined $Conf->{general}->{tmp} and length $Conf->{general}->{tmp};
$Conf->{general}->{tmp} .= '/' unless $Conf->{general}->{tmp} =~ /\/$/; $Conf->{general}->{tmp} .= '/' unless $Conf->{general}->{tmp} =~ /\/$/;
mkdir $Conf->{general}->{tmp} or logger(9,"Error creating work directory ".$Conf->{general}->{tmp}.": $!") unless -d $Conf->{general}->{tmp}; mkdir $Conf->{general}->{tmp} or logger(9,"Error creating work directory ".$Conf->{general}->{tmp}.": $!") unless -d $Conf->{general}->{tmp};

View File

@ -46,6 +46,8 @@ monitor:
# general->home is optional. if empty, this will be determined by the $HOME env variable or the current working directory. # general->home is optional. if empty, this will be determined by the $HOME env variable or the current working directory.
# general->errlogfile and logfile will default to $home/.ayudante-lobo.err and .log if removed, leaving them blank will instead disable logging for either standard logs or error logs. if both are left blank, storelogs will internally be set to 0 at runtime. # general->errlogfile and logfile will default to $home/.ayudante-lobo.err and .log if removed, leaving them blank will instead disable logging for either standard logs or error logs. if both are left blank, storelogs will internally be set to 0 at runtime.
# general->tmp is required. # general->tmp is required.
# general->notify->toast_exe is an optional directive pointing to the program to be used to display notification toasts in windows. required if running windows and general->notify->banner is turned on.
# general->notify->speech_rate only applies to speech on OSX.
general: general:
home: home:
tmp: /var/tmp tmp: /var/tmp
@ -59,5 +61,7 @@ general:
upload: 1 upload: 1
error: 0 error: 0
speech: 1 speech: 1
speech_rate: 190
speech_voice: Daniel speech_voice: Daniel
toast_exe:
banner: 1 banner: 1