Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

spacemacs-cache-directory is ignored in dotspacemacs/*-init #12127

Open
zabbal opened this issue Apr 5, 2019 · 15 comments
Open

spacemacs-cache-directory is ignored in dotspacemacs/*-init #12127

zabbal opened this issue Apr 5, 2019 · 15 comments
Assignees
Labels

Comments

@zabbal
Copy link

zabbal commented Apr 5, 2019

Description :octocat:

spacemacs-cache-directory variable is ignored when set in dotspacemacs/user-init or dotspacemacs/init
After closing Spacemacs the .cacheis created in the old location with auto-save subdirectory and spacemacs-buffer.el files
If that's the expected behavior and it should be set someplace else than it would be great to get this documented.

Reproduction guide 🪲

  • Set spacemacs-cache-directory in dotspacemacs/user-init to non-default value, for example "~/.cache/emacs/"
  • Close Spacemacs

Observed behaviour: 👀 💔
.cache is re-created at old location

Expected behaviour: ❤️ 😄
The value of spacemacs-cache-directory should be used.

System Info 💻

  • OS: gnu/linux
  • Emacs: 25.2.2
  • Spacemacs: 0.200.13
  • Spacemacs branch: master (rev. c7a103a)
  • Graphic display: t
  • Distribution: spacemacs
  • Editing style: emacs
  • Completion: helm
  • Layers:
(helm auto-completion better-defaults emacs-lisp git github markdown jabber semantic ibuffer mu4e emoji c-c   csv emacs-lisp ess go graphviz haskell scala shell-scripts org themes-megapack command-log finance pandoc pdf-tools restclient systemd search-engine
      (shell :variables shell-default-height 30 shell-default-position 'bottom)
      spell-checking syntax-checking version-control)
  • System configuration features: XPM JPEG TIFF GIF PNG RSVG IMAGEMAGICK SOUND GPM DBUS GSETTINGS NOTIFY ACL LIBSELINUX GNUTLS LIBXML2 FREETYPE M17N_FLT LIBOTF XFT ZLIB TOOLKIT_SCROLL_BARS GTK3 X11
@ViktorHaag
Copy link

This might be because the default location of the cache directory gets set in core-load-paths.el (and the location of spacemacs-auto-save-directory and pcache-directory gets set based on that initial value), so if you reset it later (in dotspacemacs/user-init or dotspacemacs/init), the auto-saves and pcache will still go into the original location, I'd expect.

@zabbal
Copy link
Author

zabbal commented Nov 21, 2019

So there's another variable in addition to spacemacs-cache-directory which governs the location, sets differently and has higher priority? That's highly confusing and seems like a bug to me - it's better to have single source of truth for this kind of stuff.

@ViktorHaag
Copy link

ViktorHaag commented Nov 21, 2019

So there's another variable in addition to spacemacs-cache-directory which governs the location, sets differently and has higher priority?

What I mean to say is that spacemacs-cache-directory gets set in /core/core-load-paths.el, and then

  • spacemacs-auto-save-directory gets set to its string value, via expand-file-name
  • pcache-directory uses its value, via (concat "pcache/")
  • the cache directory gets created if it doesn't already exist

These things all happen before (presumably) user init configuration can happen in .spacemacs, so the directory will get created, containing the pcache, and auto-save directory set there.

Presumably, then, if you wanted to do something else via .spacemacs, you'd need to move three things not just one, and I'm not sure if spacemacs uses any of these directories before your user settings happen (it's possible stuff could get cached in pcache, maybe?).

In my fork (on the develop branch), I rearranged core-load-paths.el and built the cache directory relative to user home, and not relative to spacemacs-start-directory, but not everyone would be comfortable tweaking the core engine that way, I would guess...

Given the way that spacemacs seems to be organized, I'm not sure there would actually be a better way to set the cache directory for user preference without messiness... I guess that there could be a higher level setting exposed in .spacemacs which, if set, spacemacs would move things around after the fact (but that seems really messy)... there may well be a reason that spacemacs core needs to set and have ready the cache directory so early in the init process.

@zabbal
Copy link
Author

zabbal commented Dec 9, 2019

I wonder if XDG support in upcoming Emacs 27 could help to resolve this.

@github-actions
Copy link

github-actions bot commented Dec 8, 2020

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Please let us know if this issue is still valid!

@github-actions github-actions bot added the stale marked as a stale issue/pr (usually by a bot) label Dec 8, 2020
@zabbal
Copy link
Author

zabbal commented Dec 8, 2020

The issue is still valid.

@lebensterben
Copy link
Contributor

The issue is still valid.

@zabbal Does this problem exist on develop branch?

@ViktorHaag
Copy link

ViktorHaag commented Dec 8, 2020

@lebensterben -- I believe it does, yes; my remarks above were all made in the context of using the develop branch... (I've edited my remarks above to make that more clear).

@github-actions github-actions bot closed this as completed Mar 8, 2021
@zabbal
Copy link
Author

zabbal commented Apr 13, 2021

What's the point of reporting issues if they'll be closed by some bot regardless of the comments anyway?

@duianto duianto removed the stale marked as a stale issue/pr (usually by a bot) label Apr 13, 2021
@duianto duianto reopened this Apr 13, 2021
@duianto
Copy link
Contributor

duianto commented Apr 13, 2021

This one fell through the cracks, and we didn't remove the stale label in time.
Sorry about that.

A recent commit seems to indicate that this might be handled automatically in the future:
[CI] remove stale label when issue updated a862d1a

@github-actions
Copy link

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Please let us know if this issue is still valid!

@github-actions github-actions bot added the stale marked as a stale issue/pr (usually by a bot) label Apr 13, 2022
@lebensterben lebensterben removed the stale marked as a stale issue/pr (usually by a bot) label Apr 13, 2022
Copy link

github-actions bot commented May 1, 2024

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Please let us know if this issue is still valid!

@github-actions github-actions bot added the stale marked as a stale issue/pr (usually by a bot) label May 1, 2024
@pataquets
Copy link
Contributor

Feeding the stalebot here. Issue still valid.
While I'm at it, cross-linking to @puzl's #4018 related which also got closed by stalebot.
Also, notice #7818 is related, although it seems to me the reverse of this, which may be of interest.

@pataquets
Copy link
Contributor

Anyway, @zabbal, you're welcome to let us know if the issue still stands.
If it does not, we can just let the stalebot run next time and the above linked issues will serve as redirects for those getting here from Google.

@github-actions github-actions bot removed the stale marked as a stale issue/pr (usually by a bot) label May 7, 2024
@smile13241324
Copy link
Collaborator

We will need to reorganise the loading process a bit to make this possible. Right now the cache directory is set according to your user-emacs-directory.

I assume the most elegant way would be to add a new var to the dotfile but this is read to late right now. Lets see if I can get up with something.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

6 participants