koodev

macOS 에서 Emacs 데몬이 종료되지 않는 문제

Emacs

macOS 에서 Emacs Server/Client 환경을 만들던 중 데몬이 종료가 되지 않는 문제에 대해서 정리했다.

문제점

Emacs Server/Client 설정은 EmacsWikiEmacs As Daemon 에서 잘 설명해주고 있다. Ubuntu 에서의 설정은 Emacs As Daemon 을 따라서 성공했다. 그런데 macOS에서는 Emacs 서버 데몬을 실행한 후 시스템종료가 안 되는 현상이 발생했다.

Ubuntu 에서는 Emacs 데몬의 systemd 설정파일에서 시스템 종료 시점에 emacsclient --eval "(kill-emacs)" 을 날려주도록 설정해 놨는데, macOS의 시작프로그램 관리자인 launchd 에서는 종료시점에 대해 뭔가를 할 수가 없게 되어있다. 따라서 Emacs 데몬이 종료를 못하고 강제종료를 해 주어야지만 시스템을 종료할 수가 있는 것이다. 내가 직접 테스트해보지는 않았지만 이 문제는 Emacs 를 데몬이 아닌 모드로 실행 후에 (server-start) 를 직접 또는 init.el 등에서 실행해 주면 괜찮다고 한다.

아래 글을 쓴 redinger 라는 분도 macOS에서의 Emacs 데몬 시작 스크립트를 공유해 두시고 나와 같은 문제로 인해서 사용을 하고 있지 않다고 한다.

https://gist.github.com/redinger/1394910/c0dc6877c158a13760212dbe10b4abb32ae3c4f8

그런데 (server-start) 를 불러주는 방식은 최초에 Emacs 실행 시 데몬 모드가 아닌 일반 모드로 실행을 해야 하는 번거로움이 있어서 개인적으로 마음에 들지 않는 방식이다.

데몬 종료가 되지 않는 원인

데몬 종료가 안 되어서 시스템 종료를 방해하는 원인은 바로 Emacs 개인 설정에서 Emacs 종료시에 편집 중이던 수정된 파일을 저장할지 안할지 확인하는 과정이 들어가 있기 때문이었다. Emacs를 데몬으로 실행해 버리면 이를 확인할 수가 없기 때문이다. 즉, 아래와 같은 설정이 문제였다.

(setq confirm-kill-emacs 'yes-or-no-p)

해결책

그런데 Emacs를 일반 모드로 실행하는 경우도 있기 때문에 위의 설정을 포기하는 것도 많이 아쉬웠다. 방법은 Emacs가 데몬 모드로 실행될 경우에는 confirm 설정을 포기하고, 그렇지 않은 일반 모드일 경우에만 confirm 설정을 사용하도록 init 파일에서 설정하면 되는 것이다. Emacs에는 daemonp 라는 함수가 데몬모드로 실행 중인 경우 t 를 리턴하게 되어 있다. 즉, 아래와 같은 내용을 init 파일에 넣어주면 된다.

(if (daemonp)
    nil
  (setq confirm-kill-emacs 'yes-or-no-p))

References

'Emacs' 카테고리의 다른 글

Emacs - Python 문서 열람시 멈춤현상  (0) 2019.09.18
Emacs Wdired 모드  (0) 2019.06.29
Create a new file in ido mode  (0) 2019.06.07
Emacs Server setting  (0) 2019.05.15
EIN and virtualenvwrapper  (0) 2018.07.22