mirror of
https://github.com/RGBCube/serenity
synced 2025-06-20 04:42:07 +00:00
NetworkSettings: Add command line option for opening a specific adapter
This commit is contained in:
parent
f4a5cd63bb
commit
38fb3257c8
3 changed files with 18 additions and 1 deletions
|
@ -158,4 +158,10 @@ void NetworkSettingsWidget::apply_settings()
|
||||||
GUI::Process::spawn_or_show_error(window(), "/bin/NetworkServer"sv);
|
GUI::Process::spawn_or_show_error(window(), "/bin/NetworkServer"sv);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void NetworkSettingsWidget::switch_adapter(String const& adapter)
|
||||||
|
{
|
||||||
|
m_adapters_combobox->set_text(adapter, GUI::AllowCallback::No);
|
||||||
|
on_switch_adapter(adapter);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ class NetworkSettingsWidget : public GUI::SettingsWindow::Tab {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual void apply_settings() override;
|
virtual void apply_settings() override;
|
||||||
|
void switch_adapter(String const& adapter);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
NetworkSettingsWidget();
|
NetworkSettingsWidget();
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "NetworkSettingsWidget.h"
|
#include "NetworkSettingsWidget.h"
|
||||||
|
#include <LibCore/ArgsParser.h>
|
||||||
#include <LibGUI/MessageBox.h>
|
#include <LibGUI/MessageBox.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
@ -28,6 +29,12 @@ ErrorOr<int> serenity_main(Main::Arguments args)
|
||||||
TRY(Core::System::unveil("/tmp/portal/window", "rw"));
|
TRY(Core::System::unveil("/tmp/portal/window", "rw"));
|
||||||
TRY(Core::System::unveil(nullptr, nullptr));
|
TRY(Core::System::unveil(nullptr, nullptr));
|
||||||
|
|
||||||
|
String adapter;
|
||||||
|
|
||||||
|
Core::ArgsParser parser;
|
||||||
|
parser.add_positional_argument(adapter, "Adapter to display settings for", "adapter", Core::ArgsParser::Required::No);
|
||||||
|
parser.parse(args);
|
||||||
|
|
||||||
auto app = TRY(GUI::Application::try_create(args));
|
auto app = TRY(GUI::Application::try_create(args));
|
||||||
|
|
||||||
if (getuid() != 0) {
|
if (getuid() != 0) {
|
||||||
|
@ -39,7 +46,10 @@ ErrorOr<int> serenity_main(Main::Arguments args)
|
||||||
|
|
||||||
auto app_icon = GUI::Icon::default_icon("network"sv);
|
auto app_icon = GUI::Icon::default_icon("network"sv);
|
||||||
auto window = TRY(GUI::SettingsWindow::create("Network Settings", GUI::SettingsWindow::ShowDefaultsButton::No));
|
auto window = TRY(GUI::SettingsWindow::create("Network Settings", GUI::SettingsWindow::ShowDefaultsButton::No));
|
||||||
(void)TRY(window->add_tab<NetworkSettings::NetworkSettingsWidget>("Network"sv, "network"sv));
|
auto network_settings_widget = TRY(window->add_tab<NetworkSettings::NetworkSettingsWidget>("Network"sv, "network"sv));
|
||||||
|
if (!adapter.is_null()) {
|
||||||
|
network_settings_widget->switch_adapter(adapter);
|
||||||
|
}
|
||||||
window->set_icon(app_icon.bitmap_for_size(16));
|
window->set_icon(app_icon.bitmap_for_size(16));
|
||||||
|
|
||||||
window->show();
|
window->show();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue