Ejemplo n.º 1
0
    def removeRecentProjectFile(self, projectFile):
        if not isinstance(projectFile, (QUrl, pyCompatibility.basestring)):
            raise TypeError("Unexpected data type: {}".format(
                projectFile.__class__))
        if isinstance(projectFile, QUrl):
            projectFileNorm = projectFile.toLocalFile()
            if not projectFileNorm:
                projectFileNorm = projectFile.toString()
        else:
            projectFileNorm = QUrl(projectFile).toLocalFile()
            if not projectFileNorm:
                projectFileNorm = QUrl.fromLocalFile(projectFile).toLocalFile()

        projects = self._recentProjectFiles()

        # remove duplicates while preserving order
        from collections import OrderedDict
        uniqueProjects = OrderedDict.fromkeys(projects)
        projects = list(uniqueProjects)
        # remove previous usage of the value
        if projectFileNorm not in uniqueProjects:
            return

        projects.remove(projectFileNorm)

        settings = QSettings()
        settings.beginGroup("RecentFiles")
        size = settings.beginWriteArray("Projects")
        for i, p in enumerate(projects):
            settings.setArrayIndex(i)
            settings.setValue("filepath", p)
        settings.endArray()
        settings.sync()

        self.recentProjectFilesChanged.emit()
Ejemplo n.º 2
0
 def __init__(self, profiles,  parent=None):
     """
     Constructor
     
     @param parent reference to the parent widget
     @type QWidget
     """
     super(ProfilesDialog, self).__init__(parent)
     self.setupUi(self)
     self.model = ProfilesModel(profiles)
     self.view = self.table_view
     self.view.setModel(self.model)
     settings = QSettings()
     settings.beginGroup('ProfilesDialog')
     geom = settings.value('geom')
     if geom is not None:
         self.restoreGeometry(geom)
     sz = settings.beginReadArray('col_size')
     for i in range(sz):
         settings.setArrayIndex(i)
         w = settings.value('col')
         self.view.setColumnWidth(i, w)
     settings.endArray()
     settings.endGroup()
     self.view.horizontalHeader().setStretchLastSection(True)
Ejemplo n.º 3
0
    def _loadSettings(self):

        settings = QSettings()

        # Recent documents
        size = settings.beginReadArray("RecentDocuments")
        for idx in range(size-1, -1, -1):
            settings.setArrayIndex(idx)
            canonicalName = QFileInfo(settings.value("Document")).canonicalFilePath()
            self._updateRecentDocuments(canonicalName)
        settings.endArray()

        # Application properties: Geometry
        geometry = settings.value("Application/Geometry", QByteArray()) if self._preferences.restoreApplicationGeometry() else QByteArray()
        if not geometry.isEmpty():
            self.restoreGeometry(geometry)
        else:
            availableGeometry = self.screen().availableGeometry()
            self.resize(availableGeometry.width() * 2/3, availableGeometry.height() * 2/3)
            self.move((availableGeometry.width() - self.width()) / 2, (availableGeometry.height() - self.height()) / 2)

        # Application properties: State
        state = settings.value("Application/State", QByteArray()) if self._preferences.restoreApplicationState() else QByteArray()
        if not state.isEmpty():
            self.restoreState(state)
        else:
            self._toolbarApplication.setVisible(True)
            self._toolbarDocument.setVisible(True)
            self._toolbarEdit.setVisible(True)
            self._toolbarTools.setVisible(True)
            self._toolbarView.setVisible(False)
            self._toolbarHelp.setVisible(False)
Ejemplo n.º 4
0
def _rename_step(workflow_location, old_name, new_name, new_src_uri):
    updated = False
    workflow_conf_location = os.path.join(workflow_location,
                                          DEFAULT_WORKFLOW_PROJECT_FILENAME)
    workflow_conf = QSettings(workflow_conf_location, QSettings.IniFormat)

    workflow_conf.beginGroup('nodes')
    node_count = workflow_conf.beginReadArray('nodelist')

    name_indices = []
    for i in range(node_count):
        workflow_conf.setArrayIndex(i)
        name = workflow_conf.value('name')
        if name == old_name:
            name_indices.append(i)

    workflow_conf.endArray()
    workflow_conf.beginWriteArray('nodelist')

    for i in range(node_count):
        workflow_conf.setArrayIndex(i)
        if i in name_indices:
            workflow_conf.setValue('name', new_name)
            workflow_conf.setValue('source_uri', new_src_uri)
            updated = True

    workflow_conf.endArray()
    workflow_conf.endGroup()

    return updated
