aboutsummaryrefslogtreecommitdiff
path: root/xp
diff options
context:
space:
mode:
Diffstat (limited to 'xp')
-rw-r--r--xp/level.go55
1 files changed, 49 insertions, 6 deletions
diff --git a/xp/level.go b/xp/level.go
index aeb7d91..bbcc71f 100644
--- a/xp/level.go
+++ b/xp/level.go
@@ -47,26 +47,69 @@ func LastEventUpdate(c *Copaing) {
h := c.HourSinceLastEvent()
l := Lose(h, c.XP)
xp := c.XPAlreadyRemoved()
+ oldXP := c.XP
if l-xp < 0 {
utils.SendWarn("lose - xp already removed is negative", "lose", l, "xp", xp)
c.XP = 0
} else {
- c.XP = c.XP - l + c.XPAlreadyRemoved()
+ calc := int(c.XP) - int(l) + int(c.XPAlreadyRemoved())
+ if calc < 0 {
+ c.XP = 0
+ } else {
+ c.XP = uint(calc)
+ }
+ }
+ if oldXP != c.XP {
+ c.Save()
}
- c.Save()
c.SetLastEvent()
}
func XPUpdate(c *Copaing) {
+ oldXP := c.XP
+ if oldXP == 0 {
+ return
+ }
h := c.HourSinceLastEvent()
l := Lose(h, c.XP)
xp := c.XPAlreadyRemoved()
if l-xp < 0 {
- utils.SendWarn("lose - xp already removed is negative", "lose", l, "xp", xp)
+ utils.SendWarn("lose - xp_removed is negative", "lose", l, "xp removed", xp)
c.AddXPAlreadyRemoved(0)
} else {
- c.XP = c.XP - l + xp
- c.AddXPAlreadyRemoved(l - xp)
+ calc := int(c.XP) - int(l) + int(xp)
+ if calc < 0 {
+ c.AddXPAlreadyRemoved(c.XP)
+ c.XP = 0
+ } else {
+ c.XP = uint(calc)
+ c.AddXPAlreadyRemoved(l - xp)
+ }
+ }
+ if oldXP != c.XP {
+ utils.SendDebug("Save XP", "old", oldXP, "new", c.XP, "user", c.DiscordID)
+ c.Save()
}
- c.Save()
}
+
+//func PeriodicReducer(s *discordgo.Session) {
+// var wg sync.WaitGroup
+// for _, g := range s.State.Guilds {
+// for _, m := range utils.FetchGuildUser(s, g.ID) {
+// if m.User.Bot {
+// continue
+// }
+// wg.Add(1)
+// go func() {
+// utils.SendDebug("Async reducer", "user", m.DisplayName(), "guild", g.Name)
+// c := GetCopaing(m.User.ID, g.ID)
+// XPUpdate(c)
+// wg.Done()
+// }()
+// }
+// wg.Wait() // finish the entire guild before starting another
+// utils.SendDebug("Guild finished", "guild", g.Name)
+// time.Sleep(10 * time.Second) // sleep prevents from spamming the Discord API
+// }
+// utils.SendDebug("Periodic reduce finished", "len(guilds)", len(s.State.Guilds))
+//}