A network-based Pong game, written in C++.
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Aadhavan Srinivasan ec2f3320e3 Replaced display_text_centered() with the environment-agnostic display_text() function; Changed function to include parameter to indicate environment type 9 months ago
includes Replaced display_text_centered() with the environment-agnostic display_text() function; Changed function to include parameter to indicate environment type 9 months ago
subprojects Added raylib submodule, under subprojects directory 10 months ago
.gitignore Added .gitignore 10 months ago
.gitmodules Added raylib submodule, under subprojects directory 10 months ago
README.md Updated README 10 months ago
ball.cpp Fixed misaligned bracket 10 months ago
check_input.cpp Replaced display_text_centered() with the environment-agnostic display_text() function; Changed function to include parameter to indicate environment type 9 months ago
client.cpp Removed unnecessary #include 10 months ago
connect_code.cpp Removed testing code 10 months ago
create_release_mingw.sh Compile the application if it isn't already compiled 9 months ago
create_static_linux.sh Finished script to create and package statically linked binary on Linux 10 months ago
display_text.cpp Created a file that contains functions for agnostic text output 9 months ago
easysock.c Cast sockaddr to sockaddr_storage 9 months ago
main.cpp Wrote the check_num_args() function; still need to integrate it into the program. Also wrote a help text that is printed with -h flag. 9 months ago
meson.build Replaced global_args with project_args to prevent build error on MinGW 9 months ago
numeric_base.cpp Updated comment explaining function 10 months ago
paddle.cpp Created method to set position of paddle 10 months ago
raygui_helpers.cpp Added new function to display text then exit 10 months ago
serialization.c Updated UNIX macro checks, to account for MacOS 10 months ago
server.cpp Added support for printing out the peer's IPv6 address; replaced struct sockaddr with struct sockaddr_storage 10 months ago
sock.cpp Replace all instances of sockaddr with sockaddr_storage 10 months ago
timer.c Split timer into header and implementation file 10 months ago
todo.txt Updated TODO 9 months ago

README.md

Netpong - A Pong game for the internet era

Netpong is a network-enabled Pong game, written in C++. It enables two players to play against each other, provided an IP address and a port. It also supports a single-player mode.

How it works

The game has only one runtime dependency: The raylib graphics library. In order to write idiomatic C++, I chose to use the raylib-cpp wrapper, which provides an object-oriented interface to the Raylib library.

Building

This application uses Meson as a build system. To build the application:

  1. Install meson from the link above.

  2. Set up the build directory.

    meson setup build
    
  3. Compile the application. Meson should use a system installation of raylib, if it exists. If not, it falls back to a bundled version.

    meson compile -C build
    
  4. You can also create a statically-linked version of the game (with no runtime dependencies) on Linux by running the following commands:

    meson configure -Ddefault_library=static build/
    meson compile -C build -Ddefault_library=static
    

Running

  • To run in single-player mode:

    • Run the application with no arguments: build/pong
    • Left paddle is controlled with W and S keys, right paddle is controlled with Up and Down arrow keys.
  • To run in multi-player mode:

    • One player runs the application in Server mode, specifying their IP address and a port: build/pong -S <ip_address> <port>
    • The other player connects to the first player by running in Client mode, specifying the first player's IP address and port: build/pong -C <ip_address> <port>.
    • The server controls the left paddle by default (WIP to allow the user to modify this), and the client controls the right paddle.

TODO

See todo.txt.