/* Timestamp, measured in microseconds since the Unix epoch. */
typedef int64_t bluesky_time;
+/* High-resolution timer, measured in nanoseconds. */
+typedef int64_t bluesky_time_hires;
+bluesky_time_hires bluesky_now_hires();
+
/* In-memory representation of an inode within a Blue Sky server. This
* corresponds roughly with information that is committed to persistent
* storage. Locking/refcounting rules:
/* Directory-specific fields */
GSequence *dirents; /* List of entries for READDIR */
GHashTable *dirhash; /* Hash table by name for LOOKUP */
+ GHashTable *dirhash_folded; /* As above, but case-folded */
uint64_t parent_inum; /* inode for ".."; 0 if the root directory */
} BlueSkyInode;
* is used to provide a stable key for restarting a READDIR call. */
typedef struct {
gchar *name;
+ gchar *name_folded; /* Name, folded for case-insensitive lookup */
uint32_t cookie;
uint64_t inum;
} BlueSkyDirent;
void bluesky_dirent_destroy(gpointer dirent);
uint64_t bluesky_directory_hash(gchar *name);
uint64_t bluesky_directory_lookup(BlueSkyInode *inode, gchar *name);
+uint64_t bluesky_directory_ilookup(BlueSkyInode *inode, gchar *name);
gboolean bluesky_directory_insert(BlueSkyInode *dir, gchar *name,
uint64_t inum);
void bluesky_directory_dump(BlueSkyInode *dir);