2009-07-17 11:10:31 +02:00
|
|
|
## @file
|
|
|
|
# This file is used to create/update/query/erase table for ECC reports
|
|
|
|
#
|
2018-07-05 11:40:04 +02:00
|
|
|
# Copyright (c) 2008 - 2018, Intel Corporation. All rights reserved.<BR>
|
2010-05-18 07:04:32 +02:00
|
|
|
# This program and the accompanying materials
|
2009-07-17 11:10:31 +02:00
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
|
|
|
|
##
|
|
|
|
# Import Modules
|
|
|
|
#
|
2018-07-13 12:18:44 +02:00
|
|
|
from __future__ import absolute_import
|
2009-07-17 11:10:31 +02:00
|
|
|
import Common.EdkLogger as EdkLogger
|
2014-08-15 05:06:48 +02:00
|
|
|
import Common.LongFilePathOs as os, time
|
2018-08-08 05:18:06 +02:00
|
|
|
from Table.Table import Table
|
2018-05-19 12:50:25 +02:00
|
|
|
from Common.StringUtils import ConvertToSqlString2
|
2010-03-01 00:39:39 +01:00
|
|
|
import Eot.EotToolError as EotToolError
|
|
|
|
import Eot.EotGlobalData as EotGlobalData
|
2009-07-17 11:10:31 +02:00
|
|
|
|
|
|
|
## TableReport
|
|
|
|
#
|
|
|
|
# This class defined a table used for data model
|
2018-07-05 11:40:04 +02:00
|
|
|
#
|
2009-07-17 11:10:31 +02:00
|
|
|
# @param object: Inherited from object class
|
|
|
|
#
|
|
|
|
#
|
|
|
|
class TableEotReport(Table):
|
|
|
|
def __init__(self, Cursor):
|
|
|
|
Table.__init__(self, Cursor)
|
|
|
|
self.Table = 'Report'
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
## Create table
|
|
|
|
#
|
|
|
|
# Create table report
|
|
|
|
#
|
|
|
|
#
|
|
|
|
def Create(self):
|
|
|
|
SqlCommand = """create table IF NOT EXISTS %s (ID INTEGER PRIMARY KEY,
|
|
|
|
ModuleID INTEGER DEFAULT -1,
|
|
|
|
ModuleName TEXT DEFAULT '',
|
|
|
|
ModuleGuid TEXT DEFAULT '',
|
|
|
|
SourceFileID INTEGER DEFAULT -1,
|
|
|
|
SourceFileFullPath TEXT DEFAULT '',
|
|
|
|
ItemName TEXT DEFAULT '',
|
|
|
|
ItemType TEXT DEFAULT '',
|
|
|
|
ItemMode TEXT DEFAULT '',
|
|
|
|
GuidName TEXT DEFAULT '',
|
|
|
|
GuidMacro TEXT DEFAULT '',
|
|
|
|
GuidValue TEXT DEFAULT '',
|
|
|
|
BelongsToFunction TEXT DEFAULT '',
|
|
|
|
Enabled INTEGER DEFAULT 0
|
|
|
|
)""" % self.Table
|
|
|
|
Table.Create(self, SqlCommand)
|
|
|
|
|
|
|
|
## Insert table
|
|
|
|
#
|
|
|
|
# Insert a record into table report
|
|
|
|
#
|
|
|
|
#
|
|
|
|
def Insert(self, ModuleID = -1, ModuleName = '', ModuleGuid = '', SourceFileID = -1, SourceFileFullPath = '', \
|
|
|
|
ItemName = '', ItemType = '', ItemMode = '', GuidName = '', GuidMacro = '', GuidValue = '', BelongsToFunction = '', Enabled = 0):
|
|
|
|
self.ID = self.ID + 1
|
|
|
|
SqlCommand = """insert into %s values(%s, %s, '%s', '%s', %s, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %s)""" \
|
|
|
|
% (self.Table, self.ID, ModuleID, ModuleName, ModuleGuid, SourceFileID, SourceFileFullPath, \
|
|
|
|
ItemName, ItemType, ItemMode, GuidName, GuidMacro, GuidValue, BelongsToFunction, Enabled)
|
|
|
|
Table.Insert(self, SqlCommand)
|
2018-07-05 11:40:04 +02:00
|
|
|
|
2009-07-17 11:10:31 +02:00
|
|
|
def GetMaxID(self):
|
|
|
|
SqlCommand = """select max(ID) from %s""" % self.Table
|
|
|
|
self.Cur.execute(SqlCommand)
|
|
|
|
for Item in self.Cur:
|
2018-07-05 11:40:04 +02:00
|
|
|
return Item[0]
|