~ubuntu-branches/ubuntu/utopic/9base/utopic

« back to all changes in this revision

Viewing changes to lib9/fmt/sprint.c

  • Committer: Bazaar Package Importer
  • Author(s): Daniel Baumann
  • Date: 2009-08-20 17:34:06 UTC
  • mfrom: (6.2.2 squeeze)
  • Revision ID: james.westby@ubuntu.com-20090820173406-xpwqa9ruyevvc0ut
* Updating maintainer field.
* Updating vcs fields.
* Updating package to standards version 3.8.3.
* Updatin variables writing in rules to consistent style.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
 * The authors of this software are Rob Pike and Ken Thompson.
3
 
 *              Copyright (c) 2002 by Lucent Technologies.
4
 
 * Permission to use, copy, modify, and distribute this software for any
5
 
 * purpose without fee is hereby granted, provided that this entire notice
6
 
 * is included in all copies of any software which is or includes a copy
7
 
 * or modification of this software and in all copies of the supporting
8
 
 * documentation for such software.
9
 
 * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED
10
 
 * WARRANTY.  IN PARTICULAR, NEITHER THE AUTHORS NOR LUCENT TECHNOLOGIES MAKE
11
 
 * ANY REPRESENTATION OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY
12
 
 * OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE.
13
 
 */
 
1
/* Copyright (c) 2002-2006 Lucent Technologies; see LICENSE */
14
2
#include <stdarg.h>
15
3
#include <fmt.h>
16
4
#include "plan9.h"
28
16
        /*
29
17
         * on PowerPC, the stack is near the top of memory, so
30
18
         * we must be sure not to overflow a 32-bit pointer.
 
19
         *
 
20
         * careful!  gcc-4.2 assumes buf+len < buf can never be true and
 
21
         * optimizes the test away.  casting to uintptr works around this bug.
31
22
         */
32
 
        if(buf+len < buf)
33
 
                len = -(uint)buf-1;
 
23
        if((uintptr)buf+len < (uintptr)buf)
 
24
                len = -(uintptr)buf-1;
34
25
 
35
26
        va_start(args, fmt);
36
27
        n = vsnprint(buf, len, fmt, args);