implemented djb hash matching and multiple flag name matches

This commit is contained in:
Valerie Wolfe 2024-03-22 20:09:30 -04:00
parent efbb098ed9
commit 127cbc8274

130
main.c
View file

@ -32,22 +32,32 @@ void help() {
"usage: pride [name]\n\n"
"flag names:\n"
INDENT AROACE "\n"
INDENT BISEXUAL "\n"
INDENT GAY "\n"
INDENT LESBIAN "\n"
INDENT NONBINARY "\n"
INDENT PANSEXUAL "\n"
INDENT RAINBOW "\n"
INDENT TRANSGENDER "\n"
" aroace\n"
" bisexual\n"
" gay\n"
" lesbian\n"
" nonbinary\n"
" pansexual\n"
" rainbow\n"
" transgender\n"
);
}
unsigned long djb_hash(unsigned char *string) {
unsigned long output = 5381;
int c;
while(c = *string++)
output = ((output << 5) + output) + c;
return output;
}
int main(int argc, char **argv) {
// get argv[1] or fall back to RAINBOW
char *flag;
if(argc > 1) { flag = argv[1]; }
else { flag = RAINBOW; }
else { flag = ""; }
int color_mode = 0;
@ -60,67 +70,71 @@ int main(int argc, char **argv) {
return 0;
}
if(strcmp(flag, RAINBOW) == 0) { // - RAINBOW -
if(color_mode)
rainbow_256();
else
rainbow_8();
}
unsigned long flag_hash = djb_hash(flag);
else if(strcmp(flag, AROACE) == 0) { // - ARO/ACE -
if(color_mode)
aroace_256();
else
aroace_8();
}
char *output;
switch(flag_hash) {
// - RAINBOW -
case 229480993726103lu: // 'rainbow'
case 5381lu: // (empty)
if(color_mode) rainbow_256();
else rainbow_8();
break;
else if(strcmp(flag, BISEXUAL) == 0) { // - BISEXUAL -
if(color_mode)
bisexual_256();
else
bisexual_8();
}
// - ARO/ACE -
case 6953324567312lu: // 'aroace'
case 22945708850429lu: // 'aro-ace'
if(color_mode) aroace_256();
else aroace_8();
break;
else if(strcmp(flag, GAY) == 0) { // - GAY -
if(color_mode)
gay_256();
else
gay_8();
}
// - BISEXUAL -
case 7572201611094690lu: // 'bisexual'
case 5863248lu: // 'bi'
if(color_mode) bisexual_256();
else bisexual_8();
break;
else if(strcmp(flag, LESBIAN) == 0) { // - LESBIAN -
if(color_mode)
lesbian_256();
else
lesbian_8();
}
// - GAY -
case 193492486lu: // 'gay'
case 193499371lu: // 'mlm'
if(color_mode) gay_256();
else gay_8();
break;
else if(strcmp(flag, NONBINARY) == 0) { // - NONBINARY -
if(color_mode)
nonbinary_256();
else
nonbinary_8();
}
// - LESBIAN -
case 229473412894979lu: // 'lesbian'
case 193510271lu: // 'wlw'
if(color_mode) lesbian_256();
else lesbian_8();
break;
else if(strcmp(flag, PANSEXUAL) == 0) { // - PANSEXUAL -
if(color_mode)
pansexual_256();
else
pansexual_8();
}
// - NONBINARY -
case 249899779187415445lu: // 'nonbinary'
case 5863637lu: // 'nb'
if(color_mode) nonbinary_256();
else nonbinary_8();
break;
else if(strcmp(flag, TRANSGENDER) == 0) { // - TRANSGENDER -
if(color_mode)
transgender_256();
else
transgender_8();
}
// - PANSEXUAL -
case 249901996007388822lu: // 'pansexual'
case 193502276lu: // 'pan'
if(color_mode) pansexual_256();
else nonbinary_8();
break;
// - TRANSGENDER -
case 13895753452281080578lu: // 'transgender'
case 210729322765lu: // 'trans'
if(color_mode) transgender_256();
else transgender_8();
break;
else {
default:
printf("pride-c: no flag '%s' found.", flag);
return 1;
}
printf(RESET);
return 0;
}