2013-11-09 11:26:41 +00:00
|
|
|
/* to_str-int.h
|
|
|
|
* Definitions for utilities to convert various other types to strings.
|
|
|
|
*
|
|
|
|
* Wireshark - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@wireshark.org>
|
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __TO_STR_INT_H__
|
|
|
|
#define __TO_STR_INT_H__
|
|
|
|
|
|
|
|
#include <glib.h>
|
|
|
|
|
2014-04-30 21:46:18 +00:00
|
|
|
/**
|
|
|
|
* word_to_hex()
|
|
|
|
*
|
|
|
|
* Output guint16 hex represetation to 'out', and return pointer after last character (out + 4).
|
|
|
|
* It always output full representation (padded with 0).
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 4 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *word_to_hex(char *out, guint16 word);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* word_to_hex_npad()
|
|
|
|
*
|
|
|
|
* Output guint16 hex represetation to 'out', and return pointer after last character.
|
|
|
|
* Value is not padded.
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 4 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *word_to_hex_npad(char *out, guint16 word);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* dword_to_hex_punct()
|
|
|
|
*
|
|
|
|
* Output guint32 hex represetation to 'out', and return pointer after last character.
|
|
|
|
* Each byte will be seperated with punct character (cannot be NUL).
|
|
|
|
* It always output full representation (padded with 0).
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 11 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *dword_to_hex_punct(char *out, guint32 dword, char punct);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* dword_to_hex()
|
|
|
|
*
|
|
|
|
* Output guint32 hex represetation to 'out', and return pointer after last character.
|
|
|
|
* It always output full representation (padded with 0).
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 8 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *dword_to_hex(char *out, guint32 dword);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* bytes_to_hexstr()
|
|
|
|
*
|
|
|
|
* Output hex represetation of guint8 ad array, and return pointer after last character.
|
|
|
|
* It always output full representation (padded with 0).
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least len * 2 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *bytes_to_hexstr(char *out, const guint8 *ad, guint32 len);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* bytes_to_hexstr_punct()
|
|
|
|
*
|
|
|
|
* Output hex represetation of guint8 ad array, and return pointer after last character.
|
|
|
|
* Each byte will be seperated with punct character (cannot be NUL).
|
|
|
|
* It always output full representation (padded with 0).
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least len * 3 - 1 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *bytes_to_hexstr_punct(char *out, const guint8 *ad, guint32 len, char punct);
|
|
|
|
|
2014-04-30 21:46:18 +00:00
|
|
|
/**
|
|
|
|
* oct_to_str_back()
|
|
|
|
*
|
|
|
|
* Output guint32 octal representation backward (last character will be written on ptr - 1),
|
|
|
|
* and return pointer to first character.
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 12 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *oct_to_str_back(char *ptr, guint32 value);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* hex_to_str_back()
|
|
|
|
*
|
|
|
|
* Output guint32 hex representation backward (last character will be written on ptr - 1),
|
|
|
|
* and return pointer to first character.
|
|
|
|
* This routine will output for sure (can output more) 'len' decimal characters (number padded with '0').
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 2 + MAX(8, len) bytes in the buffer.
|
|
|
|
*/
|
|
|
|
char *hex_to_str_back(char *ptr, int len, guint32 value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* uint_to_str_back()
|
|
|
|
*
|
|
|
|
* Output guint32 decimal representation backward (last character will be written on ptr - 1),
|
|
|
|
* and return pointer to first character.
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 10 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *uint_to_str_back(char *ptr, guint32 value);
|
2014-04-30 21:46:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* uint_to_str_back_len()
|
|
|
|
*
|
|
|
|
* Output guint32 decimal representation backward (last character will be written on ptr - 1),
|
|
|
|
* and return pointer to first character.
|
|
|
|
* This routine will output for sure (can output more) 'len' decimal characters (number padded with '0').
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least MAX(10, len) bytes in the buffer.
|
|
|
|
*/
|
|
|
|
char *uint_to_str_back_len(char *ptr, guint32 value, int len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* int_to_str_back()
|
|
|
|
*
|
|
|
|
* Output gint32 decimal representation backward (last character will be written on ptr - 1),
|
|
|
|
* and return pointer to first character.
|
|
|
|
*
|
|
|
|
* String is not NUL terminated by this routine.
|
|
|
|
* There needs to be at least 11 bytes in the buffer.
|
|
|
|
*/
|
2013-11-09 11:26:41 +00:00
|
|
|
char *int_to_str_back(char *ptr, gint32 value);
|
|
|
|
|
|
|
|
#endif /* __TO_STR_INT_H__ */
|