48 Commits

Author SHA1 Message Date
George Thomas
23e82c069f Make test names more opaque by removing instances 2026-01-08 01:38:57 +00:00
George Thomas
b80743c840 Indent test failures 2026-01-07 01:11:45 +00:00
George Thomas
f98a4c29d2 Switch timings to blue
Black can look pretty bad on some consoles, including GNOME's.
2026-01-07 01:02:31 +00:00
George Thomas
aefb7f067f Use Unicode for tree drawing 2026-01-07 00:55:46 +00:00
George Thomas
fb2d412f95 Simplify test name handling
We keep the internal type safety, while making things easier for users.
2026-01-07 00:55:07 +00:00
George Thomas
f634b9b42d Use Text for test names 2026-01-07 00:43:51 +00:00
George Thomas
3721c27c32 Use custom monad for more principled test failure handling 2026-01-07 00:39:35 +00:00
George Thomas
39714ff1c3 Rename some type parameters 2026-01-06 23:36:10 +00:00
George Thomas
98acc016a6 Justify test time to right of terminal 2026-01-06 23:15:41 +00:00
George Thomas
2eecc653b8 Remove colours from test times
The implementation is slightly awkward, and will be much more so when we'll want to count characters for nicer terminal layout. It's maybe not the best UX anyway. We'll think about alternatives.
2026-01-06 23:15:39 +00:00
George Thomas
fc623d0ea6 Add proper test display function 2026-01-06 23:15:37 +00:00
George Thomas
d18166951b Add mwhen 2026-01-06 23:15:36 +00:00
George Thomas
41f0b8d511 Move some utilities out of Day4.hs 2026-01-06 23:15:03 +00:00
George Thomas
99de1c4d40 Add pretty-simple to prelude 2026-01-06 23:15:03 +00:00
George Thomas
9246597b49 Render ASCII drawing of test tree 2026-01-06 23:14:56 +00:00
George Thomas
db41a65453 Avoid forcing puzzle parts outputs
Note that:
- This allows us to remove some very temporary hacky code from day 4.
- This includes a refactoring to hide `TestTree`, which could in theory have been made separate.
- This reverts a lot of 1163889.
2026-01-06 23:14:36 +00:00
George Thomas
f213cdb6c3 Minor refactor 2026-01-06 23:14:25 +00:00
George Thomas
cd292d4580 Define withConstrained 2026-01-06 23:14:17 +00:00
George Thomas
83e4489e1f Add timing information to tests
Most of this is concerned with propagating `NFData` constraints.
2026-01-06 23:13:58 +00:00
George Thomas
c1813b4725 Use safe indices for test part lookup 2026-01-05 18:31:34 +00:00
George Thomas
24a21e3807 Remove heterogenous list length function 2026-01-05 17:00:21 +00:00
George Thomas
c3e69cde09 Move to custom test library 2026-01-05 17:00:15 +00:00
George Thomas
234640fb1a Add non-parameterised version of HList fold 2026-01-04 02:58:50 +00:00
George Thomas
2180af71ad Reformat 2026-01-04 02:58:50 +00:00
George Thomas
c4b85eac71 Inline some functions and simplify 2026-01-04 02:58:45 +00:00
George Thomas
8e6179f103 Implement all HList functions in terms of single fold 2026-01-04 02:39:33 +00:00
George Thomas
784e6f2fb2 Generalise puzzle parts type 2026-01-04 02:14:35 +00:00
George Thomas
8442ce8dba Generalise test monoid instance 2026-01-01 13:24:49 +00:00
George Thomas
f7c9297a85 Reuse expensive computation for day 4 extra tests
Ideally we'd similarly add the ability for later tests to use the results of earlier ones. But this would probably require much heavier type family usage.
2025-12-31 01:49:16 +00:00
George Thomas
450d7e5240 Port from Tasty to Sydtest
There are some drawbacks:
- No properly lazy golden tests. This would in principle be nice when e.g. using `pretty-simple`.
- Because tests can be created dynamically, they can't be listed up front without running them. This presumably makes filtering slightly more annoying to use in practice.
- Terminal output is less compact than tasty, both horizontally and vertically. There appears to be no way to change this.
- We end up defining an orphan `Monoid (TestDefM '[] () ())` instance, to avoid changing much downstream code. Note though that this is not strictly necessary, and could potentially be contributed upstream.
- There's a warning about threads in GHCI which we can't seem to disable.
- The license forbids use in commercial projects without sponsoring. Thankfully that doesn't apply here.

Anyway, it's generally very impressive. It simplifies a few things for us, and will particularly help when we come to want to specify dependencies between tests.
2025-12-31 01:49:07 +00:00
George Thomas
415055dcc2 Allow output types to vary for different parts of same day
For now this applies to Haskell only, and it may turn out to be tricky for the Rust implementation.

In practice, the limitation hasn't turned out to be important, and we could even go the other way and use `Integer` everywhere. This does however at least help with debugging, as well as just being conceptually right.

The `nil` and `(/\)` functions are intended to be overloaded to work for other list-like things in a later commit, and from there we will investigate using `OverloadedLists` and `RebindableSyntax` to recover standard list syntax, although there are probably limitations due to `(:)` being special.
2025-12-16 16:15:11 +00:00
George Thomas
6ca7b4eac8 Match digitsToInt to simpler Rust version 2025-12-13 11:24:46 +00:00
George Thomas
cdc54a27aa Solve day 10 part 1 2025-12-11 11:34:36 +00:00
George Thomas
57c1613019 Move output showing to main entry point 2025-12-09 16:57:05 +00:00
George Thomas
6e851d63f0 Show diff for golden test failures 2025-12-09 16:47:12 +00:00
George Thomas
2862457529 Solve day 9 part 2 2025-12-09 13:37:39 +00:00
George Thomas
e85429629f Generalise allUnorderedPairs
Now that it's in the prelude, the desire to remove diagonals is less obvious than it was.
2025-12-09 13:35:54 +00:00
George Thomas
c608e21e26 Solve day 9 part 1 2025-12-09 13:35:54 +00:00
George Thomas
02fbb8c0be Minor refactor 2025-12-09 00:26:22 +00:00
George Thomas
1e3ed16971 Avoid unsafe list indexing 2025-12-09 00:02:54 +00:00
George Thomas
832b85fb7b Solve day 8 part 2 2025-12-08 23:38:48 +00:00
George Thomas
e92cc2f0d3 Minor refactors 2025-12-08 22:59:50 +00:00
George Thomas
d0488726a0 Add argument to parser for disambiguating real data versus examples
This breaks less code than adding it to the solution functions, and is more elegant in a way.
2025-12-08 22:59:50 +00:00
George Thomas
43918c70fa Solve day 8 part 2 2025-12-08 22:59:50 +00:00
George Thomas
b0a191edb9 Solve day 8 part 1 2025-12-08 22:59:50 +00:00
George Thomas
f6f0fc171f Solve day 7 part 1 2025-12-08 22:59:50 +00:00
George Thomas
5539a4bd05 Solve day 6 part 1 2025-12-08 22:59:35 +00:00
George Thomas
371bddf748 Use custom prelude 2025-12-08 12:48:49 +00:00