Ejemplo n.º 5
0
    def save(self) -> None:
        settings = QSettings(self.config_path)

        settings.beginWriteArray("downloads")
        for i in range(len(self.downloads)):
            settings.setArrayIndex(i)
            settings.setValue("download", Download.pack(self.downloads[i]))
        settings.endArray()
Ejemplo n.º 6
0
    def load(self) -> None:
        settings = QSettings(self.config_path)

        size = settings.beginReadArray("downloads")
        for i in range(size):
            settings.setArrayIndex(i)
            self.add_download(Download.unpack(settings.value("download")))
        settings.endArray()
Ejemplo n.º 7
0
    def load(self) -> None:
        settings = QSettings(self.config_path, QSettings.NativeFormat)

        size = settings.beginReadArray("predownloads")
        for i in range(size):
            settings.setArrayIndex(i)
            self.add_predownload(
                PreDownload.unpack(settings.value("predownload")))
        settings.endArray()
Ejemplo n.º 8
0
    def save(self) -> None:
        settings = QSettings(self.config_path, QSettings.NativeFormat)

        settings.beginWriteArray("predownloads")
        for i in range(len(self.predownloads)):
            settings.setArrayIndex(i)
            settings.setValue("predownload",
                              PreDownload.pack(self.predownloads[i]))
        settings.endArray()
Ejemplo n.º 9
0
    def store(self, settings: QSettings):
        settings.beginGroup("gui")
        self.gui.store(settings)
        settings.endGroup()

        settings.beginWriteArray("repos")
        for i, repo in enumerate(self.repositories):
            settings.setArrayIndex(i)
            repo.store(settings)
        settings.endArray()
Ejemplo n.º 10
0
 def done(self, r):
     settings = QSettings()
     settings.beginGroup('ProfilesDialog')
     settings.setValue('geom', self.saveGeometry())
     settings.beginWriteArray('col_size')
     for i in range(3):
         settings.setArrayIndex(i)
         settings.setValue('col', self.view.columnWidth(i))
     settings.endArray()
     settings.endGroup()
     super().done(r)
Ejemplo n.º 11
0
 def _recentProjectFiles(self):
     projects = []
     settings = QSettings()
     settings.beginGroup("RecentFiles")
     size = settings.beginReadArray("Projects")
     for i in range(size):
         settings.setArrayIndex(i)
         p = settings.value("filepath")
         if p:
             projects.append(p)
     settings.endArray()
     return projects
Ejemplo n.º 12
0
class NotebookManager:
    def __init__(self):
        self.settings = QSettings(ORGANIZATION_STR)        
        self.allNotebooks = []

        self.readConfig()

    def notebook(self, name):
        for notebook in self.allNotebooks:
            if notebook.name == name:
                return notebook
        
        raise KeyError(name)

    def notebooks(self):
        return self.allNotebooks

    def createNewNotebook(self, name, storagePath):
        ok = QDir(storagePath).mkpath(".")
        nb = Notebook(name, storagePath)

        self.allNotebooks.append(nb)
        self.writeConfig()

        return nb

    def readConfig(self):
        notebookCount = self.settings.beginReadArray("notebooks")

        for i in range(notebookCount):
            self.settings.setArrayIndex(i)
            name = self.settings.value("name")
            storagePath = self.settings.value("storagePath")

            self.allNotebooks.append(Notebook(name, storagePath))

        self.settings.endArray()

    def writeConfig(self):
        #self.settings.beginGroup("notebooks")

        self.settings.beginWriteArray("notebooks")
        for i, notebook in enumerate(self.allNotebooks):
            self.settings.setArrayIndex(i)
            self.settings.setValue("name", notebook.name)
            self.settings.setValue("storagePath", notebook.localStoragePath)

        self.settings.endArray()
        self.settings.sync()
        #self.settings.endGroup()
Ejemplo n.º 13
0
    def load(cls, settings: QSettings):
        settings.beginGroup("gui")
        gui = GuiConfig.load(settings)
        settings.endGroup()

        repo_count = settings.beginReadArray("repos")
        repos = []
        for i in range(repo_count):
            settings.setArrayIndex(i)
            repos.append(RepositoryConfig.load(settings))
        settings.endArray()

        return cls(
            gui=gui,
            repositories=repos,
        )
Ejemplo n.º 14
0
 def save(self):
     settings = QSettings()
     settings.beginGroup(self.__class__.__name__)
     settings.beginWriteArray('col_size')
     for i in range(3):
         settings.setArrayIndex(i)
         w = self.columnWidth(i)
         if i != 0 or w != 0:
             settings.setValue('col', w)
     settings.endArray()
     if self.ini_check:
         settings.setValue('display_images',
                           self.images_display.checkState() == Qt.Checked)
         settings.setValue('use_cache', self.use_cache)
         settings.setValue('cache_size', self.cache_size)
     settings.endGroup()
Ejemplo n.º 15
0
    def _saveSettings(self):

        settings = QSettings()

        # Recent documents
        if not self._preferences.restoreRecentDocuments():
            self._recentDocuments.clear()
        settings.remove("RecentDocuments")
        settings.beginWriteArray("RecentDocuments")
        for idx in range(len(self._recentDocuments)):
            settings.setArrayIndex(idx)
            settings.setValue("Document", self._recentDocuments[idx])
        settings.endArray()

        # Application properties: Geometry
        geometry = self.saveGeometry() if self._preferences.restoreApplicationGeometry() else QByteArray()
        settings.setValue("Application/Geometry", geometry)

        # Application properties: State
        state = self.saveState() if self._preferences.restoreApplicationState() else QByteArray()
        settings.setValue("Application/State", state)
Ejemplo n.º 16
0
    def update_path(self, signal_name):
        settings = QSettings("Nebula", self.project_name)

        settings.beginGroup("Project")
        settings.setValue("LastEdit", QDateTime.currentDateTime().toString())
        settings.endGroup()

        settings.beginGroup("SignalFiles")
        before_list_path = settings.value("Path")
        before_list_path = before_list_path.split(',')
        print(
            f'Before list : {settings.fileName(), self.project_name, signal_name, before_list_path}'
        )
        before_list_path.extend(self.list_path)
        print(f'\033[1;36;40m Before list path: {before_list_path} \033[0m \n')
        self.list_path = list(
            dict.fromkeys(before_list_path))  # Removes the repeated path names
        if 'None' in self.list_path:
            self.list_path.remove('None')
        actual_list_path = ','.join(self.list_path)
        print(f'\033[1;36;40m After list path: {actual_list_path} \033[0m \n')
        settings.setValue("Path", actual_list_path)
        settings.endGroup()

        self.info, self.sfreq = read_info(self.list_path)
        settings.beginGroup("Info")
        settings.beginWriteArray("sfreq")
        for i in range(len(self.sfreq)):
            settings.setArrayIndex(i)
            settings.setValue("sfreq", self.sfreq[i])
        settings.endArray()
        settings.beginWriteArray("SubjectInfo")
        for i in range(len(self.info)):
            settings.setArrayIndex(i)
            for key, value in self.info[i].items():
                settings.setValue(key, str(value))
        settings.endArray()
        settings.endGroup()
        del before_list_path, actual_list_path
Ejemplo n.º 17
0
 def load(self, ini_check):
     settings = QSettings()
     settings.beginGroup(self.__class__.__name__)
     sz = settings.beginReadArray('col_size')
     for i in range(sz):
         settings.setArrayIndex(i)
         w = settings.value('col', type=int)
         if w is not None:
             self.setColumnWidth(i, w)
     settings.endArray()
     if ini_check:
         display = settings.value('display_images', type=bool)
         self.images_display.setCheckState(
             Qt.Checked if display else Qt.Unchecked)
         self.use_cache = settings.value('use_cache', True, type=bool)
         self.cache_size = settings.value('cache_size', 1000)
     else:
         display = self.images_display
     if not display:
         self.setColumnHidden(0, True)
     settings.endGroup()
     delegate = ImageDelegate(self)
     self.setItemDelegateForColumn(0, delegate)
     self.pre_load(delegate)
