You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

41 lines
858 B

  1. package skiplist
  2. import "bytes"
  3. func compareElement(a *SkipListElement, key []byte) int {
  4. if len(a.Key) == 0 {
  5. return -1
  6. }
  7. return bytes.Compare(a.Key, key)
  8. }
  9. func (node *SkipListElement) Reference() *SkipListElementReference {
  10. if node == nil {
  11. return nil
  12. }
  13. return &SkipListElementReference{
  14. ElementPointer: node.Id,
  15. Key: node.Key,
  16. }
  17. }
  18. func (t *SkipList) saveElement(element *SkipListElement) error {
  19. if element == nil {
  20. return nil
  21. }
  22. return t.listStore.SaveElement(element.Id, element)
  23. }
  24. func (t *SkipList) deleteElement(element *SkipListElement) error {
  25. if element == nil {
  26. return nil
  27. }
  28. return t.listStore.DeleteElement(element.Id)
  29. }
  30. func (t *SkipList) loadElement(ref *SkipListElementReference) (*SkipListElement, error) {
  31. if ref == nil {
  32. return nil, nil
  33. }
  34. return t.listStore.LoadElement(ref.ElementPointer)
  35. }