/* capture_filter_combo.cpp * * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 1998 Gerald Combs * * SPDX-License-Identifier: GPL-2.0-or-later */ #include #include #include "ui/recent_utils.h" #include "ui/recent.h" #include #include #include #include "wireshark_application.h" CaptureFilterCombo::CaptureFilterCombo(QWidget *parent, bool plain) : QComboBox(parent), cf_edit_(NULL) { cf_edit_ = new CaptureFilterEdit(this, plain); setEditable(true); // Enabling autocompletion here gives us two simultaneous completions: // Inline (highlighted text) for entire filters, handled here and popup // completion for fields handled by CaptureFilterEdit. setCompleter(0); setLineEdit(cf_edit_); // Default is Preferred. setSizePolicy(QSizePolicy::MinimumExpanding, sizePolicy().verticalPolicy()); setInsertPolicy(QComboBox::NoInsert); setAccessibleName(tr("Capture filter selector")); updateStyleSheet(); connect(this, &CaptureFilterCombo::interfacesChanged, cf_edit_, static_cast(&CaptureFilterEdit::checkFilter)); connect(cf_edit_, &CaptureFilterEdit::pushFilterSyntaxStatus, this, &CaptureFilterCombo::pushFilterSyntaxStatus); connect(cf_edit_, &CaptureFilterEdit::popFilterSyntaxStatus, this, &CaptureFilterCombo::popFilterSyntaxStatus); connect(cf_edit_, &CaptureFilterEdit::captureFilterSyntaxChanged, this, &CaptureFilterCombo::captureFilterSyntaxChanged); connect(cf_edit_, &CaptureFilterEdit::startCapture, this, &CaptureFilterCombo::startCapture); connect(cf_edit_, &CaptureFilterEdit::startCapture, this, &CaptureFilterCombo::saveAndRebuildFilterList); connect(wsApp, &WiresharkApplication::appInitialized, this, &CaptureFilterCombo::rebuildFilterList); connect(wsApp, &WiresharkApplication::preferencesChanged, this, &CaptureFilterCombo::rebuildFilterList); rebuildFilterList(); clearEditText(); } void CaptureFilterCombo::writeRecent(FILE *rf) { int i; for (i = 0; i < count(); i++) { const QByteArray& filter = itemText(i).toUtf8(); if (!filter.isEmpty()) { fprintf(rf, RECENT_KEY_DISPLAY_FILTER ": %s\n", filter.constData()); } } } bool CaptureFilterCombo::event(QEvent *event) { switch (event->type()) { case QEvent::ApplicationPaletteChange: updateStyleSheet(); break; default: break; } return QComboBox::event(event); } void CaptureFilterCombo::updateStyleSheet() { const char *display_mode = ColorUtils::themeIsDark() ? "dark" : "light"; QString ss = QString( "QComboBox {" #ifdef Q_OS_MAC " border: 1px solid gray;" #else " border: 1px solid palette(shadow);" #endif " border-radius: 3px;" " padding: 0px 0px 0px 0px;" " margin-left: 0px;" " min-width: 20em;" " }" "QComboBox::drop-down {" " subcontrol-origin: padding;" " subcontrol-position: top right;" " width: 16px;" " border-left-width: 0px;" " }" "QComboBox::down-arrow {" " image: url(:/stock_icons/14x14/x-filter-dropdown.%1.png);" " }" "QComboBox::down-arrow:on { /* shift the arrow when popup is open */" " top: 1px;" " left: 1px;" "}" ).arg(display_mode); setStyleSheet(ss); } void CaptureFilterCombo::saveAndRebuildFilterList() { if (!currentText().isEmpty()) { recent_add_cfilter(NULL, currentText().toUtf8().constData()); } rebuildFilterList(); } void CaptureFilterCombo::rebuildFilterList() { lineEdit()->blockSignals(true); GList *cfilter_list = recent_get_cfilter_list(NULL); QString cur_filter = currentText(); clear(); for (GList *li = g_list_first(cfilter_list); li != NULL; li = g_list_next(li)) { insertItem(0, (const gchar *) li->data); } lineEdit()->setText(cur_filter); lineEdit()->blockSignals(false); } /* * Editor modelines * * Local Variables: * c-basic-offset: 4 * tab-width: 8 * indent-tabs-mode: nil * End: * * ex: set shiftwidth=4 tabstop=8 expandtab: * :indentSize=4:tabSize=8:noTabs=true: */