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 5fe24bffd9 Updated file paths 8 months ago
includes Moved serialization files into submodule 8 months ago
netpong-serialization@c0c7e14aa6 Moved submodule location 8 months ago
subprojects Moved submodule location 8 months ago
.gitignore Added .gitignore 10 months ago
.gitmodules Moved submodule location 8 months ago
README.md Updated README 8 months ago
ball.cpp Fixed misaligned bracket 10 months ago
check_input.cpp Minor changes 9 months ago
client.cpp Free memory allocated with malloc() 9 months ago
connect_code.cpp Removed testing code 10 months ago
create_release_mingw.sh Changed zip command, so that only one parent directory is included 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 Free memory allocated with malloc() 9 months ago
main.cpp Updated include path, and set the type if the game mode is M_SINGLE 8 months ago
meson.build Updated file paths 8 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 Renamed functions to make their purpose more explicit 9 months ago
server.cpp Free memory allocated with malloc() 9 months ago
sock.cpp Removed unnecessary comment 9 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. Clone the repository.

  3. Update all submodules:

    git submodule update --init --recursive
    
  4. Set up the build directory.

    meson setup build
    
  5. 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
    
  6. 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.