C++程序  |  160行  |  3.66 KB

/*############################################################################
  # Copyright 2016 Intel Corporation
  #
  # 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.
  ############################################################################*/

/*!
 * \file
 * \brief Buffer handling utilities interface.
 */
#ifndef EXAMPLE_UTIL_BUFFUTIL_H_
#define EXAMPLE_UTIL_BUFFUTIL_H_

#include <stddef.h>
#include "util/stdtypes.h"

/// Options controlling how a buffer should be printed.
typedef struct BufferPrintOptions {
  bool show_header;
  bool show_offset;
  bool show_hex;
  bool show_ascii;
  size_t bytes_per_group;
  size_t groups_per_line;
} BufferPrintOptions;

/// Toggle verbose logging
bool ToggleVerbosity();

/// Test if file exists
/*!
  \param[in] filename
  The file path.

  \returns bool
*/
bool FileExists(char const* filename);

/// Get file size
/*!
  \param[in] filename

  The file path.
  \returns size of the file in bytes
*/
size_t GetFileSize(char const* filename);

/// Get file size
/*!
  checks the size against an expected maximum size.
  \param[in] filename

  The file path.
  \param[in] max_size

  the maximum expected size of the file.
  \returns size of the file in bytes
*/
size_t GetFileSize_S(char const* filename, size_t max_size);

/// Allocate a buffer of a fixed size
/*!
  Logs an error message on failure.

  \param[out] buffer
  A pointer to the buffer to allocate.
  \param[in] size
  the requested size of the buffer in bytes.

  \returns
  A pointer to the allocated buffer or NULL if the allocation failed.

*/
void* AllocBuffer(size_t size);

/// Allocate a buffer to hold the content of a file and load
/*!
  Logs an error message on failure.

  \param[in] filename
  The file path.
  \param[out] size
  The allocated size of the buffer in bytes (same as file size).

  \returns
  A pointer to the allocated buffer or NULL if the allocation failed.

  \see ToggleVerbosity()
*/
void* NewBufferFromFile(const char* filename, size_t* size);

/// Read a buffer from a file with logging
/*!

  Verbosity of logging controlled by verbosity state


  \param[in] filename
  The file path.
  \param[in,out] buf
  The buffer.
  \param[in] size
  The size of the buffer in bytes.

  \returns 0 on success, non-zero failure

  \see ToggleVerbosity()
*/
int ReadLoud(char const* filename, void* buf, size_t size);

/// write a buffer from a file with logging
/*!

  Verbosity of logging controlled by verbosity state

  \param[in] buf
  The buffer.
  \param[in] size
  The size of the buffer in bytes.
  \param[in] filename
  The file path.

  \returns 0 on success, non-zero failure

  \see ToggleVerbosity()
*/
int WriteLoud(void* buf, size_t size, char const* filename);

/// print a buffer to standard out using user provided options
/*!
  \param[in] buf
  The buffer.
  \param[in] size
  The size of the buffer in bytes.
  \param[in] opts
  The formatting options.
*/
void PrintBufferOpt(const void* buffer, size_t size, BufferPrintOptions opts);

/// print a buffer to standard out using default options
/*!
  \param[in] buf
  The buffer.
  \param[in] size
  The size of the buffer in bytes.
*/
void PrintBuffer(const void* buffer, size_t size);

#endif  // EXAMPLE_UTIL_BUFFUTIL_H_