From: "I.S." <inquisitive.scientist@gmail.com>
To: David Maus <dmaus@ictsoc.de>
Cc: emacs-orgmode@gnu.org
Subject: Re: proposal for enhanced org-get-priority function
Date: Fri, 29 Oct 2010 07:53:37 -0400 [thread overview]
Message-ID: <4CCAB5C1.1080002@gmail.com> (raw)
In-Reply-To: <4CCAB3D8.5010505@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 1657 bytes --]
Sorry, previous patch had some junk in it. Attached is the final version
(really).
Sorry again for the confusion,
-I.S.
On 10/29/2010 7:45 AM, I.S. wrote:
> Sorry, I realized the previous patch did not contain updates to the
> org-priority-regexp. An updated patch is attached.
>
> Sorry,
> -I.S.
>
>
>
> On 10/27/2010 8:01 AM, I.S. wrote:
>> On 10/24/2010 3:18 PM, David Maus wrote:
>>> At Wed, 20 Oct 2010 13:14:39 -0400,
>>> I.S. wrote:
>>>> Dear Experts,
>>>>
>>>> I'd like to propose a replacement for the org-get-priority function
>>>> which is backward compatible with the current version but allows the
>>>> user to add a sub-priority such as [#A]-5 or [#B]+3:
>>>>
>>> Could you provide a patch against current master and send it to the
>>> list as a text/plain attachment? This way the proposed modification
>>> will end up in Org's patchtracker[1].
>>>
>>> Best,
>>> -- David
>>>
>>> [1] http://patchwork.newartisans.com/project/org-mode/
>>> --
>>> OpenPGP... 0x99ADB83B5A4478E6
>>> Jabber.... dmjena@jabber.org
>>> Email..... dmaus@ictsoc.de
>>
>> I tried looing at patchwork but couldn't figure out what I was
>> supposed to do. Please advise on usage instructions.
>>
>> Instead, I attached a manually generated patch against org.el in the
>> development version from git. I created this patch via
>>
>> $ git clone git://repo.or.cz/org-mode.git
>> $ emacs org-mode/lisp/org.el # to modify the file and write it to
>> org.mine.el
>> $ diff -rup org.el org.mine.el > org-get-priority.patch
>>
>> Please advise on proper procedure as I love org and would enjoy the
>> chance to contribute in the future.
>>
>> Thanks,
>> -I.S.
>>
[-- Attachment #2: org-get-priority.patch --]
[-- Type: text/plain, Size: 1764 bytes --]
--- org.el 2010-10-29 07:41:17.254401572 -0400
+++ org.mine.el 2010-10-29 07:49:11.814892725 -0400
@@ -12129,7 +12129,7 @@ from the `before-change-functions' in th
;;;; Priorities
-(defvar org-priority-regexp ".*?\\(\\[#\\([A-Z0-9]\\)\\] ?\\)"
+(defvar org-priority-regexp ".*?\\(\\[#\\([A-Z0-9]\\)\\]\\(-[0-9]+\\)? ?\\)"
"Regular expression matching the priority indicator.")
(defvar org-remove-priority-next-time nil)
@@ -12211,13 +12211,27 @@ ACTION can be `set', `up', `down', or a
(message "Priority of current item set to %s" news))))
(defun org-get-priority (s)
- "Find priority cookie and return priority."
- (save-match-data
- (if (not (string-match org-priority-regexp s))
- (* 1000 (- org-lowest-priority org-default-priority))
- (* 1000 (- org-lowest-priority
- (string-to-char (match-string 2 s)))))))
+ "Find priority cookie and return priority.
+Priorities of the form [#<letter>]-<number> or
+[#<letter>]+<number> are supported with +/-<number> being
+optional and modifying the letter priority. The letter priority
+is multiplied by 100000 and then the number priority is added
+on. Thus a priority string of [#B]+5 is higher than [#B] which is
+higher than [#B]-2 and all are lower than [#A].
+"
+ (save-match-data
+ (let* ((priority-match (string-match org-priority-regexp s))
+ (priority-value (if priority-match
+ (* 100000 (- org-lowest-priority
+ (string-to-char (match-string 2 s))))
+ (* 100000 (- org-lowest-priority
+org-default-priority))))
+ (sub-priority-match (match-string 3 s))
+ (sub-priority-value (if sub-priority-match
+ (string-to-number sub-priority-match) 0)))
+ (+ priority-value sub-priority-value))))
+
;;;; Tags
(defvar org-agenda-archives-mode)
[-- Attachment #3: Type: text/plain, Size: 201 bytes --]
_______________________________________________
Emacs-orgmode mailing list
Please use `Reply All' to send replies to the list.
Emacs-orgmode@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-orgmode
next prev parent reply other threads:[~2010-10-29 11:53 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-10-20 17:14 proposal for enhanced org-get-priority function I.S.
2010-10-24 19:18 ` David Maus
2010-10-24 20:05 ` George Pearson
2010-10-27 12:01 ` I.S.
2010-10-29 11:45 ` I.S.
2010-10-29 11:53 ` I.S. [this message]
2010-11-15 10:25 ` Carsten Dominik
2010-11-15 12:07 ` Juan Pechiar
2010-11-15 12:15 ` Carsten Dominik
2010-11-15 18:05 ` I.S.
2010-11-16 0:30 ` Samuel Wales
2010-11-17 8:16 ` Carsten Dominik
2010-11-17 13:11 ` I.S.
2010-11-17 19:21 ` Matt Lundin
2010-11-16 1:11 ` Matt Lundin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.orgmode.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4CCAB5C1.1080002@gmail.com \
--to=inquisitive.scientist@gmail.com \
--cc=dmaus@ictsoc.de \
--cc=emacs-orgmode@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).