rockbox/apps/plugins/puzzles
Franklin Wei d64ff86fb6 puzzles: resync with upstream
This brings the source to upstream commit 506b073 (though I have made some
extra commits on top of that). Notably this includes a fix for a double-free
bug that I myself introduced upstream.

Change-Id: I02671586bbc34d63e05398ee971271fed42538cf
2018-06-20 19:13:03 -04:00
..
dummy add fake stdio.h 2017-04-30 19:13:13 -04:00
help puzzles: update help text, make generation and testing cleaner 2018-04-24 19:06:30 -04:00
src puzzles: resync with upstream 2018-06-20 19:13:03 -04:00
compress.c puzzles: silence some warnings 2018-04-24 19:06:30 -04:00
fonts.zip puzzles: dynamic text size via custom font pack 2017-07-17 16:58:13 -04:00
genhelp.sh puzzles: update help text, make generation and testing cleaner 2018-04-24 19:06:30 -04:00
help.h puzzles: update help text, make generation and testing cleaner 2018-04-24 19:06:30 -04:00
lz4tiny.c puzzles: update help text, make generation and testing cleaner 2018-04-24 19:06:30 -04:00
lz4tiny.h puzzles: compress extensive help text 2017-08-16 11:40:37 -04:00
puzzles.make puzzles: update frontend for new upstream, misc. changes 2018-04-24 19:06:30 -04:00
rbassert.h
rbcompat.h puzzles: resync with upstream 2018-06-20 19:13:03 -04:00
rbmalloc.c puzzles: resync with upstream; add Loopy and Palisade, mouse mode 2017-11-21 19:29:45 -05:00
rbwrappers.c puzzles: misc. changes and sync with upstream 2017-08-23 14:22:09 -04:00
README.rockbox puzzles: enable all the remaining games 2018-04-17 18:20:12 -04:00
rockbox.c puzzles: minor nitpicks to fbb6a2f 2018-06-12 12:11:06 -04:00
SOURCES puzzles: update frontend for new upstream, misc. changes 2018-04-24 19:06:30 -04:00
SOURCES.games puzzles: update frontend for new upstream, misc. changes 2018-04-24 19:06:30 -04:00

Introduction
============

This is the readme for the Rockbox port of Simon Tatham's Portable
Puzzle Collection.

The upstream version used is subject to change, as it should be
relatively trivial to update it to a newer version. Simply copying the
upstream repo's contents into src/ and running genhelp.sh ought to do
it (watch out for API changes, though!).

Source structure
================

Most of the upstream files in src/ are essentially untouched, apart
from some minor adjustments to make them compile and run happily on
Rockbox. The majority of the rockbox-specific code is found in
rockbox.c, with some minor stuff in rbwrappers.c and rbmalloc.c.

Help feature
============

The Help feature is implemented by compiling each puzzle against a
compressed version of each puzzle's section from the upstream
documentation. These files are stored under help/, and are generated
by genhelp.sh from the puzzles.but file in the source
distribution. The compression is LZ4, implemented in lz4tiny.c (for
decompression on target), and compress.c (for generation). genhelp.sh
should be run whenever the documentation is changed.

Kudos to Simon (duh), and Frank, for telling me about it.

Franklin Wei (__builtin)

Changelog
=========

April 2017: Changes made to move upstream sources to a separate
subdirectory, where they are completely unmodified from the
original. Updating the upstream version is now as simple as copying a
fresh set of sources to src/. Several hacks were used to accomplish
this: a global include specified on the command line, and a directory
of dummy header files.

August 2017: Every game that can be played with only the cursor keys
is now functional.

October 2017: Added zoom feature.

March 2018: Added help styling. Changed from simple_viewer to
display_text for displaying help text. compress.c now does additional
processing on the help text, and also requires a slightly modified
halibut.

April 2018: Finished up the rest of the games. All work now! Surely
there's still bugs to fix, so stay tuned...