shithub: choc

Download patch

ref: 8bbfd5b68a289ddf933f78d369606f1f22dd91c6
parent: 3d8f10ef325d2d03f1f9535d9f201eca3d56d37f
author: James Haley <[email protected]>
date: Wed Sep 22 04:07:35 EDT 2010

Rewrote P_GiveItemToPlayer to exactly match binary, particularly with
treatment of SPR_TOKN objects, and playing proper sounds for different
item types. Fixed most S_StartSound calls in the menu engine. Removed
call to S_StopSound in S_StartSound, as Strife doesn't do it. Added call
to P_DialogDoChoice(-1) in M_Responder when menuindialog is asserted and
the menu exit key is pressed.

Subversion-branch: /branches/strife-branch
Subversion-revision: 2130

--- a/src/strife/m_menu.c
+++ b/src/strife/m_menu.c
@@ -64,6 +64,7 @@
 #include "sounds.h"
 
 #include "m_menu.h"
+#include "p_dialog.h"
 
 
 extern void M_QuitStrife(int);
@@ -691,8 +692,8 @@
 {
     if (key == key_menu_confirm)
     {
-	M_DoSave(quickSaveSlot);
-	S_StartSound(NULL,sfx_swish);   // villsa [STRIFE] TODO - fix sounds
+        M_DoSave(quickSaveSlot);
+        S_StartSound(NULL, sfx_mtalht); // [STRIFE] sound
     }
 }
 
@@ -700,7 +701,7 @@
 {
     if (!usergame)
     {
-	S_StartSound(NULL,sfx_oof);
+	S_StartSound(NULL, sfx_oof);
 	return;
     }
 
@@ -728,8 +729,8 @@
 {
     if (key == key_menu_confirm)
     {
-	M_LoadSelect(quickSaveSlot);
-	S_StartSound(NULL,sfx_swish);   // villsa [STRIFE] TODO - fix sounds
+        M_LoadSelect(quickSaveSlot);
+        S_StartSound(NULL, sfx_mtalht); // [STRIFE] sound
     }
 }
 
@@ -1685,7 +1686,7 @@
             messageRoutine(key);
 
         menuactive = false;
-        S_StartSound(NULL,sfx_swish);   // villsa [STRIFE] TODO - fix sounds
+        S_StartSound(NULL, sfx_mtalht);   // [STRIFE] sound
         return true;
     }
 
@@ -1703,7 +1704,7 @@
             if (automapactive || chat_on)
                 return false;
             M_SizeDisplay(0);
-            S_StartSound(NULL,sfx_stnmov);
+            S_StartSound(NULL, sfx_stnmov);
             return true;
         }
         else if (key == key_menu_incscreen) // Screen size up
@@ -1711,7 +1712,7 @@
             if (automapactive || chat_on)
                 return false;
             M_SizeDisplay(1);
-            S_StartSound(NULL,sfx_stnmov);
+            S_StartSound(NULL, sfx_stnmov);
             return true;
         }
         else if (key == key_menu_help)     // Help key
@@ -1721,13 +1722,13 @@
             currentMenu = &ReadDef1; 
 
             itemOn = 0;
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             return true;
         }
         else if (key == key_menu_save)     // Save
         {
             M_StartControlPanel();
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_SaveGame(0);
             return true;
         }
@@ -1734,7 +1735,7 @@
         else if (key == key_menu_load)     // Load
         {
             M_StartControlPanel();
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_LoadGame(0);
             return true;
         }
@@ -1743,7 +1744,7 @@
             M_StartControlPanel ();
             currentMenu = &SoundDef;
             itemOn = sfx_vol;
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             return true;
         }
         /*
@@ -1756,13 +1757,13 @@
         */
         else if (key == key_menu_qsave)    // Quicksave
         {
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_QuickSave();
             return true;
         }
         else if (key == key_menu_endgame)  // End game
         {
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_EndGame(0);
             return true;
         }
@@ -1769,18 +1770,18 @@
         else if (key == key_menu_messages) // Toggle messages
         {
             M_ChangeMessages(0);
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             return true;
         }
         else if (key == key_menu_qload)    // Quickload
         {
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_QuickLoad();
             return true;
         }
         else if (key == key_menu_quit)     // Quit DOOM
         {
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             M_QuitStrife(0);
             return true;
         }
