diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-01-07 19:04:12 +0100 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-01-07 19:04:12 +0100 |
commit | 4308f6e7e6586e3a27aa46c4d54c434b8533b16d (patch) | |
tree | 5a0229a80dd8dd900a9dbec809481c8538a80161 /sys/src/ape/lib/fmt/dofmt.c | |
parent | 772afbe98c7e74be35e7e5318967ce594e4d93e8 (diff) |
ape/fmt: %p and %z format for amd64
Diffstat (limited to 'sys/src/ape/lib/fmt/dofmt.c')
-rw-r--r-- | sys/src/ape/lib/fmt/dofmt.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/sys/src/ape/lib/fmt/dofmt.c b/sys/src/ape/lib/fmt/dofmt.c index 7f314e93e..3422e62cd 100644 --- a/sys/src/ape/lib/fmt/dofmt.c +++ b/sys/src/ape/lib/fmt/dofmt.c @@ -348,7 +348,11 @@ __ifmt(Fmt *f) break; } if(f->r == 'p'){ - u = (ulong)va_arg(f->args, void*); + if(sizeof(void*) == sizeof(uvlong)){ + isv = 1; + vu = (uvlong)va_arg(f->args, void*); + } else + u = (ulong)va_arg(f->args, void*); f->r = 'x'; fl |= FmtUnsigned; }else if(fl & FmtVLong){ @@ -538,6 +542,11 @@ __flagfmt(Fmt *f) f->flags |= FmtVLong; f->flags |= FmtLong; break; + case 'z': + f->flags |= FmtLong; + if(sizeof(void*) == sizeof(vlong)) + f->flags |= FmtVLong; + break; } return 1; } |