| 214 | | /* Some "weapons" and "ammo" do extra damage */ |
|---|
| 215 | | switch (o_ptr->tval) |
|---|
| 216 | | { |
|---|
| 217 | | case TV_SHOT: |
|---|
| 218 | | case TV_ARROW: |
|---|
| 219 | | case TV_BOLT: |
|---|
| 220 | | case TV_HAFTED: |
|---|
| 221 | | case TV_POLEARM: |
|---|
| 222 | | case TV_SWORD: |
|---|
| 223 | | case TV_DIGGING: |
|---|
| 224 | | { |
|---|
| 225 | | /* Slay Animal */ |
|---|
| 226 | | if ((f1 & (TR1_SLAY_ANIMAL)) && |
|---|
| 227 | | (r_ptr->flags3 & (RF3_ANIMAL))) |
|---|
| 228 | | { |
|---|
| 229 | | if (m_ptr->ml) |
|---|
| 230 | | { |
|---|
| 231 | | l_ptr->flags3 |= (RF3_ANIMAL); |
|---|
| 232 | | } |
|---|
| 233 | | |
|---|
| 234 | | if (mult < 2) mult = 2; |
|---|
| 235 | | } |
|---|
| 236 | | |
|---|
| 237 | | /* Slay Evil */ |
|---|
| 238 | | if ((f1 & (TR1_SLAY_EVIL)) && |
|---|
| 239 | | (r_ptr->flags3 & (RF3_EVIL))) |
|---|
| 240 | | { |
|---|
| 241 | | if (m_ptr->ml) |
|---|
| 242 | | { |
|---|
| 243 | | l_ptr->flags3 |= (RF3_EVIL); |
|---|
| 244 | | } |
|---|
| 245 | | |
|---|
| 246 | | if (mult < 2) mult = 2; |
|---|
| 247 | | } |
|---|
| 248 | | |
|---|
| 249 | | /* Slay Undead */ |
|---|
| 250 | | if ((f1 & (TR1_SLAY_UNDEAD)) && |
|---|
| 251 | | (r_ptr->flags3 & (RF3_UNDEAD))) |
|---|
| 252 | | { |
|---|
| 253 | | if (m_ptr->ml) |
|---|
| 254 | | { |
|---|
| 255 | | l_ptr->flags3 |= (RF3_UNDEAD); |
|---|
| 256 | | } |
|---|
| 257 | | |
|---|
| 258 | | if (mult < 3) mult = 3; |
|---|
| 259 | | } |
|---|
| 260 | | |
|---|
| 261 | | /* Slay Demon */ |
|---|
| 262 | | if ((f1 & (TR1_SLAY_DEMON)) && |
|---|
| 263 | | (r_ptr->flags3 & (RF3_DEMON))) |
|---|
| 264 | | { |
|---|
| 265 | | if (m_ptr->ml) |
|---|
| 266 | | { |
|---|
| 267 | | l_ptr->flags3 |= (RF3_DEMON); |
|---|
| 268 | | } |
|---|
| 269 | | |
|---|
| 270 | | if (mult < 3) mult = 3; |
|---|
| 271 | | } |
|---|
| 272 | | |
|---|
| 273 | | /* Slay Orc */ |
|---|
| 274 | | if ((f1 & (TR1_SLAY_ORC)) && |
|---|
| 275 | | (r_ptr->flags3 & (RF3_ORC))) |
|---|
| 276 | | { |
|---|
| 277 | | if (m_ptr->ml) |
|---|
| 278 | | { |
|---|
| 279 | | l_ptr->flags3 |= (RF3_ORC); |
|---|
| 280 | | } |
|---|
| 281 | | |
|---|
| 282 | | if (mult < 3) mult = 3; |
|---|
| 283 | | } |
|---|
| 284 | | |
|---|
| 285 | | /* Slay Troll */ |
|---|
| 286 | | if ((f1 & (TR1_SLAY_TROLL)) && |
|---|
| 287 | | (r_ptr->flags3 & (RF3_TROLL))) |
|---|
| 288 | | { |
|---|
| 289 | | if (m_ptr->ml) |
|---|
| 290 | | { |
|---|
| 291 | | l_ptr->flags3 |= (RF3_TROLL); |
|---|
| 292 | | } |
|---|
| 293 | | |
|---|
| 294 | | if (mult < 3) mult = 3; |
|---|
| 295 | | } |
|---|
| 296 | | |
|---|
| 297 | | /* Slay Giant */ |
|---|
| 298 | | if ((f1 & (TR1_SLAY_GIANT)) && |
|---|
| 299 | | (r_ptr->flags3 & (RF3_GIANT))) |
|---|
| 300 | | { |
|---|
| 301 | | if (m_ptr->ml) |
|---|
| 302 | | { |
|---|
| 303 | | l_ptr->flags3 |= (RF3_GIANT); |
|---|
| 304 | | } |
|---|
| 305 | | |
|---|
| 306 | | if (mult < 3) mult = 3; |
|---|
| 307 | | } |
|---|
| 308 | | |
|---|
| 309 | | /* Slay Dragon */ |
|---|
| 310 | | if ((f1 & (TR1_SLAY_DRAGON)) && |
|---|
| 311 | | (r_ptr->flags3 & (RF3_DRAGON))) |
|---|
| 312 | | { |
|---|
| 313 | | if (m_ptr->ml) |
|---|
| 314 | | { |
|---|
| 315 | | l_ptr->flags3 |= (RF3_DRAGON); |
|---|
| 316 | | } |
|---|
| 317 | | |
|---|
| 318 | | if (mult < 3) mult = 3; |
|---|
| 319 | | } |
|---|
| 320 | | |
|---|
| 321 | | /* Execute Dragon */ |
|---|
| 322 | | if ((f1 & (TR1_KILL_DRAGON)) && |
|---|
| 323 | | (r_ptr->flags3 & (RF3_DRAGON))) |
|---|
| 324 | | { |
|---|
| 325 | | if (m_ptr->ml) |
|---|
| 326 | | { |
|---|
| 327 | | l_ptr->flags3 |= (RF3_DRAGON); |
|---|
| 328 | | } |
|---|
| 329 | | |
|---|
| 330 | | if (mult < 5) mult = 5; |
|---|
| 331 | | } |
|---|
| 332 | | |
|---|
| 333 | | /* Execute demon */ |
|---|
| 334 | | if ((f1 & (TR1_KILL_DEMON)) && |
|---|
| 335 | | (r_ptr->flags3 & (RF3_DEMON))) |
|---|
| 336 | | { |
|---|
| 337 | | if (m_ptr->ml) |
|---|
| 338 | | { |
|---|
| 339 | | l_ptr->flags3 |= (RF3_DEMON); |
|---|
| 340 | | } |
|---|
| 341 | | |
|---|
| 342 | | if (mult < 5) mult = 5; |
|---|
| 343 | | } |
|---|
| 344 | | |
|---|
| 345 | | /* Execute undead */ |
|---|
| 346 | | if ((f1 & (TR1_KILL_UNDEAD)) && |
|---|
| 347 | | (r_ptr->flags3 & (RF3_UNDEAD))) |
|---|
| 348 | | { |
|---|
| 349 | | if (m_ptr->ml) |
|---|
| 350 | | { |
|---|
| 351 | | l_ptr->flags3 |= (RF3_UNDEAD); |
|---|
| 352 | | } |
|---|
| 353 | | |
|---|
| 354 | | if (mult < 5) mult = 5; |
|---|
| 355 | | } |
|---|
| 356 | | |
|---|
| 357 | | /* Brand (Acid) */ |
|---|
| 358 | | if (f1 & (TR1_BRAND_ACID)) |
|---|
| 359 | | { |
|---|
| 360 | | /* Notice immunity */ |
|---|
| 361 | | if (r_ptr->flags3 & (RF3_IM_ACID)) |
|---|
| 362 | | { |
|---|
| 363 | | if (m_ptr->ml) |
|---|
| 364 | | { |
|---|
| 365 | | l_ptr->flags3 |= (RF3_IM_ACID); |
|---|
| 366 | | } |
|---|
| 367 | | } |
|---|
| 368 | | |
|---|
| 369 | | /* Otherwise, take the damage */ |
|---|
| 370 | | else |
|---|
| 371 | | { |
|---|
| 372 | | if (mult < 3) mult = 3; |
|---|
| 373 | | } |
|---|
| 374 | | } |
|---|
| 375 | | |
|---|
| 376 | | /* Brand (Elec) */ |
|---|
| 377 | | if (f1 & (TR1_BRAND_ELEC)) |
|---|
| 378 | | { |
|---|
| 379 | | /* Notice immunity */ |
|---|
| 380 | | if (r_ptr->flags3 & (RF3_IM_ELEC)) |
|---|
| 381 | | { |
|---|
| 382 | | if (m_ptr->ml) |
|---|
| 383 | | { |
|---|
| 384 | | l_ptr->flags3 |= (RF3_IM_ELEC); |
|---|
| 385 | | } |
|---|
| 386 | | } |
|---|
| 387 | | |
|---|
| 388 | | /* Otherwise, take the damage */ |
|---|
| 389 | | else |
|---|
| 390 | | { |
|---|
| 391 | | if (mult < 3) mult = 3; |
|---|
| 392 | | } |
|---|
| 393 | | } |
|---|
| 394 | | |
|---|
| 395 | | /* Brand (Fire) */ |
|---|
| 396 | | if (f1 & (TR1_BRAND_FIRE)) |
|---|
| 397 | | { |
|---|
| 398 | | /* Notice immunity */ |
|---|
| 399 | | if (r_ptr->flags3 & (RF3_IM_FIRE)) |
|---|
| 400 | | { |
|---|
| 401 | | if (m_ptr->ml) |
|---|
| 402 | | { |
|---|
| 403 | | l_ptr->flags3 |= (RF3_IM_FIRE); |
|---|
| 404 | | } |
|---|
| 405 | | } |
|---|
| 406 | | |
|---|
| 407 | | /* Otherwise, take the damage */ |
|---|
| 408 | | else |
|---|
| 409 | | { |
|---|
| 410 | | if (mult < 3) mult = 3; |
|---|
| 411 | | } |
|---|
| 412 | | } |
|---|
| 413 | | |
|---|
| 414 | | /* Brand (Cold) */ |
|---|
| 415 | | if (f1 & (TR1_BRAND_COLD)) |
|---|
| 416 | | { |
|---|
| 417 | | /* Notice immunity */ |
|---|
| 418 | | if (r_ptr->flags3 & (RF3_IM_COLD)) |
|---|
| 419 | | { |
|---|
| 420 | | if (m_ptr->ml) |
|---|
| 421 | | { |
|---|
| 422 | | l_ptr->flags3 |= (RF3_IM_COLD); |
|---|
| 423 | | } |
|---|
| 424 | | } |
|---|
| 425 | | |
|---|
| 426 | | /* Otherwise, take the damage */ |
|---|
| 427 | | else |
|---|
| 428 | | { |
|---|
| 429 | | if (mult < 3) mult = 3; |
|---|
| 430 | | } |
|---|
| 431 | | } |
|---|
| 432 | | |
|---|
| 433 | | /* Brand (Poison) */ |
|---|
| 434 | | if (f1 & (TR1_BRAND_POIS)) |
|---|
| 435 | | { |
|---|
| 436 | | /* Notice immunity */ |
|---|
| 437 | | if (r_ptr->flags3 & (RF3_IM_POIS)) |
|---|
| 438 | | { |
|---|
| 439 | | if (m_ptr->ml) |
|---|
| 440 | | { |
|---|
| 441 | | l_ptr->flags3 |= (RF3_IM_POIS); |
|---|
| 442 | | } |
|---|
| 443 | | } |
|---|
| 444 | | |
|---|
| 445 | | /* Otherwise, take the damage */ |
|---|
| 446 | | else |
|---|
| 447 | | { |
|---|
| 448 | | if (mult < 3) mult = 3; |
|---|
| 449 | | } |
|---|
| 450 | | } |
|---|
| 451 | | |
|---|
| 452 | | break; |
|---|
| 453 | | } |
|---|
| 454 | | } |
|---|
| 455 | | |
|---|
| 456 | | |
|---|
| 457 | | /* Return the total damage */ |
|---|
| 458 | | return (tdam * mult); |
|---|
| | 211 | |
|---|
| | 212 | /* Slay Animal */ |
|---|
| | 213 | if ((f1 & TR1_SLAY_ANIMAL) && (r_ptr->flags3 & RF3_ANIMAL)) |
|---|
| | 214 | { |
|---|
| | 215 | if (m_ptr->ml) |
|---|
| | 216 | l_ptr->flags3 |= (RF3_ANIMAL); |
|---|
| | 217 | |
|---|
| | 218 | if (mult < 2) mult = 2; |
|---|
| | 219 | } |
|---|
| | 220 | |
|---|
| | 221 | /* Slay Evil */ |
|---|
| | 222 | if ((f1 & TR1_SLAY_EVIL) && (r_ptr->flags3 & RF3_EVIL)) |
|---|
| | 223 | { |
|---|
| | 224 | if (m_ptr->ml) |
|---|
| | 225 | l_ptr->flags3 |= (RF3_EVIL); |
|---|
| | 226 | |
|---|
| | 227 | if (mult < 2) mult = 2; |
|---|
| | 228 | } |
|---|
| | 229 | |
|---|
| | 230 | /* Slay Undead */ |
|---|
| | 231 | if ((f1 & TR1_SLAY_UNDEAD) && (r_ptr->flags3 & RF3_UNDEAD)) |
|---|
| | 232 | { |
|---|
| | 233 | if (m_ptr->ml) |
|---|
| | 234 | l_ptr->flags3 |= (RF3_UNDEAD); |
|---|
| | 235 | |
|---|
| | 236 | if (mult < 3) mult = 3; |
|---|
| | 237 | } |
|---|
| | 238 | |
|---|
| | 239 | /* Slay Demon */ |
|---|
| | 240 | if ((f1 & TR1_SLAY_DEMON) && (r_ptr->flags3 & RF3_DEMON)) |
|---|
| | 241 | { |
|---|
| | 242 | if (m_ptr->ml) |
|---|
| | 243 | l_ptr->flags3 |= (RF3_DEMON); |
|---|
| | 244 | |
|---|
| | 245 | if (mult < 3) mult = 3; |
|---|
| | 246 | } |
|---|
| | 247 | |
|---|
| | 248 | /* Slay Orc */ |
|---|
| | 249 | if ((f1 & TR1_SLAY_ORC) && (r_ptr->flags3 & RF3_ORC)) |
|---|
| | 250 | { |
|---|
| | 251 | if (m_ptr->ml) |
|---|
| | 252 | l_ptr->flags3 |= (RF3_ORC); |
|---|
| | 253 | |
|---|
| | 254 | if (mult < 3) mult = 3; |
|---|
| | 255 | } |
|---|
| | 256 | |
|---|
| | 257 | /* Slay Troll */ |
|---|
| | 258 | if ((f1 & TR1_SLAY_TROLL) && (r_ptr->flags3 & RF3_TROLL)) |
|---|
| | 259 | { |
|---|
| | 260 | if (m_ptr->ml) |
|---|
| | 261 | l_ptr->flags3 |= (RF3_TROLL); |
|---|
| | 262 | |
|---|
| | 263 | if (mult < 3) mult = 3; |
|---|
| | 264 | } |
|---|
| | 265 | |
|---|
| | 266 | /* Slay Giant */ |
|---|
| | 267 | if ((f1 & TR1_SLAY_GIANT) && (r_ptr->flags3 & RF3_GIANT)) |
|---|
| | 268 | { |
|---|
| | 269 | if (m_ptr->ml) |
|---|
| | 270 | l_ptr->flags3 |= (RF3_GIANT); |
|---|
| | 271 | |
|---|
| | 272 | if (mult < 3) mult = 3; |
|---|
| | 273 | } |
|---|
| | 274 | |
|---|
| | 275 | /* Slay Dragon */ |
|---|
| | 276 | if ((f1 & TR1_SLAY_DRAGON) && (r_ptr->flags3 & RF3_DRAGON)) |
|---|
| | 277 | { |
|---|
| | 278 | if (m_ptr->ml) |
|---|
| | 279 | l_ptr->flags3 |= (RF3_DRAGON); |
|---|
| | 280 | |
|---|
| | 281 | if (mult < 3) mult = 3; |
|---|
| | 282 | } |
|---|
| | 283 | |
|---|
| | 284 | /* Execute Dragon */ |
|---|
| | 285 | if ((f1 & TR1_KILL_DRAGON) && (r_ptr->flags3 & RF3_DRAGON)) |
|---|
| | 286 | { |
|---|
| | 287 | if (m_ptr->ml) |
|---|
| | 288 | l_ptr->flags3 |= (RF3_DRAGON); |
|---|
| | 289 | |
|---|
| | 290 | if (mult < 5) mult = 5; |
|---|
| | 291 | } |
|---|
| | 292 | |
|---|
| | 293 | /* Execute demon */ |
|---|
| | 294 | if ((f1 & TR1_KILL_DEMON) && (r_ptr->flags3 & RF3_DEMON)) |
|---|
| | 295 | { |
|---|
| | 296 | if (m_ptr->ml) |
|---|
| | 297 | l_ptr->flags3 |= (RF3_DEMON); |
|---|
| | 298 | |
|---|
| | 299 | if (mult < 5) mult = 5; |
|---|
| | 300 | } |
|---|
| | 301 | |
|---|
| | 302 | /* Execute undead */ |
|---|
| | 303 | if ((f1 & TR1_KILL_UNDEAD) && (r_ptr->flags3 & RF3_UNDEAD)) |
|---|
| | 304 | { |
|---|
| | 305 | if (m_ptr->ml) |
|---|
| | 306 | l_ptr->flags3 |= (RF3_UNDEAD); |
|---|
| | 307 | |
|---|
| | 308 | if (mult < 5) mult = 5; |
|---|
| | 309 | } |
|---|
| | 310 | |
|---|
| | 311 | /* Brand (Acid) */ |
|---|
| | 312 | if (f1 & (TR1_BRAND_ACID)) |
|---|
| | 313 | { |
|---|
| | 314 | /* Notice immunity */ |
|---|
| | 315 | if (r_ptr->flags3 & (RF3_IM_ACID)) |
|---|
| | 316 | { |
|---|
| | 317 | if (m_ptr->ml) |
|---|
| | 318 | l_ptr->flags3 |= (RF3_IM_ACID); |
|---|
| | 319 | } |
|---|
| | 320 | |
|---|
| | 321 | /* Otherwise, take the damage */ |
|---|
| | 322 | else |
|---|
| | 323 | { |
|---|
| | 324 | if (mult < 3) mult = 3; |
|---|
| | 325 | } |
|---|
| | 326 | } |
|---|
| | 327 | |
|---|
| | 328 | /* Brand (Elec) */ |
|---|
| | 329 | if (f1 & (TR1_BRAND_ELEC)) |
|---|
| | 330 | { |
|---|
| | 331 | /* Notice immunity */ |
|---|
| | 332 | if (r_ptr->flags3 & (RF3_IM_ELEC)) |
|---|
| | 333 | { |
|---|
| | 334 | if (m_ptr->ml) |
|---|
| | 335 | l_ptr->flags3 |= (RF3_IM_ELEC); |
|---|
| | 336 | } |
|---|
| | 337 | |
|---|
| | 338 | /* Otherwise, take the damage */ |
|---|
| | 339 | else |
|---|
| | 340 | { |
|---|
| | 341 | if (mult < 3) mult = 3; |
|---|
| | 342 | } |
|---|
| | 343 | } |
|---|
| | 344 | |
|---|
| | 345 | /* Brand (Fire) */ |
|---|
| | 346 | if (f1 & (TR1_BRAND_FIRE)) |
|---|
| | 347 | { |
|---|
| | 348 | /* Notice immunity */ |
|---|
| | 349 | if (r_ptr->flags3 & (RF3_IM_FIRE)) |
|---|
| | 350 | { |
|---|
| | 351 | if (m_ptr->ml) |
|---|
| | 352 | l_ptr->flags3 |= (RF3_IM_FIRE); |
|---|
| | 353 | } |
|---|
| | 354 | |
|---|
| | 355 | /* Otherwise, take the damage */ |
|---|
| | 356 | else |
|---|
| | 357 | { |
|---|
| | 358 | if (mult < 3) mult = 3; |
|---|
| | 359 | } |
|---|
| | 360 | } |
|---|
| | 361 | |
|---|
| | 362 | /* Brand (Cold) */ |
|---|
| | 363 | if (f1 & (TR1_BRAND_COLD)) |
|---|
| | 364 | { |
|---|
| | 365 | /* Notice immunity */ |
|---|
| | 366 | if (r_ptr->flags3 & (RF3_IM_COLD)) |
|---|
| | 367 | { |
|---|
| | 368 | if (m_ptr->ml) |
|---|
| | 369 | l_ptr->flags3 |= (RF3_IM_COLD); |
|---|
| | 370 | } |
|---|
| | 371 | |
|---|
| | 372 | /* Otherwise, take the damage */ |
|---|
| | 373 | else |
|---|
| | 374 | { |
|---|
| | 375 | if (mult < 3) mult = 3; |
|---|
| | 376 | } |
|---|
| | 377 | } |
|---|
| | 378 | |
|---|
| | 379 | /* Brand (Poison) */ |
|---|
| | 380 | if (f1 & (TR1_BRAND_POIS)) |
|---|
| | 381 | { |
|---|
| | 382 | /* Notice immunity */ |
|---|
| | 383 | if (r_ptr->flags3 & (RF3_IM_POIS)) |
|---|
| | 384 | { |
|---|
| | 385 | if (m_ptr->ml) |
|---|
| | 386 | l_ptr->flags3 |= (RF3_IM_POIS); |
|---|
| | 387 | } |
|---|
| | 388 | |
|---|
| | 389 | /* Otherwise, take the damage */ |
|---|
| | 390 | else |
|---|
| | 391 | { |
|---|
| | 392 | if (mult < 3) mult = 3; |
|---|
| | 393 | } |
|---|
| | 394 | } |
|---|
| | 395 | |
|---|
| | 396 | |
|---|
| | 397 | /* Return the multiplier */ |
|---|
| | 398 | return (mult); |
|---|