unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
From: Jean Louis <bugs@gnu.support>
To: Ergus <spacibba@aol.com>
Cc: help-gnu-emacs@gnu.org
Subject: Re: Elisp string function question
Date: Fri, 18 Jun 2021 15:28:05 +0300	[thread overview]
Message-ID: <YMyRVc2O3MKVIi3W@protected.localdomain> (raw)
In-Reply-To: <20210618121807.xsjdbv4ouqbv4uex@Ergus>

* Ergus <spacibba@aol.com> [2021-06-18 15:19]:
> Hi:
> 
> I just tried and this:
> 
> (string-empty-p nil)
> 
> returns nil. But nil is not an non-empty string. This forces to add some
> extra checks when using this function.
> 
> Is this intended?

I got this too, and it is not for all cases suitable.

(defun string-blank-if-nil (s)
  "Returns blank string for nil values"
  (if (null s) "" s))

I often use this one as `nil' I sometimes wish to convert to empty string.

(string-blank-if-nil nil) ⇒ ""

(string-blank-if-nil "1") ⇒ "1"

Maybe that idea will help.

(defun string-or-empty-string (i)
  "Returns empty string for nil"
  (let* ((type (type-of i)))
    (cond ((or (eql type 'integer)
	       (eql type 'float)) 
	   (number-to-string i))
	  ((null i) "")
	  ((eql type 'symbol) (prin1-to-string i))
	  ((eql type 'string) i))))

Or that anything should be converted:

(string-or-empty-string nil) ⇒ ""
(string-or-empty-string 1) ⇒ "1"
(string-or-empty-string "ok") ⇒ "ok"

Or better idea:

(seq-empty-p nil) ⇒ t
(seq-empty-p "") ⇒ t

-- 
Jean

Take action in Free Software Foundation campaigns:
https://www.fsf.org/campaigns

In support of Richard M. Stallman
https://stallmansupport.org/



  reply	other threads:[~2021-06-18 12:28 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20210618121807.xsjdbv4ouqbv4uex.ref@Ergus>
2021-06-18 12:18 ` Elisp string function question Ergus
2021-06-18 12:28   ` Jean Louis [this message]
2021-06-18 12:36   ` Eli Zaretskii
2021-06-18 13:32     ` Robert Pluim
2021-06-18 13:48       ` Eli Zaretskii
2021-06-18 14:02         ` Robert Pluim
2021-06-18 14:23           ` Eli Zaretskii
2021-06-18 14:54             ` Robert Pluim
2021-06-18 14:43   ` Stefan Monnier via Users list for the GNU Emacs text editor
2021-06-18 17:41   ` Michael Heerdegen
2021-06-18 21:25   ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-06-20  1:09     ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-06-20  1:15       ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-06-20  1:26         ` Emanuel Berg via Users list for the GNU Emacs text editor
2021-06-19  0:24   ` Michael Heerdegen

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=YMyRVc2O3MKVIi3W@protected.localdomain \
    --to=bugs@gnu.support \
    --cc=help-gnu-emacs@gnu.org \
    --cc=spacibba@aol.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
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).