2012-07-13 22:39:02 +02:00
<?xml version='1.0'?> <!-- * - nxml - * -->
2019-03-14 14:40:58 +01:00
< !DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
2023-12-25 15:48:33 +01:00
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
2020-11-09 13:23:58 +09:00
<!-- SPDX - License - Identifier: LGPL - 2.1 - or - later -->
2012-07-13 22:39:02 +02:00
2018-06-06 11:59:04 +02:00
<refentry id= "sd_journal_seek_head" xmlns:xi= "http://www.w3.org/2001/XInclude" >
2012-07-13 22:39:02 +02:00
2015-02-03 21:14:13 -05:00
<refentryinfo >
<title > sd_journal_seek_head</title>
<productname > systemd</productname>
</refentryinfo>
<refmeta >
<refentrytitle > sd_journal_seek_head</refentrytitle>
<manvolnum > 3</manvolnum>
</refmeta>
<refnamediv >
<refname > sd_journal_seek_head</refname>
<refname > sd_journal_seek_tail</refname>
<refname > sd_journal_seek_monotonic_usec</refname>
<refname > sd_journal_seek_realtime_usec</refname>
<refname > sd_journal_seek_cursor</refname>
<refpurpose > Seek to a position in the
journal</refpurpose>
</refnamediv>
<refsynopsisdiv >
<funcsynopsis >
<funcsynopsisinfo > #include < systemd/sd-journal.h> </funcsynopsisinfo>
<funcprototype >
<funcdef > int <function > sd_journal_seek_head</function> </funcdef>
<paramdef > sd_journal *<parameter > j</parameter> </paramdef>
</funcprototype>
<funcprototype >
<funcdef > int <function > sd_journal_seek_tail</function> </funcdef>
<paramdef > sd_journal *<parameter > j</parameter> </paramdef>
</funcprototype>
<funcprototype >
<funcdef > int <function > sd_journal_seek_monotonic_usec</function> </funcdef>
<paramdef > sd_journal *<parameter > j</parameter> </paramdef>
<paramdef > sd_id128_t <parameter > boot_id</parameter> </paramdef>
<paramdef > uint64_t <parameter > usec</parameter> </paramdef>
</funcprototype>
<funcprototype >
<funcdef > int <function > sd_journal_seek_realtime_usec</function> </funcdef>
<paramdef > sd_journal *<parameter > j</parameter> </paramdef>
<paramdef > uint64_t <parameter > usec</parameter> </paramdef>
</funcprototype>
<funcprototype >
<funcdef > int <function > sd_journal_seek_cursor</function> </funcdef>
<paramdef > sd_journal *<parameter > j</parameter> </paramdef>
<paramdef > const char *<parameter > cursor</parameter> </paramdef>
</funcprototype>
</funcsynopsis>
</refsynopsisdiv>
<refsect1 >
<title > Description</title>
2019-03-13 12:29:25 +01:00
<para > <function > sd_journal_seek_head()</function> seeks to the beginning of the journal, i.e. to the
position before the oldest available entry.</para>
<para > Similarly, <function > sd_journal_seek_tail()</function> may be used to seek to the end of the
journal, i.e. the position after the most recent available entry.</para>
<para > <function > sd_journal_seek_monotonic_usec()</function> seeks to a position with the specified
monotonic timestamp, i.e. <constant > CLOCK_MONOTONIC</constant> . Since monotonic time restarts on every
reboot a boot ID needs to be specified as well.</para>
<para > <function > sd_journal_seek_realtime_usec()</function> seeks to a position with the specified
realtime (wallclock) timestamp, i.e. <constant > CLOCK_REALTIME</constant> . Note that the realtime clock is
not necessarily monotonic. If a realtime timestamp is ambiguous, it is not defined which position is
sought to.</para>
<para > <function > sd_journal_seek_cursor()</function> seeks to the position at the specified cursor
string. For details on cursors, see
2015-02-03 21:14:13 -05:00
<citerefentry > <refentrytitle > sd_journal_get_cursor</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> .
2019-03-13 12:29:25 +01:00
If no entry matching the specified cursor is found the call will seek to the next closest entry (in terms
2024-04-17 18:11:31 +02:00
of time) instead.</para>
2015-02-03 21:14:13 -05:00
2019-03-13 12:29:25 +01:00
<para > Note that these calls do not actually make any entry the new current entry, this needs to be done
in a separate step with a subsequent
2015-02-03 21:14:13 -05:00
<citerefentry > <refentrytitle > sd_journal_next</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
2019-03-13 12:29:25 +01:00
invocation (or a similar call). Only then, entry data may be retrieved via
<citerefentry > <refentrytitle > sd_journal_get_data</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
or an entry cursor be retrieved via
<citerefentry > <refentrytitle > sd_journal_get_cursor</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> .
If no entry exists that matches exactly the specified seek address, the next closest is sought to. If
<citerefentry > <refentrytitle > sd_journal_next</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> is
used, the closest following entry will be sought to, if
2015-02-03 21:14:13 -05:00
<citerefentry > <refentrytitle > sd_journal_previous</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
is used the closest preceding entry is sought to.</para>
2024-04-17 18:11:31 +02:00
<para > After the seek is done, and
<citerefentry > <refentrytitle > sd_journal_next</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
or a similar call has been made,
<citerefentry > <refentrytitle > sd_journal_test_cursor</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry>
may be used to verify whether the newly selected entry actually matches the cursor.
</para>
2015-02-03 21:14:13 -05:00
</refsect1>
<refsect1 >
<title > Return Value</title>
<para > The functions return 0 on success or a negative errno-style
error code.</para>
</refsect1>
<refsect1 >
<title > Notes</title>
2018-08-03 16:43:30 +02:00
<xi:include href= "threads-aware.xml" xpointer= "strict" />
2016-10-15 15:24:55 -04:00
2018-06-06 11:59:04 +02:00
<xi:include href= "libsystemd-pkgconfig.xml" xpointer= "pkgconfig-text" />
2015-02-03 21:14:13 -05:00
</refsect1>
2023-09-04 13:46:35 +01:00
<refsect1 >
<title > History</title>
2023-09-18 17:44:26 +01:00
<para > <function > sd_journal_seek_head()</function> ,
<function > sd_journal_seek_tail()</function> ,
<function > sd_journal_seek_monotonic_usec()</function> ,
<function > sd_journal_seek_realtime_usec()</function> , and
<function > sd_journal_seek_cursor()</function> were added in version 187.</para>
2023-09-04 13:46:35 +01:00
</refsect1>
2015-02-03 21:14:13 -05:00
<refsect1 >
<title > See Also</title>
2023-12-22 19:09:32 +01:00
<para > <simplelist type= "inline" >
<member > <citerefentry > <refentrytitle > systemd</refentrytitle> <manvolnum > 1</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd-journal</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_journal_open</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_journal_next</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_journal_get_data</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_journal_get_cursor</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_journal_get_realtime_usec</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
</simplelist> </para>
2015-02-03 21:14:13 -05:00
</refsect1>
2012-07-13 22:39:02 +02:00
</refentry>