=back
+=head1 ENVIRONMENTAL VARIABLES
+
+=over
+
+=item B<TODODB>
+
+Todo databse location, set by devtodo
+
+=item B<STODO_NO_COMMIT>
+
+If set, stodo assumes that there is no network, and doesn't commit
+
+=back
+
=head1 EXAMPLES
on save {
GetOptions(\%options,'debug|d+','help|h|?','man|m','quiet|q+','simulate|s+');
-pod2usage() if $options{help} or not exists $ENV{TODODB};
+pod2usage() if $options{help};
pod2usage({verbose=>2}) if $options{man};
$DEBUG = $options{debug};
# Figure out what we're doing
-my $tododb = $ENV{TODODB};
+my $tododb = exists $ENV{TODODB} ? $ENV{TODODB} : '.todo';
if ($tododb !~ m#^/#) {
$tododb = cwd().'/'.$tododb;
}
+if (not -r $tododb) {
+ print STDERR "Todo DB '$tododb' does not exist or is not readable\n";
+ exit 1;
+}
$tododb = full_readlink($tododb);
my $base_dir = dirname($tododb);
my $tododb_name = basename($tododb);
if (not -e "$base_dir/.svn") {
- print "$base_dir/.svn doesns't exist, not commiting\n" unless $options{quiet};
+ print STDERR "$base_dir/.svn doesn't exist, not commiting\n" unless $options{quiet};
+ exit 0;
+}
+
+if (not -e "$base_dir/.svn/text-base/${tododb_name}.svn-base") {
+ print STDERR "$base_dir/.svn/text-base/${tododb_name}.svn-base doesn't exist, not committing\n" unless $options{quiet};
exit 0;
}
my $url_type;
my $svn_host;
while (<$svn_entries_fh>) {
- next unless m#^\s+url=\"(http|svn\+ssh|file):///?([^\/]+)#;
+ next unless m#^(?:\s+url=\")?(http|svn\+ssh|file):///?([^\/]+)#;
$url_type = $1;
last if $url_type eq 'file';
$svn_host = $2;
last;
}
-
-if (not defined $svn_host and $url_type ne 'file') {
+if ($ENV{STODO_NO_COMMIT}) {
+ print STDERR "Exiting because of STODO_NO_COMMIT env variable\n" unless $options{quiet};
+ exit 0;
+}
+if (not defined $svn_host and (not defined $url_type or $url_type ne 'file')) {
die "Was unable to find which host the svn repository is located on";
}
if ($url_type ne 'file') {
sub fix_content {
my ($s) = @_;
+ if (not ref(${[values %{$s}]}[0]) eq 'HASH') {
+ $s = {$s->{time} => $s};
+ }
foreach my $entry (values %{$s}) {
if (exists $entry->{content}) {
$entry->{content} =~ s/^\s*|\s*$//g;