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
|
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
#ifndef _nsStreamFunctions_h_
#define _nsStreamFunctions_h_
#include "nscore.h"
#include "nsIInputStream.h"
#include "nsIOutputStream.h"
/*
* ZIP file data is stored little-endian. These are helper functions to read and
* write little endian data to/from a char buffer.
* The off argument, where present, is incremented according to the number of
* bytes consumed from the buffer.
*/
inline void WRITE8(uint8_t* buf, uint32_t* off, uint8_t val)
{
buf[(*off)++] = val;
}
inline void WRITE16(uint8_t* buf, uint32_t* off, uint16_t val)
{
WRITE8(buf, off, val & 0xff);
WRITE8(buf, off, (val >> 8) & 0xff);
}
inline void WRITE32(uint8_t* buf, uint32_t* off, uint32_t val)
{
WRITE16(buf, off, val & 0xffff);
WRITE16(buf, off, (val >> 16) & 0xffff);
}
inline uint8_t READ8(const uint8_t* buf, uint32_t* off)
{
return buf[(*off)++];
}
inline uint16_t READ16(const uint8_t* buf, uint32_t* off)
{
uint16_t val = READ8(buf, off);
val |= READ8(buf, off) << 8;
return val;
}
inline uint32_t READ32(const uint8_t* buf, uint32_t* off)
{
uint32_t val = READ16(buf, off);
val |= READ16(buf, off) << 16;
return val;
}
inline uint32_t PEEK32(const uint8_t* buf)
{
return (uint32_t)( (buf [0] ) |
(buf [1] << 8) |
(buf [2] << 16) |
(buf [3] << 24) );
}
nsresult ZW_ReadData(nsIInputStream *aStream, char *aBuffer, uint32_t aCount);
nsresult ZW_WriteData(nsIOutputStream *aStream, const char *aBuffer,
uint32_t aCount);
#endif
|