X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fjournal%2Fjournal-internal.h;h=f576a0073d905b18b0d596f919bd630bcb15bfdb;hp=482ef61b9ab0410b3086c14d9443d0e20d7f76a5;hb=a72b63536f1da3a97677bf38590f22a962e5fe98;hpb=cbdca8525b4f36297cb9e5cb090a9648763ed1bf diff --git a/src/journal/journal-internal.h b/src/journal/journal-internal.h index 482ef61b9..f576a0073 100644 --- a/src/journal/journal-internal.h +++ b/src/journal/journal-internal.h @@ -1,7 +1,6 @@ /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ -#ifndef foojournalinternalhfoo -#define foojournalinternalhfoo +#pragma once /*** This file is part of systemd. @@ -31,11 +30,9 @@ #include "journal-def.h" #include "list.h" #include "hashmap.h" +#include "set.h" #include "journal-file.h" -typedef enum MatchType MatchType; -typedef enum LocationType LocationType; - typedef struct Match Match; typedef struct Location Location; typedef struct Directory Directory; @@ -61,27 +58,36 @@ struct Match { }; typedef enum LocationType { + /* The first and last entries, resp. */ LOCATION_HEAD, LOCATION_TAIL, - LOCATION_DISCRETE + + /* We already read the entry we currently point to, and the + * next one to read should probably not be this one again. */ + LOCATION_DISCRETE, + + /* We should seek to the precise location specified, and + * return it, as we haven't read it yet. */ + LOCATION_SEEK } LocationType; struct Location { LocationType type; + bool seqnum_set; + bool realtime_set; + bool monotonic_set; + bool xor_hash_set; + uint64_t seqnum; sd_id128_t seqnum_id; - bool seqnum_set; uint64_t realtime; - bool realtime_set; uint64_t monotonic; sd_id128_t boot_id; - bool monotonic_set; uint64_t xor_hash; - bool xor_hash_set; }; struct Directory { @@ -93,7 +99,10 @@ struct Directory { struct sd_journal { int flags; + char *path; + Hashmap *files; + MMapCache *mmap; Location current_location; @@ -105,11 +114,31 @@ struct sd_journal { int inotify_fd; - Match *level0, *level1; + Match *level0, *level1, *level2; unsigned current_invalidate_counter, last_invalidate_counter; + + char *unique_field; + JournalFile *unique_file; + uint64_t unique_offset; + + bool on_network; + + size_t data_threshold; + + Set *errors; + + usec_t last_process_usec; }; char *journal_make_match_string(sd_journal *j); +void journal_print_header(sd_journal *j); + +static inline void journal_closep(sd_journal **j) { + sd_journal_close(*j); +} + +#define _cleanup_journal_close_ _cleanup_(journal_closep) -#endif +#define JOURNAL_FOREACH_DATA_RETVAL(j, data, l, retval) \ + for (sd_journal_restart_data(j); ((retval) = sd_journal_enumerate_data((j), &(data), &(l))) > 0; )