/* file_dialog.c * Common file dialog routines * * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 2006 Gerald Combs * * SPDX-License-Identifier: GPL-2.0-or-later */ #include "config.h" #include #include #include #include #include #include "ui/file_dialog.h" ws_file_preview_stats_status get_stats_for_preview(wtap *wth, ws_file_preview_stats *stats, int *err, char **err_info) { int64_t data_offset; wtap_rec rec; Buffer buf; uint32_t records; uint32_t data_records; double start_time; double stop_time; bool have_times; bool timed_out; time_t time_preview, time_current; double cur_time; have_times = false; start_time = 0; stop_time = 0; records = 0; data_records = 0; timed_out = false; time(&time_preview); wtap_rec_init(&rec); ws_buffer_init(&buf, 1514); while ((wtap_read(wth, &rec, &buf, err, err_info, &data_offset))) { if (rec.presence_flags & WTAP_HAS_TS) { cur_time = nstime_to_sec(&rec.ts); if (!have_times) { start_time = cur_time; stop_time = cur_time; have_times = true; } if (cur_time < start_time) { start_time = cur_time; } if (cur_time > stop_time){ stop_time = cur_time; } } switch (rec.rec_type) { case REC_TYPE_PACKET: case REC_TYPE_FT_SPECIFIC_EVENT: case REC_TYPE_FT_SPECIFIC_REPORT: case REC_TYPE_SYSCALL: case REC_TYPE_SYSTEMD_JOURNAL_EXPORT: data_records++; break; } records++; if ((records % 1000) == 0) { /* do we have a timeout? */ time(&time_current); if (time_current-time_preview >= (time_t) prefs.gui_fileopen_preview) { timed_out = true; break; } } wtap_rec_reset(&rec); } stats->have_times = have_times; stats->start_time = start_time; stats->stop_time = stop_time; stats->records = records; stats->data_records = data_records; wtap_rec_cleanup(&rec); ws_buffer_free(&buf); if (*err != 0) { /* Read error. */ return PREVIEW_READ_ERROR; } return timed_out ? PREVIEW_TIMED_OUT : PREVIEW_SUCCEEDED; }