2022-08-15 19:08:30 +02:00
|
|
|
crush
|
|
|
|
=====
|
2022-08-15 11:01:51 +02:00
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
**crush** - The uncomplicated LÖVE external module system.
|
|
|
|
|
|
|
|
**crush** is a minimalistic dependency-less package system for the LÖVE engine.
|
|
|
|
It provides a structured approach to retrieve external libraries for your game project.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
## Why?
|
|
|
|
|
|
|
|
Lua knows some excellent dependency management system,
|
2022-08-15 19:08:30 +02:00
|
|
|
like [LuaRocks](https://luarocks.org).
|
2022-08-16 12:33:30 +02:00
|
|
|
Though, they are inconvenient for a game project, where:
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
* External libraries should be packed along with the game for distribution.
|
2022-08-16 12:33:30 +02:00
|
|
|
* Libraries are often small, and their code should be readily hackable by developers (library versions are not tremendously important).
|
2022-08-15 19:08:30 +02:00
|
|
|
* Depending on a complex package manager is undesireable.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
LÖVE games have limited ways to manage external libraries:
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
1. Manually, directly copying external libraries in the game source tree.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
* Pulling latest changes in the library requires more copy-pasting.
|
|
|
|
* Harder to use libraries if they depend on other libraries themselves.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
2. Using a package manager during development, and carefully
|
|
|
|
pack external libraries with the game manually upon distribution.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
* Introduce additional step to distribution phase.
|
|
|
|
* Many existing LÖVE libraries have no package manager support.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
**crush** provides an alternative approach, offering the following features:
|
|
|
|
|
|
|
|
* Fetch external libraries directly from their source code repository,
|
|
|
|
ensuring the ability to pull, or even push, the latest changes from your project.
|
|
|
|
* Automatically pack external libraries inside the project source tree, inside a well-known `lib` folder.
|
|
|
|
* Resolves dependencies recursively, making possible for libraries that depend on other libraries, saving the
|
|
|
|
developer all the manual dependency tracking.
|
|
|
|
* Works automatically with most existing LÖVE libraries, since it directly uses `git` to clone their sources.
|
|
|
|
* Does not require any complex package manager or native code, just a single Lua source file.
|
|
|
|
* Does not require any centralized package repository to publish or fetch libraries.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
## How to use it?
|
|
|
|
|
|
|
|
To use **crush** follow these steps:
|
|
|
|
|
|
|
|
1. Copy the latest `crush.lua` into your project's root folder.
|
2022-08-15 19:08:30 +02:00
|
|
|
2. Create a `.lovedeps` file in the same directory, here you will list every dependency (more in the next section).
|
2022-08-16 12:33:30 +02:00
|
|
|
3. Once you have `crush.lua` and `.lovedeps` in place, you can populate or refresh project dependencies by running:
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
```sh
|
|
|
|
lua crush.lua
|
|
|
|
```
|
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
**crush** fetches the project's dependencies recursively, cloning them inside a `lib` subdirectory.
|
|
|
|
Hence, you may use them comfortably in your code with the usual `require()`, like this:
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
```lua
|
|
|
|
local serialize = require 'lib.serialize'
|
|
|
|
```
|
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
**crush** flattens every dependency in the `lib` folder.
|
|
|
|
This implies that libraries common to different packages must be named and accessed consistently in the source code.
|
2022-08-15 19:08:30 +02:00
|
|
|
A reasonable limitation given **crush** use-case.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
## The .lovedeps file
|
|
|
|
|
|
|
|
The `.lovedeps` file is a regular Lua text file, containing a table where every entry specifies a dependency:
|
|
|
|
|
|
|
|
```lua
|
2022-08-15 19:20:48 +02:00
|
|
|
['dependency-name'] = "git-url"
|
2022-08-15 18:54:20 +02:00
|
|
|
```
|
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
The following example shows a `.lovedeps` file depending on three external libraries,
|
|
|
|
named `df-serialize`, `gear` and `yui`, every dependency has a corresponding `git` repository URL.
|
|
|
|
There dependency name is not required to match the actual repository name, but names **should** be consistent
|
|
|
|
within the entire project, otherwise the same repository may be cloned several times under different names.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
```lua
|
|
|
|
{
|
2023-11-01 17:31:47 +01:00
|
|
|
-- Fetch lib/df-serialize from https://codeberg.org/1414codeforge/df-serialize
|
2022-08-15 19:27:56 +02:00
|
|
|
-- needs ['quote'] syntax due to '-'
|
2023-11-01 17:31:47 +01:00
|
|
|
['df-serialize'] = "https://codeberg.org/1414codeforge/df-serialize",
|
2022-08-15 19:27:56 +02:00
|
|
|
|
2023-11-01 17:31:47 +01:00
|
|
|
-- Fetch lib/gear from https://codeberg.org/1414codeforge/gear
|
|
|
|
gear = "https://codeberg.org/1414codeforge/gear",
|
2022-08-15 19:27:56 +02:00
|
|
|
|
2023-11-01 17:31:47 +01:00
|
|
|
-- Fetch lib/yui from https://codeberg.org/1414codeforge/yui
|
|
|
|
yui = "https://codeberg.org/1414codeforge/yui"
|
2022-08-15 19:27:56 +02:00
|
|
|
|
|
|
|
-- NOTE: Any dependency may also pull additional subdependencies,
|
|
|
|
-- these will also be cloned within lib/
|
2022-08-15 18:54:20 +02:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
## Philosophy
|
|
|
|
|
2022-08-16 12:33:30 +02:00
|
|
|
**crush** is somehow opinionated and tied to its intended use-case.
|
|
|
|
It obeys the following rules:
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
`MUST`:
|
|
|
|
|
2022-08-15 19:27:56 +02:00
|
|
|
* Be self-contained, only a single Lua file: `crush.lua`.
|
2022-08-15 18:54:20 +02:00
|
|
|
* Must only depend on Lua, LÖVE and `git`, expected to be available on any LÖVE developer machine.
|
|
|
|
* Do one thing: fetch the dependencies listed in the `.lovedeps` file.
|
|
|
|
* Be simple and predictable, integrating **crush** into a LÖVE game must be as intuitive as possible.
|
|
|
|
* Be hackable, its code must be reasonably trivial, understandable and adaptable.
|
|
|
|
* Enforce one way to do things, encouraging consistency.
|
|
|
|
|
|
|
|
`MUST NOT`:
|
|
|
|
|
|
|
|
* Give in to feature creep.
|
2022-08-15 19:10:28 +02:00
|
|
|
* Provide a centralized repository.
|
2022-08-15 18:54:20 +02:00
|
|
|
* Be completely general, its scope is limited to the average LÖVE game or library.
|
|
|
|
* Be entirely safe, there is no demand for checksum or strict versioning in **crush** use case.
|
|
|
|
|
|
|
|
`SHOULD NOT`:
|
|
|
|
|
|
|
|
* Break compatibility with older `.lovedeps` files.
|
|
|
|
|
|
|
|
|
2022-08-15 19:08:30 +02:00
|
|
|
If this does not meet your requirements, code should still be sufficiently hackable to
|
|
|
|
provide some room for customization.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
## Similar projects
|
|
|
|
|
2022-08-16 12:35:59 +02:00
|
|
|
* [LÖVERocks](https://github.com/Alloyed/loverocks) is a more involved project aiming to bring LuaRocks features to LÖVE.
|
2022-08-15 18:54:20 +02:00
|
|
|
|
|
|
|
## License
|
|
|
|
|
2022-08-16 12:35:09 +02:00
|
|
|
MIT, see [LICENSE](LICENSE) for details.
|