summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2015-11-13 23:36:31 +0300
committerAndrei Karas <akaras@inbox.ru>2015-11-14 00:34:05 +0300
commit35b27514c8eede4daa8f07f7b44d9579c78d18cf (patch)
tree6202acddb70586efd064c51c9f98e9f3530c5e8b
parentcd7e273322d9648be6c005fd2930a6037149a357 (diff)
downloadmanaplus-35b27514c8eede4daa8f07f7b44d9579c78d18cf.tar.gz
manaplus-35b27514c8eede4daa8f07f7b44d9579c78d18cf.tar.bz2
manaplus-35b27514c8eede4daa8f07f7b44d9579c78d18cf.tar.xz
manaplus-35b27514c8eede4daa8f07f7b44d9579c78d18cf.zip
Add features.xml attribute for force account gender for new chars.
New attribute: forceAccountGender Default value: -1 (mean not forcing)
-rw-r--r--src/defaults.cpp1
-rw-r--r--src/gui/windows/charcreatedialog.cpp7
-rw-r--r--src/gui/windows/registerdialog.cpp24
3 files changed, 23 insertions, 9 deletions
diff --git a/src/defaults.cpp b/src/defaults.cpp
index 0c11be8ac..a424137c0 100644
--- a/src/defaults.cpp
+++ b/src/defaults.cpp
@@ -632,6 +632,7 @@ DefaultsData* getFeaturesDefaults()
AddDEF("languageTab", false);
AddDEF("allowFollow", true);
AddDEF("fixDeadAnimation", true);
+ AddDEF("forceAccountGender", -1);
return configData;
}
diff --git a/src/gui/windows/charcreatedialog.cpp b/src/gui/windows/charcreatedialog.cpp
index bb55e06ce..39618917e 100644
--- a/src/gui/windows/charcreatedialog.cpp
+++ b/src/gui/windows/charcreatedialog.cpp
@@ -226,8 +226,11 @@ CharCreateDialog::CharCreateDialog(CharSelectDialog *const parent,
mGenderStrip->addButton(_("F"), "f", false);
// TRANSLATORS: one char size male character gender
mGenderStrip->addButton(_("M"), "m", false);
- // TRANSLATORS: one char size unknown character gender
- mGenderStrip->addButton(_("U"), "u", true);
+ if (features.getIntValue("forceAccountGender") == -1)
+ {
+ // TRANSLATORS: one char size unknown character gender
+ mGenderStrip->addButton(_("U"), "u", true);
+ }
mGenderStrip->setVisible(Visible_true);
add(mGenderStrip);
diff --git a/src/gui/windows/registerdialog.cpp b/src/gui/windows/registerdialog.cpp
index d3deaeb5e..b4f9d8868 100644
--- a/src/gui/windows/registerdialog.cpp
+++ b/src/gui/windows/registerdialog.cpp
@@ -23,6 +23,9 @@
#include "gui/windows/registerdialog.h"
#include "client.h"
+#include "configuration.h"
+
+#include "being/being.h"
#include "gui/windows/okdialog.h"
@@ -85,8 +88,7 @@ RegisterDialog::RegisterDialog(LoginData &data) :
int row = 3;
- // for future usage flag
- if (true)
+ if (features.getIntValue("forceAccountGender") == -1)
{
// TRANSLATORS: register dialog. button.
mMaleButton = new RadioButton(this, _("Male"), "sex", true);
@@ -265,12 +267,20 @@ void RegisterDialog::action(const ActionEvent &event)
mRegisterButton->setEnabled(false);
mLoginData->username = mUserField->getText();
mLoginData->password = mPasswordField->getText();
- if (mFemaleButton && mFemaleButton->isSelected())
- mLoginData->gender = Gender::FEMALE;
- else if (mOtherButton && mOtherButton->isSelected())
- mLoginData->gender = Gender::OTHER;
+ if (features.getIntValue("forceAccountGender") == -1)
+ {
+ if (mFemaleButton && mFemaleButton->isSelected())
+ mLoginData->gender = Gender::FEMALE;
+ else if (mOtherButton && mOtherButton->isSelected())
+ mLoginData->gender = Gender::OTHER;
+ else
+ mLoginData->gender = Gender::MALE;
+ }
else
- mLoginData->gender = Gender::MALE;
+ {
+ mLoginData->gender = Being::intToGender(
+ features.getIntValue("forceAccountGender"));
+ }
if (mEmailField)
mLoginData->email = mEmailField->getText();