about summary refs log tree commit diff
path: root/Src
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2000-08-10 16:19:11 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2000-08-10 16:19:11 +0000
commitf6ecbb7f4d74099a0d4b342996696159344f4235 (patch)
treeb5da55d82acdc4ff4f3d8c0972be03a75a32837e /Src
parent4239b1243a4795fc6e7207151334cce03dafe44e (diff)
downloadzsh-f6ecbb7f4d74099a0d4b342996696159344f4235.tar.gz
zsh-f6ecbb7f4d74099a0d4b342996696159344f4235.tar.xz
zsh-f6ecbb7f4d74099a0d4b342996696159344f4235.zip
12581: C_BASES option
Diffstat (limited to 'Src')
-rw-r--r--Src/options.c1
-rw-r--r--Src/params.c7
-rw-r--r--Src/zsh.h1
3 files changed, 8 insertions, 1 deletions
diff --git a/Src/options.c b/Src/options.c
index 0bbe6b844..8660ade68 100644
--- a/Src/options.c
+++ b/Src/options.c
@@ -90,6 +90,7 @@ static struct optname optns[] = {
 {NULL, "bgnice",	      OPT_EMULATE|OPT_NONBOURNE, BGNICE},
 {NULL, "braceccl",	      OPT_EMULATE,		 BRACECCL},
 {NULL, "bsdecho",	      OPT_EMULATE|OPT_SH,	 BSDECHO},
+{NULL, "cbases",	      0,			 CBASES},
 {NULL, "cdablevars",	      OPT_EMULATE,		 CDABLEVARS},
 {NULL, "chasedots",	      OPT_EMULATE,		 CHASEDOTS},
 {NULL, "chaselinks",	      OPT_EMULATE,		 CHASELINKS},
diff --git a/Src/params.c b/Src/params.c
index 9ef3e61ca..1439e9af8 100644
--- a/Src/params.c
+++ b/Src/params.c
@@ -3045,7 +3045,12 @@ convbase(char *s, zlong v, int base)
 	base = 10;
 
     if (base != 10) {
-	sprintf(s, "%d#", base);
+	if (isset(CBASES) && base == 16)
+	    sprintf(s, "0x");
+	else if (isset(CBASES) && base == 8 && isset(OCTALZEROES))
+	    sprintf(s, "0");
+	else
+	    sprintf(s, "%d#", base);
 	s += strlen(s);
     }
     for (x = v; x; digs++)
diff --git a/Src/zsh.h b/Src/zsh.h
index bf59641b5..cdb90e264 100644
--- a/Src/zsh.h
+++ b/Src/zsh.h
@@ -1326,6 +1326,7 @@ enum {
     BGNICE,
     BRACECCL,
     BSDECHO,
+    CBASES,
     CDABLEVARS,
     CHASEDOTS,
     CHASELINKS,