unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
@ 2023-02-22 13:49 Thierry Volpiatto
  2023-02-22 14:16 ` Thierry Volpiatto
  2023-02-22 14:26 ` Andreas Schwab
  0 siblings, 2 replies; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-22 13:49 UTC (permalink / raw)
  To: 61708


Hello all,

It is unclear how to use MODES argument of
file-modes-symbolic-to-number, actually the correct way to use it is the
second example below, I found it by reading the read-file-modes code and
saw it removes all "-" to setup MODES arg to pass to
file-modes-symbolic-to-number. I was surprized to see the first example
is not supported, thus the docstring of file-modes-symbolic-to-number is
pretty unclear:

,----
| MODES is the string to convert, it should match
| "[ugoa]*([+-=][rwxXstugo]*)+,...".
`----

At least an example in docstring or manual would be welcome.

(format "%o" (file-modes-symbolic-to-number "u=rwx,g=r-x,o=---"))
"740"
(format "%o" (file-modes-symbolic-to-number "u=rwx,g=rx,o="))
"750"

Thanks.


In GNU Emacs 28.2 (build 1, x86_64-pc-linux-gnu, Motif Version 2.3.8, cairo version 1.16.0)
 of 2023-02-14 built on IPad-S340
Windowing system distributor 'The X.Org Foundation', version 11.0.12101003
System Description: Linux Mint 21.1

Configured using:
 'configure CFLAGS=-O8 --with-mailutils --with-cairo --without-dbus
 --without-gconf --without-gsettings --with-x-toolkit=motif'

Configured features:
ACL CAIRO FREETYPE GIF GLIB GMP GNUTLS GPM HARFBUZZ JPEG JSON LCMS2
LIBOTF LIBSELINUX LIBSYSTEMD LIBXML2 M17N_FLT MODULES NOTIFY INOTIFY
PDUMPER PNG RSVG SECCOMP SOUND THREADS TIFF TOOLKIT_SCROLL_BARS X11 XDBE
XIM XPM MOTIF ZLIB

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

Major mode: 

Minor modes in effect:
  emms-mode-line-mode: t
  emms-playing-time-display-mode: t
  emms-playing-time-mode: t
  psession-mode: t
  psession-savehist-mode: t
  global-undo-tree-mode: t
  undo-tree-mode: t
  global-git-gutter-mode: t
  display-time-mode: t
  winner-mode: t
  tv-save-place-mode: t
  helm-epa-mode: t
  helm-descbinds-mode: t
  helm-top-poll-mode: t
  helm-adaptive-mode: t
  helm-mode: t
  helm-minibuffer-history-mode: t
  helm-ff-icon-mode: t
  shell-dirtrack-mode: t
  helm-popup-tip-mode: t
  async-bytecomp-package-mode: t
  dired-async-mode: t
  minibuffer-depth-indicate-mode: t
  gcmh-mode: t
  tooltip-mode: t
  global-eldoc-mode: t
  eldoc-mode: t
  show-paren-mode: t
  mouse-wheel-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  column-number-mode: t
  line-number-mode: t
  transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow epa-mail face-remap emacsbug helm-ring tabify add-log which-func
cus-start helm-imenu helm-dabbrev cl-indent rect smerge-mode eieio-opt
speedbar ezimage dframe shortdoc helm-command helm-elisp helm-eval
cl-print edebug backtrace helm-x-files helm-for-files tramp-cache
tramp-sh helm-bookmark helm-info term ehelp helm-apt image-file
image-converter char-fold emms-config emms-librefm-stream
emms-librefm-scrobbler emms-playlist-limit emms-i18n emms-history
emms-score emms-stream-info emms-metaplaylist-mode emms-bookmarks
emms-cue emms-mode-line-icon emms-browser emms-volume
emms-volume-sndioctl emms-volume-mixerctl emms-volume-pulse
emms-volume-amixer emms-playlist-sort emms-last-played emms-player-xine
emms-player-mpd tq emms-lyrics emms-url emms-streams emms-show-all
emms-tag-editor emms-tag-tracktag emms-mark emms-mode-line emms-cache
emms-info-native bindat emms-info-exiftool emms-info-tinytag
emms-info-metaflac emms-info-opusinfo emms-info-ogginfo
emms-info-mp3info emms-playlist-mode emms-player-vlc emms-player-mpv
emms-playing-time emms-info emms-later-do emms-player-mplayer
emms-player-simple emms-source-playlist emms-source-file locate
emms-setup emms emms-compat emms-auto helm-external mm-archive sort
smiley gnus-cite mail-extr qp gnus-async gnus-bcklg gnus-ml disp-table
nndraft nnmh nnfolder cl-extra epa-file gnutls network-stream nsm
gnus-agent gnus-srvr gnus-score score-mode nnvirtual gnus-msg nntp
gnus-cache nnir addressbook-bookmark tv-mu4e-config config-w3m
mu4e-contrib eshell esh-cmd esh-ext esh-opt esh-proc esh-io esh-arg
esh-module esh-groups esh-util mu4e-patch mu4e mu4e-org org-config
ob-gnuplot org-crypt 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 noutline outline org-version ob-emacs-lisp
ob-core ob-eval org-table oc-basic bibtex ol rx org-keys oc org-compat
org-macs org-loaddefs find-func mu4e-notification notifications
mu4e-main mu4e-view gnus-art mm-uu mml2015 mm-view mml-smime smime dig
gnus-sum gnus-group gnus-undo gnus-start gnus-dbus gnus-cloud nnimap
nnmail mail-source utf7 netrc nnoo gnus-spec gnus-int gnus-range
gnus-win gnus nnheader appt diary-lib diary-loaddefs cal-menu calendar
cal-loaddefs mu4e-headers mu4e-compose mu4e-draft mu4e-actions smtpmail
sendmail mu4e-search mu4e-lists mu4e-bookmarks mu4e-mark mu4e-message
shr kinsoku svg dom flow-fill hl-line mu4e-contacts mu4e-update
mu4e-folders mu4e-context mu4e-query-items mu4e-server mu4e-modeline
mu4e-vars mu4e-helpers mu4e-config mu4e-window bookmark ido message rmc
puny rfc822 mml mml-sec gnus-util rmail rmail-loaddefs mm-decode
mm-bodies mm-encode mailabbrev mail-utils gmm-utils mailheader
mu4e-obsolete ffap tramp-archive tramp-gvfs dbus helm-firefox helm-net
xml helm-ls-git vc-git diff-mode vc vc-dispatcher flymake-shellcheck
flymake-proc flymake project warnings sh-script smie executable checkdoc
lisp-mnt mail-parse rfc2231 rfc2047 rfc2045 mm-util ietf-drums
mail-prsvr thingatpt bug-reference naquadah-theme server imenu psession
frameset undo-tree diff queue pcase git-gutter mule-util dired-extension
time winner describe-variable help-fns radix-tree help-mode tv-utils
tv-save-place.el advice init-helm epa derived epg rfc6068 epg-config
helm-epa isl helm-descbinds all-the-icons all-the-icons-faces
data-material data-weathericons data-octicons data-fileicons
data-faicons data-alltheicons cus-edit pp wid-edit helm-sys popup
helm-adaptive helm-mode helm-misc helm-files image-dired image-mode exif
filenotify tramp tramp-loaddefs trampver tramp-integration files-x
tramp-compat shell pcomplete parse-time iso8601 time-date ls-lisp
helm-buffers helm-occur helm-tags helm-locate helm-grep wgrep-helm wgrep
grep compile text-property-search comint ring helm-regexp format-spec
ansi-color helm-utils helm-help helm-types helm-extensions-autoloads
helm-autoloads helm helm-global-bindings helm-easymenu helm-core
easy-mmode async-bytecomp helm-source helm-multi-match helm-lib
dired-async async dired-aux dired dired-loaddefs mb-depth edmacro kmacro
avoid cus-load gcmh info w3m-load package browse-url url url-proxy
url-privacy url-expand url-methods url-history url-cookie url-domsuf
url-util mailcap url-handlers url-parse auth-source cl-seq eieio
eieio-core cl-macs eieio-loaddefs password-cache json subr-x map
url-vars seq byte-opt gv bytecomp byte-compile cconv cl-loaddefs cl-lib
iso-transl tooltip 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 cl-generic
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 simple abbrev obarray
cl-preloaded nadvice button loaddefs faces cus-face macroexp files
window text-properties overlay sha1 md5 base64 format env code-pages
mule custom widget hashtable-print-readable backquote threads inotify
lcms2 dynamic-setting font-render-setting cairo motif x-toolkit x
multi-tty make-network-process emacs)

Memory information:
((conses 16 869050 440363)
 (symbols 48 37684 5)
 (strings 32 231743 75250)
 (string-bytes 1 11819997)
 (vectors 16 95498)
 (vector-slots 8 1929698 276469)
 (floats 8 5386 4131)
 (intervals 56 27471 12074)
 (buffers 992 160))
<#secure method=pgpmime mode=sign>

-- 
Thierry





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 13:49 bug#61708: 28.2; file-modes-symbolic-to-number inconsistency Thierry Volpiatto
@ 2023-02-22 14:16 ` Thierry Volpiatto
  2023-02-22 14:26 ` Andreas Schwab
  1 sibling, 0 replies; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-22 14:16 UTC (permalink / raw)
  To: 61708

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


Here a simple patch to summarize what's wrong:

diff --git a/lisp/files.el b/lisp/files.el
index 5b989902bc3..576eb22c49f 100644
--- a/lisp/files.el
+++ b/lisp/files.el
@@ -8363,6 +8363,7 @@ If CHAR is in [Xugo], the value is taken from FROM (or 0 if omitted)."
   (cond ((eq char ?r) #o0444)
 	((eq char ?w) #o0222)
 	((eq char ?x) #o0111)
+        ((eq char ?-) #o0000)
 	((eq char ?s) #o6000)
 	((eq char ?t) #o1000)
 	;; Rights relative to the previous file modes.
@@ -8393,7 +8394,7 @@ as in \"og+rX-w\"."
       (let ((num-right 0)
 	    char-right)
 	(while (memq (setq char-right (pop list-rights))
-		     '(?r ?w ?x ?X ?s ?t ?u ?g ?o))
+		     '(?r ?w ?x ?X ?s ?t ?u ?g ?o ?-))
 	  (setq num-right
 		(logior num-right
 			(file-modes-char-to-right char-right num-rights))))

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 13:49 bug#61708: 28.2; file-modes-symbolic-to-number inconsistency Thierry Volpiatto
  2023-02-22 14:16 ` Thierry Volpiatto
