mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 13:57:35 +00:00
Utilities+Base: Rename pape
utility to wallpaper
This commit is contained in:
parent
bfa94dd0b7
commit
85b133d47f
3 changed files with 7 additions and 7 deletions
77
Userland/Utilities/wallpaper.cpp
Normal file
77
Userland/Utilities/wallpaper.cpp
Normal file
|
@ -0,0 +1,77 @@
|
|||
/*
|
||||
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
||||
* Copyright (c) 2022, James Puleo <james@jame.xyz>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
||||
#include <AK/Random.h>
|
||||
#include <AK/String.h>
|
||||
#include <AK/StringBuilder.h>
|
||||
#include <LibCore/ArgsParser.h>
|
||||
#include <LibCore/DirIterator.h>
|
||||
#include <LibGUI/Application.h>
|
||||
#include <LibGUI/Desktop.h>
|
||||
#include <LibMain/Main.h>
|
||||
|
||||
ErrorOr<int> serenity_main(Main::Arguments arguments)
|
||||
{
|
||||
bool show_all = false;
|
||||
bool show_current = false;
|
||||
bool set_random = false;
|
||||
String path;
|
||||
|
||||
Core::ArgsParser args_parser;
|
||||
args_parser.add_option(show_all, "Show all wallpapers", "show-all", 'a');
|
||||
args_parser.add_option(show_current, "Show current wallpaper", "show-current", 'c');
|
||||
args_parser.add_option(set_random, "Set random wallpaper", "set-random", 'r');
|
||||
args_parser.add_positional_argument(path, "Wallpaper to set", "path", Core::ArgsParser::Required::No);
|
||||
args_parser.parse(arguments);
|
||||
|
||||
auto app = TRY(GUI::Application::try_create(arguments));
|
||||
|
||||
if (show_all) {
|
||||
Core::DirIterator wallpapers_directory_iterator("/res/wallpapers", Core::DirIterator::SkipDots);
|
||||
if (wallpapers_directory_iterator.has_error())
|
||||
return Error::from_string_literal("Unable to iterate /res/wallpapers directory");
|
||||
|
||||
while (wallpapers_directory_iterator.has_next()) {
|
||||
auto name = wallpapers_directory_iterator.next_path();
|
||||
outln("{}", name);
|
||||
}
|
||||
} else if (show_current) {
|
||||
auto current_wallpaper_path = GUI::Desktop::the().wallpaper_path();
|
||||
outln("{}", current_wallpaper_path);
|
||||
} else if (set_random) {
|
||||
Core::DirIterator wallpapers_directory_iterator("/res/wallpapers", Core::DirIterator::SkipDots);
|
||||
if (wallpapers_directory_iterator.has_error())
|
||||
return Error::from_string_literal("Unable to iterate /res/wallpapers directory");
|
||||
|
||||
Vector<String> wallpaper_paths;
|
||||
|
||||
auto current_wallpaper_path = GUI::Desktop::the().wallpaper_path();
|
||||
while (wallpapers_directory_iterator.has_next()) {
|
||||
auto next_full_path = wallpapers_directory_iterator.next_full_path();
|
||||
if (next_full_path != current_wallpaper_path)
|
||||
wallpaper_paths.append(move(next_full_path));
|
||||
}
|
||||
|
||||
if (wallpaper_paths.is_empty())
|
||||
return Error::from_string_literal("No wallpapers found");
|
||||
|
||||
auto& chosen_wallpaper_path = wallpaper_paths.at(get_random_uniform(wallpaper_paths.size()));
|
||||
auto chosen_wallpaper_bitmap = TRY(Gfx::Bitmap::try_load_from_file(chosen_wallpaper_path));
|
||||
if (!GUI::Desktop::the().set_wallpaper(chosen_wallpaper_bitmap, chosen_wallpaper_path))
|
||||
return Error::from_string_literal("Failed to set wallpaper");
|
||||
|
||||
outln("Set wallpaper to {}", chosen_wallpaper_path);
|
||||
} else {
|
||||
if (path.is_null())
|
||||
return Error::from_string_literal("Must provide a path to a wallpaper");
|
||||
|
||||
auto wallpaper_bitmap = TRY(Gfx::Bitmap::try_load_from_file(path));
|
||||
if (!GUI::Desktop::the().set_wallpaper(wallpaper_bitmap, path))
|
||||
return Error::from_string_literal("Failed to set wallpaper");
|
||||
}
|
||||
return 0;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue