neoGFX
Cross-platform C++ app/game engine
Loading...
Searching...
No Matches
hexdump.hpp
Go to the documentation of this file.
1// hex_dump.hpp v1.0
2/*
3 * Copyright (c) 2007 Leigh Johnston.
4 *
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
9 * met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 *
14 * * Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 *
18 * * Neither the name of Leigh Johnston nor the names of any
19 * other contributors to this software may be used to endorse or
20 * promote products derived from this software without specific prior
21 * written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
24 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
25 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
27 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 */
35
36#pragma once
37
38#include <neolib/neolib.hpp>
39#include <ostream>
40#include <string>
41
42namespace neolib
43{
44 template<class Elem, class Traits>
45 inline void hex_dump(const void* aData, std::size_t aLength, std::basic_ostream<Elem, Traits>& aStream, std::size_t aWidth = 16)
46 {
47 const char* const start = static_cast<const char*>(aData);
48 const char* const end = start + aLength;
49 const char* line = start;
50 while (line != end)
51 {
52 aStream.width(4);
53 aStream.fill('0');
54 aStream << std::hex << line - start << " : ";
55 std::size_t lineLength = std::min(aWidth, static_cast<std::size_t>(end - line));
56 for (std::size_t pass = 1; pass <= 2; ++pass)
57 {
58 for (const char* next = line; next != end && next != line + aWidth; ++next)
59 {
60 char ch = *next;
61 switch(pass)
62 {
63 case 1:
64 aStream << (ch < 32 ? '.' : ch);
65 break;
66 case 2:
67 if (next != line)
68 aStream << " ";
69 aStream.width(2);
70 aStream.fill('0');
71 aStream << std::hex << std::uppercase << static_cast<int>(static_cast<unsigned char>(ch));
72 break;
73 }
74 }
75 if (pass == 1 && lineLength != aWidth)
76 aStream << std::string(aWidth - lineLength, ' ');
77 aStream << " ";
78 }
79 aStream << std::endl;
80 line = line + lineLength;
81 }
82 }
83}
void hex_dump(const void *aData, std::size_t aLength, std::basic_ostream< Elem, Traits > &aStream, std::size_t aWidth=16)
Definition hexdump.hpp:45