mirror of
https://github.com/holub/mame
synced 2025-05-07 14:54:35 +03:00

Make avi_file a class that's held with smart pointers, encapsulate various AVI I/O structures Make zip_file and _7z_file classes rather than having free functions everywhere Hide zip/7z class implementation behind an interface, no longer need to call close() to send back to the cache Don't dump as much crap in global namespace Add solaris PTY implementation Improve variable expansion for SDL OSD - supports ~/$FOO/${BAR} syntax Rearrange stuff so the same things are in file module for all OSDs Move file stuff into its own module 7z/zip open and destruct are still not thread-safe due to lack of interlocks around cache access Directory functions still need to be moved to file module SDL OSD may not initialise WinSock on Windows
179 lines
5.3 KiB
C++
179 lines
5.3 KiB
C++
// license:BSD-3-Clause
|
|
// copyright-holders:Aaron Giles
|
|
/***************************************************************************
|
|
|
|
fileio.h
|
|
|
|
Core file I/O interface functions and definitions.
|
|
|
|
***************************************************************************/
|
|
|
|
#pragma once
|
|
|
|
#ifndef MAME_EMU_FILEIO_H
|
|
#define MAME_EMU_FILEIO_H
|
|
|
|
#include "corefile.h"
|
|
#include "hash.h"
|
|
#include "unzip.h"
|
|
|
|
// some systems use macros for getc/putc rather than functions
|
|
#ifdef getc
|
|
#undef getc
|
|
#endif
|
|
|
|
//**************************************************************************
|
|
// TYPE DEFINITIONS
|
|
//**************************************************************************
|
|
|
|
// forward declarations
|
|
class _7z_file;
|
|
|
|
// ======================> path_iterator
|
|
|
|
// helper class for iterating over configured paths
|
|
class path_iterator
|
|
{
|
|
public:
|
|
// construction/destruction
|
|
path_iterator(const char *searchpath);
|
|
|
|
// getters
|
|
bool next(std::string &buffer, const char *name = nullptr);
|
|
|
|
// reset
|
|
void reset() { m_current = m_base; m_index = 0; }
|
|
|
|
private:
|
|
// internal state
|
|
const char * m_base;
|
|
const char * m_current;
|
|
int m_index;
|
|
};
|
|
|
|
|
|
|
|
// ======================> file_enumerator
|
|
|
|
// iterate over all files in all paths specified in the searchpath
|
|
class file_enumerator
|
|
{
|
|
public:
|
|
// construction/destruction
|
|
file_enumerator(const char *searchpath);
|
|
~file_enumerator();
|
|
|
|
// iterator
|
|
const osd_directory_entry *next();
|
|
|
|
private:
|
|
// internal state
|
|
path_iterator m_iterator;
|
|
osd_directory * m_curdir;
|
|
std::string m_pathbuffer;
|
|
//int m_buflen;
|
|
};
|
|
|
|
|
|
|
|
// ======================> emu_file
|
|
|
|
class emu_file
|
|
{
|
|
public:
|
|
// file open/creation
|
|
emu_file(UINT32 openflags);
|
|
emu_file(const char *searchpath, UINT32 openflags);
|
|
virtual ~emu_file();
|
|
|
|
// getters
|
|
operator util::core_file &();
|
|
bool is_open() const { return bool(m_file); }
|
|
const char *filename() const { return m_filename.c_str(); }
|
|
const char *fullpath() const { return m_fullpath.c_str(); }
|
|
UINT32 openflags() const { return m_openflags; }
|
|
hash_collection &hashes(const char *types);
|
|
bool restrict_to_mediapath() { return m_restrict_to_mediapath; }
|
|
bool part_of_mediapath(std::string path);
|
|
|
|
// setters
|
|
void remove_on_close() { m_remove_on_close = true; }
|
|
void set_openflags(UINT32 openflags) { assert(!m_file); m_openflags = openflags; }
|
|
void set_restrict_to_mediapath(bool rtmp = true) { m_restrict_to_mediapath = rtmp; }
|
|
|
|
// open/close
|
|
osd_file::error open(const char *name);
|
|
osd_file::error open(const char *name1, const char *name2);
|
|
osd_file::error open(const char *name1, const char *name2, const char *name3);
|
|
osd_file::error open(const char *name1, const char *name2, const char *name3, const char *name4);
|
|
osd_file::error open(const char *name, UINT32 crc);
|
|
osd_file::error open(const char *name1, const char *name2, UINT32 crc);
|
|
osd_file::error open(const char *name1, const char *name2, const char *name3, UINT32 crc);
|
|
osd_file::error open(const char *name1, const char *name2, const char *name3, const char *name4, UINT32 crc);
|
|
osd_file::error open_next();
|
|
osd_file::error open_ram(const void *data, UINT32 length);
|
|
void close();
|
|
|
|
// control
|
|
osd_file::error compress(int compress);
|
|
|
|
// position
|
|
int seek(INT64 offset, int whence);
|
|
UINT64 tell();
|
|
bool eof();
|
|
UINT64 size();
|
|
|
|
// reading
|
|
UINT32 read(void *buffer, UINT32 length);
|
|
int getc();
|
|
int ungetc(int c);
|
|
char *gets(char *s, int n);
|
|
|
|
// writing
|
|
UINT32 write(const void *buffer, UINT32 length);
|
|
int puts(const char *s);
|
|
int vprintf(util::format_argument_pack<std::ostream> const &args);
|
|
template <typename Format, typename... Params> int printf(Format &&fmt, Params &&...args)
|
|
{
|
|
return vprintf(util::make_format_argument_pack(std::forward<Format>(fmt), std::forward<Params>(args)...));
|
|
}
|
|
|
|
// buffers
|
|
void flush();
|
|
|
|
private:
|
|
bool compressed_file_ready(void);
|
|
|
|
// internal helpers
|
|
osd_file::error attempt_zipped();
|
|
osd_file::error load_zipped_file();
|
|
bool zip_filename_match(const zip_file::file_header &header, const std::string &filename);
|
|
bool zip_header_is_path(const zip_file::file_header &header);
|
|
|
|
osd_file::error attempt__7zped();
|
|
osd_file::error load__7zped_file();
|
|
|
|
// internal state
|
|
std::string m_filename; // original filename provided
|
|
std::string m_fullpath; // full filename
|
|
util::core_file::ptr m_file; // core file pointer
|
|
path_iterator m_iterator; // iterator for paths
|
|
path_iterator m_mediapaths; // media-path iterator
|
|
UINT32 m_crc; // file's CRC
|
|
UINT32 m_openflags; // flags we used for the open
|
|
hash_collection m_hashes; // collection of hashes
|
|
|
|
zip_file::ptr m_zipfile; // ZIP file pointer
|
|
dynamic_buffer m_zipdata; // ZIP file data
|
|
UINT64 m_ziplength; // ZIP file length
|
|
|
|
std::unique_ptr<_7z_file> m__7zfile; // 7Z file pointer
|
|
dynamic_buffer m__7zdata; // 7Z file data
|
|
UINT64 m__7zlength; // 7Z file length
|
|
|
|
bool m_remove_on_close; // flag: remove the file when closing
|
|
bool m_restrict_to_mediapath; // flag: restrict to paths inside the media-path
|
|
};
|
|
|
|
#endif // MAME_EMU_FILEIO_H
|