mirror of
				https://source.quilibrium.com/quilibrium/ceremonyclient.git
				synced 2025-11-04 15:27:27 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			1898 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			1898 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
define
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#1,1:b
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:c
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=0
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=1
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:c
 | 
						|
a#1,1:b
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.DEL.2:
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
a#1,1:b
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true snapshots=1
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.DEL.2:
 | 
						|
a.SET.1:b
 | 
						|
b.SET.3:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
b#3,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=1
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
b#3,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
a#1,1:b
 | 
						|
b#3,1:c
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.1:a
 | 
						|
b.SET.2:b
 | 
						|
c.SET.3:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#1,1:a
 | 
						|
b#2,1:b
 | 
						|
c#3,1:c
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.3:d
 | 
						|
a.MERGE.2:c
 | 
						|
a.SET.1:b
 | 
						|
b.MERGE.2:b
 | 
						|
b.MERGE.1:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,1:bcd[base]
 | 
						|
b#2,2:ab
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3 print-snapshot-pinned print-force-obsolete
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,2:d (not pinned) (not force obsolete)
 | 
						|
a#2,1:bc[base] (pinned) (not force obsolete)
 | 
						|
b#2,2:ab (not pinned) (not force obsolete)
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.9:b
 | 
						|
a.DEL.8:
 | 
						|
a.SET.7:d
 | 
						|
a.DEL.6:
 | 
						|
a.SET.5:f
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=6
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,18:b
 | 
						|
a#5,1:f
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=7
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,18:b
 | 
						|
a#6,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=8
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,18:b
 | 
						|
a#7,18:d
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=9
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,1:b
 | 
						|
a#8,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=10
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=(5,6,7,8,9)
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,1:b
 | 
						|
a#8,0:
 | 
						|
a#7,1:d
 | 
						|
a#6,0:
 | 
						|
a#5,1:f
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.INVALID.2:b
 | 
						|
a.SET.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
----
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:b
 | 
						|
a.INVALID.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,18:b
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.2:b
 | 
						|
a.INVALID.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,2:b
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
 | 
						|
define
 | 
						|
a.INVALID.2:c
 | 
						|
a.RANGEDEL.1:d
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
tombstones
 | 
						|
----
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.2:b
 | 
						|
a.MERGE.1:c
 | 
						|
a.MERGE.0:d
 | 
						|
----
 | 
						|
 | 
						|
iter snapshots=(1,2) print-snapshot-pinned print-force-obsolete
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,2:b (not pinned) (not force obsolete)
 | 
						|
a#1,2:c (pinned) (not force obsolete)
 | 
						|
a#0,2:d (pinned) (not force obsolete)
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:b
 | 
						|
a.RANGEDEL.1:c
 | 
						|
b.RANGEDEL.4:d
 | 
						|
b.SET.2:e
 | 
						|
c.SET.3:f
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,18:b
 | 
						|
a#1,15:c
 | 
						|
b#4,15:d
 | 
						|
.
 | 
						|
a-b#1
 | 
						|
b-c#4
 | 
						|
c-d#4
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,1:b
 | 
						|
a#1,15:c
 | 
						|
b#4,15:d
 | 
						|
.
 | 
						|
a-b#1
 | 
						|
b-c#4
 | 
						|
b-c#1
 | 
						|
c-d#4
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3 print-snapshot-pinned print-force-obsolete
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,18:b (not pinned) (not force obsolete)
 | 
						|
a#1,15:c (not pinned) (not force obsolete)
 | 
						|
b#4,15:d (not pinned) (not force obsolete)
 | 
						|
b#2,1:e (pinned) (force obsolete)
 | 
						|
.
 | 
						|
a-b#1
 | 
						|
b-c#4
 | 
						|
b-c#1
 | 
						|
c-d#4
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=4 print-snapshot-pinned print-force-obsolete
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,18:b (not pinned) (not force obsolete)
 | 
						|
a#1,15:c (not pinned) (not force obsolete)
 | 
						|
b#4,15:d (not pinned) (not force obsolete)
 | 
						|
b#2,1:e (pinned) (force obsolete)
 | 
						|
c#3,1:f (pinned) (force obsolete)
 | 
						|
.
 | 
						|
a-b#1
 | 
						|
b-c#4
 | 
						|
b-c#1
 | 
						|
c-d#4
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:e
 | 
						|
b.SET.4:b
 | 
						|
c.SET.3:c
 | 
						|
d.SET.2:d
 | 
						|
e.SET.1:e
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:e
 | 
						|
b#4,1:b
 | 
						|
c#3,1:c
 | 
						|
e#1,1:e
 | 
						|
.
 | 
						|
a-e#3
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:e
 | 
						|
b.MERGE.4:b
 | 
						|
c.MERGE.3:c
 | 
						|
d.MERGE.2:d
 | 
						|
e.MERGE.1:e
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:e
 | 
						|
b#4,2:b
 | 
						|
c#3,2:c
 | 
						|
e#1,2:e
 | 
						|
.
 | 
						|
a-e#3
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:c
 | 
						|
b.MERGE.5:e
 | 
						|
b.MERGE.4:d
 | 
						|
b.MERGE.2:c
 | 
						|
b.MERGE.1:b
 | 
						|
d.MERGE.5:c
 | 
						|
d.MERGE.4:b
 | 
						|
d.RANGEDEL.3:f
 | 
						|
d.MERGE.2:e
 | 
						|
d.MERGE.1:d
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#5,1:de[base]
 | 
						|
d#5,2:bc
 | 
						|
d#3,15:f
 | 
						|
.
 | 
						|
a-c#3
 | 
						|
d-f#3
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:d
 | 
						|
b.RANGEDEL.2:e
 | 
						|
c.RANGEDEL.1:f
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
b#2,15:e
 | 
						|
c#1,15:f
 | 
						|
.
 | 
						|
a-b#3
 | 
						|
b-c#3
 | 
						|
c-d#3
 | 
						|
d-e#2
 | 
						|
e-f#1
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
b#2,15:e
 | 
						|
c#1,15:f
 | 
						|
.
 | 
						|
a-b#3
 | 
						|
b-c#3
 | 
						|
c-d#3
 | 
						|
c-d#1
 | 
						|
d-e#2
 | 
						|
d-e#1
 | 
						|
e-f#1
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
b#2,15:e
 | 
						|
c#1,15:f
 | 
						|
.
 | 
						|
a-b#3
 | 
						|
b-c#3
 | 
						|
b-c#2
 | 
						|
c-d#3
 | 
						|
c-d#2
 | 
						|
d-e#2
 | 
						|
e-f#1
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=(2,3)
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
b#2,15:e
 | 
						|
c#1,15:f
 | 
						|
.
 | 
						|
a-b#3
 | 
						|
b-c#3
 | 
						|
b-c#2
 | 
						|
c-d#3
 | 
						|
c-d#2
 | 
						|
c-d#1
 | 
						|
d-e#2
 | 
						|
d-e#1
 | 
						|
e-f#1
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.10:k
 | 
						|
f.SET.9:f
 | 
						|
f.SET.8:f
 | 
						|
----
 | 
						|
 | 
						|
iter snapshots=(9,10) print-snapshot-pinned print-force-obsolete
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones f
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#10,15:k (not pinned) (not force obsolete)
 | 
						|
f#9,1:f (pinned) (force obsolete)
 | 
						|
a-f#10
 | 
						|
.
 | 
						|
f#8,1:f (pinned) (force obsolete)
 | 
						|
f-k#10
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
f.RANGEDEL.10:k
 | 
						|
f.SET.9:f
 | 
						|
f.SET.8:f
 | 
						|
----
 | 
						|
 | 
						|
iter snapshots=(9,10)
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones f
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
f#10,15:k
 | 
						|
f#9,1:f
 | 
						|
.
 | 
						|
f#8,1:f
 | 
						|
f-k#10
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.1:a
 | 
						|
b.RANGEDEL.2:d
 | 
						|
c.RANGEDEL.3:e
 | 
						|
d.SET.4:d
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones c
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#1,1:a
 | 
						|
b#2,15:d
 | 
						|
c#3,15:e
 | 
						|
d#4,1:d
 | 
						|
b-c#2
 | 
						|
.
 | 
						|
c-d#3
 | 
						|
d-e#3
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones c
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#1,1:a
 | 
						|
b#2,15:d
 | 
						|
c#3,15:e
 | 
						|
d#4,1:d
 | 
						|
b-c#2
 | 
						|
.
 | 
						|
c-d#3
 | 
						|
c-d#2
 | 
						|
d-e#3
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.1:a
 | 
						|
b.RANGEDEL.2:d
 | 
						|
c.SET.4:d
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones c
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#1,1:a
 | 
						|
b#2,15:d
 | 
						|
c#4,1:d
 | 
						|
b-c#2
 | 
						|
.
 | 
						|
c-d#2
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.2:d
 | 
						|
a.SET.2:a
 | 
						|
b.SET.2:b
 | 
						|
c.SET.2:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,15:d
 | 
						|
a#2,1:a
 | 
						|
b#2,1:b
 | 
						|
c#2,1:c
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#1,7:
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.SINGLEDEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,7:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.SET.1:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.3:a
 | 
						|
b.SINGLEDEL.2:
 | 
						|
b.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,1:a
 | 
						|
b#2,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.MERGE.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
# SET that meets a SINGLEDEL is transformed into a SETWITHDEL.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:b
 | 
						|
a.SINGLEDEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,18:b
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.6:b
 | 
						|
a.SINGLEDEL.5:
 | 
						|
a.SET.4:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#6,18:b[base]
 | 
						|
.
 | 
						|
 | 
						|
# Non-deterministic use of SINGLEDEL where there are two older SETs that have
 | 
						|
# not been deleted or single deleted. It is permitted to shadow both.
 | 
						|
define
 | 
						|
a.MERGE.6:b
 | 
						|
a.SINGLEDEL.5:
 | 
						|
a.SET.4:a
 | 
						|
a.SET.3:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#6,18:b[base]
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.SET.1:b
 | 
						|
b.SET.3:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
b#3,1:c
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.SET.2:b
 | 
						|
a.SET.1:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#1,1:a
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.MERGE.2:b
 | 
						|
a.MERGE.1:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.4:
 | 
						|
a.SET.3:val
 | 
						|
a.SINGLEDEL.2:
 | 
						|
a.SET.1:val
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
----
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,7:
 | 
						|
a#1,1:val
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.4:
 | 
						|
a.SET.3:val
 | 
						|
a.DEL.2:
 | 
						|
a.SET.1:val
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
a#1,1:val
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=(2,3)
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,0:
 | 
						|
a#1,1:val
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.4:
 | 
						|
a.SET.3:c
 | 
						|
a.MERGE.2:b
 | 
						|
a.SET.1:a
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:ab[base]
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,2:b
 | 
						|
a#1,1:a
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:ab[base]
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=(2,3,4)
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#4,7:
 | 
						|
a#3,1:c
 | 
						|
a#2,2:b
 | 
						|
a#1,1:a
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.RANGEDEL.2:c
 | 
						|
a.SET.1:val
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,7:
 | 
						|
a#2,15:c
 | 
						|
.
 | 
						|
a-c#2
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:d
 | 
						|
a.DEL.2:
 | 
						|
a.SET.1:a
 | 
						|
d.DEL.2:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
d#2,0:
 | 
						|
.
 | 
						|
a-d#3
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
a#2,0:
 | 
						|
d#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
a#1,1:a
 | 
						|
d#2,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=1
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:d
 | 
						|
d#2,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.2:a
 | 
						|
b.RANGEDEL.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
tombstones a
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,2:a
 | 
						|
.
 | 
						|
b#1,15:c
 | 
						|
.
 | 
						|
b-c#1
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.2:v2
 | 
						|
a.RANGEDEL.1:b
 | 
						|
a.MERGE.1:v1
 | 
						|
----
 | 
						|
 | 
						|
iter allow-zero-seqnum=true
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#2,2:v2
 | 
						|
a#1,15:b
 | 
						|
a#0,2:v1
 | 
						|
.
 | 
						|
a-b#1
 | 
						|
.
 | 
						|
 | 
						|
# Verify that we transform merge+del -> set.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.5:5
 | 
						|
a.DEL.3:
 | 
						|
a.MERGE.1:1
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,18:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter allow-zero-seqnum=true
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#0,18:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=true
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,18:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,18:5[base]
 | 
						|
a#1,2:1
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2 elide-tombstones=true
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,18:5[base]
 | 
						|
a#1,2:1
 | 
						|
.
 | 
						|
 | 
						|
# Verify that we transform merge+rangedel -> set. This isn't strictly
 | 
						|
# necessary, but provides consistency with the behavior for merge+del.
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:c
 | 
						|
b.MERGE.5:5
 | 
						|
b.SET.2:2
 | 
						|
b.MERGE.1:1
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#5,1:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter allow-zero-seqnum=true
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#0,1:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#5,1:5[base]
 | 
						|
b#1,2:1
 | 
						|
 | 
						|
define
 | 
						|
a.RANGEDEL.3:c
 | 
						|
b.MERGE.5:5
 | 
						|
b.MERGE.2:2
 | 
						|
b.MERGE.1:1
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#5,1:5[base]
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,15:c
 | 
						|
b#5,1:5[base]
 | 
						|
b#1,2:1
 | 
						|
 | 
						|
# SET that meets a DEL is transformed into a SETWITHDEL.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:b
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:b
 | 
						|
a#1,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.3:c
 | 
						|
a.DEL.2:
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:c
 | 
						|
a#1,1:b
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.3:c
 | 
						|
a.SET.2:b
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,1:c
 | 
						|
a#2,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,1:c
 | 
						|
a#1,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.DEL.3:
 | 
						|
a.SET.2:b
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
a#2,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
a#1,0:
 | 
						|
.
 | 
						|
 | 
						|
# SETWITHDEL-eligible entries at or under a RANGEDEL at the same user key should
 | 
						|
# be skipped.
 | 
						|
define
 | 
						|
a.SET.3:c
 | 
						|
a.RANGEDEL.2:z
 | 
						|
a.SET.2:b
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter allow-zero-seqnum=true
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#0,18:c
 | 
						|
a#2,15:z
 | 
						|
.
 | 
						|
 | 
						|
iter allow-zero-seqnum=true snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,1:c
 | 
						|
a#2,15:z
 | 
						|
a#0,18:b
 | 
						|
.
 | 
						|
 | 
						|
iter allow-zero-seqnum=true snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:c
 | 
						|
a#2,15:z
 | 
						|
a#1,0:
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.4:c
 | 
						|
a.RANGEDEL.3:z
 | 
						|
a.SET.2:b
 | 
						|
a.DEL.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#4,18:c
 | 
						|
a#3,15:z
 | 
						|
.
 | 
						|
 | 
						|
# Invalid keys are emitted under SETWITHDEL.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:b
 | 
						|
a.INVALID.1:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,18:b
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
 | 
						|
define
 | 
						|
a.SET.3:c
 | 
						|
a.INVALID.2:
 | 
						|
a.SET.1:b
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:c
 | 
						|
err=invalid internal key kind: INVALID
 | 
						|
 | 
						|
# SINGLEDEL that meets a SETWITHDEL is transformed into a DEL.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.SETWITHDEL.2:d
 | 
						|
b.SET.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
b#1,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=2
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,0:
 | 
						|
b#1,1:c
 | 
						|
.
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,7:
 | 
						|
a#2,18:d
 | 
						|
b#1,1:c
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SETWITHDEL.3:3
 | 
						|
a.SET.2:d
 | 
						|
b.SET.1:c
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:3
 | 
						|
b#1,1:c
 | 
						|
.
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
iter snapshots=3
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#3,18:3
 | 
						|
a#2,1:d
 | 
						|
b#1,1:c
 | 
						|
.
 | 
						|
 | 
						|
# Test a DELSIZED whose encoded value matches the size of a deleted key. The
 | 
						|
# DELSIZED's value should be removed, reflecting that the tombstone already
 | 
						|
# dropped the key that it was expected to drop.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.9:foo
 | 
						|
b.DELSIZED.8:varint(11)
 | 
						|
b.SET.5:helloworld
 | 
						|
c.SET.2:bar
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,1:foo
 | 
						|
b#8,23:
 | 
						|
c#2,1:bar
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
# Test two DELSIZEDs meeting. The lower-sequenced number value should carry
 | 
						|
# forward, at the higher sequence number. The first DELSIZED should be consider
 | 
						|
# missized: It never found the key it was supposed to delete.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.9:foo
 | 
						|
b.DELSIZED.9:varint(20)
 | 
						|
b.DELSIZED.8:varint(10)
 | 
						|
c.SET.2:bar
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,1:foo
 | 
						|
b#9,23:varint(10)
 | 
						|
c#2,1:bar
 | 
						|
missized-dels=1
 | 
						|
 | 
						|
# Test a DELSIZED whose encoded value is larger than the size of the deleted
 | 
						|
# key. The DELSIZED should be replaced by an ordinary DEL with the same sequence
 | 
						|
# number.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.2:foo
 | 
						|
b.DELSIZED.8:varint(25)
 | 
						|
b.SET.3:hello
 | 
						|
c.SET.9:bar
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#2,1:foo
 | 
						|
b#8,0:
 | 
						|
c#9,1:bar
 | 
						|
missized-dels=1
 | 
						|
 | 
						|
# Test two DELSIZED at the same user key, but with correctly sized deleted keys.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.9:varint(4)
 | 
						|
a.SET.8:foo
 | 
						|
a.DELSIZED.8:varint(6)
 | 
						|
a.SET.5:hello
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,23:
 | 
						|
.
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
# Test the above scenario, except the second DELSIZED is missized. It should
 | 
						|
# still count as missized.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.9:varint(4)
 | 
						|
a.SET.8:foo
 | 
						|
a.DELSIZED.8:varint(1)
 | 
						|
a.SET.5:hello
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,0:
 | 
						|
.
 | 
						|
missized-dels=1
 | 
						|
 | 
						|
# Test the above scenario, except the second tombstone is a DEL. It should
 | 
						|
# NOT count as missized.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.9:varint(4)
 | 
						|
a.SET.8:foo
 | 
						|
a.DEL.8:
 | 
						|
a.SET.5:hello
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,0:
 | 
						|
.
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
# Test various DELSIZEDs beneath live keys. SETS should be converted to
 | 
						|
# SETWITHDELs when they meet a DELSIZED.
 | 
						|
 | 
						|
define
 | 
						|
a.SET.7:foo
 | 
						|
a.DELSIZED.5:varint(5)
 | 
						|
b.SET.4:bar
 | 
						|
b.DELSIZED.2:varint(4)
 | 
						|
b.SET.1:bax
 | 
						|
c.SET.9:coconut
 | 
						|
c.DEL.8:del
 | 
						|
c.DELSIZED.5:varint(2)
 | 
						|
d.SET.8:dragonfruit
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
----
 | 
						|
a#7,18:foo
 | 
						|
b#4,18:bar
 | 
						|
c#9,18:coconut
 | 
						|
d#8,1:dragonfruit
 | 
						|
.
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
# Test a DELSIZED meeting a MERGE. This counts as a missized DEL—The user can't
 | 
						|
# know the value of the most recent MERGE since it's dependent on LSM state.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.9:varint(4)
 | 
						|
a.MERGE.8:fo
 | 
						|
a.MERGE.7:o
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#9,0:
 | 
						|
.
 | 
						|
missized-dels=1
 | 
						|
 | 
						|
# Test a DELSIZED that shadows a SINGLEDEL'd key.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.4:varint(4)
 | 
						|
b.SINGLEDEL.3:
 | 
						|
b.SET.1:val
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,23:varint(4)
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Repeat the above but with elision of tombstones.
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
tombstones
 | 
						|
----
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Test DELSIZED shadowing SINGLEDEL.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.4:varint(4)
 | 
						|
a.SET.2:foo
 | 
						|
b.SINGLEDEL.3:
 | 
						|
b.SET.1:val
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,23:
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Repeat the above but with elision of tombstones.
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
tombstones
 | 
						|
----
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Test a very subtle sequence where a elision of tombstones is active, and a
 | 
						|
# unskippable RANGEDEL sits between a DELSIZED and the key it was intended to
 | 
						|
# delete. The unskippable RANGEDEL breaks the skipping of keys within the
 | 
						|
# snapshot stripe, but it's ultimately okay because we preserve skip=true across
 | 
						|
# the RANGEDEL return.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.5:varint(4)
 | 
						|
a.RANGEDEL.4:d
 | 
						|
a.SET.3:foo
 | 
						|
----
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Try the same test as above, but with allowing sequence number zeroing as well.
 | 
						|
 | 
						|
iter elide-tombstones=t allow-zero-seqnum=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Perform a variant of the above test but with a DEL key.
 | 
						|
 | 
						|
define
 | 
						|
a.DEL.5:
 | 
						|
a.RANGEDEL.4:d
 | 
						|
a.SET.3:foo
 | 
						|
----
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Perform a variant of the above test but with a SINGLEDEL key.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.5:
 | 
						|
a.RANGEDEL.4:d
 | 
						|
a.SET.3:foo
 | 
						|
----
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#4,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Perform a few variants of the above but with a range del with a seqnum equal to
 | 
						|
# keys. NB: When seqnums are equal, the order of keys with various kinds is:
 | 
						|
#
 | 
						|
# DeleteSized < RangeKey{Delete,Unset,Set} < SetWithDelete < RangeDelete < SingleDelete < Set < Delete
 | 
						|
#
 | 
						|
# NB: Range keys are interleaved always at the maximal sequence number, so the
 | 
						|
# compaction iterator should always observe them first.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.6:
 | 
						|
a.SETWITHDEL.5:foo
 | 
						|
a.RANGEDEL.5:z
 | 
						|
----
 | 
						|
 | 
						|
define-range-keys
 | 
						|
a-z:{(#5,RANGEKEYDEL)}
 | 
						|
----
 | 
						|
 | 
						|
# In the following case, the SINGLEDEL meets a SETWITHDEL, promoting the
 | 
						|
# SINGLEDEL into a DEL.
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#72057594037927935,19:
 | 
						|
a#6,0:
 | 
						|
a#5,15:z
 | 
						|
.
 | 
						|
a-z#5
 | 
						|
.
 | 
						|
 | 
						|
# In this case, SINGLEDEL is elided (despite its transformation into a DEL) due
 | 
						|
# to elide-tombstones=t.
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#72057594037927935,19:
 | 
						|
a#5,15:z
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.6:
 | 
						|
a.RANGEDEL.5:d
 | 
						|
a.SET.5:foo
 | 
						|
----
 | 
						|
 | 
						|
# NB: In this case, the RANGEDEL acts as an unintentional snapshot stripe
 | 
						|
# change. This is a code artifact, and we will be able to remove this behavior
 | 
						|
# when range deletes are interleaved at the maximal sequence number by an
 | 
						|
# interleaving iterator (like range keys are).
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
next
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#6,7:
 | 
						|
a#5,15:d
 | 
						|
a#5,1:foo
 | 
						|
.
 | 
						|
a-d#5
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=t allow-zero-seqnum=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#5,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.SINGLEDEL.6:
 | 
						|
a.SETWITHDEL.5:foo
 | 
						|
a.RANGEDEL.5:d
 | 
						|
----
 | 
						|
 | 
						|
# When the SINGLEDEL and SETWITHDEL meet, the SINGLEDEL is promoted into a DEL.
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#6,0:
 | 
						|
a#5,15:d
 | 
						|
a-d#5
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#5,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.6:varint(3)
 | 
						|
a.RANGEDEL.5:d
 | 
						|
a.SET.5:foo
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#6,23:varint(3)
 | 
						|
a#5,15:d
 | 
						|
a-d#5
 | 
						|
.
 | 
						|
 | 
						|
iter elide-tombstones=t
 | 
						|
first
 | 
						|
next
 | 
						|
tombstones
 | 
						|
----
 | 
						|
a#5,15:d
 | 
						|
.
 | 
						|
.
 | 
						|
 | 
						|
# Test a DELSIZED with a value that fails to decode.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.5:notavarint
 | 
						|
a.SET.4:foo
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
----
 | 
						|
err=DELSIZED holds invalid value: 6e6f7461766172696e74
 | 
						|
 | 
						|
# Test a value-less DELSIZED.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.5:
 | 
						|
a.SET.4:foo
 | 
						|
a.SET.3:bar
 | 
						|
----
 | 
						|
 | 
						|
iter print-missized-dels
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,0:
 | 
						|
.
 | 
						|
missized-dels=0
 | 
						|
 | 
						|
# Regression test for #3087.
 | 
						|
#
 | 
						|
# When a DELSIZED and a SINGLEDEL meet in a compaction, a DEL key should be
 | 
						|
# emitted.
 | 
						|
 | 
						|
define
 | 
						|
a.DELSIZED.5:
 | 
						|
a.SINGLEDEL.3:
 | 
						|
a.SET.2:foo
 | 
						|
a.SET.1:bar
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,0:
 | 
						|
.
 | 
						|
 | 
						|
# When a MERGE and a DEL[SIZED] meet in a compaction, a SETWITHDEL key (NOT a
 | 
						|
# SET) should be emitted. Otherwise, a sequence such as SINGLEDDEL, MERGE, DEL,
 | 
						|
# SET could result in the SET re-appearing.
 | 
						|
 | 
						|
define
 | 
						|
a.MERGE.5:foo
 | 
						|
a.DEL.3:
 | 
						|
----
 | 
						|
 | 
						|
iter
 | 
						|
first
 | 
						|
next
 | 
						|
----
 | 
						|
a#5,18:foo[base]
 | 
						|
.
 |