-/*\r
- * Copyright (C) 2015 Roland Haeder\r
- *\r
- * This program is free software: you can redistribute it and/or modify\r
- * it under the terms of the GNU General Public License as published by\r
- * the Free Software Foundation, either version 3 of the License, or\r
- * (at your option) any later version.\r
- *\r
- * This program is distributed in the hope that it will be useful,\r
- * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
- * GNU General Public License for more details.\r
- *\r
- * You should have received a copy of the GNU General Public License\r
- * along with this program. If not, see <http://www.gnu.org/licenses/>.\r
- */\r
-package org.mxchange.addressbook;\r
-\r
-import org.apache.logging.log4j.LogManager;\r
-import org.apache.logging.log4j.Logger;\r
-import org.mxchange.addressbook.application.Application;\r
-import org.mxchange.addressbook.client.Client;\r
-import org.mxchange.addressbook.manager.contact.ContactManager;\r
-import org.mxchange.addressbook.manager.contact.ManageableContact;\r
-\r
-/**\r
- * General class\r
- *\r
- * @author Roland Haeder\r
- */\r
-public class BaseFrameworkSystem implements FrameworkInterface {\r
- /**\r
- * Class' logger\r
- */\r
- private final Logger LOG;\r
-\r
- /**\r
- * Application instance\r
- */\r
- private Application application;\r
-\r
- /**\r
- * Client instance\r
- */\r
- private Client client;\r
-\r
- /**\r
- * Contact manager instance\r
- */\r
- private ManageableContact contactManager;\r
-\r
- /**\r
- * Name of used database table, handled over to backend\r
- */\r
- private String tableName;\r
-\r
- /**\r
- * Initialize object\r
- */\r
- {\r
- LOG = LogManager.getLogger(this);\r
- }\r
-\r
- /**\r
- * No instances can be created of this class\r
- */\r
- protected BaseFrameworkSystem () {\r
- }\r
-\r
- /**\r
- * Application instance\r
- * \r
- * @return the application\r
- */\r
- @Override\r
- public Application getApplication () {\r
- return this.application;\r
- }\r
-\r
- /**\r
- * Client instance\r
- * \r
- * @return the client\r
- */\r
- @Override\r
- public Client getClient () {\r
- return this.client;\r
- }\r
-\r
- /**\r
- * Contact manager instance\r
- * @return the contactManager\r
- */\r
- @Override\r
- public ManageableContact getContactManager () {\r
- return this.contactManager;\r
- }\r
-\r
- /**\r
- * Contact manager instance\r
- * @param contactManager the contactManager to set\r
- */\r
- protected void setContactManager (final ManageableContact contactManager) {\r
- this.contactManager = contactManager;\r
- }\r
-\r
- /**\r
- * Client instance\r
- * @param client the client to set\r
- */\r
- protected void setClient (final Client client) {\r
- this.client = client;\r
- }\r
-\r
- /**\r
- * Application instance\r
- *\r
- * @param application the application to set\r
- */\r
- protected void setApplication(final Application application) {\r
- this.application = application;\r
- }\r
-\r
- /**\r
- * Getter for logger\r
- *\r
- * @return Logger\r
- */\r
- protected Logger getLogger () {\r
- return this.LOG;\r
- }\r
-\r
- /**\r
- * Name of used database table, handled over to backend\r
- * \r
- * @return the tableName\r
- */\r
- protected String getTableName () {\r
- return this.tableName;\r
- }\r
-\r
- /**\r
- * Name of used database table, handled over to backend\r
- * \r
- * @param tableName the tableName to set\r
- */\r
- protected void setTableName (final String tableName) {\r
- this.tableName = tableName;\r
- }\r
-\r
- /**\r
- * Initializes contact manager\r
- * @param client Client instance\r
- */\r
- protected void initContactManager (final Client client) {\r
- // Debug message\r
- this.getLogger().debug("Initializing contact manager ...");\r
- \r
- // Init contact manager with console client\r
- // @TODO Static initial amount of contacts\r
- ManageableContact manager = new ContactManager (100, client);\r
- \r
- // Set it here\r
- this.setContactManager(manager);\r
- \r
- // Debug message\r
- this.getLogger().debug("Contact manager has been initialized.");\r
- }\r
-}\r
+/*
+ * Copyright (C) 2015 Roland Haeder
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package org.mxchange.addressbook;
+
+import java.util.ResourceBundle;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+import org.mxchange.addressbook.application.Application;
+import org.mxchange.addressbook.client.Client;
+import org.mxchange.addressbook.manager.contact.ManageableContact;
+
+/**
+ * General class
+ *
+ * @author Roland Haeder
+ */
+public class BaseFrameworkSystem implements FrameworkInterface {
+
+ /**
+ * Class' logger
+ */
+ private final Logger LOG;
+
+ /**
+ * Application instance
+ */
+ private Application application;
+
+ /**
+ * Bundle instance
+ */
+ private final ResourceBundle bundle;
+
+ /**
+ * Client instance
+ */
+ private Client client;
+
+ /**
+ * Contact manager instance
+ */
+ private ManageableContact contactManager;
+
+ /**
+ * Name of used database table, handled over to backend
+ */
+ private String tableName;
+
+ /**
+ * Initialize object
+ */
+ {
+ LOG = LogManager.getLogger(this);
+ bundle = ResourceBundle.getBundle("org/mxchange/addressbook/localization/bundle"); // NOI18N
+ }
+
+ /**
+ * No instances can be created of this class
+ */
+ protected BaseFrameworkSystem () {
+ }
+
+ /**
+ * Application instance
+ *
+ * @return the application
+ */
+ @Override
+ public final Application getApplication () {
+ return this.application;
+ }
+
+ /**
+ * Client instance
+ *
+ * @return the client
+ */
+ @Override
+ public final Client getClient () {
+ return this.client;
+ }
+
+ /**
+ * Contact manager instance
+ *
+ * @return the contactManager
+ */
+ @Override
+ public final ManageableContact getContactManager () {
+ return this.contactManager;
+ }
+
+ /**
+ * Contact manager instance
+ *
+ * @param contactManager the contactManager to set
+ */
+ protected final void setContactManager (final ManageableContact contactManager) {
+ this.contactManager = contactManager;
+ }
+
+ /**
+ * Client instance
+ *
+ * @param client the client to set
+ */
+ protected final void setClient (final Client client) {
+ this.client = client;
+ }
+
+ /**
+ * Application instance
+ *
+ * @param application the application to set
+ */
+ protected final void setApplication (final Application application) {
+ this.application = application;
+ }
+
+ /**
+ * Getter for bundle instance
+ *
+ * @return Resource bundle
+ */
+ protected final ResourceBundle getBundle () {
+ return this.bundle;
+ }
+
+ /**
+ * Getter for logger
+ *
+ * @return Logger
+ */
+ protected final Logger getLogger () {
+ return this.LOG;
+ }
+
+ /**
+ * Name of used database table, handled over to backend
+ *
+ * @return the tableName
+ */
+ protected final String getTableName () {
+ return this.tableName;
+ }
+
+ /**
+ * Name of used database table, handled over to backend
+ *
+ * @param tableName the tableName to set
+ */
+ protected final void setTableName (final String tableName) {
+ this.tableName = tableName;
+ }
+
+ /**
+ * Getter for human-readable string from given key
+ *
+ * @param key Key to return
+ * @return Human-readable message
+ */
+ public final String getMessageStringFromKey (final String key) {
+ // Return message
+ return this.getBundle().getString(key);
+ }
+}