X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fjournal%2Fjournal-internal.h;h=75a4129e5b4aac106be2ae5f2e7a6e962c42ce8a;hb=a9cdc94f7ff40f22a3cf9472f612a80730a1b010;hp=04f77540c91f8eaab4b69f63e1318581fcbbc753;hpb=7827b1a10f4dfe2c6771b515f28f7ae22e0ae039;p=elogind.git diff --git a/src/journal/journal-internal.h b/src/journal/journal-internal.h index 04f77540c..75a4129e5 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. @@ -58,9 +57,17 @@ 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 { @@ -93,6 +100,7 @@ struct sd_journal { char *path; Hashmap *files; + MMapCache *mmap; Location current_location; @@ -107,9 +115,13 @@ struct sd_journal { Match *level0, *level1; unsigned current_invalidate_counter, last_invalidate_counter; + + char *unique_field; + JournalFile *unique_file; + uint64_t unique_offset; + + bool on_network; }; char *journal_make_match_string(sd_journal *j); void journal_print_header(sd_journal *j); - -#endif