Compare commits
	
		
			No commits in common. "9edc7863118aa110e15a380f3b3f43a04fa42073" and "f1c8b09b94b4de8d6fb622a44f134ca72e45d7be" have entirely different histories.
		
	
	
		
			9edc786311
			...
			f1c8b09b94
		
	
		
							
								
								
									
										164
									
								
								source/items.qc
									
									
									
									
									
								
							
							
						
						
									
										164
									
								
								source/items.qc
									
									
									
									
									
								
							|  | @ -1,32 +1,4 @@ | ||||||
| const string WEPNAME_AXE = "Axe"; |  | ||||||
| const string WEPNAME_SHOTGUN = "Shotgun"; |  | ||||||
| const string WEPNAME_SUPER_SHOTGUN = "Double-barrelled Shotgun"; |  | ||||||
| const string WEPNAME_NAILGUN = "Nailgun"; |  | ||||||
| const string WEPNAME_SUPER_NAILGUN = "Super Nailgun"; |  | ||||||
| const string WEPNAME_GRENADE_LAUNCHER = "Grenade Launcher"; |  | ||||||
| const string WEPNAME_ROCKET_LAUNCHER = "Rocket Launcher"; |  | ||||||
| const string WEPNAME_LIGHTNING = "Thunderbolt"; |  | ||||||
| 
 |  | ||||||
| void() W_SetCurrentAmmo; | void() W_SetCurrentAmmo; | ||||||
| 
 |  | ||||||
