all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
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



  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

* 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 external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.