summaryrefslogtreecommitdiff
path: root/net/being.py
diff options
context:
space:
mode:
authorLivio Recchia <recchialivio@libero.it>2020-02-10 23:06:34 +0100
committerLivio Recchia <recchialivio@libero.it>2020-02-10 23:06:34 +0100
commit9a13903a2f7d3a65fdf15a65fb59cccd622e2066 (patch)
tree9403b7dff39eb5e5d7fa0f79efb69b496add4c4b /net/being.py
parent11cc316b74d5f3f283413a33e7693b314741aa4a (diff)
downloadmanachat-9a13903a2f7d3a65fdf15a65fb59cccd622e2066.tar.gz
manachat-9a13903a2f7d3a65fdf15a65fb59cccd622e2066.tar.bz2
manachat-9a13903a2f7d3a65fdf15a65fb59cccd622e2066.tar.xz
manachat-9a13903a2f7d3a65fdf15a65fb59cccd622e2066.zip
Initial commit
Diffstat (limited to 'net/being.py')
-rw-r--r--net/being.py63
1 files changed, 63 insertions, 0 deletions
diff --git a/net/being.py b/net/being.py
new file mode 100644
index 0000000..ad7ad57
--- /dev/null
+++ b/net/being.py
@@ -0,0 +1,63 @@
+import monsterdb
+
+
+def job_type(job):
+ if (job <= 25 or (job >= 4001 and job <= 4049)):
+ return "player"
+ elif (job >= 46 and job <= 1000):
+ return "npc"
+ elif (job > 1000 and job <= 2000):
+ return "monster"
+ elif (job == 45):
+ return "portal"
+
+
+class Being:
+ def __init__(self, being_id, job):
+ self.id = being_id
+ self.job = job
+ self.speed = 0
+ self.x = 0
+ self.y = 0
+
+ if job_type(job) == "monster":
+ self._name = monsterdb.monster_db.get(job, "")
+ else:
+ self._name = ""
+
+ @property
+ def name(self):
+ if len(self._name) > 0:
+ return self._name
+ return "{{ID:" + str(self.id) + "}}"
+
+ @name.setter
+ def name(self, newname):
+ self._name = newname
+
+ @property
+ def type(self):
+ return job_type(self.job)
+
+ def __repr__(self):
+ return self.name
+
+
+class BeingsCache(dict):
+
+ def __init__(self, name_request_func, *args, **kwargs):
+ dict.__init__(self, *args, **kwargs)
+ self._name_request_func = name_request_func
+
+ def findId(self, name, type_="player"):
+ for id_, being in self.iteritems():
+ if being.name == name and being.type == type_:
+ return id_
+ return -10
+
+ def findName(self, id_, job=1):
+ if id_ not in self:
+ self[id_] = Being(id_, job)
+ if job_type(job) in ("player", "npc"):
+ self._name_request_func(id_)
+ return self[id_].name