A network-based Pong game, written in C++.
 
 
 
 
Go to file
Aadhavan Srinivasan fc59a7221b Removed unnecessary #include
includes Integrated upstream changes, since I forgot to pull before making local changes.
subprojects Added raylib submodule, under subprojects directory
.gitignore Added .gitignore
.gitmodules Added raylib submodule, under subprojects directory
README.md Updated README
ball.cpp Fixed misaligned bracket
check_input.cpp Updated Server and Client constructor calls
client.cpp Removed unnecessary #include
connect_code.cpp Removed testing code
create_release_mingw.sh Added bash flag to fail if any command in the script fails
create_static_linux.sh Finished script to create and package statically linked binary on Linux
easysock.c Converted easysock from CPP to C, because it was mostly just C code anyways
main.cpp Removed IP version checking code (since this is handled in the Sock constructor), and allowed server (but not client, yet) to quit game before round start
meson.build Added C++ standard as a compiler flag, which is apparently needed by compilers on macOS
numeric_base.cpp Updated comment explaining function
paddle.cpp Created method to set position of paddle
raygui_helpers.cpp Moved display_text_centered() into a separate file, since I could possibly extend this file with other raygui helper functions
serialization.c Updated UNIX macro checks, to account for MacOS
server.cpp Removed unnecessary #include
sock.cpp Removed unnecessary #include
timer.c Split timer into header and implementation file
todo.txt Updated TODO

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.