| string() Key1Name = { |  | ||||||
| 	switch(world.worldtype) { |  | ||||||
| 		case 0: return "silver key"; |  | ||||||
| 		case 1: return "silver runekey"; |  | ||||||
| 		case 2: return "silver keycard"; |  | ||||||
| 		default: return string_null; |  | ||||||
| 	} |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| string() Key2Name = { |  | ||||||
| 	switch(world.worldtype) { |  | ||||||
| 		case 0: return "gold key"; |  | ||||||
| 		case 1: return "gold runekey"; |  | ||||||
| 		case 2: return "gold keycard"; |  | ||||||
| 		default: return string_null; |  | ||||||
| 	} |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| /* ALL LIGHTS SHOULD BE 0 1 0 IN COLOR ALL OTHER ITEMS SHOULD | /* ALL LIGHTS SHOULD BE 0 1 0 IN COLOR ALL OTHER ITEMS SHOULD | ||||||
| BE .8 .3 .4 IN COLOR */ | BE .8 .3 .4 IN COLOR */ | ||||||
| 
 | 
 | ||||||
|  | @ -525,7 +497,7 @@ void() weapon_supershotgun = { | ||||||
| 	precache_model("progs/g_shot.mdl"); | 	precache_model("progs/g_shot.mdl"); | ||||||
| 	setmodel(self, "progs/g_shot.mdl"); | 	setmodel(self, "progs/g_shot.mdl"); | ||||||
| 	self.weapon = IT_SUPER_SHOTGUN; | 	self.weapon = IT_SUPER_SHOTGUN; | ||||||
| 	self.netname = WEPNAME_SUPER_SHOTGUN; | 	self.netname = "Double-barrelled Shotgun"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -538,7 +510,7 @@ void() weapon_nailgun = { | ||||||
| 	precache_model("progs/g_nail.mdl"); | 	precache_model("progs/g_nail.mdl"); | ||||||
| 	setmodel(self, "progs/g_nail.mdl"); | 	setmodel(self, "progs/g_nail.mdl"); | ||||||
| 	self.weapon = IT_NAILGUN; | 	self.weapon = IT_NAILGUN; | ||||||
| 	self.netname = WEPNAME_NAILGUN; | 	self.netname = "nailgun"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -551,7 +523,7 @@ void() weapon_supernailgun = { | ||||||
| 	precache_model("progs/g_nail2.mdl"); | 	precache_model("progs/g_nail2.mdl"); | ||||||
| 	setmodel(self, "progs/g_nail2.mdl"); | 	setmodel(self, "progs/g_nail2.mdl"); | ||||||
| 	self.weapon = IT_SUPER_NAILGUN; | 	self.weapon = IT_SUPER_NAILGUN; | ||||||
| 	self.netname = WEPNAME_SUPER_NAILGUN; | 	self.netname = "Super Nailgun"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -564,7 +536,7 @@ void() weapon_grenadelauncher = { | ||||||
| 	precache_model("progs/g_rock.mdl"); | 	precache_model("progs/g_rock.mdl"); | ||||||
| 	setmodel(self, "progs/g_rock.mdl"); | 	setmodel(self, "progs/g_rock.mdl"); | ||||||
| 	self.weapon = 3; | 	self.weapon = 3; | ||||||
| 	self.netname = WEPNAME_GRENADE_LAUNCHER; | 	self.netname = "Grenade Launcher"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -577,7 +549,7 @@ void() weapon_rocketlauncher = { | ||||||
| 	precache_model("progs/g_rock2.mdl"); | 	precache_model("progs/g_rock2.mdl"); | ||||||
| 	setmodel(self, "progs/g_rock2.mdl"); | 	setmodel(self, "progs/g_rock2.mdl"); | ||||||
| 	self.weapon = 3; | 	self.weapon = 3; | ||||||
| 	self.netname = WEPNAME_ROCKET_LAUNCHER; | 	self.netname = "Rocket Launcher"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -591,7 +563,7 @@ void() weapon_lightning = { | ||||||
| 	precache_model("progs/g_light.mdl"); | 	precache_model("progs/g_light.mdl"); | ||||||
| 	setmodel(self, "progs/g_light.mdl"); | 	setmodel(self, "progs/g_light.mdl"); | ||||||
| 	self.weapon = 3; | 	self.weapon = 3; | ||||||
| 	self.netname = WEPNAME_LIGHTNING; | 	self.netname = "Thunderbolt"; | ||||||
| 	self.touch = weapon_touch; | 	self.touch = weapon_touch; | ||||||
| 	setsize(self, '-16 -16 0', '16 16 56'); | 	setsize(self, '-16 -16 0', '16 16 56'); | ||||||
| 	StartItem(); | 	StartItem(); | ||||||
|  | @ -913,20 +885,18 @@ following: | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| void() item_key1 = { | void() item_key1 = { | ||||||
| 	self.netname = Key1Name(); | 	if(world.worldtype == 0) { | ||||||
| 	switch(world.worldtype) { | 		precache_model("progs/w_s_key.mdl"); | ||||||
| 		case 0: | 		setmodel(self, "progs/w_s_key.mdl"); | ||||||
| 			precache_model("progs/w_s_key.mdl"); | 		self.netname = "silver key"; | ||||||
| 			setmodel(self, "progs/w_s_key.mdl"); | 	} else if(world.worldtype == 1) { | ||||||
| 			break; | 		precache_model("progs/m_s_key.mdl"); | ||||||
| 		case 1: | 		setmodel(self, "progs/m_s_key.mdl"); | ||||||
| 			precache_model("progs/m_s_key.mdl"); | 		self.netname = "silver runekey"; | ||||||
| 			setmodel(self, "progs/m_s_key.mdl"); | 	} else if(world.worldtype == 2) { | ||||||
| 			break; | 		precache_model2("progs/b_s_key.mdl"); | ||||||
| 		case 2: | 		setmodel(self, "progs/b_s_key.mdl"); | ||||||
| 			precache_model2("progs/b_s_key.mdl"); | 		self.netname = "silver keycard"; | ||||||
| 			setmodel(self, "progs/b_s_key.mdl"); |  | ||||||
| 			break; |  | ||||||
| 	} | 	} | ||||||
| 	key_setsounds(); | 	key_setsounds(); | ||||||
| 	self.touch = key_touch; | 	self.touch = key_touch; | ||||||
|  | @ -947,20 +917,20 @@ following: | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| void() item_key2 = { | void() item_key2 = { | ||||||
| 	self.netname = Key2Name(); | 	if(world.worldtype == 0) { | ||||||
| 	switch(world.worldtype) { | 		precache_model("progs/w_g_key.mdl"); | ||||||
| 		case 0: | 		setmodel(self, "progs/w_g_key.mdl"); | ||||||
| 			precache_model("progs/w_g_key.mdl"); | 		self.netname = "gold key"; | ||||||
| 			setmodel(self, "progs/w_g_key.mdl"); | 	} | ||||||
| 			break; | 	if(world.worldtype == 1) { | ||||||
| 		case 1: | 		precache_model("progs/m_g_key.mdl"); | ||||||
| 			precache_model("progs/m_g_key.mdl"); | 		setmodel(self, "progs/m_g_key.mdl"); | ||||||
| 			setmodel(self, "progs/m_g_key.mdl"); | 		self.netname = "gold runekey"; | ||||||
| 			break; | 	} | ||||||
| 		case 2: | 	if(world.worldtype == 2) { | ||||||
| 			precache_model2("progs/b_g_key.mdl"); | 		precache_model2("progs/b_g_key.mdl"); | ||||||
| 			setmodel(self, "progs/b_g_key.mdl"); | 		setmodel(self, "progs/b_g_key.mdl"); | ||||||
| 			break; | 		self.netname = "gold keycard"; | ||||||
| 	} | 	} | ||||||
| 	key_setsounds(); | 	key_setsounds(); | ||||||
| 	self.touch = key_touch; | 	self.touch = key_touch; | ||||||
|  | @ -1197,30 +1167,34 @@ void() BackpackTouch = { | ||||||
| 	local entity stemp; | 	local entity stemp; | ||||||
| 	local float acount; | 	local float acount; | ||||||
| 
 | 
 | ||||||
| 	if(other.classname != "player" || other.health <= 0) { | 	if(other.classname != "player") { | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 	if(other.health <= 0) { | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	acount = 0; | 	acount = 0; | ||||||
| 	sprint(other, "You get "); | 	sprint(other, "You get "); | ||||||
| 
 | 
 | ||||||
| 	if(self.items && (other.items & self.items) == 0) { | 	if(self.items) | ||||||
| 		acount = 1; | 		if((other.items & self.items) == 0) { | ||||||
| 		sprint(other, "the "); | 			acount = 1; | ||||||
| 		sprint(other, self.netname); | 			sprint(other, "the "); | ||||||
| 	} | 			sprint(other, self.netname); | ||||||
|  | 		} | ||||||
| 
 | 
 | ||||||
| 	// if the player was using their best weapon, change up to the new one if better | 	// if the player was using his best weapon, change up to the new one if better | ||||||
| 	stemp = self; | 	stemp = self; | ||||||
| 	self = other; | 	self = other; | ||||||
| 	best = W_BestWeapon(); | 	best = W_BestWeapon(); | ||||||
| 	self = stemp; | 	self = stemp; | ||||||
| 
 | 
 | ||||||
| 	// change weapons | 	// change weapons | ||||||
| 	other.ammo_shells  = other.ammo_shells  + self.ammo_shells; | 	other.ammo_shells = other.ammo_shells + self.ammo_shells; | ||||||
| 	other.ammo_nails   = other.ammo_nails   + self.ammo_nails; | 	other.ammo_nails = other.ammo_nails + self.ammo_nails; | ||||||
| 	other.ammo_rockets = other.ammo_rockets + self.ammo_rockets; | 	other.ammo_rockets = other.ammo_rockets + self.ammo_rockets; | ||||||
| 	other.ammo_cells   = other.ammo_cells   + self.ammo_cells; | 	other.ammo_cells = other.ammo_cells + self.ammo_cells; | ||||||
| 
 | 
 | ||||||
| 	new = self.items; | 	new = self.items; | ||||||
| 	if(!new) { | 	if(!new) { | ||||||
|  | @ -1267,20 +1241,6 @@ void() BackpackTouch = { | ||||||
| 		sprint(other, s); | 		sprint(other, s); | ||||||
| 		sprint(other, " cells"); | 		sprint(other, " cells"); | ||||||
| 	} | 	} | ||||||
| 	if(self.items & IT_KEY1) { |  | ||||||
| 		if(acount) { |  | ||||||
| 			sprint(other, ", "); |  | ||||||
| 		} |  | ||||||
| 		acount = 1; |  | ||||||
| 		sprint(other, Key1Name()); |  | ||||||
| 	} |  | ||||||
| 	if(self.items & IT_KEY2) { |  | ||||||
| 		if(acount) { |  | ||||||
| 			sprint(other, ", "); |  | ||||||
| 		} |  | ||||||
| 		acount = 1; |  | ||||||
| 		sprint(other, Key2Name()); |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	sprint(other, "\n"); | 	sprint(other, "\n"); | ||||||
| 	// backpack touch sound | 	// backpack touch sound | ||||||
|  | @ -1306,37 +1266,41 @@ void() BackpackTouch = { | ||||||
| DropBackpack | DropBackpack | ||||||
| =============== | =============== | ||||||
| */ | */ | ||||||
| entity() DropBackpack = { | void() DropBackpack = { | ||||||
| 	local entity item; | 	local entity item; | ||||||
| 
 | 
 | ||||||
|  | 	if(!(self.ammo_shells + self.ammo_nails + self.ammo_rockets + self.ammo_cells)) { | ||||||
|  | 		return; // nothing in it | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	item = spawn(); | 	item = spawn(); | ||||||
| 	item.origin = self.origin - '0 0 24'; | 	item.origin = self.origin - '0 0 24'; | ||||||
| 	item.items = self.weapon | (self.items & (IT_KEY1 | IT_KEY2)); |  | ||||||
| 
 | 
 | ||||||
|  | 	item.items = self.weapon; | ||||||
| 	if(item.items == IT_AXE) { | 	if(item.items == IT_AXE) { | ||||||
| 		item.netname = WEPNAME_AXE; | 		item.netname = "Axe"; | ||||||
| 	} else if(item.items == IT_SHOTGUN) { | 	} else if(item.items == IT_SHOTGUN) { | ||||||
| 		item.netname = WEPNAME_SHOTGUN; | 		item.netname = "Shotgun"; | ||||||
| 	} else if(item.items == IT_SUPER_SHOTGUN) { | 	} else if(item.items == IT_SUPER_SHOTGUN) { | ||||||
| 		item.netname = WEPNAME_SUPER_SHOTGUN; | 		item.netname = "Double-barrelled Shotgun"; | ||||||
| 	} else if(item.items == IT_NAILGUN) { | 	} else if(item.items == IT_NAILGUN) { | ||||||
| 		item.netname = WEPNAME_NAILGUN; | 		item.netname = "Nailgun"; | ||||||
| 	} else if(item.items == IT_SUPER_NAILGUN) { | 	} else if(item.items == IT_SUPER_NAILGUN) { | ||||||
| 		item.netname = WEPNAME_SUPER_NAILGUN; | 		item.netname = "Super Nailgun"; | ||||||
| 	} else if(item.items == IT_GRENADE_LAUNCHER) { | 	} else if(item.items == IT_GRENADE_LAUNCHER) { | ||||||
| 		item.netname = WEPNAME_GRENADE_LAUNCHER; | 		item.netname = "Grenade Launcher"; | ||||||
| 	} else if(item.items == IT_ROCKET_LAUNCHER) { | 	} else if(item.items == IT_ROCKET_LAUNCHER) { | ||||||
| 		item.netname = WEPNAME_ROCKET_LAUNCHER; | 		item.netname = "Rocket Launcher"; | ||||||
| 	} else if(item.items == IT_LIGHTNING) { | 	} else if(item.items == IT_LIGHTNING) { | ||||||
| 		item.netname = WEPNAME_LIGHTNING; | 		item.netname = "Thunderbolt"; | ||||||
| 	} else { | 	} else { | ||||||
| 		item.netname = ""; | 		item.netname = ""; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	item.ammo_shells  = self.ammo_shells; | 	item.ammo_shells = self.ammo_shells; | ||||||
| 	item.ammo_nails   = self.ammo_nails; | 	item.ammo_nails = self.ammo_nails; | ||||||
| 	item.ammo_rockets = self.ammo_rockets; | 	item.ammo_rockets = self.ammo_rockets; | ||||||
| 	item.ammo_cells   = self.ammo_cells; | 	item.ammo_cells = self.ammo_cells; | ||||||
| 
 | 
 | ||||||
| 	item.velocity_z = 300; | 	item.velocity_z = 300; | ||||||
| 	item.velocity_x = -100 + (random() * 200); | 	item.velocity_x = -100 + (random() * 200); | ||||||
|  | @ -1351,6 +1315,4 @@ entity() DropBackpack = { | ||||||
| 
 | 
 | ||||||
| 	item.nextthink = time + 120; // remove after 2 minutes | 	item.nextthink = time + 120; // remove after 2 minutes | ||||||
| 	item.think = SUB_Remove; | 	item.think = SUB_Remove; | ||||||
| 
 |  | ||||||
| 	return item; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -558,7 +558,10 @@ void() PlayerDie = { | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	i = 1 + floor(random() * 6); | 	i = cvar("temp1"); | ||||||
|  | 	if(!i) { | ||||||
|  | 		i = 1 + floor(random() * 6); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if(i == 1) { | 	if(i == 1) { | ||||||
| 		player_diea1(); | 		player_diea1(); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user