about summary refs log tree commit diff stats
path: root/README.org
blob: 4c1521385a3e0a83362659b62e71a3e2dd7bcc5c (plain) (blame)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#+title: Lacerta
#+subtitle: Lacerta parses WhatsApp exported logs
#+export_file_name: index
#+setupfile: ~/.emacs.d/org-templates/projects.org

| Website         | https://andinus.nand.sh/lacerta             |
| Source          | https://git.tilde.institute/andinus/lacerta |
| GitHub (mirror) | https://github.com/andinus/lacerta          |

* Demo

This is an example output on randomly generated data.

#+begin_src
andinus@ > lacerta exported
(   ●  )
Parsed 28000 logs in 5.00s
[=== ]
Generated data in 6.00s

*---------*----------*-------*---------*-------*------------*------*
| Name    | Messages | Words | Deleted | Media | ActiveHour | Left |
*---------*----------*-------*---------*-------*------------*------*
| User #1 | 9600     | 20000 | 500     | 900   | 22         | 10   |
| User #2 | 6000     | 18000 | 200     | 900   | 22         | 20   |
| User #3 | 12000    | 40000 | 300     | 1000  | 22         | 0    |
--------------------------------------------------------------------
*---------*------------*
| Name    | FucksGiven |
*---------*------------*
| User #1 | 1          |
| User #2 | 1          |
| User #3 | 10         |
------------------------
*---------*---------------*---------------*---------------*
| Name    | MostSpoken-#1 | #2            | #3            |
*---------*---------------*---------------*---------------*
| User #1 | word (90)     | then (20)     | have (20)     |
| User #2 | word (100)    | then (300)    | have (30)     |
| User #3 | word (1000)   | deleted (200) | deleted (200) |
-----------------------------------------------------------
#+end_src

* Installation

Lacerta is released to ~fez~, you can get it from there or install it from
source. In any case, ~zef~ is required to install the distribution.

You can run Lacerta without ~zef~. Just run ~raku -Ilib bin/lacerta~ from
within the source directory.

** Release

1. Run ~zef install lacerta~.

Lacerta should be installed, try running ~lacerta --version~ to confirm.

** From Source

You can either download the release archive generated by cgit/GitHub or
clone the project if you have ~git~ installed.

*** Without ~git~

1. Download the release:
   - https://git.tilde.institute/andinus/lacerta
   - https://github.com/andinus/lacerta/releases
2. Extract the file.
3. Run ~zef install .~ in source directory.

*** With ~git~

All commits will be signed by my [[https://andinus.nand.sh/static/D9AE4AEEE1F1B3598E81D9DFB67D55D482A799FD.asc][PGP Key]].

#+begin_src sh
# Clone the project.
git clone https://git.tilde.institute/andinus/lacerta
cd lacerta

# Install lacerta.
zef install .
#+end_src

* Documentation

** Implementation

It reads the log line by line and tries to match it with ~WhatsApp~
grammar.

** Options

*** input

Exported WhatsApp log.

*** profile-name

Your WhatsApp profile name. This is required to get stats for /Left/ and
/Deleted/ column.

*** no-of-spoken

This sets the number of Most Spoken columns to be printed for each user.
The default is 3.

** Caveats

/Words/ count can be less than the actual count. If the message contains
new lines then they have them in the log too. We read the log line by
line, so it'll miss parts of messages with newline in them.

* News

** v0.1.1 - 2021-08-14

+ Add option for number of Most Spoken columns.

** v0.1.0 - 2021-07-29

Initial Implementation.