From: Eric Abrahamsen <eric@ericabrahamsen.net>
To: emacs-orgmode@gnu.org
Subject: Re: function for cleaning org-attach directories
Date: Fri, 17 Jul 2015 13:19:19 +0800 [thread overview]
Message-ID: <87vbdjico8.fsf@ericabrahamsen.net> (raw)
In-Reply-To: 87d1zs46jm.fsf@ericabrahamsen.net
Eric Abrahamsen <eric@ericabrahamsen.net> writes:
> Alan Schmitt <alan.schmitt@polytechnique.org> writes:
>
>> Hi Eric,
>>
>> On 2015-07-16 10:57, Eric Abrahamsen <eric@ericabrahamsen.net> writes:
>>
>>> I use org-attach a lot, and if you're not careful you can get a "data/"
>>> directory of many gigabytes. Not a problem, until you want to rsync it
>>> and it takes all day...
>>>
>>> I wrote this to clean my attach directories. I'm not sure how portable
>>> it is (and I'm really not pleased with the (concat attach-dir "/" d "/"
>>> d+)), but I'm posting it to see if it's useful to anyone.
>>>
>>> Comments/improvements welcome! If the final product is desirable, I can
>>> work it up as a patch.
>>
>> This would be most useful indeed. One quick question: why do you use
>> "rm" instead of "delete-file"?
>
> Because I was copy-pasting from org-attach! The real question is: why
> didn't I use `delete-directory' :)
>
> I'll do another version!
>
> E
Here we go, and this one ought to be a little more portable. I guess
I'll do it as a proper patch in a bit.
(defun org-attach-clean-dirs (&optional attach-dir clean-archived)
(interactive)
(let ((attach-dir
(if attach-dir
(file-name-as-directory attach-dir)
(concat (file-name-as-directory org-directory)
org-attach-directory)))
(valid-dir-re "\\`[0-9a-z-]+\\'")
(org-id-search-archives (if clean-archived nil org-id-search-archives)))
(dolist (d (directory-files attach-dir nil valid-dir-re))
(dolist (d+ (directory-files
(concat attach-dir d) nil valid-dir-re))
(let ((id (format "%s%s" d d+))
(full-path (concat
attach-dir
(file-name-as-directory d)
d+)))
(unless (org-id-find id)
(delete-directory full-path t)))))))
next prev parent reply other threads:[~2015-07-17 5:19 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-16 8:57 function for cleaning org-attach directories Eric Abrahamsen
2015-07-16 9:38 ` Alan Schmitt
2015-07-16 12:43 ` Eric Abrahamsen
2015-07-17 5:19 ` Eric Abrahamsen [this message]
2015-07-17 15:01 ` Alan Schmitt
2015-07-18 3:11 ` Eric Abrahamsen
2015-07-20 15:04 ` Alan Schmitt
2015-08-01 9:23 ` [PATCH] " Eric Abrahamsen
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=87vbdjico8.fsf@ericabrahamsen.net \
--to=eric@ericabrahamsen.net \
--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).