Ejemplo n.º 18
0
class Process(QObject):
    def __init__(self, engine):
        QObject.__init__(self)
        self.m_engine = engine
        self.project_name = ''
        self.process_name = list()
        self.process_description = list()
        self.action_name = list()
        self.settings = QSettings("Nebula")
        self.dat = dict()

    @Slot(str, str, result='QString')
    def process_settings(self, project_name, action_name):
        self.project_name = project_name
        self.action_name.append(action_name)
        self.settings = QSettings("Nebula", self.project_name)
        self.settings.beginGroup("ProcessInfo")
        self.settings.beginWriteArray(action_name)
        s = [str(i) for i in self.dat[project_name]]
        res = ",".join(s)
        for i in range(len(self.process_name)):
            self.settings.setArrayIndex(i)
            self.settings.setValue("Name", self.process_name[i])
            self.settings.setValue("Description", self.process_description[i])
            self.settings.setValue("Value", res)
        self.settings.endArray()
        self.settings.endGroup()
        print(self.settings.fileName())
        return self.settings.fileName()

    def process_info(self, name="", description=""):
        self.process_name.append(name)
        self.process_description.append(description)

    @Slot(str, result=bool)
    def generate_pdf(self, project_name):
        self.settings = QSettings("Nebula", project_name)

        pdf = CustomPDF()
        pdf.alias_nb_pages()
        pdf.add_page()
        pdf.set_font('Times', 'B', 15)
        pdf.cell(0, 5, 'Project details', ln=1)
        pdf.set_font('Times', '', 10)
        self.settings.beginGroup("Project")
        pdf.cell(0,
                 10,
                 txt="Name: {}".format(self.settings.value("Name")),
                 ln=1)
        pdf.cell(0,
                 10,
                 txt="Project creation date: {}".format(
                     self.settings.value("Date")),
                 ln=1)
        pdf.cell(0,
                 10,
                 txt="Inform creation date: {}".format(
                     self.settings.value("LastEdit")),
                 ln=1)
        pdf.cell(0, 10, txt=" ", ln=1)
        self.settings.endGroup()
        pdf.set_font('Times', 'B', 15)
        pdf.cell(0, 5, 'Signals', ln=1)
        pdf.set_font('Times', '', 10)
        self.settings.beginGroup("SignalFiles")
        pdf.cell(0,
                 10,
                 txt="Signals path: {}".format(self.settings.value("Path")),
                 ln=1)
        path = self.settings.value("Path")
        pdf.cell(0, 10, txt=" ", ln=1)
        self.settings.endGroup()
        pdf.set_font('Times', 'B', 15)
        pdf.cell(0, 5, 'Information', ln=1)
        pdf.set_font('Times', '', 10)
        self.settings.beginGroup("Info")
        size = self.settings.beginReadArray("sfreq")
        for i in range(size):
            self.settings.setArrayIndex(i)
            pdf.cell(0,
                     10,
                     txt="{}. sfreq: {}".format(i,
                                                self.settings.value("sfreq")),
                     ln=1)
        self.settings.endArray()
        size = self.settings.beginReadArray("SubjectInfo")
        for i in range(size):
            self.settings.setArrayIndex(i)
            pdf.cell(0,
                     10,
                     txt="{}. id: {}".format(i, self.settings.value("id")),
                     ln=1)
            pdf.cell(0,
                     10,
                     txt="{}. First name: {}".format(
                         i, self.settings.value("first_name")),
                     ln=1)
            pdf.cell(0,
                     10,
                     txt="{}. Last name: {}".format(
                         i, self.settings.value("last_name")),
                     ln=1)
            pdf.cell(0,
                     10,
                     txt="{}. Hand: {}".format(i, self.settings.value("hand")),
                     ln=1)
            pdf.cell(0,
                     10,
                     txt="{}. Sex: {}".format(i, self.settings.value("sex")),
                     ln=1)
        self.settings.endArray()
        self.settings.endGroup()
        pdf.cell(0, 10, txt=" ", ln=1)
        pdf.set_font('Times', 'B', 15)
        pdf.cell(0, 5, 'Process', ln=1)
        pdf.set_font('Times', '', 10)
        self.settings.beginGroup("ProcessInfo")
        for action_name in self.action_name:
            size = self.settings.beginReadArray(action_name)
            for i in range(size):
                self.settings.setArrayIndex(i)
                pdf.cell(0,
                         10,
                         txt="{}. Name: {}".format(
                             i, self.settings.value("Name")),
                         ln=1)
                pdf.cell(0,
                         10,
                         txt="{}. Description: {}".format(
                             i, self.settings.value("Description")),
                         ln=1)
                pdf.cell(0,
                         10,
                         txt="{}. Value: {}".format(
                             i, self.settings.value("Value")),
                         ln=1)
            self.settings.endArray()
        self.settings.endGroup()
        pdf.cell(0, 10, txt=" ", ln=1)
        print(path)
        pdf.output('{}_report.pdf'.format(project_name))
        print(f'PDF: {project_name}')
        return True

    @Slot(QObject, result="QVariantList")
    def add_chart_bar(self, chart_view):
        # https://stackoverflow.com/questions/57536401/how-to-add-qml-scatterseries-to-existing-qml-defined-chartview
        context = QQmlContext(self.m_engine.rootContext())
        context.setContextProperty("chart_view", chart_view)
        # context.setContextProperty("type", SeriesType.SeriesTypeBar.value)
        context.setContextProperty("type", SeriesType.SeriesTypePie.value)

        script = """chart_view.createSeries(type, "Pie series");"""
        expression = QQmlExpression(context, chart_view, script)
        serie = expression.evaluate()[0]
        if expression.hasError():
            print(expression.error())
            return
        print(serie, expression)
        data = self.dat[self.project_name]
        print(f'FROM ADD PIE CHART {data} and type {type(data)}')
        serie.append("a", 10.0)
        serie.append("b", 80.0)
        # serie.append("a", data[0] * 1000)
        # serie.append("b", data[1] * 1000)
        # serie.append("c", data[2] * 1000)
        # serie.append("b", data)
        return data

    @Slot(QtCharts.QAbstractSeries)
    def fill_serie(self, serie):
        import random
        mx, Mx = 0, 10
        my, My = -100, 100
        data = self.dat[self.project_name]
        serie.append(1, data[0] * 1000)
        serie.append(2, data[1] * 1000)
        serie.append(3, data[2] * 1000)
        # for _ in range(100):
        #     x = random.uniform(mx, Mx)
        #     y = random.uniform(my, My)
        #     serie.append(x, y)
        # https://doc.qt.io/qt-5/qml-qtcharts-scatterseries.html#borderColor-prop
        serie.setProperty("borderColor", QtGui.QColor("salmon"))
        # https://doc.qt.io/qt-5/qml-qtcharts-scatterseries.html#brush-prop
        serie.setProperty("brush", QtGui.QBrush(QtGui.QColor("green")))
        # https://doc.qt.io/qt-5/qml-qtcharts-scatterseries.html#borderColor-prop
        serie.setProperty("borderWidth", 4.0)

    # Process Example
    @Slot(str, result="QVariantList")
    def my_process_1(self, project_name):
        import statistics
        self.process_info("process_1", "std, variance and mean from channel 0")
        data = get_data_path(project_name)
        print(data, data[0])
        data = get_data(data[0])
        print(data.shape)
        var = statistics.variance(data[0, :])
        mean = statistics.mean(data[0, :])
        std = statistics.stdev(data[0, :])
        value = [std * 1000, float(var) * 1000, float(mean) * 1000]
        self.dat[project_name] = value
        print(value)
        return value
Ejemplo n.º 19
0
class SettingsDialog(QtWidgets.QDialog):
    validator = QRegExpValidator(QRegExp("[A-Za-z0-9_]{6,16}"))

    def __init__(self, parent=None):
        super(SettingsDialog, self).__init__(parent)

        self.settings = QSettings(
            QStandardPaths.writableLocation(QStandardPaths.ConfigLocation) +
            "/settings.ini", QSettings.IniFormat)

        self.usernames = set()
        self.engines = set()

        self.newUsername = ""
        self.newEnginePath = ""

        self._loadSettings()

        self.mainLayout = QtWidgets.QFormLayout()

        self.usernameLineEdit = QtWidgets.QLineEdit(self.newUsername)
        self.usernameLineEdit.setPlaceholderText("Username (a-zA-Z0-9_)")
        self.usernameLineEdit.setMinimumHeight(35)
        self.usernameLineEdit.setValidator(self.validator)
        self.usernameLineEdit.textChanged.connect(self.validateFields)
        self.usernameLineEdit.selectAll()
        self.usernameLineEdit.setCompleter(
            QtWidgets.QCompleter(list(self.usernames), self))

        self.engineEdit = _EngineEdit(self.newEnginePath)
        self.engineEdit.pathEdit.textChanged.connect(self.validateFields)
        self.engineEdit.pathEdit.selectAll()
        self.engineEdit.pathEdit.setCompleter(
            QtWidgets.QCompleter(list(self.engines), self))

        self.resetButton = QtWidgets.QPushButton("Reset")
        self.resetButton.clicked.connect(self._reset)

        buttonBox = QtWidgets.QDialogButtonBox()
        self.okButton = buttonBox.addButton(
            "Ok", QtWidgets.QDialogButtonBox.AcceptRole)
        self.cancelButton = buttonBox.addButton(
            "Cancel", QtWidgets.QDialogButtonBox.RejectRole)
        self.okButton.clicked.connect(self._ok)
        self.cancelButton.clicked.connect(self.reject)

        self.mainLayout.setContentsMargins(0, 0, 0, 0)
        self.mainLayout.setAlignment(Qt.AlignBottom)
        self.mainLayout.addRow("Username", self.usernameLineEdit)
        self.mainLayout.addRow("Engine", self.engineEdit)
        self.mainLayout.addWidget(self.resetButton)
        self.mainLayout.addWidget(buttonBox)
        self.setLayout(self.mainLayout)

        self.validateFields()

    def _validateEnginePath(self, path):
        return QFile.exists(path) and QFileInfo(path).isFile()

    @Slot(str)
    def validateFields(self):
        usernameValid = self.validator.validate(self.usernameLineEdit.text(), 0) and \
                        6 <= len(self.usernameLineEdit.text()) <= 16
        pathValid = self._validateEnginePath(self.engineEdit.pathEdit.text())

        if not usernameValid or not pathValid:
            if self.okButton.isEnabled():
                self.okButton.setDisabled(True)
        else:
            if not self.okButton.isEnabled():
                self.okButton.setDisabled(False)

        if not usernameValid:
            self.usernameLineEdit.setStyleSheet("border: 1px solid red;")
        else:
            self.usernameLineEdit.setStyleSheet("border: 1px solid green;")

        if not pathValid:
            self.engineEdit.pathEdit.setStyleSheet("border: 1px solid red;")
        else:
            self.engineEdit.pathEdit.setStyleSheet("border: 1px solid green;")

    def _loadSettings(self):
        i = self.settings.beginReadArray("usernames")
        currentUsername = ""
        for j in range(i):
            self.settings.setArrayIndex(j)
            currentUsername = self.settings.value("usernames", "")
            self.usernames.add(currentUsername)
        self.newUsername = currentUsername
        self.settings.endArray()

        i = self.settings.beginReadArray("engines")
        currentEngine = ""
        for j in range(i):
            self.settings.setArrayIndex(j)
            currentEngine = self.settings.value("engines", "")
            self.engines.add(currentEngine)
        self.newEnginePath = currentEngine
        self.settings.endArray()

    @Slot()
    def _reset(self):
        status = QtWidgets.QMessageBox.warning(
            self,
            "Reset",
            "Are you sure to reset the settings?",
            buttons=QtWidgets.QMessageBox.Cancel | QtWidgets.QMessageBox.Ok,
            defaultButton=QtWidgets.QMessageBox.Ok)

        if status == QtWidgets.QMessageBox.Ok:
            self.usernameLineEdit.clear()
            self.engineEdit.pathEdit.clear()
            self.usernames.clear()
            self.engines.clear()
            self.usernameLineEdit.setCompleter(QtWidgets.QCompleter())
            self.engineEdit.pathEdit.setCompleter(QtWidgets.QCompleter())
            self.settings.clear()
            self._loadSettings()

    @Slot()
    def _ok(self):
        if self.validator.validate(self.usernameLineEdit.text(), 0):
            self.newUsername = self.usernameLineEdit.text()
        else:
            QtWidgets.QMessageBox.critical(self, "Error", "Invalid username")
            self.reject()

        if self._validateEnginePath(self.engineEdit.pathEdit.text()):
            self.newEnginePath = self.engineEdit.pathEdit.text()
        else:
            QtWidgets.QMessageBox.critical(
                self, "Error", "The specified engine's path does not exist.")
            self.reject()

        self.settings.beginWriteArray("usernames")
        self.usernames.add(self.newUsername)
        for i, username in enumerate(self.usernames):
            self.settings.setArrayIndex(i)
            self.settings.setValue("usernames", username)
        self.settings.endArray()

        self.settings.beginWriteArray("engines")
        self.engines.add(self.newEnginePath)
        for i, path in enumerate(self.engines):
            self.settings.setArrayIndex(i)
            self.settings.setValue("engines", path)
        self.settings.endArray()

        self.accept()