3 |
|
|
4 |
extends 'Frey'; |
extends 'Frey'; |
5 |
with 'Frey::Web'; |
with 'Frey::Web'; |
6 |
|
with 'Frey::Path'; |
7 |
|
|
8 |
use Moose::Util::TypeConstraints; |
use Moose::Util::TypeConstraints; |
9 |
|
|
17 |
has path => ( |
has path => ( |
18 |
documentation => 'path to work with', |
documentation => 'path to work with', |
19 |
is => 'rw', |
is => 'rw', |
20 |
isa => 'Str', |
isa => 'Str|ArrayRef', |
21 |
); |
); |
22 |
|
|
23 |
has commit_message => ( |
has commit_message => ( |
64 |
} |
} |
65 |
} |
} |
66 |
|
|
67 |
sub status_as_markup { |
sub commit_as_markup { |
68 |
my ($self) = @_; |
my ($self) = @_; |
69 |
my $status = `svk status -q`; |
my $status = `svk status -q`; |
70 |
# $status =~ s{^(\w+\s+)(\S+)$}{$1<input name="commit_path" value="$2" type="checkbox"><a href="#$2">$2</a>}gm; # FIXME |
$status =~ s{^(\w+[\+\s]+)(\S+)$}{$1 . $self->checkbox('path',$2) . qq|<a href="#$2">$2</a>|}egm; |
|
$status =~ s{^(\w+[\+\s]+)(\S+)$}{$1<a href="#$2">$2</a>}gm; |
|
71 |
if ( $status ) { |
if ( $status ) { |
72 |
$self->add_css(qq| |
$self->add_css(qq| |
73 |
pre.l a { text-decoration: none; } |
pre.l a { text-decoration: none; } |
74 |
div.commit { |
form.commit { |
75 |
background: #ffd; |
background: #eee; |
76 |
padding: 1em 1em; |
padding: 1em 1em; |
77 |
position: fixed; |
position: fixed; |
78 |
top: 1em; |
top: 1em; |
81 |
} |
} |
82 |
| ); |
| ); |
83 |
|
|
84 |
|
|
85 |
$status = qq| |
$status = qq| |
86 |
<div class="commit" method="post"> |
<form class="commit" method="post"> |
|
<form> |
|
|
<textarea name="commit_message" cols=40 rows=4></textarea> |
|
|
<br><input type="submit" name="action" value="commit"> |
|
|
</form> |
|
|
</div> |
|
87 |
<pre class="l">$status</pre> |
<pre class="l">$status</pre> |
88 |
|
<textarea name="commit_message" cols=40 rows=4></textarea> |
89 |
|
<br><input type="submit" name="action" value="commit"> |
90 |
|
</form> |
91 |
|; |
|; |
92 |
$self->add_status( $status ); |
$self->add_status( status => $status ); |
93 |
|
warn "commit_as_markup ",length($status)," bytes"; |
94 |
} |
} |
|
warn "status_as_markup ",length($status)," bytes"; |
|
95 |
return $status; |
return $status; |
96 |
} |
} |
97 |
|
|
99 |
my ($self) = @_; |
my ($self) = @_; |
100 |
|
|
101 |
my $diff = `svk diff`; |
my $diff = `svk diff`; |
102 |
|
$self->add_status( diff => $diff ); |
103 |
|
|
104 |
$diff = $self->html_escape( $diff ); |
$diff = $self->html_escape( $diff ); |
105 |
$self->add_css( qq| |
$self->add_css( qq| |
111 |
$diff =~ s{^(\-.+?)$}{<span class="del">$1</span>}gm; |
$diff =~ s{^(\-.+?)$}{<span class="del">$1</span>}gm; |
112 |
sub form { |
sub form { |
113 |
my ( $path, $action ) = @_; |
my ( $path, $action ) = @_; |
114 |
qq|<form class="inline"><input type="hidden" name="path" value="$path"><input type="submit" name="action" value="$action"></form>|; |
qq|<form class="inline" method="post"><input type="hidden" name="path" value="$path"><input type="submit" name="action" value="$action"></form>|; |
115 |
}; |
}; |
116 |
$diff =~ s{^(===\s+)(\S+)$}{$1 . form($2,'revert') . qq| <a name="$2" target="editor" href="/editor+$2+1">$2</a> | . form($2,'postpone') }gem; |
$diff =~ s{^(===\s+)(\S+)$}{$1 . form($2,'revert') . qq| <a name="$2" target="editor" href="/editor+$2+1">$2</a> | . form($2,'postpone') }gem; |
117 |
|
|
118 |
$diff = qq|<pre>$diff</pre>|; |
$diff = qq|<pre>$diff</pre>| if $diff; |
119 |
warn "diff_as_markup ",length($diff)," bytes"; |
warn "diff_as_markup ",length($diff)," bytes"; |
120 |
return $diff; |
return $diff; |
121 |
} |
} |
122 |
|
|
123 |
sub as_markup { |
sub action_as_markup { |
124 |
my ($self) = @_; |
my ($self) = @_; |
125 |
|
|
|
my $html = ''; |
|
126 |
my $cmd; |
my $cmd; |
127 |
|
|
128 |
if ( $self->action eq 'postpone' ) { |
if ( $self->action eq 'postpone' ) { |
129 |
my $old = $self->path; |
my $old = $self->path; |
130 |
my $new = $old . '.postponed'; |
my $new = $old; |
131 |
die "Allready have $new" if -e $new; |
$new =~ s{/([^/]+)$}{/.postponed.$1}; |
132 |
|
|
133 |
|
die "Allready have ", $self->path_size($new) if -e $new; |
134 |
$cmd = "mv $old $new && svk revert $old"; |
$cmd = "mv $old $new && svk revert $old"; |
135 |
} elsif ( $self->action ) { |
} elsif ( $self->action ) { |
136 |
my $cmd = 'svk ' . $self->action . ' ' . $self->path; |
$cmd = 'svk ' . $self->action; |
137 |
if ( $self->action eq 'commit' ) { |
if ( $self->action eq 'commit' ) { |
138 |
confess "need commit message" unless $self->commit_message; |
my $msg = $self->commit_message || return $self->error( "need commit message\n" ); |
|
my $msg = $self->commit_message; |
|
139 |
$msg =~ s{"}{\\"}gs; |
$msg =~ s{"}{\\"}gs; |
140 |
$cmd .= qq{ -m "$msg"}; |
$cmd .= qq{ -m "$msg"}; |
141 |
} else { |
} else { |
142 |
confess "need path" unless $self->path; |
confess "need path" unless $self->path; |
143 |
} |
} |
144 |
|
|
145 |
|
my @paths = eval { @{ $self->path } }; # XXX sigh! |
146 |
|
@paths = ( $self->path ) unless @paths; |
147 |
|
warn "# path ", $self->dump( @paths ); |
148 |
|
|
149 |
|
$cmd .= ' ' . join( ' ',@paths ); |
150 |
} |
} |
151 |
if ( $cmd ) { |
if ( $cmd ) { |
152 |
$cmd .= ' 2>&1'; |
$cmd .= ' 2>&1'; |
153 |
|
warn "# cmd $cmd"; |
154 |
|
|
155 |
my $out = `$cmd`; |
my $out = `$cmd`; |
156 |
warn "$cmd $out"; |
warn "# output of $cmd is: $out"; |
157 |
|
|
158 |
$html .= qq| |
return qq| |
159 |
<code style="background: #ff8;"> |
Command <tt>$cmd</tt> produced output: |
160 |
$cmd\n |
<pre style="background: #ff8;"> |
161 |
<b>$out</b> |
$out |
162 |
</code> |
</pre> |
163 |
|; |
|; |
164 |
} |
} |
165 |
|
|
166 |
$self->title( 'svk' . ( $self->action ? ' - ' . $self->action : '' ) ); # XXX without this we get wrong icon and title |
} |
167 |
|
|
168 |
if ( ! $self->can('html_escape') ) { |
sub as_markup { |
169 |
Frey::Web->meta->apply( $self ); |
my ($self) = @_; |
170 |
$self->TODO( "Frey::Web role missing" ); |
|
171 |
} |
my $html = $self->action_as_markup; |
172 |
|
|
173 |
|
$self->title( 'svk' . ( $self->action ? ' - ' . $self->action : '' ) ); # XXX without this we get wrong icon and title |
174 |
|
|
175 |
$html .= $self->status_as_markup || 'No changes in files tracked by SVK'; |
$html .= $self->commit_as_markup . $self->diff_as_markup || |
176 |
$html .= $self->diff_as_markup; |
qq|No changes in tracked files|; |
177 |
|
|
178 |
warn "as_markup ",length($html)," bytes"; |
warn "as_markup ",length($html)," bytes"; |
179 |
|
|