mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-14 04:02:31 +00:00
Adds Linguist and Polyglot traits
This commit is contained in:
@@ -1,3 +1,6 @@
|
|||||||
|
/datum/preferences
|
||||||
|
var/extra_languages = 0
|
||||||
|
|
||||||
/datum/category_item/player_setup_item/general/language
|
/datum/category_item/player_setup_item/general/language
|
||||||
name = "Language"
|
name = "Language"
|
||||||
sort_order = 2
|
sort_order = 2
|
||||||
@@ -5,6 +8,11 @@
|
|||||||
|
|
||||||
/datum/category_item/player_setup_item/general/language/load_character(var/savefile/S)
|
/datum/category_item/player_setup_item/general/language/load_character(var/savefile/S)
|
||||||
S["language"] >> pref.alternate_languages
|
S["language"] >> pref.alternate_languages
|
||||||
|
<<<<<<< HEAD
|
||||||
|
=======
|
||||||
|
S["extra_languages"] >> pref.extra_languages
|
||||||
|
testing("LANGSANI: Loaded from [pref.client]'s character [pref.real_name || "-name not yet loaded-"] savefile: [english_list(pref.alternate_languages || list())]")
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
S["language_prefixes"] >> pref.language_prefixes
|
S["language_prefixes"] >> pref.language_prefixes
|
||||||
//CHOMPEdit Begin
|
//CHOMPEdit Begin
|
||||||
S["species"] >> pref.species
|
S["species"] >> pref.species
|
||||||
@@ -18,6 +26,11 @@
|
|||||||
|
|
||||||
/datum/category_item/player_setup_item/general/language/save_character(var/savefile/S)
|
/datum/category_item/player_setup_item/general/language/save_character(var/savefile/S)
|
||||||
S["language"] << pref.alternate_languages
|
S["language"] << pref.alternate_languages
|
||||||
|
<<<<<<< HEAD
|
||||||
|
=======
|
||||||
|
S["extra_languages"] << pref.extra_languages
|
||||||
|
testing("LANGSANI: Saved to [pref.client]'s character [pref.real_name || "-name not yet loaded-"] savefile: [english_list(pref.alternate_languages || list())]")
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
S["language_prefixes"] << pref.language_prefixes
|
S["language_prefixes"] << pref.language_prefixes
|
||||||
|
|
||||||
/datum/category_item/player_setup_item/general/language/sanitize_character()
|
/datum/category_item/player_setup_item/general/language/sanitize_character()
|
||||||
@@ -26,9 +39,16 @@
|
|||||||
var/datum/species/S = GLOB.all_species[pref.species]
|
var/datum/species/S = GLOB.all_species[pref.species]
|
||||||
if(!istype(S))
|
if(!istype(S))
|
||||||
return
|
return
|
||||||
|
<<<<<<< HEAD
|
||||||
|
|
||||||
if(pref.alternate_languages.len > pref.numlanguage()) //CHOMPEdit
|
if(pref.alternate_languages.len > pref.numlanguage()) //CHOMPEdit
|
||||||
pref.alternate_languages.len = pref.numlanguage() // Truncate to allowed length CHOMPEdit
|
pref.alternate_languages.len = pref.numlanguage() // Truncate to allowed length CHOMPEdit
|
||||||
|
=======
|
||||||
|
|
||||||
|
if(pref.alternate_languages.len > (S.num_alternate_languages + pref.extra_languages))
|
||||||
|
testing("LANGSANI: Truncated [pref.client]'s character [pref.real_name || "-name not yet loaded-"] language list because it was too long (len: [pref.alternate_languages.len], allowed: [S.num_alternate_languages])")
|
||||||
|
pref.alternate_languages.len = (S.num_alternate_languages + pref.extra_languages) // Truncate to allowed length
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
|
|
||||||
// Sanitize illegal languages
|
// Sanitize illegal languages
|
||||||
for(var/language in pref.alternate_languages)
|
for(var/language in pref.alternate_languages)
|
||||||
@@ -46,18 +66,30 @@
|
|||||||
/datum/category_item/player_setup_item/general/language/content()
|
/datum/category_item/player_setup_item/general/language/content()
|
||||||
. += "<b>Languages</b><br>"
|
. += "<b>Languages</b><br>"
|
||||||
var/datum/species/S = GLOB.all_species[pref.species]
|
var/datum/species/S = GLOB.all_species[pref.species]
|
||||||
|
if(pref.alternate_languages.len > (S.num_alternate_languages + pref.extra_languages))
|
||||||
|
testing("LANGSANI: Truncated [pref.client]'s character [pref.real_name || "-name not yet loaded-"] language list because it was too long (len: [pref.alternate_languages.len], allowed: [S.num_alternate_languages])")
|
||||||
|
pref.alternate_languages.len = (S.num_alternate_languages + pref.extra_languages) // Truncate to allowed length
|
||||||
if(S.language)
|
if(S.language)
|
||||||
. += "- [S.language]<br>"
|
. += "- [S.language]<br>"
|
||||||
if(S.default_language && S.default_language != S.language)
|
if(S.default_language && S.default_language != S.language)
|
||||||
. += "- [S.default_language]<br>"
|
. += "- [S.default_language]<br>"
|
||||||
|
<<<<<<< HEAD
|
||||||
if(pref.numlanguage()) //CHOMPEdit
|
if(pref.numlanguage()) //CHOMPEdit
|
||||||
|
=======
|
||||||
|
if(S.num_alternate_languages + pref.extra_languages)
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
if(pref.alternate_languages.len)
|
if(pref.alternate_languages.len)
|
||||||
for(var/i = 1 to pref.alternate_languages.len)
|
for(var/i = 1 to pref.alternate_languages.len)
|
||||||
var/lang = pref.alternate_languages[i]
|
var/lang = pref.alternate_languages[i]
|
||||||
. += "- [lang] - <a href='?src=\ref[src];remove_language=[i]'>remove</a><br>"
|
. += "- [lang] - <a href='?src=\ref[src];remove_language=[i]'>remove</a><br>"
|
||||||
|
|
||||||
|
<<<<<<< HEAD
|
||||||
if(pref.alternate_languages.len < pref.numlanguage()) //CHOMPEdit
|
if(pref.alternate_languages.len < pref.numlanguage()) //CHOMPEdit
|
||||||
. += "- <a href='?src=\ref[src];add_language=1'>add</a> ([pref.numlanguage() - pref.alternate_languages.len] remaining)<br>" //CHOMPEdit
|
. += "- <a href='?src=\ref[src];add_language=1'>add</a> ([pref.numlanguage() - pref.alternate_languages.len] remaining)<br>" //CHOMPEdit
|
||||||
|
=======
|
||||||
|
if(pref.alternate_languages.len < (S.num_alternate_languages + pref.extra_languages))
|
||||||
|
. += "- <a href='?src=\ref[src];add_language=1'>add</a> ([(S.num_alternate_languages + pref.extra_languages) - pref.alternate_languages.len] remaining)<br>"
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
else
|
else
|
||||||
. += "- [pref.species] cannot choose secondary languages.<br>"
|
. += "- [pref.species] cannot choose secondary languages.<br>"
|
||||||
|
|
||||||
@@ -71,7 +103,11 @@
|
|||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
else if(href_list["add_language"])
|
else if(href_list["add_language"])
|
||||||
var/datum/species/S = GLOB.all_species[pref.species]
|
var/datum/species/S = GLOB.all_species[pref.species]
|
||||||
|
<<<<<<< HEAD
|
||||||
if(pref.alternate_languages.len >= pref.numlanguage()) //CHOMPEdit
|
if(pref.alternate_languages.len >= pref.numlanguage()) //CHOMPEdit
|
||||||
|
=======
|
||||||
|
if(pref.alternate_languages.len >= (S.num_alternate_languages + pref.extra_languages))
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
tgui_alert_async(user, "You have already selected the maximum number of alternate languages for this species!")
|
tgui_alert_async(user, "You have already selected the maximum number of alternate languages for this species!")
|
||||||
else
|
else
|
||||||
var/list/available_languages = S.secondary_langs.Copy()
|
var/list/available_languages = S.secondary_langs.Copy()
|
||||||
@@ -89,7 +125,11 @@
|
|||||||
tgui_alert_async(user, "There are no additional languages available to select.")
|
tgui_alert_async(user, "There are no additional languages available to select.")
|
||||||
else
|
else
|
||||||
var/new_lang = tgui_input_list(user, "Select an additional language", "Character Generation", available_languages)
|
var/new_lang = tgui_input_list(user, "Select an additional language", "Character Generation", available_languages)
|
||||||
|
<<<<<<< HEAD
|
||||||
if(new_lang && pref.alternate_languages.len < pref.numlanguage()) //CHOMPEdit
|
if(new_lang && pref.alternate_languages.len < pref.numlanguage()) //CHOMPEdit
|
||||||
|
=======
|
||||||
|
if(new_lang && pref.alternate_languages.len < (S.num_alternate_languages + pref.extra_languages))
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
pref.alternate_languages |= new_lang
|
pref.alternate_languages |= new_lang
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
|
||||||
|
|||||||
@@ -141,6 +141,9 @@
|
|||||||
var/datum/species/S = character.species
|
var/datum/species/S = character.species
|
||||||
var/datum/species/new_S = S.produceCopy(pref.pos_traits + pref.neu_traits + pref.neg_traits, character, pref.custom_base)
|
var/datum/species/new_S = S.produceCopy(pref.pos_traits + pref.neu_traits + pref.neg_traits, character, pref.custom_base)
|
||||||
|
|
||||||
|
for(var/datum/trait/T in new_S.traits)
|
||||||
|
T.apply_pref(src)
|
||||||
|
|
||||||
//Any additional non-trait settings can be applied here
|
//Any additional non-trait settings can be applied here
|
||||||
new_S.blood_color = pref.blood_color
|
new_S.blood_color = pref.blood_color
|
||||||
|
|
||||||
@@ -151,8 +154,6 @@
|
|||||||
//Statistics for this would be nice
|
//Statistics for this would be nice
|
||||||
var/english_traits = english_list(new_S.traits, and_text = ";", comma_text = ";")
|
var/english_traits = english_list(new_S.traits, and_text = ";", comma_text = ";")
|
||||||
log_game("TRAITS [pref.client_ckey]/([character]) with: [english_traits]") //Terrible 'fake' key_name()... but they aren't in the same entity yet
|
log_game("TRAITS [pref.client_ckey]/([character]) with: [english_traits]") //Terrible 'fake' key_name()... but they aren't in the same entity yet
|
||||||
else
|
|
||||||
|
|
||||||
|
|
||||||
/datum/category_item/player_setup_item/vore/traits/content(var/mob/user)
|
/datum/category_item/player_setup_item/vore/traits/content(var/mob/user)
|
||||||
. += "<b>Custom Species Name:</b> "
|
. += "<b>Custom Species Name:</b> "
|
||||||
@@ -258,6 +259,8 @@
|
|||||||
if(traitpath == /datum/trait/positive/linguist) //CHOMPEdit
|
if(traitpath == /datum/trait/positive/linguist) //CHOMPEdit
|
||||||
pref.num_languages = null //CHOMPEdit
|
pref.num_languages = null //CHOMPEdit
|
||||||
pref.pos_traits -= trait
|
pref.pos_traits -= trait
|
||||||
|
var/datum/trait/instance = all_traits[trait]
|
||||||
|
instance.remove_pref(pref)
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
|
||||||
else if(href_list["clicked_neu_trait"])
|
else if(href_list["clicked_neu_trait"])
|
||||||
@@ -265,6 +268,8 @@
|
|||||||
var/choice = tgui_alert(usr, "Remove [initial(trait.name)]?","Remove Trait",list("Remove","Cancel"))
|
var/choice = tgui_alert(usr, "Remove [initial(trait.name)]?","Remove Trait",list("Remove","Cancel"))
|
||||||
if(choice == "Remove")
|
if(choice == "Remove")
|
||||||
pref.neu_traits -= trait
|
pref.neu_traits -= trait
|
||||||
|
var/datum/trait/instance = all_traits[trait]
|
||||||
|
instance.remove_pref(pref)
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
|
||||||
else if(href_list["clicked_neg_trait"])
|
else if(href_list["clicked_neg_trait"])
|
||||||
@@ -272,6 +277,8 @@
|
|||||||
var/choice = tgui_alert(usr, "Remove [initial(trait.name)] and lose [initial(trait.cost)] points?","Remove Trait",list("Remove","Cancel"))
|
var/choice = tgui_alert(usr, "Remove [initial(trait.name)] and lose [initial(trait.cost)] points?","Remove Trait",list("Remove","Cancel"))
|
||||||
if(choice == "Remove")
|
if(choice == "Remove")
|
||||||
pref.neg_traits -= trait
|
pref.neg_traits -= trait
|
||||||
|
var/datum/trait/instance = all_traits[trait]
|
||||||
|
instance.remove_pref(pref)
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
|
||||||
else if(href_list["custom_say"])
|
else if(href_list["custom_say"])
|
||||||
@@ -424,11 +431,21 @@
|
|||||||
conflict = instance_test.name
|
conflict = instance_test.name
|
||||||
break varconflict
|
break varconflict
|
||||||
|
|
||||||
|
for(var/V in instance.var_changes_pref)
|
||||||
|
if(V in instance_test.var_changes_pref)
|
||||||
|
conflict = instance_test.name
|
||||||
|
break varconflict
|
||||||
|
|
||||||
if(conflict)
|
if(conflict)
|
||||||
tgui_alert_async(usr, "You cannot take this trait and [conflict] at the same time. Please remove that trait, or pick another trait to add.", "Error")
|
tgui_alert_async(usr, "You cannot take this trait and [conflict] at the same time. Please remove that trait, or pick another trait to add.", "Error")
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
<<<<<<< HEAD
|
||||||
if(path==/datum/trait/positive/linguist) //CHOMPEdit
|
if(path==/datum/trait/positive/linguist) //CHOMPEdit
|
||||||
pref.num_languages = 12 //CHOMPEdit
|
pref.num_languages = 12 //CHOMPEdit
|
||||||
|
=======
|
||||||
|
|
||||||
|
instance.apply_pref(pref)
|
||||||
|
>>>>>>> a6f7e932ad... Merge pull request #13178 from Heroman3003/linguist
|
||||||
mylist += path
|
mylist += path
|
||||||
return TOPIC_REFRESH
|
return TOPIC_REFRESH
|
||||||
|
|
||||||
|
|||||||
@@ -187,3 +187,17 @@
|
|||||||
/datum/trait/positive/cocoon_tf/apply(var/datum/species/S,var/mob/living/carbon/human/H)
|
/datum/trait/positive/cocoon_tf/apply(var/datum/species/S,var/mob/living/carbon/human/H)
|
||||||
..(S,H)
|
..(S,H)
|
||||||
H.verbs |= /mob/living/carbon/human/proc/enter_cocoon
|
H.verbs |= /mob/living/carbon/human/proc/enter_cocoon
|
||||||
|
|
||||||
|
/datum/trait/positive/linguist
|
||||||
|
name = "Linguist"
|
||||||
|
desc = "Allows you to have more languages."
|
||||||
|
cost = 1
|
||||||
|
var_changes = list("num_alternate_languages" = 5)
|
||||||
|
var_changes_pref = list("extra_languages" = 2)
|
||||||
|
|
||||||
|
/datum/trait/positive/polyglot
|
||||||
|
name = "Polyglot"
|
||||||
|
desc = "Allows you to have a lot more languages."
|
||||||
|
cost = 2
|
||||||
|
var_changes = list("num_alternate_languages" = 7)
|
||||||
|
var_changes_pref = list("extra_languages" = 4)
|
||||||
@@ -6,6 +6,7 @@
|
|||||||
var/sort = TRAIT_SORT_NORMAL // Sort order, 1 before 2 before 3 etc. Alphabetical is used for same-group traits.
|
var/sort = TRAIT_SORT_NORMAL // Sort order, 1 before 2 before 3 etc. Alphabetical is used for same-group traits.
|
||||||
var/category = 0 // What category this trait is. -1 is Negative, 0 is Neutral, 1 is Positive
|
var/category = 0 // What category this trait is. -1 is Negative, 0 is Neutral, 1 is Positive
|
||||||
var/list/var_changes // A list to apply to the custom species vars.
|
var/list/var_changes // A list to apply to the custom species vars.
|
||||||
|
var/list/var_changes_pref // A list to apply to the preference vars.
|
||||||
var/list/excludes // Store a list of paths of traits to exclude, but done automatically if they change the same vars.
|
var/list/excludes // Store a list of paths of traits to exclude, but done automatically if they change the same vars.
|
||||||
var/can_take = ORGANICS|SYNTHETICS // Can freaking synths use those.
|
var/can_take = ORGANICS|SYNTHETICS // Can freaking synths use those.
|
||||||
var/list/banned_species // A list of species that can't take this trait
|
var/list/banned_species // A list of species that can't take this trait
|
||||||
@@ -20,7 +21,23 @@
|
|||||||
S.vars[V] = var_changes[V]
|
S.vars[V] = var_changes[V]
|
||||||
return
|
return
|
||||||
|
|
||||||
|
//Applying trait to preferences rather than just us.
|
||||||
|
/datum/trait/proc/apply_pref(var/datum/preferences/P)
|
||||||
|
ASSERT(P)
|
||||||
|
if(var_changes_pref)
|
||||||
|
for(var/V in var_changes_pref)
|
||||||
|
P.vars[V] = var_changes_pref[V]
|
||||||
|
return
|
||||||
|
|
||||||
//Similar to the above, but for removing. Probably won't be called often/ever.
|
//Similar to the above, but for removing. Probably won't be called often/ever.
|
||||||
/datum/trait/proc/remove(var/datum/species/S)
|
/datum/trait/proc/remove(var/datum/species/S)
|
||||||
ASSERT(S)
|
ASSERT(S)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
//Similar to the above, but for removing.
|
||||||
|
/datum/trait/proc/remove_pref(var/datum/preferences/P)
|
||||||
|
ASSERT(P)
|
||||||
|
if(var_changes_pref)
|
||||||
|
for(var/V in var_changes_pref)
|
||||||
|
P.vars[V] = initial(P.vars[V])
|
||||||
|
return
|
||||||
|
|||||||
Reference in New Issue
Block a user