forked from KhronosGroup/SPIRV-Tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathio.h
65 lines (58 loc) · 2.9 KB
/
io.h
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
// Copyright (c) 2016 Google Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#ifndef TOOLS_IO_H_
#define TOOLS_IO_H_
#include <cstdint>
#include <cstdio>
#include <cstring>
#include <vector>
// Sets the contents of the file named |filename| in |data|, assuming each
// element in the file is of type |uint32_t|. The file is opened as a binary
// file. If |filename| is nullptr or "-", reads from the standard input, but
// reopened as a binary file. If any error occurs, writes error messages to
// standard error and returns false.
//
// If the given input is detected to be in ascii hex, it is converted to binary
// automatically. In that case, the shape of the input data is determined based
// on the representation of the magic number:
//
// * "[0]x[0]7230203": Every following "0x..." represents a word.
// * "[0]x[0]7[,] [0]x23...": Every following "0x..." represents a byte, stored
// in big-endian order
// * "[0]x[0]3[,] [0]x[0]2...": Every following "0x..." represents a byte,
// stored in little-endian order
// * "07[, ]23...": Every following "XY" represents a byte, stored in
// big-endian order
// * "03[, ]02...": Every following "XY" represents a byte, stored in
// little-endian order
bool ReadBinaryFile(const char* filename, std::vector<uint32_t>* data);
// The hex->binary logic of |ReadBinaryFile| applied to a pre-loaded stream of
// bytes. Used by tests to avoid having to call |ReadBinaryFile| with temp
// files. Returns false in case of parse errors.
bool ConvertHexToBinary(const std::vector<char>& stream,
std::vector<uint32_t>* data);
// Sets the contents of the file named |filename| in |data|, assuming each
// element in the file is of type |char|. The file is opened as a text file. If
// |filename| is nullptr or "-", reads from the standard input, but reopened as
// a text file. If any error occurs, writes error messages to standard error and
// returns false.
bool ReadTextFile(const char* filename, std::vector<char>* data);
// Writes the given |data| into the file named as |filename| using the given
// |mode|, assuming |data| is an array of |count| elements of type |T|. If
// |filename| is nullptr or "-", writes to standard output. If any error occurs,
// returns false and outputs error message to standard error.
template <typename T>
bool WriteFile(const char* filename, const char* mode, const T* data,
size_t count);
#endif // TOOLS_IO_H_