Last active
December 14, 2024 16:57
-
-
Save jabofh/88b29863f57a045db18d53439183cd15 to your computer and use it in GitHub Desktop.
Convert TaskPaper formatted File or Input to Markdown on Standard Output
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/usr/bin/env perl -T | |
use strict; | |
use warnings; | |
use Getopt::Std; | |
my $VERSION = "0.0.5"; | |
$Getopt::Std::STANDARD_HELP_VERSION = 1; | |
#=============================================================================== | |
# Functions | |
#------------------------------------------------------------------------------- | |
sub VERSION_MESSAGE | |
{ | |
my $fh = shift; | |
(my $progname = $0) =~ s|^.*/||; | |
print $fh "$progname version $VERSION\n"; | |
} | |
sub HELP_MESSAGE | |
{ | |
my $fh = shift; | |
(my $progname = $0) =~ s|^.*/||; | |
print $fh "\nUsage: $progname [option] FILE\n"; | |
print $fh "\n\tWhere the options are:\n"; | |
print $fh "\t\t-h\tThis Help\n"; | |
print $fh "\t\t-v\tShow Version\n"; | |
print $fh "\t\t-o FILE\tOutput File (defaults to STDOUT)\n"; | |
print $fh "\t\t-b\tDisable Block-quote Notes\n"; | |
print $fh "\n\tConverts TaskPaper file 'FILE' to Markdown format on STDOUT\n\n"; | |
exit 1; | |
} | |
sub main | |
{ | |
my %options=(); | |
getopts('Hhvbo:', \%options) or HELP_MESSAGE("STDERR"); | |
if ($options{h} or $options{H}) { | |
VERSION_MESSAGE(*STDERR); | |
HELP_MESSAGE(*STDERR); | |
} | |
if ($options{v}) { | |
VERSION_MESSAGE(*STDERR); | |
exit 1; | |
} | |
my $fh = *STDOUT; | |
my $blockQuote = $options{b} ? 0 : 1; | |
my $filename = $options{o} ? $options{o} : '-'; | |
if ($filename =~ m{\A([\w.]+)\z} and $filename ne 'STDOUT') { | |
$filename = $1; | |
open $fh, q{>}, $filename; | |
} | |
my $calcIndent = 0; | |
my $indentOffset = 0; | |
my $displayIndent = 0; | |
while (<>) { | |
chomp; | |
next if $_ =~ m|^\s*$|; | |
my $calcIndent = CountIndent($_); | |
if ($_ =~ m|^\s*- .*$|) { | |
$_ = ProcessTasks($_); | |
} elsif ($_ =~ m|^\s*[^-].+: *@*\w*$|) { | |
$_ = ProcessProjects($_) ; | |
$indentOffset = $calcIndent; | |
} else { | |
$_ = ProcessNotes($_, $blockQuote); | |
} | |
$displayIndent = $calcIndent - $indentOffset; | |
if ($_ =~ m|@\S+|) { | |
$_ = ProcessTags($_); | |
} | |
$_ = ProcessExhortations($_); | |
print $fh " " x $displayIndent . $_ . " \n\n"; | |
} | |
close($fh); | |
} | |
sub ProcessProjects($) | |
{ | |
my $line = $_[0]; | |
my $offset = CountIndent($line); | |
$line =~ s|^|#|; | |
$line =~ s|:$||g; | |
$line =~ s|: *@| @|g; | |
$line =~ s|\t|#|g; | |
$line =~ s|^(#+)|$1 |; | |
return "\n" . $line; | |
} | |
sub ProcessTasks($) | |
{ | |
my $line = $_[0]; | |
my $offset = CountIndent($line); | |
$line =~ s|^\t+||g; | |
return $line; | |
} | |
sub ProcessNotes($) | |
{ | |
my $line = $_[0]; | |
my $blockQuote = $_[1]; | |
my $offset = CountIndent($line); | |
$line =~ s|^\t+||g; | |
if ($blockQuote) { | |
$line =~ s|^|> |; | |
} | |
return $line; | |
} | |
sub CountIndent($) | |
{ | |
my $string = $_[0]; | |
$string =~ s/^\t+//; | |
my $indent = length($_[0]) - length($string); | |
return $indent; | |
} | |
sub ProcessTags($) | |
{ | |
my $line = $_[0]; | |
$line =~ s|\s@(\w+[-]*\w+)| #$1|g; | |
return $line; | |
} | |
sub ProcessExhortations($) | |
{ | |
my $line = $_[0]; | |
my %exhortations = ( | |
MUST => '_must_', | |
SHOULD => '_should_', | |
MAY => '_may_', | |
BE => '_be_', | |
NOT => '_not_', | |
); | |
foreach my $key (keys %exhortations) { | |
$line =~ s|$key|$exhortations{$key}|g; | |
} | |
$line =~ s/_ _/ /g; | |
return $line; | |
} | |
#=============================================================================== | |
main(@ARGV); | |
exit(0); |
@abbasou: The easiest way currently, would be to redirect the output:
tp2md.pl foo.task > foo-task.md
@abbasou: I have updated the gist; the script will now take a -o
output while still defaulting to STDOUT.
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Forgive me, how do I write the output to a file? I'm on Windows 10. I use Atom as my taskpaper editor and either Atom or Typora as my markdown editor. I'm running the script via CLI. Is there an argument to define the output file? Currently it outputs directly in the terminal window. Or is there another, newer way of achieving the conversion from TP to MD? Any help is appreciated.