/usr/include/sidplayfp/SidTune.h is in libsidplayfp-dev 1.2.2-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 | /*
* This file is part of libsidplayfp, a SID player engine.
*
* Copyright 2011-2013 Leandro Nini <drfiemost@users.sourceforge.net>
* Copyright 2007-2010 Antti Lankila
* Copyright 2000 Simon White
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifndef SIDTUNE_H
#define SIDTUNE_H
#include <stdint.h>
#include <memory>
#include "sidplayfp/siddefs.h"
class SidTuneInfo;
class SidTuneBase;
class sidmemory;
/**
* SidTune
*/
class SID_EXTERN SidTune
{
public:
static const int MD5_LENGTH = 32;
private:
/// Filename extensions to append for various file types.
static const char** fileNameExtensions;
private: // -------------------------------------------------------------
std::auto_ptr<SidTuneBase> tune;
const char* m_statusString;
bool m_status;
public: // ----------------------------------------------------------------
/**
* Load a sidtune from a file.
*
* To retrieve data from standard input pass in filename "-".
* If you want to override the default filename extensions use this
* contructor. Please note, that if the specified "fileName"
* does exist and the loader is able to determine its file format,
* this function does not try to append any file name extension.
* See "SidTune.cpp" for the default list of file name extensions.
* You can specify "fileName = 0", if you do not want to
* load a sidtune. You can later load one with open().
*
* @param fileName
* @param fileNameExt
* @param separatorIsSlash
*/
SidTune(const char* fileName, const char **fileNameExt = 0,
bool separatorIsSlash = false);
/**
* Load a single-file sidtune from a memory buffer.
* Currently supported: PSID format.
*
* @param oneFileFormatSidtune the buffer that contains song data
* @param sidtuneLength length of the buffer
*/
SidTune(const uint_least8_t* oneFileFormatSidtune, uint_least32_t sidtuneLength);
virtual ~SidTune() {}
/**
* The SidTune class does not copy the list of file name extensions,
* so make sure you keep it. If the provided pointer is 0, the
* default list will be activated. This is a static list which
* is used by all SidTune objects.
*
* @param fileNameExt
*/
void setFileNameExtensions(const char **fileNameExt);
/**
* Load a sidtune into an existing object from a file.
*
* @param fileName
* @param separatorIsSlash
*/
void load(const char* fileName, bool separatorIsSlash = false);
/**
* Load a sidtune into an existing object from a buffer.
*
* @param sourceBuffer the buffer that contains song data
* @param bufferLen length of the buffer
*/
void read(const uint_least8_t* sourceBuffer, uint_least32_t bufferLen);
/**
* Select sub-song.
*
* @param songNum the selected song (0 = default starting song)
* @return active song number, 0 if no tune is loaded.
*/
unsigned int selectSong(unsigned int songNum);
/**
* Retrieve current active sub-song specific information.
*
* @return a pointer to #SidTuneInfo, 0 if no tune is loaded. The pointer must not be deleted.
*/
const SidTuneInfo* getInfo() const;
/**
* Select sub-song and retrieve information.
*
* @param songNum the selected song (0 = default starting song)
* @return a pointer to #SidTuneInfo, 0 if no tune is loaded. The pointer must not be deleted.
*/
const SidTuneInfo* getInfo(unsigned int songNum);
/**
* Determine current state of object.
* Upon error condition use #statusString to get a descriptive
* text string.
*
* @return current state (true = okay, false = error)
*/
bool getStatus() const;
/**
* Error/status message of last operation
*/
const char* statusString() const;
/**
* Copy sidtune into C64 memory (64 KB).
*/
bool placeSidTuneInC64mem(sidmemory* mem);
/**
* Calculates the MD5 hash of the tune.
* Not providing an md5 buffer will cause the internal one to be used.
* If provided, buffer must be MD5_LENGTH + 1
*
* @return a pointer to the buffer containing the md5 string, 0 if no tune is loaded.
*/
const char *createMD5(char *md5 = 0);
private: // prevent copying
SidTune(const SidTune&);
SidTune& operator=(SidTune&);
};
#endif /* SIDTUNE_H */
|