Massive bugfixes, improvements to darwin/win32 compatibility, some groundwork for linux compatibility
This commit is contained in:
parent
5b724a838c
commit
0c545e7904
|
@ -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};
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue