Commit Graph

16 Commits (09ff73b9a728580290b782419771e747c275c8e4)

Author SHA1 Message Date
Thomas Jungblut 62e81c036f introduce a freelist interface
This introduces an interface for the freelist, splits it into two concrete
implementations.

fixes etcd-io#773

Signed-off-by: Thomas Jungblut <tjungblu@redhat.com>
2024-07-09 10:41:35 +02:00
Ishan Tyagi cdac32e57c Change the type of pageId uint -> uint64.
Signed-off-by: ishan16696 <ishan.tyagi@sap.com>
2024-02-25 19:02:02 +05:30
Benjamin Wang 2b1ee6c191 Continue to enhance check functionality and add one more case to cover the nested bucket case
Signed-off-by: Benjamin Wang <benjamin.ahrtr@gmail.com>
2024-02-04 09:53:00 +00:00
Benjamin Wang 248e6f8a15 enhance check functionality to support checking starting from a pageId
Signed-off-by: Benjamin Wang <benjamin.ahrtr@gmail.com>
2024-01-22 15:43:57 +01:00
Benjamin Wang 9cec34d9c6 move the closing of channel into the same method of creating the channel
Signed-off-by: Benjamin Wang <benjamin.ahrtr@gmail.com>
2024-01-05 10:09:21 +00:00
Benjamin Wang b18e7931c5 move the invariant properties into a common method
Signed-off-by: Benjamin Wang <benjamin.ahrtr@gmail.com>
2023-12-31 14:19:19 +00:00
Benjamin Wang 23c97d55e6 refactor the implementation of check
Signed-off-by: Benjamin Wang <benjamin.ahrtr@gmail.com>
2023-12-27 15:32:54 +00:00
Benjamin Wang f7d0ed5185 bbolt: remove `CheckWithOptions` and add variadic parameter options to method Check
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2023-03-15 15:19:28 +08:00
Benjamin Wang a3a9877de6 encapsulate the logic of checking the page type
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2023-03-08 10:47:59 +08:00
Benjamin Wang ea511567eb refactor both bolt and guts_cli based on the common package
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2023-03-04 04:22:09 +08:00
Benjamin Wang 35c4569bf9 revert the signature of tx.Check and add tx.CheckWithStringer
Signed-off-by: Benjamin Wang <wachao@vmware.com>
2023-01-29 19:53:07 +08:00
Piotr Tabor eb0deb9550 Refactor common code within key-order checker.
Signed-off-by: Piotr Tabor <ptab@google.com>
2023-01-13 19:14:45 +01:00
Piotr Tabor 80edaf14f0 Rename: pgid pgid => pgId pgid to avoid confusion.
Signed-off-by: Piotr Tabor <ptab@google.com>
2023-01-13 19:14:45 +01:00
Piotr Tabor f16e2522ce Address review comments.
Signed-off-by: Piotr Tabor <ptab@google.com>
2023-01-13 19:14:45 +01:00
Piotr Tabor 0c8d75db1e Recursive checker implementation.
Recursive checker confirms database consistency with respect to b-tree
key order constraints:
  - keys on pages must be sorted
  - keys on children pages are between 2 consecutive keys on parent
branch page).

Signed-off-by: Piotr Tabor <ptab@google.com>
2023-01-13 19:14:45 +01:00
Piotr Tabor 0ccb16dc02 Mechanical move of Check functions to tx_check.go file.
Signed-off-by: Piotr Tabor <ptab@google.com>
2023-01-13 19:14:45 +01:00