1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
/*
** PJL C++ Library
** itoa.c
**
** Copyright (C) 1998 Paul J. Lucas
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
// local
#include "itoa.h"
#include "platform.h"
#include "util.h" /* for char_buffer_pool<> */
#ifndef PJL_NO_NAMESPACES
using namespace std;
namespace PJL {
#endif
//*****************************************************************************
//
// SYNOPSIS
//
char const* ltoa( register long n )
//
// DESCRIPTION
//
// Convert a long integer to a string. The string returned is from an
// internal pool of string buffers. The time you get into trouble is if
// you hang on to more then Num_Buffers strings. This doesn't normally
// happen in practice, however.
//
// PARAMETERS
//
// n The long integer to be converted.
//
// RETURN VALUE
//
// A pointer to the string.
//
// CAVEAT
//
// This function is NOT thread-safe because it uses char_buffer_pool which
// isn't.
//
// SEE ALSO
//
// Brian W. Kernighan, Dennis M. Ritchie. "The C Programming Language,
// 2nd ed." Addison-Wesley, Reading, MA, 1988. pp. 63-64.
//
//*****************************************************************************
{
static char_buffer_pool<25,5> buf;
register char *s = buf.next();
bool const is_neg = n < 0;
if ( is_neg ) n = -n;
do { // generate digits in reverse
*s++ = n % 10 + '0';
} while ( n /= 10 );
if ( is_neg ) *s++ = '-';
*s = '\0';
// now reverse the string
for ( register char *t = buf.current(); t < s; ++t ) {
char const tmp = *--s; *s = *t; *t = tmp;
}
return buf.current();
}
#ifndef PJL_NO_NAMESPACES
}
#endif
|