summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJesusaves <cpntb1@ymail.com>2021-02-18 04:02:52 -0300
committerJesusaves <cpntb1@ymail.com>2021-02-18 04:02:52 -0300
commit802c15e6a7f4c07b7fe0a7ed47d1defbcce4824d (patch)
treee09b3aafeaad9251fbcdcf146960bab4df12f0ee
parente28a3651adad1c976e5286c356e7eca21f6234cf (diff)
downloadserverdata-802c15e6a7f4c07b7fe0a7ed47d1defbcce4824d.tar.gz
serverdata-802c15e6a7f4c07b7fe0a7ed47d1defbcce4824d.tar.bz2
serverdata-802c15e6a7f4c07b7fe0a7ed47d1defbcce4824d.tar.xz
serverdata-802c15e6a7f4c07b7fe0a7ed47d1defbcce4824d.zip
Aegis Shield Blackbox
-rw-r--r--db/re/item_db.conf11
-rw-r--r--npc/001-1/portal.txt7
-rw-r--r--npc/025-2-3/boss.txt1
-rw-r--r--npc/025-2-4/_import.txt1
-rw-r--r--npc/025-2-4/tree.txt39
-rw-r--r--npc/commands/grantpower.txt13
-rw-r--r--npc/functions/hub.txt2
-rw-r--r--npc/functions/util.txt11
8 files changed, 79 insertions, 6 deletions
diff --git a/db/re/item_db.conf b/db/re/item_db.conf
index f2b74b8e2..08ca76ffa 100644
--- a/db/re/item_db.conf
+++ b/db/re/item_db.conf
@@ -12399,6 +12399,7 @@ item_db: (
Sell: 0
Weight: 2000
Atk: 1800
+ Matk: 1800
Range: 1
Loc: "EQP_HAND_R"
WeaponLv: 1
@@ -12469,7 +12470,7 @@ item_db: (
EquipLv: 1
Refine: true
Subtype: "W_KNUCKLE"
- Slots: 1
+ Slots: 2
AllowCards: {
id5022: 1
id5023: 1
@@ -12523,7 +12524,7 @@ item_db: (
EquipLv: 1
Refine: true
Subtype: "W_BOW"
- Slots: 1
+ Slots: 2
AllowCards: {
id5022: 1
id5023: 1
@@ -12587,7 +12588,7 @@ item_db: (
EquipLv: 1
Refine: true
Subtype: "W_STAFF"
- Slots: 1
+ Slots: 2
AllowCards: {
id5022: 1
id5023: 1
@@ -12649,7 +12650,7 @@ item_db: (
nomail: true
noauction: true
}
- Slots: 1
+ Slots: 2
AllowCards: {
id5022: 1
id5023: 1
@@ -12666,7 +12667,7 @@ item_db: (
}
Script: <"
bonus bFlee2,20;
- bonus bFlee,-100;
+ bonus bFlee,-100; // TODO: Replace with Walk Speed Redux + no mount
bonus bCriticalDef,100;
bonus bSPrecovRate,100;
bonus2 bHPRegenRate, BaseLevel/3, 1500;
diff --git a/npc/001-1/portal.txt b/npc/001-1/portal.txt
index 0c02c67c9..428787378 100644
--- a/npc/001-1/portal.txt
+++ b/npc/001-1/portal.txt
@@ -97,6 +97,13 @@ L_TranslationFix:
mes l("EVENT CANCELLED DUE TO PLAYER INACTIVITY");
mes l("%s has EXILED %s from %s.", "", "", "");
mes l("Aurora Events");
+ // Legendary Messages
+ mes l("WARNING: The %s is a %s. Besides being insanely powerful, no duplicate of them exist in the world. They can be tweaked freely and can hold multiple cards as well, and scale according to your level. Use its powers wisely. However, beware: This weapon cannot be traded except with \"@grantpower\" command, and if you abandon the world, the weapon will abandon you as well!", getitemlink(Acorn), b(l("legendary weapon"))), 1;
+ mes l("%s, you did your best to avenge a fallen comrade. It is my wish that you continue protecting this world. Therefore, I bestow upon you, the legendary %s. Please use its powers to protect your friend and the world peace!", "", getitemlink(Acorn)), 2;
+ mes l("%s, you did your best to protect this world inhabitants. It is my wish that you continue protecting this world. Therefore, I bestow upon you, the legendary %s. Please use its powers to protect your friend and the world peace!", "", getitemlink(Acorn)), 2;
+ mes l("%s, you did your best to entretain me. It is my wish that you continue protecting this world. Therefore, I bestow upon you, the legendary %s. Please use its powers to protect your friend and the world peace!", "", getitemlink(Acorn)), 2;
+ mes l("%s, you proved your worth today. It is my wish that you continue protecting this world. Therefore, I bestow upon you, the legendary %s. Please use its powers to protect your friend and the world peace!", "", getitemlink(Acorn)), 2;
+ mesc l("%s, your dedication is touching. It is my wish that you continue protecting this world. Therefore, I bestow upon you, the legendary %s. Please use its powers to protect your friend and the world peace!", "", getitemlink(Acorn)), 2;
mes l("sample");
close;
diff --git a/npc/025-2-3/boss.txt b/npc/025-2-3/boss.txt
index 30d374c2b..ebed55c0f 100644
--- a/npc/025-2-3/boss.txt
+++ b/npc/025-2-3/boss.txt
@@ -25,6 +25,7 @@ OnBossDeath:
} else {
mapannounce "025-2-3", "Boss deafeated by: " + strcharinfo(0), bc_all;
}
+ callfunc "02524_Revenge_BlackBox";
end;
}
diff --git a/npc/025-2-4/_import.txt b/npc/025-2-4/_import.txt
index a012b10d4..e9181f3b4 100644
--- a/npc/025-2-4/_import.txt
+++ b/npc/025-2-4/_import.txt
@@ -1,5 +1,6 @@
// Map 025-2-4: Mana Tree Cave
// This file is generated automatically. All manually added changes will be removed when running the Converter.
+"npc/025-2-4/025-2-4_aegis_blackbox.txt",
"npc/025-2-4/_mobs.txt",
"npc/025-2-4/_warps.txt",
"npc/025-2-4/tree.txt",
diff --git a/npc/025-2-4/tree.txt b/npc/025-2-4/tree.txt
index bc6544889..1087346c0 100644
--- a/npc/025-2-4/tree.txt
+++ b/npc/025-2-4/tree.txt
@@ -5,17 +5,54 @@
// Pinkie Cave Tree is part of Legendary Weapons
025-2-4,39,33,0 script Mana Tree NPC_MANATREE,{
+ function manatreeOff;
+ function manatreeAgain;
+ function manatreeAegis;
+
setpcblock(PCBLOCK_HARD, true);
mesc l("A tree glows in this dark cave, surrounded by mana lanes.");
next;
mesc l("This might be the place of a great secret, but yet, all you can do is stare.");
next;
- mesc l("...for now.");
+ if (!true) manatreeOff();
+ else if ($AEGIS_HOLDER$ == "" && @manacool < gettimetick(2)) manatreeAegis();
+ else manatreeAgain();
+
next;
setpcblock(PCBLOCK_HARD, false);
closeclientdialog;
close;
+function manatreeOff {
+ mesc l("...for now.");
+ return;
+}
+
+function manatreeAgain {
+ // TODO: getitem Manapple, 1; // Maybe can obtain one daily/weekly?
+ return;
+}
+
+function manatreeAegis {
+ mesc l("For which player do you wish to pray?");
+ next;
+ input .@prayer$;
+ if (.@prayer$ == strcharinfo(0)) {
+ mesc l("The tree doesn't likes your selfishness.");
+ percentheal -20, -50;
+ return;
+ }
+ @manacool=gettimetick(2)+30;
+ .@cid=getcharid(3, .@prayer$);
+ if (.@cid < 1) {
+ mesc l("Did you just make up that someone?");
+ return;
+ }
+ 02524_Tree_BlackBox(.@prayer$, .@cid);
+ @manacool+=150;
+ return;
+}
+
OnInit:
.sex = G_OTHER;
.distance = 2;
diff --git a/npc/commands/grantpower.txt b/npc/commands/grantpower.txt
index 3ce37e47b..d051c5896 100644
--- a/npc/commands/grantpower.txt
+++ b/npc/commands/grantpower.txt
@@ -55,6 +55,19 @@ OnCall:
detachrid();
attachrid(.@ori);
delitem .@ite, 1;
+ switch (.@ite) {
+ case DemureAxe:
+ $DEMUR_HOLDER$ = .@request$; break;
+ case Tyranny:
+ $TYRAN_HOLDER$ = .@request$; break;
+ case Runestaff:
+ $RUNES_HOLDER$ = .@request$; break;
+ case AegisShield:
+ $AEGIS_HOLDER$ = .@request$; break;
+ default:
+ Exception("Invalid legendary item "+str(.@ite),
+ RB_DEFAULT|RB_IRCBROADCAST); break;
+ }
} else {
Exception("Player not found.", RB_ISFATAL|RB_SPEECH);
}
diff --git a/npc/functions/hub.txt b/npc/functions/hub.txt
index 9974ae624..6f8378660 100644
--- a/npc/functions/hub.txt
+++ b/npc/functions/hub.txt
@@ -225,6 +225,8 @@ function script HUB_Logout {
// Register logout time
if (!.@dead)
CHAREG_CLEANUP=gettimetick(2);
+
+ callfunc "02524_Avenge_BlackBox", .@dead;
return;
}
diff --git a/npc/functions/util.txt b/npc/functions/util.txt
index 1966ce6df..5d510a709 100644
--- a/npc/functions/util.txt
+++ b/npc/functions/util.txt
@@ -633,6 +633,17 @@ function script alignment {
return 0;
}
+// Returns if you are a legendary weapon holder
+// islegendary( {strcharinfo} )
+function script islegendary {
+ .@you$ = getarg(0, strcharinfo(0));
+ return (.@you$ == $LIGHT_HOLDER$ ||
+ .@you$ == $AEGIS_HOLDER$ ||
+ .@you$ == $TYRAN_HOLDER$ ||
+ .@you$ == $RUNES_HOLDER$ ||
+ .@you$ == $DEMUR_HOLDER$);
+}
+
// Returns if an event is a ranked Aurora Event or not
// (Had to be moved from functions/aurora.txt)
function script FYEventUsesRanking {