@ 2023-02-22 14:26 ` Andreas Schwab
  2023-02-22 14:58   ` Thierry Volpiatto
  1 sibling, 1 reply; 15+ messages in thread
From: Andreas Schwab @ 2023-02-22 14:26 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 61708

On Feb 22 2023, Thierry Volpiatto wrote:

> (format "%o" (file-modes-symbolic-to-number "u=rwx,g=r-x,o=---"))
> "740"

This is the correct interpretation of the mode string, with "g=r-x"
meaning the same as "g=r,g-x" or just "g=r".

See
https://pubs.opengroup.org/onlinepubs/9699919799/utilities/chmod.html
for the full syntax.

-- 
Andreas Schwab, SUSE Labs, schwab@suse.de
GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE  1748 E4D4 88E3 0EEA B9D7
"And now for something completely different."





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 14:26 ` Andreas Schwab
@ 2023-02-22 14:58   ` Thierry Volpiatto
  2023-02-22 15:45     ` Andreas Schwab
  0 siblings, 1 reply; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-22 14:58 UTC (permalink / raw)
  To: Andreas Schwab; +Cc: 61708

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


Andreas Schwab <schwab@suse.de> writes:

> On Feb 22 2023, Thierry Volpiatto wrote:
>
>> (format "%o" (file-modes-symbolic-to-number "u=rwx,g=r-x,o=---"))
>> "740"
>
> This is the correct interpretation of the mode string, with "g=r-x"
> meaning the same as "g=r,g-x" or just "g=r".

So how do you interpret this: "drwxr-x---" (from file-attributes)?
"u=?,g=?,o=?" to pass it to file-modes-symbolic-to-number?

(nth 8 (file-attributes "/home/user"))
"drwxr-x---"

(read-file-modes nil "/home/user")
#o750

Thanks.

> See
> https://pubs.opengroup.org/onlinepubs/9699919799/utilities/chmod.html
> for the full syntax.


-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 14:58   ` Thierry Volpiatto
@ 2023-02-22 15:45     ` Andreas Schwab
  2023-02-22 17:03       ` Thierry Volpiatto
  0 siblings, 1 reply; 15+ messages in thread
