diff --git a/BeatrunAnimInstaller/BeatrunAnimInstaller.cs b/BeatrunAnimInstaller_Source/BeatrunAnimInstaller.cs
similarity index 100%
rename from BeatrunAnimInstaller/BeatrunAnimInstaller.cs
rename to BeatrunAnimInstaller_Source/BeatrunAnimInstaller.cs
diff --git a/BeatrunAnimInstaller/BeatrunAnimInstaller.csproj b/BeatrunAnimInstaller_Source/BeatrunAnimInstaller.csproj
similarity index 100%
rename from BeatrunAnimInstaller/BeatrunAnimInstaller.csproj
rename to BeatrunAnimInstaller_Source/BeatrunAnimInstaller.csproj
diff --git a/BeatrunAnimInstaller/BeatrunAnimInstaller.sln b/BeatrunAnimInstaller_Source/BeatrunAnimInstaller.sln
similarity index 100%
rename from BeatrunAnimInstaller/BeatrunAnimInstaller.sln
rename to BeatrunAnimInstaller_Source/BeatrunAnimInstaller.sln
diff --git a/BeatrunAnimInstaller/Properties/AssemblyInfo.cs b/BeatrunAnimInstaller_Source/Properties/AssemblyInfo.cs
similarity index 100%
rename from BeatrunAnimInstaller/Properties/AssemblyInfo.cs
rename to BeatrunAnimInstaller_Source/Properties/AssemblyInfo.cs
diff --git a/BeatrunAnimInstaller_Source/README.md b/BeatrunAnimInstaller_Source/README.md
new file mode 100644
index 0000000..bf6a99a
--- /dev/null
+++ b/BeatrunAnimInstaller_Source/README.md
@@ -0,0 +1,29 @@
+# ENGLISH
+
+# Animations Installer Source Code
+
+Here you can find source code of the animations installer.\
+I don't know why you will ever need that but we put it here so you can be sure we don't supply malware with our fork.
+
+## How To Use
+
+Please refer to this [README](../beatrun/README.md).
+
+## Credits
+
+* [YuRaNnNzZZ](https://github.com/YuRaNnNzZZ) - Creator of this installer.
+
+# RUSSIAN
+
+# Исходный код установщика анимаций
+
+Здесь находятся исходники нашего установщика анимаций.\
+Я не знаю зачем это вам, но мы оставили их здесь чтобы вы могли убедиться что мы не распространяем вирусы в нашем форке.
+
+## Как использовать
+
+Прочитайте этот файл [README](../beatrun/README.md).
+
+## Благодарность
+
+* [YuRaNnNzZZ](https://github.com/YuRaNnNzZZ) - Создатель установщика.
diff --git a/BeatrunAnimInstaller/app.config b/BeatrunAnimInstaller_Source/app.config
similarity index 100%
rename from BeatrunAnimInstaller/app.config
rename to BeatrunAnimInstaller_Source/app.config
diff --git a/README.md b/README.md
index 068f11b..e349278 100644
--- a/README.md
+++ b/README.md
@@ -1,75 +1,95 @@
-# Beatrun | Community version
+# Beatrun | Community edition
-Infamous parkour addon for Garry's Mod, fully open sourced and maintained by the community.
+* [Русский](./README_ru.md)
-This version does not include malicious modules, code or networking. What it does contain is:
-* Lua modules for Discord Rich Presence
-* Lua modules for Steam Presence
-* Network connectivity for courses (activates only when you load or upload courses, and by default `courses.beatrun.ru` is used)
+Infamous parkour addon for Garry's Mod, fully open sourced and maintained by the community (me 😞).
-**All of this is optional and you may remove all of it. (modules are located [here](https://github.com/JonnyBro/beatrun/blob/master/lua/bin/) and online courses functionality is [here](https://github.com/JonnyBro/beatrun/blob/master/beatrun/gamemodes/beatrun/gamemode/cl/OnlineCourse.lua))**
+> [!IMPORTANT]
+> You will not find here any malicious modules, code or networking! We have modules and networking for:
+>
+> * Discord Rich Presence.
+> * Steam Presence.
+> * Custom Courses Database.
+>
+> **All of this is optional and you can remove all of it.**\
+> Modules are located [here](https://github.com/JonnyBro/beatrun/tree/main/lua/bin) and courses database functionality is [here](https://github.com/JonnyBro/beatrun/blob/main/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).\
+> You can find source code for modules in [Credits](#credits) section.
-# Installation (Manual)
-1. Download this repository [here](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip).
-2. Delete the `beatrun` folder in *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](https://github.com/JonnyBro/beatrun?tab=readme-ov-file#credits-3) section
+**PLEASE READ EVERYTHING BEFORE ASKING QUESTIONS ON OUR SERVER!**
+
+## Automatic Installation (Recommended | Windows only)
+
+Run the command below in Powershell.
+> [!NOTE]
+> Win + R > `powershell`
-# Installation (Automatic | Windows only)
-Run the command below in the Powershell. (Win + R --> powershell --> the command below)
```powershell
-iex (iwr "beatrun.ru/install.ps1" -UseBasicParsing)
+iex (iwr "rlxx.ru/beatrun" -UseBasicParsing)
```
+## Manual Installation
+
+1. Download this repository [here](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip).
+2. **Delete the `beatrun` folder in *your_game_folder/garrysmod/addons* if you have one.**
+3. Extract the `beatrun-main/beatrun` folder to *your_game_folder/garrysmod/addons*.
+4. Extract the `beatrun-main/lua` folder to *your_game_folder/garrysmod*.
+
## Animations
-You can use "**Beatrun Animations Installer**" for custom animations. Currently there's:
-* Beatrun Reanimated
-* Fixed Original
-Start the executable and press a key on your keyboard with the number of the animation you want to install (if nothing's changed, run the program as admin).
-Installer's source can be found [here](/BeatrunAnimInstaller).
+Please refer to this [README](beatrun/README.md).
-## Changes and fixes done by me
-* Created a [custom online courses database](https://courses.beatrun.ru), which is also free and [open source](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
-* Added a new gamemode - *Deathmatch*, it's like Data Theft, but you collect kills not cubes!
-* Added an in-game config menu - You can find it in the tool menu, in the *Beatrun* Category!\
-All of the settings below can be changed in the configuration menu.
-* Added the ability Getting off of ladders.
-* Allowed jumping while slowwalking.
-* Done various tweaks to the Time Trials Menu (F4).
+## Changes
+
+> [!IMPORTANT]
+> There are many undocumented changes and fixes in this version, you better look at the commits for more specific changes.
+
+* Jonny_Bro is hosting [custom online courses database](https://courses.beatrun.ru), which is also free and [open source](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
+* Implemented a new gamemode - **Deathmatch** (it's way more fun than Data Theft I promise).
+* Implemented "Proper" Kick Glitch just like in [original ME](https://www.youtube.com/watch?v=zK5y3NBUStc).
+* Added an in-game config menu - you can find it in the tool menu, in the *Beatrun* Category.\
+**All** of the Beatrun settings can be changed in the configuration menu.
+* Localization support.\
+For now Russian and English are supported.
+* Added the ability to get off of ladders.
* Added an arrow that shows the next checkpoint.
-* Added a convar to allow Overdrive usage on the server - `Beatrun_AllowOverdriveInMultiplayer`.
-* Added a convar to toggle between old and new (like in ME) Kick-Glitch - `Beatrun_OldKickGlitch`.
-* Added convars to change HUD's colors - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`.
-* Added a convar to allow players to spawn props without admin rights - `Beatrun_AllowPropSpawn`.
-* Added a convar to disable grapple ability - `Beatrun_DisableGrapple`.
-* Implemented Discord Rich Presence using open source tools (See step 3).
+* Added a ConVar to allow Overdrive usage on the server - `Beatrun_AllowOverdriveInMultiplayer`.
+* Added a ConVar to toggle between old and new Kick Glitch - `Beatrun_OldKickGlitch`.
+* Added some ConVars to change HUD colors - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`.
+* Added a ConVar to allow players to spawn props and weapons without admin rights - `Beatrun_AllowPropSpawn`.
+* Added a ConVar to disable grapple ability - `Beatrun_DisableGrapple`.
+* Added a ConVar to allow QuickTurn with any weapon or only with *Runner Hands* - `Beatrun_QuickturnHandsOnly`.
* Added small camera punch when diving.
-* Added the ability to remove ziplines that created with *Zipline Gun* - RMB.
-* SteamID in the right corner is no longer present.
+* Added the ability to remove ziplines that created with *Zipline Gun* - `RMB`.
+* Implemented Discord Rich Presence using [open source](#credits) module.
-## Notable changes and fixes done by the community
-* Made QuickTurn work only with `Runner Hands`.
+## Fixes
+
+* Your SteamID in the right corner is no longer present.
+* Fixed some playermodels show up as ERROR.
+* Done various tweaks to the Courses Menu (F4).
+* Allowed jumping while walking (🤷).
* Fixed leaderboard sorting in gamemodes.
* Fixed grapple usage in courses and gamemodes.
-* Fixed a crash in DataTheft when touching data bank.
-* Fixed an error on course load.
-* Fixed collisions issues. (you getting stuck in walls for no reason or player to player damage not going through in gamemodes other than datatheft)
-* Added Proper Kick Glitch ([Like in original ME](https://www.youtube.com/watch?v=zK5y3NBUStc)). (cry about prediction errors l0l)
+* Fixed a crash in Data Theft when touching Data Bank.
+* Fixed an error on course loading.
+* Fixed collisions issues. (PvP damage not going through in gamemodes other than Data Theft)
* Tweaked safety roll, now you can roll under things.
+* Tweaked some grapple related stuff. Now it moves with the entity it was attached to and other players can see the rope.
* Made it possible to dive to your death =).
-* Added some grapple related stuff. Now it moves with the entity it was attached to and other players can see the rope.
## TODO
-- [ ] Gamemodes menu.
-# Related
-* [beatrun-anims](https://github.com/JonnyBro/beatrun-anims) - Decompiled beatrun animations.
+* [ ] Loadouts creation menu for Data Theft and Deathmatch. (idk how to properly implement this for know).
-# Credits <3
-* All contributors.
-* [MTB](https://www.youtube.com/@MTB396) - Beatrun Reanimated project.
+## Related
+
+* [Beatrun Reanimated Project](https://github.com/JonnyBro/beatrun-anims).
+
+## Credits
+
+* [All contributors](https://github.com/JonnyBro/beatrun/graphs/contributors) - <3.
+* [EarthyKiller127](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - He made that piece of shit.
+* [relaxtakenotes](https://github.com/relaxtakenotes) - Made all of this possible.
+* [MTB](https://www.youtube.com/@MTB396) - Beatrun Reanimated Project.
* [Discord Rich Presence](https://github.com/fluffy-servers/gmod-discord-rpc) by Fluffy Servers.
* [Steam Presence](https://github.com/YuRaNnNzZZ/gmcl_steamrichpresencer) by YuRaNnNzZZ.
-* [earthykiller](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - He made that piece of shit code.
diff --git a/README_ru.md b/README_ru.md
new file mode 100644
index 0000000..bfc1ff7
--- /dev/null
+++ b/README_ru.md
@@ -0,0 +1,95 @@
+# Beatrun | Версия от сообщества
+
+* [English](./README.md)
+
+Печально известный паркур-аддон для Garry's Mod, с полностью открытым исходным кодом и поддерживаемый сообществом (мной 😞).
+
+> [!IMPORTANT]
+> У нас вы не найдёте вредоносного кода, модулей или сетевого кода! У нас есть модули и сетевой код, который используется для:
+>
+> * Discord Rich Presence.
+> * Steam Presence.
+> * Пользовательская онлайн база курсов.
+>
+> **Всё это необязательно и может быть удалено.**\
+> Модули находятся [тут](https://github.com/JonnyBro/beatrun/tree/main/lua/bin) и функционал онлайн базы курсов доступен [здесь](https://github.com/JonnyBro/beatrun/blob/main/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).\
+> Исходный код модулей можно найти в [благодарностях](#благодарности).
+
+**ПОЖАЛУЙСТА, ПРОЧТИТЕ ВЕСЬ ДОКУМЕНТ ПЕРЕД ТЕМ КАК ЗАДАВАТЬ ВОПРОСЫ НА НАШЕМ СЕРВЕРЕ!**
+
+## Автоматическая установка (Рекомендуемое | только для Windows)
+
+Запустите команду ниже в Powershell.
+> [!NOTE]
+> Win + R > `powershell`
+
+```powershell
+iex (iwr "rlxx.ru/beatrun" -UseBasicParsing)
+```
+
+## Ручная установка
+
+1. Скачайте данный репозиторий по данной [ссылке](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip).
+2. **Удалите старую папку `beatrun` по пути *путь_к_игре/garrysmod/addons* если она у вас имеется.**
+3. Извлеките папку `beatrun-main/beatrun` по пути *путь_к_игре/garrysmod/addons*.
+4. Извлеките папку `beatrun-main/lua` по пути *путь_к_игре/garrysmod*.
+
+## Анимации
+
+Пожалуйста, обратитесь к данному [README](beatrun/README.md).
+
+## Изменения
+
+> [!IMPORTANT]
+> Множество изменений и исправлений не задокументированы, обратитесь к списку коммитов для более подробного списка изменений.
+
+* Jonny_Bro держит [пользовательскую онлайн базу курсов](https://courses.beatrun.ru), которая так же бесплатна и имеет [открытый исходный код](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
+* Реализован новый режим - **Deathmatch** (намного веселее чем Data Theft, честно).
+* Реализован "правильный" Kick Glitch прямо как в [оригинальной ME](https://www.youtube.com/watch?v=zK5y3NBUStc).
+* Добавлено меню настроек в игре - его можно найти в списке инструментов, в категории *Beatrun*.\
+Вам доступны **все** настройки Beatrun из данного меню.
+* Поддержка локализации.\
+На данный момент доступны Русский и Английский языки.
+* Добавлена возможность слезания с лестниц.
+* Добавлена стрелка указывающая на следующую контрольную точку.
+* Добавлена переменная которая разрешает использование Overdrive на сервере - `Beatrun_AllowOverdriveInMultiplayer`.
+* Добавлена переменная которая позволяет переключится между старым и новым Kick Glitch - `Beatrun_OldKickGlitch`.
+* Добавлено несколько переменных позволяющих настроить цвета HUD - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`.
+* Добавлена переменная которая разрешает игрокам без админ прав создавать пропы и оружие - `Beatrun_AllowPropSpawn`.
+* Добавлена переменная которая позволяет переключить работу крюка-кошки - `Beatrun_DisableGrapple`.
+* Добавлена переменная которая позволяет переключить использование Quickturn только с *Runner Hands* или с любым оружием - `Beatrun_QuickturnHandsOnly`.
+* Добавлен небольшой толчёк камеры при нырянии.
+* Добавлена возможность удаления зиплайнов созданных *Zipline Gun* - `ПКМ`.
+* Реализована поддержка Discord Rich Presence используя модуль с [открытым исходным кодом](#благодарности).
+
+## Исправления
+
+* Ваш SteamID больше не показывается в углу экрана.
+* Исправлено отображение некоторых моделей игрока как ERROR.
+* Сделано несколько изменений в меню выбора курсов (F4).
+* Разрешены прыжки во время ходьбы (🤷).
+* Исправлена сортировка в таблице лидеров.
+* Исправлено использование крюка-кошки в режимах и курсах.
+* Исправлен краш при соприкосновении с Data Bank в Data Theft.
+* Исправлена ошибка загрузки курсов.
+* Исправлены ошибки коллизий. (PvP урон не проходил нигде, кроме Data Theft)
+* Изменён кувырок, теперь можно кувыркаться под объектами.
+* Изменена крюк-кошка. Теперь вы движетесь вместе с объектом к которому она прицеплена и её видят другие игроки.
+* Теперь можно нырнуть до смерти =).
+
+## TODO
+
+* [ ] Меню выбора снаряжения для Data Theft и Deathmatch (не знаю пока как это реализовать).
+
+## Может быть полезно
+
+* [Beatrun Reanimated Project](https://github.com/JonnyBro/beatrun-anims).
+
+## Благодарности
+
+* [Все участники](https://github.com/JonnyBro/beatrun/graphs/contributors) - <3.
+* [EarthyKiller127](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - Создатель этого куска дерьма.
+* [relaxtakenotes](https://github.com/relaxtakenotes) - Если бы не он, этого проекта бы не существовало.
+* [MTB](https://www.youtube.com/@MTB396) - Создатель Beatrun Reanimated Project.
+* [Discord Rich Presence](https://github.com/fluffy-servers/gmod-discord-rpc) от Fluffy Servers.
+* [Steam Presence](https://github.com/YuRaNnNzZZ/gmcl_steamrichpresencer) от YuRaNnNzZZ.
diff --git a/beatrun/Beatrun Reanimated/climbanim.dx80.vtx b/beatrun/Beatrun Reanimated/climbanim.dx80.vtx
index 072458c..429205d 100644
Binary files a/beatrun/Beatrun Reanimated/climbanim.dx80.vtx and b/beatrun/Beatrun Reanimated/climbanim.dx80.vtx differ
diff --git a/beatrun/Beatrun Reanimated/climbanim.dx90.vtx b/beatrun/Beatrun Reanimated/climbanim.dx90.vtx
index dcfe7f6..c2400ef 100644
Binary files a/beatrun/Beatrun Reanimated/climbanim.dx90.vtx and b/beatrun/Beatrun Reanimated/climbanim.dx90.vtx differ
diff --git a/beatrun/Beatrun Reanimated/climbanim.mdl b/beatrun/Beatrun Reanimated/climbanim.mdl
index 28fc60b..36eeadb 100644
Binary files a/beatrun/Beatrun Reanimated/climbanim.mdl and b/beatrun/Beatrun Reanimated/climbanim.mdl differ
diff --git a/beatrun/Beatrun Reanimated/climbanim.sw.vtx b/beatrun/Beatrun Reanimated/climbanim.sw.vtx
index 9497afb..cfc3465 100644
Binary files a/beatrun/Beatrun Reanimated/climbanim.sw.vtx and b/beatrun/Beatrun Reanimated/climbanim.sw.vtx differ
diff --git a/beatrun/Beatrun Reanimated/climbanim.vvd b/beatrun/Beatrun Reanimated/climbanim.vvd
index ff6be2d..26b1ef9 100644
Binary files a/beatrun/Beatrun Reanimated/climbanim.vvd and b/beatrun/Beatrun Reanimated/climbanim.vvd differ
diff --git a/beatrun/Original Animations/climbanim.dx80.vtx b/beatrun/Original Animations/climbanim.dx80.vtx
index f33d91e..04d708c 100644
Binary files a/beatrun/Original Animations/climbanim.dx80.vtx and b/beatrun/Original Animations/climbanim.dx80.vtx differ
diff --git a/beatrun/Original Animations/climbanim.dx90.vtx b/beatrun/Original Animations/climbanim.dx90.vtx
index 1209185..3c073e3 100644
Binary files a/beatrun/Original Animations/climbanim.dx90.vtx and b/beatrun/Original Animations/climbanim.dx90.vtx differ
diff --git a/beatrun/Original Animations/climbanim.mdl b/beatrun/Original Animations/climbanim.mdl
index bb704be..935c6e0 100644
Binary files a/beatrun/Original Animations/climbanim.mdl and b/beatrun/Original Animations/climbanim.mdl differ
diff --git a/beatrun/Original Animations/climbanim.sw.vtx b/beatrun/Original Animations/climbanim.sw.vtx
index e7376f3..d305ab5 100644
Binary files a/beatrun/Original Animations/climbanim.sw.vtx and b/beatrun/Original Animations/climbanim.sw.vtx differ
diff --git a/beatrun/Original Animations/climbanim.vvd b/beatrun/Original Animations/climbanim.vvd
index 0d823d0..62e239c 100644
Binary files a/beatrun/Original Animations/climbanim.vvd and b/beatrun/Original Animations/climbanim.vvd differ
diff --git a/beatrun/README.md b/beatrun/README.md
new file mode 100644
index 0000000..2edc20c
--- /dev/null
+++ b/beatrun/README.md
@@ -0,0 +1,39 @@
+# ENGLISH
+
+# Animations Installer
+
+You can use **BeatrunAnimInstaller** (located literally here) to change animations. Currently we have:
+
+1. `Beatrun Reanimated Project` animations.
+2. Original but fixed animations.
+
+## How To Use
+
+1. Start the executable.
+2. Press a key on your keyboard with the number of the animation you want to install.
+> [!NOTE]
+> If nothing is changed, close the game and/or try run the program with admin priveleges.
+
+## Source Code
+
+Please refer to this [README](../BeatrunAnimInstaller_Source/README.md).
+
+# RUSSIAN
+
+# Установщик анимаций
+
+Используйте **BeatrunAnimInstaller** (который расположен прямо тут) чтобы менять анимации. На данный момент у нас имеются:
+
+1. Анимации из `Beatrun Reanimated Project`.
+2. Оригинальные анимации с правками и фиксами.
+
+## Как использовать
+
+1. Запустите исполняемый файл.
+2. Нажмите цифру желаемых анимаций на клавиатуре.
+> [!NOTE]
+> Если ничего не изменилось, закройте игру и/или запустите файл от имени администратора.
+
+## Исходный код
+
+Прочитайте этот файл [README](../BeatrunAnimInstaller_Source/README.md).
diff --git a/beatrun/gamemodes/beatrun/beatrun.txt b/beatrun/gamemodes/beatrun/beatrun.txt
index 53fdc6b..db2e9b9 100644
--- a/beatrun/gamemodes/beatrun/beatrun.txt
+++ b/beatrun/gamemodes/beatrun/beatrun.txt
@@ -3,5 +3,6 @@
"base" "base"
"title" "Beatrun"
"maps" "^br_"
+ "category" "other"
"menusystem" "1"
}
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/content/models/climbanim.dx80.vtx b/beatrun/gamemodes/beatrun/content/models/climbanim.dx80.vtx
index f33d91e..429205d 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/climbanim.dx80.vtx and b/beatrun/gamemodes/beatrun/content/models/climbanim.dx80.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/climbanim.dx90.vtx b/beatrun/gamemodes/beatrun/content/models/climbanim.dx90.vtx
index 1209185..c2400ef 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/climbanim.dx90.vtx and b/beatrun/gamemodes/beatrun/content/models/climbanim.dx90.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/climbanim.mdl b/beatrun/gamemodes/beatrun/content/models/climbanim.mdl
index bb704be..36eeadb 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/climbanim.mdl and b/beatrun/gamemodes/beatrun/content/models/climbanim.mdl differ
diff --git a/beatrun/gamemodes/beatrun/content/models/climbanim.sw.vtx b/beatrun/gamemodes/beatrun/content/models/climbanim.sw.vtx
index e7376f3..cfc3465 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/climbanim.sw.vtx and b/beatrun/gamemodes/beatrun/content/models/climbanim.sw.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/climbanim.vvd b/beatrun/gamemodes/beatrun/content/models/climbanim.vvd
index 0d823d0..26b1ef9 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/climbanim.vvd and b/beatrun/gamemodes/beatrun/content/models/climbanim.vvd differ
diff --git a/beatrun/gamemodes/beatrun/content/models/runnerhands.dx80.vtx b/beatrun/gamemodes/beatrun/content/models/runnerhands.dx80.vtx
index db4206e..5304d64 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/runnerhands.dx80.vtx and b/beatrun/gamemodes/beatrun/content/models/runnerhands.dx80.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/runnerhands.dx90.vtx b/beatrun/gamemodes/beatrun/content/models/runnerhands.dx90.vtx
index a99e8fe..a815f0f 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/runnerhands.dx90.vtx and b/beatrun/gamemodes/beatrun/content/models/runnerhands.dx90.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/runnerhands.mdl b/beatrun/gamemodes/beatrun/content/models/runnerhands.mdl
index cd82fe9..4d52e5e 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/runnerhands.mdl and b/beatrun/gamemodes/beatrun/content/models/runnerhands.mdl differ
diff --git a/beatrun/gamemodes/beatrun/content/models/runnerhands.sw.vtx b/beatrun/gamemodes/beatrun/content/models/runnerhands.sw.vtx
index e8d5a08..8f0ced3 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/runnerhands.sw.vtx and b/beatrun/gamemodes/beatrun/content/models/runnerhands.sw.vtx differ
diff --git a/beatrun/gamemodes/beatrun/content/models/runnerhands.vvd b/beatrun/gamemodes/beatrun/content/models/runnerhands.vvd
index 2934cc9..64ed585 100644
Binary files a/beatrun/gamemodes/beatrun/content/models/runnerhands.vvd and b/beatrun/gamemodes/beatrun/content/models/runnerhands.vvd differ
diff --git a/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties b/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties
new file mode 100644
index 0000000..d8e5aee
--- /dev/null
+++ b/beatrun/gamemodes/beatrun/content/resource/localization/en/beatrun.properties
@@ -0,0 +1,238 @@
+# Misc
+beatrun.misc.ok=OK
+beatrun.misc.noclipdetected=Noclip Detected! Respawn to restart the course
+beatrun.misc.checkconsole=Check console!
+
+# 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 HUD
+beatrun.convars.hudreticle=Display a reticle
+beatrun.convars.hudtextcolor=HUD Text Color\nDefault: 255 255 255 255
+beatrun.convars.hudcornercolor=HUD Corner Color\nDefault: 20 20 20 100
+beatrun.convars.hudfloatxpcolor=HUD Floating XP Color\nDefault: 255 255 255 255
+beatrun.convars.nametags=Display 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=Courses - %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 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 to course with name %s on map %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.updatecourse=Update a Course on the Database
+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\nDefault: 325
+
+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 version\nDisabled - New version\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 Jump 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 USE 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=Toggles 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.gamemodes.infection=Toggle Infection Gamemode
+beatrun.toolsmenu.gamemodes.infectionstarttime=Time before starting
+beatrun.toolsmenu.gamemodes.infectiongametime=Length of the game
+beatrun.toolsmenu.gamemodes.infectiontime=Time in seconds
+beatrun.toolsmenu.gamemodes.datatheft=Toggle Data Theft Gamemode
+beatrun.toolsmenu.gamemodes.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.infectedtext=(Infected)
+beatrun.infection.humantext=(Human)
+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
diff --git a/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties b/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties
new file mode 100644
index 0000000..f55175a
--- /dev/null
+++ b/beatrun/gamemodes/beatrun/content/resource/localization/ru/beatrun.properties
@@ -0,0 +1,238 @@
+# Misc
+beatrun.misc.ok=Ок
+beatrun.misc.noclipdetected=Обнаружен NoClip! Нажмите R чтобы начать заного
+beatrun.misc.checkconsole=Проверьте консоль!
+
+# AddonWarning
+beatrun.addonwarning.warntext=ВНИМАНИЕ\nПожалуйста, отключите данные аддоны перед игрой\nили созданием сообщений на GitHub:
+beatrun.addonwarning.quitbutton=Выйти в меню
+beatrun.addonwarning.play=Играть
+beatrun.addonwarning.conflictfound=НЕСОВМЕСТИМЫЕ АДДОНЫ ОБНАРУЖЕНЫ
+
+# BuildModeHUD
+beatrun.buildmodehud.info=Указатель: %s\nВыбрано: %s\nУгол: %s
+beatrun.buildmodehud.props=Меню / Пропы
+beatrun.buildmodehud.entities=Меню / Энтити
+beatrun.buildmodehud.drag=Переместить (G)
+beatrun.buildmodehud.copy=Копировать (SHIFT+D)
+beatrun.buildmodehud.delete=Удалить (DEL/BCKSPC)
+beatrun.buildmodehud.highlight=Подсветить (T)
+beatrun.buildmodehud.select=Выбрать
+beatrun.buildmodehud.zipline=Зиплайн (SHIFT = двухсторонний)
+
+# All ConVars
+beatrun.convars.hudxp=Показать весь опыт рядом с ником
+beatrun.convars.hudsway=Отображать покачивание HUD
+beatrun.convars.huddynamic=Скрыть HUD при движении
+beatrun.convars.hudhidden=Скрыть HUD
+beatrun.convars.hudreticle=Показать точку
+beatrun.convars.hudtextcolor=Цвет текста в HUD\nDefault: 255 255 255 255
+beatrun.convars.hudcornercolor=Цвет края в HUD\nDefault: 20 20 20 100
+beatrun.convars.hudfloatxpcolor=Цвет всплывающего XP в HUD\nDefault: 255 255 255 255
+beatrun.convars.nametags=Показать ники над игроками
+beatrun.convars.apikey=API ключ
+beatrun.convars.domain=Домен онлайн базы курсов
+beatrun.convars.viewbob=Интенсивность покачивания камеры
+beatrun.convars.viewbobstabilization=Включите чтобы снизить покачивание камеры центрируя её
+beatrun.convars.fov=Угол обзора игрока
+beatrun.convars.cpsave=Респавн в курсах отправляет на последнюю контрольную точку
+beatrun.convars.faststart=Быстрый отчёт в начале курса
+beatrun.convars.disablegrapple=Переключить крюк-кошку
+beatrun.convars.puristmode=Режим Purist это клиентский параметр который сильно снижает движение игрока в стороны будучи в воздухе, прямо как в оригинальное ME.\n0 = Нет ограничений\n1 = Снижает движение игрока в воздухе в стороны
+beatrun.convars.quickturnground=Переключить Quickturn будучи на земле
+beatrun.convars.quickturnhandsonly=Переключить Quickturn только с "Runner Hands"
+
+# HUD
+beatrun.hud.course=Курс: %s
+beatrun.hud.freeplay=Свободная игра
+beatrun.hud.lvl=Лвл: %s
+beatrun.hud.infector=Заражённый
+
+# Menu_Course
+beatrun.coursemenu.trials=Курсы - %s
+beatrun.coursemenu.buildmode=Режим строительства
+beatrun.coursemenu.freeplay=Свободная игра
+
+# CoursesDatabase
+beatrun.coursesdatabase.cantuploadfreeplay=Нельзя загружать во время свободной игры
+beatrun.coursesdatabase.upload1=Вы пытаетесь загрузить курс с названием %s на карте %s.
+beatrun.coursesdatabase.upload2=Используйте Beatrun_Confirm чтобы продолжить или Beatrun_Cancel чтобы отменить.
+beatrun.coursesdatabase.update1=Вы пытаетесь обновить курс с кодом %s на курс с названием %s на карте %s.
+
+# Tools Menu
+beatrun.toolsmenu.client=Клиент
+beatrun.toolsmenu.server=Сервер
+
+# Tools Menu Courses Section
+beatrun.toolsmenu.courses.name=Курсы
+beatrun.toolsmenu.courses.desc=Настройки курсов
+
+beatrun.toolsmenu.courses.faststart=Быстрый старт
+beatrun.toolsmenu.courses.faststartdesc=Быстрый отчёт в начале курса
+
+beatrun.toolsmenu.courses.checkpointsave=Сохранение на Контр. точках
+beatrun.toolsmenu.courses.checkpointsavedesc=Респавн на последней контрольной точке
+
+beatrun.toolsmenu.courses.database=Домен Базы
+beatrun.toolsmenu.courses.databasedesc=Домен/IP онлайн базы курсов\nПо умолчанию: courses.beatrun.ru
+
+beatrun.toolsmenu.courses.changeapikey=Изменить API Ключ
+beatrun.toolsmenu.courses.enterapikey=Введите ваш API ключ
+
+beatrun.toolsmenu.courses.savecourse=Сохранить Текущий Курс в Файл
+beatrun.toolsmenu.courses.namesavecourse=Введите название для курса
+
+beatrun.toolsmenu.courses.loadcourse=Загрузить Курс из Базы
+beatrun.toolsmenu.courses.enterloadcourse=Введите код курса
+
+beatrun.toolsmenu.courses.uploadcourse=Опубликовать Текущий Курс в Базу курсов
+
+beatrun.toolsmenu.courses.updatecourse=Обновить курс в Базе
+beatrun.toolsmenu.courses.updatecoursehelp=Обновляет курс в базе по коду на текущий
+
+# Tools Menu HUD Section
+beatrun.toolsmenu.hud.name=HUD
+beatrun.toolsmenu.hud.desc=Настройки HUD
+
+beatrun.toolsmenu.hud.dynamic=Динамический HUD
+beatrun.toolsmenu.hud.dynamicdesc=Прячет HUD во время движения
+
+beatrun.toolsmenu.hud.sway=Покачивание HUD
+beatrun.toolsmenu.hud.swaydesc=Покачивает HUD при разнообразных действиях
+
+beatrun.toolsmenu.hud.reticle=Показать Точку
+beatrun.toolsmenu.hud.reticledesc=Показывает точку по середине экрана
+
+beatrun.toolsmenu.hud.nametags=Показать Ники
+beatrun.toolsmenu.hud.nametagsdesc=Показывает ники над игроками
+
+beatrun.toolsmenu.hud.hudxp=Показать XP в HUD
+beatrun.toolsmenu.hud.hudxpdesc=Показывает весь XP в HUD
+
+beatrun.toolsmenu.hud.wind=Эффект Ветра
+beatrun.toolsmenu.hud.winddesc=Шум ветра во время бега
+
+beatrun.toolsmenu.hud.fov=Угол Обзора
+beatrun.toolsmenu.hud.fovdesc=Вам нужно сделать респавн после изменения FOV!
+
+beatrun.toolsmenu.hud.hidden=Скрыть HUD
+beatrun.toolsmenu.hud.hiddendesc=0 - Показать\n1 - Только режим\n2 - Скрыть полностью
+
+beatrun.toolsmenu.hud.textcolor=Цвет Текста в HUD
+beatrun.toolsmenu.hud.cornercolor=Цвет Края в HUD
+beatrun.toolsmenu.hud.floatxpcolor=Цвет Всплывающего XP в HUD
+
+# Tools Menu Viewbob Section
+beatrun.toolsmenu.viewbob.name=Покачивание Камеры
+beatrun.toolsmenu.viewbob.desc=Настройки покачивания камеры
+
+beatrun.toolsmenu.viewbob.stabilization=Стабилизация Покачивания
+beatrun.toolsmenu.viewbob.stabilizationdesc=Включите чтобы снизить покачивание камеры центрируя её
+beatrun.toolsmenu.viewbob.intensity=Интенсивность Покачивания Камеры
+
+# Tools Menu Gameplay Section
+beatrun.toolsmenu.gameplay.name=Геймплей
+beatrun.toolsmenu.gameplay.desc=Настройки геймплея
+
+beatrun.toolsmenu.gameplay.quickturnground=Quickturn на Земле
+beatrun.toolsmenu.gameplay.quickturngrounddesc=Переключает Quickturn будучи на земле (быстрый разворот)
+
+beatrun.toolsmenu.gameplay.quickturnhandsonly=Quickturn Только с Руками
+beatrun.toolsmenu.gameplay.quickturnhandsonlydesc=Переключает Quickturn только с "Runner Hands"
+
+beatrun.toolsmenu.gameplay.puristmode=Режим Purist
+beatrun.toolsmenu.gameplay.puristmodedesc=Режим Purist это клиентский параметр который сильно снижает движение игрока в стороны будучи в воздухе, прямо как в оригинальное ME.\n0 = Нет ограничений\n1 = Снижает движение игрока в воздухе в стороны
+
+beatrun.toolsmenu.gameplay.disablegrapple=Отключить Крюк-Кошку
+beatrun.toolsmenu.gameplay.disablegrappledesc=Отключает использование крюка-кошки
+
+# Tools Menu Misc Section
+beatrun.toolsmenu.misc.name=Другое
+beatrun.toolsmenu.misc.desc=Другие настройки
+
+beatrun.toolsmenu.misc.propspawn=Создание Пропов/Оружия
+beatrun.toolsmenu.misc.propspawndesc=Позволяет создавать игрокам без админ прав оружие, пропы и энтити
+
+beatrun.toolsmenu.misc.overdrivemp=Overdrive в Мультиплеере
+beatrun.toolsmenu.misc.overdrivempdesc=Разрешает использование Overdrive в мультиплеере
+
+# Tools Menu Moves Section
+beatrun.toolsmenu.moves.name=Движения
+beatrun.toolsmenu.moves.desc=Настройки движений
+beatrun.toolsmenu.moves.help=Нырнуть Можно с Помощью Ctrl + ПКМ Будучи в Воздухе!\nOverdrive Переключается с Помощью E + ЛКМ.
+
+beatrun.toolsmenu.moves.speedlimit=Ограничение Скорости
+beatrun.toolsmenu.moves.speedlimitdesc=Изменяет ограничение скорости передвижения\nПо умолчанию: 325
+
+beatrun.toolsmenu.moves.forcepuristmode=Принудительный Режим Purist
+beatrun.toolsmenu.moves.forcepuristmodedesc=Включает режим Purist для всех игроков
+
+beatrun.toolsmenu.moves.realisticwallrunning="Реалистичный" Бег по Стенам
+beatrun.toolsmenu.moves.realisticwallrunningdesc=Нет потери в скорости если отключить
+
+beatrun.toolsmenu.moves.kickglitch=Kick Glitch
+beatrun.toolsmenu.moves.kickglitchdesc=Переключает Kick Glitch\nНажмите ЛКМ во время бега по стене и зажатии/нажатии на прыжок сразу после
+
+beatrun.toolsmenu.moves.kickglitchversion=Версия Kick Glitch
+beatrun.toolsmenu.moves.kickglitchversiondesc=Вкл - Старая версия\nDisabled - Новая версия\nНовая версия использует механику из ME которая создаёт небольшую платформу под игроком
+
+beatrun.toolsmenu.moves.quakejump=Quake Jump
+beatrun.toolsmenu.moves.quakejumpdesc=Переключает Quake Jump\nНажмите Прыжок сразу после Side Step
+
+beatrun.toolsmenu.moves.sidestep=Side Step
+beatrun.toolsmenu.moves.sidestepdesc=Переключает Side Step\nA/D + ПКМ
+
+beatrun.toolsmenu.moves.disarm=Разоружение
+beatrun.toolsmenu.moves.disarmdesc=Переключает возможность разоружить (убить) NPC\nНажмите ИСПОЛЬЗОВАТЬ на NPC
+
+beatrun.toolsmenu.moves.divesettings=Настройки ныряния
+
+beatrun.toolsmenu.moves.totsugeki=Totsugeki
+beatrun.toolsmenu.moves.totsugekidesc=Переключает Totsugeki\nНырнуть сразу после Quake Jump
+
+beatrun.toolsmenu.moves.totsugekispam=Спам Totsugeki
+beatrun.toolsmenu.moves.totsugekispamdesc=Переключает возможность спамить Totsugeki
+
+beatrun.toolsmenu.moves.totsugekiheading=Угол Totsugeki
+beatrun.toolsmenu.moves.totsugekiheadingdesc=Позволяет делать Totsugeki по оси X (вверх/вниз)
+
+beatrun.toolsmenu.moves.totsugekidirection=Направление Totsugeki
+beatrun.toolsmenu.moves.totsugekidirectiondesc=Позволяет делать Totsugeki в направлении глаз\nCombined with Spam and Heading Allows You to Fly =)
+
+# Tools Menu Gamemodes Section
+beatrun.toolsmenu.gamemodes.name=Режимы
+beatrun.toolsmenu.gamemodes.desc=Настройка режимов
+beatrun.toolsmenu.gamemodes.error=Другой режим уже запущен!
+
+beatrun.toolsmenu.gamemodes.infection=Переключить Infection
+beatrun.toolsmenu.gamemodes.infectionstarttime=Время перед началом
+beatrun.toolsmenu.gamemodes.infectiongametime=Продолжительность
+beatrun.toolsmenu.gamemodes.infectiontime=Время в секундах
+beatrun.toolsmenu.gamemodes.datatheft=Переключить Data Theft
+beatrun.toolsmenu.gamemodes.deathmatch=Переключить Deathmatch
+
+# Checkpoints
+beatrun.checkpoints.countdown1=Раз
+beatrun.checkpoints.countdown2=Два
+beatrun.checkpoints.countdown3=ПОШЁЛ!
+beatrun.checkpoints.speedometer=%s км/ч
+
+# DataTheft
+beatrun.datatheft.name=Data Theft (%s)
+beatrun.datatheft.start=Data Theft! Убивайте игроков, собирайте кубики и вкладывайте в банк и зарабатывайте очки
+
+# Deathmatch
+beatrun.deathmatch.name=Deathmatch
+beatrun.deathmatch.start=Deathmatch! Убивайте игроков чтобы зарабатывать очки
+
+# Infection
+beatrun.infection.name=Infection
+beatrun.infection.infectedtext=(Заражённый)
+beatrun.infection.humantext=(Человек)
+beatrun.infection.start=Infection! Дотрагивайтесь до других игроков чтобы заразить их\n%s игрок(а/ов) будет выбрано через %s сек
+beatrun.infection.nosurvivors=Никто...
+beatrun.infection.infected=был заражён!
+beatrun.infection.infectedby=заразил
+beatrun.infection.award=Вы получили 200 XP за выживание!
+beatrun.infection.awardinfected=Вы получили 100 XP за спавн заражённым!
+beatrun.infection.end=Игра окончена!\nВыжившие: %s\nПерезапуск через 15 сек
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_04.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_04.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_dirt_04.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_dirt_04.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_generic_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_generic_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_04.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_04.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_glass_04.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_glass_04.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_grate_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_grate_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_grate_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_grate_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_metal_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_metal_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_04.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_04.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_slide_sand_04.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_slide_sand_04.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_01.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_01.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_01.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_01.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_02.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_02.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_02.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_02.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_03.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_03.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_03.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_03.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_04.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_04.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_04.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_04.wav
diff --git a/beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_05.wav b/beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_05.wav
similarity index 100%
rename from beatrun/gamemodes/beatrun/content/sound/datae/fol_sprint_rustle_05.wav
rename to beatrun/gamemodes/beatrun/content/sound/fol/fol_sprint_rustle_05.wav
diff --git a/beatrun/gamemodes/beatrun/entities/entities/br_rabbitfrog/shared.lua b/beatrun/gamemodes/beatrun/entities/entities/br_rabbitfrog/shared.lua
index 2617232..e171770 100644
--- a/beatrun/gamemodes/beatrun/entities/entities/br_rabbitfrog/shared.lua
+++ b/beatrun/gamemodes/beatrun/entities/entities/br_rabbitfrog/shared.lua
@@ -202,6 +202,7 @@ local function RabbitCalcView(ply, origin, ang)
neweye = true
ply:CLViewPunch(Angle(12, 0, 0))
+
if VManip then
VManip:PlayAnim("vault")
end
diff --git a/beatrun/gamemodes/beatrun/entities/entities/tt_cp/shared.lua b/beatrun/gamemodes/beatrun/entities/entities/tt_cp/shared.lua
index 9e50eb1..d65bb30 100644
--- a/beatrun/gamemodes/beatrun/entities/entities/tt_cp/shared.lua
+++ b/beatrun/gamemodes/beatrun/entities/entities/tt_cp/shared.lua
@@ -100,7 +100,7 @@ function ENT:DrawTranslucent()
render.DrawBeam(newpos, newpos + circleup, 8, 0, 1, red, true)
end
- local nextCP = Checkpoints[self:GetCPNum() + 1] or self
+ local nextCP = IsValid(Checkpoints[self:GetCPNum() + 1]) and Checkpoints[self:GetCPNum() + 1] or self
local selfpos = self:GetPos() + checkheight
local fwAng = (nextCP:GetPos() - selfpos):GetNormalized():Angle()
diff --git a/beatrun/gamemodes/beatrun/entities/weapons/runnerhands/shared.lua b/beatrun/gamemodes/beatrun/entities/weapons/runnerhands/shared.lua
index 07d8f44..78e5cb1 100644
--- a/beatrun/gamemodes/beatrun/entities/weapons/runnerhands/shared.lua
+++ b/beatrun/gamemodes/beatrun/entities/weapons/runnerhands/shared.lua
@@ -1,9 +1,7 @@
-local cvarwindsound
-local minimalvm
+local windsound
if CLIENT then
- minimalvm = CreateClientConVar("Beatrun_MinimalVM", 1, true, true, "Lowers the running viewmodel", 0, 1)
- cvarwindsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises", 0, 1)
+ windsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises", 0, 1)
SWEP.PrintName = "Runner Hands"
SWEP.Slot = 0
@@ -12,7 +10,7 @@ if CLIENT then
SWEP.DrawCrosshair = false
hook.Add("VManipPrePlayAnim", "LOCNoVManip", function()
- if LocalPlayer():GetActiveWeapon():GetClass() == "runnerhands" or blinded then return false end
+ if LocalPlayer():UsingRH() or blinded then return false end
end)
end
@@ -73,10 +71,10 @@ function SWEP:SetupDataTables()
self:NetworkVar("Float", 2, "PunchReset")
end
-local runseq = {
- [6] = true,
- [7] = true
-}
+-- local runseq = {
+-- [6] = true,
+-- [7] = true
+-- }
local oddseq = {
[8] = true,
@@ -86,22 +84,6 @@ local oddseq = {
}
function SWEP:GetViewModelPosition(pos, ang)
- if minimalvm:GetBool() then
- if not self.posz then
- self.posz = pos.z
- end
-
- local seq = self:GetSequence()
-
- if runseq[seq] then
- self.posz = Lerp(10 * FrameTime(), self.posz, -2)
- else
- self.posz = Lerp(10 * FrameTime(), self.posz, 0)
- end
-
- pos.z = pos.z + self.posz
- end
-
if oddseq[self:GetSequence()] then return pos, ang end
self.BobScale = 0
@@ -142,6 +124,7 @@ local fallct = 0
function SWEP:Think()
local ply = self:GetOwner()
local viewmodel = ply:GetViewModel()
+
if not IsValid(viewmodel) then return end
if self:GetHoldType() == "fist" and CurTime() > self:GetPunchReset() then
@@ -163,6 +146,36 @@ function SWEP:Think()
local injump = curseq == 13 or curseq == 14 or curseq == 17 or curseq == -1 or curseq == 1
infall = curseq == 19
+ --[[ what a piece of shit, send help
+ if vel:Length() == 0 and util.QuickTrace(ply:GetShootPos(), ply:GetAimVector() * 30, ply).Hit and ply:GetMoveType() ~= MOVETYPE_NOCLIP and not ply:Crouching() and ply:WaterLevel() == 0 and ply:GetWallrun() == 0 then
+ if (math.floor(ply:LocalEyeAngles().y) <= 35 and math.floor(ply:LocalEyeAngles().y) >= 5) or (math.floor(ply:LocalEyeAngles().y) <= 125 and math.floor(ply:LocalEyeAngles().y) >= 95) or (math.floor(ply:LocalEyeAngles().y) <= -55 and math.floor(ply:LocalEyeAngles().y) >= -85) or (math.floor(ply:LocalEyeAngles().y) <= -145 and math.floor(ply:LocalEyeAngles().y) >= -175) then
+ if CLIENT then
+ BodyLimitX = 20
+
+ return ArmInterrupt("standhandwallright")
+ elseif game.SinglePlayer() then
+ return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallright')")
+ end
+ elseif (math.floor(ply:LocalEyeAngles().y) <= 5 and math.floor(ply:LocalEyeAngles().y) >= -5) or (math.floor(ply:LocalEyeAngles().y) <= 95 and math.floor(ply:LocalEyeAngles().y) >= 85) or (math.floor(ply:LocalEyeAngles().y) <= -85 and math.floor(ply:LocalEyeAngles().y) >= -95) or (math.floor(ply:LocalEyeAngles().y) <= -175 or math.floor(ply:LocalEyeAngles().y) >= 175) then
+ if CLIENT then
+ BodyLimitX = 20
+
+ return ArmInterrupt("standhandwallboth")
+ elseif game.SinglePlayer() then
+ return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallboth')")
+ end
+ elseif (math.floor(ply:LocalEyeAngles().y) <= 5 and math.floor(ply:LocalEyeAngles().y) >= -35) or (math.floor(ply:LocalEyeAngles().y) <= 85 and math.floor(ply:LocalEyeAngles().y) >= 55) or (math.floor(ply:LocalEyeAngles().y) <= -95 and math.floor(ply:LocalEyeAngles().y) >= -125) or (math.floor(ply:LocalEyeAngles().y) <= 175 and math.floor(ply:LocalEyeAngles().y) >= 145) then
+ if CLIENT then
+ BodyLimitX = 20
+
+ return ArmInterrupt("standhandwallleft")
+ elseif game.SinglePlayer() then
+ return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallleft')")
+ end
+ end
+ end
+ --]]
+
self:SetSideStep((curseq == 15 or curseq == 16) and GetConVar("Beatrun_SideStep"):GetBool())
local insidestep = self:GetSideStep()
@@ -296,7 +309,7 @@ function SWEP:Think()
self.RunWind2 = CreateSound(self, "runwind.wav")
end
- if velocity > 250 and cvarwindsound:GetBool() then
+ if velocity > 250 and windsound:GetBool() then
self.RunWind1:Play()
self.RunWind2:Play()
@@ -510,4 +523,4 @@ function SWEP:PrimaryAttack()
end
function SWEP:SecondaryAttack()
-end
\ No newline at end of file
+end
diff --git a/beatrun/gamemodes/beatrun/entities/weapons/shapedrawer/shared.lua b/beatrun/gamemodes/beatrun/entities/weapons/shapedrawer/shared.lua
index 655280c..cd0373d 100644
--- a/beatrun/gamemodes/beatrun/entities/weapons/shapedrawer/shared.lua
+++ b/beatrun/gamemodes/beatrun/entities/weapons/shapedrawer/shared.lua
@@ -67,7 +67,7 @@ end
function SWEP:PrimaryAttack()
self:CallOnClient("PrimaryAttack")
- local ply = self.Owner
+ local ply = self:GetOwner()
if not self.points[#self.points] or (ply:EyePos() + ply:EyeAngles():Forward() * 50):Distance(self.points[#self.points]) > 5 then
table.insert(self.points, ply:EyePos() + ply:EyeAngles():Forward() * 50)
@@ -77,17 +77,20 @@ end
function SWEP:SecondaryAttack()
self:CallOnClient("SecondaryAttack")
- local ply = self.Owner
+ local ply = self:GetOwner()
self.center:Set(ply:GetEyeTrace().HitPos)
end
hook.Add("PostDrawTranslucentRenderables", "ShapeGun", function()
- local ply = Entity(1)
- local wep = ply:GetActiveWeapon() or nil
+ if not CLIENT then return end
- if IsValid(wep) and wep:GetClass() == "shapedrawer" then
- for k, v in ipairs(wep.points) do
+ local ply = LocalPlayer()
+ local wep = ply:GetActiveWeapon()
+ local isShapeDrawer = IsValid(wep) and wep:GetClass() == "shapedrawer"
+
+ if IsValid(ply) and isShapeDrawer then
+ for _, v in ipairs(wep.points) do
render.DrawWireframeBox(v, angle_zero, Vector(-1, -1, -1), Vector(1, 1, 1))
end
diff --git a/beatrun/gamemodes/beatrun/entities/weapons/ziplinegun/shared.lua b/beatrun/gamemodes/beatrun/entities/weapons/ziplinegun/shared.lua
index 71b979b..00b913f 100644
--- a/beatrun/gamemodes/beatrun/entities/weapons/ziplinegun/shared.lua
+++ b/beatrun/gamemodes/beatrun/entities/weapons/ziplinegun/shared.lua
@@ -66,6 +66,8 @@ function SWEP:PrimaryAttack()
if SERVER then
local zip = CreateZipline(ply:EyePos(), ply:GetEyeTrace().HitPos)
+ zip:SetTwoWay(true)
+
table.insert(self.ziplines, zip)
end
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/Maps/dm_cubix_fix.lua b/beatrun/gamemodes/beatrun/gamemode/Maps/dm_cubix_fix.lua
index 7cc192c..a016ce7 100644
--- a/beatrun/gamemodes/beatrun/gamemode/Maps/dm_cubix_fix.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/Maps/dm_cubix_fix.lua
@@ -186,7 +186,7 @@ local spawn = {
}
function PrintAllBars()
- for k, v in pairs(ents.FindByClass("br_swingbar")) do
+ for _, v in pairs(ents.FindByClass("br_swingbar")) do
local pos, ang = v:GetPos(), v:GetAngles()
local str = "{\"br_swingbar\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")},"
print(str)
@@ -194,7 +194,7 @@ function PrintAllBars()
end
function PrintAllCampBoxes()
- for k, v in pairs(ents.FindByClass("br_anticampbox")) do
+ for _, v in pairs(ents.FindByClass("br_anticampbox")) do
local pos, ang = v:GetPos(), v:GetAngles()
local str = "{\"br_anticampbox\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")},"
print(str)
@@ -202,7 +202,7 @@ function PrintAllCampBoxes()
end
local function CreateSpawnEntities()
- for k, v in ipairs(spawn) do
+ for _, v in ipairs(spawn) do
BRProtectedEntity(v[1], v[2], v[3])
end
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/0_UI.lua b/beatrun/gamemodes/beatrun/gamemode/cl/0_UI.lua
index 7621286..2267bb1 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/0_UI.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/0_UI.lua
@@ -203,13 +203,13 @@ end
local function AEUIDraw()
if AEUI.NoDraw then return end
- for k, v in ipairs(AEUI.Panels) do
+ for _, v in ipairs(AEUI.Panels) do
surface.SetAlphaMultiplier(v.alpha or 1)
AEUI:DrawPanel(v)
surface.SetAlphaMultiplier(1)
if v.elements then
- for l, b in ipairs(v.elements) do
+ for _, b in ipairs(v.elements) do
AEUI:DrawElement(v, b)
end
end
@@ -288,7 +288,7 @@ hook.Add("StartCommand", "AEUI_StartCommand", function(ply, cmd)
local click = input.WasMousePressed(MOUSE_LEFT)
if hoveredpanel then
- for k, v in ipairs(hoveredpanel.elements) do
+ for _, v in ipairs(hoveredpanel.elements) do
if (v.onclick or v.hover) and (not v.greyed or not v.greyed()) and v.w and v.h then
local x = SScaleX(hoveredpanel.x) + SScaleX(v.x)
local y = SScaleY(hoveredpanel.y) + SScaleY(v.y) + (hoveredpanel.scroll or 0)
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/AddonWarning.lua b/beatrun/gamemodes/beatrun/gamemode/cl/AddonWarning.lua
index fdcd532..05da52b 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/AddonWarning.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/AddonWarning.lua
@@ -23,30 +23,33 @@ end
local addons = 0
local incompatible = {
- ["1581533176"] = true,
- ["2675972006"] = true,
- ["378401390"] = true,
- ["2027577882"] = true,
- ["1190705063"] = true,
- ["123514260"] = true,
- ["2416989205"] = true,
- ["2591814455"] = true,
- ["240159269"] = true,
- ["2230307188"] = true,
- ["2137973704"] = true,
- ["577145478"] = true,
- ["1632091428"] = true,
- ["1622199072"] = true,
- ["2840019616"] = true,
- ["583517911"] = true,
- ["2106330193"] = true,
- ["2593047682"] = true,
- ["142911907"] = true,
- ["2316713217"] = true,
- ["2052642961"] = true,
- ["2635378860"] = true,
- ["2919957168"] = true,
- ["104815552"] = true
+ ["1581533176"] = true, -- The Aperture [Reupload]
+ ["2675972006"] = true, -- Custom Loadout
+ ["378401390"] = true, -- Quake/Half-Life View bobbing
+ ["2027577882"] = true, -- Mantle + Wallrun
+ ["1190705063"] = true, -- Lerped View Models
+ ["123514260"] = true, -- SharpeYe
+ ["2416989205"] = true, -- Quick Slide
+ ["2591814455"] = true, -- [PF] Half-Life: Alyx
+ ["240159269"] = true, -- S.M.A.R.T.:Smooth Parkour Movement
+ ["2230307188"] = true, -- EFT Walk Sounds (Footsteps)
+ ["2137973704"] = true, -- [PF] Modern Warfare 2
+ ["577145478"] = true, -- ViewMod
+ ["1632091428"] = true, -- Fine Speed
+ ["1622199072"] = true, -- SaVav Parkour Mod
+ ["2840019616"] = true, -- cBobbing (Reupped & Fixed)
+ ["583517911"] = true, -- Eye View Attachment
+ ["2106330193"] = true, -- BSMod Punch SWEP + Kick & KillMoves
+ ["2593047682"] = true, -- Viewpunch Viewbob
+ ["142911907"] = true, -- Advanced Combat Rolls
+ ["2316713217"] = true, -- Player Speeds Changer 2.0 [REUPLOAD]
+ ["2635378860"] = true, -- MW/WZ Skydive/Parachute + Infil
+ ["2919957168"] = true, -- Modern Warfare II - Takedowns & Revive System
+ ["2600234804"] = true, -- ASTW2 - Base Weapons
+ ["2824714462"] = true, -- [TFA] Screen Shake
+ ["3037375111"] = true, -- Quick Slide With Legs
+ ["748422181"] = true, -- FOV Changer
+ ["2930331275"] = true -- Realistic Fragmentation System
}
local warnpanel = {
@@ -79,7 +82,7 @@ local warntext = {
y = warnpanel.h * 0.125,
centered = true,
color = color_white,
- string = "NOTICE\nPlease disable the following addons before playing\nor submitting any issues to GitHub:"
+ string = language.GetPhrase("beatrun.addonwarning.warntext")
}
table.insert(warnpanel.elements, warntext)
@@ -91,21 +94,18 @@ local quitbutton = {
y = warnpanel.h * 0.85,
centered = true,
color = color_white,
- string = "Return to Main Menu",
+ string = "#beatrun.addonwarning.quitbutton",
onclick = function(self)
surface.PlaySound("garrysmod/ui_click.wav")
- MsgC(Color(255, 100, 100), "Quitting Beatrun due to conflicting addons!")
- timer.Simple(0.5, function()
- RunConsoleCommand("killserver")
+ timer.Simple(0.2, function()
+ RunConsoleCommand("disconnect")
end)
-
- self.onclick = nil
end
}
table.insert(warnpanel.elements, quitbutton)
-AEUI:AddButton(warnpanel, "Play", warnclosebutton, "AEUIDefault", warnpanel.w * 0.5, warnpanel.h * 0.93, true)
+AEUI:AddButton(warnpanel, "#beatrun.addonwarning.play", warnclosebutton, "AEUIDefault", warnpanel.w * 0.5, warnpanel.h * 0.93, true)
local conflictlist = {
type = "Text",
@@ -132,8 +132,6 @@ local function CheckAddons()
end
end
- print(conflictlist.string)
-
return addons
end
@@ -142,7 +140,7 @@ local function WarningIcon()
surface.SetFont("BeatrunHUD")
surface.SetTextPos(2, 0)
surface.SetTextColor(220, 20, 20, math.abs(math.sin(CurTime() * 2) * 255))
- surface.DrawText("CONFLICTING ADDONS FOUND")
+ surface.DrawText("#beatrun.addonwarning.conflictfound")
return
else
@@ -161,4 +159,4 @@ if conflictlist.string ~= "" then
AEUI:AddPanel(warnpanel)
AEUI:AddPanel(conflictpanel)
end)
-end
\ No newline at end of file
+end
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/BodyAnim.lua b/beatrun/gamemodes/beatrun/gamemode/cl/BodyAnim.lua
index efc53db..44d9422 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/BodyAnim.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/BodyAnim.lua
@@ -10,11 +10,14 @@ BodyAnimString = "nil"
BodyAnimMDLString = "nil"
BodyAnimSpeed = 1
bodyanimlastattachang = Angle(0, 0, 0)
+
followplayer = true
deleteonend = true
lockang = false
+
CamAddAng = false
CamIgnoreAng = false
+
-- local BodyAnimPos = Vector(0, 0, 0)
-- local BodyAnimAngLerp = Angle(0, 0, 0)
-- local DidDraw = false
@@ -24,29 +27,38 @@ local savedeyeangb = Angle(0, 0, 0)
-- local bodylockview = false
-- local bodyanimdone = false
-- local holstertime = 0
+
local animmodelstring = ""
local showweapon = false
local showvm = false
local usefullbody = false
local ignorez = false
local customcycle = false
+
deathanim = false
+
local allowmove = false
local allowedangchange = false
local attach, attachId, weapontoidle = nil, nil, nil
local smoothend = false
local endlerp = 0
+
camoffset = Vector()
camjoint = "eyes"
+
BodyAnimCrouchLerp = 1
BodyAnimCrouchLerpZ = 0
BodyAnimLimitEase = false
+
CamShake = false
CamShakeAng = Angle()
CamShakeMult = 1
+
local lastangy = 0
+
viewtiltlerp = Angle()
ViewTiltAngle = Angle()
+
local BodyAnimStartPos = Vector()
local view = {}
local justremoved = false
@@ -108,7 +120,7 @@ function RemoveBodyAnim(noang)
local currentwep = ply:GetActiveWeapon()
local vm = ply:GetViewModel()
- if IsValid(currentwep) and currentwep:GetClass() ~= "runnerhands" then
+ if ply:notUsingRH() then
if currentwep.PlayViewModelAnimation then
currentwep:PlayViewModelAnimation("Draw")
else
@@ -210,13 +222,13 @@ function CacheLerpBodyAnim()
local pos = LocalPlayer():GetPos()
-- local posdelta = pos - matrixfrompos
- local self = BodyAnim
- self.m = self.m or Matrix()
+ local this = BodyAnim
+ this.m = this.m or Matrix()
local from = matrixfrom
local to = matrixto
- for bone = 0, self:GetBoneCount() - 1 do
+ for bone = 0, this:GetBoneCount() - 1 do
if not armbones[BodyAnim:GetBoneName(bone)] then
if not to[bone] then
to[bone] = {{}, {}, {}}
@@ -228,7 +240,7 @@ function CacheLerpBodyAnim()
from[bone] = cachebody[bone]:FastToTable(from[bone]) or from[bone]
to[bone] = to[bone] or ModelBoneMatrix:FastToTable(to[bone])
- local bonematrix = self:GetBoneMatrix(bone)
+ local bonematrix = this:GetBoneMatrix(bone)
bonematrix:SetTranslation(bonematrix:GetTranslation() - pos)
to[bone] = bonematrix:FastToTable(to[bone])
@@ -243,8 +255,8 @@ function CacheLerpBodyAnim()
v[4] = LerpL(transitionlerp, from[4], v[4])
end
- if not self.m then
- self.m = Matrix(to[bone])
+ if not this.m then
+ this.m = Matrix(to[bone])
else
local bt = to[bone]
local bt1 = bt[1]
@@ -252,12 +264,12 @@ function CacheLerpBodyAnim()
local bt3 = bt[3]
slot15 = bt[4]
- self.m:SetUnpacked(bt1[1], bt1[2], bt1[3], bt1[4], bt2[1], bt2[2], bt2[3], bt2[4], bt3[1], bt3[2], bt3[3], bt3[4], 0, 0, 0, 1)
+ this.m:SetUnpacked(bt1[1], bt1[2], bt1[3], bt1[4], bt2[1], bt2[2], bt2[3], bt2[4], bt3[1], bt3[2], bt3[3], bt3[4], 0, 0, 0, 1)
end
- self.m:SetTranslation(self.m:GetTranslation() + pos)
- self.m:SetScale(scalevec)
- self:SetBoneMatrix(bone, self.m)
+ this.m:SetTranslation(this.m:GetTranslation() + pos)
+ this.m:SetScale(scalevec)
+ this:SetBoneMatrix(bone, this.m)
end
end
@@ -331,8 +343,8 @@ function StartBodyAnim(animtable)
if not IsValid(ply:GetHands()) then return end
local plymodel = ply
- local playermodel = string.Replace(ply:GetModel(), "models/models/", "models/")
- local handsmodel = string.Replace(ply:GetHands():GetModel(), "models/models/", "models/")
+ local playermodel = ply:GetModel()
+ local handsmodel = ply:GetHands():GetModel()
if usefullbody == 2 then
BodyAnimMDL = ClientsideModel(playermodel, RENDERGROUP_BOTH)
@@ -468,8 +480,7 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
return
end
- -- This is the issue with disappearing model when sliding, should be fixed for now
- if IsValid(BodyAnim) and pos:Distance(ply:EyePos()) > 20 then -- TODO: Something if appears again...
+ if IsValid(BodyAnim) and pos:Distance(ply:EyePos()) > 20 then
if updatethirdperson then
ply:SetNoDraw(false)
BodyAnim:SetNoDraw(true)
@@ -494,9 +505,8 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
if ply:Crouching() then
local from = BodyAnimCrouchLerpZ
- local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
+ if ply:UsingRH() then
from = ply:EyePos().z - 64
end
@@ -696,8 +706,6 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
end
hook.Add("CreateMove", "BodyLimitMove", function(cmd)
- -- local ply = LocalPlayer()
-
if IsValid(BodyAnimMDL) and not allowmove then
cmd:ClearButtons()
cmd:ClearMovement()
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/BuildModeHUD.lua b/beatrun/gamemodes/beatrun/gamemode/cl/BuildModeHUD.lua
index 4f854d0..f146a60 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/BuildModeHUD.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/BuildModeHUD.lua
@@ -57,9 +57,10 @@ local function infostring()
y = math.Round(y)
p = math.Round(p)
- local a = "Index: " .. BuildModeIndex .. "\nSelected: " .. table.Count(buildmode_selected) .. "\nAngle: " .. p .. ", " .. y .. ", " .. r
+ local angle = p .. ", " .. y .. ", " .. r
+ local str = language.GetPhrase("beatrun.buildmodehud.info"):format(BuildModeIndex, table.Count(buildmode_selected), angle)
- return a
+ return str
end
AEUI:AddText(bminfo, infostring, "AEUIDefault", bminfo.w / 2, bminfo.h / 2 - 20, true)
@@ -75,25 +76,27 @@ end
local function PanelElementsToggle(e)
local showingents = propspanel.elements == EntitiesElements
propspanel.elements = showingents and propspanel_elements or EntitiesElements
- e.string = showingents and "Menu / Props" or "Menu / Entities"
+
+ e.string = showingents and "#beatrun.buildmodehud.props" or "#beatrun.buildmodehud.entities"
+
propspanel.maxscroll = nil
propspanel.scroll = nil
end
-local b = AEUI:AddButton(bmbuttons, "Drag (G)", BuildModeHUDButton, "AEUIDefault", 2, 0, false)
+local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.drag", BuildModeHUDButton, "AEUIDefault", 2, 0, false)
b.key = KEY_G
b.greyed = GreyButtons
-local b = AEUI:AddButton(bmbuttons, "Copy (SHIFT+D)", BuildModeHUDButton, "AEUIDefault", 2, 25, false)
+local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.copy", BuildModeHUDButton, "AEUIDefault", 2, 25, false)
b.key = KEY_D
b.greyed = GreyButtons
-local b = AEUI:AddButton(bmbuttons, "Delete (DEL/BCKSPC)", BuildModeHUDButton, "AEUIDefault", 2, 50, false)
+local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.delete", BuildModeHUDButton, "AEUIDefault", 2, 50, false)
b.key = KEY_DELETE
b.greyed = GreyButtons
-local b = AEUI:AddButton(bmbuttons, "Highlight (T)", BuildModeHUDButton, "AEUIDefault", 2, 75, false)
+local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.highlight", BuildModeHUDButton, "AEUIDefault", 2, 75, false)
b.key = KEY_T
b.greyed = GreyButtons
-AEUI:AddButton(elementstogglepanel, "Menu / Props", PanelElementsToggle, "AEUILarge", 192, 20, true)
+AEUI:AddButton(elementstogglepanel, "#beatrun.buildmodehud.props", PanelElementsToggle, "AEUILarge", 192, 20, true)
local dummy = ClientsideModel("models/hunter/blocks/cube025x025x025.mdl")
@@ -150,7 +153,6 @@ end
local function BMPropClick(e)
BuildModeIndex = e.prop or 0
- print(e.prop)
LocalPlayer():EmitSound("buttonclick.wav")
if BuildModeIndex == 0 then
@@ -168,7 +170,7 @@ end
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64)
img.prop = 0
-img.hover = "Select"
+img.hover = "#beatrun.buildmodehud.select"
local row = 1
local col = 0
@@ -194,7 +196,7 @@ end
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 64 * row, 64 * col, 64, 64)
img.prop = 0
-img.hover = "Select"
+img.hover = "#beatrun.buildmodehud.select"
local function BuildModeElements()
propspanel.elements = EntitiesElements
@@ -206,7 +208,7 @@ local function BuildModeElements()
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64)
img.prop = 0
- img.hover = "Select"
+ img.hover = "#beatrun.buildmodehud.select"
local buildmode_enticons = {
br_swingbar = Material("vgui/editor/swingbar.png"),
@@ -221,7 +223,7 @@ local function BuildModeElements()
}
local buildmode_entnames = {
- br_zipline = "Zipline (SHIFT = 2-Way)"
+ br_zipline = "#beatrun.buildmodehud.zipline"
}
local obsolete = Material("editor/obsolete")
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/OnlineCourse.lua b/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua
similarity index 67%
rename from beatrun/gamemodes/beatrun/gamemode/cl/OnlineCourse.lua
rename to beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua
index 8fd909a..7a5c1ee 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/OnlineCourse.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua
@@ -1,19 +1,26 @@
-local apikey = CreateClientConVar("Beatrun_Apikey", "0", true, false, "API key")
-local domain = CreateClientConVar("Beatrun_Domain", "courses.beatrun.ru", true, false, "Online courses domain")
+local apikey = CreateClientConVar("Beatrun_Apikey", "0", true, false, language.GetPhrase("beatrun.convars.apikey"))
+local domain = CreateClientConVar("Beatrun_Domain", "courses.beatrun.ru", true, false, language.GetPhrase("beatrun.convars.domain"))
local QueuedArgs = NULL
local QueuedFunction = NULL
-concommand.Add("beatrun_confirm", function()
+local currentMap = game.GetMap()
+
+concommand.Add("Beatrun_Confirm", function()
if QueuedArgs and QueuedFunction then
QueuedFunction(QueuedArgs)
+
return
end
+
if QueuedFunction then
QueuedFunction()
+
return
end
end)
-concommand.Add("beatrun_cancel", function()
+
+concommand.Add("Beatrun_Cancel", function()
+ QueuedArgs = NULL
QueuedFunction = NULL
end)
@@ -23,22 +30,22 @@ local function GetCurrentMapWorkshopID()
_, addon_folders = file.Find("*", addon.title)
- if file.Exists("maps/" .. game.GetMap() .. ".bsp", addon.title) then return addon.wsid end
+ if file.Exists("maps/" .. currentMap .. ".bsp", addon.title) then return addon.wsid end
end
return 0
end
function UploadCourse()
- if Course_Name == "" or Course_ID == "" then return print("Can't upload in Freeplay") end
+ if Course_Name == "" or Course_ID == "" then return print(language.GetPhrase("beatrun.coursesdatabase.cantuploadfreeplay")) end
local url = domain:GetString() .. "/upload.php"
- local data = file.Open("beatrun/courses/" .. game.GetMap() .. "/" .. Course_ID .. ".txt", "rb", "DATA")
+ local data = file.Open("beatrun/courses/" .. currentMap .. "/" .. Course_ID .. ".txt", "rb", "DATA")
local filedata = util.Decompress(data:Read(data:Size()))
http.Post(url, {
key = apikey:GetString(),
- map = string.Replace(game.GetMap(), " ", "-"),
+ map = string.Replace(currentMap, " ", "-"),
course_data = util.Base64Encode(filedata, true),
mapid = GetCurrentMapWorkshopID()
}, function(body, length, headers, code) -- onSuccess function
@@ -54,24 +61,24 @@ end
concommand.Add("Beatrun_UploadCourse", function()
QueuedFunction = UploadCourse
- print("You're trying to upload a course with the name "..Course_Name.." and on map "..game.GetMap()..".")
- print("Write beatrun_confirm to continue, or beatrun_cancel to stop.")
+
+ print(language.GetPhrase("beatrun.coursesdatabase.upload1"):format(Course_Name, currentMap))
+ print(language.GetPhrase("beatrun.coursesdatabase.upload2"))
end)
function GetCourse(sharecode)
local url = domain:GetString() .. "/getcourse.php"
.. "?sharecode=" .. sharecode
- .. "&map=" .. string.gsub(game.GetMap(), " ", "-")
+ .. "&map=" .. string.Replace(currentMap, " ", "-")
.. "&key=" .. apikey:GetString()
http.Fetch(url, function(body, length, headers, code)
if code == 200 then
- print("Success! | Response: " .. code .. " | Length: " .. length)
- print("Loading course...")
+ print("Success! | Response: " .. code .. " | Length: " .. length .. "\nLoading course...")
PrintTable(headers)
- local dir = "beatrun/courses/" .. game.GetMap() .. "/"
+ local dir = "beatrun/courses/" .. currentMap .. "/"
file.CreateDir(dir)
local coursedata = util.Compress(body)
@@ -103,15 +110,15 @@ concommand.Add("Beatrun_LoadCode", function(ply, cmd, args, argstr)
end)
function UpdateCourse(course_code)
- if Course_Name == "" or Course_ID == "" then return print("Can't upload in Freeplay") end
+ if Course_Name == "" or Course_ID == "" then return print(language.GetPhrase("beatrun.coursesdatabase.cantuploadfreeplay")) end
local url = domain:GetString() .. "/updatecourse.php"
- local data = file.Open("beatrun/courses/" .. game.GetMap() .. "/" .. Course_ID .. ".txt", "rb", "DATA")
+ local data = file.Open("beatrun/courses/" .. currentMap .. "/" .. Course_ID .. ".txt", "rb", "DATA")
local filedata = util.Decompress(data:Read(data:Size()))
http.Post(url, {
key = apikey:GetString(),
- map = string.Replace(game.GetMap(), " ", "-"),
+ map = string.Replace(currentMap, " ", "-"),
course_data = util.Base64Encode(filedata, true),
code = course_code
}, function(body, length, headers, code) -- onSuccess function
@@ -128,6 +135,7 @@ end
concommand.Add("Beatrun_UpdateCode", function(ply, cmd, args, argstr)
QueuedFunction = UpdateCourse
QueuedArgs = args[1]
- print("You're trying to update a course with this code: "..args[1]..", with a course on map "..game.GetMap().." and name "..Course_Name..".")
- print("Write beatrun_confirm to continue, or beatrun_cancel to stop.")
-end)
+
+ print(language.GetPhrase("beatrun.coursesdatabase.update1"):format(QueuedArgs, Course_Name, currentMap))
+ print(language.GetPhrase("beatrun.coursesdatabase.upload2"))
+end)
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/DiscordPresence.lua b/beatrun/gamemodes/beatrun/gamemode/cl/DiscordPresence.lua
index 9259173..41220ee 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/DiscordPresence.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/DiscordPresence.lua
@@ -1,4 +1,4 @@
-if not util.IsBinaryModuleInstalled("gdiscord", "GAME") then return end
+if not util.IsBinaryModuleInstalled("gdiscord") then return end
require("gdiscord")
@@ -8,6 +8,10 @@ local refresh_time = 60
local discord_start = discord_start or -1
function DiscordUpdate()
+ local ply = LocalPlayer()
+
+ if not ply.GetLevel then return end
+
local rpc_data = {}
if game.SinglePlayer() then
@@ -34,14 +38,10 @@ function DiscordUpdate()
rpc_data["partyMax"] = 0
end
- local level = LocalPlayer():GetLevel()
+ local level = ply:GetLevel()
local customname = hook.Run("BeatrunHUDCourse")
local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay"
- if course == nil then
- course = "Freeplay"
- end
-
rpc_data["details"] = "Level: " .. level .. " | Map: " .. game.GetMap()
rpc_data["startTimestamp"] = discord_start
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/Fall.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Fall.lua
index 809b8d0..cb6a91f 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Fall.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Fall.lua
@@ -16,6 +16,7 @@ local vignettealpha = 0
local function FallCheck()
local ply = LocalPlayer()
if not IsValid(ply) then return end
+
local speed = ply:GetVelocity().z
if not ply.FallStatic and speed <= -800 and ply:GetMoveType() ~= MOVETYPE_NOCLIP and ply:GetDive() == false then
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/HUD.lua b/beatrun/gamemodes/beatrun/gamemode/cl/HUD.lua
index a613443..928ebda 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/HUD.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/HUD.lua
@@ -1,16 +1,17 @@
-local showtotalXP = CreateClientConVar("Beatrun_HUDXP", "1", true, false, "Show total XP near nickname", 0, 1)
-local sway = CreateClientConVar("Beatrun_HUDSway", "1", true, false, "Display HUD swaying", 0, 1)
-local dynamic = CreateClientConVar("Beatrun_HUDDynamic", "0", true, false, "Hide HUD when moving", 0, 1)
-local hidden = CreateClientConVar("Beatrun_HUDHidden", "0", true, false, "Hides most of the XP HUD", 0, 2)
-local reticle = CreateClientConVar("Beatrun_HUDReticle", "1", true, false, "Display a reticle", 0, 1)
+local showtotalXP = CreateClientConVar("Beatrun_HUDXP", "1", true, false, language.GetPhrase("beatrun.convars.hudxp"), 0, 1)
+local sway = CreateClientConVar("Beatrun_HUDSway", "1", true, false, language.GetPhrase("beatrun.convars.hudsway"), 0, 1)
+local dynamic = CreateClientConVar("Beatrun_HUDDynamic", "0", true, false, language.GetPhrase("beatrun.convars.huddynamic"), 0, 1)
+local hidden = CreateClientConVar("Beatrun_HUDHidden", "0", true, false, language.GetPhrase("beatrun.convars.hudhidden"), 0, 2)
+local reticle = CreateClientConVar("Beatrun_HUDReticle", "1", true, false, language.GetPhrase("beatrun.convars.hudreticle"), 0, 1)
+
+CreateClientConVar("Beatrun_HUDTextColor", "255 255 255 255", true, true, language.GetPhrase("beatrun.convars.hudtextcolor"))
+CreateClientConVar("Beatrun_HUDCornerColor", "20 20 20 100", true, true, language.GetPhrase("beatrun.convars.hudcornercolor"))
+CreateClientConVar("Beatrun_HUDFloatingXPColor", "255 255 255 255", true, true, language.GetPhrase("beatrun.convars.hudfloatxpcolor"))
+
local packetloss = Material("vgui/packetloss.png")
local lastloss = 0
local MELogo = Material("vgui/MELogo.png", "mips smooth")
-CreateClientConVar("Beatrun_HUDTextColor", "255 255 255 255", true, true, "HUD Text Color\nDefault: 255 255 255 255")
-CreateClientConVar("Beatrun_HUDCornerColor", "20 20 20 100", true, true, "HUD Left Corner Color\nDefault: 20 20 20 100")
-CreateClientConVar("Beatrun_HUDFloatingXPColor", "255 255 255 255", true, true, "HUD Floating XP Color\nDefault: 255 255 255 255")
-
local hide = {
CHudBattery = true,
CHudHealth = true,
@@ -129,12 +130,12 @@ local function BeatrunHUD()
surface.SetFont("DebugFixedSmall")
- -- local vtext = (ply:SteamID() or "?") .. " | " .. VERSIONGLOBAL
- -- local tw, th = surface.GetTextSize(vtext)
- -- surface.SetTextColor(255, 255, 255, 15)
- -- surface.SetTextPos(scrw - tw, 0)
- -- surface.DrawText(vtext)
- -- surface.SetFont("BeatrunHUD")
+ local vtext = VERSIONGLOBAL
+ local tw, _ = surface.GetTextSize(vtext)
+ surface.SetTextColor(255, 255, 255, 15)
+ surface.SetTextPos(scrw - tw, 0)
+ surface.DrawText(vtext)
+ surface.SetFont("BeatrunHUD")
local pl = ply:GetNW2Int("PLoss")
local CT = CurTime()
@@ -170,7 +171,7 @@ local function BeatrunHUD()
local coursename = nil
local customname = hook.Run("BeatrunHUDCourse")
- coursename = customname and customname or Course_Name ~= "" and "Course: " .. Course_Name or "Freeplay"
+ coursename = customname and customname or Course_Name ~= "" and language.GetPhrase("beatrun.hud.course"):format(Course_Name) or "#beatrun.hud.freeplay"
-- local lastxp = ply.LastXP or 0
local nicktext = nil
@@ -223,7 +224,7 @@ local function BeatrunHUD()
surface.SetFont("BeatrunHUD")
surface.SetTextColor(text_color)
surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.9 + vp.x)
- surface.DrawText("Lv." .. ply:GetLevel())
+ surface.DrawText(language.GetPhrase("beatrun.hud.lvl"):format(ply:GetLevel()))
if tobool(LocalPlayer():GetInfo("Beatrun_PuristMode")) then
surface.SetDrawColor(230, 230, 230)
@@ -396,7 +397,7 @@ function BeatrunLeaderboard(forced)
if isinfection and pbtimenum == 0 and v:GetNW2Bool("Infected") then
surface.SetTextColor(infectorcolor)
- surface.DrawText(" | Infector")
+ surface.DrawText(" | " .. language.GetPhrase("beatrun.hud.infector"))
else
surface.DrawText(" | " .. pbtime)
end
@@ -541,7 +542,7 @@ local function BeatrunReticle()
local wep = LocalPlayer():GetActiveWeapon()
- if not IsValid(wep) or wep:GetClass() ~= "runnerhands" then return end
+ if not IsValid(wep) or LocalPlayer():notUsingRH() then return end
surface.SetDrawColor(255, 255, 255)
surface.SetMaterial(crosshair_standard)
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua b/beatrun/gamemodes/beatrun/gamemode/cl/JumpAnim.lua
index 04c17b9..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,10 +102,20 @@ fbanims = {
ladderclimbuprighthandstill = true,
jumpidle = true,
jumpair = true,
+ vaultkong = true,
+ vaultonto = true,
+ vaultover = true,
+ vaultontohigh = true,
+ vaultoverhigh = true,
walkbalancefalloffright = true,
meleeairstill = true,
swingjumpoff = true,
- snatchscar = true
+ snatchscar = true,
+ water_swimfwd = true,
+ water_swimright = true,
+ water_swimleft = true,
+ water_swimback = true,
+ water_float = true
}
local jumpanims = {
@@ -149,7 +154,6 @@ local events = {
fall = true,
ladderclimbleft = true,
jumpwallrun = true,
- vaultonto = true,
ziplinestart = true,
hangstrafeleft = true,
hangstraferight = true,
@@ -165,7 +169,6 @@ local events = {
jumpslide = true,
swingpipeleft = true,
ladderenterhang = true,
- vault = true,
disarmsniper = true,
jumpstill = true,
climb = true,
@@ -199,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 = {
@@ -275,7 +281,10 @@ local armfollowanims = {
diestandlong = true,
diveslidestart = true,
vaultoverhigh = true,
- walkfwd = true
+ walkfwd = true,
+ crouchstill = true,
+ crouchfwd = true,
+ crouchbwd = true
}
local armlock = {
@@ -321,10 +330,13 @@ local stillanims = {
local arminterrupts = {
punchright = true,
- doorbash = true,
- punchmid = true,
punchleft = true,
- jumpturnflypiecesign = true
+ punchmid = true,
+ doorbash = true,
+ jumpturnflypiecesign = true,
+ standhandwallright = true,
+ standhandwallleft = true,
+ standhandwallboth = true
}
local transitionanims = {
@@ -333,8 +345,6 @@ local transitionanims = {
ladderexittoplefthand = "runfwd",
walktostandleft = "stand",
fallinguncontrolled = "runfwd",
- vaultoverhigh = "runfwd",
- vaultonto = "runfwd",
hangstrafeleft = "hang",
ladderclimbhangstart = "ladderclimbuprighthandstill",
hanghardstart2 = "hang",
@@ -350,7 +360,6 @@ local transitionanims = {
hangheaveup = "runfwd",
dodgejumpleft = "stand",
walkbalancefalloffleft = "jumpair",
- vaultover = "jumpair",
meleeairhit = "jumpair",
dodgejumpright = "stand",
meleeair = "jumpair",
@@ -368,7 +377,6 @@ local transitionanims = {
ladderclimbuplefthand = "ladderclimbuplefthandstill",
jumpturnfly = "jumpturnflyidle",
meleewrleft = "jumpair",
- vaultkong = "runfwd",
meleeslide = "meslideloop",
stepuprightleg = "runfwd",
snatchsniper = "stand",
@@ -377,8 +385,17 @@ local transitionanims = {
wallrunverticalturn = "jumpslow",
ladderclimbuprighthand = "ladderclimbuprighthandstill",
meleeairstill = "jumpair",
+ vaultoverhigh = "runfwd",
+ vaultonto = "runfwd",
+ vaultover = "jumpair",
+ vaultkong = "runfwd",
vaultontohigh = "runfwd",
- snatchscar = "stand"
+ snatchscar = "stand",
+ water_swimfwd = "runfwd",
+ water_swimright = "runfwd",
+ water_swimleft = "runfwd",
+ water_swimback = "runfwd",
+ water_float = "runfwd"
}
local nospinebend = {
@@ -412,7 +429,10 @@ local nospinebend = {
ladderclimbuprighthand = true,
ladderclimbhangstart = true,
vaultontohigh = true,
- snatchscar = true
+ snatchscar = true,
+ crouchstill = true,
+ crouchfwd = true,
+ crouchbwd = true
}
local worldarm = {
@@ -442,8 +462,12 @@ local worldarm = {
ladderclimbuprighthand = true,
ladderclimbhangstart = true,
snatchscar = true,
- jumpcoil = true,
- jumpturnlandidle = true
+ jumpturnlandidle = true,
+ standhandwallright = true,
+ standhandwallleft = true,
+ standhandwallboth = true,
+ swing = true,
+ swingstraight = true
}
local ignorezarm = {
@@ -464,7 +488,8 @@ local nocyclereset = {
local ignorebac = {
evaderoll = true,
- meroll = true
+ meroll = true,
+ merollgun = true
}
local customspeed = {
@@ -489,7 +514,7 @@ local customarmoffset = {
meslidestart45 = Vector(2, 5, 5),
meslideloop45 = Vector(2, 5, 5),
meslideend = Vector(2, 5, 9.5),
- meslideendprone = Vector(2, 5, 9.5),
+ meslideendprone = Vector(0, 0, 3),
meleeslide = Vector(2, 5, 9.5),
jumpturnfly = Vector(0, 2.5, 7.5),
jumpturnflyidle = Vector(0, 2.5, 7.5),
@@ -508,9 +533,9 @@ local customarmoffset = {
ladderexittoprighthand = Vector(5, 0, 0),
ladderclimbhangstart = Vector(-5, 0, 0),
ladderenterbottom = Vector(-7.5, 0, 0),
- crouchstill = Vector(-4, 0, -5),
- crouchfwd = Vector(-4, 0, -5),
- crouchbwd = Vector(0, 0, 0),
+ crouchstill = Vector(-4, 0, -2),
+ crouchfwd = Vector(-4, 0, -2),
+ crouchbwd = Vector(-4, 0, -2),
walkfwd = Vector(10, 0, -10),
runbwd = Vector(0, 0, 3),
stand = Vector(10, 0, -10),
@@ -533,9 +558,9 @@ local customcamoffset = {
hangstrafeleft = Vector(-2.5, 0, 0),
hangstraferight = Vector(-2.5, 0, 0),
snatchscar = snatchscarcam1,
- crouchstill = Vector(0, 0, 2.5),
- crouchfwd = Vector(0, 0, 2.5),
- crouchbwd = Vector(0, 0, 2.5)
+ crouchstill = Vector(2, 0, 2.5),
+ crouchfwd = Vector(2, 0, 2.5),
+ crouchbwd = Vector(2, 0, 2.5)
}
local transitionchecks = {
@@ -753,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)
@@ -914,7 +946,6 @@ fbfunctions = {
local defaultcamoffset = Vector()
local playermodelbones = {"ValveBiped.Bip01_L_UpperArm", "ValveBiped.Bip01_R_UpperArm"}
-
local fingers = {"ValveBiped.Bip01_L_Finger4", "ValveBiped.Bip01_L_Finger41", "ValveBiped.Bip01_L_Finger3", "ValveBiped.Bip01_L_Finger31", "ValveBiped.Bip01_L_Finger2", "ValveBiped.Bip01_L_Finger21", "ValveBiped.Bip01_L_Finger1", "ValveBiped.Bip01_L_Finger11", "ValveBiped.Bip01_R_Finger4", "ValveBiped.Bip01_R_Finger41", "ValveBiped.Bip01_R_Finger3", "ValveBiped.Bip01_R_Finger31", "ValveBiped.Bip01_R_Finger2", "ValveBiped.Bip01_R_Finger21", "ValveBiped.Bip01_R_Finger1", "ValveBiped.Bip01_R_Finger11"}
local fingerscustom = {
@@ -1011,7 +1042,6 @@ eventsounds = {
}
local CharaName = "Faith"
-local CharaLen = #CharaName
local function BodyEventSounds(anim)
local tbl = eventsounds[anim]
@@ -1022,7 +1052,7 @@ local function BodyEventSounds(anim)
for k, v in pairs(tbl) do
local func = nil
- if v:Left(CharaLen) == CharaName then
+ if v:Left(#CharaName) == CharaName then
func = ply.FaithVO
else
func = ply.EmitSound
@@ -1212,7 +1242,7 @@ local function JumpArmDraw(a, b, c)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
+ if ply:UsingRH() then
if not worldarm[BodyAnimString] then
cam.Start3D(pos, ang)
cam.IgnoreZ(ignorezarm[BodyAnimString] or false)
@@ -1372,7 +1402,7 @@ function ArmInterrupt(anim)
local arm = CreateBodyAnimArmCopy()
if IsValid(arm) then
- for k, v in ipairs(fingers) do
+ for _, v in ipairs(fingers) do
local b = BodyAnimArmCopy:LookupBone(v)
if b then
@@ -1380,7 +1410,7 @@ function ArmInterrupt(anim)
end
end
- for k, v in pairs(fingerscustom) do
+ for k, _ in pairs(fingerscustom) do
local b = BodyAnimArmCopy:LookupBone(k)
if b then
@@ -1388,6 +1418,22 @@ function ArmInterrupt(anim)
end
end
+ --[[ TODO: make work good
+ if string.match(anim, "standhandwall") then
+ local ply = LocalPlayer()
+ local trace = util.QuickTrace(ply:GetShootPos(), ply:GetAimVector() * 30, ply)
+ local x = trace.Normal.x < 0.6 and trace.Normal.x or trace.Normal.y
+ local y = trace.Normal.y > -0.8 and trace.Normal.y or -trace.Normal.x
+
+ local newAng = Angle(x * (5 * trace.Fraction * x), 0, x * (10 * trace.Fraction * y))
+
+ ply:ChatPrint("Fraction: " .. tostring(trace.Fraction))
+ ply:ChatPrint("Normal: " .. tostring(trace.Normal))
+
+ arm:SetAngles(newAng)
+ end
+ --]]
+
arm:SetSequence(anim)
arm:SetCycle(0)
end
@@ -1623,6 +1669,20 @@ local function JumpThink()
BodyAnim:SetSequence(transitionanims[BodyAnimString])
end
+ if ply:WaterLevel() >= 2 and not ply:Crouching() and not ply:OnGround() and ply:GetMoveType() ~= MOVETYPE_NOCLIP then
+ BodyAnim:SetSequence(BodyAnim:LookupSequence("water_float"))
+
+ if ply:KeyDown(IN_MOVELEFT) and vel_l > 5 then
+ BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimleft"))
+ elseif ply:KeyDown(IN_MOVERIGHT) and vel_l > 5 then
+ BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimright"))
+ elseif ply:KeyDown(IN_FORWARD) and vel_l > 5 then
+ BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimfwd"))
+ elseif ply:KeyDown(IN_BACK) and vel_l > 5 then
+ BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimback"))
+ end
+ end
+
if BodyAnimString == "wallrunverticalstart" or BodyAnimString == "wallrunvertical" then
ang = ply.WallrunOrigAng or ang
BodyAnimSpeed = 1.2 * math.Clamp((LocalPlayer():GetWallrunTime() - CurTime()) / 1.2, 0.5, 1)
@@ -1728,4 +1788,4 @@ local function JumpThink()
end
end
-hook.Add("Think", "JumpThink", JumpThink)
\ No newline at end of file
+hook.Add("Think", "JumpThink", JumpThink)
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/Menu_Course.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Menu_Course.lua
index 6ce80e1..80b9e40 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Menu_Course.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Menu_Course.lua
@@ -25,12 +25,12 @@ local function buildmodebutton()
LocalPlayer():ConCommand("buildmode")
end
-AEUI:AddText(coursepanel, "Time Trials - " .. game.GetMap(), "AEUIVeryLarge", 20, 30)
+AEUI:AddText(coursepanel, language.GetPhrase("beatrun.coursemenu.trials"):format(game.GetMap()), "AEUIVeryLarge", 20, 30)
-local buildmodebutton = AEUI:AddButton(coursepanel, "Build Mode Toggle", buildmodebutton, "AEUILarge", coursepanel.w - 400, coursepanel.h - 50)
+local buildmodebutton = AEUI:AddButton(coursepanel, "#beatrun.coursemenu.buildmode", buildmodebutton, "AEUILarge", coursepanel.w - 400, coursepanel.h - 50)
buildmodebutton.greyed = sacheck
-local stopbutton = AEUI:AddButton(coursepanel, "Return to Freeplay", stopbutton, "AEUILarge", coursepanel.w - 750, coursepanel.h - 50)
+local stopbutton = AEUI:AddButton(coursepanel, "#beatrun.coursemenu.freeplay", stopbutton, "AEUILarge", coursepanel.w - 750, coursepanel.h - 50)
stopbutton.greyed = sacheck
local courselist = {
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/Nametags.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Nametags.lua
index b02a9bd..49af3b7 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Nametags.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Nametags.lua
@@ -1,4 +1,4 @@
-local NametagsEnable = CreateClientConVar("Beatrun_Nametags", "1", true, false, "Toggles nametags above players", 0, 1)
+local NametagsEnable = CreateClientConVar("Beatrun_Nametags", "1", true, false, language.GetPhrase("beatrun.convars.nametags"), 0, 1)
local enemy = Color(255, 0, 0)
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/SteamPresence.lua b/beatrun/gamemodes/beatrun/gamemode/cl/SteamPresence.lua
index a0453aa..31108a0 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/SteamPresence.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/SteamPresence.lua
@@ -1,4 +1,4 @@
-if not util.IsBinaryModuleInstalled("steamrichpresencer", "GAME") then return end
+if not util.IsBinaryModuleInstalled("steamrichpresencer") then return end
require("steamrichpresencer")
@@ -7,17 +7,13 @@ local refresh_time = 60
local function UpdateRichPresence()
local ply = LocalPlayer()
+
if not ply.GetLevel then return end
local map = game.GetMap()
- local level = LocalPlayer():GetLevel()
- local course = nil
+ local level = ply:GetLevel()
local customname = hook.Run("BeatrunHUDCourse")
- course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay"
-
- if course == nil then
- course = "Freeplay"
- end
+ local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay"
local updatedtext = "Beatrun Lv. " .. level .. " (" .. map .. ") | " .. course
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/ToolMenuSettings.lua b/beatrun/gamemodes/beatrun/gamemode/cl/ToolMenuSettings.lua
index ed85aca..4e7d4c8 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/ToolMenuSettings.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/ToolMenuSettings.lua
@@ -5,33 +5,33 @@ local function ToggleGamemode(gm)
end
hook.Add("AddToolMenuCategories", "Beatrun_Category", function()
- spawnmenu.AddToolCategory("Beatrun", "Client", "Client")
- spawnmenu.AddToolCategory("Beatrun", "Server", "Server")
+ spawnmenu.AddToolCategory("Beatrun", "Client", language.GetPhrase("beatrun.toolsmenu.client"))
+ spawnmenu.AddToolCategory("Beatrun", "Server", language.GetPhrase("beatrun.toolsmenu.server"))
end)
hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
- spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_courses", "Courses", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_courses", language.GetPhrase("beatrun.toolsmenu.courses.name"), "", "", function(panel)
panel:ClearControls()
- panel:SetName("Courses Setttings")
+ panel:SetName("#beatrun.toolsmenu.courses.desc")
- panel:CheckBox("Fast Start", "Beatrun_FastStart")
- panel:ControlHelp("Faster countdown in courses")
+ panel:CheckBox("#beatrun.toolsmenu.courses.faststart", "Beatrun_FastStart")
+ panel:ControlHelp("#beatrun.toolsmenu.courses.faststartdesc")
- panel:CheckBox("Save at Checkpoint", "Beatrun_CPSave")
- panel:ControlHelp("Respawn at last hit checkpoint in courses")
+ panel:CheckBox("#beatrun.toolsmenu.courses.checkpointsave", "Beatrun_CPSave")
+ panel:ControlHelp("#beatrun.toolsmenu.courses.checkpointsavedesc")
local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider)
- panel:TextEntry("Courses server", "Beatrun_Domain")
- panel:ControlHelp("Database domain\nDefault: courses.beatrun.ru")
+ panel:TextEntry("#beatrun.toolsmenu.courses.database", "Beatrun_Domain")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.courses.databasedesc"))
local apiKeyButton = vgui.Create("DButton", panel)
- apiKeyButton:SetText("Change API Key")
+ apiKeyButton:SetText("#beatrun.toolsmenu.courses.changeapikey")
apiKeyButton:SetSize(0, 20)
apiKeyButton.DoClick = function()
local frame = vgui.Create("DFrame")
- frame:SetTitle("Enter your API Key")
+ frame:SetTitle("#beatrun.toolsmenu.courses.enterapikey")
frame:SetSize(300, 100)
frame:SetDeleteOnClose(true)
frame:Center()
@@ -41,11 +41,13 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame)
- okButton:SetText("OK")
+ okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60)
okButton:SetSize(250, 30)
okButton.DoClick = function()
- RunConsoleCommand("Beatrun_Apikey", TextEntry:GetValue())
+ local key = string.Replace(TextEntry:GetValue(), " ", "")
+
+ RunConsoleCommand("Beatrun_Apikey", key)
frame:Close()
end
end
@@ -55,11 +57,11 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(divider)
local saveCourseButton = vgui.Create("DButton", panel)
- saveCourseButton:SetText("Save current course to a file")
+ saveCourseButton:SetText("#beatrun.toolsmenu.courses.savecourse")
saveCourseButton:SetSize(0, 20)
saveCourseButton.DoClick = function()
local frame = vgui.Create("DFrame")
- frame:SetTitle("Enter a name for your course")
+ frame:SetTitle("#beatrun.toolsmenu.courses.namesavecourse")
frame:SetSize(300, 100)
frame:SetDeleteOnClose(true)
frame:Center()
@@ -69,22 +71,24 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame)
- okButton:SetText("OK")
+ okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60)
okButton:SetSize(250, 30)
okButton.DoClick = function()
- RunConsoleCommand("Beatrun_SaveCourse", TextEntry:GetValue())
+ local name = string.Replace(TextEntry:GetValue(), " ", "_")
+
+ RunConsoleCommand("Beatrun_SaveCourse", name)
frame:Close()
end
end
panel:AddItem(saveCourseButton)
- local loadCodeButton = vgui.Create("DButton", panel)
- loadCodeButton:SetText("Load a course from the database")
- loadCodeButton:SetSize(0, 20)
- loadCodeButton.DoClick = function()
+ local loadCourseButton = vgui.Create("DButton", panel)
+ loadCourseButton:SetText("#beatrun.toolsmenu.courses.loadcourse")
+ loadCourseButton:SetSize(0, 20)
+ loadCourseButton.DoClick = function()
local frame = vgui.Create("DFrame")
- frame:SetTitle("Enter course code")
+ frame:SetTitle("#beatrun.toolsmenu.courses.enterloadcourse")
frame:SetSize(300, 100)
frame:SetDeleteOnClose(true)
frame:Center()
@@ -94,31 +98,33 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame)
- okButton:SetText("OK")
+ okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60)
okButton:SetSize(250, 30)
okButton.DoClick = function()
- RunConsoleCommand("Beatrun_LoadCode", TextEntry:GetValue())
+ local code = string.Replace(TextEntry:GetValue(), " ", "")
+
+ RunConsoleCommand("Beatrun_LoadCode", code)
frame:Close()
end
end
- panel:AddItem(loadCodeButton)
+ panel:AddItem(loadCourseButton)
local uploadCourseButton = vgui.Create("DButton", panel)
- uploadCourseButton:SetText("Upload current course to the database")
+ uploadCourseButton:SetText("#beatrun.toolsmenu.courses.uploadcourse")
uploadCourseButton:SetSize(0, 20)
uploadCourseButton.DoClick = function()
RunConsoleCommand("Beatrun_UploadCourse")
- notification.AddLegacy("Open your console for the code!", NOTIFY_HINT, 5)
+ notification.AddLegacy("#beatrun.misc.checkconsole", NOTIFY_HINT, 5)
end
panel:AddItem(uploadCourseButton)
- local updateCodeButton = vgui.Create("DButton", panel)
- updateCodeButton:SetText("Update a course on the database")
- updateCodeButton:SetSize(0, 20)
- updateCodeButton.DoClick = function()
+ local updateCourseButton = vgui.Create("DButton", panel)
+ updateCourseButton:SetText("#beatrun.toolsmenu.courses.updatecourse")
+ updateCourseButton:SetSize(0, 20)
+ updateCourseButton.DoClick = function()
local frame = vgui.Create("DFrame")
- frame:SetTitle("Enter course code")
+ frame:SetTitle("#beatrun.toolsmenu.courses.enterloadcourse")
frame:SetSize(300, 100)
frame:SetDeleteOnClose(true)
frame:Center()
@@ -128,53 +134,51 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame)
- okButton:SetText("OK")
+ okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60)
okButton:SetSize(250, 30)
okButton.DoClick = function()
RunConsoleCommand("Beatrun_UpdateCode", TextEntry:GetValue())
- notification.AddLegacy("Open your console for server's response!", NOTIFY_HINT, 5)
+ notification.AddLegacy("#beatrun.misc.checkconsole", NOTIFY_HINT, 5)
frame:Close()
end
end
- panel:AddItem(updateCodeButton)
+ panel:AddItem(updateCourseButton)
+ panel:Help("#beatrun.toolsmenu.courses.updatecoursehelp")
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_hud", "HUD", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_hud", "#beatrun.toolsmenu.hud.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("HUD Setttings")
+ panel:SetName("#beatrun.toolsmenu.hud.desc")
- panel:CheckBox("Dynamic HUD", "Beatrun_HUDDynamic")
- panel:ControlHelp("Hides HUD when moving")
+ panel:CheckBox("#beatrun.toolsmenu.hud.dynamic", "Beatrun_HUDDynamic")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.dynamicdesc")
- panel:CheckBox("HUD Sway", "Beatrun_HUDSway")
- panel:ControlHelp("Toggles HUD swaying")
+ panel:CheckBox("#beatrun.toolsmenu.hud.sway", "Beatrun_HUDSway")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.swaydesc")
- panel:CheckBox("Dot", "Beatrun_HUDReticle")
- panel:ControlHelp("Shows a dot in the center of the screen")
+ panel:CheckBox("#beatrun.toolsmenu.hud.reticle", "Beatrun_HUDReticle")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.reticledesc")
- panel:CheckBox("Nametags", "Beatrun_Nametags")
- panel:ControlHelp("Toggles nametags above players")
+ panel:CheckBox("#beatrun.toolsmenu.hud.nametags", "Beatrun_Nametags")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.nametagsdesc")
- panel:CheckBox("Floating XP", "Beatrun_HUDXP")
- panel:ControlHelp("Show total XP near your nickname")
+ panel:CheckBox("#beatrun.toolsmenu.hud.hudxp", "Beatrun_HUDXP")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.hudxpdesc")
- panel:CheckBox("Lower Viewmodel", "Beatrun_MinimalVM")
- panel:ControlHelp("Lowers the running viewmodel")
+ panel:CheckBox("#beatrun.toolsmenu.hud.wind", "Beatrun_Wind")
+ panel:ControlHelp("#beatrun.toolsmenu.hud.winddesc")
- panel:CheckBox("Wind", "Beatrun_Wind")
- panel:ControlHelp("Wind noises when running")
+ panel:NumSlider("#beatrun.toolsmenu.hud.fov", "Beatrun_FOV", 90, 120, 0)
+ panel:Help("#beatrun.toolsmenu.hud.fovdesc")
- panel:NumSlider("FOV", "Beatrun_FOV", 90, 120, 0)
- panel:ControlHelp("You need to respawn after changing the FOV!")
-
- panel:NumSlider("Hide HUD", "Beatrun_HUDHidden", 0, 2, 0)
- panel:ControlHelp("0 - Shown\n1 - Gamemode only\n2 - Hidden")
+ panel:NumSlider("#beatrun.toolsmenu.hud.hidden", "Beatrun_HUDHidden", 0, 2, 0)
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.hud.hiddendesc"))
local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider)
- panel:Help("HUD Text Color")
+ panel:Help("#beatrun.toolsmenu.hud.textcolor")
local HudTextColor = vgui.Create("DColorMixer", panel)
HudTextColor:Dock(FILL)
HudTextColor:SetPalette(true)
@@ -186,7 +190,7 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
end
panel:AddItem(HudTextColor)
- panel:Help("HUD Corners Color")
+ panel:Help("#beatrun.toolsmenu.hud.cornercolor")
local HudCornerColor = vgui.Create("DColorMixer", panel)
HudCornerColor:Dock(FILL)
HudCornerColor:SetPalette(true)
@@ -198,7 +202,7 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
end
panel:AddItem(HudCornerColor)
- panel:Help("HUD Floating XP Color")
+ panel:Help("#beatrun.toolsmenu.hud.floatxpcolor")
local HudFXPColor = vgui.Create("DColorMixer", panel)
HudFXPColor:Dock(FILL)
HudFXPColor:SetPalette(true)
@@ -211,100 +215,115 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(HudFXPColor)
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_viewbob", "Viewbob", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_viewbob", "#beatrun.toolsmenu.viewbob.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("Viewbob Settings")
+ panel:SetName("#beatrun.toolsmenu.viewbob.desc")
- panel:CheckBox("Viewbob Stabilization", "Beatrun_ViewbobStabilized")
- panel:ControlHelp("Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered")
- panel:NumSlider("Viewbob Intensity", "Beatrun_ViewbobIntensity", -100, 100, 0)
+ panel:CheckBox("#beatrun.toolsmenu.viewbob.stabilization", "Beatrun_ViewbobStabilized")
+ panel:ControlHelp("#beatrun.toolsmenu.viewbob.stabilizationdesc")
+
+ panel:NumSlider("#beatrun.toolsmenu.viewbob.intensity", "Beatrun_ViewbobIntensity", -100, 100, 0)
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_gameplay", "Gameplay", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_gameplay", "#beatrun.toolsmenu.gameplay.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("Gameplay Settings")
+ panel:SetName("#beatrun.toolsmenu.gameplay.desc")
- panel:CheckBox("Quickturn", "Beatrun_QuickturnGround")
- panel:ControlHelp("Enables quickturning with secondary attack while on the ground")
+ panel:CheckBox("#beatrun.toolsmenu.gameplay.quickturnground", "Beatrun_QuickturnGround")
+ panel:ControlHelp("#beatrun.toolsmenu.gameplay.quickturngrounddesc")
- panel:CheckBox("Purist Mode", "Beatrun_PuristMode")
- panel:ControlHelp("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")
+ panel:CheckBox("#beatrun.toolsmenu.gameplay.quickturnhandsonly", "Beatrun_QuickturnHandsOnly")
+ panel:ControlHelp("#beatrun.toolsmenu.gameplay.quickturnhandsonlydesc")
- panel:CheckBox("Disable Grapple Ability", "Beatrun_DisableGrapple")
- panel:ControlHelp("Disables grapple ability")
+ panel:CheckBox("#beatrun.toolsmenu.gameplay.puristmode", "Beatrun_PuristMode")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.gameplay.puristmodedesc"))
+
+ panel:CheckBox("#beatrun.toolsmenu.gameplay.disablegrapple", "Beatrun_DisableGrapple")
+ panel:ControlHelp("#beatrun.toolsmenu.gameplay.disablegrappledesc")
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_main", "Main", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_misc", "#beatrun.toolsmenu.misc.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("Misc Settings")
+ panel:SetName("#beatrun.toolsmenu.misc.desc")
- panel:CheckBox("Prop Spawning", "Beatrun_AllowPropSpawn")
- panel:ControlHelp("Allows players without admin rights to spawn props, entities and weapons")
+ panel:CheckBox("#beatrun.toolsmenu.misc.propspawn", "Beatrun_AllowPropSpawn")
+ panel:ControlHelp("#beatrun.toolsmenu.misc.propspawndesc")
- panel:CheckBox("Overdrive in Multiplayer", "Beatrun_AllowOverdriveInMultiplayer")
- panel:ControlHelp("Allows Overdrive usage on the server\nDoesn't affect singleplayer")
+ panel:CheckBox("#beatrun.toolsmenu.misc.overdrivemp", "Beatrun_AllowOverdriveInMultiplayer")
+ panel:ControlHelp("#beatrun.toolsmenu.misc.overdrivempdesc")
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_moves", "Moves", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_moves", "#beatrun.toolsmenu.moves.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("Moves Settings")
- panel:Help("You Can Dive with Ctrl + RMB While Midair!\nOverdrive Toggles with E + LMB.")
+ panel:SetName("#beatrun.toolsmenu.moves.desc")
+ panel:Help(language.GetPhrase("beatrun.toolsmenu.moves.help"))
- panel:CheckBox("Force Purist Mode", "Beatrun_PuristModeForce")
- panel:ControlHelp("Forces Purist Mode for all players")
+ panel:NumSlider("#beatrun.toolsmenu.moves.speedlimit", "Beatrun_SpeedLimit", 325, 1000, 0)
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.speedlimitdesc"))
- panel:CheckBox("\"Realistic\" wallrunning", "Beatrun_PuristWallrun")
- panel:ControlHelp("You don't lose speed when starting wallrunning when disabled")
+ panel:CheckBox("#beatrun.toolsmenu.moves.forcepuristmode", "Beatrun_PuristModeForce")
+ panel:ControlHelp("#beatrun.toolsmenu.moves.forcepuristmodedesc")
+
+ panel:CheckBox("#beatrun.toolsmenu.moves.realisticwallrunning", "Beatrun_PuristWallrun")
+ panel:ControlHelp("#beatrun.toolsmenu.moves.realisticwallrunningdesc")
local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider)
- panel:CheckBox("Kick-Glitch", "Beatrun_KickGlitch")
- panel:ControlHelp("Toggles Kick-Glitch Move\nLMB when Wallrunning and Then Jumping Right After")
+ panel:CheckBox("#beatrun.toolsmenu.moves.kickglitch", "Beatrun_KickGlitch")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.kickglitchdesc"))
- panel:CheckBox("Kick-Glitch Version", "Beatrun_OldKickGlitch")
- panel:ControlHelp("Enabled - Old Kick-Glitch\nDisabled - New Kick-Glitch\nNew version uses mechanic from Mirror's Edge that spawns a small platform under a player")
+ panel:CheckBox("#beatrun.toolsmenu.moves.kickglitchversion", "Beatrun_OldKickGlitch")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.kickglitchversiondesc"))
- panel:CheckBox("Quake Jump", "Beatrun_QuakeJump")
- panel:ControlHelp("Toggles Quake Jump Move\nPress RMB Right After Side Step")
+ panel:CheckBox("#beatrun.toolsmenu.moves.quakejump", "Beatrun_QuakeJump")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.quakejumpdesc"))
- panel:CheckBox("Side Step", "Beatrun_SideStep")
- panel:ControlHelp("Toggles Side Step Move\nA/D + RMB")
+ panel:CheckBox("#beatrun.toolsmenu.moves.sidestep", "Beatrun_SideStep")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.sidestepdesc"))
- panel:CheckBox("Disarm", "Beatrun_Disarm")
- panel:ControlHelp("Toggles Ability to Disarm NPC\nInteract with NPC")
+ panel:CheckBox("#beatrun.toolsmenu.moves.disarm", "Beatrun_Disarm")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.disarmdesc"))
local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider)
- panel:Help("Dive Settings")
+ panel:Help("#beatrun.toolsmenu.moves.divesettings")
- panel:CheckBox("Totsugeki", "Beatrun_Totsugeki")
- panel:ControlHelp("Toggles Totsugeki Move\nDive After Quake Jump")
+ panel:CheckBox("#beatrun.toolsmenu.moves.totsugeki", "Beatrun_Totsugeki")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.totsugekidesc"))
- panel:CheckBox("Totsugeki Spam", "Beatrun_TotsugekiSpam")
- panel:ControlHelp("Toggles Ability to Spam Totsugeki")
+ panel:CheckBox("#beatrun.toolsmenu.moves.totsugekispam", "Beatrun_TotsugekiSpam")
+ panel:ControlHelp("#beatrun.toolsmenu.moves.totsugekispamdesc")
- panel:CheckBox("Totsugeki Heading", "Beatrun_TotsugekiHeading")
- panel:ControlHelp("Allows to Totsugeki on X axis (up/down)")
+ panel:CheckBox("#beatrun.toolsmenu.moves.totsugekiheading", "Beatrun_TotsugekiHeading")
+ panel:ControlHelp("#beatrun.toolsmenu.moves.totsugekiheadingdesc")
- panel:CheckBox("Totsugeki Direction", "Beatrun_TotsugekiDir")
- panel:ControlHelp("Allows to Totsugeki into Another Direction\nCombined with Spam and Heading Allows You to Fly =)")
+ panel:CheckBox("#beatrun.toolsmenu.moves.totsugekidirection", "Beatrun_TotsugekiDir")
+ panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.totsugekidirectiondesc"))
end)
- spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_gamemodes", "Gamemodes", "", "", function(panel)
+ spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_gamemodes", "#beatrun.toolsmenu.gamemodes.name", "", "", function(panel)
panel:ClearControls()
- panel:SetName("Gamemodes Settings")
+ panel:SetName("#beatrun.toolsmenu.gamemodes.desc")
+
+ panel:NumSlider("#beatrun.toolsmenu.gamemodes.infectionstarttime", "Beatrun_InfectionStartTime", 5, 20, 0)
+ panel:Help("#beatrun.toolsmenu.gamemodes.infectiontime")
+
+ panel:NumSlider("#beatrun.toolsmenu.gamemodes.infectiongametime", "Beatrun_InfectionGameTime", 30, 600, 0)
+ panel:Help("#beatrun.toolsmenu.gamemodes.infectiontime")
local InfectionButton = vgui.Create("DButton", panel)
- InfectionButton:SetText("Toggle Infection Gamemode")
+ InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.infection")
InfectionButton:SetSize(0, 20)
InfectionButton.DoClick = function()
if GetGlobalBool("GM_DEATHMATCH") or GetGlobalBool("GM_DATATHEFT") then
- InfectionButton:SetText("Another gamemode is running!")
+ InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.error")
+
timer.Simple(2, function()
- InfectionButton:SetText("Toggle Infection Gamemode")
+ InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.infection")
end)
+
return
end
@@ -313,14 +332,16 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(InfectionButton)
local DatatheftButton = vgui.Create("DButton", panel)
- DatatheftButton:SetText("Toggle Data Theft Gamemode")
+ DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.datatheft")
DatatheftButton:SetSize(0, 20)
DatatheftButton.DoClick = function()
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DEATHMATCH") then
- DatatheftButton:SetText("Another gamemode is running!")
+ DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.error")
+
timer.Simple(2, function()
- DatatheftButton:SetText("Toggle Data Theft Gamemode")
+ DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.datatheft")
end)
+
return
end
@@ -329,14 +350,16 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(DatatheftButton)
local DeathmatchButton = vgui.Create("DButton", panel)
- DeathmatchButton:SetText("Toggle Deathmatch Gamemode")
+ DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.deathmatch")
DeathmatchButton:SetSize(0, 20)
DeathmatchButton.DoClick = function()
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") then
- DeathmatchButton:SetText("Another gamemode is running!")
+ DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.error")
+
timer.Simple(2, function()
- DeathmatchButton:SetText("Toggle Deathmatch Gamemode")
+ DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.deathmatch")
end)
+
return
end
@@ -372,4 +395,4 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
-- end
-- panel:AddItem(LoadoutMenuButton)
end)
-end)
\ No newline at end of file
+end)
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/cl/Watermark.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Watermark.lua
index 0e903f6..2e96dda 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Watermark.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Watermark.lua
@@ -24,4 +24,4 @@ hook.Add("PostRender", "Watermark", function()
surface.DrawText(LocalPlayer():Nick())
cam.End2D()
end)
-]]
\ No newline at end of file
+--]]
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/Whitescale.lua b/beatrun/gamemodes/beatrun/gamemode/cl/Whitescale.lua
index 0e7bf2a..1ebfaec 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/Whitescale.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/Whitescale.lua
@@ -72,4 +72,4 @@ local function ToggleWhitescale()
end
end
-concommand.Add("ToggleWhitescale", ToggleWhitescale)
\ No newline at end of file
+concommand.Add("Beatrun_ToggleWhitescale", ToggleWhitescale)
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/XP.lua b/beatrun/gamemodes/beatrun/gamemode/cl/XP.lua
index 4ebe447..9ce75c3 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/XP.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/XP.lua
@@ -1,5 +1,4 @@
local meta = FindMetaTable("Player")
--- local XP_max = 2000000
local XP_ratiocache = nil
local parkourevent_lastpos = Vector()
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/CA.lua b/beatrun/gamemodes/beatrun/gamemode/cl/off/CA.lua
similarity index 100%
rename from beatrun/gamemodes/beatrun/gamemode/cl/CA.lua
rename to beatrun/gamemodes/beatrun/gamemode/cl/off/CA.lua
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl/off/blind.lua b/beatrun/gamemodes/beatrun/gamemode/cl/off/blind.lua
index 63730e6..68ac2df 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl/off/blind.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl/off/blind.lua
@@ -610,9 +610,8 @@ function ToggleBlindness(toggle)
if blinded then
local ply = LocalPlayer()
local activewep = ply:GetActiveWeapon()
- local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
- if usingrh and activewep.RunWind1 then
+ if ply:UsingRH() and activewep.RunWind1 then
activewep.RunWind1:Stop()
activewep.RunWind2:Stop()
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/cl_init.lua b/beatrun/gamemodes/beatrun/gamemode/cl_init.lua
index de48afe..7b719c4 100644
--- a/beatrun/gamemodes/beatrun/gamemode/cl_init.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/cl_init.lua
@@ -1,5 +1,5 @@
include("shared.lua")
-for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME", "nameasc")) do
+for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME")) do
include("cl/" .. v)
end
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/init.lua b/beatrun/gamemodes/beatrun/gamemode/init.lua
index 5030e87..236b127 100644
--- a/beatrun/gamemodes/beatrun/gamemode/init.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/init.lua
@@ -2,18 +2,21 @@ AddCSLuaFile("cl_init.lua")
AddCSLuaFile("shared.lua")
include("shared.lua")
-for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME", "nameasc")) do
+for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME")) do
print(v)
+
AddCSLuaFile("cl/" .. v)
end
-for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sh/*.lua", "GAME", "nameasc")) do
+for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sh/*.lua", "GAME")) do
print(v)
- include("sh/" .. v)
+
AddCSLuaFile("sh/" .. v)
+ include("sh/" .. v)
end
-for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sv/*.lua", "GAME", "nameasc")) do
+for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sv/*.lua", "GAME")) do
print(v)
+
include("sv/" .. v)
end
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/player_class/player_beatrun.lua b/beatrun/gamemodes/beatrun/gamemode/player_class/player_beatrun.lua
index 5eac96a..d29f6b4 100644
--- a/beatrun/gamemodes/beatrun/gamemode/player_class/player_beatrun.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/player_class/player_beatrun.lua
@@ -319,7 +319,7 @@ end
hook.Add("EntityFireBullets", "thisengineismadebyacrackhead", function(ent, data)
if not IsValid(ent) or not isfunction(ent.GetShootPos) or not ent:IsPlayer() then return end
- for i, ply in ipairs(player.GetAll()) do
+ for _, ply in ipairs(player.GetAll()) do
if ply == ent then continue end
local fov = calc_fov(data.Dir:Angle(), (ply:GetShootPos() - data.Src):Angle())
@@ -374,7 +374,7 @@ end
hook.Add("FinishMove", "BeatrunRHVelocity", function(ply, mv)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() == "runnerhands" and activewep.SetOwnerVelocity then
+ if ply:UsingRH() and activewep.SetOwnerVelocity then
activewep:SetOwnerVelocity(math.Round(mv:GetVelocity():Length()))
end
end)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/0_Helpers.lua b/beatrun/gamemodes/beatrun/gamemode/sh/0_Helpers.lua
index 3d8b40e..b23ee15 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/0_Helpers.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/0_Helpers.lua
@@ -3,19 +3,6 @@ local playermeta = FindMetaTable("Player")
CLoadout = {}
-function CLIENT_IFTP()
- return CLIENT and IsFirstTimePredicted()
-end
-
---[[
-local matrixdatatmp = {
- {0, 0, 0, 0},
- {0, 0, 0, 0},
- {0, 0, 0, 0},
- {0, 0, 0, 1}
-}
-]]
-
local mtmp = {
{0, 0, 0, 0},
{0, 0, 0, 0},
@@ -81,5 +68,20 @@ end
function playermeta:UsingRH(wep)
local activewep = wep or self:GetActiveWeapon()
- if IsValid(activewep) then return activewep:GetClass() == "runnerhands" end
+
+ if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
+ return true
+ else
+ return false
+ end
+end
+
+function playermeta:notUsingRH(wep)
+ local activewep = wep or self:GetActiveWeapon()
+
+ if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
+ return true
+ else
+ return false
+ end
end
\ No newline at end of file
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Misc.lua b/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
similarity index 82%
rename from beatrun/gamemodes/beatrun/gamemode/sh/Misc.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
index d6d78f4..466db84 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Misc.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/0_Misc.lua
@@ -1,6 +1,6 @@
-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})
+if SERVER then
util.AddNetworkString("SPParkourEvent")
local spawn = {"PlayerGiveSWEP", "PlayerSpawnEffect", "PlayerSpawnNPC", "PlayerSpawnObject", "PlayerSpawnProp", "PlayerSpawnRagdoll", "PlayerSpawnSENT", "PlayerSpawnSWEP", "PlayerSpawnVehicle"}
@@ -9,7 +9,7 @@ if SERVER then
if not ply:IsAdmin() and not allowPropSpawn:GetBool() then return false end
end
- for k, v in ipairs(spawn) do
+ for _, v in ipairs(spawn) do
hook.Add(v, "BlockSpawn", BlockSpawn)
end
@@ -21,18 +21,18 @@ 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)
if enabled and Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 then
ply:SetNW2Int("CPNum", -1)
- if CLIENT_IFTP() then
- notification.AddLegacy("Noclip Detected! Respawn to restart the course", NOTIFY_ERROR, 4)
+ if CLIENT and IsFirstTimePredicted() then
+ 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
@@ -70,9 +70,7 @@ hook.Add("SetupMove", "JumpDetect", function(ply, mv, cmd)
end
end
- local activewep = ply:GetActiveWeapon()
-
- if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
+ if ply:UsingRH() then
ply:SetWasOnGround(ply:OnGround())
return
@@ -106,11 +104,11 @@ hook.Add("SetupMove", "JumpDetect", function(ply, mv, cmd)
end)
hook.Add("CanProperty", "BlockProperty", function(ply)
- if not ply:IsSuperAdmin() then return false end
+ if not ply:IsAdmin() then return false end
end)
hook.Add("CanDrive", "BlockDrive", function(ply)
- if not ply:IsSuperAdmin() then return false end
+ if not ply:IsAdmin() then return false end
end)
if CLIENT and game.SinglePlayer() then
@@ -161,4 +159,4 @@ if CLIENT then
impactblurlerp = intensity
lastintensity = intensity
end
-end
\ No newline at end of file
+end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/0_Sounds_!Precache.lua b/beatrun/gamemodes/beatrun/gamemode/sh/0_Sounds_!Precache.lua
index bcae2eb..eb57365 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/0_Sounds_!Precache.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/0_Sounds_!Precache.lua
@@ -2,6 +2,7 @@ soundAdd_old = sound.Add
local function soundAdd_detour(tbl)
if not tbl.name then return end
+
soundAdd_old(tbl)
timer.Simple(2, function()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Balance.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Balance.lua
index 550c601..4b02193 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Balance.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Balance.lua
@@ -75,7 +75,7 @@ hook.Add("SetupMove", "Balance", function(ply, mv, cmd)
ParkourEvent("walkbalancestill", ply)
end
- if CLIENT_IFTP() and mv:KeyPressed(IN_ATTACK2) then
+ if CLIENT and IsFirstTimePredicted() and mv:KeyPressed(IN_ATTACK2) then
dircache.y = dircache.y - 180
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/sh_buildmode.lua b/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
similarity index 96%
rename from beatrun/gamemodes/beatrun/gamemode/sh/sh_buildmode.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
index 1ab5b8e..edd8510 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/sh_buildmode.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/BuildMode.lua
@@ -1,23 +1,28 @@
local mousex = 0
local mousey = 0
local inf = math.huge
+
buildmode_props = {}
+
local propmatsblacklist = {}
local blocksdir = "models/hunter/blocks/"
local blocksdir_s = blocksdir .. "*.mdl"
-for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
+
+for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
table.insert(buildmode_props, blocksdir .. v:lower())
end
local blocksdir = "models/hunter/triangles/"
local blocksdir_s = blocksdir .. "*.mdl"
-for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
+
+for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
table.insert(buildmode_props, blocksdir .. v:lower())
end
local blocksdir = "models/props_phx/construct/glass/"
local blocksdir_s = blocksdir .. "*.mdl"
-for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
+
+for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
local key = table.insert(buildmode_props, blocksdir .. v:lower())
propmatsblacklist[key] = true
end
@@ -323,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)
@@ -423,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)
@@ -435,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())
@@ -456,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)
@@ -474,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)
@@ -490,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)
@@ -508,10 +498,10 @@ if SERVER then
net.Receive("BuildMode_ReadSave", function(len, ply)
if not ply.BuildMode then return end
- local a = util.Decompress(net.ReadData(len))
+ local a = 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])
@@ -611,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])
@@ -629,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")
@@ -641,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
@@ -666,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)
@@ -898,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")
@@ -930,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
@@ -958,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)
@@ -1155,24 +1144,13 @@ if CLIENT then
end
end,
[KEY_BACKSPACE] = function()
- if not dragging then
- local props = {}
-
- for k, v in pairs(buildmode_selected) do
- table.insert(props, k)
- buildmode_selected[k] = nil
- end
-
- net.Start("BuildMode_Delete")
- net.WriteTable(props)
- net.SendToServer()
- end
+ buildmodeinputs[KEY_DELETE]()
end,
[KEY_T] = function()
if not dragging then
local props = {}
- for k, v in pairs(buildmode_selected) do
+ for k, _ in pairs(buildmode_selected) do
if not propmatsblacklist[buildmode_props_index[k:GetModel()]] then
table.insert(props, k)
end
@@ -1216,7 +1194,7 @@ if CLIENT then
end
end
end,
- [KEY_ENTER] = function()
+ [KEY_PAD_MINUS] = function()
if table.Count(buildmode_selected) == 0 then return end
local save = {}
@@ -1239,7 +1217,7 @@ if CLIENT then
local jsonsave = util.TableToJSON(save)
file.CreateDir("beatrun/savedbuilds")
- file.Write("beatrun/savedbuilds/save.txt", util.Compress(jsonsave))
+ file.Write("beatrun/savedbuilds/save.txt", jsonsave)
end,
[KEY_PAD_PLUS] = function()
local save = file.Read("beatrun/savedbuilds/save.txt", "DATA")
@@ -1453,7 +1431,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()
@@ -1546,7 +1524,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()
@@ -1557,7 +1535,7 @@ if CLIENT then
local num = v:GetCPNum()
surface.SetTextPos(w2s.x, w2s.y)
- surface.DrawText(num)
+ surface.DrawText("Checkpoint: " .. num)
end
local startw2s = Course_StartPos:ToScreen()
@@ -1637,4 +1615,4 @@ if CLIENT then
hook.Run("BuildModeState", false)
end
end)
-end
\ No newline at end of file
+end
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/Climb.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Climb.lua
index 7e5fbdf..dfe7d3d 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Climb.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Climb.lua
@@ -159,7 +159,7 @@ local function ClimbingThink(ply, mv, cmd)
ParkourEvent("hangend", ply)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
lockang2 = false
lockang = false
BodyLimitX = 90
@@ -182,7 +182,7 @@ local function ClimbingThink(ply, mv, cmd)
ply:SetSafetyRollKeyTime(CurTime() + 0.1)
ParkourEvent("hangjump", ply)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
lockang2 = false
lockang = false
BodyLimitX = 90
@@ -649,11 +649,7 @@ local function ClimbingCheck(ply, mv, cmd)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh and activewep.SendWeaponAnim then
+ if ply:UsingRH() and activewep.SendWeaponAnim then
activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false)
end
@@ -716,7 +712,7 @@ local function ClimbingCheck(ply, mv, cmd)
ply:EmitSound("Handsteps.ConcreteHard")
ply:EmitSound("Cloth.RollLand")
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply.OrigEyeAng = wallang
lockang2 = true
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/CrouchJump.lua b/beatrun/gamemodes/beatrun/gamemode/sh/CrouchJump.lua
index 8101005..fb5496b 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/CrouchJump.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/CrouchJump.lua
@@ -1,4 +1,3 @@
-local usingrh = nil
local punch = Angle(0.5, 0, 0)
local punchland = Angle(10, 0, 0.5)
local punchthink = Angle()
@@ -30,13 +29,9 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:SetCrouchJumpBlocked(false)
end
+ local activewep = ply:GetActiveWeapon()
+
if ply:Alive() and not ply:GetCrouchJumpBlocked() and not IsValid(ply:GetZipline()) and not IsValid(ply:GetLadder()) and ply:GetClimbing() == 0 and not ply:GetJumpTurn() and ply:GetMantle() == 0 and not ply:OnGround() and ply:GetVelocity().z > -350 and ply:GetCrouchJumpTime() < CurTime() and ply:GetWallrun() == 0 and mv:KeyPressed(IN_DUCK) then
- local activewep = ply:GetActiveWeapon()
-
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
if CLIENT then
local ang = ply:EyeAngles()
ang.x = 0
@@ -47,7 +42,7 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
BodyAnimCycle = 0
BodyAnimCrouchLerp = 0
- if usingrh then
+ if ply:UsingRH() then
BodyAnimCrouchLerpZ = mv:GetOrigin().z - 32
else
BodyAnimCrouchLerpZ = mv:GetOrigin().z
@@ -70,16 +65,10 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:ViewPunch(punch)
ply:SetViewOffsetDucked(Vector(0, 0, 28))
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HOLSTER)
end
elseif (ply:OnGround() or ply:GetCrouchJumpTime() < CurTime() or not ply:Alive()) and ply:GetCrouchJump() then
- local activewep = ply:GetActiveWeapon()
-
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
if game.SinglePlayer() then
net.Start("CrouchJumpSP")
net.WriteBool(false)
@@ -88,7 +77,7 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:SetCrouchJump(false)
- if usingrh and IsValid(activewep) then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_DRAW)
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua b/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
index ee603a9..1c36def 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/DataTheft.lua
@@ -1,4 +1,3 @@
-GM_DATATHEFT = 0
DATATHEFT_LOADOUTS = {
{"weapon_357", "weapon_ar2"}
}
@@ -87,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
@@ -99,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), language.GetPhrase("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 474f71e..f72f05b 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Deathmatch.lua
@@ -1,5 +1,3 @@
-GM_DEATHMATCH = 0
-
if SERVER then
util.AddNetworkString("Deathmatch_Start")
util.AddNetworkString("Deathmatch_Sync")
@@ -17,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
@@ -66,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
@@ -78,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), language.GetPhrase("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 863c6a7..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
@@ -37,7 +37,7 @@ local function Dive(ply, mv, cmd)
effectdata:SetOrigin(vPoint)
util.Effect("WaterSurfaceExplosion", effectdata)
- elseif CLIENT_IFTP() then
+ elseif CLIENT and IsFirstTimePredicted() then
local vPoint = mv:GetOrigin()
local effectdata = EffectData()
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/sh_freerunsysall.lua b/beatrun/gamemodes/beatrun/gamemode/sh/FreerunSysAll.lua
similarity index 84%
rename from beatrun/gamemodes/beatrun/gamemode/sh/sh_freerunsysall.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/FreerunSysAll.lua
index 95068eb..9aecb33 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/sh_freerunsysall.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/FreerunSysAll.lua
@@ -1,5 +1,6 @@
local quakejump = CreateConVar("Beatrun_QuakeJump", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
local sidestep = CreateConVar("Beatrun_SideStep", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
+local speed_limit = CreateConVar("Beatrun_SpeedLimit", 325, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
local function Hardland(jt)
local ply = LocalPlayer()
@@ -16,6 +17,7 @@ local function Hardland(jt)
end
DoJumpTurn(jt)
+
BodyAnim:SetSequence("jumpturnflyidle")
else
BodyAnim:SetSequence("jumpcoilend")
@@ -34,8 +36,7 @@ if game.SinglePlayer() and CLIENT then
end
hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
- local activewep = ply:GetActiveWeapon()
- local sprint = ply:GetMEMoveLimit() < 300
+ local sprint = ply:GetMEMoveLimit() < speed_limit:GetInt() - 25
local stepmod = ply:GetStepRight() and 1 or -1
local stepvel = 1.25
local stepvel2 = 1
@@ -49,7 +50,7 @@ hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
local stepmod2 = 1
local stepmod3 = 1
- if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
+ if ply:notUsingRH() then
stepmod2 = 0.25
if not ply:IsSprinting() then
@@ -57,7 +58,7 @@ hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
end
end
- if not ply:Crouching() and not ply:KeyDown(IN_WALK) then
+ if not ply:Crouching() and not walking then
if game.SinglePlayer() then
local intensity = ply:GetInfoNum("Beatrun_ViewbobIntensity", 20) / 20
@@ -92,7 +93,7 @@ hook.Add("PlayerFootstep", "MEStepSound", function(ply, pos, foot, sound, volume
ply:SetStepRight(not ply:GetStepRight())
if (ply:GetSliding() or CurTime() < ply:GetSafetyRollTime() - 0.5) and not skipcheck then return true end
- if ply:GetMEMoveLimit() < 155 and ply:KeyDown(IN_FORWARD) and not ply.FootstepLand and not IsValid(ply:GetBalanceEntity()) then return true end
+ if ply:GetMEMoveLimit() < 100 and ply:KeyDown(IN_FORWARD) and not ply.FootstepLand and not IsValid(ply:GetBalanceEntity()) then return true end
local mat = sound:sub(0, -6)
local newsound = FOOTSTEPS_LUT[mat]
@@ -124,11 +125,11 @@ hook.Add("PlayerFootstep", "MEStepSound", function(ply, pos, foot, sound, volume
ply:EmitSound("Footsteps.Water")
end
- if ply:InOverdrive() and ply:GetVelocity():Length() > 300 then
+ if ply:InOverdrive() and ply:GetVelocity():Length() > 400 then
ply:EmitSound("Footsteps.Spark")
end
- if (CLIENT_IFTP() or game.SinglePlayer()) and ply.FootstepLand then
+ if (CLIENT and IsFirstTimePredicted() or game.SinglePlayer()) and ply.FootstepLand then
local landsound = FOOTSTEPS_LAND_LUT[mat] or "Concrete"
ply:EmitSound("Land." .. landsound)
@@ -157,7 +158,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
ParkourEvent("land", ply)
if ply:GetMelee() == MELEE_DROPKICK and ply:GetMeleeTime() < CurTime() and vel:Length() < 300 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
Hardland(false)
elseif SERVER and game.SinglePlayer() then
net.Start("Beatrun_HardLand")
@@ -185,7 +186,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
ply:SetJumpTurn(true)
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
Hardland(jt)
elseif SERVER and game.SinglePlayer() then
net.Start("Beatrun_HardLand")
@@ -210,8 +211,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
end)
hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
- local activewep = ply:GetActiveWeapon()
- local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
+ local usingrh = ply:UsingRH()
local ismoving = (mv:KeyDown(IN_FORWARD) or not ply:OnGround() or ply:Crouching()) and not mv:KeyDown(IN_BACK) and ply:Alive() and (mv:GetVelocity():Length() > 50 or ply:GetMantle() ~= 0 or ply:Crouching())
if (CLIENT or game.SinglePlayer()) and CurTime() > (ply:GetStepRelease() or 0) and ply.FootstepReleaseLand then
@@ -229,12 +229,12 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
ply.FootstepLand = true
end
- if ply:GetRunSpeed() ~= 325 * ply:GetOverdriveMult() then
- ply:SetRunSpeed(325 * ply:GetOverdriveMult())
+ if ply:GetRunSpeed() ~= speed_limit:GetInt() * ply:GetOverdriveMult() then
+ ply:SetRunSpeed(speed_limit:GetInt() * ply:GetOverdriveMult())
end
if not ply:GetMEMoveLimit() then
- ply:SetMEMoveLimit(150)
+ ply:SetMEMoveLimit(speed_limit:GetInt())
ply:SetMESprintDelay(0)
ply:SetMEAng(0)
end
@@ -246,8 +246,6 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
ply:SetMEMoveLimit(150)
ply:SetMESprintDelay(0)
ply:SetMEAng(0)
-
- -- mv:SetButtons(bit.band(mv:GetButtons(), bit.bnot(IN_JUMP)))
end
local ang = mv:GetAngles()
@@ -259,14 +257,14 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local weaponspeed = 150
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
- weaponspeed = 250
+ if ply:notUsingRH() then
+ weaponspeed = speed_limit:GetInt()
end
if (ismoving or ply:GetMantle() ~= 0) and ply:GetMESprintDelay() < CurTime() and (cmd:KeyDown(IN_SPEED) or ply:GetMantle() ~= 0 or not ply:OnGround() or (not ply:OnGround() or ply:GetMantle() ~= 0) and mv:GetVelocity().z > -450) then
- local mult = 0.6 + math.abs(ply:GetMEMoveLimit() / 300 - 1)
+ local mult = 0.6 + math.abs(ply:GetMEMoveLimit() / (speed_limit:GetInt() - 25) - 1)
- if not ply:InOverdrive() and ply:GetMEMoveLimit() > 225 then
+ if not ply:InOverdrive() and ply:GetMEMoveLimit() > (speed_limit:GetInt() - 100) then
mult = mult * 0.35
end
@@ -274,9 +272,9 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
mult = mult * ply:GetMEMoveLimit() / 1000
end
- ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() + mult * ply:GetOverdriveMult() * 2, 0, 325 * ply:GetOverdriveMult()))
+ ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() + mult * ply:GetOverdriveMult() * 2, 0, speed_limit:GetInt() * ply:GetOverdriveMult()))
elseif not ismoving and (not ply:Crouching() or ply:GetCrouchJump()) or CurTime() < ply:GetMESprintDelay() and ply:OnGround() then
- ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() - 40, weaponspeed, 325 * ply:GetOverdriveMult()))
+ ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() - 40, weaponspeed, speed_limit:GetInt() * ply:GetOverdriveMult()))
end
if MEAngDiff > 1.25 and ply:GetWallrun() == 0 then
@@ -288,9 +286,9 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local stepheight = mv:GetOrigin().z - (ply.LastOrigin or vector_origin).z
if stepheight > 1.5 then
- ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), 250, FrameTime() * 100))
+ ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), speed_limit:GetInt() - 75, FrameTime() * 100))
elseif stepheight < -0.8 then
- ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), 400, FrameTime() * 100))
+ ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), speed_limit:GetInt() + 75, FrameTime() * 100))
end
end
@@ -310,7 +308,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
activewep:SendWeaponAnim(ACT_TURNLEFT45)
activewep:SetSideStep(true)
- mv:SetVelocity(cmd:GetViewAngles():Right() * -600)
+ mv:SetVelocity(cmd:GetViewAngles():Right() * -(speed_limit:GetInt() * 1.8))
ply:ViewPunch(Angle(-3, 0, -4.5))
@@ -325,7 +323,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
activewep:SendWeaponAnim(ACT_TURNRIGHT45)
activewep:SetSideStep(true)
- mv:SetVelocity(cmd:GetViewAngles():Right() * 600)
+ mv:SetVelocity(cmd:GetViewAngles():Right() * (speed_limit:GetInt() * 1.8))
ply:ViewPunch(Angle(-3, 0, 4.5))
@@ -341,7 +339,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local forwarddelta = activewep.SideStepDir:Dot(ang:Forward())
if forwarddelta > 0.35 then
- ply:SetMEMoveLimit(250)
+ ply:SetMEMoveLimit(speed_limit:GetInt())
end
if forwarddelta < 0.65 then
@@ -356,7 +354,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
if mv:KeyPressed(IN_JUMP) and not quakejump:GetBool() and activewep:GetWasOnGround() and not ply:GetJumpTurn() and ply:GetViewModel():GetCycle() < 0.25 then
local vel = mv:GetVelocity()
vel:Mul(0.75)
- vel.z = -300
+ vel.z = -speed_limit:GetInt() + 25
mv:SetVelocity(vel)
@@ -370,7 +368,6 @@ if CLIENT then
hook.Add("CreateMove", "MECreateMove", function(cmd)
local ply = LocalPlayer()
- local usingrh = ply:UsingRH()
local hardland = CurTime() < (ply.hardlandtime or 0)
if hardland and not ply:InOverdrive() then
@@ -379,7 +376,7 @@ if CLIENT then
cmd:SetSideMove(cmd:GetSideMove() * 0.01)
end
- if (ply:InOverdrive() or usingrh and ply:GetMoveType() == MOVETYPE_WALK and not hardland and ply:OnGround()) and not cmd:KeyDown(IN_SPEED) and not ply:GetSliding() and not IsValid(ply:GetBalanceEntity()) then
+ if (ply:InOverdrive() or ply:UsingRH() and ply:GetMoveType() == MOVETYPE_WALK and not hardland and ply:OnGround()) and not cmd:KeyDown(IN_SPEED) and not ply:GetSliding() and not IsValid(ply:GetBalanceEntity()) then
cmd:SetButtons(cmd:GetButtons() + IN_SPEED)
end
end)
@@ -396,7 +393,7 @@ if CLIENT then
vel = vector_origin
end
- if vel:Length() > 300 then
+ if vel:Length() > speed_limit:GetInt() + 75 then
ply.blurspeed = Lerp(0.001, ply.blurspeed, 0.1)
elseif ply:GetMantle() == 0 then
ply.blurspeed = math.Approach(ply.blurspeed, 0, 0.005)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
index 54783e1..db80b94 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Grapple.lua
@@ -1,18 +1,15 @@
-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()
local ply = LocalPlayer()
- if disable_grapple:GetBool() then return end
+ if disable_grapple:GetBool() and Course_Name == "" then return end
if ply:GetMantle() ~= 0 or ply:GetClimbing() ~= 0 then return end
if not ply:Alive() or Course_Name ~= "" then return end
-
- local activewep = ply:GetActiveWeapon()
-
- if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then return end
+ if ply:notUsingRH() then return end
if ply:GetMoveType() == MOVETYPE_NOCLIP then return end
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") then return end
@@ -60,8 +57,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
if not ply:Alive() or Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 and not ply:GetNW2Entity("Swingrope"):IsValid() then return end
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") and not ply:GetNW2Entity("Swingrope"):IsValid() then return end
- local activewep = ply:GetActiveWeapon()
- local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
+ local usingrh = ply:UsingRH()
if not ply.Grapple_tr then
ply.Grapple_tr = {}
@@ -91,7 +87,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
ply:SetNW2Entity("grappleEntity", trout.Entity)
ply:SetNW2Bool("grappledNonCourse", true)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("MirrorsEdge/Gadgets/ME_Magrope_Fire.wav", 40, 100 + math.random(-25, 10))
end
@@ -131,7 +127,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
ply:SetGrappling(false)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("MirrorsEdge/zipline_detach.wav", 40, 100 + math.random(-25, 10))
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
index a4b2bd8..ed65e5c 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Infection.lua
@@ -1,7 +1,9 @@
-GM_INFECTION = 0
Infection_StartTime = 0
Infection_EndTime = 0
+local startTime = CreateConVar("Beatrun_InfectionStartTime", 10, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 5, 20)
+local gameTime = CreateConVar("Beatrun_InfectionGameTime", 190, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 30, 600)
+
function table.Shuffle(t)
local n = #t
@@ -18,7 +20,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
@@ -240,8 +242,8 @@ if SERVER then
end
end
- Infection_StartTime = CurTime() + 10
- Infection_EndTime = CurTime() + 190
+ Infection_StartTime = CurTime() + startTime:GetInt()
+ Infection_EndTime = CurTime() + gameTime:GetInt()
hook.Add("Think", "InfectionTimer", InfectionTimer)
end
@@ -284,7 +286,7 @@ if SERVER then
if timeremaining <= 70 and timeremaining >= 50 and player.GetCount() > 6 and humancount == 1 then
timer.Simple(0.1, function()
- for k, v in ipairs(player.GetAll()) do
+ for _, v in ipairs(player.GetAll()) do
if v:Alive() and not v:GetNW2Bool("Infected") then
net.Start("Infection_LastMan")
net.Send(v)
@@ -307,7 +309,7 @@ if CLIENT then
local function InfectionHUDName()
if GetGlobalBool("GM_INFECTION") then
- local team = LocalPlayer():GetNW2Bool("Infected") and "(Infected)" or "(Human)"
+ local team = LocalPlayer():GetNW2Bool("Infected") and language.GetPhrase("beatrun.infection.infectedtext") or language.GetPhrase("beatrun.infection.humantext")
return "Infection " .. team
else
@@ -371,13 +373,13 @@ if CLIENT then
noclipkey = input.GetKeyCode(noclipbind)
endtime = 0
- Infection_StartTime = start + 10
- Infection_EndTime = start + 190
+ Infection_StartTime = start + startTime:GetInt()
+ Infection_EndTime = start + gameTime:GetInt()
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), startTime:GetInt()))
end)
local music = nil
@@ -400,12 +402,12 @@ if CLIENT then
survivors = survivors:sub(1, -3)
if survivors == "" then
- survivors = "None..."
+ survivors = language.GetPhrase("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, _time))
end)
if music and music.Stop then
@@ -433,9 +435,9 @@ if CLIENT then
if IsValid(attacker) and IsValid(victim) then
if attacker == victim then
- chat.AddText(attacker, red, " died!")
+ chat.AddText(attacker, red, " " .. language.GetPhrase("beatrun.infection.infected"))
else
- chat.AddText(attacker, red, " has infected ", yellow, victim, "!")
+ chat.AddText(attacker, red, " " .. language.GetPhrase("beatrun.infection.infectedby") .. " ", yellow, victim, "!")
end
attacker.InfectionTouchDelay = CurTime() + 3
@@ -498,10 +500,10 @@ if CLIENT then
if humanwin then
LocalPlayer():AddXP(200)
- chat.AddText(chatcolor, "You were awarded 200 XP for surviving")
+ chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.award"))
else
LocalPlayer():AddXP(100)
- chat.AddText(chatcolor, "You were awarded 100 XP for spawning as an infected")
+ chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.awardinfected"))
end
end)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Ladder.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Ladder.lua
index ce8d228..9b4eff4 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Ladder.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Ladder.lua
@@ -36,7 +36,7 @@ local function LadderCheck(ply, mv, cmd, ladder)
ply:SendLua("BodyAnimSetEase(LocalPlayer():GetNW2Vector('SPBAEase'))")
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
local ang = ply:EyeAngles()
ang.y = ladder:GetAngles().y - 180
ang.x = 0
@@ -141,7 +141,7 @@ local function LadderThink(ply, mv, cmd, ladder)
elseif ply.LadderDown and ply:GetLadderDelay() < CurTime() then
ply.LadderDown = false
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(5, 0, 0))
BodyAnim:SetSequence("ladderclimbuprighthandstill")
elseif game.SinglePlayer() then
@@ -233,7 +233,7 @@ local function LadderThink(ply, mv, cmd, ladder)
mv:SetOrigin(newpos)
mv:SetVelocity(vector_origin)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
BodyAnim:SetSequence("jumpfast")
elseif game.SinglePlayer() then
ply:SendLua("BodyAnim:SetSequence('jumpfast')")
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Melee.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Melee.lua
index 6ac01af..e304939 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Melee.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Melee.lua
@@ -19,7 +19,7 @@ local meleedata = {
},
{
"meleeslide", 0.175, 0.6, function(ply, mv, cmd)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.05, 0, -1))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.1, 0, -1.5))
@@ -29,7 +29,7 @@ local meleedata = {
},
{
"meleeairstill", 0.1, 1, function(ply, mv, cmd)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.5, 0, -0.1))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(1, 0, -0.25))
@@ -39,7 +39,7 @@ local meleedata = {
},
{
"meleeair", 0.15, 1, function(ply, mv, cmd)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.05, 0, -1))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.1, 0, -1.5))
@@ -51,7 +51,7 @@ local meleedata = {
meleedata[5] = {
"meleewrleft", 0.2, 0.75, function(ply, mv, cmd)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.075, 0, 1))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.1, 0, 1.5))
@@ -64,7 +64,7 @@ meleedata[5] = {
mv:SetVelocity(vel)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
local ang = ply:EyeAngles()
ang.y = ang.y + (CurTime() - ply:GetMeleeDelay()) / 0.15 * 0.25
@@ -76,7 +76,7 @@ meleedata[5] = {
meleedata[6] = {
"meleewrright", 0.2, 0.75, function(ply, mv, cmd)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.075, 0, -1))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.1, 0, -1.5))
@@ -89,7 +89,7 @@ meleedata[6] = {
mv:SetVelocity(vel)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
local ang = ply:EyeAngles()
ang.y = ang.y - (CurTime() - ply:GetMeleeDelay()) / 0.15 * 0.25
@@ -105,7 +105,7 @@ local doors = {
}
local function KeyMelee(ply, mv)
- return mv:KeyPressed(IN_ALT2) or mv:KeyPressed(IN_ATTACK) and IsValid(ply:GetActiveWeapon()) and ply:GetActiveWeapon():GetClass() == "runnerhands"
+ return mv:KeyPressed(IN_ALT2) or mv:KeyPressed(IN_ATTACK) and ply:UsingRH()
end
local function MeleeType(ply, mv, cmd)
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 51c6b07..dcc3fdf 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Quickturn.lua
@@ -1,5 +1,6 @@
if CLIENT then
- QuickturnGround = CreateClientConVar("Beatrun_QuickturnGround", "0", true, true, "Enables quickturning with secondary attack while on the ground", 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)
@@ -10,6 +11,7 @@ function DoJumpTurn(lookbehind)
end
BodyAnim:SetSequence("jumpturnfly")
+
BodyAnimCycle = 0
BodyAnimSpeed = 1
BodyLimitX = 40
@@ -36,9 +38,7 @@ function DoJumpTurnStand()
VMLegs:Remove()
end
- local activewep = LocalPlayer():GetActiveWeapon()
-
- if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
+ if LocalPlayer():notUsingRH() then
BodyAnim:SetSequence("jumpturnlandstandgun")
else
BodyAnim:SetSequence("jumpturnlandstand")
@@ -54,7 +54,7 @@ end
local standpunch = Angle(-5, 0, 0)
local function Quickturn(ply, mv, cmd)
- local keypressed = mv:KeyPressed(IN_ATTACK2) and ply:GetActiveWeapon():GetClass() == "runnerhands"
+ local keypressed = ply:Alive() and mv:KeyPressed(IN_ATTACK2) and (ply:GetInfoNum("Beatrun_QuickturnHandsOnly", 0) == 1 and ply:UsingRH() or ply:GetInfoNum("Beatrun_QuickturnHandsOnly", 0) == 0)
if ply:GetWallrun() ~= 0 then
if mv:KeyDown(IN_BACK) and mv:KeyPressed(IN_JUMP) or ply:GetQuickturn() then
@@ -81,7 +81,7 @@ local function Quickturn(ply, mv, cmd)
end
end
- if not ply:GetQuickturn() and not ply:GetJumpTurn() and not ply:GetCrouchJump() and not ply:GetGrappling() and keypressed and not mv:KeyDown(IN_MOVELEFT) and not mv:KeyDown(IN_MOVERIGHT) and (ply:GetWallrun() > 0 or not ply:OnGround() or ply:GetInfoNum("Beatrun_QuickturnGround", 0) == 1 and not ply:Crouching()) then
+ if not ply:GetQuickturn() and not ply:GetJumpTurn() and not ply:GetCrouchJump() and not ply:GetGrappling() and not ply:GetSliding() and keypressed and not mv:KeyDown(IN_MOVELEFT) and not mv:KeyDown(IN_MOVERIGHT) and (ply:GetWallrun() > 0 or not ply:OnGround() or ply:GetInfoNum("Beatrun_QuickturnGround", 0) == 1 and not ply:Crouching()) then
if ply:GetWallrun() == 0 and not ply:OnGround() then
local eyedir = cmd:GetViewAngles()
eyedir.x = 0
@@ -96,9 +96,9 @@ local function Quickturn(ply, mv, cmd)
if not lookahead and not lookbehind and ply:WaterLevel() < 3 and not IsValid(ply:GetSwingbar()) and not IsValid(ply:GetZipline()) then
return
elseif (lookahead or lookbehind) and ply:WaterLevel() < 3 and not IsValid(ply:GetSwingbar()) and not IsValid(ply:GetZipline()) then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
DoJumpTurn(lookbehind)
- elseif SERVER and game.SinglePlayer() then
+ elseif game.SinglePlayer() then
ply:SendLua("DoJumpTurn(" .. tostring(lookbehind) .. ")")
end
@@ -116,14 +116,7 @@ local function Quickturn(ply, mv, cmd)
end
end
- local usingrh = false
- local activewep = ply:GetActiveWeapon()
-
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if not usingrh and ply:GetWallrun() >= 2 then return end
+ if not ply:UsingRH() and ply:GetWallrun() >= 2 then return end
ply:SetQuickturn(true)
ply:SetQuickturnTime(CurTime())
@@ -145,11 +138,7 @@ local function Quickturn(ply, mv, cmd)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_PRIMARYATTACK)
activewep:SetBlockAnims(true)
end
@@ -202,9 +191,8 @@ local function Quickturn(ply, mv, cmd)
end
standpunch.x = -math.abs(math.min(CurTime() - ply:GetJumpTurnRecovery() + 0.5, 0))
- local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
+ if ply:notUsingRH() then
standpunch.x = standpunch.x * 0.1
standpunch.z = standpunch.x * 10
else
@@ -212,7 +200,7 @@ local function Quickturn(ply, mv, cmd)
standpunch.z = 0
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(standpunch)
elseif game.SinglePlayer() then
ply:ViewPunch(standpunch)
@@ -236,7 +224,7 @@ local function Quickturn(ply, mv, cmd)
target.y = lerp
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:SetEyeAngles(target)
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/SafetyRoll.lua b/beatrun/gamemodes/beatrun/gamemode/sh/SafetyRoll.lua
index de83799..fea11c3 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/SafetyRoll.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/SafetyRoll.lua
@@ -7,7 +7,7 @@ local landang = Angle(0, 0, 0)
local function SafetyRollThink(ply, mv, cmd)
local speed = mv:GetVelocity().z
- if speed <= -350 and not ply:OnGround() and not ply:GetWasOnGround() and (mv:KeyPressed(IN_SPEED) or mv:KeyPressed(IN_DUCK) or mv:KeyPressed(IN_BULLRUSH)) then
+ if speed <= -350 and not ply:OnGround() and not ply:GetWasOnGround() and (mv:KeyPressed(IN_DUCK) or mv:KeyPressed(IN_SPEED) or mv:KeyPressed(IN_BULLRUSH)) then
ply:SetSafetyRollKeyTime(CurTime() + 0.5)
mv:SetButtons(bit.band(mv:GetButtons(), bit.bnot(IN_DUCK)))
@@ -35,6 +35,12 @@ local function SafetyRollThink(ply, mv, cmd)
mv:SetVelocity(vector_origin)
end
end
+
+ if ply:Alive() and ply:GetActiveWeapon():IsValid() and CurTime() > ply:GetSafetyRollTime() then
+ if weapons.IsBasedOn(ply:GetActiveWeapon():GetClass(), "mg_base") then
+ RunConsoleCommand("mgbase_debug_vmrender", "1")
+ end
+ end
end
hook.Add("SetupMove", "SafetyRoll", SafetyRollThink)
@@ -51,8 +57,14 @@ local roll = {
}
net.Receive("RollAnimSP", function()
+ local ply = LocalPlayer()
+
if net.ReadBool() then
- roll.AnimString = "land"
+ if ply:UsingRH() then
+ roll.AnimString = "land"
+ else
+ roll.AnimString = "landgun"
+ end
roll.animmodelstring = "climbanim"
roll.BodyAnimSpeed = 1
elseif net.ReadBool() then
@@ -60,7 +72,12 @@ net.Receive("RollAnimSP", function()
roll.animmodelstring = "climbanim"
roll.BodyAnimSpeed = 1.5
else
- roll.AnimString = "meroll"
+ if ply:UsingRH() then
+ roll.AnimString = "meroll"
+ else
+ roll.AnimString = "merollgun"
+ end
+
roll.animmodelstring = "climbanim"
roll.BodyAnimSpeed = 1.15
end
@@ -72,6 +89,12 @@ end)
hook.Add("SetupMove", "EvadeRoll", function(ply, mv, cmd)
if ply:GetJumpTurn() and ply:OnGround() and mv:KeyPressed(IN_BACK) then
+ if ply:Alive() and ply:GetActiveWeapon():IsValid() then
+ if weapons.IsBasedOn(ply:GetActiveWeapon():GetClass(), "mg_base") then
+ RunConsoleCommand("mgbase_debug_vmrender", "0")
+ end
+ end
+
local ang = cmd:GetViewAngles()
ply:SetViewOffset(Vector(0, 0, 64))
@@ -91,12 +114,12 @@ hook.Add("SetupMove", "EvadeRoll", function(ply, mv, cmd)
if SERVER and not land then
ply:EmitSound("Cloth.Roll")
ply:EmitSound("Cloth.RollLand")
- elseif CLIENT_IFTP() or game.SinglePlayer() then
+ elseif CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("Handsteps.ConcreteHard")
ply:EmitSound("Land.Concrete")
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
CacheBodyAnim()
RemoveBodyAnim()
StartBodyAnim(roll)
@@ -126,6 +149,12 @@ hook.Add("OnPlayerHitGround", "SafetyRoll", function(ply, water, floater, speed)
ParkourEvent("roll", ply)
+ if ply:Alive() and ply:GetActiveWeapon():IsValid() then
+ if weapons.IsBasedOn(ply:GetActiveWeapon():GetClass(), "mg_base") then
+ RunConsoleCommand("mgbase_debug_vmrender", "0")
+ end
+ end
+
local ang = ply:EyeAngles()
local land = ply:GetVelocity()
ang.x = 0
@@ -138,7 +167,12 @@ hook.Add("OnPlayerHitGround", "SafetyRoll", function(ply, water, floater, speed)
ply:SetSafetyRollAng(landang)
ply:SetSafetyRollTime(CurTime() + 0.6)
- roll.AnimString = "land"
+ if ply:UsingRH() then
+ roll.AnimString = "land"
+ else
+ roll.AnimString = "landgun"
+ end
+
roll.animmodelstring = "climbanim"
roll.usefullbody = true
else
@@ -147,7 +181,12 @@ hook.Add("OnPlayerHitGround", "SafetyRoll", function(ply, water, floater, speed)
ply:SetSafetyRollAng(ang)
ply:SetSafetyRollTime(CurTime() + 1.05)
- roll.AnimString = "meroll"
+ if ply:UsingRH() then
+ roll.AnimString = "meroll"
+ else
+ roll.AnimString = "merollgun"
+ end
+
roll.animmodelstring = "climbanim"
roll.usefullbody = false
end
@@ -155,12 +194,12 @@ hook.Add("OnPlayerHitGround", "SafetyRoll", function(ply, water, floater, speed)
if SERVER and not land then
ply:EmitSound("Cloth.Roll")
ply:EmitSound("Cloth.RollLand")
- elseif CLIENT_IFTP() or game.SinglePlayer() then
+ elseif CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("Handsteps.ConcreteHard")
ply:EmitSound("Land.Concrete")
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
CacheBodyAnim()
RemoveBodyAnim()
StartBodyAnim(roll)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Sliding.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Sliding.lua
index 86facac..d048742 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Sliding.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Sliding.lua
@@ -2,13 +2,13 @@ local qslide_duration = 3
local qslide_speedmult = 1
local slide_sounds = {
- [MAT_DIRT] = {"datae/fol_slide_dirt_01.wav", "datae/fol_slide_dirt_02.wav", "datae/fol_slide_dirt_03.wav", "datae/fol_slide_dirt_04.wav"},
- [MAT_SAND] = {"datae/fol_slide_sand_01.wav", "datae/fol_slide_sand_02.wav", "datae/fol_slide_sand_03.wav", "datae/fol_slide_sand_04.wav"},
- [MAT_METAL] = {"datae/fol_slide_metal_01.wav", "datae/fol_slide_metal_02.wav", "datae/fol_slide_metal_03.wav"},
- [MAT_GLASS] = {"datae/fol_slide_glass_01.wav", "datae/fol_slide_glass_02.wav", "datae/fol_slide_glass_03.wav", "datae/fol_slide_glass_04.wav"},
- [MAT_GRATE] = {"datae/fol_slide_grate_01.wav"},
+ [MAT_DIRT] = {"fol/fol_slide_dirt_01.wav", "fol/fol_slide_dirt_02.wav", "fol/fol_slide_dirt_03.wav", "fol/fol_slide_dirt_04.wav"},
+ [MAT_SAND] = {"fol/fol_slide_sand_01.wav", "fol/fol_slide_sand_02.wav", "fol/fol_slide_sand_03.wav", "fol/fol_slide_sand_04.wav"},
+ [MAT_METAL] = {"fol/fol_slide_metal_01.wav", "fol/fol_slide_metal_02.wav", "fol/fol_slide_metal_03.wav"},
+ [MAT_GLASS] = {"fol/fol_slide_glass_01.wav", "fol/fol_slide_glass_02.wav", "fol/fol_slide_glass_03.wav", "fol/fol_slide_glass_04.wav"},
+ [MAT_GRATE] = {"fol/fol_slide_grate_01.wav"},
[MAT_SLOSH] = {"ambient/water/water_splash1.wav", "ambient/water/water_splash2.wav", "ambient/water/water_splash3.wav"},
- [MAT_WOOD] = {"datae/fol_slide_generic_01.wav", "datae/fol_slide_generic_02.wav", "datae/fol_slide_generic_03.wav"}
+ [MAT_WOOD] = {"fol/fol_slide_generic_01.wav", "fol/fol_slide_generic_02.wav", "fol/fol_slide_generic_03.wav"}
}
local slideloop_sounds = {
@@ -72,7 +72,7 @@ local function SlidingAnimThink()
local newang = LerpAngle(20 * FrameTime(), oldang, ang)
ba:SetAngles(newang)
- BodyLimitX = math.min(40 + ang[1] - 360, 60)
+ BodyLimitX = math.min(20 + ang[1] - 360, 60)
CamShakeMult = ply:GetVelocity():Length() * 0.0005
end
end
@@ -346,7 +346,7 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
local normal = slipperytraceout.HitNormal
local sang = normal:Angle()
- local slippery = sang.x > 315 and sang.x < 330 and ply:GetMoveType() ~= MOVETYPE_NOCLIP and not ply:GetCrouchJump() and onground and not slipfail
+ local slippery = sang.x > 315 and sang.x < 330 and ply:GetMoveType() ~= MOVETYPE_NOCLIP and not ply:GetCrouchJump() and onground and not slipfail and ply:WaterLevel() < 1
ply:SetSlidingSlippery(slippery)
@@ -430,7 +430,7 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
net.Send(ply)
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
SlidingAnimStart()
hook.Add("Think", "SlidingAnimThink", SlidingAnimThink)
@@ -480,7 +480,7 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
net.Send(ply)
ply.DiveSliding = false
- elseif CLIENT_IFTP() then
+ elseif CLIENT and IsFirstTimePredicted() then
SlidingAnimEnd(false, ply.DiveSliding)
ply.DiveSliding = false
@@ -578,7 +578,7 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
end
if mv:KeyPressed(IN_BACK) and ply:GetMelee() == 0 and ply:GetSlidingTime() < CT + slidetime * 0.95 then
- if CLIENT or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
cmd:SetViewAngles(ply:GetSlidingAngle())
end
@@ -589,14 +589,16 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
ply:SetQuickturnTime(CT)
ply:SetQuickturnAng(cmd:GetViewAngles())
- if CLIENT then
+ if CLIENT and IsFirstTimePredicted() then
DoJumpTurn(false)
elseif game.SinglePlayer() then
ply:SendLua("DoJumpTurn(false)")
end
ply:SetJumpTurn(true)
+
ply:ViewPunch(Angle(2.5, 0, 5))
+
ply:SetViewOffsetDucked(Vector(0, 0, 17))
ply:SetViewOffset(Vector(0, 0, 64))
@@ -623,7 +625,7 @@ hook.Add("SetupMove", "qslide", function(ply, mv, cmd)
net.WriteBool(slippery)
net.WriteBool(ply.DiveSliding)
net.Send(ply)
- elseif CLIENT_IFTP() then
+ elseif CLIENT and IsFirstTimePredicted() then
SlidingAnimEnd(slippery, ply.DiveSliding)
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/SwingPipe.lua b/beatrun/gamemodes/beatrun/gamemode/sh/SwingPipe.lua
index 2b99db7..0faf361 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/SwingPipe.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/SwingPipe.lua
@@ -162,7 +162,7 @@ local function SwingpipeThink(ply, mv, cmd)
if CLIENT or game.SinglePlayer() then
ply:SetEyeAngles(LerpAngle(startlerp, ply:EyeAngles(), circlepos:Angle()))
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
viewtiltlerp.z = startlerp * -10 * dir
ply:CLViewPunch(Angle(0, 0.1 * dir))
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Monkey.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Swingbar.lua
similarity index 97%
rename from beatrun/gamemodes/beatrun/gamemode/sh/Monkey.lua
rename to beatrun/gamemodes/beatrun/gamemode/sh/Swingbar.lua
index b581516..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
@@ -158,11 +159,11 @@ local function SwingbarThink(ply, mv, cmd)
ply:SetSBDelay(CurTime() + 1)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
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 b53fa6b..6bc0162 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Vaulting.lua
@@ -45,10 +45,10 @@ 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 IsValid(activewep) and activewep:GetClass() == "runnerhands" and activewep:GetSequence() == 17 then
+ if ply:UsingRH() and activewep:GetSequence() == 17 then
activewep:SendWeaponAnim(ACT_VM_DRAW)
end
@@ -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()
@@ -231,14 +231,14 @@ local function Vault2(ply, mv, ang, t, h)
local hulltr2 = util.TraceHull(h)
if not hulltr.Hit and not hulltr2.Hit then
- if t.MatType == MAT_GRATE and (CLIENT_IFTP() or game.SinglePlayer()) then
+ if t.MatType == MAT_GRATE and (CLIENT and IsFirstTimePredicted() or game.SinglePlayer()) then
ply:EmitSound("FenceClimb")
end
ply:SetMantleData(mv:GetOrigin(), vaultpos, 0, 2)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, 1)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch2)
ply.MantleInitVel = mv:GetVelocity()
@@ -331,14 +331,14 @@ local function Vault3(ply, mv, ang, t, h)
local hulltr2 = util.TraceHull(h)
if not hulltr.Hit and not hulltr2.Hit then
- if t.MatType == MAT_GRATE and (CLIENT_IFTP() or game.SinglePlayer()) then
+ if t.MatType == MAT_GRATE and (CLIENT and IsFirstTimePredicted() or game.SinglePlayer()) then
ply:EmitSound("FenceClimb")
end
ply:SetMantleData(mv:GetOrigin(), vaultpos, 0, 3)
ply:SetWallrunTime(0)
- PlayVaultAnim(ply, 2)
+ PlayVaultAnim(ply, ang)
ply:ViewPunch(vpunch3)
ply.MantleInitVel = mv:GetVelocity()
@@ -389,6 +389,7 @@ function Vault4(ply, mv, ang, t, h)
local tsafetyout = util.TraceLine(tsafety)
if tsafetyout.Hit then return false end
+
tsafety.start = mv:GetOrigin() + chestvec
tsafety.endpos = tsafety.start + ang:Forward() * 150
@@ -414,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()
@@ -471,6 +472,7 @@ function Vault5(ply, mv, ang, t, h)
t = util.TraceLine(t)
if not t.Hit then return false end
+
if t.Entity and t.Entity.NoPlayerCollisions then return false end
local vaultend = t.HitPos + mantlevec
@@ -514,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()
@@ -596,7 +598,7 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
if not ply.VaultStepUp and mlerp > 0.01 and mlerp < 0.65 then
mlerprate = mlerprate * mlerp / 0.5
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.1 / (mlerp / 0.25), 0, 0.05))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.33 / (mlerp / 0.25), 0, 0.05))
@@ -617,13 +619,13 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
mlerprate = mlerprate * mult
end
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.25 * mlerp / 0.2, -0.05, -0.15))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.75 * mlerp / 0.2, -0.25, -0.5))
end
elseif mlerp > 0.45 and mlerp < 0.7 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(-0.15, 0.1, 0.15))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(-0.75, 0.25, 0.5))
@@ -633,13 +635,13 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
ply:SetMantleLerp(math.Approach(mlerp, 1, mlerprate))
elseif mantletype == 3 then
if mlerp < 0.45 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.15, 0, 0))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.3, 0, 0))
end
elseif mlerp > 0.45 and mlerp < 0.8 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(-0.05, 0, 0))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(-0.25, 0, 0))
@@ -655,14 +657,14 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
mlerprate = 0.03 / TargetTick
if mlerp < 0.0575 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.25 * mlerp / 0.2, 0, -0.25))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.75 * mlerp / 0.1, 0, -0.5))
end
mlerprate = mlerprate * 0.1
- elseif CLIENT_IFTP() then
+ elseif CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(-0.05, 0, 0.25 / (mlerp / 0.3)))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(-0.15, 0, 0.5 / (mlerp / 0.3)))
@@ -677,7 +679,7 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
mlerprate = 0.03 / TargetTick
if mlerp < 0.0575 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(-0.15 * mlerp / 0.1, 0, -0.25))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(0.15 * mlerp / 0.1, 0, -0.5))
@@ -685,7 +687,7 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
mlerprate = mlerprate * 0.1
else
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(0.01, 0, 0.5 / (mlerp / 0.15)))
elseif game.SinglePlayer() then
ply:ViewPunch(Angle(-0.05, 0, 0.5 / (mlerp / 0.3)))
@@ -734,7 +736,7 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
end
if mv:KeyDown(IN_JUMP) and mantletype < 4 then
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
BodyLimitX = 90
BodyLimitY = 180
elseif game.SinglePlayer() then
@@ -764,7 +766,7 @@ hook.Add("SetupMove", "BeatrunVaulting", function(ply, mv, cmd)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) and activewep:GetClass() == "runnerhands" and mantletype == 1 then
+ if ply:UsingRH() and mantletype == 1 then
activewep:SendWeaponAnim(ACT_VM_RECOIL1)
end
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Wallrun.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Wallrun.lua
index 58dec61..b956f17 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Wallrun.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Wallrun.lua
@@ -105,11 +105,7 @@ local function WallrunningThink(ply, mv, cmd)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false)
end
@@ -132,11 +128,7 @@ local function WallrunningThink(ply, mv, cmd)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false)
end
@@ -423,7 +415,7 @@ local function WallrunningCheck(ply, mv, cmd)
ParkourEvent("wallrunv", ply)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
BodyLimitX = 30
BodyLimitY = 70
BodyAnimCycle = 0
@@ -534,7 +526,7 @@ hook.Add("SetupMove", "Wallrunning", function(ply, mv, cmd)
ply:SetWallrun(0)
end
- if ply:GetWallrun() == 0 and mv:GetVelocity().z > -450 and not ply:OnGround() and mv:KeyDown(IN_FORWARD) and not ply:Crouching() and not mv:KeyDown(IN_DUCK) and ply:GetMoveType() ~= MOVETYPE_NOCLIP then
+ if ply:GetWallrun() == 0 and mv:GetVelocity().z > -450 and not ply:OnGround() and mv:KeyDown(IN_FORWARD) and not ply:Crouching() and not mv:KeyDown(IN_DUCK) and ply:GetMoveType() ~= MOVETYPE_NOCLIP and ply:WaterLevel() < 1 then
WallrunningCheck(ply, mv, cmd)
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/WallrunME.lua b/beatrun/gamemodes/beatrun/gamemode/sh/WallrunME.lua
index 012b357..c1d34e0 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/WallrunME.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/WallrunME.lua
@@ -70,7 +70,7 @@ function PuristWallrunningCheck(ply, mv, cmd, vel, eyeang, timemult, speedmult)
ParkourEvent("wallrunv", ply)
- if CLIENT_IFTP() then
+ if CLIENT and IsFirstTimePredicted() then
BodyLimitX = 30
BodyLimitY = 70
BodyAnimCycle = 0
@@ -198,11 +198,7 @@ function PuristWallrunningThink(ply, mv, cmd, wr, wrtimeremains)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false)
end
@@ -225,11 +221,7 @@ function PuristWallrunningThink(ply, mv, cmd, wr, wrtimeremains)
local activewep = ply:GetActiveWeapon()
- if IsValid(activewep) then
- usingrh = activewep:GetClass() == "runnerhands"
- end
-
- if usingrh then
+ if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false)
end
diff --git a/beatrun/gamemodes/beatrun/gamemode/sh/Zipline.lua b/beatrun/gamemodes/beatrun/gamemode/sh/Zipline.lua
index cefcd45..4774bbd 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sh/Zipline.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sh/Zipline.lua
@@ -104,8 +104,7 @@ local function ZiplineCheck(ply, mv, cmd, zipline)
ply:SetZiplineSpeed(math.min(vel:Length(), 750))
ply:SetCrouchJumpBlocked(false)
- if CLIENT_IFTP() then
- -- local zipline = ply:GetZipline()
+ if CLIENT and IsFirstTimePredicted() then
ply.OrigEyeAng = (endpos - startpos):Angle()
elseif game.SinglePlayer() then
net.Start("Zipline_SPFix")
@@ -113,7 +112,7 @@ local function ZiplineCheck(ply, mv, cmd, zipline)
net.Send(ply)
end
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("ZiplineLoop")
ply:EmitSound("ZiplineStart")
end
@@ -149,7 +148,7 @@ local function ZiplineThink(ply, mv, cmd, zipline)
ply:SetZiplineDelay(CurTime() + 0.75)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("ZiplineEnd")
ply:StopSound("ZiplineLoop")
@@ -189,7 +188,7 @@ local function ZiplineThink(ply, mv, cmd, zipline)
ply:SetZiplineDelay(CurTime() + 0.75)
- if CLIENT_IFTP() or game.SinglePlayer() then
+ if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("ZiplineEnd")
ply:StopSound("ZiplineLoop")
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/MapScript.lua b/beatrun/gamemodes/beatrun/gamemode/sv/MapScript.lua
index 7dfcd59..8d82e18 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/MapScript.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/MapScript.lua
@@ -1,5 +1,6 @@
function BRProtectedEntity(class, pos, ang)
local a = ents.Create(class)
+
a:SetPos(pos)
a:SetAngles(ang)
a:Spawn()
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/ToggleGamemodes.lua b/beatrun/gamemodes/beatrun/gamemode/sv/ToggleGamemodes.lua
index 57a6a85..a202024 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/ToggleGamemodes.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/ToggleGamemodes.lua
@@ -3,7 +3,7 @@ util.AddNetworkString("Beatrun_ToggleGamemode")
net.Receive("Beatrun_ToggleGamemode", function(_, ply)
if not ply:IsAdmin() then return end
- local gm = net.ReadString()
+ local gm = string.lower(net.ReadString())
if gm == "datatheft" then
if not GetGlobalBool("GM_DATATHEFT") then
diff --git a/beatrun/gamemodes/beatrun/gamemode/sv/off/blind.lua b/beatrun/gamemodes/beatrun/gamemode/sv/off/blind.lua
index e0bc942..0ee6b59 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/off/blind.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/off/blind.lua
@@ -48,7 +48,7 @@ concommand.Add("blindplayer", function(ply, cmd, args)
local mname = ""
local mcount = 0
- for k, v in ipairs(player.GetAll()) do
+ for _, v in ipairs(player.GetAll()) do
local name = v:Nick()
local smatch = string.match(name, plysearch)
diff --git a/beatrun/gamemodes/beatrun/gamemode/sv/spawn.lua b/beatrun/gamemodes/beatrun/gamemode/sv/spawn.lua
index cfa826b..b4ea80a 100644
--- a/beatrun/gamemodes/beatrun/gamemode/sv/spawn.lua
+++ b/beatrun/gamemodes/beatrun/gamemode/sv/spawn.lua
@@ -1,9 +1,85 @@
DEFINE_BASECLASS("gamemode_base")
+local entMeta = FindMetaTable("Entity")
+
+-- successfully yonked from DarkRP, thanks <3
+function fp(tbl)
+ local func = tbl[1]
+
+ return function(...)
+ local fnArgs = {}
+ local arg = {...}
+ local tblN = table.maxn(tbl)
+
+ for i = 2, tblN do fnArgs[i - 1] = tbl[i] end
+ for i = 1, table.maxn(arg) do fnArgs[tblN + i - 1] = arg[i] end
+
+ return func(unpack(fnArgs, 1, table.maxn(fnArgs)))
+ end
+end
+
+local oldPlyColor
+
+local function disableBabyGod(ply)
+ if not IsValid(ply) or not ply.Babygod then return end
+
+ ply.Babygod = nil
+
+ ply:SetRenderMode(RENDERMODE_NORMAL)
+ ply:GodDisable()
+
+ local reinstateOldColor = true
+
+ for _, p in ipairs(player.GetAll()) do
+ reinstateOldColor = reinstateOldColor and p.Babygod == nil
+ end
+
+ if reinstateOldColor then
+ entMeta.SetColor = oldPlyColor
+ oldPlyColor = nil
+ end
+
+ ply:SetColor(ply.babyGodColor or color_white)
+
+ ply.babyGodColor = nil
+end
+
+local function enableBabyGod(ply)
+ timer.Remove(ply:EntIndex() .. "babygod")
+
+ ply.Babygod = true
+
+ ply:GodEnable()
+
+ ply.babyGodColor = ply:GetColor()
+
+ ply:SetRenderMode(RENDERMODE_TRANSALPHA)
+
+ if not oldPlyColor then
+ oldPlyColor = entMeta.SetColor
+
+ entMeta.SetColor = function(p, c, ...)
+ if not p.Babygod then return oldPlyColor(p, c, ...) end
+
+ p.babyGodColor = c
+
+ oldPlyColor(p, Color(c.r, c.g, c.b, 100))
+ end
+ end
+
+ ply:SetColor(ply.babyGodColor)
+
+ timer.Create(ply:EntIndex() .. "babygod", 5, 1, fp({disableBabyGod, ply}))
+end
+
function GM:PlayerSpawn(ply, transition)
player_manager.SetPlayerClass(ply, "player_beatrun")
ply:StripAmmo()
BaseClass.PlayerSpawn(self, ply, transition)
+
+ if GetGlobalBool("GM_DEATHMATCH") or GetGlobalBool("GM_DATATHEFT") then
+ enableBabyGod(ply)
+ end
end
\ No newline at end of file
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")