From: Mark Oteiza <mvoteiza@udel.edu>
To: Philipp Stephani <p.stephani2@gmail.com>
Cc: emacs-devel@gnu.org
Subject: Re: [PATCH] Add XDG utility library
Date: Wed, 1 Feb 2017 07:17:02 -0500 [thread overview]
Message-ID: <20170201121702.GB997@holos.localdomain> (raw)
In-Reply-To: <CAArVCkQZmoF7+9JtY3C=UkDyCCVPknahvPWku5Cwx+jXDSC7Ww@mail.gmail.com>
On 01/02/17 at 11:24am, Philipp Stephani wrote:
> Mark Oteiza <mvoteiza@udel.edu> schrieb am Mi., 1. Feb. 2017 um 01:28 Uhr:
>
> >
> > +;; XDG User Directories
> > +;; https://www.freedesktop.org/wiki/Software/xdg-user-dirs/
> > +
> > +(defconst xdg-line-regexp
> > + (eval-when-compile
> > + (rx "XDG_"
> > + (group-n 1 (or "DESKTOP" "DOWNLOAD" "TEMPLATES" "PUBLICSHARE"
> > + "DOCUMENTS" "MUSIC" "PICTURES" "VIDEOS"))
> > + "_DIR=\""
> > + (group-n 2 (or "/" "$HOME/") (*? (or (not (any "\"")) "\\\"")))
> > + "\""))
> > + "Regexp matching non-comment lines in xdg-user-dirs config files.")
> > +
> > +(defvar xdg-user-dirs nil
> > + "Alist of directory keys and values.")
> > +
> > +(defun xdg--user-dirs-parse-line ()
> > + "Return pair of user-dirs key to directory value in LINE, otherwise nil.
> > +This should be called at the beginning of a line."
> > + (skip-chars-forward "[:blank:]")
> > + (when (and (/= (following-char) ?#)
> > + (looking-at xdg-line-regexp))
> > + (let ((k (match-string 1))
> > + (v (match-string 2)))
> > + (when (and k v) (cons k v)))))
> > +
> > +(defun xdg--user-dirs-parse-file (filename)
> > + "Return alist of xdg-user-dirs from FILENAME."
> > + (let (elt res)
> > + (with-temp-buffer
> > + (insert-file-contents filename)
> > + (goto-char (point-min))
> > + (while (not (eobp))
> > + (setq elt (xdg--user-dirs-parse-line))
> > + (when (consp elt) (push elt res))
> > + (forward-line)))
> > + res))
> > +
> > +(defun xdg-user-dir (name)
> > + "Return the path of user directory referred to by NAME."
> > + (when (null xdg-user-dirs)
> > + (setq xdg-user-dirs
> > + (xdg--user-dirs-parse-file
> > + (expand-file-name "user-dirs.dirs" (xdg-config-home)))))
> > + (cdr (assoc name xdg-user-dirs)))
> >
>
> This parsing seems a bit brittle (what if the file contains ${HOME} instead
> of $HOME?); probably this should call the xdg-user-dir program instead.
Then it's not valid. There's no point in depending on a binary for
this.
https://cgit.freedesktop.org/xdg/xdg-user-dirs/tree/xdg-user-dir-lookup.c
next prev parent reply other threads:[~2017-02-01 12:17 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-02-01 0:26 [PATCH] Add XDG utility library Mark Oteiza
2017-02-01 11:19 ` Philipp Stephani
2017-02-01 12:14 ` Mark Oteiza
2017-02-01 11:24 ` Philipp Stephani
2017-02-01 12:17 ` Mark Oteiza [this message]
2017-02-01 15:01 ` Ted Zlatanov
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.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170201121702.GB997@holos.localdomain \
--to=mvoteiza@udel.edu \
--cc=emacs-devel@gnu.org \
--cc=p.stephani2@gmail.com \
/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.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).