summaryrefslogtreecommitdiff
path: root/calc.py
blob: a55af718bafffe0df55b164172949140d106c014 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
from helpers import *

evals_toggle_list = []
calc_perm = "utils.calc"

def lex(msg):
  fullmessage = msg
  msg = list(msg)
  msg.append("f")
  print(msg)
  tok = ""
  expression = False
  counter = 0
  startPos = 0
  startPos_set = False
  endPos = 0
  for char in msg: 
    counter += 1
    if char.isnumeric():
      if not expression:
        startPos = counter
      expression = True
      tok += char
    elif char == "+" or char == "-" or char == "*" or char == "/":
      tok += char
    elif tok == " ":
      if not expression:
        tok = ""
      else:
        tok += char
    elif char.isalpha():
      if expression:
        print("It is an expression")
        msg = "".join(msg)

        print("Before evaluating: "+msg)
        print("Before evaluating (Token): "+tok)
        print("So that's str eval tok" +str(eval(tok)))

        return_value = msg[0:startPos-1]
        return_value += str(eval(tok))
        return_value += msg[counter:]
        print("Evaluated it: "+msg)
        expression = False
        return return_value
      else:
        print("It is NOT an expression - " + tok)
        tok = ""
  return fullmessage
 


@hook.event("player.AsyncPlayerChatEvent", "high")
def on_calc_chat(event):
  try:
    sender = event.getPlayer()
    message = event.getMessage()
    if sender.getName() not in evals_toggle_list:
      return
    output = lex(message)
    event.setMessage(colorify(str(output)))
  except Exception as e:
    print(e)
  
@hook.command("calc", description="Toggles chat calculations")
def on_calc_command(sender, args):
  plugin_header(sender, "Chat Calculator")
  if len(args):
    if not sender.hasPermission(calc_perm):
      noperm(sender)
      return
    target = args[0].lower()
    if not is_player(target):
      msg(sender, "&cLooks like %s isn't a player at all!" % target)
      return
    target = server.getPlayer(target)
    
    status = "disabled"
    if target.getName() in evals_toggle_list:
      evals_toggle_list.remove(target.getName())
    else:
      status = "enabled"
      evals_toggle_list.append(target.getName())
    msg(target, "&6We just &e%s&6 Chat Calculator for you!" % status)
    msg(sender, "&6We &e%s&6 this player's Chat Calculator" % status)
  
  
    return
  
  status = "disabled"
  if sender.getName() in evals_toggle_list:
    evals_toggle_list.remove(sender.getName())
  else:
    status = "enabled"
    evals_toggle_list.append(sender.getName())
  msg(sender, "&6We just &e%s&6 Chat Calculator for you!" % status)