Showing 605 to 608

Worth solving

We can struggle with a decision and call it "very hard" for two very different reasons:

  1. It seems impossible. I.e. your initial reflexive judgment induced so much panic that you gave up before you could start trying.
  2. It doesn't matter. I.e. it your choices are equally good on net, with different pros/cons – no choice sticks up as obvious. You have been reconsidering and reconsidering, possibly for weeks.

What links here

Created (2 months ago)

How to Downgrade/Rollback an Emacs Package

They don't exactly tell you in the tutorial, so a quick remedial course.

In our example today, let's say we want to downgrade org-node to 1.6.2.

With vc-use-package (built into Emacs from Emacs 30+):

(use-package org-node
  :vc (:fetcher github :repo "meedstrom/org-node"
       :rev "6ed833d1025d5163137904f2a1f6d80d930610b4"))

With Quelpa:

(use-package org-node
  :quelpa (org-node :fetcher github :repo "meedstrom/org-node"
                    :commit "6ed833d1025d5163137904f2a1f6d80d930610b4"))

With Elpaca as follows. Note that if you had already installed the package, modifying the recipe to include :tag will only take effect after you do M-x elpaca-delete RET org-node RET and have it re-install. The idea is that Elpaca users will prefer to do this kind of thing manually inside the cloned repo.

(use-package org-node
  :ensure (:fetcher github :repo "meedstrom/org-node"
           :tag "1.6.2"))

With Straight, it's a bit different, since it cannot pin a commit nor a tag directly. Three methods:

  1. Create a Straight lockfile.
  2. If you know about Git, enter the cloned repo (M-x find-library RET org-node RET) and check out an old commit yourself. Tip: if you cannot see many old commits in the Git log, first run the command git fetch --unshallow.
  3. Easiest: Hope that the author made a branch for an old version.

It turns out we can use method #3 this time because org-node does have a branch for the 1.6.x series:

(use-package org-node
  :straight (org-node :type git :host github :repo "meedstrom/org-node"
                      :branch "v1.6"))

Bonus: Find out the installed version of a package🔗

You've probably seen a line like this near the top of an Emacs Lisp source file:

;; Version: 2.2.2

or

;; Package-Version: 2.2.2

Unfortunately, this number is not always present, nor is it always to be believed. It depends on the author's development style.

So unless you only install from GNU/NonGNU ELPA, which mandate the above line, it's worth knowing a reliable method specific to your package-manager:

  • Elpaca
    • type M-x elpaca-info RET org-node RET
  • Straight, Borg and anything that uses Git clones
    • go to M-x find-library RET org-node RET
    • then run the Git command git log --tags --pretty="%ci %d"
      • if that yields no answers, run git fetch --unshallow and try again
        • if still no answers, the ;; Version: line is right
  • The built-in package.el
    • If it came from MELPA Stable, look inside the autogenerated file org-node-pkg.el, because they'll put the tag there. Primary MELPA still needs to revamp their version naming scheme before they can do the same – correlate with the date.

Bonus: Explore past versions to find the correct commit🔗

The examples on this page were easy because org-node is a package that uses Git tags: we can see on the tags page that tag 1.6.2 corresponds to commit 6ed833d1025d5163137904f2a1f6d80d930610b4.

Alternatively, Straight users can check the branches page and hope that the author has seen fit to spin off branches for some old versions.

But what to do if there are no tags or branches? That occurs in two cases:

  1. The author doesn't version at all
  2. The author only updates the ;; Package-Version: header inside the source file. Typical on the GNU ELPA.

As far as I can tell, GNU and NonGNU ELPA use some specialized tool to crawl the commit history to look for the version header. I don't know what that tool is. So as an user, for now I'd just visit the commits page and pick any random old commit to try.

Created (3 months ago)

In what order does Emacs handle simultaneous process sentinels?

#emacs

Couldn't find this info in the manual.

Answer: The first process that finished is the first one handled.

Verified as follows:

(dotimes (i 10)
  (make-process :name (format "*%d*" i)
                :buffer (get-buffer-create (format "*foo-%d*" i) t)
                :command (list "emacs" "-Q" "--batch"
                               "--eval"
                               (prin1-to-string
                                `(progn
                                   (make-list (random 100)
                                              (make-list (random 100)
                                                         t))
                                   (print
                                    (format "%dth spawned, finished at %.3fs"
                                            ,i (time-to-seconds))))))
                :sentinel (lambda (proc _)
                            (with-current-buffer (process-buffer proc)
                              (message "%s" (buffer-string)))
                            (kill-buffer (process-buffer proc)))))

A result:

"6th spawned, finished at 1730132198.780s"
"2th spawned, finished at 1730132198.778s"
"0th spawned, finished at 1730132198.781s"
"1th spawned, finished at 1730132198.803s"
"3th spawned, finished at 1730132198.822s"
"4th spawned, finished at 1730132198.838s"
"9th spawned, finished at 1730132198.842s"
"5th spawned, finished at 1730132198.850s"
"7th spawned, finished at 1730132198.876s"
"8th spawned, finished at 1730132198.900s"

Related

Emacs async process performance

What links here

  • 2024-10-28
Created (3 months ago)
Showing 605 to 608