aboutsummaryrefslogtreecommitdiffstats
path: root/AoC2022/07/solver.el
blob: ab97c08a52411aca1c57bbb729e89bd855474cc0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
;;; solver.el --- Day 07 -*- lexical-binding: t; -*-
;;
;; Copyright (C) 2022 Óscar Nájera
;;
;; Author: Óscar Nájera <hi@oscarnajera.com>
;; Maintainer: Óscar Nájera <hi@oscarnajera.com>
;; Created: December 08, 2022
;; Modified: December 08, 2022
;; Version: 0.0.1
;; Keywords: abbrev bib c calendar comm convenience data docs emulations extensions faces files frames games hardware help hypermedia i18n internal languages lisp local maint mail matching mouse multimedia news outlines processes terminals tex tools unix vc wp
;; Homepage: https://github.com/titan/solver
;; Package-Requires: ((emacs "24.3"))
;;
;; This file is not part of GNU Emacs.
;;
;;; Commentary:
;;
;;  Day 07
;;
;;; Code:


(require 'cl-lib)

(with-temp-buffer
  (insert "$ cd /
$ ls
dir a
14848514 b.txt
8504156 c.dat
dir d
$ cd a
$ ls
dir e
29116 f
2557 g
62596 h.lst
$ cd e
$ ls
584 i
$ cd ..
$ cd ..
$ cd d
$ ls
4060174 j
8033020 d.log
5626152 d.ext
7214296 k")
  (let ((data (split-string (buffer-string) "\n")))
    (cl-labels ((scan ()
                      (cl-loop for item = (pop data)
                               while (and item (not (string= "$ cd .." item)))
                               when (parse item)
                               collect it))
                (parse (entry)
                       (pcase (split-string entry)
                         (`("$" "cd" ,dir) (cons dir (scan)))
                         (`("$" "ls") nil)
                         (`("dir" ,dir) nil)
                         (`(,size ,name) (cons name (string-to-number size))))))

      (scan)
      )))



(append '(5 6 8) (cons 5 8))
(provide 'solver)
;;; solver.el ends here