[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[O] [PATCH] Bug: org-clock-out-if-current => "marker does not point anyw
From: |
Dave Abrahams |
Subject: |
[O] [PATCH] Bug: org-clock-out-if-current => "marker does not point anywhere" [7.7 (release_7.7.397.g5adafd)] |
Date: |
Tue, 22 Nov 2011 20:49:12 -0800 |
User-agent: |
Gnus/5.110018 (No Gnus v0.18) Emacs/23.3 (darwin) |
The following patch fixes the bug.
--8<---------------cut here---------------start------------->8---
diff --git a/lisp/org-clock.el b/lisp/org-clock.el
index e026d93..b47ac66 100644
--- a/lisp/org-clock.el
+++ b/lisp/org-clock.el
@@ -1697,6 +1697,7 @@ from the `before-change-functions' in the current buffer."
This is used to stop the clock after a TODO entry is marked DONE,
and is only done if the variable `org-clock-out-when-done' is not nil."
(when (and org-clock-out-when-done
+ (marker-buffer org-clock-marker)
(or (and (eq t org-clock-out-when-done)
(member state org-done-keywords))
(and (listp org-clock-out-when-done)
--8<---------------cut here---------------end--------------->8---
on Fri Nov 18 2011, Dave Abrahams <dave-AT-boostpro.com> wrote:
> Remember to cover the basics, that is, what you expected to happen and
> what in fact did happen. You don't know how to make a good report? See
>
> http://orgmode.org/manual/Feedback.html#Feedback
>
> Your bug report will be posted to the Org-mode mailing list.
>
> ------------------------------------------------------------------------
>
> The bug is caused by the following lines:
>
> (< (point) org-clock-marker)
> (> (save-excursion (outline-next-heading) (point))
>
> where org-clock-marker is `#<marker in no buffer>'
> org-clock-out-if-current()
> run-hooks(org-after-todo-state-change-hook)
> byte-code("\306\307!\210\310!\203..\311\225Sb\210\310\312
> \313Q!\204..\310\314!\210\302 .\315 .\302
> address@hidden@.A.A.B.B\322\323!.C\311\224.D\324.C!.E\325.E.F\"address@hidden
> \202\367..Q\334\232\203\300..R\203\263..P\204\300.\335\336\337\340.M\"address@hidden@\202\367..Q\342=\203...N.M\232?\205\367..C\203..\343.MG.OG\344#.M8\202\367..M.S\345.S!@)\202\367..R\307=\203#..Q\346\232\203#.\320\211.Q\206\367..Q\203\247..Q\330\232\2033.\320\202\367..Q\347=\203>address@hidden@address@hidden@\206\201..U@)address@hidden;\203\234.\354\355.Q\"address@hidden>address@hidden@address@hidden:\203j..C.T\235?.]\212\302
>
> .\370\216\212\214~\210\371\372.Z\"-\204j.\373\374!\203[.\354\375.C.X#\210\202j.\376\375.C.X#\210\377\201g.\320\"\210\201h.\n!\210\201i..Y\307\211#\210\201j..D!\204\216.\376\201k.\201l..Y!\"\210.E\204\262.\324.X!.E\325.E.F\"address@hidden>\203\344.\376\201n.\343.^G\201o.\325.X.^\".^>G#.^G\201p.\201q.\325.X.^\"\362#$\210.X.T\235?.].X.T\235\205\372..C.T\235?.\\.\203..\201r.
> address@hidden>\204\271.\325.X.B\"address@hidden"address@hidden
> \"address@hidden|.\320\307\"\210.c\203\333.\201}.
> \210\201~.\201.!\210.Q\203\366..X.T\235\204\366.\324.X!.E\201\200.\315
> \201\201. \201\202..E$\210.\\\203*.\201\203.\201d.!\203#.\302
> .\201\204.\216\201\205. .d*\201\206..X!\210\201\207.
> \203f.n\204f.\212\201\210.\323!\210\310.e!)\203f.`\344\211\225\206M.\323\225\\W\203f.\344\225\206Y.\323\225b\210\310\362!\203f.\201\211.
> \210.f\205v.\212\201\212.\201f..Z\")..\207" [org-outline-regexp
> org-todo-regexp match-data startpos save-match-data-internal logging
> org-back-to-heading t looking-at 0 " +" "\\( +\\|$\\)" " *" point-at-bol
> ((byte-code "\301\302\"\207" [save-match-data-internal set-match-data
> evaporate] 3)) org-entry-get nil "LOGGING" match-string 1
> org-get-todo-sequence-head assoc 3 4 "" (4) prefix org-fast-todo-selection
> (4) org-icompleting-read "State: " mapcar #[(x) "C\207" [x] 1] right left -
> 2 last (4) none done nextset previousset reverse error "State `%s' not valid
> in this file" prefix-numeric-value (type priority)
> run-hook-with-args-until-success org-todo-get-default-hook ...] 10)
> org-todo(done)
> (if (or (match-string 2) (and ... ...)) (org-todo (quote done)) (org-todo
> (quote todo)))
> (progn (if (or ... ...) (org-todo ...) (org-todo ...)))
> (if (looking-at (concat "^\\*+[ ]+" org-todo-regexp "[ ].*\\[" "\\(?:"
> "\\(?2:100%\\)\\|[0-9]+%" "\\|" "\\(?3:[0-9]+\\)" "/" "\\(?4:[0-9]+\\)" "\\)"
> "\\]")) (progn (if ... ... ...)))
> (when (looking-at (concat "^\\*+[ ]+" org-todo-regexp "[ ].*\\[" "\\(?:"
> "\\(?2:100%\\)\\|[0-9]+%" "\\|" "\\(?3:[0-9]+\\)" "/" "\\(?4:[0-9]+\\)" "\\)"
> "\\]")) (if (or ... ...) (org-todo ...) (org-todo ...)))
> (save-excursion (org-back-to-heading t) (when (looking-at ...) (if ... ...
> ...)))
> dwa/checkbox-list-complete()
> run-hooks(org-checkbox-statistics-hook)
> org-update-checkbox-count-maybe()
> org-ctrl-c-ctrl-c(nil)
> call-interactively(org-ctrl-c-ctrl-c nil nil)
> Emacs : GNU Emacs 23.3.1 (x86_64-apple-darwin11.2.0, Carbon Version 1.6.0
> AppKit 1138.23)
> of 2011-11-13 on pluto.luannocracy.com
> Package: Org-mode version 7.7 (release_7.7.397.g5adafd)
>
> current state:
> ==============
> (setq
> org-x-backends '(ox-org ox-redmine)
> org-log-done 'time
> org-agenda-deadline-leaders '("D: " "D%d: ")
> org-clock-in-switch-to-state "STARTED"
> org-agenda-skip-scheduled-if-deadline-is-shown t
> org-export-latex-after-initial-vars-hook '(org-beamer-after-initial-vars)
> org-special-ctrl-a/e '(nil . t)
> org-x-redmine-title-prefix-match-function 'org-x-redmine-title-prefix-match
> org-default-priority 67
> org-speed-command-hook '(org-speed-command-default-hook
> org-babel-speed-command-hook)
> org-agenda-custom-commands '(("E" "Errands (next 3 days)" tags
>
> "Errand&TODO<>\"DONE\"&TODO<>\"CANCELED\"&STYLE<>\"habit\"&SCHEDULED<\"<+3d>\""
> ((org-agenda-overriding-header "Errands (next
> 3 days)")))
> ("A" "Priority #A tasks" agenda ""
> ((org-agenda-ndays 1)
> (org-agenda-overriding-header "Today's priority #A tasks: ")
> (org-agenda-skip-function
> (quote (org-agenda-skip-entry-if (quote
> notregexp) "\\=.*\\[#A\\]")))
> )
> )
> ("b" "Priority #A and #B tasks" agenda ""
> ((org-agenda-ndays 1)
> (org-agenda-overriding-header "Today's
> priority #A and #B tasks: ")
> (org-agenda-skip-function
> (quote (org-agenda-skip-entry-if (quote
> regexp) "\\=.*\\[#C\\]")))
> )
> )
> ("w" "Waiting/delegated tasks" tags
> "TODO=\"WAITING\"|TODO=\"DELEGATED\""
> ((org-agenda-overriding-header
> "Waiting/delegated tasks:")
> (org-agenda-sorting-strategy (quote
> (todo-state-up priority-down category-up))))
> )
> ("p" "Unprioritized tasks" tags
>
> "AREA<>\"Work\"&TODO<>\"\"&TODO<>{DONE\\|CANCELED\\|NOTE\\|PROJECT\\|DEFERRED\\|SOMEDAY}"
> ((org-agenda-files
>
>
> (quote
>
>
>
> ("~/Documents/Tasks/todo.txt")
>
>
> )
>
>
> )
>
>
> (org-agenda-overriding-header
> "Unprioritized tasks: ")
>
>
> (org-agenda-skip-function
>
>
> (quote
>
>
>
> (org-agenda-skip-entry-if
>
>
>
> (quote regexp)
>
>
>
> "\\=.*\\[#[A-Z]\\]")
>
>
> )
>
>
> )
>
>
> )
> )
> ("u" "Unscheduled tasks" tags
>
> "AREA<>\"Work\"&TODO<>\"\"&TODO<>{DONE\\|CANCELED\\|NOTE\\|PROJECT}"
> ((org-agenda-files (quote
> ("~/Documents/Tasks/todo.txt")))
> (org-agenda-overriding-header "Unscheduled
> tasks: ")
> (org-agenda-skip-function
> (quote
> (org-agenda-skip-entry-if (quote scheduled)
> (quote deadline) (quote timestamp)
> (quote regexp) "\\*
> \\(DEFERRED\\|SOMEDAY\\)")
> )
> )
> (org-agenda-sorting-strategy (quote
> (priority-down))))
> )
> ("U" "Deferred tasks" tags "TODO=\"DEFERRED\""
> ((org-agenda-files (quote
> ("~/Documents/Tasks/todo.txt")))
> (org-agenda-overriding-header "Deferred
> tasks:"))
> )
> ("Y" "Someday tasks" tags "TODO=\"SOMEDAY\""
> ((org-agenda-overriding-header "Someday
> tasks:")))
> ("G" "Ledger tasks (all)" alltodo ""
> ((org-agenda-files (quote
> ("~/src/ledger/plan/TODO")))
> (org-agenda-overriding-header "Ledger tasks:")
> (org-agenda-sorting-strategy (quote
> (todo-state-up priority-down category-up))))
> )
> ("N" "Ledger tasks (all, alphabetical)" alltodo
> ""
> ((org-agenda-files (quote
> ("~/src/ledger/plan/TODO")))
> (org-agenda-overriding-header "Ledger tasks,
> alphabetical:")
> (org-agenda-sorting-strategy (quote
> (alpha-up))))
> )
> ("l" "Ledger tasks" tags-todo
> "TODO<>{SOMEDAY\\|DEFERRED}"
> ((org-agenda-files (quote
> ("~/src/ledger/plan/TODO")))
> (org-agenda-overriding-header "Ledger tasks:")
> (org-agenda-sorting-strategy (quote
> (todo-state-up priority-down category-up)))
> (org-agenda-skip-function
> (quote (org-agenda-skip-entry-if (quote
> regexp) "\\=.*\\[#C\\]")))
> )
> )
> ("L" "Ledger tasks not in Bugzilla" tags
> "TODO<>{DONE\\|TESTED\\|CLOSED\\|NOTE}&LEVEL=2"
> ((org-agenda-files (quote
> ("~/src/ledger/plan/TODO")))
> (org-agenda-overriding-header "Ledger tasks:")
> (org-agenda-sorting-strategy (quote
> (todo-state-up priority-down category-up)))
> (org-agenda-skip-function (quote
> (org-agenda-skip-entry-if (quote regexp) "#"))))
> )
> ("r" "Uncategorized items" tags
> "CATEGORY=\"Inbox\"&LEVEL=2"
> ((org-agenda-overriding-header "Uncategorized
> items")))
> ("V" "Unscheduled work-related tasks" tags
>
> "AREA=\"Work\"&TODO<>\"\"&TODO<>{DONE\\|CANCELED\\|NOTE\\|PROJECT}"
> ((org-agenda-overriding-header "Unscheduled
> work-related tasks")
> (org-agenda-files (quote
> ("~/Documents/Tasks/todo.txt")))
> (org-agenda-sorting-strategy (quote
> (category-up)))
> (org-agenda-skip-function
> (quote
> (org-agenda-skip-entry-if (quote scheduled)
> (quote deadline) (quote timestamp)
> (quote regexp) "\\*
> \\(DEFERRED\\|SOMEDAY\\)")
> )
> )
> )
> )
> ("W" "Work-related tasks" tags
>
> "AREA=\"Work\"&TODO<>\"\"&TODO<>{DONE\\|CANCELED\\|NOTE\\|PROJECT}"
> ((org-agenda-overriding-header "Work-related
> tasks")
> (org-agenda-files (quote
> ("~/Documents/Tasks/todo.txt")))
> (org-agenda-sorting-strategy
> (quote (category-up priority-down
> todo-state-up alpha-up)))
> (org-agenda-skip-function
> (quote (org-agenda-skip-entry-if (quote
> regexp) "\\* \\(DEFERRED\\|SOMEDAY\\)")))
> )
> )
> )
> org-agenda-files '("~/Documents/Tasks/todo.txt")
> org-agenda-include-diary t
> org-blocker-hook '(org-block-todo-from-children-or-siblings-or-parent)
> org-src-fontify-natively t
> org-habit-completed-glyph 10004
> org-habit-show-habits-only-for-today nil
> org-agenda-window-setup 'current-window
> org-hide-leading-stars t
> org-clock-into-drawer "LOGBOOK"
> org-checklist-export-function 'org-export-as-ascii
> org-completion-use-ido t
> org-metaup-hook '(org-babel-load-in-session-maybe)
> org-capture-templates '(("t" "Task" entry (file+headline
> "~/Documents/Tasks/todo.txt" "Inbox")
> "* TODO %?\n SCHEDULED: %t\n :PROPERTIES:\n :ID:
> %(shell-command-to-string \"uuidgen\") :CREATED: %U\n :END:"
> :prepend t)
> )
> org-footnote-section nil
> org-agenda-scheduled-leaders '("" "S%d: ")
> org-archive-save-context-info '(time category itags)
> org-after-todo-state-change-hook '(org-clock-out-if-current org-checklist)
> org-babel-tangle-lang-exts '(("python" . "py") ("emacs-lisp" . "el"))
> org-agenda-text-search-extra-files '(agenda-archives)
> org-x-priority-B-silent nil
> org-agenda-follow-indirect t
> org-archive-location "TODO-archive::"
> org-agenda-skip-unavailable-files t
> org-agenda-default-appointment-duration 60
> org-speed-commands-user '(("+" . org-priority-up) ("-" . org-priority-down))
> org-habit-today-glyph 9483
> org-time-clocksum-use-fractional t
> org-edit-src-content-indentation 0
> org-agenda-sorting-strategy '((agenda habit-down time-up todo-state-up
> priority-down category-keep)
> (todo priority-down category-keep) (tags
> priority-down category-keep)
> (search category-keep))
> org-export-blocks-postblock-hook '(org-exp-res/src-name-cleanup)
> org-agenda-prefix-format '((agenda . " %-11:c%?-12t% s") (timeline . " %
> s") (todo . " %-11:c")
> (tags . " %-11:c"))
> org-after-todo-statistics-hook '(dwa/org-summary-todo)
> org-agenda-restore-windows-after-quit t
> org-habit-preceding-days 42
> org-export-latex-format-toc-function 'org-export-latex-format-toc-default
> org-agenda-skip-scheduled-if-done t
> org-x-redmine-title-prefix-function 'org-x-redmine-title-prefix
> org-clock-in-resume t
> org-tab-first-hook '(yas/org-very-safe-expand org-hide-block-toggle-maybe
> org-src-native-tab-command-maybe
> org-babel-hide-result-toggle-maybe)
> org-src-mode-hook '(org-src-babel-configure-edit-buffer
> org-src-mode-configure-edit-buffer)
> org-finalize-agenda-hook '(org-agenda-add-overlays)
> org-cycle-global-at-bob t
> org-confirm-shell-link-function nil
> org-export-first-hook '(org-beamer-initialize-open-trackers)
> org-clock-persist 'history
> org-agenda-before-write-hook '(org-agenda-add-entry-text)
> org-agenda-start-with-follow-mode t
> org-default-notes-file "~/Documents/Tasks/todo.txt"
> org-use-property-inheritance '("AREA")
> org-directory "~/Documents/Tasks/"
> org-agenda-persistent-filter t
> org-blank-before-new-entry nil
> org-babel-pre-tangle-hook '(save-buffer)
> org-cycle-hook '(org-cycle-hide-archived-subtrees org-cycle-hide-drawers
> org-cycle-show-empty-lines
> org-optimize-window-after-visibility-change)
> org-export-preprocess-before-normalizing-links-hook
> '(org-remove-file-link-modifiers)
> org-enable-table-editor t
> org-refile-target-verify-function 'dwa/org-verify-refile-target
> org-use-speed-commands t
> org-mode-hook '((lambda nil (set (make-local-variable (quote
> yas/trigger-key)) [tab])
> (add-to-list (quote org-tab-first-hook) (quote
> yas/org-very-safe-expand))
> (define-key yas/keymap [tab] (quote yas/next-field)))
> (lambda nil (local-unset-key (kbd ".,")))
> #[nil "\300\301\302\303\304$\207"
> [org-add-hook change-major-mode-hook org-show-block-all
> append local] 5]
> #[nil "\300\301\302\303\304$\207"
> [org-add-hook change-major-mode-hook
> org-babel-show-result-all append local] 5]
> org-babel-result-hide-spec org-babel-hide-all-hashes)
> org-clock-out-remove-zero-time-clocks t
> org-agenda-ndays 1
> org-refile-targets '((nil :todo . "PROJECT") (nil :maxlevel . 2))
> org-extend-today-until 6
> org-mobile-pre-pull-hook '(my-org-convert-incoming-items)
> org-ctrl-c-ctrl-c-hook '(org-babel-hash-at-point
> org-babel-execute-safely-maybe)
> org-log-buffer-setup-hook '((lambda nil (setq fill-column (- fill-column
> 5))))
> org-pretty-entities t
> org-return-follows-link t
> org-confirm-elisp-link-function nil
> org-fast-tag-selection-single-key 'expert
> org-todo-repeat-to-state "TODO"
> org-log-into-drawer t
> org-clock-modeline-total 'current
> org-agenda-mode-hook '((lambda nil (local-unset-key (kbd ".,"))))
> org-agenda-start-on-weekday nil
> org-agenda-fontify-priorities t
> org-export-interblocks '((lob org-babel-exp-lob-one-liners) (src
> org-babel-exp-inline-src-blocks))
> org-log-repeat nil
> org-clock-out-hook '(org-clock-remove-empty-clock-drawer)
> org-enforce-todo-dependencies t
> org-agenda-skip-deadline-if-done t
> org-reverse-note-order t
> org-occur-hook '(org-first-headline-recenter)
> org-checkbox-statistics-hook '(dwa/checkbox-list-complete)
> org-export-babel-evaluate nil
> org-mobile-post-push-hook '((lambda nil (shell-command "/bin/rm -f
> ~/Dropbox/MobileOrg/agendas.org")
> (shell-command
> (concat "perl -i -ne 'print unless
> /agendas\\.org/;'"
> "~/Dropbox/MobileOrg/checksums.dat")
> )
> (shell-command
> (concat "perl -i -ne 'print unless
> /agendas\\.org/;'" "~/Dropbox/MobileOrg/index.org")
> )
> )
> )
> org-drawers '("PROPERTIES" "CLOCK" "LOGBOOK" "OUT")
> org-export-preprocess-before-selecting-backend-code-hook
> '(org-beamer-select-beamer-code)
> org-tags-column -97
> org-modules '(org-id org-info org-habit)
> org-agenda-auto-exclude-function 'org-my-auto-exclude-function
> org-export-latex-final-hook '(org-beamer-amend-header org-beamer-fix-toc
> org-beamer-auto-fragile-frames
> org-beamer-place-default-actions-for-lists)
> org-metadown-hook '(org-babel-pop-to-session-maybe)
> org-clock-idle-time 10
> org-attach-method 'mv
> org-export-blocks '((src org-babel-exp-src-block nil) (comment
> org-export-blocks-format-comment t)
> (ditaa org-export-blocks-format-ditaa nil) (dot
> org-export-blocks-format-dot nil))
> )
--
Dave Abrahams
BoostPro Computing
http://www.boostpro.com