@@ -1801,7 +1802,7 @@
         if (key == key_menu_activate)
         {
             M_StartControlPanel ();
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
             return true;
         }
         return false;
@@ -1819,7 +1820,7 @@
             if (itemOn+1 > currentMenu->numitems-1)
                 itemOn = 0;
             else itemOn++;
-            S_StartSound(NULL,sfx_pstop);
+            S_StartSound(NULL, sfx_pstop);
         } while(currentMenu->menuitems[itemOn].status==-1);
 
         return true;
@@ -1833,7 +1834,7 @@
             if (!itemOn)
                 itemOn = currentMenu->numitems-1;
             else itemOn--;
-            S_StartSound(NULL,sfx_pstop);
+            S_StartSound(NULL, sfx_pstop);
         } while(currentMenu->menuitems[itemOn].status==-1);
 
         return true;
@@ -1845,7 +1846,7 @@
         if (currentMenu->menuitems[itemOn].routine &&
             currentMenu->menuitems[itemOn].status == 2)
         {
-            S_StartSound(NULL,sfx_stnmov);
+            S_StartSound(NULL, sfx_stnmov);
             currentMenu->menuitems[itemOn].routine(0);
         }
         return true;
@@ -1857,7 +1858,7 @@
         if (currentMenu->menuitems[itemOn].routine &&
             currentMenu->menuitems[itemOn].status == 2)
         {
-            S_StartSound(NULL,sfx_stnmov);
+            S_StartSound(NULL, sfx_stnmov);
             currentMenu->menuitems[itemOn].routine(1);
         }
         return true;
@@ -1873,12 +1874,12 @@
             if (currentMenu->menuitems[itemOn].status == 2)
             {
                 currentMenu->menuitems[itemOn].routine(1);      // right arrow
-                S_StartSound(NULL,sfx_stnmov);
+                S_StartSound(NULL, sfx_stnmov);
             }
             else
             {
                 currentMenu->menuitems[itemOn].routine(itemOn);
-                S_StartSound(NULL,sfx_swish);   // villsa [STRIFE] TODO - fix sounds
+                //S_StartSound(NULL, sfx_swish); [STRIFE] No sound is played here.
             }
         }
         return true;
@@ -1886,10 +1887,12 @@
     else if (key == key_menu_activate)
     {
         // Deactivate menu
+        if(menuindialog) // [STRIFE] - Get out of dialog engine semi-gracefully
+            P_DialogDoChoice(-1);
 
         currentMenu->lastOn = itemOn;
         M_ClearMenus (0);
-        S_StartSound(NULL,sfx_swish);   // villsa [STRIFE] TODO - fix sounds
+        S_StartSound(NULL, sfx_mtalht);   // villsa [STRIFE] TODO - fix sounds
         return true;
     }
     else if (key == key_menu_back)
@@ -1901,7 +1904,7 @@
         {
             currentMenu = currentMenu->prevMenu;
             itemOn = currentMenu->lastOn;
-            S_StartSound(NULL,sfx_swtchn);
+            S_StartSound(NULL, sfx_swtchn);
         }
         return true;
     }
@@ -1914,7 +1917,7 @@
             if (currentMenu->menuitems[i].alphaKey == ch)
             {
                 itemOn = i;
-                S_StartSound(NULL,sfx_pstop);
+                S_StartSound(NULL, sfx_pstop);
                 return true;
             }
         }
@@ -1924,7 +1927,7 @@
             if (currentMenu->menuitems[i].alphaKey == ch)
             {
                 itemOn = i;
-                S_StartSound(NULL,sfx_pstop);
+                S_StartSound(NULL, sfx_pstop);
                 return true;
             }
         }
--- a/src/strife/p_dialog.c
+++ b/src/strife/p_dialog.c
@@ -702,6 +702,7 @@
     int i = 0;
     line_t junk;
     boolean ok = true;
+    int sound = sfx_itemup; // haleyjd 09/21/10: different sounds for items
 
     // set quest if mf_givequest flag is set
     if(mobjinfo[type].flags & MF_GIVEQUEST)
