| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- // 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_
|