File: io.h

package info (click to toggle)
spirv-tools 2026.1-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 28,900 kB
  • sloc: cpp: 477,281; javascript: 5,908; python: 3,326; ansic: 488; sh: 450; ruby: 88; makefile: 18; lisp: 9
file content (65 lines) | stat: -rw-r--r-- 2,974 bytes parent folder | download | duplicates (10)
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_