mirror of
https://github.com/vgmstream/vgmstream.git
synced 2025-01-07 10:51:36 +01:00
178 lines
7.8 KiB
C
178 lines
7.8 KiB
C
|
// XMPlay plugin functions header
|
||
|
// new plugins can be submitted to plugins@xmplay.com
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include <wtypes.h>
|
||
|
|
||
|
typedef unsigned __int64 QWORD;
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
// Note all texts are UTF-8 on WinNT based systems and ANSI on Win9x
|
||
|
#define Utf2Uni(src,slen,dst,dlen) MultiByteToWideChar(CP_UTF8,0,src,slen,dst,dlen) // convert UTF-8 to Windows Unicode/WideChar
|
||
|
|
||
|
typedef void *(WINAPI *InterfaceProc)(DWORD face); // XMPlay interface retrieval function received by plugin
|
||
|
|
||
|
#define XMPFUNC_MISC_FACE 0 // miscellaneous functions (XMPFUNC_MISC)
|
||
|
#define XMPFUNC_REGISTRY_FACE 1 // registry functions (XMPFUNC_REGISTRY)
|
||
|
#define XMPFUNC_FILE_FACE 2 // file functions (XMPFUNC_FILE)
|
||
|
#define XMPFUNC_TEXT_FACE 3 // text functions (XMPFUNC_TEXT)
|
||
|
#define XMPFUNC_STATUS_FACE 4 // playback status functions (XMPFUNC_STATUS)
|
||
|
|
||
|
#define XMPCONFIG_NET_BUFFER 0
|
||
|
#define XMPCONFIG_NET_RESTRICT 1
|
||
|
#define XMPCONFIG_NET_RECONNECT 2
|
||
|
#define XMPCONFIG_NET_PROXY 3
|
||
|
#define XMPCONFIG_NET_PROXYCONF 4 // pointer to string
|
||
|
#define XMPCONFIG_NET_TIMEOUT 5
|
||
|
#define XMPCONFIG_NET_PREBUF 6
|
||
|
#define XMPCONFIG_OUTPUT 7 // pointer to XMPFORMAT (version 3.6)
|
||
|
|
||
|
#define XMPINFO_TEXT_GENERAL 0 // General info text
|
||
|
#define XMPINFO_TEXT_MESSAGE 1 // Message info text
|
||
|
#define XMPINFO_TEXT_SAMPLES 2 // Samples info text
|
||
|
|
||
|
#define XMPINFO_REFRESH_MAIN 1 // main window info area
|
||
|
#define XMPINFO_REFRESH_GENERAL 2 // General info window
|
||
|
#define XMPINFO_REFRESH_MESSAGE 4 // Message info window
|
||
|
#define XMPINFO_REFRESH_SAMPLES 8 // Samples info window
|
||
|
|
||
|
typedef void *XMPFILE;
|
||
|
|
||
|
#define XMPFILE_TYPE_MEMORY 0 // file in memory
|
||
|
#define XMPFILE_TYPE_FILE 1 // local file
|
||
|
#define XMPFILE_TYPE_NETFILE 2 // file on the 'net
|
||
|
#define XMPFILE_TYPE_NETSTREAM 3 // 'net stream (unknown length)
|
||
|
|
||
|
typedef void (WINAPI *XMPSHORTCUTPROC)();
|
||
|
typedef void (WINAPI *XMPSHORTCUTPROCEX)(DWORD id);
|
||
|
|
||
|
typedef struct {
|
||
|
DWORD id; // must be unique and >=0x10000
|
||
|
const char *text; // description
|
||
|
union { // handler
|
||
|
XMPSHORTCUTPROC proc;
|
||
|
XMPSHORTCUTPROCEX procex; // if id&0x80000000
|
||
|
};
|
||
|
} XMPSHORTCUT;
|
||
|
|
||
|
typedef struct {
|
||
|
DWORD rate; // sample rate
|
||
|
DWORD chan; // channels
|
||
|
DWORD res; // bytes per sample (1=8-bit,2=16-bit,3=24-bit,4=float,0=undefined)
|
||
|
} XMPFORMAT;
|
||
|
|
||
|
typedef struct {
|
||
|
float time; // cue position
|
||
|
const char *title;
|
||
|
const char *performer;
|
||
|
} XMPCUE;
|
||
|
|
||
|
#define TAG_FORMATTED_TITLE (char*)-1 // formatted track title
|
||
|
#define TAG_FILENAME (char*)-2 // filename
|
||
|
#define TAG_TRACK_TITLE (char*)-3 // stream track (or CUE sheet) title
|
||
|
#define TAG_LENGTH (char*)-4 // length in seconds
|
||
|
#define TAG_SUBSONGS (char*)-5 // subsong count
|
||
|
#define TAG_SUBSONG (char*)-6 // separated subsong (number/total)
|
||
|
#define TAG_RATING (char*)-7 // user rating
|
||
|
#define TAG_TITLE (char*)0 // = "title"
|
||
|
#define TAG_ARTIST (char*)1 // = "artist"
|
||
|
#define TAG_ALBUM (char*)2 // = "album"
|
||
|
#define TAG_DATE (char*)3 // = "date"
|
||
|
#define TAG_TRACK (char*)4 // = "title"
|
||
|
#define TAG_GENRE (char*)5 // = "genre"
|
||
|
#define TAG_COMMENT (char*)6 // = "comment"
|
||
|
#define TAG_FILETYPE (char*)7 // = "filetype"
|
||
|
|
||
|
/*
|
||
|
Non-"const" pointers returned by these functions should be freed via XMPFUNC_MISC:Free when done with them.
|
||
|
*/
|
||
|
|
||
|
typedef struct { // miscellaneous functions
|
||
|
DWORD (WINAPI *GetVersion)(); // get XMPlay version (eg. 0x03040001 = 3.4.0.1)
|
||
|
HWND (WINAPI *GetWindow)(); // get XMPlay window handle
|
||
|
void *(WINAPI *Alloc)(DWORD len); // allocate memory
|
||
|
void *(WINAPI *ReAlloc)(void *mem, DWORD len); // re-allocate memory
|
||
|
void (WINAPI *Free)(void *mem); // free allocated memory/text
|
||
|
BOOL (WINAPI *CheckCancel)(); // user wants to cancel?
|
||
|
DWORD (WINAPI *GetConfig)(DWORD option); // get a config (XMPCONFIG_xxx) value
|
||
|
const char *(WINAPI *GetSkinConfig)(const char *name); // get a skinconfig value
|
||
|
void (WINAPI *ShowBubble)(const char *text, DWORD time); // show a help bubble (time in ms, 0=default)
|
||
|
void (WINAPI *RefreshInfo)(DWORD mode); // refresh info displays (XMPINFO_REFRESH_xxx flags)
|
||
|
char *(WINAPI *GetInfoText)(DWORD mode); // get info window text (XMPINFO_TEXT_xxx)
|
||
|
char *(WINAPI *FormatInfoText)(char *buf, const char *name, const char *value); // format text for info window (tabs & new-lines)
|
||
|
char *(WINAPI *GetTag)(const char *tag); // get a current track's tag (tag name or TAG_xxx)
|
||
|
BOOL (WINAPI *RegisterShortcut)(const XMPSHORTCUT *cut); // add a shortcut
|
||
|
BOOL (WINAPI *PerformShortcut)(DWORD id); // perform a shortcut action
|
||
|
// version 3.4.0.14
|
||
|
const XMPCUE *(WINAPI *GetCue)(DWORD cue); // get a cue entry (0=image, 1=1st track)
|
||
|
// version 3.8
|
||
|
BOOL (WINAPI *DDE)(const char *command); // execute a DDE command without using DDE
|
||
|
} XMPFUNC_MISC;
|
||
|
|
||
|
typedef struct { // "registry" functions
|
||
|
DWORD (WINAPI *Get)(const char *section, const char *key, void *data, DWORD size); // if data=NULL, required size is returned
|
||
|
DWORD (WINAPI *GetString)(const char *section, const char *key, char *data, DWORD size); // if data=NULL, required size is returned
|
||
|
BOOL (WINAPI *GetInt)(const char *section, const char *key, int *data);
|
||
|
BOOL (WINAPI *Set)(const char *section, const char *key, const void *data, DWORD size); // data=NULL = delete key
|
||
|
BOOL (WINAPI *SetString)(const char *section, const char *key, const char *data);
|
||
|
BOOL (WINAPI *SetInt)(const char *section, const char *key, const int *data);
|
||
|
} XMPFUNC_REGISTRY;
|
||
|
|
||
|
typedef struct { // file functions
|
||
|
XMPFILE (WINAPI *Open)(const char *filename); // open a file
|
||
|
XMPFILE (WINAPI *OpenMemory)(const void *buf, DWORD len); // open a file from memory
|
||
|
void (WINAPI *Close)(XMPFILE file); // close an opened file
|
||
|
DWORD (WINAPI *GetType)(XMPFILE file); // return XMPFILE_TYPE_xxx
|
||
|
DWORD (WINAPI *GetSize)(XMPFILE file); // file size
|
||
|
const char *(WINAPI *GetFilename)(XMPFILE file); // filename
|
||
|
const void *(WINAPI *GetMemory)(XMPFILE file); // memory location (XMPFILE_TYPE_MEMORY)
|
||
|
DWORD (WINAPI *Read)(XMPFILE file, void *buf, DWORD len); // read from file
|
||
|
BOOL (WINAPI *Seek)(XMPFILE file, DWORD pos); // seek in file
|
||
|
DWORD (WINAPI *Tell)(XMPFILE file); // get current file pos
|
||
|
// net-only stuff
|
||
|
void (WINAPI *NetSetRate)(XMPFILE file, DWORD rate); // set bitrate in bytes/sec (decides buffer size)
|
||
|
BOOL (WINAPI *NetIsActive)(XMPFILE file); // connection is still up?
|
||
|
BOOL (WINAPI *NetPreBuf)(XMPFILE file); // pre-buffer data
|
||
|
DWORD (WINAPI *NetAvailable)(XMPFILE file); // get amount of data ready to go
|
||
|
|
||
|
char *(WINAPI *ArchiveList)(XMPFILE file); // get archive contents (series of NULL-terminated entries)
|
||
|
XMPFILE (WINAPI *ArchiveExtract)(XMPFILE file, const char *entry, DWORD len); // decompress file from archive
|
||
|
} XMPFUNC_FILE;
|
||
|
|
||
|
typedef struct { // text functions - return new string in native form (UTF-8/ANSI)
|
||
|
char *(WINAPI *Ansi)(const char *text, int len); // ANSI string (len=-1=null terminated)
|
||
|
char *(WINAPI *Unicode)(const WCHAR *text, int len); // Unicode string
|
||
|
char *(WINAPI *Utf8)(const char *text, int len); // UTF-8 string
|
||
|
} XMPFUNC_TEXT;
|
||
|
|
||
|
typedef struct { // playback status functions
|
||
|
BOOL (WINAPI *IsPlaying)(); // playing?
|
||
|
double (WINAPI *GetTime)(); // track position in seconds
|
||
|
QWORD (WINAPI *GetWritten)(); // samples written to output
|
||
|
DWORD (WINAPI *GetLatency)(); // samples in output buffer
|
||
|
const XMPFORMAT *(WINAPI *GetFormat)(BOOL in); // get input/output sample format
|
||
|
} XMPFUNC_STATUS;
|
||
|
|
||
|
// The following Winamp messages are also supported by XMPlay (see Winamp SDK for descriptions)
|
||
|
#define WM_WA_IPC WM_USER
|
||
|
#define IPC_DELETE 101
|
||
|
#define IPC_STARTPLAY 102
|
||
|
#define IPC_ISPLAYING 104
|
||
|
#define IPC_GETOUTPUTTIME 105
|
||
|
#define IPC_JUMPTOTIME 106
|
||
|
#define IPC_SETPLAYLISTPOS 121
|
||
|
#define IPC_SETVOLUME 122
|
||
|
#define IPC_SETPANNING 123
|
||
|
#define IPC_GETLISTLENGTH 124
|
||
|
#define IPC_GETLISTPOS 125
|
||
|
#define IPC_GETPLAYLISTFILE 211
|
||
|
#define IPC_GETPLAYLISTTITLE 212
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|