summaryrefslogtreecommitdiff
path: root/lib/App/Raps2/UI.pm
diff options
context:
space:
mode:
Diffstat (limited to 'lib/App/Raps2/UI.pm')
-rw-r--r--lib/App/Raps2/UI.pm94
1 files changed, 94 insertions, 0 deletions
diff --git a/lib/App/Raps2/UI.pm b/lib/App/Raps2/UI.pm
index faca33f..51f4838 100644
--- a/lib/App/Raps2/UI.pm
+++ b/lib/App/Raps2/UI.pm
@@ -10,6 +10,34 @@ use Term::ReadLine;
our $VERSION = '0.2';
+=head1 NAME
+
+App::Raps2::UI - App::Raps2 User Interface
+
+=head1 SYNOPSIS
+
+ my $ui = App::Raps2::UI->new();
+
+ my $input = $ui->read_line('Say something');
+
+ my $password = $ui->read_pw('New password', 1);
+
+ $ui->to_clipboard('stuff!');
+
+=head1 VERSION
+
+This manual documents B<App::Raps2::UI> version 0.2
+
+=head1 METHODS
+
+=over
+
+=item $ui = App::Raps2::UI->new()
+
+Returns a new App::Raps2::UI object.
+
+=cut
+
sub new {
my ($obj) = @_;
my $ref = {};
@@ -17,6 +45,14 @@ sub new {
return bless($ref, $obj);
}
+=item $ui->list(I<\@item1>, I<\@item2>, I<\@item3>)
+
+Print the list items neatly formatted to stdout. Each I<item> looks like B<[>
+I<key>, I<value> B<]>. When B<list> is called for the first time, it will
+print the keys as well as the values.
+
+=cut
+
sub list {
my ($self, @list) = @_;
my $format = "%-20s %-20s %s\n";
@@ -28,6 +64,15 @@ sub list {
printf($format, map { $_->[1] // q{} } @list);
}
+=item $ui->read_line(I<$question>, [I<$prefill>])
+
+Print "I<question>: " to stdout and wait for the user to input text followed
+by a newline. I<prefill> sets the default content of the answer field.
+
+Returns the user's reply, excluding the newline.
+
+=cut
+
sub read_line {
my ($self, $str, $pre) = @_;
@@ -36,6 +81,14 @@ sub read_line {
return $input;
}
+=item $ui->read_multiline(I<$message>)
+
+Like B<read_line>, but repeats I<message> each time the user hits return.
+Input is terminated by EOF (Ctrl+D). Returns a string concatenation of all
+lines (including newlines).
+
+=cut
+
sub read_multiline {
my ($self, $str) = @_;
my $in;
@@ -48,6 +101,14 @@ sub read_multiline {
return $in;
}
+=item $ui->read_pw(I<$message>, I<$verify>)
+
+Prompt the user for a password. I<message> is displayed, the user's input is
+noch echoed. If I<verify> is set, the user has to enter the same input twice,
+otherwise B<read_pw> dies. Returns the input.
+
+=cut
+
sub read_pw {
my ($self, $str, $verify) = @_;
my ($in1, $in2);
@@ -78,6 +139,12 @@ sub read_pw {
return $in1;
}
+=item $ui->to_clipboard(I<$string>)
+
+Place I<string> in the primary X Clipboard.
+
+=cut
+
sub to_clipboard {
my ($self, $str) = @_;
@@ -87,6 +154,13 @@ sub to_clipboard {
return;
}
+=item $ui->output(I<\@pair>, I<...>)
+
+I<pair> consinsts of B<[> I<key>, I<value> B<]>. For each I<pair>, prints
+" key : value" to stdout.
+
+=cut
+
sub output {
my ($self, @out) = @_;
@@ -101,3 +175,23 @@ sub output {
}
1;
+
+__END__
+
+=back
+
+=head1 DEPENDENCIES
+
+This module requires B<Term::ReadLine> and the B<xclip> executable.
+
+=head1 SEE ALSO
+
+App::Raps2(3pm).
+
+=head1 AUTHOR
+
+Copyright (C) 2011 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt>
+
+=head1 LICENSE
+
+ 0. You just DO WHAT THE FUCK YOU WANT TO.