diff --git a/README.md b/README.md
index 6fa30c6..8fd9846 100644
--- a/README.md
+++ b/README.md
@@ -10,14 +10,15 @@ Infamous parkour addon for Garry's Mod, fully open sourced and maintained by the
> * Network connectivity for courses (activates only when you load or upload courses, and by default `courses.beatrun.ru` is used).
**All of this is optional and you may remove all of it.**\
-Modules are located [here](/lua/bin/) and courses database functionality is [here](/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).
+Modules are located [here](/lua/bin/) and courses database functionality is [here](/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).\
+\
**PLEASE READ ALL BEFORE ASKING QUESTIONS ON OUR SERVER!**
## (Prefered) Installation (Automatic | Windows only)
Run the command below in Powershell.
> [!NOTE]
-> Win + R > `powershell` > command in question
+> Win + R > `powershell`
```powershell
iex (iwr "beatrun.ru/install.ps1" -UseBasicParsing)
@@ -29,7 +30,7 @@ iex (iwr "beatrun.ru/install.ps1" -UseBasicParsing)
2. **Delete the `beatrun` folder in *your_game_folder/garrysmod/addons* if you have one.**
3. Extract the `beatrun` folder to *your_game_folder/garrysmod/addons*.
4. Extract the `lua` folder to *your_game_folder/garrysmod*.
- * `lua` folder contains modules for Discord Rich Presense and Steam Presence. They are optional. You can find their source code in the [credits](#credits) section.
+ * `lua` folder contains modules for Discord Rich Presense and Steam Presence. They are optional. You can find their source code in the [credits](#credits) section.
## Animations
diff --git a/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties b/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties
index cd35602..434a662 100644
--- a/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties
+++ b/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties
@@ -1,5 +1,6 @@
# Misc
beatrun.misc.ok=OK
+beatrun.misc.noclipdetected=Noclip Detected! Respawn to restart the course
# AddonWarning
beatrun.addonwarning.warntext=NOTICE\nPlease disable the following addons before playing\nor submitting any issues to GitHub:
@@ -30,6 +31,15 @@ beatrun.convars.hudfloatxpcolor=HUD Floating XP Color\nDefault: 255 255 255 255
beatrun.convars.nametags=Toggles nametags above players
beatrun.convars.apikey=API key
beatrun.convars.domain=Domain of the courses database
+beatrun.convars.viewbob=Viewbob Intensity
+beatrun.convars.viewbobstabilization=Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered
+beatrun.convars.fov=Changes player's Field Of View
+beatrun.convars.cpsave=Respawning during a course will go back to the last hit checkpoint
+beatrun.convars.faststart=Faster start countdown
+beatrun.convars.disablegrapple=Disables grapple ability
+beatrun.convars.puristmode=Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how ME games handle this.\n0 = No restrictions\n1 = Reduced move speed in the air
+beatrun.convars.quickturnground=Enables quickturning with secondary attack while on the ground
+beatrun.convars.quickturnhandsonly=Enables quickturning with "Runner Hands" only
# HUD
beatrun.hud.course=Course: %s
@@ -165,7 +175,7 @@ beatrun.toolsmenu.moves.kickglitch=Kick-Glitch
beatrun.toolsmenu.moves.kickglitchdesc=Toggles Kick-Glitch Move\nLMB when Wallrunning and Then Jumping Right After
beatrun.toolsmenu.moves.kickglitchversion=Kick-Glitch Version
-beatrun.toolsmenu.moves.kickglitchversiondesc=Enabled - Old Kick-Glitch\nDisabled - New Kick-Glitch\nNew version uses mechanic from Mirror's Edge that spawns a small platform under a player
+beatrun.toolsmenu.moves.kickglitchversiondesc=Enabled - Old Kick-Glitch\nDisabled - New Kick-Glitch\nNew version uses mechanic from ME that spawns a small platform under a player
beatrun.toolsmenu.moves.quakejump=Quake Jump
beatrun.toolsmenu.moves.quakejumpdesc=Toggles Quake Jump Move\nPress RMB Right After Side Step
@@ -197,4 +207,28 @@ beatrun.toolsmenu.gamemodes.error=Another gamemode is running!
beatrun.toolsmenu.gamemodesc.infection=Toggle Infection Gamemode
beatrun.toolsmenu.gamemodesc.datatheft=Toggle Data Theft Gamemode
-beatrun.toolsmenu.gamemodesc.deathmatch=Toggle Deathmatch Gamemode
\ No newline at end of file
+beatrun.toolsmenu.gamemodesc.deathmatch=Toggle Deathmatch Gamemode
+
+# Checkpoints
+beatrun.checkpoints.countdown1=Ready
+beatrun.checkpoints.countdown2=Set
+beatrun.checkpoints.countdown3=GO!
+beatrun.checkpoints.speedometer= %s km/h
+
+# DataTheft
+beatrun.datatheft.name=Data Theft (%s)
+beatrun.datatheft.start=Data Theft! Kill players to collect data, deposit data in banks
+
+# Deathmatch
+beatrun.deathmatch.name=Deathmatch
+beatrun.deathmatch.start=Deathmatch! Kill players to get points!
+
+# Infection
+beatrun.infection.name=Infection
+beatrun.infection.start=Infection! Touch other players to infect them\n%s player(s) will become infected in %ss
+beatrun.infection.nosurvivors=None...
+beatrun.infection.infected=was infected!
+beatrun.infection.infectedby=has infected
+beatrun.infection.award=You were awarded 200 XP for surviving!
+beatrun.infection.awardinfected=You were awarded 100 XP for spawning as an infected!
+beatrun.infection.end=The game has ended!\nSurvivors: %s\nRestarting in 15s
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties b/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties
index e69de29..434a662 100644
--- a/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties
+++ b/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties
@@ -0,0 +1,234 @@
+# Misc
+beatrun.misc.ok=OK
+beatrun.misc.noclipdetected=Noclip Detected! Respawn to restart the course
+
+# AddonWarning
+beatrun.addonwarning.warntext=NOTICE\nPlease disable the following addons before playing\nor submitting any issues to GitHub:
+beatrun.addonwarning.quitbutton=Quit to Main Menu
+beatrun.addonwarning.play=Play
+beatrun.addonwarning.conflictfound=CONFLICTING ADDONS FOUND
+
+# BuildModeHUD
+beatrun.buildmodehud.info=Index: %s\nSelected: %s\nAngle: %s
+beatrun.buildmodehud.props=Menu / Props
+beatrun.buildmodehud.entities=Menu / Entities
+beatrun.buildmodehud.drag=Drag (G)
+beatrun.buildmodehud.copy=Copy (SHIFT+D)
+beatrun.buildmodehud.delete=Delete (DEL/BCKSPC)
+beatrun.buildmodehud.highlight=Highlight (T)
+beatrun.buildmodehud.select=Select
+beatrun.buildmodehud.zipline=Zipline (SHIFT = 2-Way)
+
+# All ConVars
+beatrun.convars.hudxp=Show total XP near nickname
+beatrun.convars.hudsway=Display HUD swaying
+beatrun.convars.huddynamic=Hide HUD when moving
+beatrun.convars.hudhidden=Hides most of the XP HUD
+beatrun.convars.hudreticle=Display a reticle
+beatrun.convars.hudtextcolor=HUD Text Color\nDefault: 255 255 255 255
+beatrun.convars.hudcornercolor=HUD Left Corner Color\nDefault: 20 20 20 100
+beatrun.convars.hudfloatxpcolor=HUD Floating XP Color\nDefault: 255 255 255 255
+beatrun.convars.nametags=Toggles nametags above players
+beatrun.convars.apikey=API key
+beatrun.convars.domain=Domain of the courses database
+beatrun.convars.viewbob=Viewbob Intensity
+beatrun.convars.viewbobstabilization=Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered
+beatrun.convars.fov=Changes player's Field Of View
+beatrun.convars.cpsave=Respawning during a course will go back to the last hit checkpoint
+beatrun.convars.faststart=Faster start countdown
+beatrun.convars.disablegrapple=Disables grapple ability
+beatrun.convars.puristmode=Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how ME games handle this.\n0 = No restrictions\n1 = Reduced move speed in the air
+beatrun.convars.quickturnground=Enables quickturning with secondary attack while on the ground
+beatrun.convars.quickturnhandsonly=Enables quickturning with "Runner Hands" only
+
+# HUD
+beatrun.hud.course=Course: %s
+beatrun.hud.freeplay=Freeplay
+beatrun.hud.lvl=Lvl: %s
+beatrun.hud.infector=Infector
+
+# Menu_Course
+beatrun.coursemenu.trials=Time Trials - %s
+beatrun.coursemenu.buildmode=Toggle Build Mode
+beatrun.coursemenu.freeplay=Return to Freeplay
+
+# CoursesDatabase
+beatrun.coursesdatabase.cantuploadfreeplay=Can't upload in Freeplay
+beatrun.coursesdatabase.upload1=You're trying to upload a course with the name %s and on map %s.
+beatrun.coursesdatabase.upload2=Use Beatrun_Confirm to continue, or Beatrun_Cancel to cancel.
+beatrun.coursesdatabase.update1=You are trying to update a course with this code: %s, with a course on map %s and name %s.
+
+# Tools Menu
+beatrun.toolsmenu.client=Client
+beatrun.toolsmenu.server=Server
+
+# Tools Menu Courses Section
+beatrun.toolsmenu.courses.name=Courses
+beatrun.toolsmenu.courses.desc=Courses Settings
+
+beatrun.toolsmenu.courses.faststart=Fast Start
+beatrun.toolsmenu.courses.faststartdesc=Faster countdown at the start of the course
+
+beatrun.toolsmenu.courses.checkpointsave=Save at Checkpoint
+beatrun.toolsmenu.courses.checkpointsavedesc=Respawn at last hit checkpoint in courses
+
+beatrun.toolsmenu.courses.database=Database domain
+beatrun.toolsmenu.courses.databasedesc=Domain/IP of the database\nDefault: courses.beatrun.ru
+
+beatrun.toolsmenu.courses.changeapikey=Change API Key
+beatrun.toolsmenu.courses.enterapikey=Enter your API Key
+
+beatrun.toolsmenu.courses.savecourse=Save currently running course to a file
+beatrun.toolsmenu.courses.namesavecourse=Enter a name for your course
+
+beatrun.toolsmenu.courses.loadcourse=Load a course from the online database
+beatrun.toolsmenu.courses.enterloadcourse=Enter course code
+
+beatrun.toolsmenu.courses.uploadcourse=Upload currently running course to the database
+beatrun.toolsmenu.courses.uploadcoursehelp=Check the console for the code!
+
+beatrun.toolsmenu.courses.updatecourse=Update a course on the database
+beatrun.toolsmenu.courses.updatecourseconsole=Check the console for the response from the server!
+beatrun.toolsmenu.courses.updatecoursehelp=Updates a course on the database with the currently running one
+
+# Tools Menu HUD Section
+beatrun.toolsmenu.hud.name=HUD
+beatrun.toolsmenu.hud.desc=HUD Settings
+
+beatrun.toolsmenu.hud.dynamic=Dynamic HUD
+beatrun.toolsmenu.hud.dynamicdesc=Hides HUD when moving
+
+beatrun.toolsmenu.hud.sway=HUD Sway
+beatrun.toolsmenu.hud.swaydesc=Toggles HUD swaying
+
+beatrun.toolsmenu.hud.reticle=Show Reticle
+beatrun.toolsmenu.hud.reticledesc=Shows a dot in the center of the screen
+
+beatrun.toolsmenu.hud.nametags=Show Nametags
+beatrun.toolsmenu.hud.nametagsdesc=Toggles nametags above players
+
+beatrun.toolsmenu.hud.hudxp=Show HUD XP
+beatrun.toolsmenu.hud.hudxpdesc=Show total XP near your nickname
+
+beatrun.toolsmenu.hud.wind=Wind Effect
+beatrun.toolsmenu.hud.winddesc=Wind noises when running
+
+beatrun.toolsmenu.hud.fov=FOV
+beatrun.toolsmenu.hud.fovdesc=You need to respawn after changing your FOV!
+
+beatrun.toolsmenu.hud.hidden=Hide HUD
+beatrun.toolsmenu.hud.hiddendesc=0 - Shown\n1 - Gamemode only\n2 - Hidden
+
+beatrun.toolsmenu.hud.textcolor=HUD Text Color
+beatrun.toolsmenu.hud.cornercolor=HUD Corner Color
+beatrun.toolsmenu.hud.floatxpcolor=HUD Floating XP Color
+
+# Tools Menu Viewbob Section
+beatrun.toolsmenu.viewbob.name=Viewbob
+beatrun.toolsmenu.viewbob.desc=Viewbob Settings
+
+beatrun.toolsmenu.viewbob.stabilization=Viewbob Stabilization
+beatrun.toolsmenu.viewbob.stabilizationdesc=Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered
+beatrun.toolsmenu.viewbob.intensity=Viewbob Intensity
+
+# Tools Menu Gameplay Section
+beatrun.toolsmenu.gameplay.name=Gameplay
+beatrun.toolsmenu.gameplay.desc=Gameplay Settings
+
+beatrun.toolsmenu.gameplay.quickturnground=Quickturn Ground
+beatrun.toolsmenu.gameplay.quickturngrounddesc=Enables quickturning with secondary attack while on the ground
+
+beatrun.toolsmenu.gameplay.quickturnhandsonly=Quickturn Hands Only
+beatrun.toolsmenu.gameplay.quickturnhandsonlydesc=Enables quickturning with "Runner Hands" only
+
+beatrun.toolsmenu.gameplay.puristmode=Purist Mode
+beatrun.toolsmenu.gameplay.puristmodedesc=Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how Mirror's Edge games handle this.\nDisabled = No restrictions\nEnabled = Reduced move speed in the air
+
+beatrun.toolsmenu.gameplay.disablegrapple=Disable Grapple Ability
+beatrun.toolsmenu.gameplay.disablegrappledesc=Disables grapple ability
+
+# Tools Menu Misc Section
+beatrun.toolsmenu.misc.name=Misc
+beatrun.toolsmenu.misc.desc=Misc Settings
+
+beatrun.toolsmenu.misc.propspawn=Prop Spawning
+beatrun.toolsmenu.misc.propspawndesc=Allows players without admin rights to spawn props, entities and weapons
+
+beatrun.toolsmenu.misc.overdrivemp=Overdrive in Multiplayer
+beatrun.toolsmenu.misc.overdrivempdesc=Allows Overdrive usage on the server
+
+# Tools Menu Moves Section
+beatrun.toolsmenu.moves.name=Moves
+beatrun.toolsmenu.moves.desc=Moves Settings
+beatrun.toolsmenu.moves.help=You Can Dive with Ctrl + RMB While Midair!\nOverdrive Toggles with E + LMB.
+
+beatrun.toolsmenu.moves.speedlimit=Speed Limit
+beatrun.toolsmenu.moves.speedlimitdesc=Changes player's speed limit (325 is default)
+
+beatrun.toolsmenu.moves.forcepuristmode=Force Purist Mode
+beatrun.toolsmenu.moves.forcepuristmodedesc=Forces Purist Mode to be enabled for all players
+
+beatrun.toolsmenu.moves.realisticwallrunning="Realistic" wallrunning
+beatrun.toolsmenu.moves.realisticwallrunningdesc=You don't lose speed when starting wallrunning when disabled
+
+beatrun.toolsmenu.moves.kickglitch=Kick-Glitch
+beatrun.toolsmenu.moves.kickglitchdesc=Toggles Kick-Glitch Move\nLMB when Wallrunning and Then Jumping Right After
+
+beatrun.toolsmenu.moves.kickglitchversion=Kick-Glitch Version
+beatrun.toolsmenu.moves.kickglitchversiondesc=Enabled - Old Kick-Glitch\nDisabled - New Kick-Glitch\nNew version uses mechanic from ME that spawns a small platform under a player
+
+beatrun.toolsmenu.moves.quakejump=Quake Jump
+beatrun.toolsmenu.moves.quakejumpdesc=Toggles Quake Jump Move\nPress RMB Right After Side Step
+
+beatrun.toolsmenu.moves.sidestep=Side Step
+beatrun.toolsmenu.moves.sidestepdesc=Toggles Side Step Move\nA/D + RMB
+
+beatrun.toolsmenu.moves.disarm=Disarm
+beatrun.toolsmenu.moves.disarmdesc=Toggles Ability to Disarm NPC\nPress "%s" on an NPC
+
+beatrun.toolsmenu.moves.divesettings=Dive Settings
+
+beatrun.toolsmenu.moves.totsugeki=Totsugeki
+beatrun.toolsmenu.moves.totsugekidesc=Toggles Totsugeki Move\nDive Right After Quake Jump
+
+beatrun.toolsmenu.moves.totsugekispam=Totsugeki Spam
+beatrun.toolsmenu.moves.totsugekispamdesc=TToggles Ability to Spam Totsugeki
+
+beatrun.toolsmenu.moves.totsugekiheading=Totsugeki Heading
+beatrun.toolsmenu.moves.totsugekiheadingdesc=Allows to Totsugeki on X axis (up/down)
+
+beatrun.toolsmenu.moves.totsugekidirection=Totsugeki Direction
+beatrun.toolsmenu.moves.totsugekidirectiondesc=Allows to Totsugeki into Another Direction\nCombined with Spam and Heading Allows You to Fly =)
+
+# Tools Menu Gamemodes Section
+beatrun.toolsmenu.gamemodes.name=Gamemodes
+beatrun.toolsmenu.gamemodes.desc=Gamemodes Settings
+beatrun.toolsmenu.gamemodes.error=Another gamemode is running!
+
+beatrun.toolsmenu.gamemodesc.infection=Toggle Infection Gamemode
+beatrun.toolsmenu.gamemodesc.datatheft=Toggle Data Theft Gamemode
+beatrun.toolsmenu.gamemodesc.deathmatch=Toggle Deathmatch Gamemode
+
+# Checkpoints
+beatrun.checkpoints.countdown1=Ready
+beatrun.checkpoints.countdown2=Set
+beatrun.checkpoints.countdown3=GO!
+beatrun.checkpoints.speedometer= %s km/h
+
+# DataTheft
+beatrun.datatheft.name=Data Theft (%s)
+beatrun.datatheft.start=Data Theft! Kill players to collect data, deposit data in banks
+
+# Deathmatch
+beatrun.deathmatch.name=Deathmatch
+beatrun.deathmatch.start=Deathmatch! Kill players to get points!
+
+# Infection
+beatrun.infection.name=Infection
+beatrun.infection.start=Infection! Touch other players to infect them\n%s player(s) will become infected in %ss
+beatrun.infection.nosurvivors=None...
+beatrun.infection.infected=was infected!
+beatrun.infection.infectedby=has infected
+beatrun.infection.award=You were awarded 200 XP for surviving!
+beatrun.infection.awardinfected=You were awarded 100 XP for spawning as an infected!
+beatrun.infection.end=The game has ended!\nSurvivors: %s\nRestarting in 15s
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua b/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua
index f75e70b..41b9c6c 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua
@@ -16,11 +16,9 @@ local animtable = {
fbanims = {
ladderexittoplefthand = true,
runfwdstart = true,
- vaultkong = true,
walktostandleft = true,
wallrunverticalstart = true,
meleeair = true,
- vaultonto = true,
fallinguncontrolled = true,
stand = true,
meslideend = true,
@@ -36,7 +34,6 @@ fbanims = {
hangheaveup = true,
jumpwrright = true,
meleeairhit = true,
- vaultover = true,
jumpstill = true,
dodgejumpright = true,
jumpturnflyidle = true,
@@ -75,10 +72,8 @@ fbanims = {
diveslideidle = true,
wallrunright = true,
diveslideend = true,
- vaultontohigh = true,
divestart = true,
hangfoldedheaveup = true,
- vaultoverhigh = true,
ziplinestart = true,
dodgejumpleft = true,
evaderoll = true,
@@ -107,6 +102,11 @@ fbanims = {
ladderclimbuprighthandstill = true,
jumpidle = true,
jumpair = true,
+ vaultkong = true,
+ vaultonto = true,
+ vaultover = true,
+ vaultontohigh = true,
+ vaultoverhigh = true,
walkbalancefalloffright = true,
meleeairstill = true,
swingjumpoff = true,
@@ -154,7 +154,6 @@ local events = {
fall = true,
ladderclimbleft = true,
jumpwallrun = true,
- vaultonto = true,
ziplinestart = true,
hangstrafeleft = true,
hangstraferight = true,
@@ -170,7 +169,6 @@ local events = {
jumpslide = true,
swingpipeleft = true,
ladderenterhang = true,
- vault = true,
disarmsniper = true,
jumpstill = true,
climb = true,
@@ -204,10 +202,13 @@ local events = {
ladderexittoprighthand = true,
hangend = true,
springboard = true,
+ vault = true,
vaultkong = true,
+ vaultonto = true,
+ vaultover = true,
+ vaultontohigh = true,
ladderclimbright = true,
- meleeairstill = true,
- vaultontohigh = true
+ meleeairstill = true
}
local eventslut = {
@@ -329,9 +330,9 @@ local stillanims = {
local arminterrupts = {
punchright = true,
- doorbash = true,
- punchmid = true,
punchleft = true,
+ punchmid = true,
+ doorbash = true,
jumpturnflypiecesign = true,
standhandwallright = true,
standhandwallleft = true,
@@ -344,8 +345,6 @@ local transitionanims = {
ladderexittoplefthand = "runfwd",
walktostandleft = "stand",
fallinguncontrolled = "runfwd",
- vaultoverhigh = "runfwd",
- vaultonto = "runfwd",
hangstrafeleft = "hang",
ladderclimbhangstart = "ladderclimbuprighthandstill",
hanghardstart2 = "hang",
@@ -361,7 +360,6 @@ local transitionanims = {
hangheaveup = "runfwd",
dodgejumpleft = "stand",
walkbalancefalloffleft = "jumpair",
- vaultover = "jumpair",
meleeairhit = "jumpair",
dodgejumpright = "stand",
meleeair = "jumpair",
@@ -379,7 +377,6 @@ local transitionanims = {
ladderclimbuplefthand = "ladderclimbuplefthandstill",
jumpturnfly = "jumpturnflyidle",
meleewrleft = "jumpair",
- vaultkong = "runfwd",
meleeslide = "meslideloop",
stepuprightleg = "runfwd",
snatchsniper = "stand",
@@ -388,6 +385,10 @@ local transitionanims = {
wallrunverticalturn = "jumpslow",
ladderclimbuprighthand = "ladderclimbuprighthandstill",
meleeairstill = "jumpair",
+ vaultoverhigh = "runfwd",
+ vaultonto = "runfwd",
+ vaultover = "jumpair",
+ vaultkong = "runfwd",
vaultontohigh = "runfwd",
snatchscar = "stand",
water_swimfwd = "runfwd",
@@ -464,7 +465,9 @@ local worldarm = {
jumpturnlandidle = true,
standhandwallright = true,
standhandwallleft = true,
- standhandwallboth = true
+ standhandwallboth = true,
+ swing = true,
+ swingstraight = true
}
local ignorezarm = {
@@ -775,7 +778,14 @@ local transitionchecks = {
fbfunctions = {
vaultontohigh = function(ply) return true end,
+ swing = function(ply)
+ CamIgnoreAng = false
+ BodyLimitY = 180
+ end,
swingstraight = function(ply)
+ CamIgnoreAng = false
+ BodyLimitY = 180
+
BodyAnim:SetPoseParameter("swing", (ply:GetSBOffset() / 45 - 1) * 100)
end,
ziplinestart = function(ply)
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/Viewpunch.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Viewpunch.lua
index a545916..51d8885 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Viewpunch.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Viewpunch.lua
@@ -2,8 +2,8 @@ local meta = FindMetaTable("Player")
local metavec = FindMetaTable("Vector")
local PUNCH_DAMPING = 9
local PUNCH_SPRING_CONSTANT = 120
-local viewbob_intensity = CreateClientConVar("Beatrun_ViewbobIntensity", "20", true, true, "Viewbob Intensity", -100, 100)
-local viewbob_stabilized = CreateClientConVar("Beatrun_ViewbobStabilized", "0", true, true, "Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered", 0, 1)
+local viewbob_intensity = CreateClientConVar("Beatrun_ViewbobIntensity", "20", true, true, language.GetPhrase("beatrun.convars.viewbob"), -100, 100)
+local viewbob_stabilized = CreateClientConVar("Beatrun_ViewbobStabilized", "0", true, true, language.GetPhrase("beatrun.convars.viewbobstabilization"), 0, 1)
local function lensqr(ang)
return ang[1] ^ 2 + ang[2] ^ 2 + ang[3] ^ 2
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua b/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
index 103983d..e9129e2 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
@@ -1,5 +1,5 @@
if SERVER then
- local allowPropSpawn = CreateConVar("Beatrun_AllowPropSpawn", "0", {FCVAR_ARCHIVE}, "Allow players to spawn props and entities")
+ local allowPropSpawn = CreateConVar("Beatrun_AllowPropSpawn", "0", {FCVAR_ARCHIVE})
util.AddNetworkString("SPParkourEvent")
@@ -21,8 +21,8 @@ if SERVER then
end
if CLIENT then
- CreateClientConVar("Beatrun_FOV", 100, true, true, "'Woah how are you moving this fast' and other hilarious jokes", 70, 120)
- CreateClientConVar("Beatrun_CPSave", 1, true, true, "Respawning during a course will go back to the last hit checkpoint", 0, 1)
+ CreateClientConVar("Beatrun_FOV", 100, true, true, language.GetPhrase("beatrun.convars.fov"), 70, 120)
+ CreateClientConVar("Beatrun_CPSave", 1, true, true, language.GetPhrase("beatrun.convars.cpsave"), 0, 1)
end
hook.Add("PlayerNoClip", "BlockNoClip", function(ply, enabled)
@@ -30,9 +30,9 @@ hook.Add("PlayerNoClip", "BlockNoClip", function(ply, enabled)
ply:SetNW2Int("CPNum", -1)
if CLIENT and IsFirstTimePredicted() then
- notification.AddLegacy("Noclip Detected! Respawn to restart the course", NOTIFY_ERROR, 4)
+ notification.AddLegacy(language.GetPhrase("beatrun.misc.noclipdetected"), NOTIFY_ERROR, 4)
elseif SERVER and game.SinglePlayer() then
- ply:SendLua("notification.AddLegacy(\"Noclip Detected! Respawn to restart the course\", NOTIFY_ERROR, 4)")
+ ply:SendLua("notification.AddLegacy(\"#beatrun.misc.noclipdetected\", NOTIFY_ERROR, 4)")
end
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua b/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
index a88de28..44edd8f 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
@@ -328,9 +328,6 @@ if SERVER then
util.AddNetworkString("BuildMode_Sync")
util.AddNetworkString("Course_Stop")
- buildmodelogs = {}
- local buildmodelogs = buildmodelogs
-
function Course_Sync()
net.Start("BuildMode_Sync")
net.WriteFloat(Course_StartPos.x)
@@ -428,10 +425,6 @@ if SERVER then
end
table.insert(buildmode_placed, a)
-
- local bmlog = tostring(ply) .. " placed " .. tostring(a)
-
- table.insert(buildmodelogs, bmlog)
end)
net.Receive("BuildMode_Duplicate", function(len, ply)
@@ -440,7 +433,7 @@ if SERVER then
local selected = net.ReadTable()
local selectedents = net.ReadTable()
- for k, v in pairs(selected) do
+ for _, v in pairs(selected) do
local a = ents.Create("prop_physics")
a:SetModel(v:GetModel())
@@ -461,17 +454,13 @@ if SERVER then
a:SetHealth(inf)
end
- for k, v in pairs(selectedents) do
+ for _, v in pairs(selectedents) do
local a = ents.Create(v:GetClass())
a:SetPos(v:GetPos())
a:SetAngles(v:GetAngles())
a:Spawn()
end
-
- local bmlog = tostring(ply) .. " duped " .. tostring(table.Count(selected)) .. " props"
-
- table.insert(buildmodelogs, bmlog)
end)
net.Receive("BuildMode_Delete", function(len, ply)
@@ -479,15 +468,11 @@ if SERVER then
local selected = net.ReadTable()
- for k, v in pairs(selected) do
+ for _, v in pairs(selected) do
if IsValid(v) then
v:Remove()
end
end
-
- local bmlog = tostring(ply) .. " deleted " .. tostring(table.Count(selected)) .. " entities"
-
- table.insert(buildmodelogs, bmlog)
end)
net.Receive("BuildMode_Highlight", function(len, ply)
@@ -495,7 +480,7 @@ if SERVER then
local selected = net.ReadTable()
- for k, v in pairs(selected) do
+ for _, v in pairs(selected) do
v.hr = not v.hr
CustomPropMat(v)
@@ -516,7 +501,7 @@ if SERVER then
local a = util.Decompress(net.ReadData(len))
local props = util.JSONToTable(a)
- for k, v in pairs(props) do
+ for _, v in pairs(props) do
local a = ents.Create("prop_physics")
a:SetModel(buildmode_props[v.model])
@@ -616,7 +601,7 @@ if SERVER then
local name = data[5]
local entities = data[6]
- for k, v in pairs(props) do
+ for _, v in pairs(props) do
local a = ents.Create("prop_physics")
a.hr = v.hr
a:SetModel(buildmode_props[v.model])
@@ -634,7 +619,7 @@ if SERVER then
a:SetHealth(inf)
end
- for k, v in ipairs(cp) do
+ for _, v in ipairs(cp) do
LoadCheckpoints()
local a = ents.Create("tt_cp")
@@ -646,7 +631,7 @@ if SERVER then
end
if entities then
- for k, v in ipairs(entities) do
+ for _, v in ipairs(entities) do
local a = ents.Create(v.ent)
local dontsetpos = nil
@@ -671,7 +656,7 @@ if SERVER then
Course_Sync()
- for k, v in pairs(player.GetAll()) do
+ for _, v in pairs(player.GetAll()) do
v:SetNW2Float("PBTime", 0)
v:SetNW2Int("CPNum", 1)
v:SetMoveType(MOVETYPE_WALK)
@@ -903,7 +888,7 @@ if CLIENT then
function CourseData(name)
local save = {{}, {}, Course_StartPos, Course_StartAng, name or "Unnamed", {}}
- for k, v in pairs(buildmode_placed) do
+ for _, v in pairs(buildmode_placed) do
if not IsValid(v) then -- Nothing
elseif v:GetNW2Bool("BRProtected") then
print("ignoring protected ent")
@@ -935,7 +920,7 @@ if CLIENT then
end
end
- for k, v in ipairs(Checkpoints) do
+ for _, v in ipairs(Checkpoints) do
table.insert(save[2], v:GetPos())
end
@@ -963,7 +948,6 @@ if CLIENT then
concommand.Add("Beatrun_SaveCourse", function(ply, cmd, args, argstr)
local name = args[1] or "Unnamed"
- -- local compress = not args[2]
SaveCourse(name, args[2])
end)
@@ -1458,7 +1442,7 @@ if CLIENT then
cam.Start3D()
- for k, v in ipairs(buildmode_placed) do
+ for _, v in ipairs(buildmode_placed) do
if IsValid(v) and not v:GetNW2Bool("BRProtected") then
local pos = v:GetRenderOrigin() or v:GetPos()
local w2s = pos:ToScreen()
@@ -1551,7 +1535,7 @@ if CLIENT then
surface.SetFont("DebugFixed")
surface.SetTextColor(255, 255, 255)
- for k, v in pairs(Checkpoints) do
+ for _, v in pairs(Checkpoints) do
if not IsValid(v) then
LoadCheckpoints()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Checkpoints.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Checkpoints.lua
index 6ffb5f0..d0f993d 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Checkpoints.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Checkpoints.lua
@@ -44,28 +44,28 @@ function LoadCheckpoints()
table.Empty(Checkpoints)
if SERVER then
- for k, v in pairs(player.GetAll()) do
+ for _, v in pairs(player.GetAll()) do
v:SetNW2Int("CPNum", 1)
end
end
if CLIENT then
timer.Simple(1, function()
- for k, v in pairs(ents.FindByClass("tt_cp")) do
+ for _, v in pairs(ents.FindByClass("tt_cp")) do
if IsValid(v) and v.GetCPNum then
Checkpoints[v:GetCPNum()] = v
end
end
end)
else
- for k, v in pairs(ents.FindByClass("tt_cp")) do
+ for _, v in pairs(ents.FindByClass("tt_cp")) do
Checkpoints[v:GetCPNum()] = v
end
end
end
if CLIENT then
- CreateClientConVar("Beatrun_FastStart", "0", true, true, "Faster start countdown", 0, 1)
+ CreateClientConVar("Beatrun_FastStart", "0", true, true, language.GetPhrase("beatrun.convars.faststart"), 0, 1)
net.Receive("Checkpoint_Hit", function()
local timetaken = CurTime() - lastcptime
@@ -181,7 +181,11 @@ end
local countdown = 0
local countdownalpha = 255
-local countdowntext = {"Ready", "Set", "Go!!"}
+local countdowntext = {
+ "#beatrun.checkpoints.countdown1",
+ "#beatrun.checkpoints.countdown2",
+ "#beatrun.checkpoints.countdown3"
+}
local function StartCountdown()
local CT = CurTime()
@@ -243,7 +247,8 @@ function CourseHUD()
speed = "0" .. speed
end
- text = speed .. " km/h"
+ text = language.GetPhrase("beatrun.checkpoints.speedometer"):format(speed)
+
local w, _ = surface.GetTextSize(text)
w = w or 0
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Conflicts.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Conflicts.lua
index 0af1f88..98b2dad 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Conflicts.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Conflicts.lua
@@ -4,7 +4,7 @@ local problematichooks = {
local function RemoveConflicting()
for k, v in pairs(problematichooks) do
- for l, b in ipairs(v) do
+ for _, b in ipairs(v) do
hook.Remove(k, b)
end
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua b/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
index a097b6e..2185ba7 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
@@ -86,7 +86,7 @@ if CLIENT then
if GetGlobalBool("GM_DATATHEFT") then
local datacubes = LocalPlayer():GetNW2Int("DataCubes", 0)
- return "Data Theft (" .. datacubes .. ")"
+ return language.GetPhrase("beatrun.datatheft.name"):format(datacubes)
else
hook.Remove("BeatrunHUDCourse", "DataTheftHUDName")
end
@@ -98,6 +98,6 @@ if CLIENT then
net.Receive("DataTheft_Start", function()
hook.Add("BeatrunHUDCourse", "DataTheftHUDName", DataTheftHUDName)
- chat.AddText(Color(200, 200, 200), "Data Theft! Kill players to collect data, deposit data in banks")
+ chat.AddText(Color(200, 200, 200), "#beatrun.datatheft.start")
end)
end
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua
index 1215547..69372c4 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua
@@ -15,7 +15,8 @@ if SERVER then
else
for _, b in ipairs(DATATHEFT_LOADOUTS[math.random(#DATATHEFT_LOADOUTS)]) do
local wep = v:Give(b)
- v:GiveAmmo(1000, wep:GetPrimaryAmmoType())
+
+ v:GiveAmmo(9999, wep:GetPrimaryAmmoType() or "Pistol", true)
end
end
end
@@ -64,7 +65,7 @@ end
if CLIENT then
local function DeathmatchHUDName()
if GetGlobalBool("GM_DEATHMATCH") then
- return "Deathmatch"
+ return "#beatrun.deathmatch.name"
else
hook.Remove("BeatrunHUDCourse", "DeathmatchHUDName")
end
@@ -76,6 +77,6 @@ if CLIENT then
net.Receive("Deathmatch_Start", function()
hook.Add("BeatrunHUDCourse", "DeathmatchHUDName", DeathmatchHUDName)
- chat.AddText(Color(200, 200, 200), "Deathmatch! Kill players to get points!")
+ chat.AddText(Color(200, 200, 200), "#beatrun.deathmatch.start")
end)
end
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Dive.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Dive.lua
index 7819eae..67c51d6 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Dive.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Dive.lua
@@ -1,7 +1,7 @@
-local totsugeki = CreateConVar("Beatrun_Totsugeki", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Oh no...", 0, 1)
-local totsugekispam = CreateConVar("Beatrun_TotsugekiSpam", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "OH NO...", 0, 1)
-local totsugekiheading = CreateConVar("Beatrun_TotsugekiHeading", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Can we dive on the x axis?", 0, 1)
-local totsugekidir = CreateConVar("Beatrun_TotsugekiDir", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Can we dive into another dir?", 0, 1)
+local totsugeki = CreateConVar("Beatrun_Totsugeki", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
+local totsugekispam = CreateConVar("Beatrun_TotsugekiSpam", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
+local totsugekiheading = CreateConVar("Beatrun_TotsugekiHeading", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
+local totsugekidir = CreateConVar("Beatrun_TotsugekiDir", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local function Dive(ply, mv, cmd)
if (not ply:GetDive() or ply:GetDive() and ply.QuakeJumping and totsugeki:GetBool() and totsugekispam:GetBool()) and ply:GetCrouchJump() and mv:KeyPressed(IN_ATTACK2) then
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
index ff4dfc0..db80b94 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
@@ -1,6 +1,6 @@
-local disable_grapple = CreateClientConVar("Beatrun_DisableGrapple", 0, true, true, "Disables grapple ability", 0, 1)
-
if CLIENT then
+ local disable_grapple = CreateClientConVar("Beatrun_DisableGrapple", 0, true, true, language.GetPhrase("beatrun.convars.disablegrapple"), 0, 1)
+
local circle = Material("circlesmooth.png", "nocull smooth")
hook.Add("HUDPaint", "grappleicon", function()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
index 15a026e..b423ded 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
@@ -17,7 +17,7 @@ end
local function HumanCount()
local count = 0
- for k, v in ipairs(player.GetAll()) do
+ for _, v in ipairs(player.GetAll()) do
if IsValid(v) and not v:GetNW2Bool("Infected") then
count = count + 1
end
@@ -376,7 +376,7 @@ if CLIENT then
hook.Add("BeatrunHUDCourse", "InfectionHUDName", InfectionHUDName)
hook.Add("CalcView", "InfectionCalcView", InfectionCalcView)
- chat.AddText(chatcolor, "Infection! Touch other players to infect them\n", math.max(math.floor(player.GetCount() / 4), 1) .. " player(s) will become infected in 10s")
+ chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.start"):format(math.max(math.floor(player.GetCount() / 4), 1), time))
end)
local music = nil
@@ -399,12 +399,12 @@ if CLIENT then
survivors = survivors:sub(1, -3)
if survivors == "" then
- survivors = "None..."
+ survivors = "#beatrun.infection.nosurvivors"
LocalPlayer():EmitSound("death.wav")
end
- chat.AddText(chatcolor, "The game has ended!\nSurvivors: " .. survivors .. "\nRestarting in 15s")
+ chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.end"):format(survivors))
end)
if music and music.Stop then
@@ -432,9 +432,9 @@ if CLIENT then
if IsValid(attacker) and IsValid(victim) then
if attacker == victim then
- chat.AddText(attacker, red, " died!")
+ chat.AddText(attacker, red, " #beatrun.infection.infected")
else
- chat.AddText(attacker, red, " has infected ", yellow, victim, "!")
+ chat.AddText(attacker, red, " #beatrun.infection.infectedby ", yellow, victim, "!")
end
attacker.InfectionTouchDelay = CurTime() + 3
@@ -497,10 +497,10 @@ if CLIENT then
if humanwin then
LocalPlayer():AddXP(200)
- chat.AddText(chatcolor, "You were awarded 200 XP for surviving")
+ chat.AddText(chatcolor, "#beatrun.infection.award")
else
LocalPlayer():AddXP(100)
- chat.AddText(chatcolor, "You were awarded 100 XP for spawning as an infected")
+ chat.AddText(chatcolor, "#beatrun.infection.awardinfected")
end
end)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/PuristMode.lua b/beatrun/gamemodes/beatrun/gamemode/sh/PuristMode.lua
index 8619d13..403c50d 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/PuristMode.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/PuristMode.lua
@@ -1,8 +1,8 @@
if CLIENT then
- CreateClientConVar("Beatrun_PuristMode", "1", true, true, "Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how Mirror's Edge games handle this.\n0 = No restrictions\n1 = Reduced move speed in the air")
+ CreateClientConVar("Beatrun_PuristMode", "1", true, true, language.GetPhrase("beatrun.convars.puristmode"))
end
-local PuristModeForce = CreateConVar("Beatrun_PuristModeForce", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Force players to adhere to purist rules", 0, 1)
+local PuristModeForce = CreateConVar("Beatrun_PuristModeForce", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local function PuristMove(ply, mv, cmd)
if not ply:OnGround() and not ply:GetGrappling() then
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua
index 1215ad3..dcc3fdf 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua
@@ -1,6 +1,6 @@
if CLIENT then
- QuickturnGround = CreateClientConVar("Beatrun_QuickturnGround", "0", true, true, "Enables quickturning with secondary attack while on the ground", 0, 1)
- QuickturnHandsOnly = CreateClientConVar("Beatrun_QuickturnHandsOnly", "1", true, true, "Enables quickturning with \"Runner Hands\" only", 0, 1)
+ QuickturnGround = CreateClientConVar("Beatrun_QuickturnGround", "0", true, true, language.GetPhrase("beatrun.convars.quickturnground"), 0, 1)
+ QuickturnHandsOnly = CreateClientConVar("Beatrun_QuickturnHandsOnly", "1", true, true, language.GetPhrase("beatrun.convars.quickturnhandsonly"), 0, 1)
end
function DoJumpTurn(lookbehind)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Monkey.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Swingbar.lua
similarity index 98%
rename from beatrun/gamemodes/beatrun/gamemode/sh/Monkey.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/Swingbar.lua
index 5472ea7..814d10f 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Monkey.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Swingbar.lua
@@ -26,6 +26,7 @@ local function SwingbarCheck(ply, mv, cmd)
if math.abs(dot) < 0.7 then return end
+
if CLIENT then
swingbar:SetPredictable(true)
end
@@ -162,7 +163,7 @@ local function SwingbarThink(ply, mv, cmd)
ply:EmitSound("Cloth.VaultSwish")
end
- ply:SetMEMoveLimit(350)
+ ply:SetMEMoveLimit(GetConVar("Beatrun_SpeedLimit"):GetInt())
ply:SetMESprintDelay(-1)
if CLIENT then
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/TimeSlow.lua b/beatrun/gamemodes/beatrun/gamemode/sh/TimeSlow.lua
index 43e8bc2..b3abdea 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/TimeSlow.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/TimeSlow.lua
@@ -45,7 +45,7 @@ net.Receive("SlowSounds", function()
end
end)
-concommand.Add("ToggleTimeSlow", function(ply)
+concommand.Add("Beatrun_ToggleTimeSlow", function(ply)
slow = not slow
net.Start("SlowSounds")
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua
index 27a6df3..6bc0162 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua
@@ -45,7 +45,7 @@ function meta:SetMantleEndPos(value)
return self:SetDTVector(14, value)
end
-local function PlayVaultAnim(ply, legs, ang)
+local function PlayVaultAnim(ply, ang)
local activewep = ply:GetActiveWeapon()
if ply:UsingRH() and activewep:GetSequence() == 17 then
@@ -140,7 +140,7 @@ local function Vault1(ply, mv, ang, t, h)
ply:SetMantle(1)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch1)
ply.MantleInitVel = mv:GetVelocity()
@@ -238,7 +238,7 @@ local function Vault2(ply, mv, ang, t, h)
ply:SetMantleData(mv:GetOrigin(), vaultpos, 0, 2)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, 1)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch2)
ply.MantleInitVel = mv:GetVelocity()
@@ -338,7 +338,7 @@ local function Vault3(ply, mv, ang, t, h)
ply:SetMantleData(mv:GetOrigin(), vaultpos, 0, 3)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, 2)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch3)
ply.MantleInitVel = mv:GetVelocity()
@@ -415,7 +415,7 @@ function Vault4(ply, mv, ang, t, h)
ply:SetMantleData(startpos, vaultpos, 0, 4)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, 1)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(Angle(2.5, 0, 0))
ply.MantleInitVel = mv:GetVelocity()
@@ -516,7 +516,7 @@ function Vault5(ply, mv, ang, t, h)
ply:SetMantle(5)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, false, ang)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch1)
ply.MantleInitVel = mv:GetVelocity()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Endless_Run.lua b/beatrun/gamemodes/beatrun/gamemode/sh/off/Endless_Run.lua
similarity index 100%
rename from beatrun/gamemodes/beatrun/gamemode/sh/Endless_Run.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/off/Endless_Run.lua
diff --git a/beatrun/gamemodes/beatrun/gamemode/sv/Disarm.lua b/beatrun/gamemodes/beatrun/gamemode/sv/Disarm.lua
index af94030..443a790 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/Disarm.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/Disarm.lua
@@ -1,5 +1,5 @@
util.AddNetworkString("DisarmStart")
-local cvardisarm = CreateConVar("Beatrun_Disarm", 1, FCVAR_ARCHIVE, "Whether 'using' NPCs triggers a disarm", 0, 1)
+local cvardisarm = CreateConVar("Beatrun_Disarm", 1, FCVAR_ARCHIVE, "", 0, 1)
local function Disarm_Init(ply, victim)
victim:NextThink(CurTime() + 100)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sv/NetSpamKick.lua b/beatrun/gamemodes/beatrun/gamemode/sv/NetSpamKick.lua
index 5927cbf..bba5d15 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/NetSpamKick.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/NetSpamKick.lua
@@ -1,7 +1,7 @@
if game.SinglePlayer() then return end
local maxmsgcount = 100
-local netIncoming_old = net.Receive
+-- local netIncoming_old = net.Incoming
local netIncoming_detour = function(length, ply)
local tickcount = engine.TickCount()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sv/sv_hitsoundsme.lua b/beatrun/gamemodes/beatrun/gamemode/sv/sv_hitsoundsme.lua
index 80d2a29..6bc9dc3 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/sv_hitsoundsme.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/sv_hitsoundsme.lua
@@ -4,7 +4,7 @@ hook.Add("EntityTakeDamage", "MEHitSounds", function(ply, dmginfo)
if not ply:IsPlayer() then return end
if dmginfo:IsBulletDamage() then
- --[[Block damage if they're going very fast]]
+ -- Block damage if they're going very fast
if ply:GetVelocity():Length() > 400 then return true end
ply:EmitSound("mirrorsedge/Flesh_0" .. tostring(math.random(1, 9)) .. ".wav")