fsautoproc
Basic file transformation automation management utility
Loading...
Searching...
No Matches
index.c File Reference

File index mapping and serialization implementation. More...

#include "index.h"
#include <errno.h>
#include <inttypes.h>
#include <stdlib.h>
#include <string.h>
#include "jemalloc/jemalloc.h"
#include "je.h"
#include "log.h"
Include dependency graph for index.c:

Macros

#define indexbucket(hash)   ((int) (hash & INDEXBUCKETSMASK))
 Maps and casts the hash value to a bucket index via the last N bits (where N is the number of buckets, INDEXBUCKETS).
 
#define INDEXWRITEFMT   "%s,%" PRIu64 ",%" PRIu64 ",%" PRIu64 "\n"
 Format string used for writing index entries to a file stream.
 
#define INDEXREADFMT   "%[^,],%" PRIu64 ",%" PRIu64 ",%" PRIu64 "\n"
 Format string used for reading index entries from a file stream.
 

Functions

uint64_t indexhash (const char *fp)
 Hashes the filepath string for use in the index map.
 
struct inode_sindexfind (const struct index_s *idx, const char *fp, const uint64_t fphash)
 Searches the index for a node with a matching filepath.
 
static int indexnodecmp (const void *a, const void *b)
 Compares two file nodes for sorting in ascending order by filepath.
 
int indexwrite (struct index_s *idx, FILE *s)
 Flattens the index map into a sorted array of nodes (by filepath). The list is then written to the file stream and freed.
 
int indexread (struct index_s *idx, FILE *s)
 Reads a file stream and deserializes the contents into a map of individual file nodes.
 
static void indexappend (struct ibucket_s *bucket, struct inode_s *node)
 Appends the node to the end of the bucket (linked list), potentially assigning a new head if the bucket is empty.
 
struct inode_sindexput (struct index_s *idx, const char *fp, const uint64_t fphash, const struct fsstat_s *st, const uint64_t xx)
 Copies the node and inserts it into the index mapping.
 
static void indexfree_r (struct inode_s *idx)
 Recursively frees a linked list of nodes starting from a given head.
 
void indexfree (struct index_s *idx)
 Frees all nodes in the index map.
 
struct inode_s ** indexlist (const struct index_s *idx)
 Flattens the index map into an unsorted array of nodes. The list is dynamically allocated and must be freed by the caller. Array size is determined by the size field in the index struct.
 

Variables

static char indexfpbuf [1024]
 Filepath buffer for index I/O operations.
 

Detailed Description

File index mapping and serialization implementation.

Macro Definition Documentation

◆ indexbucket

#define indexbucket (   hash)    ((int) (hash & INDEXBUCKETSMASK))

Maps and casts the hash value to a bucket index via the last N bits (where N is the number of buckets, INDEXBUCKETS).

◆ INDEXREADFMT

#define INDEXREADFMT   "%[^,],%" PRIu64 ",%" PRIu64 ",%" PRIu64 "\n"

Format string used for reading index entries from a file stream.

◆ INDEXWRITEFMT

#define INDEXWRITEFMT   "%s,%" PRIu64 ",%" PRIu64 ",%" PRIu64 "\n"

Format string used for writing index entries to a file stream.

Function Documentation

◆ indexappend()

static void indexappend ( struct ibucket_s bucket,
struct inode_s node 
)
static

Appends the node to the end of the bucket (linked list), potentially assigning a new head if the bucket is empty.

Parameters
headThe head of the linked list
nodeThe node pointer to insert
Here is the caller graph for this function:

◆ indexfind()

struct inode_s * indexfind ( const struct index_s idx,
const char *  fp,
uint64_t  fphash 
)

Searches the index for a node with a matching filepath.

Parameters
idxThe index to search
fpThe search value (filepath) to compare
fphashThe hash value of the filepath to compare
Returns
If a match is found, its pointer is returned, otherwise NULL.
Here is the caller graph for this function:

◆ indexfree()

void indexfree ( struct index_s idx)

Frees all nodes in the index map.

Parameters
idxThe index to free
Here is the call graph for this function:
Here is the caller graph for this function:

◆ indexfree_r()

static void indexfree_r ( struct inode_s idx)
static

Recursively frees a linked list of nodes starting from a given head.

Parameters
idxThe head of the linked list
Here is the caller graph for this function:

◆ indexhash()

uint64_t indexhash ( const char *  fp)

Hashes the filepath string for use in the index map.

Note
64-bit FNV-1a implementation is used for hashing.
Parameters
fpThe filepath string to hash
Returns
The hashed value of the filepath.
Here is the caller graph for this function:

◆ indexlist()

struct inode_s ** indexlist ( const struct index_s idx)

Flattens the index map into an unsorted array of nodes. The list is dynamically allocated and must be freed by the caller. Array size is determined by the size field in the index struct.

Parameters
idxThe index to flatten
Returns
If successful, a pointer to an array of size idx->size is returned. Otherwise, NULL is returned and errno is set.
Here is the caller graph for this function:

◆ indexnodecmp()

static int indexnodecmp ( const void *  a,
const void *  b 
)
static

Compares two file nodes for sorting in ascending order by filepath.

Parameters
aThe first file node to compare
bThe second file node to compare
Returns
The result of the comparison.
Note
This function is equivalent to strcmp(a->fp, b->fp).
Here is the caller graph for this function:

◆ indexput()

struct inode_s * indexput ( struct index_s idx,
const char *  fp,
uint64_t  fphash,
const struct fsstat_s st,
uint64_t  xx 
)

Copies the node and inserts it into the index mapping.

Parameters
idxThe index to insert into
fpThe file path to use for the new node, duplicated internally
fphashThe file path hash value to use for the new node
stThe file stat info to use for the new node
xxThe xxHash64 hash value to use for the new node
Returns
The pointer to the new node in the index map, otherwise NULL is returned and errno is set.
Here is the call graph for this function:
Here is the caller graph for this function:

◆ indexread()

int indexread ( struct index_s idx,
FILE *  s 
)

Reads a file stream and deserializes the contents into a map of individual file nodes.

Parameters
idxThe index to populate
sThe file stream to read from
Returns
If successful, 0 is returned. Otherwise, -1 is returned and errno is set.
Here is the call graph for this function:
Here is the caller graph for this function:

◆ indexwrite()

int indexwrite ( struct index_s idx,
FILE *  s 
)

Flattens the index map into a sorted array of nodes (by filepath). The list is then written to the file stream and freed.

Parameters
idxThe index to flatten
sThe file stream to write to
Returns
If successful, 0 is returned. Otherwise, -1 is returned and errno is set.
Here is the call graph for this function:
Here is the caller graph for this function:

Variable Documentation

◆ indexfpbuf

char indexfpbuf[1024]
static

Filepath buffer for index I/O operations.