home *** CD-ROM | disk | FTP | other *** search
/ Inside Multimedia 1995 August / IMM0895.ISO01.iso / share / os2 / pmsndx / history.txt < prev    next >
Text File  |  1995-01-22  |  41KB  |  813 lines

  1.  
  2. Future work (user requests):
  3. X.  Add tool to SWAP channels
  4. X.  Add system resources page
  5. X.  Warp function (like caliope)
  6. X.  Allow editing of the info field
  7. X.  On AVG funciton, allow combination based on percentages
  8. X.  Find a way to remove the notebook pages for the major tabs
  9.     (Idea:  Remove the NOTEBOOK tabs and make the notebook a
  10.     regular dialog which has all of the pages hidden.  Add a
  11.     menu to let the user select which page is displayed.)
  12. X.  Integrate MMPM into the editor dialog (maybe)
  13. X.  Display multiple channels on the edit display.
  14. X.  Add RECORD capability for REXX command scripts
  15. X.  Make an EFFECTS.DLL and an IO.DLL so that PMsndX can share
  16.     the same code with new applications that share the same code.
  17. X.  Add menu to the editor
  18. 2.X Make the Editor the central point of control
  19. 2.X Create Multiple Document Interface
  20.  
  21. Revision history:
  22. Version 1.37b:
  23. 1.  Added capability to pull the sound out of an AVI movie
  24.  
  25. Version 1.37:
  26. 1.  Added expiration date to registration information
  27.  
  28. Version 1.36b-d:
  29. 1.  Corrected simple bugs and changed email address of author
  30.  
  31. Version 1.36a: (9 Dec 94)
  32. 1.  Added an option to the MISC Properties to warn the user
  33.     when a .AU file is created which is not ULaw format.
  34. 2.  Added functions to query and set the tristate property
  35.     for forcing ULaw format
  36.  
  37. Version 1.36:  (8 Dec 94)
  38. 1.  Added option to the properties box to enable or disable
  39.     the footnote display.
  40. 2.  Animated the Pause button
  41. 3.  Fixed a problem with the help to conform with the recommended
  42.     usage of the F1 key (from the CUA guidelines).
  43. 4.  Added rexx functions to query and set the new Properties
  44.     for sharing the audio device and creating the footnote
  45.     on the main control panel.
  46. 5.  Enabled UL for the unregistered version of PMsndX.
  47.  
  48. Version 1.36 (beta 2):  (27 Nov 94)
  49. 1.  Recompiled with IBM CSet++ to solve a problem with crashing
  50.     under OS/2 3.0 (Warp) GA.
  51. 2.  Oops...I forgot to update the version text to indicate that
  52.     the first beta was actually a beta.
  53. 3.  Corrected a major oversight in the MMPM code which prevented
  54.     PMsndX from playing sounds after the 12 sample was loaded.
  55. 4.  Added option to use the audio device without sharing.
  56.  
  57. Version 1.36 (beta 1):  (16 Nov 94)
  58. 1.  Fixed the HELP so that the standard F1 key is now supported
  59. 2.  Added TOOLPAGE AND PROPPAGE features to the REXX scripts to
  60.     change pages of the Toolbox and the Properties notebook.
  61. 3.  Modified parsing of the RECORD command so that the keywords
  62.     can be specified in any order.  Previously, the limit had to
  63.     be specified after the rate and channels and PMsndX would
  64.     crash if it was not in this order.
  65. 4.  Bug:  When AVERAGING channels, if the average was to the
  66.     CENTER, the result would be random.
  67. 5.  Modified the AVERAGE 4TO1 REXX syntax to allow the specification
  68.     of the FROM channels.
  69. 6.  Changed the memory allocation scheme.  Now, the limit specified
  70.     represents the total amount of OS/2 memory that can be allocated
  71.     by the program and can be set to as many as 32767 4k pages.  The
  72.     AUTO settings essentially places no limit on the amount of memory
  73.     that the program will attempt to take.  You better have a big
  74.     swap file if you plan on using AUTO and large samples!
  75. 7.  Bug:  Previously MMPM would refuse to play a sample which had
  76.     more channels that the audio device supported regardless of the
  77.     channel selection setting.  Now, if the channel selection is
  78.     set and a channel has been selected, the audio device will play
  79.     the specified channel.
  80. 8.  Changed the REXX syntax for the EDITOR.  The editor is no longer
  81.     displayed when data is manipulated.
  82. 9.  Finished the REXX implementation.
  83.  
  84. Version 1.35:  (6 Nov 94)
  85. 1.  Removed all "Cancel", and "Dismiss" buttons from all
  86.     dialogs.  The system menu for the dialogs is used to
  87.     close the boxes.  A new button "RESET" has been created
  88.     for the dialogs which have an "APPLY" button.
  89. 2.  Added an option to the AUDIO Properties to play on Command line
  90.     load.  This allows sounds to be played from the command line
  91.     without setting the PLAY ON LOAD setting.  The PLAY ON LOAD
  92.     still operates as it did before.
  93. 3.  When PMsndX is registered and a file is specified on the command
  94.     line, the ABOUT dialog box is not displayed.
  95. 4.  Added volume control to the AUDIO and QUERY parts of the REXX
  96.     syntax to let the REXX set the initial volume.
  97. 5.  Added keyboard input through the REXX OUTPUT window.  Handles
  98.     STDIN (e.g. PULL) but not CHARIN.
  99. 6.  Modified and implemented the MESSAGE portion of the REXX
  100.     scripts.  (Changed the MESSAGE subcommands to functions so
  101.     that they can return the status of the buttons.  Also, added
  102.     an array of capabilities to match all possible combinations that
  103.     OS/2 offers).
  104. 7.  Changed FILE subcommands to functions to allow for better
  105.     processing of arguments and to allow PMsndX to return the
  106.     fully qualified filename.
  107. 8.  Added command to suppress the display of the PMsndX REXX
  108.     commands in the output window.
  109. 9.  Fixed the RECORD portion of the REXX scripts so that they work!
  110. 10. Added a REXX page to the Properties Dialog.  Also moved the
  111.     REXX Lines to the REXX page and added 4 spinbutton type windows
  112.     to let the user choose the colors of the REXX display.
  113. 11. Added the EDITOR functions to the REXX scripts.
  114. 12. Added DISPLAY section to the REXX
  115.  
  116. Version 1.34:  (1 Nov 94)
  117. 1.  All dialogs now use the following buttons:
  118.     APPLY  means "do it", "apply", "save changes" or whatever I use to use
  119.     CANCEL means "dismiss", "close", "get this damn window off my screen"
  120.          without recording any changes made.
  121.     ABORT  (where applicable) "stop that task from taking up my CPU!"
  122.     (A description of the major buttons has been added to the HELP file)
  123. 2.  Added CANCEL button to the play options dialog
  124. 3.  The checkboxes for "Auto Dismiss" and "Save Directory" are
  125.     only saved when a file is successfully loaded.  (Why not when
  126.     the window dismisses?  Well duh!  If you don't set the "Auto
  127.     Dismiss" the only way to get rid of the box is with the Cancel
  128.     button.  So, I save the status after a file is successfully loaded.
  129. 4.  Added item to the MISC Properties page to specify the location
  130.     of the PMsndX.ini file.
  131. 5.  CRITICAL CHANGE!!!!  While starting to implement the REXX
  132.     processing I found that I had overlooked an important problem.
  133.     With all the ownerships of C++, I could not manipulate all of
  134.     the private variables without the dialog boxes.  All of the
  135.     functions had to be modified to allow a "back door" for the
  136.     rexx scripts.  This could bring in new errors.  Look out!
  137. 6.  Modified the Clipboard routines so that they do not clear
  138.     the clipboard when data is pasted.
  139. 7.  When a file is loaded, the UNDO is updated if it is enabled.
  140. 8.  When a file is aborted, and UNDO is enabled, the old data
  141.     is automatically restored.
  142. 9.  When an error occurs when loading a file and UNDO is enabled,
  143.     the previous data is restored.
  144. 10. Implemented the FILE portion of the REXX scripts
  145. 11. Modified the REXX output so that all commands are displayed
  146.     before the command is executed.  Also, when an error occurs,
  147.     the command is now displayed before the error is displayed.
  148. 12. When command line playback is used, the AUDIO dialog box is
  149.     displayed.
  150. 13. Rewrote the commandline playback section so that a REXX script
  151.     can be played.  (Commandline playback will stop after the
  152.     first rexx script that is encountered.)  Previously, playback
  153.     was hit or miss because I did not expand filenames properly.
  154.     It is fixed in this version.
  155. 14. Implemented the MISC portions of the REXX scripts
  156. 15. Implemented the AUDIO PLAY support in the REXX scripts
  157. 16. Added MMPM_DEVICE, MMPM_INI_PATH, and MMPM_PLAY_16ON8 to the
  158.     REXX script syntax.
  159. 17. Implemented the PROPERTIES portion of the REXX script.
  160. 18. Modified the syntax of the RECORD command
  161. 19. Changed the QUERY commands from subcoms to functions
  162. 20. Added option to the PROPERTIES to play headerless .AU
  163.     files automatically
  164.  
  165. Version 1.33:  (24 Oct 94)
  166. 1.  Bug:  The Drag/Drop routines did not check to see if PMsndX was
  167.     currently processing data before the drop operation started.
  168.     (When the F1 key is pressed during this condition, a dialog
  169.     box displays the problem.)
  170. 2.  Added option to the AUDIO page of the settings dialog to
  171.     let 16 bit samples play on 8 bit cards.  (Someone with an 8
  172.     bit card needs to test this!)
  173. 3.  Added option to ignore unknown header blocks when loading a file
  174.     (if the result of the unknown header block makes the file unloadable
  175.     an error will be displayed.  This only disables the warnings.)
  176. 4.  Bug:  Drag/Drop previously concatenated successive drag/drop
  177.     names together because I did a strcat instead of a strcpy.
  178. 5.  Added option to let the .AU file extension override the header
  179.     information.  Essentially, by default, if a file with an extension
  180.     of .AU is opened and it does not contain a header, it will be
  181.     forced to be interpreted as ULAW with standard characteristics of
  182.     1 channel, and 8012 Hz sampling rate.  By turning this option on
  183.     the operation requires that all .AU files contain a valid header.
  184. 6.  Changed the "Settings..." menu item to "Properties..."
  185. 7.  When a command script (REXX) is opened, the name on the control
  186.     panel is not changed.
  187. 8.  When a command script (REXX) is opened, the REXX output window
  188.     will have the title of the file that is running.
  189. 9.  Added a series of QUERY commands to the REXX syntax to allow
  190.     information about both PMsndX properties and file properties.
  191.  
  192. Version 1.32:  (30 Sep 94)
  193. 1.  Bug:  Fixed bug in writing 16 bit .WAV files.  (I was writing
  194.     a FormatTag of 0x02 instead of 0x01.)
  195.  
  196. Version 1.31:  (28 Sep 94)
  197. 1.  Removed Help, Exit, and Settings from the control panel
  198. 2.  Moved the Playback options to a dialog from the
  199.     SysMenu of the AUDIO dialog
  200. 3.  Changed the Settings to a Notebook
  201. 4.  Completed the following REXX commands:
  202.         PMSNDX EXIT
  203.         PMSNDX CLOSE
  204. 5.  Fixed bug in REXX display window
  205.  
  206. Version 1.3:   (never released)
  207. 1.  Added footnote window to main control panel
  208. 2.  Added REXX hooks
  209. 3.  Added a display window for the REXX output
  210.  
  211. Version 1.2:   (16 Sep 94)
  212. 1.  Fixed bug with semaphores in MMPM which caused the data to
  213.     become locked.
  214.  
  215. Version 1.2:   (8 Sep 94)
  216. 1.  Drag and Drop functionality added
  217.     - Accepts Files for dropping.
  218.     - When sending a file, if it is not a OS/2 file, it must
  219.       be rendered into a file by the source first
  220. 2.  When registering, the current password is not displayed
  221. 3.  Fixed bug in writing .VOC files
  222.  
  223. Version 1.1:   (4 Sep 94)
  224. 1.  Previously, REMOVE in the editor did not utilize the UNDO
  225.     feature.
  226. 2.  Added recording capability for the MMPM Player.
  227.     - Records directly to memory
  228.     - Records till a specified limit or till STOP is pressed
  229.     - Detects current AUDIO capabilities
  230. 3.  Added VOLUME control for both playback and record
  231. 4.  Changed the name of the MMPM/PLAYBACK button to AUDIO
  232. 5.  Changed over to MUTEX semaphores to limit access to the
  233.     sample data between tasks
  234. 6.  Added a semaphore to the MMPM copy of the data (This
  235.     was necessary to avoid conflicts between play and
  236.     record)
  237.  
  238. Version 1.0:   (22 Aug 94)
  239. 1.  Modified Copy command to only copy a single channel when
  240.     a single channel is selected.
  241. 2.  Renamed class to "PMsndX 1.00" (This will have the effect
  242.     of forcing beta testers to recreate the pmsndx.ini file)
  243. 3.  Bug.  Previously, the length of the start was always added
  244.     to the end when the clipboard was merged.
  245. 4.  Bug.  Previously, no matter if a selection was specified
  246.     for a channel or ALL was selected, REMOVE would remove
  247.     from all channels.
  248. 5.  Changed the profile operation so that the os2.ini file is
  249.     only modified when the program is registered.
  250. 6.  Added examples of the user interface to the help file.
  251. 7.  Created two help files.  The larger file is the default
  252.     and contains examples of the user interface.
  253.     smallhlp.hlp is the version of the help without the
  254.     examples.  To use the smaller version, copy it to
  255.     pmsndx.hlp.
  256.  
  257. Version 0.88:  (16 Aug 94)
  258. 1.  Bug.  Oh hey, secondary windows receive a WM_QUIT message
  259.     when they exit!  That caused PMsndX to exit too!  The solution?
  260.     Remove the CLOSE item from the MMPM system menu.
  261. 2.  Bug.  When using the VIBRO function, if the speed was left
  262.     at zero (0), PMsndX would hang.
  263. 3.  AUTO DISMISS is now the default for the OPEN and SAVE dialogs.
  264. 4.  The MMPM button has been renamed to PLAYBACK.
  265. 5.  Added more updates to the CLOCK pointer so that it does
  266.     not hang at positions when operations end prematurely.
  267. 6.  If MMPM is installed it is automatically enabled in the
  268.     settings box.
  269. 7.  The default is to save the window positions and the last
  270.     directory accessed.
  271. 8.  Removed the REWind button from the MMPM player and reorganized
  272.     the buttons.
  273. 9.  Bug.  The horizontal sides of the control panel would allow
  274.     the panel to resize smaller without resizing the buttons.
  275.     Now, resizing using the horizontal sides just moves the box.
  276.  
  277. Version 0.87:  (14 Aug 94)
  278. 1.  Bug.  The average function did not work for 4 channels.
  279. 2.  Bug.  The rate and speed dialogs did not properly manipulate
  280.     the mouse pointer and it would go from 0 to 2 but no further.
  281.     Note that there was nothing wrong with the operation other
  282.     than the mouse pointer did not get updated properly.
  283. 3.  Bug.  When a range was selected for the REVERSE tool, the
  284.     actual data reversed would be incorrect if the beginning
  285.     was not at 0.0 offset.
  286. 4.  Add tool to invert a waveform
  287. 5.  When PASTING from the clipboard, if the SHIFT key is held down
  288.     while pressing the PASTE button, the data on the clipboard will
  289.     be merged instead of pasting.  (merge = average 50/50).
  290. 6.  Bug.  When pasting, the old bug for Signed/Unsigned WAV
  291.     data was found again.
  292.  
  293. Version 0.86:  (11 Aug 94)
  294. 1.  Bug.  The Lowpass dialog would not redraw itself after it is
  295.     uncovered by another window.
  296. 2.  Bug.  If a .WAV file was loaded which contained a bad header,
  297.     the READ task would hang.
  298. 3.  If very small files were loaded (e.g. under 100 samples) the
  299.     clock pointer would stick at the 11:00 position and the open
  300.     dialog did not receive the signal to close.  It appears that
  301.     the system receives too many posts to the pointer queue and
  302.     as we all know, OS/2 deletes posts that are duplicated.  The
  303.     solution...force a .1 second delay after the read before sending
  304.     the update information.
  305. 4.  Previous versions just BEEPed when an operation was attempted
  306.     while the current sample was being manipulated.  That has been
  307.     changes so that if an operation is attempted while the data
  308.     is "busy" an error is displayed.
  309. 5.  Bug.  If the MMPM dialog was dismissed while the MMPM buffers
  310.     were being loaded, the "busy" flag would not be cleared
  311.     and no further operations could be done.
  312.  
  313. Version 0.85:  (9 Aug 94)
  314. 1.  Edited virtually all of the dialogs so that they would
  315.     appear correctly when VGA fonts are used with SVGA displays.
  316.     (Note, this may be an odd combination, but people use it
  317.     and I had to make sure that PMsndX displays correctly).
  318.  
  319. Version 0.84:  (8 Aug 94)
  320. 1.  Resized the MMPM dialog (moved the group box, added space
  321.     between the checkboxes, and increased the width and height
  322.     of the overall box)
  323. 2.  Widened the OPEN and SAVE dialog boxes and moved things
  324.     over to the right to add more space to avoid clipping
  325. 3.  Bug.  When the editor display is updated with a new file,
  326.     the Vertical Scroll bar (Zoom) would be set to maximum but
  327.     the actual zoom would be minimized.
  328. 4.  Bug.  When the redraw button on the editor was pressed, the
  329.     horizontal scroll bar would revert to the leftmost position
  330.     but the display would remain unchanged.  Pressing an arrow
  331.     would return it to the correct position.
  332. 5.  The Tools box size has been increased to allow more space
  333.     between the controls to avoid clipping.  On a 1024x768 display
  334.     the controls looked fine but at VGA resolution they were clipped.
  335.     a.  The Type page previously clipped the IRACAM and SMPVS
  336.     b.  The Average Channels page had the checkboxes touching
  337.     c.  The band-pass filter page clipped the "Add filter noise"
  338.     d.  The low-pass filter page clipped the slider at the top
  339.     e.  The Vibro-champ page had the sliders clipped
  340.     f.  The Fade page was clipped on the right side
  341.     g.  The Limit page clipped the sliders
  342.  
  343. Version 0.83:  (7 Aug 94)
  344. 1.  Fixed up the bitmap displays.
  345. 2.  PMsndX now checks the MMPM parameters to verify that the sound
  346.     card can play 16 bit sound samples.  If the sound card cannot
  347.     play 16 bit sounds, then the MMPM player will not load its buffers
  348.     and will just refuse to play.
  349.  
  350. Version 0.82:  (7 Aug 94)
  351. 1.  In previous versions, if a file was being saved and the program
  352.     exited, the program would wait indefinitely till the save completed.
  353.     This could prevent killing PMsndX and would lock the message queue.
  354. 2.  The MMPM player now displays "Loading Data" when it is filling
  355.     the data buffers.
  356. 3.  PMsndX now exits correctly when Ctrl-C is pressed from a command
  357.     window or when PMsndX is terminated from a task manager.
  358. 4.  PMsndX now properly terminates all tasks (save and MMPM) when
  359.     the program exits.  In previous versions, the MMPM task for
  360.     loading buffers was not killed when the program exited or when
  361.     the MMPM dialog was destroyed.
  362. 5.  In previous versions I did not save the last position of the
  363.     windows if the program exited while the windows were open.  This
  364.     was because I saved settings stuff before closing the windows and
  365.     the windows did not save their positions till they closed.
  366. 6.  The Toolbox now sets the tabs size based on the resolution of
  367.     the monitor.  This should avoid problems with clipping of text
  368.     found in previous versions.  (David Charlap showed me how to do
  369.     this effectively)
  370. 7.  Added hotkeys to the Tools notebook
  371. 8.  Moved the registration information out of the pmsndx.ini file
  372.     and into the system user ini file so that a user may use the
  373.     pmsndx.ini file on any computer or on a network.
  374.  
  375. Version 0.81:  (17 Jul 94)
  376. 1.  Bug.  The MMPM reloaded its buffers when the channel to manipulate
  377.     was changed regardless of the checkbox for global channels
  378. 2.  Bug.  The MMPM reloaded its buffers when the range to manipulate
  379.     was changed regardless of the checkbox for global range
  380. 3.  Bug.  (Well, not really) The error boxes were not application
  381.     modal.  They are now.
  382. 4.  A few fixups on the help text.
  383. 5.  Dialog windows do not move with the main control panel.
  384. 6.  The welcome dialog box has been changed so that the standard
  385.     text is greyed and the new stuff is dark to make it easier to
  386.     read.
  387. 7.  If the current sample in memory has been modified and the
  388.     EXIT button is pushed, the program will tell the user that
  389.     modified buffers exist and verify that the user wants to continue.
  390. 8.  The Registration box now has the capability to read a file
  391.     and find the registration information if it has the proper
  392.     keywords (i.e. if it was a password that I emailed you).
  393. 9.  Fixed bug in .WAV reader in which an the header was not checked
  394.     for invalid data and a "divide by 0" error could occur.
  395.  
  396. Version 0.8:  (17 Jul 94)
  397. 1.  Added a menu item to the main control panel to reset the size
  398.     of the main control panel to the default
  399. 2.  Bug.  When a sample is very short, the Display was not cleared
  400.     beyond the end of the sample.
  401. 3.  Bug.  When "Play on load" was selected, the new MMPM thread
  402.     would get triggered by window updates.
  403. 4.  Bug.  The Repeat button on the MMPM box could not be cleared
  404.     once set without closing down the box and reopening it.
  405. 5.  Resizable main control panel (what a bear!!!)
  406. 6.  Fixed windows so that they cannot fall outside of the viewable area
  407. 7.  Fix the file wildcard usage
  408. X.  Added HOTKEYS for the main control panel
  409.  
  410. Version 0.7:  (13 Jul 94)
  411. 1.  Added a REGISTRATION button the to Welcome box
  412. 2.  Completed a little tool (which you will never see) to
  413.     automatically generate the passwords and store them in
  414.     a database.  This illustrates the power of OS/2 because
  415.     I completed a fully functional editor in about 1 day.
  416. 3.  Edit confirmation to the EXIT button
  417. 4.  .WAV files now skip unknown keywords rather than reporting errors
  418. 5.  Added another thread to the MMPM player for loading the
  419.     buffers.
  420. 6.  Added new BITMAPs for the main control panel when MMPM
  421.     is not installed.
  422. 7.  Added a Repeat function to the MMPM playback
  423. 8.  Finished the BALANCE tool
  424. 9.  Fix all tasks so that sounds cannot be operated on while
  425.     another a task is modifying the buffers (i.e. while the
  426.     buffers are loading for the MMPM, the range selections
  427.     cannot be made)
  428. 10. Added a redraw button the the editor
  429. 11. Bug fixed.  When the display box was previously selected, the
  430.     display would receive the mouse movements, but the window would
  431.     not become the active window.
  432. 12. Add the ability to UNDO the last command.  This will double
  433.     the memory requirements and should be in the settings page
  434.     to disable for users who don't want to lose the memory.
  435. 13. The letters "I" and "O" were removed from the passwords to prevent
  436.     confusion over the number 1 and the letter I and the number 0 and
  437.     the letter O.
  438. 14. Fixed window locations so that they can never fall off the
  439.     screen.
  440. 15. Added MINIMIZE button to the dialogs
  441. 16. Bug fixed.  VOC files with a type 0x0a marker were not
  442.     read.  Unknown markers are skipped now.
  443. 17. Bug/oversight.  The Cut button was disabled for ranges
  444.     even if the program was registered.
  445.  
  446. Note 1: For Beta Testing purposes, use the following to enable
  447. all functions
  448.     Name:               "Beta Version Registration"
  449.     Through Version:    0.99
  450.     Password:           "cHLttnr0sqypjc2e"
  451. To enter the password, select REGISTER on the ABOUT or
  452. WELCOME boxes (accessed from the system menu).
  453.  
  454. Version 0.6:  (6 Jul 94)
  455. 1.  Renamed the initialization file from pmsndx03.ini to pmsndx.ini
  456. 2.  Removed QUALITY factor from the SAMPLING RATE tool
  457. 3.  Set up a global object which is shared between all dialogs
  458.     to allow the editor to be the central point of control for
  459.     selecting the range and channels for operations.
  460. 4.  Added checkbox to let the user select if he wants to automatically
  461.     dismiss the save/open dialogs
  462. 5.  Add "Global range selection" checkbox to MMPM Player
  463. 6.  Use "Global channel selection" for MMPM player (add checkbox)
  464. 7.  Add version indicator in the .ini file - (current version)
  465. 8.  Setup timer to MAIN control panel which propagates to the dialogs
  466. 9.  Check the size of the clipboard data and warn if it is
  467.     dissimilar to memory (use smaller of the two after paste)
  468. 10. Check the rate of the clipboard data and warn if it is
  469.     dissimilar to memory
  470. 11. When a version is run for the first time, a Welcome dialog is
  471.     displayed in place of the About box with information about the
  472.     current version.  (The welcome can be redisplayed from the main
  473.     menu.)
  474. 12. Change initial ABOUT box so that it doesn't block the message
  475.     queue
  476. 13. Added info box to indicate whether each tool uses the global objects
  477. 14. Use "Global range selection" in place of local display for tools
  478. 15. Use "Global channel selection" for the tools
  479. 16. Add registration stuff (after 15 minutes of use, guilt!)
  480.     - Disable all formats except .WAV and .AU if registration fails
  481.     - Disable individual channel selection on the editor
  482.     - Disable Range selection for Copy and Cut on the editor
  483.  
  484. Note 1: For Beta Testing purposes, use the following to enable
  485. all functions
  486.     Name:               "Beta Version Registration"
  487.     Through Version:    0.99
  488.     Password:           "cHLttnr0sqypjc2e"
  489.  
  490. Note 2:  The format of the .ini file has not changed.  Rename
  491. pmsndx03.ini to pmsndx.ini and you will not have to recreate
  492. the window locations and settings.
  493.  
  494. Version 0.5:  (8 June 94)
  495. 1.  Finished the Editor
  496. 2.  Added page in notebook for swapping channels
  497. 3.  Fixed an error when writing WAVE files with multiple channels
  498.  
  499. Note:  The big addition of the editor was a lot of work and is
  500. probably not perfect for everyone's needs.  Handling of multiple
  501. channels is awkward at best, but I think that I have made the
  502. most of it.  Opinions for improvement are welcome.  Read the
  503. help page to understand the PASTE operation before using it!
  504. The editor has been written such that it does not use the MMPM
  505. libraries for the sound manipulations in order to allow it to
  506. work on any system.
  507.  
  508. Note 2:  The global channel selection is not implemented across
  509. all the tools yet.  That will be in the next release.
  510.  
  511. Version 0.4a:  (4 June 94)
  512. 1.  Finished the Dupe dialog box in the tools box.
  513. 2.  Fixed an error with processing the Rate effect when
  514.     multiple channels are present.
  515. 3.  Fixed Echo effect to work with multiple channels
  516. 4.  Fixed Fade effect to work with multiple channels
  517.  
  518. Version 0.4*:  (22 May 94)
  519. 1.  Added support for the MAC HCOM format.  Unfortunately the only
  520.     portions of the header that are implemented are the ones that
  521.     SOX implements because I could not find examples of the HCOM
  522.     format and had to create a sample file from a .WAV file using
  523.     SOX.
  524. 2.  Added support for the IRCAM format.  Again, like the HCOM
  525.     format, I could not find samples in this format and had to
  526.     use SOX to create samples for testing.  As a result, only
  527.     the header fields supported by SOX are enabled.
  528. 3.  Added support for SampleVision (.smp) format.  WARNING:  This
  529.     is a wierd format in which the RATE is stored at the end
  530.     of the file.  You may find that when loading this type of
  531.     file no error is produced but an absurd rate may be displayed
  532.     in the Info tool page.  (Some reasons...SOX10 for OS/2 replaces
  533.     every CR return (char 13) with a CRLF.  I think that the output
  534.     file was not set to RAW so the file functions were fixing the
  535.     data up for DOS.  By the way, you can fix this up by changing
  536.     the playback speed (not the rate!!!) to something logical.)
  537. 4.  Reorganized the toolbox (again) and added place holders for
  538.     fading and balancing in a sample.  This will be added later.
  539. 5.  Added the user interface for the editor.  It is non-functional,
  540.     but is intended to get feedback on the functions that it will
  541.     be provided.  If you don't like it, now is the time to change
  542.     it!
  543. 6.  *** BUG:  Fixed bug in display routines for graphs when an absolute
  544.     value was entered into the start and end fields for the reverse
  545.     effect.
  546. 7.  Added fading to the tool box under the major header of VOLUME.
  547.     Samples can be faded in or out and at different rates.
  548.  
  549. *   Note:  With this version, all of the functionality of SOX has
  550.     been completed.  From here on out, we are breaking new ground.
  551. **  Note:  Space is reserved for the Dupe, Fade, and Balance effects,
  552.     but they have not been implemented and the DOIT button is
  553.     never enabled.
  554. *** The size of the executable is about 300k right now.  The good
  555.     news is that the only major additions will be the code for
  556.     the clipboard stuff.  The program currently has about 18000
  557.     lines of C code.  I could change over to DLLs to make the
  558.     actual executable smaller, but the way DLLs work with OS/2,
  559.     there is no memory savings.  If you hate 300k for a program
  560.     like this, then go back to SOX.
  561.  
  562. Version 0.3e:  (27 March 94)
  563. NOTE:  Since the size of the Open dialog box has changed, PMsndX
  564.     will not use the window positions or settings from the .ini
  565.     file.  This is to prevent the Open dialog box from being
  566.     positioned off the screen.
  567.  
  568. 1.  Multithreaded the command line playback functions.  Previous
  569.     versions shared the message queue through threads for playback
  570.     when the control panel was used, but when a sound was played
  571.     from the command line, all message processing would stop till
  572.     the file had been played.
  573. 2.  Fixed the .WAV read/write routines to handle the LIST fields
  574.     correctly.  Previous versions could not deal with the LIST
  575.     field and returned a error indicating that the file was in
  576.     a bad style.
  577. 3.  Changed the .VOC to be able to store the ASCII text string
  578.     in the info field.
  579. 4.  Added support for .IFF formats (Amiga).  This format has a
  580.     couple of fields that need mention here.  If you read a file
  581.     in, the ANNO field is discarded and the NAME field is used
  582.     for the Comment data retained in the files.  If a file is
  583.     written to disk, PMsndX arrogantly writes the "PMsndX ..."
  584.     into the ANNO field (... is replaced by the version number).
  585. 5.  The Version number has been changed to reflect the alpha version
  586.     of the program.  In the past changes to the version number
  587.     changed the name of the profile and resulted in loss of the
  588.     window positions and settings from previous versions.  This has
  589.     been changed such that the window positions and settings remain
  590.     active unless a major change is made in the profile information.
  591. 6.  Added user overrides for the file types when opening files.
  592.     When a file is opened, if the user specifies a specific filetype
  593.     (other than Auto), the program will try to open the file in
  594.     that format.  In the event that the filetype is not the
  595.     type specified, the PMsndX will attempt to determine the
  596.     file type as if the user had selected "Auto".
  597. 7.  When the file type is changed through the Tools notebook, the
  598.     output type is then specified and selected in the file type
  599.     area of the SAVE dialog box.
  600. 8.  The default format for saving a file is the same as the input
  601.     format.
  602. 9.  A field called "AUTO" has been added to the filetypes.  When
  603.     this button is selected, the file will be saved based on the
  604.     filename alone.
  605. 10. If the filename field is changed, the "AUTO" button will
  606.     automatically be selected.  This is because the file type
  607.     specified in the buttons will override the extension.  As
  608.     a result, if the user changes the filename and assumes that
  609.     the file would be saved based on the filename extension,
  610.     the file could be saved in a different format than the
  611.     extension indicates.
  612. 11. The filename used to load a sample into memory is automatically
  613.     used as the default filename when saving a file.  The path
  614.     for saving the file remains the last path used for saving
  615.     the file.
  616. 12. Added the .sb (Signed Byte) format.  This is a headerless
  617.     format.  If the user selects to load this format, the program
  618.     must ask the user for the sampling rate before the file
  619.     can be loaded.  Each byte of the file is treated as an 8
  620.     bit signed sample.
  621. 13. Added the .sw (Signed Word) format.  This is a headerless
  622.     format and the program will request a sampling rate when
  623.     the user loads this file format.  Each word (2 bytes) is
  624.     treated as a signed word in little endian order.
  625. 14. Added the .ub (Unsigned byte) format.  This is a headerless
  626.     format and the program will request a sampling rate when
  627.     the user loads a file of this format.  Each byte is treated
  628.     as a unsigned byte.
  629. 15. Added the .uw (Unsigned word) format.  This is a headerless
  630.     format and the program will request a sampling rate when
  631.     the user loads a file of this format.  Each word (2 bytes)
  632.     is treated as a unsigned word in little endian order.
  633. 16. Added the .ul (Ulaw) format.  This is a headerless format
  634.     and the program will request a sampling rate when the user
  635.     loads a file of this format.  Each byte is treated as a
  636.     ULAW encoded sample.  This format is the same format used
  637.     for .AU files.
  638. 17. The file Open dialog box does not close when the operation is
  639.     completed.
  640. 18. Multithreaded the file open operations.  When a file is being
  641.     read, the user may press the Abort button on the file open
  642.     dialog box to stop the read process.  If the program exits
  643.     before a file read thread has completed, the read thread is
  644.     terminated.
  645. 19. Multithreaded the file save operations.  There is no means
  646.     provided to abort a save operation.  If the program exits when
  647.     the file is saving, the program will wait till the save operation
  648.     has completed before exiting.
  649. 20. Added support for the Amiga/SGI .aif format.  Documentation
  650.     for this format was hard to find.  The only chunk formats
  651.     I could find were for COMM, and SSND.
  652.  
  653. Version 0.3d:
  654. 1.  Added use of the second mouse button (usually the right
  655.     mouse button) for the reverse effect and removed the
  656.     dynamic sorting of the start and end so that the numbers
  657.     don't jump back and forth when the user is entering
  658.     the endpoints.
  659. 2.  Added support for .VOC file formats.
  660.     Note:  I don't know what the hell SOX is doing, but it does
  661.            not seem to produce a useable file.
  662.     I always add an Extended data block to the file.  I don't
  663.       know if this will cause problems, but the extended part
  664.       contains the number of channels.
  665.     I don't know what to do with Repeat/End Repeat information
  666.       so I am currently ignoring it.  Any ideas?
  667.     I currently dump (on the floor) any ASCII text.  Anyone want
  668.       me to keep the stuff in the info field?
  669.     I currently only load 8 bit data.  I cannot deal with packed
  670.       data right now.  It is 1:00am and I am tired.
  671.     Some programs seem to expect the first block to be the
  672.       DATA block so I write this first always.
  673.  
  674. Version 0.3c:
  675. 1.  Added Speed Effect
  676. 2.  Reorganized the Tools notebook.  There were too many
  677.     tools to display the tabs on the notebook so major and
  678.     minor pages were created to group the tools.
  679. 3.  Modified the MMPM support to use a separate region of
  680.     memory than the samples are stored in.  Previously, the
  681.     memory for storing the playlist was taken out of the
  682.     pool for storing the samples for the effects.  As a
  683.     result, if you started the MMPM box an performed a
  684.     effect that took up more memory, a hole would be left
  685.     such that another block of memory could not be
  686.     allocated.  This method prevents creating the holes.
  687. 4.  Added Reverse Effect.
  688.  
  689. Version 0.3b:
  690. 1.  Fixed a big bug in the Bandpass filter.  If a sample
  691.     had multiple channels, it would only bandpass on the
  692.     first channel.
  693. 2.  Fixed a big bug in the Lowpass filter.  If a sample
  694.     had multiple channels, it would only lowpass on the
  695.     first channel.
  696. 3.  Added the little clock pointer to indicate how much
  697.     work has been completed.
  698. 4.  Removed the requirement for the audio device to be a
  699.     form of WaveAudio??.  Any string will work as long as
  700.     the device really exists.
  701. 5.  Multi-threaded all of the effects so that the program
  702.     is not a system hog.  The file read/write functions
  703.     are not multi-threaded.  Should they be?
  704.  
  705. Version 0.3a:
  706. 1.  Fixed the Play button so that it is animated when the
  707.     sample is played as it is loaded.  (What is the longest
  708.     record for staring at a code before you realize that it
  709.     is so late that you have been staring at the bug all
  710.     night and just did not recognize it?...What a dumb error
  711.     on my part!!!)
  712. 2.  Fixed the dynamic linking so that DosLoadModule is used
  713.     rather than linking with the dynamic libraries.  Version
  714.     0.3 would refuse to run on machines without MMPM
  715.     installed because the libraries were loaded even if the
  716.     MMPM support was not enabled.
  717. 3.  Changed to using SW.DLL for the buttons of the MMPM
  718.     dialog box.  This guarantees that the program will use
  719.     the latest formats for the buttons.
  720. 4.  Added command line playing.  I the PLAY_ON_LOAD option
  721.     is selected, any filenames which appear on the command
  722.     line will be played.  If a file is not found, the
  723.     program will signal an error and continue to the next
  724.     command line file.  If EXIT_AFTER_PLAY is not selected,
  725.     the last file that was successfully loaded will be
  726.     the current file in memory.
  727. 5.  Enabled the EXIT_AFTER_PLAY feature and modified the
  728.     behaviour such that the MMPM dialog is not displayed
  729.     during the playback.
  730.  
  731. Version 0.3:
  732. 1.  Removed the RECORD button (now just a blank button until
  733.     I can think of something)
  734. 2.  Changed PLAY button to MMPM and added basic play
  735.     capabilities (i.e. Play, Stop, Rewind, Pause).
  736. 3.  Updated Settings dialog to reflect options for the MMPM
  737.     stuff.
  738.  
  739. Version 0.2: (20 March 94)
  740. 1.  Fixed error with memory settings.  In version 0.1 if you
  741.     opened the Settings box and then applied it by pressing
  742.     the DOIT button it sould clear the data samples even if
  743.     the memory configuration had not changed.
  744. 2.  Fixed bug in version 0 in which the data was cleared
  745.     when the memory configuration was changed, but the
  746.     sample header was not cleared.  This led to th dialogs
  747.     trying to access data that had been released causing a
  748.     protection violation.
  749. 3.  Added the Bandpass notebook page.  This is probably one
  750.     of the most complex user interfaces in the notebook.
  751. 4.  Added the Echo effect.  This is the most complex
  752.     programming challenge for a useable user interface.
  753.     (Note, the echo only works for single channel samples).
  754. 5.  Fixed bug.  In version 0.1, the lowpass function did not
  755.     take into account the number of channels.  This has a
  756.     significant impact on the FFT operation.  This is fixed
  757.     in 0.2.
  758. 6.  Fixed bug.  In version 0.1, the Vibro effect did not
  759.     take into account multiple channels in a sample.  As a
  760.     result, the vibro was not continuous on individual
  761.     channels.
  762.  
  763. Version 0.1:  (13 March 94)
  764. 1.  Added Channel Averaging (0.1a)
  765. 2.  Added Vibro effect
  766. 3.  The .ini file are automatically located in the same directory
  767.     as the executable.
  768. 4.  Individual tool pages no longer have separate HELP buttons
  769. 5.  A HELP button has been added to the tool box for all pages.
  770.     When pressed, the help page for the page shown in the tools
  771.     dialog box will be displayed.
  772. 6.  A DISMISS button has been added to the tools dialog box for
  773.     a more consistent approach to dismissing.  The user can still
  774.     depress the tools button on the main control panel to dismiss
  775.     any tool dialog.
  776. 7.  Rearranged the buttons on the main control panel and added
  777.     two new buttons for Playing and Recording samples (not implemented
  778.     in this release...just placeholders)
  779. 8.  Changed the memory storage requirements so that data takes
  780.     half as much memory.  Each sample is stored as a signed SHORT
  781.     regardless of the sound type.
  782. 9.  Corrected major memory bug which resulted in a memory leak.
  783. 10. The echo effect presents an interesting challenge to the
  784.     user interface.  How do you provide the user with an
  785.     intuitive method to set the echo locations and the
  786.     strength of the echo from a dialog box?  My first
  787.     attempt was to try to display the waveform in a window
  788.     and then to let the user set the echo points, but the
  789.     problem of setting the echo strength is still difficult.
  790.     This operation may have to wait for another revision
  791.     after I have had some time to "sleep" on it.  The effect
  792.     itself is very simple, but the interface is much more
  793.     difficult.
  794.  
  795. 0.1a - SOX can averages 4 channels to 1 by putting all four
  796.        channels into 1.  4 channels to 2 is done by
  797.        averaging the left channels and the right channels
  798.        together.  PMsndX allows the user to select any
  799.        combination of the source channels.
  800.  
  801. Version 0.0 (initial release):
  802. 1.  6 buttons and associated dialog boxes created
  803. 1.  Ability to load and save .au files
  804. 2.  Ability to load and save .wav files
  805. 3.  Tool for changing the sampling rate (0.0a)
  806. 4.  Display of information about the current sample
  807.  
  808. 0.0a - SOX appears to use linear approximation to create the
  809.        new sample.  PMsndX provides for quality which allows the
  810.        approximation to be adjusted.
  811.  
  812.  
  813.