The QuakeC repository for NZ:P, all platforms.
Find a file
Ian 1d51c1ca74
Server: Make Precache_Set an inline function
will help out a bit with jumps when this gets more widely adopted in our codebase. also hello from GitHub for iOS :^)
2022-11-19 11:08:06 -05:00
.github/workflows GH: Update actions/checkout to v3 2022-10-24 08:49:47 -04:00
bin ..same for FTEQCC 2022-02-08 13:46:47 -05:00
progs Add CTR QuakeC 2022-09-02 20:19:25 -04:00
source Server: Make Precache_Set an inline function 2022-11-19 11:08:06 -05:00
tools Add CTR QuakeC 2022-09-02 20:19:25 -04:00
.gitignore Initial commit 2022-02-08 13:42:28 -05:00
LICENSE Initial commit 2022-02-08 13:42:28 -05:00
README.md Initial commit 2022-02-08 13:42:28 -05:00

Nazi Zombies: Portable QuakeC

About

This is the QuakeC portion of the NZ:P source code. QuakeC is responsible for most game-related code such as weapon logic, ai, and Perks. You can read more about QuakeC on the Wikipedia page. NZ:P makes use of CSQC for PC/FTE.

Project Structure

Here is a brief explanation for each of the (sub)directories in this repository:

  • bin: Command line binaries for FTEQCC + the ini configuration file.
  • progs: *.src files, a list of QuakeC source files each platform is dependent on.
  • source:
    • client: FTE-exclusive CSQC, used for the HUD, achievements, and other server->client requests.
    • server: Game code relevant to all platforms, contains most expected logic.
    • shared: Definitions for weapon stats and some utility functions shared by both the client and server.
  • tools: Build scripts to compile the QuakeC into .dat and .lno files.

Updating

While it's usually recommended to stay on the QuakeC version provided with your build of NZ:P, you may want to update it to the current development builds to test new features and changes. To do this, navigate to the Releases page and follow the instructions there for downloading and installing.

Building (Beginner Friendly)

There are no prerequisites or dependancies needed to build QuakeC other than a working Windows or Linux-based machine (MacOS is not natively supported, but you can use WINE).

Before you can build the NZ:P QuakeC, you must either download this repository (easy) or clone it (for developers).

To build, simply navigate to the tools directory and run the qc-compiler-* script for your platform. If unfamiliar with executing shell (.sh) scripts on Linux systems, give this itsFOSS article a read.

After having done this, a build directory will have been created, and inside of it will be more directories named after every platform. Copy the contents of the platform directories into your nzp game directory. (Example: copy progs.dat and progs.lno from build/psp to PSP/GAME/nzportable/nzp).