summaryrefslogtreecommitdiff
path: root/Tools/Python/Fd.py
diff options
context:
space:
mode:
Diffstat (limited to 'Tools/Python/Fd.py')
-rw-r--r--Tools/Python/Fd.py573
1 files changed, 573 insertions, 0 deletions
diff --git a/Tools/Python/Fd.py b/Tools/Python/Fd.py
new file mode 100644
index 0000000000..f71cc07171
--- /dev/null
+++ b/Tools/Python/Fd.py
@@ -0,0 +1,573 @@
+#!/usr/bin/env python
+
+# An EDK II Build System Framework Database Utility maintains FrameworkDatabase.db
+# settings in an EDK II Workspace.
+
+import wx, os, sys, copy
+from EdkIIWorkspace import *
+
+class FrameworkDatabaseModel(EdkIIWorkspace):
+ def __init__(self):
+ self.WorkspaceStatus = EdkIIWorkspace.__init__(self)
+ self.Database = {}
+ self.OriginalDatabase = {}
+
+ def AddFile (self, DirName, FileName, FileType, Enabled):
+ if DirName != '':
+ FileName = os.path.join(DirName,FileName)
+ if FileType == 'Package':
+ Header = self.XmlParseFileSection (FileName, 'SpdHeader')
+ Name = XmlElement (Header, '/SpdHeader/PackageName')
+ Version = XmlElement (Header, '/SpdHeader/Version')
+ elif FileType == 'Platform':
+ Header = self.XmlParseFileSection (FileName, 'PlatformHeader')
+ Name = XmlElement (Header, '/PlatformHeader/PlatformName')
+ Version = XmlElement (Header, '/PlatformHeader/Version')
+ else:
+ return
+ FileName = FileName.replace('\\','/')
+ if Name == '' and Version == '':
+ ValidType = 'Invalid'
+ OtherType = 'Valid'
+ UiName = FileName
+ else:
+ ValidType = 'Valid'
+ OtherType = 'Invalid'
+ UiName = Name + ' [' + Version + ']'
+ self.Database[FileType][OtherType]['PossibleSettings'].pop(FileName, None)
+ self.Database[FileType][OtherType]['EnabledSettings'].pop(FileName, None)
+ self.Database[FileType][ValidType]['PossibleSettings'][FileName] = UiName
+ if Enabled:
+ self.Database[FileType][ValidType]['EnabledSettings'][FileName] = UiName
+ return
+
+ def NewModel(self):
+ self.Database['Platform'] = {'Valid': {'PossibleSettings':{}, 'EnabledSettings':{}},'Invalid': {'PossibleSettings':{}, 'EnabledSettings':{}}}
+ self.Database['Package'] = {'Valid': {'PossibleSettings':{}, 'EnabledSettings':{}},'Invalid': {'PossibleSettings':{}, 'EnabledSettings':{}}}
+
+ def RevertModel(self):
+ self.Database = copy.deepcopy(self.OriginalDatabase)
+
+ def RescanModel(self):
+ self.NewModel()
+ self.Fd = self.XmlParseFile ('Tools/Conf/FrameworkDatabase.db')
+ PackageList = XmlList (self.Fd, '/FrameworkDatabase/PackageList/Filename')
+ for File in PackageList:
+ SpdFileName = XmlElementData(File)
+ self.AddFile ('', SpdFileName, 'Package', True)
+ PlatformList = XmlList (self.Fd, '/FrameworkDatabase/PlatformList/Filename')
+ for File in PlatformList:
+ FpdFileName = XmlElementData(File)
+ self.AddFile ('', FpdFileName, 'Platform', True)
+ self.OriginalDatabase = copy.deepcopy(self.Database)
+
+ def RefreshModel(self):
+ Temp = copy.deepcopy(self.Database)
+ for FileType in ['Package','Platform']:
+ for Valid in ['Valid','Invalid']:
+ for Item in Temp[FileType][Valid]['PossibleSettings']:
+ self.AddFile('',Item, FileType, Item in Temp[FileType][Valid]['EnabledSettings'])
+ return True
+
+ def ModelModified(self):
+ if self.Database['Package']['Valid']['EnabledSettings'] != self.OriginalDatabase['Package']['Valid']['EnabledSettings']:
+ return True
+ if self.Database['Package']['Invalid']['EnabledSettings'] != self.OriginalDatabase['Package']['Invalid']['EnabledSettings']:
+ return True
+ if self.Database['Platform']['Valid']['EnabledSettings'] != self.OriginalDatabase['Platform']['Valid']['EnabledSettings']:
+ return True
+ if self.Database['Platform']['Invalid']['EnabledSettings'] != self.OriginalDatabase['Platform']['Invalid']['EnabledSettings']:
+ return True
+ return False
+
+ def SaveModel(self, Filename='Tools/Conf/FrameworkDatabase.db'):
+ EnabledList = self.Database['Package']['Valid']['EnabledSettings'].keys()
+ EnabledList += self.Database['Package']['Invalid']['EnabledSettings'].keys()
+ PackageList = XmlList (self.Fd, '/FrameworkDatabase/PackageList/Filename')
+ for File in PackageList:
+ SpdFileName = XmlElementData(File)
+ if SpdFileName in EnabledList:
+ EnabledList.remove(SpdFileName)
+ continue
+ XmlRemoveElement(File)
+
+ ParentNode = XmlList (self.Fd, '/FrameworkDatabase/PackageList')[0]
+ for SpdFileName in EnabledList:
+ XmlAppendChildElement(ParentNode, u'Filename', SpdFileName)
+
+ EnabledList = self.Database['Platform']['Valid']['EnabledSettings'].keys()
+ EnabledList += self.Database['Platform']['Invalid']['EnabledSettings'].keys()
+ PlatformList = XmlList (self.Fd, '/FrameworkDatabase/PlatformList/Filename')
+ for File in PlatformList:
+ FpdFileName = XmlElementData(File)
+ if FpdFileName in EnabledList:
+ EnabledList.remove(FpdFileName)
+ continue
+ XmlRemoveElement(File)
+
+ ParentNode = XmlList (self.Fd, '/FrameworkDatabase/PlatformList')[0]
+ for FpdFileName in EnabledList:
+ XmlAppendChildElement(ParentNode, u'Filename', FpdFileName)
+
+ self.XmlSaveFile (self.Fd, Filename)
+ self.OriginalDatabase = copy.deepcopy(self.Database)
+
+ def CloseModel(self):
+ pass
+
+class Frame(wx.Frame):
+ def __init__(self):
+ wx.Frame.__init__(self,None,-1,'EDK II Build System Framework Database Utility')
+ panel = wx.Panel(self, style=wx.SUNKEN_BORDER | wx.TAB_TRAVERSAL)
+ wx.HelpProvider_Set(wx.SimpleHelpProvider())
+
+ self.Model = FrameworkDatabaseModel()
+
+ #
+ # Help text
+ #
+ PackagesHelpText = (
+ "The set of packages that are active in the current WORKSPACE."
+ )
+
+ PlatformsHelpText = (
+ "The set of platforms that are active in the current WORKSPACE."
+ )
+
+ InvalidPackagesHelpText = (
+ "The set of packages that are in Framework Database, but not in the current WORKSPACE."
+ )
+
+ InvalidPlatformsHelpText = (
+ "The set of platforms that are in Framework Database, but not in the current WORKSPACE."
+ )
+
+ #
+ # Status Bar
+ #
+ self.StatusBar = self.CreateStatusBar()
+
+ #
+ # Build Menus
+ #
+ MenuBar = wx.MenuBar()
+
+ FileMenu = wx.Menu()
+ NewMenuItem = FileMenu.Append(-1, "&New\tCtrl+N", "New FrameworkDatabase.db")
+ SaveMenuItem = FileMenu.Append(-1, "&Save\tCtrl+S", "Save FramdworkDatabase.db")
+ SaveAsMenuItem = FileMenu.Append(-1, "Save &As...", "Save FrameworkDatabase.db as...")
+ RevertMenuItem = FileMenu.Append(-1, "&Revert", "Revert to the original FrameworkDatabase.db")
+ ScanMenuItem = FileMenu.Append(-1, "Scan &WORKSPACE\tCtrl+W", "Scan WORKSPACE for additional packages and platforms")
+ ScanAndSyncMenuItem = FileMenu.Append(-1, "Scan &WORKSPACE and Sync\tCtrl+W", "Scan WORKSPACE for additional packages and platforms and sync FramdworkDatabase.db")
+ ExitMenuItem = FileMenu.Append(-1, "E&xit\tAlt+F4", "Exit Framework Database Tool")
+ MenuBar.Append(FileMenu, "&File")
+ self.Bind(wx.EVT_MENU, self.OnSaveClick, SaveMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnSaveAsClick, SaveAsMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnRevertClick, RevertMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnScanClick, ScanMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnScanAndSyncClick, ScanAndSyncMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnExitClick, ExitMenuItem)
+
+ EditMenu = wx.Menu()
+ SelectAllPlatformsMenuItem = EditMenu.Append (-1, "Select All Platforms", "Select all platforms")
+ ClearAllPlatformsMenuItem = EditMenu.Append (-1, "Clear All Platforms", "Clear all platforms")
+ SelectAllPackagesMenuItem = EditMenu.Append (-1, "Select All Packages", "Select all packages")
+ ClearAllPackagesMenuItem = EditMenu.Append (-1, "Clear All Packages", "Clear all packages")
+ SelectAllInvalidPlatformsMenuItem = EditMenu.Append (-1, "Select All Invalid Platforms", "Select all invalid platforms")
+ ClearAllInvalidPlatformsMenuItem = EditMenu.Append (-1, "Clear All Invalid Platforms", "Clear all invalid platforms")
+ SelectAllInvalidPackagesMenuItem = EditMenu.Append (-1, "Select All Invalid Packages", "Select all invalid packages")
+ ClearAllInvalidPackagesMenuItem = EditMenu.Append (-1, "Clear All Invalid Packages", "Clear all invalid packages")
+ MenuBar.Append(EditMenu, "&Edit")
+ self.Bind(wx.EVT_MENU, self.OnSelectAllPlatformsClick, SelectAllPlatformsMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnClearAllPlatformsClick, ClearAllPlatformsMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnSelectAllPackagesClick, SelectAllPackagesMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnClearAllPackagesClick, ClearAllPackagesMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnSelectAllInvalidPlatformsClick, SelectAllInvalidPlatformsMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnClearAllInvalidPlatformsClick, ClearAllInvalidPlatformsMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnSelectAllInvalidPackagesClick, SelectAllInvalidPackagesMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnClearAllInvalidPackagesClick, ClearAllInvalidPackagesMenuItem)
+
+ ViewMenu = wx.Menu()
+ RefreshMenuItem = ViewMenu.Append (-1, "&Refresh\tF5", "Rescan FrameworkDatabase.db")
+ ShowToolBarMenuItem = ViewMenu.AppendCheckItem (-1, "Show &Toolbar", "Shows or hides the toolbar")
+ ShowToolBarMenuItem.Check(True)
+ MenuBar.Append(ViewMenu, "&View")
+ self.Bind(wx.EVT_MENU, self.OnViewRefreshClick, RefreshMenuItem)
+ self.Bind(wx.EVT_MENU, self.OnShowToolBarClick, ShowToolBarMenuItem)
+
+ HelpMenu = wx.Menu()
+ AboutMenuItem = HelpMenu.Append (-1, "&About...", "About")
+ MenuBar.Append(HelpMenu, "&Help")
+ self.Bind(wx.EVT_MENU, self.OnAboutClick, AboutMenuItem)
+
+ self.SetMenuBar (MenuBar)
+
+ #
+ # Build Toolbar
+ #
+ self.ShowToolBar = False
+ self.OnShowToolBarClick(self)
+
+ #
+ # Target, ToolChain, and Arch Check List Boxes
+ #
+ PackagesLabel = wx.StaticText(panel, -1, 'Packages')
+ PackagesLabel.SetFont(wx.Font(12, wx.FONTFAMILY_DEFAULT, wx.NORMAL, wx.FONTWEIGHT_BOLD))
+ PackagesLabel.SetHelpText(PackagesHelpText)
+
+ PlatformsLabel = wx.StaticText(panel, -1, 'Platforms')
+ PlatformsLabel.SetFont(wx.Font(12, wx.FONTFAMILY_DEFAULT, wx.NORMAL, wx.FONTWEIGHT_BOLD))
+ PlatformsLabel.SetHelpText(PlatformsHelpText)
+
+ #
+ # Buttons
+ #
+ self.SelectAllPackagesButton = wx.Button(panel, -1, 'Select All')
+ self.ClearAllPackagesButton = wx.Button(panel, -1, 'Clear All')
+ self.SelectAllPackagesButton.Bind (wx.EVT_BUTTON, self.OnSelectAllPackagesClick)
+ self.ClearAllPackagesButton.Bind (wx.EVT_BUTTON, self.OnClearAllPackagesClick)
+
+ self.PackagesCheckListBox = wx.CheckListBox(panel, -1)
+ self.PackagesCheckListBox.Bind(wx.EVT_CHECKLISTBOX, self.OnPackagesCheckListClick)
+ self.PackagesCheckListBox.Bind(wx.EVT_SET_FOCUS, self.OnPackagesSetFocus)
+ self.PackagesCheckListBox.Bind(wx.EVT_KILL_FOCUS, self.OnPackagesKillFocus)
+ self.PackagesCheckListBox.SetHelpText(PackagesHelpText)
+
+
+ self.SelectAllPlatformsButton = wx.Button(panel, -1, 'Select All')
+ self.ClearAllPlatformsButton = wx.Button(panel, -1, 'Clear All')
+ self.SelectAllPlatformsButton.Bind(wx.EVT_BUTTON, self.OnSelectAllPlatformsClick)
+ self.ClearAllPlatformsButton.Bind (wx.EVT_BUTTON, self.OnClearAllPlatformsClick)
+
+ self.PlatformsCheckListBox = wx.CheckListBox(panel, -1)
+ self.PlatformsCheckListBox.Bind(wx.EVT_CHECKLISTBOX, self.OnPlatformsCheckListClick)
+ self.PlatformsCheckListBox.Bind(wx.EVT_SET_FOCUS, self.OnPlatformsSetFocus)
+ self.PlatformsCheckListBox.Bind(wx.EVT_KILL_FOCUS, self.OnPlatformsKillFocus)
+ self.PlatformsCheckListBox.SetHelpText(PlatformsHelpText)
+
+ InvalidPackagesLabel = wx.StaticText(panel, -1, 'Invalid Packages')
+ InvalidPackagesLabel.SetFont(wx.Font(12, wx.FONTFAMILY_DEFAULT, wx.NORMAL, wx.FONTWEIGHT_BOLD))
+ InvalidPackagesLabel.SetHelpText(InvalidPackagesHelpText)
+
+ InvalidPlatformsLabel = wx.StaticText(panel, -1, 'Invalid Platforms')
+ InvalidPlatformsLabel.SetFont(wx.Font(12, wx.FONTFAMILY_DEFAULT, wx.NORMAL, wx.FONTWEIGHT_BOLD))
+ InvalidPlatformsLabel.SetHelpText(InvalidPlatformsHelpText)
+
+ self.SelectAllInvalidPackagesButton = wx.Button(panel, -1, 'Select All')
+ self.ClearAllInvalidPackagesButton = wx.Button(panel, -1, 'Clear All')
+ self.SelectAllInvalidPackagesButton.Bind (wx.EVT_BUTTON, self.OnSelectAllInvalidPackagesClick)
+ self.ClearAllInvalidPackagesButton.Bind (wx.EVT_BUTTON, self.OnClearAllInvalidPackagesClick)
+
+ self.InvalidPackagesCheckListBox = wx.CheckListBox(panel, -1)
+ self.InvalidPackagesCheckListBox.Bind(wx.EVT_CHECKLISTBOX, self.OnInvalidPackagesCheckListClick)
+ self.InvalidPackagesCheckListBox.Bind(wx.EVT_SET_FOCUS, self.OnInvalidPackagesSetFocus)
+ self.InvalidPackagesCheckListBox.Bind(wx.EVT_KILL_FOCUS, self.OnInvalidPackagesKillFocus)
+ self.InvalidPackagesCheckListBox.SetHelpText(PackagesHelpText)
+
+ self.SelectAllInvalidPlatformsButton = wx.Button(panel, -1, 'Select All')
+ self.ClearAllInvalidPlatformsButton = wx.Button(panel, -1, 'Clear All')
+ self.SelectAllInvalidPlatformsButton.Bind(wx.EVT_BUTTON, self.OnSelectAllInvalidPlatformsClick)
+ self.ClearAllInvalidPlatformsButton.Bind (wx.EVT_BUTTON, self.OnClearAllInvalidPlatformsClick)
+
+ self.InvalidPlatformsCheckListBox = wx.CheckListBox(panel, -1)
+ self.InvalidPlatformsCheckListBox.Bind(wx.EVT_CHECKLISTBOX, self.OnInvalidPlatformsCheckListClick)
+ self.InvalidPlatformsCheckListBox.Bind(wx.EVT_SET_FOCUS, self.OnInvalidPlatformsSetFocus)
+ self.InvalidPlatformsCheckListBox.Bind(wx.EVT_KILL_FOCUS, self.OnInvalidPlatformsKillFocus)
+ self.InvalidPlatformsCheckListBox.SetHelpText(PlatformsHelpText)
+
+ #
+ # Define layout using sizers
+ #
+ self.mainSizer = wx.BoxSizer(wx.VERTICAL)
+
+ listSizer = wx.GridBagSizer(hgap=5, vgap=5)
+ listSizer.Add(PackagesLabel, pos=(0,0), span=(1,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(PlatformsLabel, pos=(0,2), span=(1,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.SelectAllPackagesButton, pos=(1,0), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.ClearAllPackagesButton, pos=(1,1), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.SelectAllPlatformsButton, pos=(1,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.ClearAllPlatformsButton, pos=(1,3), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.PackagesCheckListBox, pos=(2,0), span=(1,2), flag=wx.ALL | wx.EXPAND)
+ listSizer.Add(self.PlatformsCheckListBox, pos=(2,2), span=(1,2), flag=wx.ALL | wx.EXPAND)
+
+ listSizer.Add(InvalidPackagesLabel, pos=(3,0), span=(1,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(InvalidPlatformsLabel, pos=(3,2), span=(1,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.SelectAllInvalidPackagesButton, pos=(4,0), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.ClearAllInvalidPackagesButton, pos=(4,1), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.SelectAllInvalidPlatformsButton, pos=(4,2), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.ClearAllInvalidPlatformsButton, pos=(4,3), flag=wx.ALIGN_CENTER)
+ listSizer.Add(self.InvalidPackagesCheckListBox, pos=(5,0), span=(1,2), flag=wx.ALL | wx.EXPAND)
+ listSizer.Add(self.InvalidPlatformsCheckListBox, pos=(5,2), span=(1,2), flag=wx.ALL | wx.EXPAND)
+
+ listSizer.AddGrowableRow(2)
+ listSizer.AddGrowableRow(5)
+ listSizer.AddGrowableCol(0)
+ listSizer.AddGrowableCol(1)
+ listSizer.AddGrowableCol(2)
+ listSizer.AddGrowableCol(3)
+
+ self.mainSizer.Add (listSizer, wx.EXPAND | wx.ALL, wx.EXPAND | wx.ALL, 10)
+
+ panel.SetSizer (self.mainSizer)
+
+ self.OnViewRefreshClick(self)
+
+ def CheckListFocus(self, CheckListBox, Set):
+ Index = 0
+ while Index < CheckListBox.GetCount():
+ CheckListBox.SetSelection(Index, False)
+ Index += 1
+ if Set and CheckListBox.GetCount() > 0:
+ CheckListBox.SetSelection(0, True)
+
+ def CheckListClick(self, CheckListBox, Database):
+ Index = 0
+ Database['EnabledSettings'] = {}
+ while Index < CheckListBox.GetCount():
+ if CheckListBox.IsChecked(Index):
+ for Item in Database['PossibleSettings']:
+ if Database['PossibleSettings'][Item] == CheckListBox.GetString(Index):
+ Database['EnabledSettings'][Item] = Database['PossibleSettings'][Item]
+ Index += 1
+
+ def OnPackagesCheckListClick(self, event):
+ self.CheckListClick(self.PackagesCheckListBox, self.Model.Database['Package']['Valid'])
+
+ def OnPackagesSetFocus(self, event):
+ self.CheckListFocus(self.PackagesCheckListBox, True)
+
+ def OnPackagesKillFocus(self, event):
+ self.CheckListFocus(self.PackagesCheckListBox, False)
+
+ def OnPlatformsCheckListClick(self, event):
+ self.CheckListClick(self.PlatformsCheckListBox, self.Model.Database['Platform']['Valid'])
+
+ def OnPlatformsSetFocus(self, event):
+ self.CheckListFocus(self.PlatformsCheckListBox, True)
+
+ def OnPlatformsKillFocus(self, event):
+ self.CheckListFocus(self.PlatformsCheckListBox, False)
+
+ def OnInvalidPackagesCheckListClick(self, event):
+ self.CheckListClick(self.InvalidPackagesCheckListBox, self.Model.Database['Package']['Invalid'])
+
+ def OnInvalidPackagesSetFocus(self, event):
+ self.CheckListFocus(self.InvalidPackagesCheckListBox, True)
+
+ def OnInvalidPackagesKillFocus(self, event):
+ self.CheckListFocus(self.InvalidPackagesCheckListBox, False)
+
+ def OnInvalidPlatformsCheckListClick(self, event):
+ self.CheckListClick(self.InvalidPlatformsCheckListBox, self.Model.Database['Platform']['Invalid'])
+
+ def OnInvalidPlatformsSetFocus(self, event):
+ self.CheckListFocus(self.InvalidPlatformsCheckListBox, True)
+
+ def OnInvalidPlatformsKillFocus(self, event):
+ self.CheckListFocus(self.InvalidPlatformsCheckListBox, False)
+
+ def OnRevertClick(self, event):
+ self.Model.RevertModel()
+ self.StatusBar.SetFocus()
+ self.OnRefreshClick(self)
+
+ def RefreshCheckListBox(self, CheckListBox, SelectAllButton, ClearAllButton, Database):
+ NameList = []
+ for Item in Database['PossibleSettings']:
+ NameList.append(Database['PossibleSettings'][Item])
+ NameList.sort()
+ CheckListBox.Set(NameList)
+ Index = 0
+ MaximumString = '.'
+ while Index < CheckListBox.GetCount():
+ String = CheckListBox.GetString(Index)
+ if len(String) > len(MaximumString):
+ MaximumString = String
+ Enabled = False
+ for Item in Database['EnabledSettings']:
+ if String == Database['EnabledSettings'][Item]:
+ Enabled = True
+ if Enabled:
+ CheckListBox.Check(Index, True)
+ else:
+ CheckListBox.Check(Index, False)
+ Index += 1
+ Extents = CheckListBox.GetFullTextExtent (MaximumString)
+ CheckListBox.SetMinSize((Extents[0] + 30,(CheckListBox.GetCount()+2) * (Extents[1]+Extents[2])))
+ if NameList == []:
+ CheckListBox.Disable()
+ SelectAllButton.Disable()
+ ClearAllButton.Disable()
+ else:
+ CheckListBox.Enable()
+ SelectAllButton.Enable()
+ ClearAllButton.Enable()
+
+ def OnRefreshClick(self, event):
+ self.Model.RefreshModel()
+ self.RefreshCheckListBox (self.PackagesCheckListBox, self.SelectAllPackagesButton, self.ClearAllPackagesButton, self.Model.Database['Package']['Valid'])
+ self.RefreshCheckListBox (self.PlatformsCheckListBox, self.SelectAllPlatformsButton, self.ClearAllPlatformsButton, self.Model.Database['Platform']['Valid'])
+ self.RefreshCheckListBox (self.InvalidPackagesCheckListBox, self.SelectAllInvalidPackagesButton, self.ClearAllInvalidPackagesButton, self.Model.Database['Package']['Invalid'])
+ self.RefreshCheckListBox (self.InvalidPlatformsCheckListBox, self.SelectAllInvalidPlatformsButton, self.ClearAllInvalidPlatformsButton, self.Model.Database['Platform']['Invalid'])
+ self.mainSizer.SetSizeHints(self)
+ self.mainSizer.Fit(self)
+ self.Update()
+
+ def OnViewRefreshClick(self, event):
+ self.Model.RescanModel()
+ self.StatusBar.SetFocus()
+ self.OnRefreshClick(self)
+
+ def AddTool (self, Handler, ArtId, Label, HelpText):
+ Tool = self.ToolBar.AddSimpleTool(
+ -1,
+ wx.ArtProvider.GetBitmap(ArtId, wx.ART_TOOLBAR, self.ToolSize),
+ Label,
+ HelpText
+ )
+ self.Bind(wx.EVT_MENU, Handler, Tool)
+
+ def OnShowToolBarClick(self, event):
+ if self.ShowToolBar:
+ self.ShowToolBar = False
+ self.ToolBar.Destroy()
+ else:
+ self.ShowToolBar = True
+ self.ToolBar = self.CreateToolBar()
+ self.ToolSize = (24,24)
+ self.ToolBar.SetToolBitmapSize(self.ToolSize)
+ self.AddTool (self.OnNewClick, wx.ART_NEW, "New", "New FrameworkDatabase.db")
+ self.AddTool (self.OnScanAndSyncClick, wx.ART_HARDDISK, "Scan WORKSPACE and Sync", "Scan WORKSPACE for new Packages and Platforms and sync FrameworkDatabase.db")
+ self.AddTool (self.OnSaveClick, wx.ART_FILE_SAVE, "Save", "Save FrameworkDatabase.db")
+ self.AddTool (self.OnSaveAsClick, wx.ART_FILE_SAVE_AS, "Save As...", "Save FrameworkDatabase.db as...")
+ self.AddTool (self.OnRevertClick, wx.ART_UNDO, "Revert", "Revert to original FrameworkDatabase.db")
+ self.AddTool (self.OnHelpClick, wx.ART_HELP, "Help", "Context Sensitive Help")
+ self.AddTool (self.OnExitClick, wx.ART_QUIT, "Exit", "Exit EDK II Build System Framework Database Utility")
+ self.ToolBar.Realize()
+
+ def OnNewClick(self, event):
+ self.Model.NewModel()
+ self.OnRefreshClick(self)
+
+ def ScanDirectory(self, Data, DirName, FilesInDir):
+ WorkspaceDirName = self.Model.WorkspaceRelativePath(DirName)
+ self.StatusBar.SetStatusText('Scanning: ' + WorkspaceDirName)
+ RemoveList = []
+ for File in FilesInDir:
+ if File[0] == '.':
+ RemoveList.insert(0, File)
+ for File in RemoveList:
+ FilesInDir.remove(File)
+ for File in FilesInDir:
+ if os.path.splitext(File)[1].lower() == '.spd':
+ self.Model.AddFile (WorkspaceDirName, File, 'Package', False)
+ self.OnRefreshClick(self)
+ if os.path.splitext(File)[1].lower() == '.fpd':
+ self.Model.AddFile (WorkspaceDirName, File, 'Platform', False)
+ self.OnRefreshClick(self)
+
+ def OnScanClick(self, event):
+ os.path.walk(self.Model.WorkspaceFile(''), self.ScanDirectory, None)
+ self.StatusBar.SetStatusText('Scanning: Complete')
+ self.StatusBar.SetFocus()
+ self.OnRefreshClick(self)
+
+ def OnScanAndSyncClick(self, event):
+ self.OnSelectAllPackagesClick(self)
+ self.OnSelectAllPlatformsClick(self)
+ self.OnClearAllInvalidPackagesClick(self)
+ self.OnClearAllInvalidPlatformsClick(self)
+ self.OnScanClick(self)
+ self.OnSelectAllPackagesClick(self)
+ self.OnSelectAllPlatformsClick(self)
+ self.OnClearAllInvalidPackagesClick(self)
+ self.OnClearAllInvalidPlatformsClick(self)
+
+ def OnSelectAllPackagesClick(self, event):
+ self.Model.Database['Package']['Valid']['EnabledSettings'] = self.Model.Database['Package']['Valid']['PossibleSettings']
+ self.OnRefreshClick(self)
+
+ def OnClearAllPackagesClick(self, event):
+ self.Model.Database['Package']['Valid']['EnabledSettings'] = {}
+ self.OnRefreshClick(self)
+
+ def OnSelectAllPlatformsClick(self, event):
+ self.Model.Database['Platform']['Valid']['EnabledSettings'] = self.Model.Database['Platform']['Valid']['PossibleSettings']
+ self.OnRefreshClick(self)
+
+ def OnClearAllPlatformsClick(self, event):
+ self.Model.Database['Platform']['Valid']['EnabledSettings'] = {}
+ self.OnRefreshClick(self)
+
+ def OnSelectAllInvalidPackagesClick(self, event):
+ self.Model.Database['Package']['Invalid']['EnabledSettings'] = self.Model.Database['Package']['Invalid']['PossibleSettings']
+ self.OnRefreshClick(self)
+
+ def OnClearAllInvalidPackagesClick(self, event):
+ self.Model.Database['Package']['Invalid']['EnabledSettings'] = {}
+ self.OnRefreshClick(self)
+
+ def OnSelectAllInvalidPlatformsClick(self, event):
+ self.Model.Database['Platform']['Invalid']['EnabledSettings'] = self.Model.Database['Platform']['Invalid']['PossibleSettings']
+ self.OnRefreshClick(self)
+
+ def OnClearAllInvalidPlatformsClick(self, event):
+ self.Model.Database['Platform']['Invalid']['EnabledSettings'] = {}
+ self.OnRefreshClick(self)
+
+ def OnSaveClick(self, event):
+ self.Model.SaveModel()
+
+ def OnSaveAsClick(self, event):
+ wildcard = "Text Documents (*.db)|*.db|" \
+ "All files (*.*)|*.*"
+ dialog = wx.FileDialog (None, 'Save As', self.Model.WorkspaceFile('Tools/Conf'), '', wildcard, wx.SAVE | wx.OVERWRITE_PROMPT)
+ if dialog.ShowModal() == wx.ID_OK:
+ FrameworkDatabaseDbFile = self.Model.WorkspaceRelativePath(dialog.GetPath())
+ if FrameworkDatabaseDbFile != '':
+ self.Model.SaveModel(FrameworkDatabaseDbFile)
+ dialog.Destroy()
+
+ def OnExitClick(self, event):
+ if self.Model.ModelModified():
+ dialog = wx.MessageDialog(None, 'The contents have changed.\nDo you want to save changes?', 'EDK II Build System Framework Databsase Utility', style = wx.YES_NO | wx.YES_DEFAULT | wx.CANCEL | wx.ICON_EXCLAMATION)
+ Status = dialog.ShowModal()
+ dialog.Destroy()
+ if Status == wx.ID_YES:
+ self.OnSaveClick (self)
+ elif Status == wx.ID_CANCEL:
+ return
+ self.Model.CloseModel()
+ self.Close()
+
+ def OnHelpClick(self, event):
+ wx.ContextHelp().BeginContextHelp()
+
+ def OnAboutClick(self, event):
+ AboutInfo = wx.AboutDialogInfo()
+ AboutInfo.Name = 'EDK II Build System Framework Database Utility'
+ AboutInfo.Version = '0.3'
+ AboutInfo.Copyright = 'Copyright (c) 2006, Intel Corporation'
+ AboutInfo.Description = """
+ The EDK II Build System Framework Database Utility maintains FrameworkDatabase.db
+ settings in an EDK II Workspace."""
+ AboutInfo.WebSite = ("http://tianocore.org", "Tiano Core home page")
+ AboutInfo.License = """
+ All rights reserved. This program and the accompanying materials are
+ licensed and made available under the terms and conditions of the BSD
+ License which accompanies this distribution. The full text of the
+ license may be found at http://opensource.org/licenses/bsd-license.php
+
+ THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS"
+ BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND,
+ EITHER EXPRESS OR IMPLIED."""
+ if self.Model.Icon != None:
+ AboutInfo.Icon = self.Model.Icon
+ wx.AboutBox(AboutInfo)
+
+if __name__ == '__main__':
+ app = wx.PySimpleApp()
+ frame = Frame()
+ frame.Show()
+ app.MainLoop()
+ \ No newline at end of file