unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu
@ 2022-11-18 22:18 Manuel Giraud
  2022-11-19  7:28 ` Eli Zaretskii
  0 siblings, 1 reply; 5+ messages in thread
From: Manuel Giraud @ 2022-11-18 22:18 UTC (permalink / raw)
  To: 59370

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


Hi,

This was bugging me and shows some menus (e.g. Message or Calc)

Thanks.

[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-Fix-easy-menu-separator-in-oldXMenu.patch --]
[-- Type: text/x-patch, Size: 1415 bytes --]

From 4878e3e7cebeb88c38945fa8db3197fe55609c53 Mon Sep 17 00:00:00 2001
From: Manuel Giraud <manuel@ledu-giraud.fr>
Date: Fri, 18 Nov 2022 22:58:19 +0100
Subject: [PATCH] Fix easy menu separator in oldXMenu

* lisp/emacs-lisp/easymenu.el (easy-menu-convert-item-1): Replace
a string of dash with a real menu separator as the doc says.
---
 lisp/emacs-lisp/easymenu.el | 11 +++++++----
 1 file changed, 7 insertions(+), 4 deletions(-)

diff --git a/lisp/emacs-lisp/easymenu.el b/lisp/emacs-lisp/easymenu.el
index 41e3a197af..2a45c1ab1c 100644
--- a/lisp/emacs-lisp/easymenu.el
+++ b/lisp/emacs-lisp/easymenu.el
@@ -390,10 +390,13 @@ easy-menu-convert-item-1
     (let ((key (easy-menu-intern name)))
       (cons key
             (and (not remove)
-                 (cons 'menu-item
-                       (cons label
-                             (and name
-                                  (cons command prop)))))))))
+                 (if (and (stringp label)
+                          (seq-every-p (lambda (c) (char-equal c ?-)) label))
+                     menu-bar-separator
+                   (cons 'menu-item
+                         (cons label
+                               (and name
+                                    (cons command prop))))))))))
 
 (defun easy-menu-define-key (menu key item &optional before)
   "Add binding in MENU for KEY => ITEM.  Similar to `define-key-after'.
-- 
2.38.1


