Intricacy - Le Bottin des Jeux Linux

Intricacy

🗃️ Specifications

📰 Title: Intricacy 🕹️ / 🛠️ Type: Game
🗃️ Genre: Puzzle 🚦 Status: 05. Tested & Working (status)
🏷️ Category: Puzzle ➤ Transport ➤ Misc. 🌍️ Browser version:
🔖 Tags: Puzzle; Transport; Difficult; PvP; PvE; Competitive; Level Editor; Flagship 📦️ Package Name:
🐣️ Approx. start: 2014-01-19 📦️ Arch package:
🐓️ Latest: 2019-01-20 📦️ RPM package:
📍️ Version: Latest: 0.7.2 📦️ Deb package:
🏛️ License type: 🕊️ Libre 📦️ Flatpak package:
🏛️ License: GPL-3 📦️ AppImage package:
🏝️ Perspective: Top-down 📦️ Snap package:
👁️ Visual: 2D Top-Down ⚙️ Generic binary: ✓
⏱️ Pacing: Turn-Based 📄️ Source: ✓
👫️ Played: Single & Multi 📱️ PDA support:
🎖️ This record: 5 stars 🕳️ Not used:
🎀️ Game design: 5 stars 👫️ Contrib.: goupildb & Louis
🎰️ ID: 14721 🐛️ Created: 2015-04-26
🐜️ Updated: 2021-12-20

📖️ Summary

