|  | // Copyright 2019 The IREE Authors | 
|  | // | 
|  | // Licensed under the Apache License v2.0 with LLVM Exceptions. | 
|  | // See https://llvm.org/LICENSE.txt for license information. | 
|  | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
|  |  | 
|  | #ifndef IREE_BASE_INTERNAL_FILE_IO_H_ | 
|  | #define IREE_BASE_INTERNAL_FILE_IO_H_ | 
|  |  | 
|  | #include "iree/base/api.h" | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | // Checks if a file exists at the provided |path|. | 
|  | // | 
|  | // Returns an OK status if the file definitely exists. An OK status does not | 
|  | // indicate that attempts to read or write the file will succeed. | 
|  | // Returns IREE_STATUS_NOT_FOUND if the file does not exist. | 
|  | iree_status_t iree_file_exists(const char* path); | 
|  |  | 
|  | // Loaded file contents. | 
|  | typedef struct iree_file_contents_t { | 
|  | iree_allocator_t allocator; | 
|  | union { | 
|  | iree_byte_span_t buffer; | 
|  | iree_const_byte_span_t const_buffer; | 
|  | }; | 
|  | } iree_file_contents_t; | 
|  |  | 
|  | // Returns an allocator that deallocates the |contents|. | 
|  | // This can be passed to functions that require a deallocation mechanism. | 
|  | iree_allocator_t iree_file_contents_deallocator(iree_file_contents_t* contents); | 
|  |  | 
|  | // Frees memory associated with |contents|. | 
|  | void iree_file_contents_free(iree_file_contents_t* contents); | 
|  |  | 
|  | // Synchronously reads a file's contents into memory. | 
|  | // | 
|  | // Returns the contents of the file in |out_contents|. | 
|  | // |allocator| is used to allocate the memory and the caller must use | 
|  | // iree_file_contents_free to release the memory. | 
|  | iree_status_t iree_file_read_contents(const char* path, | 
|  | iree_allocator_t allocator, | 
|  | iree_file_contents_t** out_contents); | 
|  |  | 
|  | // Synchronously writes a byte buffer into a file. | 
|  | // Existing contents are overwritten. | 
|  | iree_status_t iree_file_write_contents(const char* path, | 
|  | iree_const_byte_span_t content); | 
|  |  | 
|  | // Reads the contents of stdin until EOF into memory. | 
|  | // The contents will specify up until EOF and the allocation will have a | 
|  | // trailing NUL to allow use as a C-string (assuming the contents themselves | 
|  | // don't contain NUL). | 
|  | // | 
|  | // Returns the contents of the file in |out_contents|. | 
|  | // |allocator| is used to allocate the memory and the caller must use | 
|  | // iree_file_contents_free to release the memory. | 
|  | iree_status_t iree_stdin_read_contents(iree_allocator_t allocator, | 
|  | iree_file_contents_t** out_contents); | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | }  // extern "C" | 
|  | #endif | 
|  |  | 
|  | #endif  // IREE_BASE_INTERNAL_FILE_IO_H_ |