diff options
Diffstat (limited to 'lib/App')
| -rw-r--r-- | lib/App/Raps2/UI.pm | 94 | 
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. | 
