aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tom Willemsen2012-12-28 01:39:16 +0100
committerGravatar Tom Willemsen2012-12-28 01:39:16 +0100
commit59af3a13f9bbe828286c1658c42f832f90cb575b (patch)
tree320800dd7f0f548009310e3d11bfe30353a85e28
parent908bbc3cfba656de895f4803d6b040f917594ff9 (diff)
downloadmarkam-59af3a13f9bbe828286c1658c42f832f90cb575b.tar.gz
markam-59af3a13f9bbe828286c1658c42f832f90cb575b.zip
Don't bail when a tag doesn't exist yet
Add the tag to the database if `first-result' returns nothing.
-rw-r--r--linkwave.scm20
1 files changed, 13 insertions, 7 deletions
diff --git a/linkwave.scm b/linkwave.scm
index 235615b..455b0a2 100644
--- a/linkwave.scm
+++ b/linkwave.scm
@@ -15,19 +15,25 @@
(format #t "~a~% ~a~% ~a~% ~a~%~%" (string-no-null name) (string-no-null description)
(string-no-null url) (seconds->string seconds)))
+(define (add-tag name)
+ (execute db "INSERT INTO tag VALUES (?)" name)
+ (last-insert-rowid db))
+
(define (add-bookmark url name description tags)
(execute db "INSERT INTO bookmark VALUES (?, STRFTIME('%s'), ?, ?)"
url name description)
(let ((bookmark-id (last-insert-rowid db)))
(for-each (lambda (tag)
- (let ((tag-id (first-result db "SELECT rowid FROM tag WHERE name = ?" tag)))
- (unless tag-id
- (execute db "INSERT INTO tag VALUES (?)" tag)
- (set! tag-id (last-insert-rowid db)))
+ (let ((tag-id '()))
+ (condition-case
+ (set! tag-id (first-result db "SELECT rowid FROM tag WHERE name = ?" tag))
+ (exn (exn sqlite3)
+ (if (eq? (get-condition-property exn 'sqlite3 'status) 'done)
+ (set! tag-id (add-tag tag))
+ (signal exn))))
(execute db "INSERT INTO bookmark_tag VALUES (?, ?)"
bookmark-id tag-id)))
- tags))
- #t)
+ tags)))
(define (url-string? str)
(and (> (string-length str) 7)
@@ -42,7 +48,7 @@
(cond
((url-string? (car cla))
(with-transaction
- db (lambda () (add-bookmark (car cla) (cadr cla) (caddr cla) (cdddr cla)))))
+ db (lambda () (add-bookmark (car cla) (cadr cla) (caddr cla) (cdddr cla)) #t)))
(else
(format #t "Unrecognized option: ~a~%" (car cla))))))