[en]: A libre, multi-platform, turn-based, solo/multi (competitive), abstract puzzle game in which the player tries to thwart a complex mechanism (possibly designed by another player if playing in MP) presented to him. Once he has thwarted the protection of this lock, he will have to secure this secret behind a lock of his own design. An editor integrated in the interface allows to elaborate new puzzles (especially for the multiplayer mode). [fr]: Un puzzle abstrait solo/multi (en compétition) libre et multi-plateforme au tour par tour, dans lequel le joueur tente de déjouer un mécanisme complexe (conçu éventuellement par un autre joueur s'il joue en multi) qui lui est présenté. Une fois qu'il a déjoué la protection de cette serrure, il devra sécuriser ce secret derrière un verrouillage de sa propre conception. Un éditeur intégré à l'interface permet d'élaborer de nouveaux puzzles (notamment pour le mode multi).

🎥️ Videos


🦉️ From Devs: (202xxx),

🕸️ Links

🏡️ Website & videos
[Homepage] [Dev site] [Features/About] [Screenshots] [Videos t(202xxx) gd(202xxx) gu(202xxx) r(202xxx) lp(202xxx) g(202xxx) g[fr](202xxx) g[de](202xxx) g[ru](202xxx) g[pl](202xxx) g[cz](202xxx) g[sp](202xxx) g[pt](202xxx) g[it](202xxx) g[tr](202xxx) g(202xxx)] [WIKI] [FAQ] [RSS] [Changelog 1 2 3]

💰 Commercial: (empty)

🍩️ Resources
(empty, license): [Homepage] [Dev site] 🎬️ g(202xxx)

🛠️ Technical informations
[PCGamingWiki] [MobyGames]

🦣️ Social
Devs (Martin Bays [fr] [en]): [Site 1 2] [Chat] [mastodon] [PeerTube] [YouTube] [PressKit] [Interview 1(202xxx) 2(202xxx)]
The Project: [Blog] [Forums] [mastodon] [PeerTube] [YouTube] [PressKit] [reddit] [Discord]

🐝️ Related


📦️ Misc. repositories
[Repology] [pkgs.org] [Generic binary] [Arch Linux / AUR] [openSUSE] [Debian/Ubuntu] [Flatpak] [AppImage(author's repo)] [Snap] [PortableLinuxGames]

🕵️ Reviews
[HowLongToBeat] [metacritic] [OpenCritic] [iGDB]

📰 News / Source of this Entry (SotE) / News (SotN)
[Changes with v. 0.7.2 (20190120)]

🕊️ Source of this Entry: [Site (date)]

🦣️ Social Networking Update (on mastodon)

🕹️ Title:
🦊️ What's:
🏡️
🐣️
🔖 #Flagship
📦️
📖 Our entry: https://www.lebottindesjeuxlinux.tuxfamily.org/en/online/lights-on/

🥁️ Update:
⚗️
📌️ Changes:
🦣️ From: 📶️

🏝️ https://www.youtube.com/embed/
🦉️ https://www.youtube.com/embed/
🦝️ https://www.youtube.com/embed/
🦝️ https://www.youtube.com/embed/
🕵️ https://www.youtube.com/embed/
🕯️ https://www.youtube.com/embed/
🕯️ https://www.youtube.com/embed/
🎲️ https://www.youtube.com/embed/
🎲️ https://www.youtube.com/embed/
🎲️ https://www.youtube.com/embed/
🎲️[fr] https://www.youtube.com/embed/
🎮️ https://www.youtube.com/embed/
🎮️ https://www.youtube.com/embed/
🐧 https://www.youtube.com/embed/
🐧 https://www.youtube.com/embed/

📕 Description [en]

📕🐧"A libre abstract puzzle game in which the player tries to thwart a complex mechanism"🐧📕.

A game of competitive puzzle-design.

By ruthlessly guarded secret arrangement, the council's agents can pick any lock in the city. A secret guild produces the necessary locks - apparently secure, but with fatal hidden flaws. A ritual game is played to determine the best designs; to master it, you must build locks which can be picked only by one who knows the secret, and you must discover the secret flaws in the locks designed by your colleagues.

Coordinate a pair of tools to pick locks devised by other players in a mechanistic turn-based puzzle game; construct intricate locks of your own to protect the secrets you discover.

Free software, released under the GPLv3.

Written in Haskell, with SDL and Curses user interfaces.


README

Rough description of the game mechanics
=======================================
• Locks consist of blocks, pivots and balls. Blocks can be connected to other blocks by springs. Pivots have arms. When picking a lock, you control two tools - a hook, which acts as a mobile one-armed pivot, and a wrench, which acts as a mobile block with momentum.
• To open a lock, the "bolthole" (the area in the top-right) must be empty.
• Each turn, the tools push and rotate according to the player's commands, and then each spring which is compressed or extended beyond its natural length pushes/pulls on the block at its end.
• If two forces try to move a piece in two different directions, or try to move two pieces into the same hex, one or both is blocked.
• If a pivot/hook is trying to turn and there's a piece in the way of one of its arms, it will at first try to push the piece away - but if that force is blocked, it will try instead to pull the piece round with the arm as it turns.
• If two springs are trying to push two blocks into the same hex, they will generally both be blocked. However, if one of the forces is also pushing against a fixed piece such as a tool, it won't block the other force.

Full details of the metagame mechanics
======================================
(Where by the 'game' I mean the lock-picking bit, and by the 'metagame' I mean the bit with the 3-letter codenames and the three lock slots and notes and so on.)

Scoring is always relative - each player has a score relative to each other player. That score is the number of the second player's lock slots to which the first player has access, minus the number of the first player's lock slots to which the second player has access.

A player accesses a lock slot when one of the following holds :
• the player has solved the lock in the slot, and declared the solution;
• the player has read three notes on the lock in the slot;
• there's no lock in the slot, and the player has accessed all the slots which do have locks in them.

A player reads every note in every lock the player accesses. When a lock is replaced ('retired'), each note secured by the lock becomes 'public', and is read by every player.

Note this means that once three notes on a lock become public, every player accesses the lock. The lock is then 'public' (and its owner should replace it!).

To declare a solution, you must secure a note on it behind a non-public lock in one of your three lock slots. Once the note is placed, it can't be moved.


Full details of the game mechanics
==================================
Springs are directed; one of the blocks it is connected to is the 'root', the other the 'end'. A block is stationary if it is not the end of any spring. The directed graph whose nodes are the blocks and whose edges are the springs is required to be acyclic. A spring may also be rooted in a pivot.

I will now attempt to describe in full excruciating detail the game physics, i.e. the algorithm used to determine what happens on a turn. You shouldn't need to read this to play the game! Experimenting and turning on blockage annotations should be enough.

The following description corresponds to the code in Physics.hs. The algorithm is the result of an extended process of experiment and iterated simplification; see notes/game in the source distribution if you're perverse enough to want to read a scattered stream-of-consciousness account of the process.

Each turn is separated into two phases. In the first phase, the forces arising from the player's move are 'resolved', possibly resulting in some movement. In the second phase, forces arising from stretched or compressed springs are resolved, possibly resulting in some movement.

Here we abuse physics terminology, and use the term 'force' to refer to either a directional force in the usual sense, which we call a 'push', or a rotational force, which we call a 'torque'. A force is always on a piece, in some direction. Only the obvious six hex directions and the two obvious rotational directions occur; the magnitude is always 1.

Player moves result in forces on the tools in the obvious way. A wrench which is moving gets a push in that direction each turn (sorry, Newton!). A spring which is not at its relaxed length results in a push on the end piece.

To _resolve_ these initial forces:
• each initial force is 'propagated to a force group'
• if a group is 'inconsistent' with another group: if one of the group is 'dominated' by the other, it is 'blocked'; else both are blocked
• each force in each unblocked force group is 'applied'

To _apply_ a push: move the piece in the given direction.
To _apply_ a torque: rotate the piece in the given direction.

To _propagate_ a force:
• If applying the force would result in an overlap with another piece, push that piece - but if it's an arm, twist the pivot instead when that makes sense.
• If the force is a torque and an arm is pushing on another piece, we have a special rule: if the obvious push ends up propagating to a resisted force (see below), then it is replaced with a 'clawing' push. e.g. in the following situation:
\ O #
o
if the pivot is twisted clockwise, the ball will first be pushed east, but when that force propagates to a push on the stationary block to its east which is resisted, processing will back up and a push on the ball southeast will be tried instead.
• A spring connecting two blocks transmits a push on one block to the other unless the direction is such that the push is tending to compress/extend the spring and the spring isn't already fully compressed/extended.

A force is _resisted_ if it is a push on a pivot or on a block which isn't the end of a spring, or it's a torque on a block, or it's a force on a hook which isn't already getting that force this phase as the result of a player move, or it's a force on a wrench which isn't a push in the direction it's already moving.

To _propagate an initial force to a force group_:
• Propagate the force as above, then recursively propagate the resulting forces, checking for resistance as we go. The force group consists of all the resulting propagated forces.
• On resistance: back up to try clawing as described above if appropriate, else consider the whole force group resisted - so the resulting force group is empty.

Two forces are _inconsistent_ when
• they act on the same piece in different directions, or
• applying both at once results in overlapping pieces.

Two force groups are _inconsistent_ iff there is some force from the first which is inconsistent with some force from the second.

A force group _dominates_ another iff their initial forces are spring forces, and the root of the first spring is an ancestor of the root of the second spring, where an ancestor of a block B is recursively defined to be a block which is the root of a spring which ends at B, or an ancestor of such a block.

-- mbays@sdf.org 2013

📕 Description [fr]

Un puzzle abstrait solo/multi en compétition et au tour par tour, par Martin Bays (mbays).
En Haskell.

Intricacy est un puzzle abstrait solo/multi (en compétition) libre et multi-plateforme au tour par tour, dans lequel le joueur tente de déjouer un mécanisme complexe (conçu éventuellement par un autre joueur s'il joue en multi) qui lui est présenté. Une fois qu'il a déjoué la protection de cette serrure, il devra sécuriser ce secret derrière un verrouillage de sa propre conception. Un éditeur intégré à l'interface permet d'élaborer de nouveaux puzzles (notamment pour le mode multi).

Gameplay :
Le joueur dispose de 2 outils (un petit et un gros) en bas à gauche de l'interface (grise), qu'il peut déplacer de case en case (cases hexagonales).
A l'aide d'un outil il déplace un mécanisme comprimé par un ressort, permettant éventuellement de libérer la place pour en glisser un autre un peu plus loin, le but étant de parvenir à libérer une gâchette en haut à droite de l'interface. Plusieurs types de mécanismes viennent complexifier l'ensemble.


Un jeu de puzzle-conception compétitif.

Grâce à un arrangement secret impitoyablement gardé, les agents du conseil municipal peuvent crocheter n'importe quelle serrure de la ville. Une guilde secrète produit les serrures nécessaires - apparemment sûres, mais avec des défauts cachés fatals. Un jeu rituel est joué pour déterminer les meilleurs modèles ; pour le maîtriser, vous devez construire des serrures qui ne peuvent être crochetées que par une personne connaissant le secret, et vous devez découvrir les défauts secrets des serrures conçues par vos collègues.

Coordonnez une paire d'outils pour crocheter les serrures conçues par d'autres joueurs dans un jeu mécanique de puzzle au tour par tour ; construisez vos propres serrures complexes pour protéger les secrets que vous découvrez.

Logiciel libre, publié sous licence GPLv3.

Écrit en Haskell, avec des interfaces utilisateur SDL et Curses.

🕵️ Test [fr]

🕵️ Test (du binaire en version 0.4.1) par goupildb :
(testé 10 min)
Le jeu est fonctionnel, avec une belle interface.
Pas évident à maîtriser.
J'étais plutôt sceptique avant d'essayer le jeu (la page du site semblant ancienne je me demandais s'il allait fonctionner, et donc l'entrer dans le Bottin), mais il m'est rapidement apparu intéressant et même addictif.

Très très bien. Bravo et merci à son auteur !