# HG changeset patch # User Edouard Tisserant # Date 1403513822 -7200 # Node ID 0e1a6fcf4670ce7260b14286d5fd8f750652df57 # Parent 71b1545d746f574bb8e45952b4985302928021e2 Enable overloading of availables languages in POU creation dialog diff -r 71b1545d746f -r 0e1a6fcf4670 dialogs/PouDialog.py --- a/dialogs/PouDialog.py Fri Jun 20 21:36:23 2014 +0200 +++ b/dialogs/PouDialog.py Mon Jun 23 10:57:02 2014 +0200 @@ -2,7 +2,7 @@ # -*- coding: utf-8 -*- #This file is part of PLCOpenEditor, a library implementing an IEC 61131-3 editor -#based on the plcopen standard. +#based on the plcopen standard. # #Copyright (C) 2012: Edouard TISSERANT and Laurent BESSARD # @@ -34,54 +34,56 @@ def GetPouLanguages(): _ = lambda x : x return [_("IL"), _("ST"), _("LD"), _("FBD"), _("SFC")] -POU_LANGUAGES_DICT = dict([(_(language), language) for language in GetPouLanguages()]) class PouDialog(wx.Dialog): - + + POU_LANGUAGES = GetPouLanguages() + POU_LANGUAGES_DICT = dict([(_(language), language) for language in POU_LANGUAGES]) + def __init__(self, parent, pou_type = None): wx.Dialog.__init__(self, id=-1, parent=parent, - name='PouDialog', title=_('Create a new POU'), + name='PouDialog', title=_('Create a new POU'), size=wx.Size(300, 200), style=wx.DEFAULT_DIALOG_STYLE) self.SetClientSize(wx.Size(300, 200)) - + main_sizer = wx.FlexGridSizer(cols=1, hgap=0, rows=2, vgap=10) main_sizer.AddGrowableCol(0) main_sizer.AddGrowableRow(0) - + infos_sizer = wx.FlexGridSizer(cols=2, hgap=5, rows=3, vgap=15) infos_sizer.AddGrowableCol(1) - main_sizer.AddSizer(infos_sizer, border=20, + main_sizer.AddSizer(infos_sizer, border=20, flag=wx.GROW|wx.TOP|wx.LEFT|wx.RIGHT) - + pouname_label = wx.StaticText(self, label=_('POU Name:')) - infos_sizer.AddWindow(pouname_label, border=4, + infos_sizer.AddWindow(pouname_label, border=4, flag=wx.ALIGN_CENTER_VERTICAL|wx.TOP) - + self.PouName = wx.TextCtrl(self) infos_sizer.AddWindow(self.PouName, flag=wx.GROW) - + poutype_label = wx.StaticText(self, label=_('POU Type:')) - infos_sizer.AddWindow(poutype_label, border=4, + infos_sizer.AddWindow(poutype_label, border=4, flag=wx.ALIGN_CENTER_VERTICAL|wx.TOP) - + self.PouType = wx.ComboBox(self, style=wx.CB_READONLY) self.Bind(wx.EVT_COMBOBOX, self.OnTypeChanged, self.PouType) infos_sizer.AddWindow(self.PouType, flag=wx.GROW) - + language_label = wx.StaticText(self, label=_('Language:')) - infos_sizer.AddWindow(language_label, border=4, + infos_sizer.AddWindow(language_label, border=4, flag=wx.ALIGN_CENTER_VERTICAL|wx.TOP) - + self.Language = wx.ComboBox(self, style=wx.CB_READONLY) infos_sizer.AddWindow(self.Language, flag=wx.GROW) - + button_sizer = self.CreateButtonSizer(wx.OK|wx.CANCEL|wx.CENTRE) self.Bind(wx.EVT_BUTTON, self.OnOK, button_sizer.GetAffirmativeButton()) - main_sizer.AddSizer(button_sizer, border=20, + main_sizer.AddSizer(button_sizer, border=20, flag=wx.ALIGN_RIGHT|wx.BOTTOM|wx.LEFT|wx.RIGHT) - + self.SetSizer(main_sizer) - + for option in GetPouTypes(): self.PouType.Append(_(option)) if pou_type is not None: @@ -110,7 +112,7 @@ elif i == len(error) - 1: text += _(" and %s")%item else: - text += _(", %s")%item + text += _(", %s")%item message = _("Form isn't complete. %s must be filled!") % text elif not TestIdentifier(pou_name): message = _("\"%s\" is not a valid identifier!") % pou_name @@ -136,9 +138,9 @@ self.EndModal(wx.ID_OK) def RefreshLanguage(self): - selection = POU_LANGUAGES_DICT.get(self.Language.GetStringSelection(), "") + selection = self.POU_LANGUAGES_DICT.get(self.Language.GetStringSelection(), "") self.Language.Clear() - for language in GetPouLanguages(): + for language in self.POU_LANGUAGES: if language != "SFC" or POU_TYPES_DICT[self.PouType.GetStringSelection()] != "function": self.Language.Append(_(language)) if self.Language.FindString(_(selection)) != wx.NOT_FOUND: @@ -162,10 +164,10 @@ self.PouType.SetStringSelection(_(value)) elif item == "language": self.Language.SetStringSelection(_(value)) - + def GetValues(self): values = {} values["pouName"] = self.PouName.GetValue() values["pouType"] = POU_TYPES_DICT[self.PouType.GetStringSelection()] - values["language"] = POU_LANGUAGES_DICT[self.Language.GetStringSelection()] + values["language"] = self.POU_LANGUAGES_DICT[self.Language.GetStringSelection()] return values