summaryrefslogtreecommitdiff
path: root/lib/coderay/scanners
diff options
context:
space:
mode:
authorKornelius Kalnbach <murphy@rubychan.de>2013-06-12 15:09:45 +0200
committerKornelius Kalnbach <murphy@rubychan.de>2013-06-12 15:09:45 +0200
commitce3f8389dda50a93a4aec151f6051841d7c65099 (patch)
treefcc971ea1151dacdb50c0368833848d86a18bff0 /lib/coderay/scanners
parent2e4e83bf84282d6ce7fbc9eeff2cbe1c79788a9b (diff)
parentaeac6672fbe70702288b259605cb863493ad8ac2 (diff)
downloadcoderay-ce3f8389dda50a93a4aec151f6051841d7c65099.tar.gz
Merge remote-tracking branch 'shimomura1004/taskpaper' into taskpaper-scanner
Diffstat (limited to 'lib/coderay/scanners')
-rw-r--r--lib/coderay/scanners/taskpaper.rb34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/coderay/scanners/taskpaper.rb b/lib/coderay/scanners/taskpaper.rb
new file mode 100644
index 0000000..c6eb3b3
--- /dev/null
+++ b/lib/coderay/scanners/taskpaper.rb
@@ -0,0 +1,34 @@
+module CodeRay
+module Scanners
+
+ class Taskpaper < Scanner
+
+ register_for :taskpaper
+ file_extension 'taskpaper'
+
+ protected
+
+ def scan_tokens encoder, options
+ until eos?
+ if match = scan(/^\S.*:.*$/) # project
+ encoder.text_token(match, :project)
+ elsif match = scan(/^-.+@done(?:\(.*)?.*$/) # completed task
+ encoder.text_token(match, :complete)
+ elsif match = scan(/^-.+$/) # task
+ encoder.text_token(match, :plain)
+ elsif match = scan(/^.+$/) # comment
+ encoder.text_token(match, :comment)
+ elsif match = scan(/\s+/) # space
+ encoder.text_token(match, :space)
+ else # other
+ encoder.text_token getch, :error
+ end
+ end
+
+ encoder
+ end
+
+ end
+
+end
+end