From: Andreas Schwab @ 2023-02-22 15:45 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 61708

On Feb 22 2023, Thierry Volpiatto wrote:

> So how do you interpret this: "drwxr-x---" (from file-attributes)?

This is not a symbolic mode.

-- 
Andreas Schwab, SUSE Labs, schwab@suse.de
GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE  1748 E4D4 88E3 0EEA B9D7
"And now for something completely different."





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 15:45     ` Andreas Schwab
@ 2023-02-22 17:03       ` Thierry Volpiatto
  2023-02-22 17:11         ` Gregory Heytings
  2023-02-23  9:14         ` Andreas Schwab
  0 siblings, 2 replies; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-22 17:03 UTC (permalink / raw)
  To: Andreas Schwab; +Cc: 61708

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


Andreas Schwab <schwab@suse.de> writes:

> On Feb 22 2023, Thierry Volpiatto wrote:
>
>> So how do you interpret this: "drwxr-x---" (from file-attributes)?
>
> This is not a symbolic mode.

(file-modes-number-to-symbolic #o750)
=>"-rwxr-x---"

I will reformulate my question:

How one convert the output of (nth 8 (file-attributes "/home/user")) to
numeric mode?

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 17:03       ` Thierry Volpiatto
@ 2023-02-22 17:11         ` Gregory Heytings
  2023-02-22 17:44           ` Thierry Volpiatto
  2023-02-23  9:14         ` Andreas Schwab
  1 sibling, 1 reply; 15+ messages in thread
From: Gregory Heytings @ 2023-02-22 17:11 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: Andreas Schwab, 61708


>
> How one convert the output of (nth 8 (file-attributes "/home/user")) to 
> numeric mode?
>

(file-modes "/home/user")






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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 17:11         ` Gregory Heytings
@ 2023-02-22 17:44           ` Thierry Volpiatto
  2023-02-22 21:40             ` Gregory Heytings
  0 siblings, 1 reply; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-22 17:44 UTC (permalink / raw)
  To: Gregory Heytings; +Cc: Andreas Schwab, 61708

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


Gregory Heytings <gregory@heytings.org> writes:

>>
>> How one convert the output of (nth 8 (file-attributes "/home/user"))
>> to numeric mode?
>>
>
> (file-modes "/home/user")

Yes, thanks I know this one, what I want to convert is e.g. "-rwxr-x---"
to number.

(file-modes-number-to-symbolic #o750)
"-rwxr-x---"
Means
"-|rwx|r-x|---"
rwx for user, rx for group and nothing for others.

What I mean is that file-modes-symbolic-to-number returns the right
value with MODES "u=rwx,g=rx,o=" but the wrong value with
"u=rwx,g=r-x,o=---".
This is why read-file-modes remove the "-" for passing the string as
MODES to file-modes-symbolic-to-number.

So shouldn't file-modes-symbolic-to-number supports "u=rwx,g=r-x,o=---"
and "u=rwx,g=rx,o=" in the same way.

I ask because I had to read code to understand this as I can't
understand the docstring.

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 17:44           ` Thierry Volpiatto
@ 2023-02-22 21:40             ` Gregory Heytings
  2023-02-23  4:44               ` Thierry Volpiatto
                                 ` (2 more replies)
  0 siblings, 3 replies; 15+ messages in thread
From: Gregory Heytings @ 2023-02-22 21:40 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: Andreas Schwab, 61708


>>> How one convert the output of (nth 8 (file-attributes "/home/user")) 
>>> to numeric mode?
>>
>> (file-modes "/home/user")
>
> Yes, thanks I know this one, what I want to convert is e.g. "-rwxr-x---" 
> to number.
>

(defun symbolic-mode-to-number (mode)
   (string-to-number
    (replace-regexp-in-string
     "[^0]" "1"
     (string-replace "-" "0" mode))
    2))






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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 21:40             ` Gregory Heytings
@ 2023-02-23  4:44               ` Thierry Volpiatto
  2023-02-23  6:08               ` Eli Zaretskii
  2023-02-23  9:18               ` Andreas Schwab
  2 siblings, 0 replies; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-23  4:44 UTC (permalink / raw)
  To: Gregory Heytings; +Cc: Andreas Schwab, 61708

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


Gregory Heytings <gregory@heytings.org> writes:

>>>> How one convert the output of (nth 8 (file-attributes
>>>> "/home/user")) to numeric mode?
>>>
>>> (file-modes "/home/user")
>>
>> Yes, thanks I know this one, what I want to convert is
>> e.g. "-rwxr-x---" to number.
>>
>
> (defun symbolic-mode-to-number (mode)
>   (string-to-number
>    (replace-regexp-in-string
>     "[^0]" "1"
>     (string-replace "-" "0" mode))
>    2))

Nice! I never used the BASE argument of string-to-number probably due to
my catastrophic math level :-), however this is very basic and doesn't
cover modes like "-rwxrwxrwt" or "-rwsr-xr-x".

I already wrote the needed functions for my needs (helm), however what I
had like is to clarify the usage of `file-modes-symbolic-to-number' in
docstring (examples?).
As Andrea pointed the MODES argument handle (+-=) like chmod would do
i.e. the function returns the numeric mode that for example chmod would set on
a file. Once you know it that's fine , you remove the "-" in MODES like
read-file-modes does otherwise you may think it interpret the mode that
a file already has.

Thanks.

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 21:40             ` Gregory Heytings
  2023-02-23  4:44               ` Thierry Volpiatto
@ 2023-02-23  6:08               ` Eli Zaretskii
  2023-02-23  7:00                 ` Thierry Volpiatto
  2023-02-23  9:18               ` Andreas Schwab
  2 siblings, 1 reply; 15+ messages in thread
From: Eli Zaretskii @ 2023-02-23  6:08 UTC (permalink / raw)
  To: Gregory Heytings; +Cc: thievol, schwab, 61708

> Cc: Andreas Schwab <schwab@suse.de>, 61708@debbugs.gnu.org
> Date: Wed, 22 Feb 2023 21:40:21 +0000
> From: Gregory Heytings <gregory@heytings.org>
> 
> 
> >>> How one convert the output of (nth 8 (file-attributes "/home/user")) 
> >>> to numeric mode?
> >>
> >> (file-modes "/home/user")
> >
> > Yes, thanks I know this one, what I want to convert is e.g. "-rwxr-x---" 
> > to number.
> >
> 
> (defun symbolic-mode-to-number (mode)
>    (string-to-number
>     (replace-regexp-in-string
>      "[^0]" "1"
>      (string-replace "-" "0" mode))
>     2))

Maybe we should have a knob in file-attributes or in
file-attribute-modes to return the modes as either a number or in
symbolic form suitable for file-modes-symbolic-to-number?





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-23  6:08               ` Eli Zaretskii
@ 2023-02-23  7:00                 ` Thierry Volpiatto
  0 siblings, 0 replies; 15+ messages in thread
From: Thierry Volpiatto @ 2023-02-23  7:00 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: schwab, Gregory Heytings, 61708

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


Eli Zaretskii <eliz@gnu.org> writes:

>> Cc: Andreas Schwab <schwab@suse.de>, 61708@debbugs.gnu.org
>> Date: Wed, 22 Feb 2023 21:40:21 +0000
>> From: Gregory Heytings <gregory@heytings.org>
>> 
>> 
>> >>> How one convert the output of (nth 8 (file-attributes "/home/user")) 
>> >>> to numeric mode?
>> >>
>> >> (file-modes "/home/user")
>> >
>> > Yes, thanks I know this one, what I want to convert is e.g. "-rwxr-x---" 
>> > to number.
>> >
>> 
>> (defun symbolic-mode-to-number (mode)
>>    (string-to-number
>>     (replace-regexp-in-string
>>      "[^0]" "1"
>>      (string-replace "-" "0" mode))
>>     2))
>
> Maybe we should have a knob in file-attributes or in
> file-attribute-modes to return the modes as either a number or in
> symbolic form suitable for file-modes-symbolic-to-number?

That's a good idea.

-- 
Thierry

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 686 bytes --]

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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 17:03       ` Thierry Volpiatto
  2023-02-22 17:11         ` Gregory Heytings
@ 2023-02-23  9:14         ` Andreas Schwab
  1 sibling, 0 replies; 15+ messages in thread
From: Andreas Schwab @ 2023-02-23  9:14 UTC (permalink / raw)
  To: Thierry Volpiatto; +Cc: 61708

On Feb 22 2023, Thierry Volpiatto wrote:

> (file-modes-number-to-symbolic #o750)

This function is misnamed.  It doesn't return a symbolic mode, but a
different text representation, and certainly isn't the inverse of
file-modes-symbolic-to-number.

-- 
Andreas Schwab, SUSE Labs, schwab@suse.de
GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE  1748 E4D4 88E3 0EEA B9D7
"And now for something completely different."





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-22 21:40             ` Gregory Heytings
  2023-02-23  4:44               ` Thierry Volpiatto
  2023-02-23  6:08               ` Eli Zaretskii
@ 2023-02-23  9:18               ` Andreas Schwab
  2023-02-23  9:27                 ` Gregory Heytings
  2 siblings, 1 reply; 15+ messages in thread
From: Andreas Schwab @ 2023-02-23  9:18 UTC (permalink / raw)
  To: Gregory Heytings; +Cc: Thierry Volpiatto, 61708

On Feb 22 2023, Gregory Heytings wrote:

> (defun symbolic-mode-to-number (mode)
>   (string-to-number
>    (replace-regexp-in-string
>     "[^0]" "1"
>     (string-replace "-" "0" mode))
>    2))

Apart from being misnamed, it doesn't handle tTsS.

-- 
Andreas Schwab, SUSE Labs, schwab@suse.de
GPG Key fingerprint = 0196 BAD8 1CE9 1970 F4BE  1748 E4D4 88E3 0EEA B9D7
"And now for something completely different."





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

* bug#61708: 28.2; file-modes-symbolic-to-number inconsistency
  2023-02-23  9:18               ` Andreas Schwab
@ 2023-02-23  9:27                 ` Gregory Heytings
  0 siblings, 0 replies; 15+ messages in thread
From: Gregory Heytings @ 2023-02-23  9:27 UTC (permalink / raw)
  To: Andreas Schwab; +Cc: Thierry Volpiatto, 61708


>> (defun symbolic-mode-to-number (mode)
>>   (string-to-number
>>    (replace-regexp-in-string
>>     "[^0]" "1"
>>     (string-replace "-" "0" mode))
>>    2))
>
> Apart from being misnamed, it doesn't handle tTsS.
>

Yes, that was just a quick PoC.  It doesn't handle the leading letter, 
either.






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

end of thread, other threads:[~2023-02-23  9:27 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-02-22 13:49 bug#61708: 28.2; file-modes-symbolic-to-number inconsistency Thierry Volpiatto
2023-02-22 14:16 ` Thierry Volpiatto
2023-02-22 14:26 ` Andreas Schwab
2023-02-22 14:58   ` Thierry Volpiatto
2023-02-22 15:45     ` Andreas Schwab
2023-02-22 17:03       ` Thierry Volpiatto
2023-02-22 17:11         ` Gregory Heytings
2023-02-22 17:44           ` Thierry Volpiatto
2023-02-22 21:40             ` Gregory Heytings
2023-02-23  4:44               ` Thierry Volpiatto
2023-02-23  6:08               ` Eli Zaretskii
2023-02-23  7:00                 ` Thierry Volpiatto
2023-02-23  9:18               ` Andreas Schwab
2023-02-23  9:27                 ` Gregory Heytings
2023-02-23  9:14         ` Andreas Schwab

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).