all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* bug#19815: 25.0.50; [PATCH] css-mode: function call indentation
@ 2015-02-08 12:19 Simen Heggestøyl
  2015-02-09 17:27 ` Stefan Monnier
  0 siblings, 1 reply; 2+ messages in thread
From: Simen Heggestøyl @ 2015-02-08 12:19 UTC (permalink / raw
  To: 19815

[-- Attachment #1: Type: text/plain, Size: 3871 bytes --]

Sometimes it is convenient to break CSS function calls up in multiple
lines. The current CSS indentation engine does not handle this well
when the parameters don't begin at the same line as the opening
paren. For instance:

div {
    background: linear-gradient(
                        to right, red, orange, yellow,
                        green, blue, indigo, violet
                    );
}

div {
    background: linear-gradient(
                        135deg,
                        red,
                        blue
                    );
}

I would instead expect the following indentation:

div {
    background: linear-gradient(
        to right, red, orange, yellow,
        green, blue, indigo, violet
    );
}

div {
    background: linear-gradient(
        135deg,
        red,
        blue
    );
}

The following patch accomplishes this:

diff --git a/lisp/textmodes/css-mode.el b/lisp/textmodes/css-mode.el
index f6a3ca6..ab911ce 100644
--- a/lisp/textmodes/css-mode.el
+++ b/lisp/textmodes/css-mode.el
@@ -331,8 +331,9 @@
     (`(:elem . basic) css-indent-offset)
     (`(:elem . arg) 0)
     (`(:list-intro . ,(or `";" `"")) t) ;"" stands for BOB (bug#15467).
-    (`(:before . "{") (if (smie-rule-hanging-p)
-                         (smie-rule-parent 0)))))
+    (`(:before . ,(or "{" "("))
+     (if (smie-rule-hanging-p)
+         (smie-rule-parent 0)))))

 ;;;###autoload
 (define-derived-mode css-mode fundamental-mode "CSS"


In GNU Emacs 25.0.50.11 (x86_64-unknown-linux-gnu, GTK+ Version 3.14.5)
 of 2015-02-08 on x240
Repository revision: dcec731abfc110f719f0890fd0769e099393af7d
Windowing system distributor `The X.Org Foundation', version 
11.0.11602901
System Description:	Debian GNU/Linux 8.0 (jessie)

Configured using:
 `configure --without-makeinfo'

Configured features:
XPM JPEG TIFF GIF PNG SOUND DBUS GSETTINGS NOTIFY LIBXML2 FREETYPE XFT
ZLIB

Important settings:
  value of $LANG: en_US.UTF-8
  locale-coding-system: utf-8-unix

Major mode: Lisp Interaction

Minor modes in effect:
  tooltip-mode: t
  global-eldoc-mode: t
  electric-indent-mode: t
  mouse-wheel-mode: t
  tool-bar-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t

Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.

Load-path shadows:
None found.

Features:
(shadow sort gnus-util mail-extr emacsbug message dired format-spec
rfc822 mml easymenu mml-sec mm-decode mm-bodies mm-encode mail-parse
rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047 rfc2045
ietf-drums mm-util help-fns mail-prsvr mail-utils time-date tooltip
eldoc electric uniquify ediff-hook vc-hooks lisp-float-type mwheel x-win
x-dnd tool-bar dnd fontset image regexp-opt fringe tabulated-list
newcomment elisp-mode lisp-mode prog-mode register page menu-bar
rfn-eshadow timer select scroll-bar mouse jit-lock font-lock syntax
facemenu font-core frame cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese hebrew greek romanian slovak
czech european ethiopic indian cyrillic chinese case-table epa-hook
jka-cmpr-hook help simple abbrev minibuffer cl-preloaded nadvice
loaddefs button faces cus-face macroexp files text-properties overlay
sha1 md5 base64 format env code-pages mule custom widget
hashtable-print-readable backquote make-network-process dbusbind
gfilenotify dynamic-setting system-font-setting font-render-setting
move-toolbar gtk x-toolkit x multi-tty emacs)

Memory information:
((conses 16 74953 5948)
 (symbols 48 17996 0)
 (miscs 40 43 124)
 (strings 32 10952 5168)
 (string-bytes 1 296625)
 (vectors 16 9370)
 (vector-slots 8 386714 15587)
 (floats 8 70 63)
 (intervals 56 175 9)
 (buffers 976 11)
 (heap 1024 23572 1045))

[-- Attachment #2: Type: text/html, Size: 6163 bytes --]

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* bug#19815: 25.0.50; [PATCH] css-mode: function call indentation
  2015-02-08 12:19 bug#19815: 25.0.50; [PATCH] css-mode: function call indentation Simen Heggestøyl
@ 2015-02-09 17:27 ` Stefan Monnier
  0 siblings, 0 replies; 2+ messages in thread
From: Stefan Monnier @ 2015-02-09 17:27 UTC (permalink / raw
  To: Simen Heggestøyl; +Cc: 19815-done

> -    (`(:before . "{") (if (smie-rule-hanging-p)
> -                         (smie-rule-parent 0)))))
> +    (`(:before . ,(or "{" "("))
> +     (if (smie-rule-hanging-p)
> +         (smie-rule-parent 0)))))

Thanks, installed,


        Stefan





^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2015-02-09 17:27 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-02-08 12:19 bug#19815: 25.0.50; [PATCH] css-mode: function call indentation Simen Heggestøyl
2015-02-09 17:27 ` Stefan Monnier

Code repositories for project(s) associated with this external index

	https://git.savannah.gnu.org/cgit/emacs.git
	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.