summaryrefslogtreecommitdiff
path: root/FreeRTOS/Test/VeriFast/scripts/diff_files.md
blob: 59f62d3640675c484c3e23e587a97eec3d738510 (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
# Generate diffs between FreeRTOS source and proofs

## Requirements

  - python3
  - ctags 5.8
  - diff 3.4+
  - [diff2html](https://diff2html.xyz/)

## Instructions

The following will extract per-function files from the original FreeRTOS source
implementation and the proof directory.


```
cd scripts
./generate_diff_files.sh
# will extract to ./FreeRTOS-Kernel/generated and ./queue/generated
```

Then use `diff` for a side-by-side comparison.  Note that the `--color=always`
flag needs v3.4+:

```
diff --color=always --width=$COLUMNS --suppress-common-lines --side-by-side FreeRTOS-Kernel/generated queue/generated | less -r
```

Or generate a html report using `diff2html`:

```
diff -u FreeRTOS-Kernel/generated queue/generated | diff2html -i stdin
```

The expectation is that the proofs make minimal changes to the original source
implementation in the form of:

  - VeriFast annotations `/*@...@*/` and `//*...`
  - Additional comments explaining the proof `/*...*/`
  - Flagged changes within `#if[n]def VERIFAST`