aboutsummaryrefslogtreecommitdiff
path: root/swaylock
diff options
context:
space:
mode:
authorChristoph Gysin <christoph.gysin@gmail.com>2016-01-23 15:16:36 +0200
committerChristoph Gysin <christoph.gysin@gmail.com>2016-01-23 16:36:19 +0200
commit7b25caba47af4b2755f675c1326e27e9d51ffa1c (patch)
tree2bba8b750bc2c90548524691a3a0d8da9eb2f63c /swaylock
parent259dc25ba33d6f9f05a92f9f00ce493f87f1e4c6 (diff)
swaylock: add i3lock compatible options
Diffstat (limited to 'swaylock')
-rw-r--r--swaylock/main.c33
1 files changed, 27 insertions, 6 deletions
diff --git a/swaylock/main.c b/swaylock/main.c
index 0bf64621..c01445e7 100644
--- a/swaylock/main.c
+++ b/swaylock/main.c
@@ -92,28 +92,46 @@ void notify_key(enum wl_keyboard_key_state state, xkb_keysym_t sym, uint32_t cod
}
int main(int argc, char **argv) {
+ char *image_path = NULL;
+ char *scaling_mode_str = "fit";
+
init_log(L_INFO);
static struct option long_options[] = {
{"help", no_argument, NULL, 'h'},
+ {"image", required_argument, NULL, 'i'},
+ {"scaling", required_argument, NULL, 's'},
+ {"tiling", no_argument, NULL, 't'},
{"version", no_argument, NULL, 'v'},
{0, 0, 0, 0}
};
const char *usage =
- "Usage: swaylock <image> [stretch|fit|fill|center|tile]\n"
+ "Usage: swaylock [options...]\n"
"\n"
" -h, --help Show help message and quit.\n"
- " -v, --version Show the version number and quit.\n";
+ " -s, --scaling Scaling mode: stretch, fill, fit, center, tile.\n"
+ " -t, --tiling Same as --scaling=tile.\n"
+ " -v, --version Show the version number and quit.\n"
+ " -i, --image <path> Display the given image.\n";
int c;
while (1) {
int option_index = 0;
- c = getopt_long(argc, argv, "hv", long_options, &option_index);
+ c = getopt_long(argc, argv, "hi:s:tv", long_options, &option_index);
if (c == -1) {
break;
}
switch (c) {
+ case 'i':
+ image_path = optarg;
+ break;
+ case 's':
+ scaling_mode_str = optarg;
+ break;
+ case 't':
+ scaling_mode_str = "tile";
+ break;
case 'v':
#if defined SWAY_GIT_VERSION && defined SWAY_GIT_BRANCH && defined SWAY_VERSION_DATE
fprintf(stdout, "swaylock version %s (%s, branch \"%s\")\n", SWAY_GIT_VERSION, SWAY_VERSION_DATE, SWAY_GIT_BRANCH);
@@ -128,8 +146,11 @@ int main(int argc, char **argv) {
}
}
- char *image_path = argv[optind];
- char *scaling_mode_str = argv[optind+1];
+ // TODO: support locking without image
+ if (!image_path) {
+ fprintf(stderr, "No image specified!\n");
+ exit(EXIT_FAILURE);
+ }
password = malloc(1024); // TODO: Let this grow
password[0] = '\0';
@@ -154,7 +175,7 @@ int main(int argc, char **argv) {
#ifdef WITH_GDK_PIXBUF
GError *err = NULL;
- GdkPixbuf *pixbuf = gdk_pixbuf_new_from_file(image_path, &err); // TODO: Parse i3lock arguments
+ GdkPixbuf *pixbuf = gdk_pixbuf_new_from_file(image_path, &err);
if (!pixbuf) {
sway_abort("Failed to load background image.");
}