X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fjournal%2Fjournal-internal.h;h=2c401e3083d0fde852b7bb482f31060d4951bf94;hb=9b55cd5665d94e2245a4ca90d2548bbcfe8c34fb;hp=75a4129e5b4aac106be2ae5f2e7a6e962c42ce8a;hpb=85210bffd8363e491b4c31f2d09404f9869ad0c7;p=elogind.git diff --git a/src/journal/journal-internal.h b/src/journal/journal-internal.h index 75a4129e5..2c401e308 100644 --- a/src/journal/journal-internal.h +++ b/src/journal/journal-internal.h @@ -30,6 +30,7 @@ #include "journal-def.h" #include "list.h" #include "hashmap.h" +#include "set.h" #include "journal-file.h" typedef struct Match Match; @@ -73,19 +74,20 @@ typedef enum 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 { @@ -95,9 +97,8 @@ struct Directory { }; struct sd_journal { - int flags; - char *path; + char *prefix; Hashmap *files; MMapCache *mmap; @@ -107,21 +108,36 @@ struct sd_journal { JournalFile *current_file; uint64_t current_field; - Hashmap *directories_by_path; - Hashmap *directories_by_wd; + Match *level0, *level1, *level2; - int inotify_fd; - - Match *level0, *level1; + pid_t original_pid; + int inotify_fd; unsigned current_invalidate_counter, last_invalidate_counter; + usec_t last_process_usec; char *unique_field; JournalFile *unique_file; uint64_t unique_offset; + int flags; + bool on_network; + bool no_new_files; + + size_t data_threshold; + + Hashmap *directories_by_path; + Hashmap *directories_by_wd; + + Set *errors; }; char *journal_make_match_string(sd_journal *j); void journal_print_header(sd_journal *j); + +DEFINE_TRIVIAL_CLEANUP_FUNC(sd_journal*, sd_journal_close); +#define _cleanup_journal_close_ _cleanup_(sd_journal_closep) + +#define JOURNAL_FOREACH_DATA_RETVAL(j, data, l, retval) \ + for (sd_journal_restart_data(j); ((retval) = sd_journal_enumerate_data((j), &(data), &(l))) > 0; )