Skip to content

Line endings specified in file conflict with recommended Windows git settings #1631

@bradyt

Description

@bradyt

Issue:

Windows users may be advised to use git config --global core.autocrlf true, or input. See here: https://git-scm.com/book/en/v2/Customizing-Git-Git-Configuration#_formatting_and_whitespace.

If I understand correctly, this would lead to haskell-mode being checked out with CRLF line endings. However, in haskell-font-lock.el, there are local variables set. In particular, coding: utf-8-unix.

Even opening the file leads to errors, but especially, one cannot run make or byte-compile-file there.

Possible solutions:

I am not certain why coding: utf-8-unix was added. Apparently it was done while discussing the addition of unicode, at #510, but there wasn't a motivating bug. I would propose we remove it, or at least relax it to coding: utf-8.

Alternatively, maybe if we add some .gitattributes or similar, then this repo would be checked out with LF line endings, to match the file local variables. But this leads to more code, not less.

Reproduce:

This is reproducible on *nix by setting the git config. I've created a Dockerfile to demonstrate.

From, https://github.com/bradyt/docker-emacs/tree/haskell-mode,

FROM ubuntu
RUN apt-get update && apt-get install -y \
        apt-transport-https \
        gnupg2 \
        curl \
        software-properties-common \
        git \
        make \
        texinfo \
        locales \
        install-info \
        && rm -rf /var/lib/apt/lists/*
RUN add-apt-repository ppa:kelleyk/emacs && apt-get update && apt-get install -y \
       emacs26-nox \
       && rm -rf /var/lib/apt/lists/*
RUN locale-gen en_US.UTF-8
RUN git config --global core.autocrlf true
RUN git clone https://github.com/haskell/haskell-mode.git
WORKDIR haskell-mode
# CMD emacs -f toggle-debug-on-error haskell-font-lock.el
CMD emacs -batch --eval="(progn (setq debug-on-error t) (byte-compile-file \"haskell-font-lock.el\"))"
# CMD make

Then,

$ docker build . -t this:one
$ docker run --rm -it this:one
Debugger entered--Lisp error: (error "Local variables entry is missing the suffix")
  signal(error ("Local variables entry is missing the suffix"))
  error("Local variables entry is missing the suffix")
  hack-local-variables(t)
  set-auto-mode()
  normal-mode(t)
  byte-compile-file("haskell-font-lock.el")
  (progn (setq debug-on-error t) (byte-compile-file "haskell-font-lock.el"))
  eval((progn (setq debug-on-error t) (byte-compile-file "haskell-font-lock.el")))
  command-line-1(("--eval=(progn (setq debug-on-error t) (byte-compile-file \"haskell-font-lock.el\"))"))
  command-line()
  normal-top-level()

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions