mirror of
https://github.com/Raymo111/i3lock-color.git
synced 2024-11-11 13:50:52 -05:00
upstream + locale detection tweak
This commit is contained in:
commit
f31df3c1c7
1 changed files with 42 additions and 40 deletions
82
i3lock.c
82
i3lock.c
|
@ -890,7 +890,7 @@ int main(int argc, char *argv[]) {
|
|||
#endif
|
||||
int curs_choice = CURS_NONE;
|
||||
int o;
|
||||
int optind = 0;
|
||||
int longoptind = 0;
|
||||
struct option longopts[] = {
|
||||
{"version", no_argument, NULL, 'v'},
|
||||
{"nofork", no_argument, NULL, 'n'},
|
||||
|
@ -950,15 +950,13 @@ int main(int argc, char *argv[]) {
|
|||
|
||||
{NULL, no_argument, NULL, 0}};
|
||||
|
||||
setlocale(LC_ALL, "");
|
||||
|
||||
if ((pw = getpwuid(getuid())) == NULL)
|
||||
err(EXIT_FAILURE, "getpwuid() failed");
|
||||
if ((username = pw->pw_name) == NULL)
|
||||
errx(EXIT_FAILURE, "pw->pw_name is NULL.\n");
|
||||
|
||||
char *optstring = "hvnbdc:p:ui:teI:frsS:kB:";
|
||||
while ((o = getopt_long(argc, argv, optstring, longopts, &optind)) != -1) {
|
||||
while ((o = getopt_long(argc, argv, optstring, longopts, &longoptind)) != -1) {
|
||||
switch (o) {
|
||||
case 'v':
|
||||
errx(EXIT_SUCCESS, "version " VERSION " © 2010 Michael Stapelberg");
|
||||
|
@ -1032,12 +1030,12 @@ int main(int argc, char *argv[]) {
|
|||
blur_sigma = atoi(optarg);
|
||||
break;
|
||||
case 0:
|
||||
if (strcmp(longopts[optind].name, "debug") == 0)
|
||||
if (strcmp(longopts[longoptind].name, "debug") == 0)
|
||||
debug_mode = true;
|
||||
else if (strcmp(longopts[optind].name, "indicator") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "indicator") == 0) {
|
||||
show_indicator = true;
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "insidevercolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "insidevercolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1047,7 +1045,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", insidevercolor) != 1)
|
||||
errx(1, "insidevercolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "insidewrongcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "insidewrongcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1057,7 +1055,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", insidewrongcolor) != 1)
|
||||
errx(1, "insidewrongcolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "insidecolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "insidecolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1067,7 +1065,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", insidecolor) != 1)
|
||||
errx(1, "insidecolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "ringvercolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "ringvercolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1077,7 +1075,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", ringvercolor) != 1)
|
||||
errx(1, "ringvercolor is invalid, color must be given in 4-byte format: rrggbb\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "ringwrongcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "ringwrongcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1087,7 +1085,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", ringwrongcolor) != 1)
|
||||
errx(1, "ringwrongcolor is invalid, color must be given in r-byte format: rrggbb\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "ringcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "ringcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1097,7 +1095,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", ringcolor) != 1)
|
||||
errx(1, "ringcolor is invalid, color must be given in 4-byte format: rrggbb\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "linecolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "linecolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1107,7 +1105,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", linecolor) != 1)
|
||||
errx(1, "linecolor is invalid, color must be given in 4-byte format: rrggbb\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "textcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "textcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1117,7 +1115,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", textcolor) != 1)
|
||||
errx(1, "textcolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "timecolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "timecolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1127,7 +1125,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", timecolor) != 1)
|
||||
errx(1, "timecolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "datecolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "datecolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1137,7 +1135,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", datecolor) != 1)
|
||||
errx(1, "datecolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "keyhlcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "keyhlcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1147,7 +1145,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", keyhlcolor) != 1)
|
||||
errx(1, "keyhlcolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "bshlcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "bshlcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1157,7 +1155,7 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", bshlcolor) != 1)
|
||||
errx(1, "bshlcolor is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "separatorcolor") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "separatorcolor") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
/* Skip # if present */
|
||||
|
@ -1167,35 +1165,35 @@ int main(int argc, char *argv[]) {
|
|||
if (strlen(arg) != 8 || sscanf(arg, "%08[0-9a-fA-F]", separatorcolor) != 1)
|
||||
errx(1, "separator is invalid, color must be given in 4-byte format: rrggbbaa\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "timestr") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "timestr") == 0) {
|
||||
//read in to timestr
|
||||
if (strlen(optarg) > 31) {
|
||||
errx(1, "time format string can be at most 31 characters\n");
|
||||
}
|
||||
strcpy(time_format,optarg);
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "datestr") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "datestr") == 0) {
|
||||
//read in to datestr
|
||||
if (strlen(optarg) > 31) {
|
||||
errx(1, "time format string can be at most 31 characters\n");
|
||||
}
|
||||
strcpy(date_format,optarg);
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "timefont") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "timefont") == 0) {
|
||||
//read in to time_font
|
||||
if (strlen(optarg) > 31) {
|
||||
errx(1, "time font string can be at most 31 characters\n");
|
||||
}
|
||||
strcpy(time_font,optarg);
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "datefont") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "datefont") == 0) {
|
||||
//read in to date_font
|
||||
if (strlen(optarg) > 31) {
|
||||
errx(1, "date font string can be at most 31 characters\n");
|
||||
}
|
||||
strcpy(date_font,optarg);
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "timesize") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "timesize") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
if (sscanf(arg, "%lf", &time_size) != 1)
|
||||
|
@ -1203,7 +1201,7 @@ int main(int argc, char *argv[]) {
|
|||
if (time_size < 1)
|
||||
errx(1, "timesize must be larger than 0\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "datesize") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "datesize") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
if (sscanf(arg, "%lf", &date_size) != 1)
|
||||
|
@ -1211,7 +1209,7 @@ int main(int argc, char *argv[]) {
|
|||
if (date_size < 1)
|
||||
errx(1, "datesize must be larger than 0\n");
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "indpos") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "indpos") == 0) {
|
||||
//read in to ind_x_expr and ind_y_expr
|
||||
if (strlen(optarg) > 31) {
|
||||
// this is overly restrictive since both the x and y string buffers have size 32, but it's easier to check.
|
||||
|
@ -1222,7 +1220,7 @@ int main(int argc, char *argv[]) {
|
|||
errx(1, "indpos must be of the form x:y\n");
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "timepos") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "timepos") == 0) {
|
||||
//read in to time_x_expr and time_y_expr
|
||||
if (strlen(optarg) > 31) {
|
||||
// this is overly restrictive since both the x and y string buffers have size 32, but it's easier to check.
|
||||
|
@ -1233,7 +1231,7 @@ int main(int argc, char *argv[]) {
|
|||
errx(1, "timepos must be of the form x:y\n");
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "datepos") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "datepos") == 0) {
|
||||
//read in to date_x_expr and date_y_expr
|
||||
if (strlen(optarg) > 31) {
|
||||
// this is overly restrictive since both the x and y string buffers have size 32, but it's easier to check.
|
||||
|
@ -1244,7 +1242,7 @@ int main(int argc, char *argv[]) {
|
|||
errx(1, "datepos must be of the form x:y\n");
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "refresh-rate") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "refresh-rate") == 0) {
|
||||
char* arg = optarg;
|
||||
refresh_rate = strtof(arg, NULL);
|
||||
if (refresh_rate < 1.0) {
|
||||
|
@ -1252,16 +1250,16 @@ int main(int argc, char *argv[]) {
|
|||
refresh_rate = 1.0;
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "composite") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "composite") == 0) {
|
||||
composite = true;
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "veriftext") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "veriftext") == 0) {
|
||||
verif_text = optarg;
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "wrongtext") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "wrongtext") == 0) {
|
||||
wrong_text = optarg;
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "textsize") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "textsize") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
if (sscanf(arg, "%lf", &text_size) != 1)
|
||||
|
@ -1271,7 +1269,7 @@ int main(int argc, char *argv[]) {
|
|||
text_size = 28.0;
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "modsize") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "modsize") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
if (sscanf(arg, "%lf", &modifier_size) != 1)
|
||||
|
@ -1281,7 +1279,7 @@ int main(int argc, char *argv[]) {
|
|||
modifier_size = 14.0;
|
||||
}
|
||||
}
|
||||
else if (strcmp(longopts[optind].name, "radius") == 0) {
|
||||
else if (strcmp(longopts[longoptind].name, "radius") == 0) {
|
||||
char *arg = optarg;
|
||||
|
||||
if (sscanf(arg, "%lf", &circle_radius) != 1)
|
||||
|
@ -1372,20 +1370,24 @@ int main(int argc, char *argv[]) {
|
|||
if (!load_keymap())
|
||||
errx(EXIT_FAILURE, "Could not load keymap");
|
||||
|
||||
#if XKBCOMPOSE == 1
|
||||
const char *locale = getenv("LC_ALL");
|
||||
if (!locale)
|
||||
if (!locale || !*locale)
|
||||
locale = getenv("LC_CTYPE");
|
||||
if (!locale)
|
||||
fprintf(stderr, "Locale get (lc_ctype): %s\n", locale);
|
||||
if (!locale || !*locale)
|
||||
locale = getenv("LANG");
|
||||
if (!locale) {
|
||||
fprintf(stderr, "Locale get (lang): %s\n", locale);
|
||||
if (!locale || !*locale) {
|
||||
if (debug_mode)
|
||||
fprintf(stderr, "Can't detect your locale, fallback to C\n");
|
||||
locale = "C";
|
||||
}
|
||||
|
||||
setlocale(LC_ALL, locale);
|
||||
|
||||
//#if XKBCOMPOSE == 1
|
||||
load_compose_table(locale);
|
||||
#endif
|
||||
//#endif
|
||||
|
||||
xinerama_init();
|
||||
xinerama_query_screens();
|
||||
|
|
Loading…
Reference in a new issue