Skip to content

A puzzle game for 2 to 4 player. Written in portable C as an experiment: can a program with non-trivial algorithmic logic be compiled and run on an 8-bit platform? Answer: yes.

Notifications You must be signed in to change notification settings

cpcitor/color-flood-for-amstrad-cpc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Color Flood

By cpcitor

Coded in C + SDCC + cpc-dev-tool-chain

Build status Linux result
Full build: SDCC cross-compiler + binutils + tape/disk image tools + tape/disk images + audio file Build Status

Principle of the game

A puzzle game for 2 to 4 player.

  • Each player owns a colored domain.
  • At each move change your domain color and annex neighbours of target color.
  • When no more moves are possible, player with biggest area wins.

What makes the game somewhat interesting is that it's sometimes good to play not what is the best for you (sometimes nothing is really better than another) but playing what will slow down your opponent.

How to use

First screen

Use cursor keys to select your options :

  • grid size 12x12 16x16 or 24x24
  • which corners are occupied by an active player.

Intro screen

Game screen

  • The next player to play is shown with a cross in the corner.
  • Each player has their own 3 keys to choose the next color (top left player near keyboard top left, and so on).
  • Press up/down keys until you get your preferred color, then confirm.

At the bottom, progress bars allow to compare surface of each player (easier than trying to count squares).

Illustration: in game with 4 players.

In game with 4 players. In game with 4 players. In game with 4 players.

Illustration: older release, 4 players, 6 colors instead of 9.

Older release

Game end

The program shows the final area of each players. Sometimes there are draw games.

Illustration: 2 players end screen

2 players end screen

Illustration: 4 players end screen

4 players end screen

How to compile

  • Linux users will recognize the usual clone/configure/make workflow. Dependencies may already be there, or as simple to get as running this command line: sudo apt-get --no-install-recommends --assume-yes install git ca-certificates wget make patch gcc bzip2 unzip g++ texinfo bison flex libboost-dev libsdl1.2-dev pkgconf libfreetype6-dev libncurses-dev details.
  • Windows users have to fetch a Linux-like environment first. Details on How to install.

For a quick start, just copy-paste this!

git clone https://github.com/cpcitor/color-flood-for-amstrad-cpc
cd color-flood-for-amstrad-cpc

./configure_cdtc_build_tree.sh
# The configure script will automatically find a cpc-dev-tool-chain
# tree if CDTC_ROOT environment variable is set.
# Alternatively you can do:
# /path/to/your/cpc-dev-tool-chain/copy/configure_cdtc_build_tree.sh .

make    # on Linux, try "make run" it will even run the project on caprice32 emulator!
## While the project compiles, read on.

If you don't have all prerequisites you can install them and do make again.

This fetches dependencies (cross-compiler, tools, etc), builds then generates cf2.dsk that you can use in an emulator:

Options for compilation

More or less parallel compilation

cpc-dev-tool-chain features an automatic parallel build for the longest dependencies (sdcc, caprice32).

You can force more parallel builds manually when e.g. if your PC has e.g. 8 cores (or even 4 multi-threaded cores):

    make -j8

Beware, though, it consumes more memory, especially to compile SDCC. For example, 2GB is okay for make -j4.

On the contrary, you may limit memory consumption by disabling parallel builds:

    make NPROC=1

Generate audio file, others

Try different targets:

    make run    # Linux only at the moment: runs project in caprice32 emulator.
    make dsk    # Disk file for emulator, can be written to real floppies.
    make cdt    # Tape file for emulator, can be converted to audio.
    make wav    # Generate audio file (also voc au)

About

A puzzle game for 2 to 4 player. Written in portable C as an experiment: can a program with non-trivial algorithmic logic be compiled and run on an 8-bit platform? Answer: yes.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •