Merge branch 'master' of code.orgmode.org:bzg/org-mode

This commit is contained in:
Bastien 2018-11-27 09:22:31 +01:00
commit 32b16bceb6
6 changed files with 107 additions and 13 deletions

View File

@ -66,6 +66,7 @@
;; Vimperator/Firefox.app - Grab the url of the frontmost tab in the frontmost window ;; Vimperator/Firefox.app - Grab the url of the frontmost tab in the frontmost window
;; Safari.app - Grab the url of the frontmost tab in the frontmost window ;; Safari.app - Grab the url of the frontmost tab in the frontmost window
;; Google Chrome.app - Grab the url of the frontmost tab in the frontmost window ;; Google Chrome.app - Grab the url of the frontmost tab in the frontmost window
;; Brave.app - Grab the url of the frontmost tab in the frontmost window
;; Together.app - Grab links to the selected items in the library list ;; Together.app - Grab links to the selected items in the library list
;; Skim.app - Grab a link to the selected page in the topmost pdf document ;; Skim.app - Grab a link to the selected page in the topmost pdf document
;; Microsoft Outlook.app - Grab a link to the selected message in the message list ;; Microsoft Outlook.app - Grab a link to the selected message in the message list
@ -164,6 +165,12 @@
:group 'org-mac-link :group 'org-mac-link
:type 'boolean) :type 'boolean)
(defcustom org-mac-grab-Brave-app-p t
"Add menu option [b]rave to grab links from Brave.app."
:tag "Grab Brave.app links"
:group 'org-mac-link
:type 'boolean)
(defcustom org-mac-grab-Together-app-p nil (defcustom org-mac-grab-Together-app-p nil
"Add menu option [t]ogether to grab links from Together.app." "Add menu option [t]ogether to grab links from Together.app."
:tag "Grab Together.app links" :tag "Grab Together.app links"
@ -249,6 +256,7 @@ When done, go grab the link, and insert it at point."
("f" "irefox" org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p) ("f" "irefox" org-mac-firefox-insert-frontmost-url ,org-mac-grab-Firefox-app-p)
("v" "imperator" org-mac-vimperator-insert-frontmost-url ,org-mac-grab-Firefox+Vimperator-p) ("v" "imperator" org-mac-vimperator-insert-frontmost-url ,org-mac-grab-Firefox+Vimperator-p)
("c" "hrome" org-mac-chrome-insert-frontmost-url ,org-mac-grab-Chrome-app-p) ("c" "hrome" org-mac-chrome-insert-frontmost-url ,org-mac-grab-Chrome-app-p)
("b" "rave" org-mac-brave-insert-frontmost-url ,org-mac-grab-Brave-app-p)
("e" "evernote" org-mac-evernote-note-insert-selected ,org-mac-grab-Evernote-app-p) ("e" "evernote" org-mac-evernote-note-insert-selected ,org-mac-grab-Evernote-app-p)
("t" "ogether" org-mac-together-insert-selected ,org-mac-grab-Together-app-p) ("t" "ogether" org-mac-together-insert-selected ,org-mac-grab-Together-app-p)
("S" "kim" org-mac-skim-insert-page ,org-mac-grab-Skim-app-p) ("S" "kim" org-mac-skim-insert-page ,org-mac-grab-Skim-app-p)
@ -424,6 +432,39 @@ The links are of the form <link>::split::<name>."
(interactive) (interactive)
(insert (org-mac-chrome-get-frontmost-url))) (insert (org-mac-chrome-get-frontmost-url)))
;; Handle links from Brave.app
;; Grab the frontmost url from Brave. Same limitations as
;; Firefox/Chrome because Brave doesn't publish an Applescript
;; dictionary
(defun org-as-mac-brave-get-frontmost-url ()
(let ((result
(do-applescript
(concat
"set frontmostApplication to path to frontmost application\n"
"tell application \"Brave\"\n"
" set theUrl to get URL of active tab of first window\n"
" set theResult to (get theUrl) & \"::split::\" & (get name of window 1)\n"
"end tell\n"
"activate application (frontmostApplication as text)\n"
"set links to {}\n"
"copy theResult to the end of links\n"
"return links as string\n"))))
(replace-regexp-in-string
"^\"\\|\"$" "" (car (split-string result "[\r\n]+" t)))))
;;;###autoload
(defun org-mac-brave-get-frontmost-url ()
(interactive)
(message "Applescript: Getting Brave url...")
(org-mac-paste-applescript-links (org-as-mac-brave-get-frontmost-url)))
;;;###autoload
(defun org-mac-brave-insert-frontmost-url ()
(interactive)
(insert (org-mac-brave-get-frontmost-url)))
;; Handle links from Safari.app ;; Handle links from Safari.app
;; Grab the frontmost url from Safari. ;; Grab the frontmost url from Safari.

View File

@ -3912,7 +3912,18 @@ element it has to parse."
((looking-at "%%(") ((looking-at "%%(")
(org-element-diary-sexp-parser limit affiliated)) (org-element-diary-sexp-parser limit affiliated))
;; Table. ;; Table.
((looking-at "[ \t]*\\(|\\|\\+\\(-+\\+\\)+[ \t]*$\\)") ((or (looking-at "[ \t]*|")
;; There is no strict definition of a table.el
;; table. Try to prevent false positive while being
;; quick.
(let ((rule-regexp "[ \t]*\\+\\(-+\\+\\)+[ \t]*$")
(next (line-beginning-position 2)))
(and (looking-at rule-regexp)
(save-excursion
(forward-line)
(re-search-forward "^[ \t]*\\($\\|[^|]\\)" limit t)
(and (> (line-beginning-position) next)
(org-match-line rule-regexp))))))
(org-element-table-parser limit affiliated)) (org-element-table-parser limit affiliated))
;; List. ;; List.
((looking-at (org-item-re)) ((looking-at (org-item-re))

View File

@ -104,10 +104,11 @@ The return value is a string naming the thing at point."
(char-before))) (char-before)))
(cons "tex" nil)) (cons "tex" nil))
;; Tags on a headline. ;; Tags on a headline.
((and (org-at-heading-p) ((and (org-match-line
(eq ?: (save-excursion (format "\\*+ \\(?:.+? \\)?\\(:\\)\\(\\(?::\\|%s\\)+\\)?[ \t]*$"
(skip-chars-backward "[:alnum:]_@#%") org-tag-re))
(char-before)))) (or (org-point-in-group (point) 2)
(= (point) (match-end 1))))
(cons "tag" nil)) (cons "tag" nil))
;; TODO keywords on an empty headline. ;; TODO keywords on an empty headline.
((and (string-match "^\\*+ +\\S-*$" line-to-here) ((and (string-match "^\\*+ +\\S-*$" line-to-here)
@ -372,7 +373,8 @@ This needs more work, to handle headings with lots of spaces in them."
(setq lst (delete tag lst))) (setq lst (delete tag lst)))
lst)) lst))
(and (string-match ".*:" pcomplete-stub) (and (string-match ".*:" pcomplete-stub)
(substring pcomplete-stub (match-end 0)))))) (substring pcomplete-stub (match-end 0)))
t)))
(defun pcomplete/org-mode/drawer () (defun pcomplete/org-mode/drawer ()
"Complete a drawer name, including \"PROPERTIES\"." "Complete a drawer name, including \"PROPERTIES\"."

View File

@ -10284,9 +10284,10 @@ a link."
(org-search-radio-target (org-search-radio-target
(org-element-property :path context)) (org-element-property :path context))
(org-link-search (org-link-search
(if (member type '("custom-id" "coderef")) (pcase type
(org-element-property :raw-link context) ("custom-id" (concat "#" path))
path) ("coderef" (format "(%s)" path))
(_ path))
;; Prevent fuzzy links from matching ;; Prevent fuzzy links from matching
;; themselves. ;; themselves.
(and (equal type "fuzzy") (and (equal type "fuzzy")
@ -20442,7 +20443,8 @@ object (e.g., within a comment). In these case, you need to use
(cond (cond
;; In a table, call `org-table-next-row'. However, before first ;; In a table, call `org-table-next-row'. However, before first
;; column or after last one, split the table. ;; column or after last one, split the table.
((or (and (eq (org-element-type context) 'table) ((or (and (eq 'table (org-element-type context))
(not (eq 'table.el (org-element-property :type context)))
(>= (point) (org-element-property :contents-begin context)) (>= (point) (org-element-property :contents-begin context))
(< (point) (org-element-property :contents-end context))) (< (point) (org-element-property :contents-end context)))
(org-element-lineage context '(table-row table-cell) t)) (org-element-lineage context '(table-row table-cell) t))
@ -20468,9 +20470,8 @@ object (e.g., within a comment). In these case, you need to use
(call-interactively #'org-open-at-point)) (call-interactively #'org-open-at-point))
;; Insert newline in heading, but preserve tags. ;; Insert newline in heading, but preserve tags.
((and (not (bolp)) ((and (not (bolp))
(save-excursion (beginning-of-line) (let ((case-fold-search nil))
(let ((case-fold-search nil)) (org-match-line org-complex-heading-regexp)))
(looking-at org-complex-heading-regexp))))
;; At headline. Split line. However, if point is on keyword, ;; At headline. Split line. However, if point is on keyword,
;; priority cookie or tags, do not break any of them: add ;; priority cookie or tags, do not break any of them: add
;; a newline after the headline instead. ;; a newline after the headline instead.

View File

@ -125,6 +125,39 @@
(pcomplete) (pcomplete)
(buffer-string))))) (buffer-string)))))
(ert-deftest test-org-pcomplete/tag ()
"Test tag completion."
;; Complete at end of line, according to `org-current-tag-alist'.
(should
(equal "* H :foo:"
(org-test-with-temp-text "* H :<point>"
(let ((org-current-tag-alist '(("foo")))) (pcomplete))
(buffer-string))))
(should
(equal "* H :foo:bar:"
(org-test-with-temp-text "* H :foo:b<point>"
(let ((org-current-tag-alist '(("bar")))) (pcomplete))
(buffer-string))))
;; If `org-current-tag-alist' is non-nil, complete against tags in
;; buffer.
(should
(equal "* H1 :bar:\n* H2 :bar:"
(org-test-with-temp-text "* H1 :bar:\n* H2 :<point>"
(let ((org-current-tag-alist nil)) (pcomplete))
(buffer-string))))
;; Do not complete in the middle of a line.
(should
(equal "* H :notag: :real:tags:"
(org-test-with-temp-text "* H :notag:<point> :real:tags:"
(let ((org-current-tag-alist '(("foo")))) (pcomplete))
(buffer-string))))
;; Complete even when there's a match on the line.
(should
(equal "* foo: :foo:"
(org-test-with-temp-text "* foo: :<point>"
(let ((org-current-tag-alist '(("foo")))) (pcomplete))
(buffer-string)))))
(ert-deftest test-org-pcomplete/todo () (ert-deftest test-org-pcomplete/todo ()
"Test TODO completion." "Test TODO completion."
(should (should

View File

@ -2338,6 +2338,12 @@ SCHEDULED: <2014-03-04 tue.>"
"* H1\n:PROPERTIES:\n:CUSTOM_ID: custom\n:END:\n* H2\n[[#custom<point>]]" "* H1\n:PROPERTIES:\n:CUSTOM_ID: custom\n:END:\n* H2\n[[#custom<point>]]"
(org-open-at-point) (org-open-at-point)
(looking-at-p "\\* H1"))) (looking-at-p "\\* H1")))
;; Handle escape characters.
(should
(org-test-with-temp-text
"* H1\n:PROPERTIES:\n:CUSTOM_ID: [%]\n:END:\n* H2\n[[#%5B%25%5D<point>]]"
(org-open-at-point)
(looking-at-p "\\* H1")))
;; Throw an error on false positives. ;; Throw an error on false positives.
(should-error (should-error
(org-test-with-temp-text (org-test-with-temp-text