[-- Attachment #3: Type: text/plain, Size: 7172 bytes --]



In GNU Emacs 29.0.50 (build 1, x86_64-unknown-openbsd7.2, cairo version
 1.17.6) of 2022-11-18 built on elite.giraud
Repository revision: 69852b345c2c1a75af1ca3f6b380845d27436cb2
Repository branch: mgi/menu-separator
Windowing system distributor 'The X.Org Foundation', version 11.0.12101004
System Description: OpenBSD elite.giraud 7.2 GENERIC.MP#835 amd64

Configured using:
 'configure --prefix=/home/manuel/emacs --bindir=/home/manuel/bin
 --with-x-toolkit=no --without-sound --without-compress-install
 CPPFLAGS=-I/usr/local/include LDFLAGS=-L/usr/local/lib'

Configured features:
CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GSETTINGS HARFBUZZ JPEG JSON
LCMS2 LIBOTF LIBXML2 MODULES NOTIFY KQUEUE OLDXMENU PDUMPER PNG RSVG
SQLITE3 THREADS TIFF WEBP X11 XDBE XIM XINPUT2 XPM ZLIB

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

Major mode: Lisp Interaction

Minor modes in effect:
  global-git-commit-mode: t
  magit-auto-revert-mode: t
  paredit-mode: t
  display-time-mode: t
  display-battery-mode: t
  server-mode: t
  shell-dirtrack-mode: t
  global-so-long-mode: t
  repeat-mode: t
  global-eldoc-mode: t
  eldoc-mode: t
  show-paren-mode: t
  electric-indent-mode: t
  mouse-wheel-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  line-number-mode: t
  indent-tabs-mode: t
  transient-mark-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t

Load-path shadows:
/home/manuel/.emacs.d/elpa/transient-20221028.1430/transient hides /home/manuel/emacs/share/emacs/29.0.50/lisp/transient

Features:
(shadow sort mail-extr emacsbug pulse magit-patch executable vc-git
vc-dispatcher vc-svn bug-reference magit-extras face-remap
magit-bookmark magit-submodule magit-obsolete magit-blame magit-stash
magit-reflog magit-bisect magit-push magit-pull magit-fetch magit-clone
magit-remote magit-commit magit-sequence magit-notes magit-worktree
magit-tag magit-merge magit-branch magit-reset magit-files magit-refs
magit-status magit magit-repos magit-apply magit-wip magit-log
which-func imenu magit-diff smerge-mode diff diff-mode git-commit
log-edit pcvs-util add-log magit-core magit-autorevert autorevert
filenotify magit-margin magit-transient magit-process with-editor
magit-mode transient magit-git magit-base magit-section dash compat-27
compat-26 compat compat-macs calc-menu paredit edmacro time battery
exwm-randr xcb-randr exwm-config exwm exwm-input xcb-keysyms xcb-xkb
exwm-manage exwm-floating xcb-cursor xcb-render exwm-layout
exwm-workspace exwm-core xcb-ewmh xcb-icccm xcb xcb-xproto xcb-types
xcb-debug kmacro server stimmung-themes modus-operandi-theme
modus-themes ytdious osm mingus libmpdee reporter edebug debug backtrace
transmission diary-lib diary-loaddefs color calc-bin calc-ext calc
calc-loaddefs rect calc-macs w3m-load mu4e mu4e-org mu4e-main mu4e-view
mu4e-headers mu4e-compose mu4e-draft mu4e-actions smtpmail mu4e-search
mu4e-lists mu4e-bookmarks mu4e-mark mu4e-message flow-fill mule-util
hl-line mu4e-contacts mu4e-update mu4e-folders mu4e-server mu4e-context
mu4e-vars mu4e-helpers mu4e-config bookmark ido supercite regi
ebdb-message ebdb-gnus nnselect gnus-msg gnus-art mm-uu mml2015 mm-view
mml-smime smime gnutls dig gnus-sum shr pixel-fill kinsoku url-file svg
dom gnus-group gnus-undo gnus-start gnus-dbus gnus-cloud nnimap nnmail
mail-source utf7 nnoo gnus-spec gnus-int gnus-range message sendmail
yank-media puny rfc822 mml mml-sec epa epg rfc6068 epg-config mm-decode
mm-bodies mm-encode mail-parse rfc2231 rfc2047 rfc2045 ietf-drums
gmm-utils mailheader gnus-win gnus nnheader gnus-util mail-utils range
mm-util mail-prsvr ebdb-mua ebdb-com crm ebdb-format ebdb inline
mailabbrev eieio-opt cl-extra help-mode speedbar ezimage dframe
eieio-base pcase timezone org ob ob-tangle ob-ref ob-lob ob-table ob-exp
org-macro org-footnote org-src ob-comint org-pcomplete org-list
org-faces org-entities org-version ob-emacs-lisp ob-core ob-eval
org-table oc-basic bibtex ol org-keys oc org-compat org-macs
org-loaddefs find-func cal-menu calendar cal-loaddefs visual-basic-mode
cl web-mode derived disp-table erlang-start smart-tabs-mode skeleton
cc-mode cc-fonts cc-guess cc-menus cc-cmds cc-styles cc-align cc-engine
cc-vars cc-defs slime-asdf grep slime-tramp tramp tramp-loaddefs
trampver tramp-integration cus-edit cus-load wid-edit files-x
tramp-compat rx shell pcomplete parse-time iso8601 time-date ls-lisp
format-spec slime-fancy slime-indentation slime-cl-indent cl-indent
slime-trace-dialog slime-fontifying-fu slime-package-fu slime-references
slime-compiler-notes-tree advice slime-scratch slime-presentations
bridge slime-macrostep macrostep slime-mdot-fu slime-enclosing-context
slime-fuzzy slime-fancy-trace slime-fancy-inspector slime-c-p-c
slime-editing-commands slime-autodoc slime-repl slime-parse slime
compile text-property-search etags fileloop generator xref project
arc-mode archive-mode noutline outline icons pp comint ansi-osc
ansi-color ring hyperspec thingatpt slime-autoloads dired-aux dired-x
dired dired-loaddefs so-long notifications dbus xml repeat easy-mmode
rust-mode-autoloads stimmung-themes-autoloads debbugs-autoloads
paredit-autoloads ebdb-autoloads ef-themes-autoloads ytdious-autoloads
auctex-autoloads tex-site exwm-autoloads hyperbole-autoloads
magit-autoloads magit-section-autoloads git-commit-autoloads
with-editor-autoloads transient-autoloads dash-autoloads
compat-autoloads info package browse-url url url-proxy url-privacy
url-expand url-methods url-history url-cookie generate-lisp-file
url-domsuf url-util mailcap url-handlers url-parse auth-source cl-seq
eieio eieio-core cl-macs password-cache json subr-x map byte-opt gv
bytecomp byte-compile url-vars cl-loaddefs cl-lib rmc iso-transl tooltip
cconv eldoc paren electric uniquify ediff-hook vc-hooks lisp-float-type
elisp-mode mwheel term/x-win x-win term/common-win x-dnd tool-bar dnd
fontset image regexp-opt fringe tabulated-list replace newcomment
text-mode lisp-mode prog-mode register page tab-bar menu-bar rfn-eshadow
isearch easymenu timer select scroll-bar mouse jit-lock font-lock syntax
font-core term/tty-colors frame minibuffer nadvice seq simple cl-generic
indonesian philippine cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese eucjp-ms cp51932 hebrew greek
romanian slovak czech european ethiopic indian cyrillic chinese
composite emoji-zwj charscript charprop case-table epa-hook
jka-cmpr-hook help abbrev obarray oclosure cl-preloaded button loaddefs
theme-loaddefs faces cus-face macroexp files window text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget keymap
hashtable-print-readable backquote threads dbusbind kqueue lcms2
dynamic-setting system-font-setting font-render-setting cairo xinput2 x
multi-tty make-network-process emacs)

Memory information:
((conses 16 676012 44354)
 (symbols 48 57003 1)
 (strings 32 167915 8351)
 (string-bytes 1 5496794)
 (vectors 16 96999)
 (vector-slots 8 1292859 83084)
 (floats 8 516 478)
 (intervals 56 641 32)
 (buffers 984 17))

-- 
Manuel Giraud

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

* bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu
  2022-11-18 22:18 bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu Manuel Giraud
@ 2022-11-19  7:28 ` Eli Zaretskii
  2022-11-19  9:15   ` Manuel Giraud
  0 siblings, 1 reply; 5+ messages in thread
From: Eli Zaretskii @ 2022-11-19  7:28 UTC (permalink / raw)
  To: Manuel Giraud; +Cc: 59370

> From: Manuel Giraud <manuel@ledu-giraud.fr>
> Date: Fri, 18 Nov 2022 23:18:20 +0100
> 
> This was bugging me and shows some menus (e.g. Message or Calc)

Could you please say what "this" is, and how it manifests itself in
those menus?  I don't think I understand this from the little you
said, and I cannot make up my mind about this without understanding.

Thanks.





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

* bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu
  2022-11-19  7:28 ` Eli Zaretskii
@ 2022-11-19  9:15   ` Manuel Giraud
  2022-11-19 10:21     ` Eli Zaretskii
  0 siblings, 1 reply; 5+ messages in thread
From: Manuel Giraud @ 2022-11-19  9:15 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 59370

Eli Zaretskii <eliz@gnu.org> writes:

>> From: Manuel Giraud <manuel@ledu-giraud.fr>
>> Date: Fri, 18 Nov 2022 23:18:20 +0100
>> 
>> This was bugging me and shows some menus (e.g. Message or Calc)
>
> Could you please say what "this" is, and how it manifests itself in
> those menus?  I don't think I understand this from the little you
> said, and I cannot make up my mind about this without understanding.

Hi Eli,

Before this patch a separator, into an easy defined menu, shows a string
of dashes "----".  With this patch, a separator shows as line that
crosses all the menu.  Do you want some screenshots?
-- 
Manuel Giraud





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

* bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu
  2022-11-19  9:15   ` Manuel Giraud
@ 2022-11-19 10:21     ` Eli Zaretskii
  2022-11-25  0:03       ` Stefan Kangas
  0 siblings, 1 reply; 5+ messages in thread
From: Eli Zaretskii @ 2022-11-19 10:21 UTC (permalink / raw)
  To: Manuel Giraud; +Cc: 59370

> From: Manuel Giraud <manuel@ledu-giraud.fr>
> Cc: 59370@debbugs.gnu.org
> Date: Sat, 19 Nov 2022 10:15:11 +0100
> 
> Eli Zaretskii <eliz@gnu.org> writes:
> 
> >> From: Manuel Giraud <manuel@ledu-giraud.fr>
> >> Date: Fri, 18 Nov 2022 23:18:20 +0100
> >> 
> >> This was bugging me and shows some menus (e.g. Message or Calc)
> >
> > Could you please say what "this" is, and how it manifests itself in
> > those menus?  I don't think I understand this from the little you
> > said, and I cannot make up my mind about this without understanding.
> 
> Hi Eli,
> 
> Before this patch a separator, into an easy defined menu, shows a string
> of dashes "----".  With this patch, a separator shows as line that
> crosses all the menu.  Do you want some screenshots?

Ah, okay.  Then the patch is fine by me, thanks.





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

* bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu
  2022-11-19 10:21     ` Eli Zaretskii
@ 2022-11-25  0:03       ` Stefan Kangas
  0 siblings, 0 replies; 5+ messages in thread
From: Stefan Kangas @ 2022-11-25  0:03 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: 59370, Manuel Giraud

close 59370 29.1
thanks

Eli Zaretskii <eliz@gnu.org> writes:

>> Before this patch a separator, into an easy defined menu, shows a string
>> of dashes "----".  With this patch, a separator shows as line that
>> crosses all the menu.  Do you want some screenshots?
>
> Ah, okay.  Then the patch is fine by me, thanks.

Thanks, so I gave the patch some testing under GTK+ and it seems to be
working.  So I installed it (commit 2b123edcf6), and I'm closing this bug.





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

end of thread, other threads:[~2022-11-25  0:03 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-11-18 22:18 bug#59370: 29.0.50; [PATCH] Fix easy menu separator in old XMenu Manuel Giraud
2022-11-19  7:28 ` Eli Zaretskii
2022-11-19  9:15   ` Manuel Giraud
2022-11-19 10:21     ` Eli Zaretskii
2022-11-25  0:03       ` Stefan Kangas

Code repositories for project(s) associated with this public inbox

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

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).