File: hashpath.h

package info (click to toggle)
sjaakii 1.4.1-3.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,628 kB
  • sloc: ansic: 16,287; cpp: 4,543; makefile: 15
file content (29 lines) | stat: -rw-r--r-- 622 bytes parent folder | download | duplicates (5)
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
#ifndef HASHPATH_H
#define HASHPATH_H

#include <stdint.h>
#include "move.h"

#define MAX_HASH_PATH_LENGTH  128

typedef struct {
   uint64_t lock;
   move_t moves[MAX_HASH_PATH_LENGTH];
   int length;
   int generation;
} hash_path_entry_t;

typedef struct {
   /* We keep two parallel hash tables: a "depth priority" table and an
    * "always replace" table.
    */
   hash_path_table_entry_t *data;
   size_t number_of_elements;
   size_t write_count;
   uint8_t generation;
} hash_path_table_t;

hash_path_table_t *create_hash_path_table(size_t nelem);
void destroy_hash_path_table(hash_path_table_t *table);

#endif