42 lines
1.8 KiB
Markdown
42 lines
1.8 KiB
Markdown
|
# Progs {#progs}
|
||
|
|
||
|
Progs are binary files containing bytecode that contain platform and architecture
|
||
|
indepenent programs.
|
||
|
|
||
|
We generally refer to them as **progs**.
|
||
|
|
||
|
Our SDK is built using QuakeC as the language of choice, as that's where
|
||
|
the engine-provided API is the most powerful and there is a great
|
||
|
deal of history of games using it.
|
||
|
|
||
|
## Server-Side QuakeC {#SSQC}
|
||
|
|
||
|
The main game-logic module, first introduced with **Quake (1996)**.
|
||
|
It is involved with the core game entities, triggers, and decides what
|
||
|
monsters, items and weapons are allowed in the game and how they are used.
|
||
|
In Nuclide, the server game is tightly coupled with @ref entitydef to
|
||
|
make everything streamlined for content creators and developers alike.
|
||
|
|
||
|
## Client-Side QuakeC {#CSQC}
|
||
|
|
||
|
Largely responsible for visual effects and the overall presentation.
|
||
|
A large chunk of the client-side code is spent executing shared code
|
||
|
between client and server. Player movement, weapons and vehicle input
|
||
|
is shared between client and server to ensure smooth network play.
|
||
|
|
||
|
## Additional Progs
|
||
|
|
||
|
We offer multiple types of progs the game-logic can load/unload at runtime.
|
||
|
|
||
|
You will generally find them within your `<gamedir>/progs` directory.
|
||
|
|
||
|
They are optional. So if you want to handle everything internally, you can.
|
||
|
|
||
|
But if you're worried about keeping up with changes, you may want to depend on their stable APIs and extend your game using modules as the main method of feature-injection.
|
||
|
|
||
|
- data:image/s3,"s3://crabby-images/4275c/4275c35968c0e60aec5142a4c4d01400554b967e" alt="" [HudC](@ref hudC) powers our client-side, hot-pluggable **heads-up-display**.
|
||
|
- data:image/s3,"s3://crabby-images/23a7c/23a7cd3536371f6d22e89874f91510a1b144446c" alt="" [AddonC](@ref addonC) is our server-side **plugin** system.
|
||
|
- data:image/s3,"s3://crabby-images/eec5c/eec5c68a48b156bd2e95956e754823336933f8c7" alt="" [MapC](@ref mapC) handles server-side **map-oriented** tasks and logic.
|
||
|
- data:image/s3,"s3://crabby-images/bf925/bf9251410f70b4313d92854a95a8a790faf52a28" alt="" [RuleC](@ref ruleC) is responsible for the shared, **global set of game-rules**.
|
||
|
|