aboutsummaryrefslogtreecommitdiffstats
path: root/readme_generator.pl
diff options
context:
space:
mode:
authorTom Feist <shabble@metavore.org>2011-04-18 09:27:56 +0000
committerTom Feist <shabble@metavore.org>2011-04-18 09:27:56 +0000
commit8f2c0f48264fd91477c0d2b049b964d9088bbb6c (patch)
tree554d5ad92d80b4ba1f42762ff201b3252836004e /readme_generator.pl
parentfixed readme_generator again to append to files, rather than trying to create (diff)
downloadirssi-scripts-8f2c0f48264fd91477c0d2b049b964d9088bbb6c.tar.gz
irssi-scripts-8f2c0f48264fd91477c0d2b049b964d9088bbb6c.zip
vim-mode/vim_mode: more changes to docs and generator. Starting to look almost
readable now.
Diffstat (limited to 'readme_generator.pl')
-rw-r--r--readme_generator.pl43
1 files changed, 23 insertions, 20 deletions
diff --git a/readme_generator.pl b/readme_generator.pl
index 67da7ac..2062ad1 100644
--- a/readme_generator.pl
+++ b/readme_generator.pl
@@ -14,6 +14,15 @@ use File::Spec;
use Pod::Markdown;
use feature qw/say/;
use Cwd;
+
+my $overwrite = $ARGV[0];
+if ($overwrite =~ m/--overwrite/) {
+ shift @ARGV; # remove it form list of dirs.
+ $overwrite = 1;
+} else {
+ $overwrite = 0;
+}
+
my @dirs = map { File::Spec->catdir(getcwd(), $_) } @ARGV;
die unless @dirs;
@@ -32,25 +41,12 @@ sub read_input_file {
my ($dir, $filename) = @_;
my $filepath = File::Spec->catfile($dir, $filename);
-
- open my $rfh, '<', $filepath or die "Couldn't open $filepath for input: $!";
-
_err("reading $filepath");
my $parser = Pod::Markdown->new;
+ $parser->parse_from_file($filepath);
- $parser->parse_from_filehandle($rfh);
-
- close $rfh;
-
- my @other_files = glob($dir . "/*.pl");
-
- # if (@other_files > 1) {
- # $filename =~ s/\.pl$//;
- # create_output_file($dir, "README-$filename.md", $parser);
- # } else {
- create_output_file($dir, "README.md", $parser);
- # }
+ create_output_file($dir, "README.md", $parser);
}
sub create_output_file {
@@ -59,20 +55,27 @@ sub create_output_file {
my $filepath = File::Spec->catfile($dir, $filename);
my $markdown = $parser->as_markdown;
+
return unless length chomp($markdown);
return if $markdown =~ m/^\s*$/;
- _err("Writing to $filepath");
my $sec_sep = '';
- if (-f $filepath) {
- _err("$filepath already exists, going to append");
+
+ if (-f $filepath and not $overwrite) {
+ _err("$filepath already exists, going to append") unless $overwrite;
$sec_sep = "\n\n* * * *\n\n";
}
- open my $wfh, '>>', $filepath or die "Couldn't open $filepath for output: $!";
+ my $mode = $overwrite ? '>' : '>>';
+
+ _err("Writing to $mode $filepath");
+
+ open my $wfh, $mode, $filepath
+ or die "Couldn't open $filepath for $mode output: $!";
+
print $wfh $sec_sep;
- print $wfh $parser->as_markdown;
+ print $wfh $parser->as_markdown; # fetch it again since we chomped $markdown.
close $wfh;
}