OpenTTD/table/namegen.h

2587 lines
34 KiB
C
Raw Blame History

#include "../stdafx.h"
#include "../ttd.h"
static const char *name_original_english_1[] = {
"Great ",
"Little ",
"New ",
"Fort ",
};
static const char *name_original_english_2[] = {
"Wr",
"B",
"C",
"Ch",
"Br",
"D",
"Dr",
"F",
"Fr",
"Fl",
"G",
"Gr",
"H",
"L",
"M",
"N",
"P",
"Pr",
"Pl",
"R",
"S",
"S",
"Sl",
"T",
"Tr",
"W"
};
static const char *name_original_english_3[] = {
"ar",
"a",
"e",
"in",
"on",
"u",
"un",
"en"
};
static const char *name_original_english_4[] = {
"n",
"ning",
"ding",
"d",
"",
"t"
"fing"
};
static const char *name_original_english_5[] = {
"ville",
"ham",
"field",
"ton",
"town",
"bridge",
"bury",
"wood",
"ford",
"hall",
"ston",
"way",
"stone",
"borough",
"ley",
"head",
"bourne",
"pool",
"worth",
"hill",
"well",
"hattan",
"burg",
};
static const char *name_original_english_6[] = {
"-on-sea",
" Bay",
" Market",
" Cross",
" Bridge",
" Falls",
" City",
" Ridge",
" Springs"
};
static const char *name_additional_english_prefix[] = {
"Great ",
"Little ",
"New ",
"Fort ",
"St. ",
"Old "
};
static const char *name_additional_english_1a[] = {
"Pen",
"Lough",
"Stam",
"Aber",
"Acc",
"Ex",
"Ax",
"Bre",
"Cum",
"Dun",
"Fin",
"Inver",
"Kin",
"Mon",
"Nan",
"Nant",
"Pit",
"Pol",
"Pont",
"Strath",
"Tre",
"Tilly",
"Beck",
"Canter",
"Bath",
"Liver",
"Mal",
"Ox",
"Bletch",
"Maccles",
"Grim",
"Wind",
"Sher",
"Gates",
"Orp",
"Brom",
"Lewis",
"Whit",
"White",
"Worm",
"Tyne",
"Avon",
"Stan"
};
static const char *name_additional_english_1b1[] = {
"Wr",
"B",
"C",
"Ch",
"Br",
"D",
"Dr",
"F",
"Fr",
"Fl",
"G",
"Gr",
"H",
"L",
"M",
"N",
"P",
"Pr",
"Pl",
"R",
"S",
"S",
"Sl",
"T",
"Tr",
"W"
};
static const char *name_additional_english_1b2[] = {
"ar",
"a",
"e",
"in",
"on",
"u",
"o",
"ee",
"es",
"ea",
"un",
"en"
};
static const char *name_additional_english_1b3a[] = {
"n",
"d",
"",
"t",
"",
""
};
static const char *name_additional_english_1b3b[] = {
"ning",
"ding",
"fing"
};
static const char *name_additional_english_2[] = {
"ville",
"ham",
"field",
"ton",
"town",
"borough",
"bridge",
"bury",
"wood",
"ditch",
"ford",
"hall",
"dean",
"leigh",
"dore",
"ston",
"stow",
"church",
"wich",
"low",
"way",
"stone",
"minster",
"ley",
"head",
"bourne",
"pool",
"worth",
"hill",
"well",
"hattan",
"burg",
"berg",
"burgh",
"port",
"stoke",
"haven",
"stable",
"stock",
"side",
"brook",
"don",
"den",
"down",
"nor",
"grove",
"combe",
"by",
"say",
"ney",
"chester",
"dale",
"ness",
"shaw",
"thwaite"
};
static const char *name_additional_english_3[] = {
"-on-sea",
" Bay",
" Market",
" Beeches",
" Common",
" Park",
" Heath",
" Marsh",
" Green",
" Castle",
" End",
" Rivers",
" Cross",
" Bridge",
" Falls",
" City",
" Ridge",
" Springs"
};
static const char *name_austrian_a1[] = {
"Bad ",
"Deutsch ",
"Gross ",
"Klein ",
"Markt ",
"Maria "
};
static const char *name_austrian_a2[] = {
"Aus",
"Alten",
"Braun",
"V<EFBFBD>sl",
"Mittern",
"Nuss",
"Neu",
"Walters",
"Breiten",
"Eisen",
"Feld",
"Mittern",
"Gall",
"Obern",
"Grat",
"Heiligen",
"Hof",
"Holla",
"Stein",
"Eber",
"Eggen",
"Enzers",
"Frauen",
"Herren",
"Hof",
"H<EFBFBD>tt",
"Kaisers",
"K<EFBFBD>nigs",
"Knittel",
"Lang",
"Ober",
"Ollers",
"Pfaffen",
"Potten",
"Salz",
"Schwarz",
"Stocker",
"Unter",
"Utten",
"V<EFBFBD>sen",
"Vill",
"Weissen"
};
static const char *name_austrian_a3[] = {
"see",
"bach",
"dorf",
"ach",
"stein",
"hofen",
"au",
"ach",
"kirch",
"kirchen",
"kreuz",
"brunn",
"siedl",
"markt",
"wang",
"haag"
};
static const char *name_austrian_a4[] = {
"Bruck",
"Brunn",
"Gams",
"Grein",
"Ried",
"Faak",
"Zell",
"Spital",
"Kirchberg",
"Saal",
"Taferl",
"Wald"
};
static const char *name_austrian_a5[] = {
"St. ",
"Sankt "
};
static const char *name_austrian_a6[] = {
"Aegyd",
"Andr<EFBFBD>",
"Georgen",
"Jakob",
"Johann",
"Leonhard",
"Marein",
"Lorenzen",
"Margarethen",
"Martin",
"Michael",
"Nikolai",
"Oswald",
"Peter",
"P<EFBFBD>lten",
"Stefan",
"Stephan",
"Thomas",
"Veit",
"Wolfgang"
};
static const char *name_austrian_f1[] = {
" an der ",
" ob der "
};
static const char *name_austrian_f2[] = {
"Donau",
"Steyr",
"Lafnitz",
"Leitha",
"Thaya",
"Gail",
"Drau",
"Salzach",
"Ybbs",
"Traisen",
"Enns",
"Mur",
"Ill"
};
static const char *name_austrian_b1[] = {
" am "
};
static const char *name_austrian_b2[] = {
"Brenner",
"Dachstein",
"Gebirge",
"Grossglockner",
"Hausruck",
"Semmering",
"Wagram",
"Wechsel",
"Wilden Kaiser",
"Ziller"
};
static const char *name_german_real[] = {
"Berlin",
"Bonn",
"Bremen",
"Cottbus",
"Chemnitz",
"Dortmund",
"Dresden",
"Erfurt",
"Erlangen",
"Essen",
"Fulda",
"Gera",
"Kassel",
"Kiel",
"K<EFBFBD>ln",
"L<EFBFBD>beck",
"Magdeburg",
"M<EFBFBD>nchen",
"Potsdam",
"Stuttgart",
"Wiesbaden"
};
static const char *name_german_pre[] = {
"Bad ",
"Klein ",
"Neu "
};
static const char *name_german_1[] = {
"Alb",
"Als",
"Ander",
"Arns",
"Bruns",
"Bam",
"Biele",
"Cloppen",
"Co",
"Duis",
"D<EFBFBD>ssel",
"Dannen",
"Elb",
"Els",
"Elster",
"Eichen",
"Ems",
"Fahr",
"Falken",
"Flens",
"Frank",
"Frei",
"Freuden",
"Fried",
"F<EFBFBD>rsten",
"Hahn",
"Ham",
"Harz",
"Heidel",
"Hers",
"Herz",
"Holz",
"Hildes",
"Inns",
"Ilsen",
"Ingols",
"Kel",
"Kies",
"Korn",
"Kor",
"Kreuz",
"Kulm",
"Langen",
"Lim",
"Lohr",
"L<EFBFBD>ne",
"Mel",
"Michels",
"M<EFBFBD>hl",
"Naum",
"Nest",
"Nord",
"Nort",
"Nien",
"Nidda",
"Nieder",
"N<EFBFBD>rn",
"Ober",
"Offen",
"Osna",
"Olden",
"Ols",
"Oranien",
"Pader",
"Quedlin",
"Quer",
"Ravens",
"Regens",
"Rott",
"Ros",
"R<EFBFBD>ssels",
"Saal",
"Saar",
"Salz",
"Sch<EFBFBD>ne",
"Schwein",
"Sonder",
"Sonnen",
"Stein",
"Strals",
"Straus",
"S<EFBFBD>d",
"Ton",
"Unter",
"Ur",
"Vor",
"Wald",
"War",
"Wert",
"Wester",
"Witten",
"Wolfs",
"W<EFBFBD>rz"
};
static const char *name_german_2[] = {
"bach",
"berg",
"br<EFBFBD>ck",
"br<EFBFBD>cken",
"burg",
"dorf",
"feld",
"furt",
"hausen",
"haven",
"heim",
"horst",
"mund",
"m<EFBFBD>nster",
"stadt",
"wald"
};
static const char *name_german_3_an_der[] = {
" an der "
};
static const char *name_german_3_am[] = {
" am "
};
static const char *name_german_4_an_der[] = {
"Oder",
"Spree",
"Donau",
"Saale",
"Elbe"
};
static const char *name_german_4_am[] = {
"Main"
};
static const char *name_spanish_real[] = {
"Caracas",
"Maracay",
"Maracaibo",
"Velencia",
"El Dorado",
"Morrocoy",
"Cata",
"Cataito",
"Ciudad Bolivar",
"Barquisimeto",
"Merida",
"Puerto Ordaz",
"Santa Elena",
"San Juan",
"San Luis",
"San Rafael",
"Santiago",
"Barcelona",
"Barinas",
"San Cristobal",
"San Fransisco",
"San Martin",
"Guayana",
"San Carlos",
"El Limon",
"Coro",
"Corocoro",
"Puerto Ayacucho",
"Elorza",
"Arismendi",
"Trujillo",
"Carupano",
"Anaco",
"Lima",
"Cuzco",
"Iquitos",
"Callao",
"Huacho",
"Camana",
"Puerto Chala",
"Santa Cruz",
"Quito",
"Cuenca",
"Huacho",
"Tulcan",
"Esmereldas",
"Ibarra",
"San Lorenzo",
"Macas",
"Morana",
"Machala",
"Zamora",
"Latacunga",
"Tena",
"Cochabamba",
"Ascencion",
"Magdalena",
"Santa Ana",
"Manoa",
"Sucre",
"Oruro",
"Uyuni",
"Potosi",
"Tupiza",
"La Quiaca",
"Yacuiba",
"San Borja",
"Fuerte Olimpio",
"Fortin Esteros",
"Campo Grande",
"Bogota",
"El Banco",
"Zaragosa",
"Neiva",
"Mariano",
"Cali",
"La Palma",
"Andoas",
"Barranca",
"Montevideo",
"Valdivia",
"Arica",
"Temuco",
"Tocopilla",
"Mendoza",
"Santa Rosa"
};
static const char *name_french_real[] = {
"Agincourt",
"Lille",
"Dinan",
"Aubusson",
"Rodez",
"Bergerac",
"Bordeaux",
"Bayonne",
"Montpellier",
"Montelimar",
"Valence",
"Digne",
"Nice",
"Cannes",
"St. Tropez",
"Marseilles",
"Narbonne",
"S<EFBFBD>te",
"Aurillac",
"Gueret",
"Le Creusot",
"Nevers",
"Auxerre",
"Versailles",
"Meaux",
"Ch<EFBFBD>lons",
"Compi<EFBFBD>gne",
"Metz",
"Chaumont",
"Langres",
"Bourg",
"Lyons",
"Vienne",
"Grenoble",
"Toulon",
"Rennes",
"Le Mans",
"Angers",
"Nantes",
"Ch<EFBFBD>teauroux",
"Orl<EFBFBD>ans",
"Lisieux",
"Cherbourg",
"Morlaix",
"Cognac",
"Agen",
"Tulle",
"Blois",
"Troyes",
"Charolles",
"Grenoble",
"Chamb<EFBFBD>ry",
"Tours",
"St. Brieuc",
"St. Malo",
"La Rochelle",
"St. Flour",
"Le Puy",
"Vichy",
"St. Valery",
"Beaujolais",
"Narbonne",
"Albi",
"St. Valery",
"Biarritz",
"B<EFBFBD>ziers",
"N<EFBFBD>mes",
"Chamonix",
"Angoul<EFBFBD>me",
"Alen<EFBFBD>on"
};
static const char *name_silly_1[] = {
"Binky",
"Blubber",
"Bumble",
"Crinkle",
"Crusty",
"Dangle",
"Dribble",
"Flippety",
"Google",
"Muffin",
"Nosey",
"Pinker",
"Quack",
"Rumble",
"Sleepy",
"Sliggles",
"Snooze",
"Teddy",
"Tinkle",
"Twister",
"Pinker",
"Hippo",
"Itchy",
"Jelly",
"Jingle",
"Jolly",
"Kipper",
"Lazy",
"Frogs",
"Mouse",
"Quack",
"Cheeky",
"Lumpy",
"Grumpy",
"Mangle",
"Fiddle",
"Slugs",
"Noodles",
"Poodles",
"Shiver",
"Rumble",
"Pixie",
"Puddle",
"Riddle",
"Rattle",
"Rickety",
"Waffle",
"Sagging",
"Sausage",
"Egg",
"Sleepy",
"Scatter",
"Scramble",
"Silly",
"Simple",
"Trickle",
"Slippery",
"Slimey",
"Slumber",
"Soggy",
"Sliggles",
"Splutter",
"Sulky",
"Swindle",
"Swivel",
"Tasty",
"Tangle",
"Toggle",
"Trotting",
"Tumble",
"Snooze",
"Water",
"Windy",
"Amble",
"Bubble",
"Cheery",
"Cheese",
"Cockle",
"Cracker",
"Crumple",
"Teddy",
"Evil",
"Fairy",
"Falling",
"Fishy",
"Fizzle",
"Frosty",
"Griddle"
};
static const char *name_silly_2[] = {
"ton",
"bury",
"bottom",
"ville",
"well",
"weed",
"worth",
"wig",
"wick",
"wood",
"pool",
"head",
"burg",
"gate",
"bridge"
};
static const char *name_swedish_1[] = {
"Gamla ",
"Lilla ",
"Nya ",
"Stora "
};
static const char *name_swedish_2[] = {
"Boll",
"Bor",
"Ed",
"En",
"Erik",
"Es",
"Fin",
"Fisk",
"Gr<EFBFBD>n",
"Hag",
"Halm",
"Karl",
"Kram",
"Kung",
"Land",
"Lid",
"Lin",
"Mal",
"Malm",
"Marie",
"Ner",
"Norr",
"Oskar",
"Sand",
"Skog",
"Stock",
"Stor",
"Str<EFBFBD>m",
"Sund",
"S<EFBFBD>der",
"Tall",
"Tratt",
"Troll",
"Upp",
"Var",
"V<EFBFBD>ster",
"<EFBFBD>ngel",
"<EFBFBD>ster"
};
static const char *name_swedish_2a[] = {
"B",
"Br",
"D",
"Dr",
"Dv",
"F",
"Fj",
"Fl",
"Fr",
"G",
"Gl",
"Gn",
"Gr",
"H",
"J",
"K",
"Kl",
"Kn",
"Kr",
"Kv",
"L",
"M",
"N",
"P",
"Pl",
"Pr",
"R",
"S",
"Sk",
"Skr",
"Sl",
"Sn",
"Sp",
"Spr",
"St",
"Str",
"Sv",
"T",
"Tr",
"Tv",
"V",
"Vr"
};
static const char *name_swedish_2b[] = {
"a",
"e",
"i",
"o",
"u",
"y",
"<EFBFBD>",
"<EFBFBD>",
"<EFBFBD>"
};
static const char *name_swedish_2c[] = {
"ck",
"d",
"dd",
"g",
"gg",
"l",
"ld",
"m",
"n",
"nd",
"ng",
"nn",
"p",
"pp",
"r",
"rd",
"rk",
"rp",
"rr",
"rt",
"s",
"sk",
"st",
"t",
"tt",
"v"
};
static const char *name_swedish_3[] = {
"arp",
"berg",
"boda",
"borg",
"bro",
"bukten",
"by",
"byn",
"fors",
"hammar",
"hamn",
"holm",
"hus",
"h<EFBFBD>ttan",
"kulle",
"k<EFBFBD>ping",
"lund",
"l<EFBFBD>v",
"sala",
"skrona",
"sl<EFBFBD>tt",
"sp<EFBFBD>ng",
"stad",
"sund",
"svall",
"svik",
"s<EFBFBD>ker",
"udde",
"valla",
"viken",
"<EFBFBD>lv",
"<EFBFBD>s"
};
static const char *name_dutch_1[] = {
"Nieuw ",
"Oud ",
"Groot ",
"Zuid ",
"Noord ",
"Oost ",
"West ",
"Klein "
};
static const char *name_dutch_2[] = {
"Hoog",
"Laag",
"Zuider",
"Zuid",
"Ooster",
"Oost",
"Wester",
"West",
"Hoofd",
"Midden",
"Eind",
"Amster",
"Amstel",
"Dord",
"Rotter",
"Haar",
"Til",
"Enk",
"Dok",
"Veen",
"Leidsch",
"Lely",
"En",
"Kaats",
"U",
"Maas",
"Mar",
"Bla",
"Al",
"Alk",
"Eer",
"Drie",
"Ter",
"Groes",
"Goes",
"Soest",
"Coe",
"Uit",
"Zwaag",
"Hellen",
"Slie",
"IJ",
"Grubben",
"Groen",
"Lek",
"Ridder",
"Schie",
"Olde",
"Roose",
"Haar",
"Til",
"Loos",
"Hil"
};
static const char *name_dutch_3[] = {
"Drog",
"Nat",
"Valk",
"Bob",
"Dedem",
"Kollum",
"Best",
"Hoend",
"Leeuw",
"Graaf",
"Uithuis",
"Purm",
"Hard",
"Hell",
"Werk",
"Spijk",
"Vink",
"Wams",
"Heerhug",
"Koning"
};
static const char *name_dutch_4[] = {
"e",
"er",
"el",
"en",
"o",
"s"
};
static const char *name_dutch_5[] = {
"stad",
"vorst",
"dorp",
"dam",
"beek",
"doorn",
"zijl",
"zijlen",
"lo",
"muiden",
"meden",
"vliet",
"nisse",
"daal",
"vorden",
"vaart",
"mond",
"zaal",
"water",
"duinen",
"heuvel",
"geest",
"kerk",
"meer",
"maar",
"hoorn",
"rade",
"wijk",
"berg",
"heim",
"sum",
"richt",
"burg",
"recht",
"drecht",
"trecht",
"tricht",
"dricht",
"lum",
"rum",
"halen",
"oever",
"wolde",
"veen",
"hoven",
"gast",
"kum",
"hage",
"dijk",
"zwaag",
"pomp",
"huizen",
"bergen",
"schede",
"mere",
"end"
};
static const char *name_finnish_real[] = {
"Aijala",
"Kisko",
"Espoo",
"Helsinki",
"Tapiola",
"J<EFBFBD>rvel<EFBFBD>",
"Lahti",
"Kotka",
"Hamina",
"Loviisa",
"Kouvola",
"Tampere",
"Kokkola",
"Oulu",
"Salo",
"Malmi",
"Pelto",
"Koski",
"Iisalmi",
"Raisio",
"Taavetti",
"Joensuu",
"Imatra",
"Tapanila",
"Pasila"
};
static const char *name_finnish_1[] = {
"Hiekka",
"Haapa",
"Mylly",
"Kivi",
"Lappeen",
"Lohjan",
"Savon",
"Sauna",
"Keri",
"Uusi",
"Vanha",
"Lapin",
"Kes<EFBFBD>",
"Kuusi",
"Pelto",
"Tuomi",
"Pit<EFBFBD>j<EFBFBD>n",
"Terva",
"Olki",
"Hein<EFBFBD>",
"Kuusan",
"Sein<EFBFBD>",
"Kemi",
"Rova",
"Martin",
"Koivu"
};
static const char *name_finnish_2[] = {
"harju",
"linna",
"j<EFBFBD>rvi",
"kallio",
"m<EFBFBD>ki",
"nummi",
"joki",
"kyl<EFBFBD>",
"lampi",
"lahti",
"mets<EFBFBD>",
"suo",
"laakso",
"niitty",
"luoto",
"hovi",
"ranta",
"koski"
};
static const char *name_polish_1_m[] = {
"Wielki ",
"Maly ",
"Zly ",
"Dobry ",
"Nowy ",
"Stary ",
"Zloty ",
"Zielony ",
"Bialy ",
"Modry ",
"Debowy "
};
static const char *name_polish_1_f[] = {
"Wielka ",
"Mala ",
"Zla ",
"Dobra ",
"Nowa ",
"Stara ",
"Zlota ",
"Zielona ",
"Biala ",
"Modra ",
"Debowa "
};
static const char *name_polish_1_n[] = {
"Wielkie ",
"Male ",
"Zle ",
"Dobre ",
"Nowe ",
"Stare ",
"Zlote ",
"Zielone ",
"Biale ",
"Modre ",
"Debowe "
};
static const char *name_polish_2_o[] = {
"Frombork",
"Gniezno",
"Olsztyn",
"Torun",
"Bydgoszcz",
"Terespol",
"Krakow",
"Poznan",
"Wroclaw",
"Katowice",
"Cieszyn",
"Bytom",
"Frombork",
"Hel",
"Konin",
"Lublin",
"Malbork",
"Sopot",
"Sosnowiec",
"Gdansk",
"Gdynia",
"Sieradz",
"Sandomierz",
"Szczyrk",
"Szczytno",
"Szczecin",
"Zakopane",
"Szklarska Poreba",
"Bochnia",
"Golub-Dobrzyn",
"Chojnice",
"Ostrowiec",
"Otwock",
"Wolsztyn"
};
static const char *name_polish_2_m[] = {
"Jarocin",
"Gogolin",
"Tomaszow",
"Piotrkow",
"Lidzbark",
"Rypin",
"Radzymin",
"Wolomin",
"Pruszkow",
"Olsztynek",
"Rypin",
"Cisek",
"Krotoszyn",
"Stoczek",
"Lubin",
"Lubicz",
"Milicz",
"Targ",
"Ostrow",
"Ozimek",
"Puck",
"Rzepin",
"Siewierz",
"Stargard",
"Starogard",
"Turek",
"Tymbark",
"Wolsztyn",
"Strzepcz",
"Strzebielin",
"Sochaczew",
"Grebocin",
"Gniew",
"Lubliniec",
"Lubasz",
"Lutomiersk",
"Niemodlin",
"Przeworsk",
"Ursus",
"Tyczyn",
"Sztum",
"Szczebrzeszyn",
"Wolin",
"Wrzeszcz",
"Zgierz",
"Zieleniec",
"Drobin",
"Garwolin"
};
static const char *name_polish_2_f[] = {
"Szprotawa",
"Pogorzelica",
"Motlawa",
"Lubawa",
"Nidzica",
"Kruszwica",
"Bierawa",
"Brodnica",
"Chojna",
"Krzepica",
"Ruda",
"Rumia",
"Tuchola",
"Trzebinia",
"Ustka",
"Warszawa",
"Bobowa",
"Dukla",
"Krynica",
"Murowana",
"Niemcza",
"Zaspa",
"Zawoja",
"Wola",
"Limanowa",
"Rabka",
"Skawina",
"Pilawa"
};
static const char *name_polish_2_n[] = {
"Lipsko",
"Pilzno",
"Przodkowo",
"Strzelno",
"Susz",
"Jaworzno",
"Choszczno",
"Mogilno",
"Luzino",
"Miasto",
"Dziadowo",
"Kowalewo",
"Legionowo",
"Miastko",
"Zabrze",
"Zawiercie",
"Kochanowo",
"Miechucino",
"Mirachowo",
"Robakowo",
"Kosakowo",
"Borne",
"Braniewo",
"Sulinowo",
"Chmielno",
"Jastrzebie",
"Gryfino",
"Koronowo",
"Lubichowo",
"Opoczno"
};
static const char *name_polish_3_m[] = {
" Wybudowanie",
" Swietokrzyski",
" Gorski",
" Morski",
" Zdroj",
" Wody",
" Bajoro",
" Krajenski",
" Slaski",
" Mazowiecki",
" Pomorski",
" Wielki",
" Maly",
" Warminski",
" Mazurski",
" Mniejszy",
" Wiekszy",
" Gorny",
" Dolny",
" Wielki",
" Stary",
" Nowy",
" Wielkopolski",
" Wzgorze",
" Mosty",
" Kujawski",
" Malopolski",
" Podlaski",
" Lesny"
};
static const char *name_polish_3_f[] = {
" Wybudowanie",
" Swietokrzyska",
" Gorska",
" Morska",
" Zdroj",
" Woda",
" Bajoro",
" Krajenska",
" Slaska",
" Mazowiecka",
" Pomorska",
" Wielka",
" Mala",
" Warminska",
" Mazurska",
" Mniejsza",
" Wieksza",
" Gorna",
" Dolna",
" Wielka",
" Stara",
" Nowa",
" Wielkopolska",
" Wzgorza",
" Mosty",
" Kujawska",
" Malopolska",
" Podlaska",
" Lesna"
};
static const char *name_polish_3_n[] = {
" Wybudowanie",
" Swietokrzyskie",
" Gorskie",
" Morskie",
" Zdroj",
" Wody",
" Bajoro",
" Krajenskie",
" Slaskie",
" Mazowieckie",
" Pomorskie",
" Wielkie",
" Male",
" Warminskie ",
" Mazurskie ",
" Mniejsze",
" Wieksze",
" Gorne",
" Dolne",
" Wielkie",
" Stare",
" Nowe",
" Wielkopolskie",
" Wzgorze",
" Mosty",
" Kujawskie",
" Malopolskie",
" Podlaskie",
" Lesne"
};
static const char *name_czech_real[] = {
"As",
"Benesov",
"Beroun",
"Bezdruzice",
"Blansko",
"Breclav",
"Brno",
"Brunt<EFBFBD>l",
"Cesk<EFBFBD> L<>pa",
"Cesk<EFBFBD> Budejovice",
"Cesk<EFBFBD> Krumlov",
"Dec<EFBFBD>n",
"Domazlice",
"Dub<EFBFBD>",
"Fr<EFBFBD>dek-M<>stek",
"Havl<EFBFBD>ckuv Brod",
"Hodon<EFBFBD>n",
"Hradec Kr<4B>lov<6F>",
"Humpolec",
"Cheb",
"Chomutov",
"Chrudim",
"Jablonec nad Nisou",
"Jesen<EFBFBD>k",
"Jic<EFBFBD>n",
"Jihlava",
"Jindrichuv Hradec",
"Karlovy Vary",
"Karvin<EFBFBD>",
"Kladno",
"Klatovy",
"Kol<EFBFBD>n",
"Kosmonosy",
"Kromer<EFBFBD>z",
"Kutn<EFBFBD> Hora",
"Liberec",
"Litomerice",
"Louny",
"Manet<EFBFBD>n",
"Meln<EFBFBD>k",
"Mlad<EFBFBD> Boleslav",
"Most",
"N<EFBFBD>chod",
"Nov<EFBFBD> Jic<69>n",
"Nymburk",
"Olomouc",
"Opava",
"Or<EFBFBD>cov",
"Ostrava",
"Pardubice",
"Pelhrimov",
"Polzice",
"P<EFBFBD>sek",
"Plzen",
"Praha",
"Prachatice",
"Prerov",
"Pr<EFBFBD>bram",
"Prostejov",
"Rakovn<EFBFBD>k",
"Rokycany",
"Rudn<EFBFBD>",
"Rychnov nad Kneznou",
"Semily",
"Sokolov",
"Strakonice",
"Stredokluky",
"Sumperk",
"Svitavy",
"T<EFBFBD>bor",
"Tachov",
"Teplice",
"Treb<EFBFBD>c",
"Trutnov",
"Uhersk<EFBFBD> Hradiste",
"<EFBFBD>st<EFBFBD> nad Labem",
"<EFBFBD>st<EFBFBD> nad Orlic<69>",
"Vset<EFBFBD>n",
"Vyskov",
"Zd<EFBFBD>r nad S<>zavou",
"Zl<EFBFBD>n",
"Znojmo"
};
/* The advanced hyperintelligent Czech town names generator! */
/* The tables and MakeCzechTownName() is (c) Petr Baudis 2005 (GPL'd)
* Feel free to ask me about anything unclear or if you need help
* with cloning this for your own language. */
// Sing., pl.
enum CzechGender {
CZG_SMASC,
CZG_SFEM,
CZG_SNEUT,
CZG_PMASC,
CZG_PFEM,
CZG_PNEUT,
// Special for substantive stems - the ending chooses the gender.
CZG_FREE,
// Like CZG_FREE, but disallow CZG_SNEUT.
CZG_NFREE
};
enum CzechPattern {
CZP_JARNI,
CZP_MLADY,
CZP_PRIVL
};
/* [CzechGender][CzechPattern] - replaces the last character of the adjective
* by this. */
// XXX: [CZG_SMASC][CZP_PRIVL] needs special handling: -ovX -> -uv.
static const char name_czech_patmod[6][3] = {
/* CZG_SMASC */ { '<EFBFBD>', '<EFBFBD>', 'X' },
/* CZG_SFEM */ { '<EFBFBD>', '<EFBFBD>', 'a' },
/* CZG_SNEUT */ { '<EFBFBD>', '<EFBFBD>', 'o' },
/* CZG_PMASC */ { '<EFBFBD>', '<EFBFBD>', 'y' },
/* CZG_PFEM */ { '<EFBFBD>', '<EFBFBD>', 'y' },
/* CZG_PNEUT */ { '<EFBFBD>', '<EFBFBD>', 'a' }
};
// This way the substantives can choose only some adjectives/endings:
// At least one of these flags must be satisfied:
enum CzechAllow {
CZA_SHORT = 1,
CZA_MIDDLE = 2,
CZA_LONG = 4,
CZA_ALL = ~0
};
// All these flags must be satisfied (in the stem->others direction):
enum CzechChoose {
CZC_NONE = 0, // No requirements.
CZC_COLOR = 1,
CZC_POSTFIX = 2, // Matched if postfix was inserted.
CZC_NOPOSTFIX = 4, // Matched if no postfix was inserted.
CZC_ANY = ~0
};
struct CzechNameSubst {
enum CzechGender gender;
enum CzechAllow allow;
enum CzechChoose choose;
const char *name;
};
struct CzechNameAdj {
enum CzechPattern pattern;
enum CzechChoose choose;
const char *name;
};
// Some of items which should be common are doubled.
static const struct CzechNameAdj name_czech_adj[] = {
{ CZP_JARNI, CZC_ANY, "Horn<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Horn<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Doln<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Doln<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Predn<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Zadn<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Kosteln<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "Havran<EFBFBD>" },
{ CZP_JARNI, CZC_ANY, "R<EFBFBD>cn<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Velk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Velk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Mal<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Mal<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Vysok<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Cesk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Moravsk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Slov<EFBFBD>ck<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Uhersk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Star<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Star<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Nov<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Nov<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Mlad<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Kr<EFBFBD>lovsk<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Kamenn<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Cihlov<EFBFBD>" },
{ CZP_MLADY, CZC_ANY, "Divn<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Cerven<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Cerven<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Zelen<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Zlut<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Siv<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Sed<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "B<EFBFBD>l<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Modr<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Ruzov<EFBFBD>" },
{ CZP_MLADY, CZC_COLOR, "Cern<EFBFBD>" },
{ CZP_PRIVL, CZC_ANY, "Kr<EFBFBD>lova" },
{ CZP_PRIVL, CZC_ANY, "Janova" },
{ CZP_PRIVL, CZC_ANY, "Karlova" },
{ CZP_PRIVL, CZC_ANY, "Krystofova" },
{ CZP_PRIVL, CZC_ANY, "Jir<EFBFBD>kova" },
{ CZP_PRIVL, CZC_ANY, "Petrova" },
{ CZP_PRIVL, CZC_ANY, "Sudovo" },
};
// Considered a stem for choose/allow matching purposes.
static const struct CzechNameSubst name_czech_subst_full[] = {
{ CZG_SMASC, CZA_ALL, CZC_COLOR, "Sedlec" },
{ CZG_SMASC, CZA_ALL, CZC_COLOR, "Brod" },
{ CZG_SMASC, CZA_ALL, CZC_COLOR, "Brod" },
{ CZG_SMASC, CZA_ALL, CZC_NONE, "<EFBFBD>val" },
{ CZG_SMASC, CZA_ALL, CZC_COLOR, "Zd<EFBFBD>r" },
{ CZG_SFEM, CZA_ALL, CZC_COLOR, "Hora" },
{ CZG_SFEM, CZA_ALL, CZC_COLOR, "Lhota" },
{ CZG_SFEM, CZA_ALL, CZC_COLOR, "Lhota" },
{ CZG_SFEM, CZA_ALL, CZC_COLOR, "Hlava" },
{ CZG_SNEUT, CZA_ALL, CZC_COLOR, "Pole" },
{ CZG_SNEUT, CZA_ALL, CZC_COLOR, "<EFBFBD>dol<EFBFBD>" },
{ CZG_PMASC, CZA_ALL, CZC_NONE, "<EFBFBD>valy" },
{ CZG_PFEM, CZA_ALL, CZC_COLOR, "Luka" },
{ CZG_PNEUT, CZA_ALL, CZC_COLOR, "Pole" },
};
// TODO: More stems needed. --pasky
static const struct CzechNameSubst name_czech_subst_stem[] = {
{ CZG_SMASC, CZA_MIDDLE, CZC_COLOR, "Kostel" },
{ CZG_SMASC, CZA_MIDDLE, CZC_COLOR, "Kl<EFBFBD>ster" },
{ CZG_SMASC, CZA_SHORT, CZC_COLOR, "Lhot" },
{ CZG_SFEM, CZA_SHORT, CZC_COLOR, "Lhot" },
{ CZG_SFEM, CZA_SHORT, CZC_COLOR, "Hur" },
{ CZG_FREE, CZA_MIDDLE | CZA_LONG, CZC_NONE, "Sedl" },
{ CZG_FREE, CZA_SHORT | CZA_MIDDLE | CZA_LONG, CZC_COLOR, "Hrad" },
{ CZG_NFREE, CZA_MIDDLE, CZC_NONE, "Pras" },
{ CZG_NFREE, CZA_MIDDLE, CZC_NONE, "Baz" },
{ CZG_NFREE, CZA_MIDDLE, CZC_NONE, "Tes" },
{ CZG_NFREE, CZA_MIDDLE, CZC_NONE, "Uz" },
{ CZG_NFREE, CZA_MIDDLE | CZA_LONG, CZC_NONE, "Br" },
{ CZG_NFREE, CZA_MIDDLE | CZA_LONG, CZC_NONE, "Vod" },
{ CZG_NFREE, CZA_MIDDLE | CZA_LONG, CZC_NONE, "Jan" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Prach" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Kunr" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Strak" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Vit" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Vys" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Zat" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Zer" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Stred" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Harv" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Pruh" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Tach" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "P<EFBFBD>sn" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Jin" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Jes" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Jar" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Sok" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Hod" },
{ CZG_NFREE, CZA_LONG, CZC_NONE, "Net" },
{ CZG_FREE, CZA_LONG, CZC_NONE, "Praz" },
{ CZG_FREE, CZA_LONG, CZC_NONE, "Nerat" },
{ CZG_FREE, CZA_LONG, CZC_NONE, "Kral" },
{ CZG_FREE, CZA_LONG, CZC_NONE, "Hut" },
{ CZG_FREE, CZA_LONG, CZC_NOPOSTFIX, "Pan" },
{ CZG_FREE, CZA_SHORT | CZA_MIDDLE | CZA_LONG, CZC_NONE, "Odstred" },
{ CZG_FREE, CZA_SHORT | CZA_MIDDLE | CZA_LONG, CZC_COLOR, "Mrat" },
{ CZG_FREE, CZA_LONG, CZC_COLOR, "Hlav" },
{ CZG_FREE, CZA_SHORT | CZA_MIDDLE, CZC_NONE, "Mer" },
};
// Optional postfix inserted between stem and ending.
static const char *name_czech_subst_postfix[] = {
"av", "an", "at",
"ov", "on", "ot",
"ev", "en", "et",
};
// This array must have the both neutral genders at the end!
static const struct CzechNameSubst name_czech_subst_ending[] = {
{ CZG_SMASC, CZA_SHORT | CZA_MIDDLE, CZC_ANY, "ec" },
{ CZG_SMASC, CZA_SHORT | CZA_MIDDLE, CZC_ANY, "<EFBFBD>n" },
{ CZG_SMASC, CZA_SHORT | CZA_MIDDLE | CZA_LONG, CZC_ANY, "ov" },
{ CZG_SMASC, CZA_SHORT | CZA_LONG, CZC_ANY, "kov" },
{ CZG_SMASC, CZA_LONG, CZC_POSTFIX, "<EFBFBD>n" },
{ CZG_SMASC, CZA_LONG, CZC_POSTFIX, "n<EFBFBD>k" },
{ CZG_SFEM, CZA_SHORT, CZC_ANY, "ka" },
{ CZG_SFEM, CZA_MIDDLE, CZC_ANY, "inka" },
{ CZG_SFEM, CZA_MIDDLE, CZC_NOPOSTFIX, "na" },
{ CZG_SFEM, CZA_MIDDLE, CZC_ANY, "n<EFBFBD>" },
{ CZG_SFEM, CZA_LONG, CZC_ANY, "ava" },
{ CZG_PMASC, CZA_LONG, CZC_ANY, "<EFBFBD>ky" },
{ CZG_PMASC, CZA_LONG, CZC_ANY, "upy" },
{ CZG_PFEM, CZA_LONG, CZC_ANY, "avy" },
{ CZG_PFEM, CZA_SHORT | CZA_MIDDLE | CZA_LONG, CZC_ANY, "ice" },
{ CZG_PNEUT, CZA_SHORT | CZA_MIDDLE, CZC_ANY, "na" },
{ CZG_SNEUT, CZA_SHORT | CZA_MIDDLE, CZC_ANY, "no" },
{ CZG_SNEUT, CZA_LONG, CZC_ANY, "iste" },
};
static const char *name_czech_suffix[] = {
"nad Cydlinou",
"nad Dyj<79>",
"nad Jihlavou",
"nad Labem",
"nad Lesy",
"nad Moravou",
"nad Nisou",
"nad Odrou",
"nad Ostravic<69>",
"nad S<>zavou",
"nad Vltavou",
"pod Pradedem",
"pod Radhostem",
"pod R<>pem",
"pod Snezkou",
"pod Spic<69>kem",
"pod Sedlem",
};
static const char *name_romanian_real[]= {
"Adjud",
"Alba Iulia",
"Alexandria",
"Babadag",
"Bac<EFBFBD>u",
"Baia Mare",
"B<EFBFBD>ile Herculane",
"B<EFBFBD>ilesti",
"B<EFBFBD>rlad",
"Bicaz",
"Bistrita",
"Blaj",
"Borsec",
"Botosani",
"Br<EFBFBD>ila",
"Brasov",
"Bucuresti",
"Buftea",
"Buz<EFBFBD>u",
"C<EFBFBD>l<EFBFBD>rasi",
"Caransebes",
"Cernavod<EFBFBD>",
"Cluj-Napoca",
"Constanta",
"Covasna",
"Craiova",
"Dej",
"Deva",
"Dorohoi",
"Dr.-Tr. Severin",
"Dr<EFBFBD>g<EFBFBD>sani",
"F<EFBFBD>g<EFBFBD>ras",
"F<EFBFBD>lticeni",
"Fetesti",
"Focsani",
"Galati",
"Gheorgheni",
"Giurgiu",
"H<EFBFBD>rsova",
"Hunedoara",
"Husi",
"Iasi",
"Isaccea",
"Lugoj",
"M<EFBFBD>cin",
"Mangalia",
"Medgidia",
"Medias",
"Miercurea Ciuc",
"Mizil",
"Motru",
"N<EFBFBD>s<EFBFBD>ud",
"N<EFBFBD>vodari",
"Odobesti",
"Oltenita",
"Onesti",
"Oradea",
"Orsova",
"Petrosani",
"Piatra Neamt",
"Pitesti",
"Ploiesti",
"Predeal",
"R<EFBFBD>mnicu V<>lcea",
"Reghin",
"Resita",
"Roman",
"Rosiorii de Vede",
"Satu Mare",
"Sebes",
"Sf<EFBFBD>ntu Gheorghe",
"Sibiu",
"Sighisoara",
"Sinaia",
"Slatina",
"Slobozia",
"Sovata",
"Suceava",
"Sulina",
"T<EFBFBD>nd<EFBFBD>rei",
"T<EFBFBD>rgoviste",
"T<EFBFBD>rgu Jiu",
"T<EFBFBD>rgu Mures",
"Tecuci",
"Timisoara",
"Tulcea",
"Turda",
"Turnu M<>gurele",
"Urziceni",
"Vaslui",
"Vatra Dornei",
"Victoria",
"Videle",
"Zal<EFBFBD>u"
};
static const char *name_slovak_real[] = {
"Bratislava",
"Banovce nad Bebravou",
"Banska Bystrica",
"Banska Stiavnica",
"Bardejov",
"Brezno",
"Brezova pod Bradlom",
"Bytca",
"Cadca",
"Cierna nad Tisou",
"Detva",
"Detva",
"Dolny Kubin",
"Dolny Kubin",
"Dunajska Streda",
"Gabcikovo",
"Galanta",
"Gbely",
"Gelnica",
"Handlova",
"Hlohovec",
"Holic",
"Humenne",
"Hurbanovo",
"Kezmarok",
"Komarno",
"Kosice",
"Kremnica",
"Krompachy",
"Kuty",
"Leopoldov",
"Levoca",
"Liptovsky Mikulas",
"Lucenec",
"Malacky",
"Martin",
"Medzilaborce",
"Michalovce",
"Modra",
"Myjava",
"Namestovo",
"Nitra",
"Nova Bana",
"Nove Mesto nad Vahom",
"Nove Zamky",
"Partizanske",
"Pezinok",
"Piestany",
"Poltar",
"Poprad",
"Povazska Bystrica",
"Prievidza",
"Puchov",
"Revuca",
"Rimavska Sobota",
"Roznava",
"Ruzomberok",
"Sabinov",
"Sala",
"Senec",
"Senica",
"Sered",
"Skalica",
"Sladkovicovo",
"Smolenice",
"Snina",
"Stara Lubovna",
"Stara Tura",
"Strazske",
"Stropkov",
"Stupava",
"Sturovo",
"Sulekovo",
"Topolcany",
"Trebisov",
"Trencin",
"Trnava",
"Turcianske Teplice",
"Tvrdosin",
"Vrable",
"Vranov nad Toplov",
"Zahorska Bystrica",
"Zdiar",
"Ziar nad Hronom",
"Zilina",
"Zlate Moravce",
"Zvolen"
};
static const char *name_norwegian_1[] = {
"Arna",
"Aust",
"Bj<EFBFBD>rk",
"Bj<EFBFBD>rn",
"Brand",
"B<EFBFBD>ver",
"Drag",
"Dr<EFBFBD>",
"Eids",
"Egge",
"Fager",
"Finns",
"Flat",
"Foll",
"Foss",
"Fugle",
"Furu",
"Gaus",
"Galte",
"Geir",
"Gl<EFBFBD>s",
"Gran",
"Grind",
"Grims",
"Gr<EFBFBD>n",
"Gr<EFBFBD>t",
"Gulle",
"Haka",
"Hammer",
"Haug",
"Hol",
"Hon",
"Hop",
"Hov",
"Jess",
"Kabel",
"Kjerns",
"Kjerring",
"Knatte",
"Krok",
"K<EFBFBD>y",
"Lang",
"Lauv",
"Leir",
"Lund",
"Logn",
"Lo",
"Lyng",
"L<EFBFBD>n",
"Mesna",
"Mel",
"Mo",
"Nar",
"Nitte",
"Nord",
"Odd",
"Ola",
"Otte",
"Ran",
"Rev",
"Rog",
"Roms",
"Rosen",
"Sand",
"Sau",
"Sel",
"Sol",
"Sjur",
"Sk<EFBFBD>r",
"Sl<EFBFBD>tt",
"Stj<EFBFBD>r",
"Stor",
"Svart",
"Svens",
"Svin",
"Sylte",
"Syn",
"Tran",
"Vass",
"Ved",
"Vest",
"Vesle",
"Vik",
"V<EFBFBD>g"
};
static const char *name_norwegian_2[] = {
"aker",
"anger",
"bakken",
"bekk",
"berg",
"botn",
"breen",
"bu",
"bugen",
"by",
"bygd",
"b<EFBFBD>",
"dal",
"egga",
"eid",
"elv",
"enga",
"foss",
"fjell",
"fjord",
"foten",
"gard",
"grend",
"hammer",
"haug",
"havn",
"heim",
"hella",
"hovda",
"h<EFBFBD>a",
"h<EFBFBD>gda",
"kampen",
"kj<EFBFBD>len",
"kollen",
"kroken",
"land",
"lia",
"mark",
"moen",
"myr",
"nes",
"nuten",
"osen",
"rike",
"rud",
"sand",
"set",
"sj<EFBFBD>en",
"skogen",
"slette",
"snipa",
"stad",
"stua",
"stulen",
"sund",
"svingen",
"s<EFBFBD>tra",
"tinden",
"tun",
"vang",
"vatn",
"veid",
"vik",
"voll",
"v<EFBFBD>g",
"um",
"<EFBFBD>sen"
};
static const char *name_norwegian_real[] = {
"Alta",
"Arendal",
"Askim",
"Bergen",
"Bod<EFBFBD>",
"Brevik",
"Bryne",
"Br<EFBFBD>nn<EFBFBD>ysund",
"Drammen",
"Dr<EFBFBD>bak",
"Egersund",
"Elverum",
"Farsund",
"Fauske",
"Finnsnes",
"Flekkefjord",
"Flora",
"Fosnav<EFBFBD>g",
"Fredrikstad",
"F<EFBFBD>rde",
"Gj<EFBFBD>vik",
"Grimstad",
"Halden",
"Hamar",
"Hammerfest",
"Harstad",
"Haugesund",
"Holmestrand",
"Horten",
"J<EFBFBD>rpeland",
"Kirkenes",
"Kolvereid",
"Kongsberg",
"Kongsvinger",
"Kopervik",
"Krager<EFBFBD>",
"Kristiansand",
"Kristiansund",
"Langesund",
"Larvik",
"Leirvik",
"Leknes",
"Levanger",
"Lillehammer",
"Lillesand",
"Lillestr<EFBFBD>m",
"Lyngdal",
"L<EFBFBD>renskog",
"Mandal",
"Mo i Rana",
"Molde",
"Mosj<EFBFBD>en",
"Moss",
"Mysen",
"M<EFBFBD>l<EFBFBD>y",
"Namsos",
"Narvik",
"Notodden",
"Odda",
"Oslo",
"Otta",
"Porsgrunn",
"Ringerike",
"Ris<EFBFBD>r",
"Rjukan",
"Sandefjord",
"Sandnes",
"Sandnessj<EFBFBD>en",
"Sandvika",
"Sarpsborg",
"Sauda",
"Ski",
"Skien",
"Skudeneshavn",
"Sortland",
"Stathelle",
"Stavanger",
"Steinkjer",
"Stj<EFBFBD>rdal",
"Stokmarknes",
"Stord",
"Svelvik",
"Svolv<EFBFBD>r",
"Troms<EFBFBD>",
"Trondheim",
"Tvedestrand",
"T<EFBFBD>nsberg",
"Ulsteinvik",
"Vads<EFBFBD>",
"Vard<EFBFBD>",
"Verdals<EFBFBD>ra",
"<EFBFBD>krehamn",
"<EFBFBD>lesund",
"<EFBFBD>ndalsnes"
};
static const char *name_hungarian_1[] = {
"Nagy-",
"Kis-",
"Fels<EFBFBD>-",
"Als<EFBFBD>-",
"<EFBFBD>j-"
};
static const char *name_hungarian_2[] = {
"Bodrog",
"Dr<EFBFBD>va",
"Duna",
"Hej<EFBFBD>",
"Hern<EFBFBD>d",
"R<EFBFBD>ba",
"Saj<EFBFBD>",
"Szamos",
"Tisza",
"Zala",
"Balaton",
"Fert<EFBFBD>",
"Bakony",
"Cserh<EFBFBD>t",
"Bihar",
"Hajd<EFBFBD>",
"J<EFBFBD>sz",
"Kun",
"Magyar",
"N<EFBFBD>gr<EFBFBD>d",
"Ny<EFBFBD>r",
"Somogy",
"Sz<EFBFBD>kely",
"Buda",
"Gy<EFBFBD>r",
"Pest",
"Feh<EFBFBD>r",
"Cser<EFBFBD>p",
"Erd<EFBFBD>",
"Hegy",
"Homok",
"Mez<EFBFBD>",
"Puszta",
"S<EFBFBD>r",
"Cs<EFBFBD>sz<EFBFBD>r",
"Herceg",
"Kir<EFBFBD>ly",
"Nemes",
"P<EFBFBD>sp<EFBFBD>k",
"Szent",
"Alm<EFBFBD>s",
"Szilv<EFBFBD>s",
"Agg",
"Aranyos",
"B<EFBFBD>k<EFBFBD>s",
"Egyh<EFBFBD>zas",
"Gagy",
"Heves",
"Kapos",
"T<EFBFBD>pi<EFBFBD>",
"Torna",
"Vas",
"V<EFBFBD>mos",
"V<EFBFBD>s<EFBFBD>ros"
};
static const char *name_hungarian_3[] = {
"ap<EFBFBD>ti",
"b<EFBFBD>ba",
"bikk",
"dob",
"fa",
"f<EFBFBD>ld",
"hegyes",
"kak",
"kereszt",
"k<EFBFBD>rt",
"lad<EFBFBD>ny",
"m<EFBFBD>rges",
"szalonta",
"telek",
"vas",
"v<EFBFBD>lgy"
};
static const char *name_hungarian_4[] = {
"alja",
"egyh<EFBFBD>za",
"h<EFBFBD>za",
"<EFBFBD>r",
"v<EFBFBD>r"
};
static const char *name_hungarian_real[] = {
"Ajka",
"Asz<EFBFBD>d",
"Badacsony",
"Baja",
"Budapest",
"Debrecen",
"Eger",
"Fony<EFBFBD>d",
"G<EFBFBD>d<EFBFBD>ll<EFBFBD>",
"Gy<EFBFBD>r",
"Gyula",
"Karcag",
"Kecskem<EFBFBD>t",
"Keszthely",
"Kisk<EFBFBD>re",
"Kocsord",
"Kom<EFBFBD>rom",
"K<EFBFBD>szeg",
"Mak<EFBFBD>",
"Moh<EFBFBD>cs",
"Miskolc",
"<EFBFBD>zd",
"Paks",
"P<EFBFBD>pa",
"P<EFBFBD>cs",
"Polg<EFBFBD>r",
"Sarkad",
"Si<EFBFBD>fok",
"Szeged",
"Szentes",
"Szolnok",
"Tihany",
"Tokaj",
"V<EFBFBD>c",
"Z<EFBFBD>hony",
"Zirc"
};
static const char *name_swiss_real[] = {
"Aarau",
"Aesch",
"Altdorf",
"Arosa",
"Appenzell",
"Arbon",
"Altst<EFBFBD>tten",
"Baar",
"Baden",
"Bellinzona",
"Brig-Glis",
"Bienne",
"Bulle",
"Binningen",
"Burgdorf",
"Bern",
"Basel",
"B<EFBFBD>lach",
"Carouge",
"Cham",
"Chiasso",
"Chur",
"Davos",
"Del<EFBFBD>mont",
"Dietikon",
"D<EFBFBD>bendorf",
"Emmen",
"Freienbach-Pf<50>ffikon",
"Fribourg",
"Frauenfeld",
"Gen<EFBFBD>ve",
"Glarus",
"Gossau",
"Grenchen",
"Herisau",
"Horgen",
"Horw",
"Illnau-Effretikon",
"Ittigen",
"Jona",
"Kriens",
"Kloten",
"K<EFBFBD>niz",
"Kreuzlingen",
"K<EFBFBD>snacht",
"Agen",
"Lancy",
"La Chaux-de-Fonds",
"Lenzburg",
"Lugano",
"Langenthal",
"Littau",
"Le Locle",
"La Neuveville",
"Locarno",
"Liestal",
"La Tour-de-Peilz",
"Lausanne",
"Lyss",
"Luzern",
"Martigny",
"M<EFBFBD>nchenstein",
"Meyrin",
"Montreux",
"Monthey",
"Morges",
"Murten",
"Moutier",
"Muttenz",
"Neuch<EFBFBD>tel",
"Neuhausen am Rheinfall",
"Nyon",
"Olten",
"Onex",
"Opfikon",
"Ostermundigen",
"Payerne",
"Peseux",
"Prilly",
"Pully",
"Rapperswil",
"Richterswil",
"Regensdorf",
"Rheinfelden",
"Riehen",
"Renens",
"Romanshorn",
"Rorschach",
"Stans",
"Schaffhausen",
"Steffisburg",
"St. Gallen",
"Schlieren",
"Sierre",
"Solothurn",
"St. Moritz",
"Sion",
"Spiez",
"St<EFBFBD>fa",
"Sursee",
"Schwyz",
"Thalwil",
"Th<EFBFBD>nex",
"Thun",
"Uster",
"Uzwil",
"Vernier",
"Volketswil",
"Versoix",
"Vevey",
"W<EFBFBD>denswil",
"Wettingen",
"Wil",
"Wallisellen",
"Winterthur",
"Wohlen",
"Worb",
"Wetzikon",
"Yverdon-les-Bains",
"Zollikon",
"Zofingen",
"Z<EFBFBD>rich",
"Zug",
};