@@ -719,264 +720,327 @@
     {
         if(mobjinfo[type].name)
         {
-            strncpy(pickupstring, mobjinfo[type].name, 39);
+            strncpy(pickupstring, DEH_String(mobjinfo[type].name), 39);
             player->message = pickupstring;
         }
         player->questflags |= 1 << (type - MT_TOKEN_QUEST1);
+
+        if(player == &players[consoleplayer])
+            S_StartSound(NULL, sound);
+        return true;
     }
-    // check for other types
-    else switch(type)
+
+    // haleyjd 09/22/10: Refactored to give sprites higher priority than
+    // mobjtypes and to implement missing logic.
+    switch(sprnum)
     {
-    // severed hand
-    case MT_KEY_HAND:
-        P_GiveCard(player, key_SeveredHand);
+    case SPR_HELT: // STRIFE-TODO: verify - I believe this is related to a cheat
+        P_GiveInventoryItem(player, SPR_HELT, MT_TOKEN_TOUGHNESS);
+        P_GiveInventoryItem(player, SPR_GUNT, MT_TOKEN_ACCURACY);
+
+        // [STRIFE] Bizarre...
+        for(i = 0; i < 5 * player->accuracy + 300; i++)
+            P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
         break;
 
-    // 300 gold
-    case MT_MONY_300:
-        for(i = 0; i < 300; i++)
+    case SPR_ARM1: // Armor 1
+        if(!P_GiveArmor(player, -2))
+            P_GiveInventoryItem(player, sprnum, type);
+        break;
+
+    case SPR_ARM2: // Armor 2
+        if(!P_GiveArmor(player, -1))
+            P_GiveInventoryItem(player, sprnum, type);
+        break;
+
+    case SPR_COIN: // 1 Gold
+        P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        break;
+
+    case SPR_CRED: // 10 Gold
+        for(i = 0; i < 10; i++)
             P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
         break;
 
-    // ammo refill (at training)
-    case MT_TOKEN_AMMO:
-        if(player->ammo[am_bullets] >= 50)
-            return false;
+    case SPR_SACK: // 25 gold
+        for(i = 0; i < 25; i++)
+            P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        break;
 
-        player->ammo[am_bullets] = 50;
+    case SPR_CHST: // 50 gold
+        for(i = 0; i < 50; i++)
+            P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+
+    case SPR_BBOX: // Box of Bullets
+        if(!P_GiveAmmo(player, am_bullets, 5))
+            return false;
         break;
 
-    // health refill (at front HQ)
-    case MT_TOKEN_HEALTH:
-        if(!P_GiveBody(player, healthamounts[gameskill]))
+    case SPR_BLIT: // Bullet Clip
+        if(!P_GiveAmmo(player, am_bullets, 1))
             return false;
         break;
 
-    // alarm
-    case MT_TOKEN_ALARM:
-        P_NoiseAlert(player->mo, player->mo);
-        A_AlertSpectreC(dialogtalker);
+    case SPR_PMAP: // Map powerup
+        if(!P_GivePower(player, pw_allmap))
+            return false;
+        sound = sfx_yeah; // bluh-doop!
         break;
 
-    // door special 1
-    case MT_TOKEN_DOOR1:
-        junk.tag = 222;
-        EV_DoDoor(&junk, open);
+    case SPR_COMM: // Communicator
+        if(!P_GivePower(player, pw_communicator))
+            return false;
+        sound = sfx_yeah; // bluh-doop!
         break;
 
-    // door special 2
-    case MT_TOKEN_PRISON_PASS:
-        junk.tag = 223;
-        EV_DoDoor(&junk, open);
-        if(gamemap == 2)
-            P_GiveInventoryItem(player, sprnum, type);
+    case SPR_MSSL: // Mini-missile
+        if(!P_GiveAmmo(player, am_missiles, 1))
+            return false;
         break;
 
-    // door special 3
-    case MT_TOKEN_SHOPCLOSE:
-        junk.tag = 222;
-        EV_DoDoor(&junk, close);
+    case SPR_ROKT: // Crate of missiles
+        if(!P_GiveAmmo(player, am_missiles, 5))
+            return false;
         break;
 
-    // door special 4
-    case MT_TOKEN_DOOR3:
-        junk.tag = 224;
-        EV_DoDoor(&junk, close);
+    case SPR_BRY1: // Battery cell
+        if(!P_GiveAmmo(player, am_cell, 1))
+            return false;
         break;
 
-    // stamina upgrade
-    case MT_TOKEN_STAMINA:
-        if(player->stamina >= 100)
+    case SPR_CPAC: // Cell pack
+        if(!P_GiveAmmo(player, am_cell, 5))
             return false;
+        break;
 
-        player->stamina += 10;
-        P_GiveBody(player, 200);
+    case SPR_PQRL: // Poison bolts
+        if(!P_GiveAmmo(player, am_poisonbolts, 5))
+            return false;
         break;
 
-    // accuracy upgrade
-    case MT_TOKEN_NEW_ACCURACY:
-        if(player->accuracy >= 100)
+    case SPR_XQRL: // Electric bolts
+        if(!P_GiveAmmo(player, am_elecbolts, 5))
             return false;
+        break;
 
-        player->accuracy += 10;
+    case SPR_GRN1: // HE Grenades
+        if(!P_GiveAmmo(player, am_hegrenades, 1))
+            return false;
         break;
 
-    // slideshow
-    case MT_SLIDESHOW:
-        gameaction = ga_victory;
-        if(gamemap == 10)
-            P_GiveItemToPlayer(player, SPR_TOKN, MT_TOKEN_QUEST17);
+    case SPR_GRN2: // WP Grenades
+        if(!P_GiveAmmo(player, am_wpgrenades, 1))
+            return false;
         break;
 
-    default:
-        // check for sprites if no specific type is found
-        switch(sprnum)
+    case SPR_BKPK: // Backpack (aka Ammo Satchel)
+        if(!player->backpack)
         {
-            // bullets
-        case SPR_BLIT:
-            ok = P_GiveAmmo(player, am_bullets, 1);
-            break;
+            for(i = 0; i < NUMAMMO; i++)
+                player->maxammo[i] *= 2;
 
-            // box of bullets
-        case SPR_BBOX:
-            ok = P_GiveAmmo(player, am_bullets, 5);
-            break;
+            player->backpack = true;
+        }
+        for(i = 0; i < NUMAMMO; i++)
+            P_GiveAmmo(player, i, 1);
+        break;
 
-            // missile
-        case SPR_MSSL:
-            ok = P_GiveAmmo(player, am_missiles, 1);
-            break;
+    case SPR_RIFL: // Assault Rifle
+        if(player->weaponowned[wp_rifle])
+            return false;
 
-            // box of missiles
-        case SPR_ROKT:
-            ok = P_GiveAmmo(player, am_missiles, 5);
-            break;
+        if(!P_GiveWeapon(player, wp_rifle, false))
+            return false;
+        
+        sound = sfx_wpnup; // SHK-CHK!
+        break;
 
-            // battery
-        case SPR_BRY1:
-            ok = P_GiveAmmo(player, am_cell, 1);
-            break;
+    case SPR_FLAM: // Flamethrower
+        if(player->weaponowned[wp_flame])
+            return false;
 
-            // cell pack
-        case SPR_CPAC:
-            ok = P_GiveAmmo(player, am_cell, 5);
-            break;
+        if(!P_GiveWeapon(player, wp_flame, false))
+            return false;
 
-            // poison bolts
-        case SPR_PQRL:
-            ok = P_GiveAmmo(player, am_poisonbolts, 5);
-            break;
+        sound = sfx_wpnup; // SHK-CHK!
+        break;
 
-            // electric bolts
-        case SPR_XQRL:
-            ok = P_GiveAmmo(player, am_elecbolts, 5);
-            break;
+    case SPR_MMSL: // Mini-missile Launcher
+        if(player->weaponowned[wp_missile])
+            return false;
 
-            // he grenades
-        case SPR_GRN1:
-            ok = P_GiveAmmo(player, am_hegrenades, 1);
-            break;
+        if(!P_GiveWeapon(player, wp_missile, false))
+            return false;
 
-            // wp grenades
-        case SPR_GRN2:
-            ok = P_GiveAmmo(player, am_wpgrenades, 1);
-            break;
+        sound = sfx_wpnup; // SHK-CHK!
+        break;
 
-            // backpack
-        case SPR_BKPK:
-            if(!player->backpack)
-            {
-                for(i = 0; i < NUMAMMO; i++)
-                    player->maxammo[i] *= 2;
+    case SPR_TRPD: // Mauler
+        if(player->weaponowned[wp_mauler])
+            return false;
 
-                player->backpack = true;
-            }
-            for(i = 0; i < NUMAMMO; i++)
-                P_GiveAmmo(player, i, 1);
-            break;
+        if(!P_GiveWeapon(player, wp_mauler, false))
+            return false;
 
-            // coin
-        case SPR_COIN:
-            P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        sound = sfx_wpnup; // SHK-CHK!
+        break;
+
+    case SPR_CBOW: // Here's a crossbow. Just aim straight, and *SPLAT!*
+        if(player->weaponowned[wp_elecbow])
+            return false;
+
+        if(!P_GiveWeapon(player, wp_elecbow, false))
+            return false;
+
+        sound = sfx_wpnup; // SHK-CHK!
+        break;
+
+    case SPR_TOKN: // Miscellaneous items - These are determined by thingtype.
+        switch(type)
+        {
+        case MT_KEY_HAND: // Severed hand
+            P_GiveCard(player, key_SeveredHand);
             break;
 
-            // gold 10
-        case SPR_CRED:
-            for(i = 0; i < 10; i++)
+        case MT_MONY_300: // 300 Gold (this is the only way to get it, in fact)
+            for(i = 0; i < 300; i++)
                 P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
             break;
 
-            // gold 25
-        case SPR_SACK:
-            for(i = 0; i < 25; i++)
-                P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        case MT_TOKEN_AMMO: // Ammo token - you get this from the Weapons Trainer
+            if(player->ammo[am_bullets] >= 50)
+                return false;
+
+            player->ammo[am_bullets] = 50;
             break;
 
-            // gold 50
-        case SPR_CHST:
-            for(i = 0; i < 50; i++)
-                P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        case MT_TOKEN_HEALTH: // Health token - from the Front's doctor
+            if(!P_GiveBody(player, healthamounts[gameskill]))
+                return false;
             break;
 
-            // ???
-        case SPR_HELT:
-            P_GiveInventoryItem(player, SPR_HELT, MT_TOKEN_TOUGHNESS);
-            P_GiveInventoryItem(player, SPR_GUNT, MT_TOKEN_ACCURACY);
-
-            // [STRIFE] TODO - verify
-            for(i = 0; i < 5 * player->numinventory + 300; i++)
-                P_GiveInventoryItem(player, SPR_COIN, MT_MONY_1);
+        case MT_TOKEN_ALARM: // Alarm token - particularly from the Oracle.
+            P_NoiseAlert(player->mo, player->mo);
+            A_AlertSpectreC(dialogtalker); // BUG: assumes in a dialog o_O
             break;
 
-            // metal armor
-        case SPR_ARM1:
-            if(!P_GiveArmor(player, -2))
-                P_GiveInventoryItem(player, sprnum, type);
+        case MT_TOKEN_DOOR1: // Door special 1
+            junk.tag = 222;
+            EV_DoDoor(&junk, open);
             break;
 
-            // leather armor
-        case SPR_ARM2:
-            if(!P_GiveArmor(player, -1))
+        case MT_TOKEN_PRISON_PASS: // Door special 1 - Prison pass
+            junk.tag = 223;
+            EV_DoDoor(&junk, open);
+            if(gamemap == 2) // If on Tarnhill, give Prison pass object
                 P_GiveInventoryItem(player, sprnum, type);
             break;
 
-            // communicator
-        case SPR_COMM:
-            if(!P_GivePower(player, pw_communicator))
-                return false;
+        case MT_TOKEN_SHOPCLOSE: // Door special 3 - "Shop close" - unused?
+            junk.tag = 222;
+            EV_DoDoor(&junk, close);
             break;
 
-            // map
-        case SPR_PMAP:
-            if(!P_GivePower(player, pw_allmap))
-                return false;
+        case MT_TOKEN_DOOR3: // Door special 4 (or 3? :P ) 
+            junk.tag = 224;
+            EV_DoDoor(&junk, close);
             break;
 
-            // rifle
-        case SPR_RIFL:
-            if(player->weaponowned[wp_rifle])
+        case MT_TOKEN_STAMINA: // Stamina upgrade
+            if(player->stamina >= 100)
                 return false;
 
-            if(!P_GiveWeapon(player, wp_rifle, false))
-                return false;
+            player->stamina += 10;
+            P_GiveBody(player, 200); // full healing
             break;
 
-            // flame thrower
-        case SPR_FLAM:
-            if(player->weaponowned[wp_flame])
+        case MT_TOKEN_NEW_ACCURACY: // Accuracy upgrade
+            if(player->accuracy >= 100)
                 return false;
 
-            if(!P_GiveWeapon(player, wp_flame, false))
-                return false;
+            player->accuracy += 10;
             break;
 
-            // missile launcher
-        case SPR_MMSL:
-            if(player->weaponowned[wp_missile])
-                return false;
-
-            if(!P_GiveWeapon(player, wp_missile, false))
-                return false;
+        case MT_SLIDESHOW: // Slideshow (start a finale)
+            gameaction = ga_victory;
+            if(gamemap == 10)
+                P_GiveItemToPlayer(player, SPR_TOKN, MT_TOKEN_QUEST17);
             break;
+        
+        default: // The default is to just give it as an inventory item.
+            P_GiveInventoryItem(player, sprnum, type);
+            break;
+        }
+        break;
 
-            // mauler
-        case SPR_TRPD:
-            if(player->weaponowned[wp_mauler])
-                return false;
+    default: // The ultimate default: Give it as an inventory item.
+        if(!P_GiveInventoryItem(player, sprnum, type))
+            return false;
+        break;
+    }
 
-            if(!P_GiveWeapon(player, wp_mauler, false))
-                return false;
-            break;
+    // Play sound.
+    if(player == &players[consoleplayer])
+        S_StartSound(NULL, sound);
 
-            // crossbow
-        case SPR_CBOW:
-            if(player->weaponowned[wp_elecbow])
-                return false;
+    return true;
 
-            if(!P_GiveWeapon(player, wp_elecbow, false))
-                return false;
-            break;
+    // check for other types
+    /*
+    switch(type)
+    {
+    // severed hand
 
+    // 300 gold
+
+    // ammo refill (at training)
+
+    // health refill (at front HQ)
+
+    // alarm
+
+    // door special 1
+
+    // door special 2
+
+    // door special 3
+
+    // door special 4
+
+    // stamina upgrade
+
+    // slideshow
+
+    default:
+        // check for sprites if no specific type is found
+        switch(sprnum)
+        {
+            // bullets
+
+            // box of bullets
+
+            // missile
+
+            // box of missiles
+
+            // battery
+
+
+
+            // backpack
+
+            // communicator
+
+
+            // rifle
+
+            // flame thrower
+
+            // missile launcher
+
+            // mauler
+
+
             // misc item
         default:
             if(!P_GiveInventoryItem(player, sprnum, type))
@@ -988,6 +1052,7 @@
 
     S_StartSound(player->mo, sfx_itemup);
     return true;
+    */
 }
 
 //
--- a/src/strife/p_inter.c
+++ b/src/strife/p_inter.c
@@ -418,7 +418,7 @@
     if(delta > toucher->height || delta < -8*FRACUNIT)
         return; // out of reach
 
-    sound = sfx_itemup;	
+    sound = sfx_itemup;
     player = toucher->player;
 
     // Dead thing touching.
--- a/src/strife/s_sound.c
+++ b/src/strife/s_sound.c
@@ -480,7 +480,7 @@
     }
 
     // kill old sound
-    S_StopSound(origin);
+    //S_StopSound(origin);
 
     // try to find a channel
     cnum = S_GetChannel(origin, sfx, false); // haleyjd: not a voice.