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<input name="commit_path" value="$2" type="checkbox"><a href="#$2">$2</a>}gm; # FIXME |
71 |
$status =~ s{^(\w+[\+\s]+)(\S+)$}{$1<a href="#$2">$2</a>}gm; |
# $status =~ s{^(\w+[\+\s]+)(\S+)$}{$1<a href="#$2">$2</a>}gm; |
72 |
if ( $status ) { |
if ( $status ) { |
73 |
$self->add_css(qq| |
$self->add_css(qq| |
74 |
pre.l a { text-decoration: none; } |
pre.l a { text-decoration: none; } |
75 |
div.commit { |
form.commit { |
76 |
background: #ffd; |
background: #ffd; |
77 |
padding: 1em 1em; |
padding: 1em 1em; |
78 |
position: fixed; |
position: fixed; |
82 |
} |
} |
83 |
| ); |
| ); |
84 |
|
|
85 |
|
|
86 |
$status = qq| |
$status = qq| |
87 |
<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> |
|
88 |
<pre class="l">$status</pre> |
<pre class="l">$status</pre> |
89 |
|
<textarea name="commit_message" cols=40 rows=4></textarea> |
90 |
|
<br><input type="submit" name="action" value="commit"> |
91 |
|
</form> |
92 |
|; |
|; |
93 |
$self->add_status( $status ); |
$self->add_status( status => $status ); |
94 |
|
warn "commit_as_markup ",length($status)," bytes"; |
95 |
} |
} |
|
warn "status_as_markup ",length($status)," bytes"; |
|
96 |
return $status; |
return $status; |
97 |
} |
} |
98 |
|
|
100 |
my ($self) = @_; |
my ($self) = @_; |
101 |
|
|
102 |
my $diff = `svk diff`; |
my $diff = `svk diff`; |
103 |
|
$self->add_status( diff => $diff ); |
104 |
|
|
105 |
$diff = $self->html_escape( $diff ); |
$diff = $self->html_escape( $diff ); |
106 |
$self->add_css( qq| |
$self->add_css( qq| |
135 |
die "Allready have ", $self->path_size($new) if -e $new; |
die "Allready have ", $self->path_size($new) if -e $new; |
136 |
$cmd = "mv $old $new && svk revert $old"; |
$cmd = "mv $old $new && svk revert $old"; |
137 |
} elsif ( $self->action ) { |
} elsif ( $self->action ) { |
138 |
$cmd = 'svk ' . $self->action . ' ' . $self->path; |
$cmd = 'svk ' . $self->action; |
139 |
if ( $self->action eq 'commit' ) { |
if ( $self->action eq 'commit' ) { |
140 |
confess "need commit message" unless $self->commit_message; |
my $msg = $self->commit_message || confess "need commit message"; |
|
my $msg = $self->commit_message; |
|
141 |
$msg =~ s{"}{\\"}gs; |
$msg =~ s{"}{\\"}gs; |
142 |
$cmd .= qq{ -m "$msg"}; |
$cmd .= qq{ -m "$msg"}; |
143 |
|
} elsif ( my $path = $self->path ) { |
144 |
|
$cmd .= " $path"; |
145 |
} else { |
} else { |
146 |
confess "need path" unless $self->path; |
confess "need path" unless $self->path; |
147 |
} |
} |
161 |
|
|
162 |
$self->title( 'svk' . ( $self->action ? ' - ' . $self->action : '' ) ); # XXX without this we get wrong icon and title |
$self->title( 'svk' . ( $self->action ? ' - ' . $self->action : '' ) ); # XXX without this we get wrong icon and title |
163 |
|
|
164 |
$html .= $self->status_as_markup || 'No changes in files tracked by SVK'; |
$html .= $self->commit_as_markup . $self->diff_as_markup; |
|
$html .= $self->diff_as_markup; |
|
165 |
|
|
166 |
warn "as_markup ",length($html)," bytes"; |
warn "as_markup ",length($html)," bytes"; |
167 |
|
|