Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

415 lines
12 KiB

  1. //************************************************************************
  2. //**
  3. //** THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
  4. //** ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED
  5. //** TO THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR
  6. //** A PARTICULAR PURPOSE.
  7. //**
  8. //** Copyright (C) 1993, 1994 Microsoft Corporation. All Rights Reserved.
  9. //**
  10. //** IDF.h
  11. //**
  12. //** DESCRIPTION:
  13. //** This file contains the format of the .IDF files.
  14. //**
  15. //** HISTORY:
  16. //** 04/29/93 created.
  17. //** 07/04/93 added UNICODE for displayable strings.
  18. //** 09/04/93 added keymaps.
  19. //** 09/05/93 added ID's for channel types.
  20. //**
  21. //************************************************************************
  22. /*
  23. @doc EXTERNAL SDK
  24. @types IDFHEADER |
  25. This is the format of the "hdr " chunk in a Microsoft IDF file.
  26. This will be the first subchunk of a "MMAP" list chunk. This will
  27. provide information on the IDF itself; what version, who created it,
  28. and a unique ASCII ID for the instrument.
  29. @field DWORD | cbStruct |
  30. This is the inclusive size of the header structure.
  31. @field DWORD | dwVersion |
  32. This is the version of the IDF file.
  33. under.
  34. @field DWORD | dwCreator |
  35. This is the creator ID for the IDF.
  36. @field DWORD | cbInstID |
  37. This is the size of the unique instrument identifier including the NULL.
  38. @field BYTE | abInstID[] |
  39. This is the actual ASCII bytes of the unique instrument id. This _IS_
  40. NULL terminated. There is no UNICODE version of this since this will
  41. only be used internally and not displayed to the user.
  42. @othertype IDFHEADER * | PIDFHEADER |
  43. A memory model dependant pointer to the structure.
  44. @othertype IDFHEADER FAR* | LPIDFHEADER |
  45. A far pointer to the structure.
  46. */
  47. typedef struct tag_IDFHEADER
  48. {
  49. DWORD cbStruct;
  50. DWORD dwVersion;
  51. DWORD dwCreator;
  52. DWORD cbInstID;
  53. BYTE abInstID[1];
  54. } IDFHEADER, *PIDFHEADER, FAR *LPIDFHEADER;
  55. /*
  56. @doc EXTERNAL SDK
  57. @types IDFINSTINFO |
  58. This is the format of the "inst" chunk in a Microsoft IDF file.
  59. This chunk will contain information on the instrument, e.g. who
  60. manufactured it, the name of the instrument, it's manufacturer and
  61. product id's and a revision number.
  62. @field DWORD | cbStruct |
  63. This is the inclusive size of the instrument information structure.
  64. @field DWORD | dwManufactID |
  65. Manufacturer's ID.
  66. @field DWORD | dwProductID |
  67. Product's ID.
  68. @field DWORD | dwRevision |
  69. Revision of the product.
  70. @field DWORD | cbManufactASCII |
  71. Length of the ASCII version of the manufacturuers name.
  72. @field DWORD | cbManufactUNICODE |
  73. Length of the UNICODE version of the manufacturuers name.
  74. @field DWORD | cbProductASCII |
  75. Length of the ASCII version of the product name.
  76. @field DWORD | cbProductUNICODE |
  77. Length of the UNICODE version of the product name.
  78. @field BYTE | abData[] |
  79. Contains the ASCII and UNICODE strings for the manufacturer and product
  80. names. NOTE that all strings are separated by a NULL and the NULL IS
  81. counted in the string lengths.
  82. @othertype IDFINSTINFO * | PIDFINSTINFO |
  83. A memory model dependant pointer to the structure.
  84. @othertype IDFINSTINFO FAR * | LPIDFINSTINFO |
  85. A far pointer to the structure.
  86. @comm The idea is that the cbManufactXXXXX and cbProductXXXXX will be the
  87. offsets into the bData array of bytes and it will contain a complete
  88. string that you can strcpy out. That is why the NULL is included in
  89. the byte count and in the actual data.
  90. */
  91. typedef struct tag_IDFINSTINFO
  92. {
  93. DWORD cbStruct;
  94. DWORD dwManufactID;
  95. DWORD dwProductID;
  96. DWORD dwRevision;
  97. DWORD cbManufactASCII;
  98. DWORD cbManufactUNICODE;
  99. DWORD cbProductASCII;
  100. DWORD cbProductUNICODE;
  101. BYTE abData[1];
  102. } IDFINSTINFO, FAR *LPIDFINSTINFO;
  103. /*
  104. @doc EXTERNAL SDK
  105. @types IDFINSTCAPS |
  106. This is the format of the "caps" chunk in a Microsoft IDF file.
  107. This chunk will contain information on the MIDI capabilities of
  108. the device. e.g. basic channel of the instrument, number of channels
  109. that the instrument has available. the polyphony of the instrument,
  110. whether or not it supports General MIDI, etc....
  111. @field DWORD | cbStruct |
  112. This is the size of the capabilities structure.
  113. @field DWORD | fdwFlags |
  114. Flags specifiying additional capabilities of an instrument.
  115. @flag IDFINSTCAPS_F_GENERAL_MIDI |
  116. Instrument supports General MIDI.
  117. @flag IDFINSTCAPS_F_SYSTEMEXCLUSIVE |
  118. Instrument supports system exclusive messages
  119. @field DWORD | dwBasicChannel |
  120. The basic channel for the instrument.
  121. @field DWORD | cNumChannels |
  122. Number of channels that the instrument supports to.
  123. @field DWORD | cInstrumentPolyphony |
  124. The total polyphony for the instrument.
  125. @field DWORD | cChannelPolyphony |
  126. The polyphony per channel.
  127. @othertype IDFINSTCAPS * | PIDFINSTCAPS |
  128. A memory model dependant pointer to the structure.
  129. @othertype IDFINSTCAPS FAR * | LPIDFINSTCAPS |
  130. A far pointer to the structure.
  131. */
  132. typedef struct tag_IDFINSTCAPS
  133. {
  134. DWORD cbStruct;
  135. DWORD fdwFlags;
  136. DWORD dwBasicChannel;
  137. DWORD cNumChannels;
  138. DWORD cInstrumentPolyphony;
  139. DWORD cChannelPolyphony;
  140. } IDFINSTCAPS, *PIDFINSTCAPS, FAR *LPIDFINSTCAPS;
  141. #define IDFINSTCAPS_F_GENERAL_MIDI 0x00000001
  142. #define IDFINSTCAPS_F_SYSTEMEXCLUSIVE 0x00000002
  143. /*
  144. @doc EXTERNAL SDK
  145. @types IDFCHANNELHDR |
  146. This is the format of the "chnl" chunk in a Microsoft IDF file.
  147. This contains a description on what "type" a channel is, i.e.
  148. is it a General MIDI channel, a drum channel, etc... Directly
  149. following this header is the actual data on each channel.
  150. @field DWORD | cbStruct |
  151. This is the size of the channel header structure.
  152. @field DWORD | fdwFlags |
  153. Flags describing the channel type information.
  154. @flag IDFCHANNELHDR_F_GENERAL_MIDI |
  155. If this flag is set then any channels that are not defined in the
  156. IDF are General MIDI channel types. If this flag is _NOT_ set then
  157. any channels that are not defined in the IDF are undefined and should
  158. NOT be used in mapping.
  159. @field DWORD | cNumChannels |
  160. This is the number of channels that follows the header.
  161. @othertype IDFCHANNELHDR * | PIDFCHANNELHDR |
  162. A memory model dependant pointer to the structure.
  163. @othertype IDFCHANNELHDR FAR * | LPIDFCHANNELHDR |
  164. A far pointer to the structure.
  165. */
  166. typedef struct tag_IDFCHANNELHDR
  167. {
  168. DWORD cbStruct;
  169. DWORD cNumChannels;
  170. DWORD fdwFlags;
  171. } IDFCHANNELHDR, *PIDFCHANNELHDR, FAR *LPIDFCHANNELHDR;
  172. #define IDFCHANNELHDR_F_GENERAL_MIDI 0x00000001
  173. /*
  174. @doc EXTERNAL SDK
  175. @types IDFCHANNELINFO |
  176. This is the format of the actual channel information for Microsoft
  177. authored IDF files. This is the Microsoft supported format for
  178. channel information.
  179. @field DWORD | dwChannel |
  180. This is the channel number that the structure defines.
  181. @field DWORD | fdwChannel |
  182. Defines the possible types this channel can be.
  183. @flag IDFCHANNELINFO_F_GENERAL_CHANNEL |
  184. Indicates that this channel may be a general channel.
  185. @flag IDFCHANNELINFO_F_DRUM_CHANNEL |
  186. Indicates that this channel may be a drum channel.
  187. @field DWORD | cbGeneralInitData |
  188. Specifies the length of the data which should be sent to initialize
  189. the channel to a general channel. This data will be sent whenever the
  190. channel is allocated as a general channel. If no initialization data
  191. is desired, this field should be set to zero. If more than one channel
  192. type is specified in the <f fdwChannel> field, initialization data
  193. must be specified and this field may not be zero.
  194. @field DWORD | cbDrumInitData |
  195. Specifies the length of the data which should be sent to initialize
  196. the channel to a drum channel. This data will be sent whenever the
  197. channel is allocated as a drum channel. If no initialization data
  198. is desired, this field should be set to zero. If more than one channel
  199. type is specified in the <f fdwChannel> field, initialization data
  200. must be specified and this field may not be zero.
  201. @field BYTE | abData[] |
  202. This field contains the actual initialization data to set the channel
  203. to general or drum. <f abData> contains first the initialization
  204. sequence to set the channel to a general channel, followed by
  205. the sequence to initialize the channel to a drum channel.
  206. <f cbGeneralInitData> and <f cbDrumInitData> should indicate the lengths
  207. of these sequences, byte aligned. However, the actual sequence should
  208. be padded so that it is actually DWORD aligned (i.e. even multiple
  209. of four bytes). <f cbStruct> should reflect the padded length of
  210. the sequences.
  211. @othertype IDFCHANNELINFO * | PIDFCHANNELINFO |
  212. A memory model dependant pointer to the structure.
  213. @othertype IDFCHANNELINFO FAR * | LPIDFCHANNELINFO |
  214. A far pointer to the structure.
  215. */
  216. typedef struct tag_IDFCHANNELINFO
  217. {
  218. DWORD cbStruct;
  219. DWORD dwChannel;
  220. DWORD fdwChannel;
  221. DWORD cbGeneralInitData;
  222. DWORD cbDrumInitData;
  223. BYTE abData[];
  224. } IDFCHANNELINFO, *PIDFCHANNELINFO, FAR *LPIDFCHANNELINFO;
  225. //
  226. // Currently defined channel types.
  227. //
  228. #define IDFCHANNELINFO_F_GENERAL_CHANNEL 0x00000001
  229. #define IDFCHANNELINFO_F_DRUM_CHANNEL 0x00000002
  230. /*
  231. @doc EXTERNAL SDK
  232. @types IDFPATCHMAPHDR |
  233. This is the format of the "map " chunk in a Microsoft IDF file.
  234. This chunk contains information on the patch map used for the
  235. instrument. Directly following this header is the actual mapping
  236. information for each patch.
  237. @field DWORD | cbStruct |
  238. This is the size of the patch map header structure.
  239. @field BYTE | abPatchMap[128] |
  240. This array contains the actual patch map. The incoming patch is
  241. used to index the array; the array contents are the new patch value
  242. and must be in the range 0x00-0x7F. Patch maps will only apply to
  243. channels of type general. If the instrument needs a patch change
  244. on a drum channel, it should be included in the initialization data
  245. in the IDFCHANNELINFO.
  246. @othertype IDFPATCHMAPHDR * | PIDFPATCHMAPHDR |
  247. A memory model dependant pointer to the structure.
  248. @othertype IDFPATCHMAPHDR FAR * | LPIDFPATCHMAPHDR |
  249. A far pointer to the structure.
  250. */
  251. typedef struct tag_IDFPATCHMAPHDR
  252. {
  253. DWORD cbStruct;
  254. BYTE abPatchMap[128];
  255. } IDFPATCHMAPHDR, *PIDFPATCHMAPHDR, FAR *LPIDFPATCHMAPHDR;
  256. /*
  257. @doc EXTERNAL SDK
  258. @types IDFKEYMAPHDR |
  259. This is the format of the "key " chunk in a Microsoft IDF file.
  260. This chunk contains information on the all of the key maps used
  261. for a given instrument. The information that is in this structure
  262. pertains to all of the key maps for the instrument. It contains
  263. the total number of key maps for the instrument and whether or not
  264. the key maps are General MIDI.
  265. @field DWORD | cbStruct |
  266. This is the size of the key map header structure.
  267. @field DWORD | cNumKeyMaps |
  268. This is the number of key maps that follow the header.
  269. @field DWORD | cbKeyMap |
  270. This is the size of each key map that follows the header.
  271. @othertype IDFPATCHMAPHDR * | PIDFPATCHMAPHDR |
  272. A memory model dependant pointer to the structure.
  273. @othertype IDFPATCHMAPHDR FAR * | LPIDFPATCHMAPHDR |
  274. A far pointer to the structure.
  275. */
  276. typedef struct tag_IDFKEYMAPHDR
  277. {
  278. DWORD cbStruct;
  279. DWORD cNumKeyMaps;
  280. DWORD cbKeyMap;
  281. } IDFKEYMAPHDR, *PIDFKEYMAPHDR, FAR *LPIDFKEYMAPHDR;
  282. /*
  283. @doc EXTERNAL SDK
  284. @types IDFKEYMAP |
  285. This is a keymap that follows the key map header.
  286. @field DWORD | cbStruct |
  287. This is the size of the key map header structure.
  288. @field DWORD | fdwKeyMapType |
  289. This field specifies the channel type this key map is valid for.
  290. @flag IDFKEYMAP_F_GENERAL_CHANNEL 0x00000001
  291. @flag IDFKEYMAP_F_DRUM_CHANNEL 0x00000002
  292. @field BYTE | abKeyMap[128] |
  293. This field contains the actual key map. The incoming key number from
  294. a note on or note off message is used to index this array; the array
  295. contents are the new key value. If the high bit it set in the new
  296. key value, then the note on or note off will be ignore; otherwise,
  297. it will be transmitted with the new key value.
  298. @othertype IDFKEYMAP * | PIDFKEYMAP |
  299. A memory model dependant pointer to the structure.
  300. @othertype IDFKEYMAP FAR * | LPIDFKEYMAP |
  301. A far pointer to the structure.
  302. */
  303. typedef struct tag_IDFKEYMAP
  304. {
  305. DWORD cbStruct;
  306. DWORD fdwKeyMap;
  307. BYTE abKeyMap[128];
  308. } IDFKEYMAP, *PIDFKEYMAP, FAR *LPIDFKEYMAP;
  309. #define IDFKEYMAP_F_GENERAL_CHANNEL 0x00000001L
  310. #define IDFKEYMAP_F_DRUM_CHANNEL 0x00000002L