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=e99050cdf27a65405d3da184f4dec773de985670;hp=b767901432e5f5c695250d1bed00fa6608a1c06b;hb=99cc7653a83af6647f28ac0cbedf6f6062e92b72;hpb=dca6219e04505e9fa10b32e71059ce2abfae1dad diff --git a/src/journal/journal-internal.h b/src/journal/journal-internal.h index b76790143..e99050cdf 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. @@ -26,11 +25,12 @@ #include #include -#include +#include "systemd/sd-id128.h" #include "journal-def.h" #include "list.h" #include "hashmap.h" +#include "set.h" #include "journal-file.h" typedef struct Match Match; @@ -57,28 +57,23 @@ struct Match { LIST_HEAD(Match, matches); }; -typedef enum LocationType { - LOCATION_HEAD, - LOCATION_TAIL, - LOCATION_DISCRETE -} 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 { @@ -88,26 +83,51 @@ struct Directory { }; struct sd_journal { - int flags; + char *path; + char *prefix; - Hashmap *files; + OrderedHashmap *files; + MMapCache *mmap; Location current_location; JournalFile *current_file; uint64_t current_field; - Hashmap *directories_by_path; - Hashmap *directories_by_wd; + Match *level0, *level1, *level2; + + pid_t original_pid; int inotify_fd; + unsigned current_invalidate_counter, last_invalidate_counter; + usec_t last_process_usec; - Match *level0, *level1; + char *unique_field; + JournalFile *unique_file; + uint64_t unique_offset; - unsigned current_invalidate_counter, last_invalidate_counter; + int flags; + + bool on_network; + bool no_new_files; + bool unique_file_lost; /* File we were iterating over got + removed, and there were no more + files, so sd_j_enumerate_unique + will return a value equal to 0. */ + + 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); -#endif +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; )