Blaze (he/him)@lemmy.cafe to Stardew Valley@lemm.eeEnglish · 2 months agoSomeone ported the code for the Stardew Valley name generator to the Webstardewna.meexternal-linkmessage-square9fedilinkarrow-up146arrow-down10file-text
arrow-up146arrow-down1external-linkSomeone ported the code for the Stardew Valley name generator to the Webstardewna.meBlaze (he/him)@lemmy.cafe to Stardew Valley@lemm.eeEnglish · 2 months agomessage-square9fedilinkfile-text
minus-squareSatyrSacklinkfedilinkEnglisharrow-up4·edit-22 months agoFor fun, I just ported it to Python source from random import random from math import floor strings_start = [ "B", "Br", "C", "Ch", "F", "Fr", "G", "Gr", "K", "J", "L", "M", "N", "P", "Pr", "R", "S", "Sh", "Sn", "St", "T", "Tr", "W", "Z" ] strings_connective = [ "c", "l", "ll", "m", "n", "p", "r", "s", "t", "rt", "tch", "ts" ] strings_end = [ "a", "ers", "ie", "ley", "o" ] strings_vowel = [ "a", "e", "i", "o", "u" ] strings_expletive = [ 'bitch', 'cock', 'cum', 'fuck', 'goock', 'gook', 'kike', 'nigg', 'pusie', 'puss', 'rape', 'sex', 'shit', 'taboo', 'trann', 'willy' ] dictionary_vowel_1 = { "a": [ "bell", "bella", "bo", "boo", "nie", "s" ], "e": [ "", "ll", "llo", "o" ], "i": [ "a", "bo", "ba", "ca", "ck", "co", "e", "la", "lo", "mi" "na", "no", "ni", "o", "que", "ta", "to", "zor", ], "o": [ "da", "dy", "la", "lo", "mo", "nie", "ny", "o", "ra", "s", "ver", "ze" ], "u": [ "", "mo", "rt", "s" ] } dictionary_vowel_2 = { "a": [ "-bell", "bo", "boo", "ck", "ishe", "lbert", "nny", "rk", "sh", "sko", "sper", "trina" ], "e": [ "cardo", "ffe", "lla", "llo", "ppa", "ppo", "rnard", "tch", "x" ], "i": [ "ana", "card", "cky", "lbert", "lbo", "llard", "lly", "msy", "nana", "nano", "ne", "nnie", "nono", "nsy", "rda", "rdo", "sh", "skers", ], "o": [ "-mo", "cco", "do", "la", "llo", "ma", "na", "nie", "ng", "ngus", "ny", "ra", "ver", "z", "ze", "zzy" ], "u": [ "bba", "bbie", "cky", "ffy", "mby", "mbo", "mbus", "ngus", "rt", "ssie", "s" ] } def random_num(num_1, num_2 = None): return floor(random() * num_1) if num_2 == None else floor(random() * (num_2 - num_1)) + num_1 def random_name(): num = random_num(3, 6) # Get start of string output_name = strings_start[random_num(len(strings_start) - 1)] # Add some chars from array 2 or array 3 for index in range(num): if index % 2 == 0: output_name += strings_vowel[random_num(len(strings_vowel))] else: output_name += strings_connective[random_num(len(strings_connective))] # Stop if greater than the number if len(output_name) >= num: break last_letter = output_name[-1] # if last letter is not a vowel and 50% chance, add some letters if random() < 0.5 and (last_letter not in strings_vowel): output_name += strings_end[random_num(len(strings_end))] # otherwise if the last letter is a vowel elif last_letter in strings_vowel: # if 80 percent chance if random() < 0.8: # if it's short add something from voweldict2 if len(output_name) <= 3: value_max = len(dictionary_vowel_2[last_letter]) - 1 suffix = dictionary_vowel_2[last_letter][random_num(value_max)] # if it's long add something from voweldict1 else: value_max = len(dictionary_vowel_1[last_letter]) - 1 suffix = dictionary_vowel_1[last_letter][random_num(value_max)] output_name += suffix # otherwise add a vowel else: output_name += strings_vowel[random_num(len(strings_vowel))] # from end of the output_name, every character inserted = 0 for index in reversed(range(1, len(output_name))): index -= inserted # if the target letter and the letter two indices back are both vowels if output_name[index] in strings_vowel and output_name[index - 2] in strings_vowel: # find the letter in between and add a letter to it # so "noco" turns into "nocko" etc char_target = output_name[index - 1] match char_target: case 'c' | 'r': output_name = output_name[:index] + 'k' + output_name[index:] inserted += 1 case 'l': output_name = output_name[:index] + 'n' + output_name[index:] inserted += 1 # small percent chance of doubling the string if it's short, a la kaka or ka-ka if len(output_name) <= 3 and random() < 0.1: output_name += output_name if random() < 0.5 else '-' + output_name # if name is short and has an e at the end, add an m, p, or b if len(output_name) <= 2 and output_name[-1] == 'e': output_name += 'm' if random() < 0.3 else 'p' if random() < 0.5 else 'b' # if generated name contains an expletive, try again for expletive in strings_expletive: if expletive in output_name.lower(): output_name = random_name() break return output_name if __name__ == '__main__': print(random_name())
minus-squaresag@lemm.eeMlinkfedilinkarrow-up3·edit-22 months agoCool, I am gonna put in on my Codeberg. It’s now our code. XD
For fun, I just ported it to Python
source
from random import random from math import floor strings_start = [ "B", "Br", "C", "Ch", "F", "Fr", "G", "Gr", "K", "J", "L", "M", "N", "P", "Pr", "R", "S", "Sh", "Sn", "St", "T", "Tr", "W", "Z" ] strings_connective = [ "c", "l", "ll", "m", "n", "p", "r", "s", "t", "rt", "tch", "ts" ] strings_end = [ "a", "ers", "ie", "ley", "o" ] strings_vowel = [ "a", "e", "i", "o", "u" ] strings_expletive = [ 'bitch', 'cock', 'cum', 'fuck', 'goock', 'gook', 'kike', 'nigg', 'pusie', 'puss', 'rape', 'sex', 'shit', 'taboo', 'trann', 'willy' ] dictionary_vowel_1 = { "a": [ "bell", "bella", "bo", "boo", "nie", "s" ], "e": [ "", "ll", "llo", "o" ], "i": [ "a", "bo", "ba", "ca", "ck", "co", "e", "la", "lo", "mi" "na", "no", "ni", "o", "que", "ta", "to", "zor", ], "o": [ "da", "dy", "la", "lo", "mo", "nie", "ny", "o", "ra", "s", "ver", "ze" ], "u": [ "", "mo", "rt", "s" ] } dictionary_vowel_2 = { "a": [ "-bell", "bo", "boo", "ck", "ishe", "lbert", "nny", "rk", "sh", "sko", "sper", "trina" ], "e": [ "cardo", "ffe", "lla", "llo", "ppa", "ppo", "rnard", "tch", "x" ], "i": [ "ana", "card", "cky", "lbert", "lbo", "llard", "lly", "msy", "nana", "nano", "ne", "nnie", "nono", "nsy", "rda", "rdo", "sh", "skers", ], "o": [ "-mo", "cco", "do", "la", "llo", "ma", "na", "nie", "ng", "ngus", "ny", "ra", "ver", "z", "ze", "zzy" ], "u": [ "bba", "bbie", "cky", "ffy", "mby", "mbo", "mbus", "ngus", "rt", "ssie", "s" ] } def random_num(num_1, num_2 = None): return floor(random() * num_1) if num_2 == None else floor(random() * (num_2 - num_1)) + num_1 def random_name(): num = random_num(3, 6) # Get start of string output_name = strings_start[random_num(len(strings_start) - 1)] # Add some chars from array 2 or array 3 for index in range(num): if index % 2 == 0: output_name += strings_vowel[random_num(len(strings_vowel))] else: output_name += strings_connective[random_num(len(strings_connective))] # Stop if greater than the number if len(output_name) >= num: break last_letter = output_name[-1] # if last letter is not a vowel and 50% chance, add some letters if random() < 0.5 and (last_letter not in strings_vowel): output_name += strings_end[random_num(len(strings_end))] # otherwise if the last letter is a vowel elif last_letter in strings_vowel: # if 80 percent chance if random() < 0.8: # if it's short add something from voweldict2 if len(output_name) <= 3: value_max = len(dictionary_vowel_2[last_letter]) - 1 suffix = dictionary_vowel_2[last_letter][random_num(value_max)] # if it's long add something from voweldict1 else: value_max = len(dictionary_vowel_1[last_letter]) - 1 suffix = dictionary_vowel_1[last_letter][random_num(value_max)] output_name += suffix # otherwise add a vowel else: output_name += strings_vowel[random_num(len(strings_vowel))] # from end of the output_name, every character inserted = 0 for index in reversed(range(1, len(output_name))): index -= inserted # if the target letter and the letter two indices back are both vowels if output_name[index] in strings_vowel and output_name[index - 2] in strings_vowel: # find the letter in between and add a letter to it # so "noco" turns into "nocko" etc char_target = output_name[index - 1] match char_target: case 'c' | 'r': output_name = output_name[:index] + 'k' + output_name[index:] inserted += 1 case 'l': output_name = output_name[:index] + 'n' + output_name[index:] inserted += 1 # small percent chance of doubling the string if it's short, a la kaka or ka-ka if len(output_name) <= 3 and random() < 0.1: output_name += output_name if random() < 0.5 else '-' + output_name # if name is short and has an e at the end, add an m, p, or b if len(output_name) <= 2 and output_name[-1] == 'e': output_name += 'm' if random() < 0.3 else 'p' if random() < 0.5 else 'b' # if generated name contains an expletive, try again for expletive in strings_expletive: if expletive in output_name.lower(): output_name = random_name() break return output_name if __name__ == '__main__': print(random_name())
Cool, I am gonna put in on my Codeberg. It’s now our code. XD
Feel free. I claim no ownership