]> git.proxmox.com Git - mirror_edk2.git/blame - BaseTools/Source/Python/Table/TableFunction.py
UefiCpuPkg: Move AsmRelocateApLoopStart from Mpfuncs.nasm to AmdSev.nasm
[mirror_edk2.git] / BaseTools / Source / Python / Table / TableFunction.py
CommitLineData
30fdf114
LG
1## @file\r
2# This file is used to create/update/query/erase table for functions\r
3#\r
f7496d71 4# Copyright (c) 2008 - 2018, Intel Corporation. All rights reserved.<BR>\r
2e351cbe 5# SPDX-License-Identifier: BSD-2-Clause-Patent\r
30fdf114
LG
6#\r
7\r
8##\r
9# Import Modules\r
10#\r
1ccc4d89 11from __future__ import absolute_import\r
30fdf114 12import Common.EdkLogger as EdkLogger\r
855698fb 13from Table.Table import Table\r
5a57246e 14from Common.StringUtils import ConvertToSqlString\r
30fdf114
LG
15\r
16## TableFunction\r
17#\r
18# This class defined a table used for function\r
f7496d71 19#\r
30fdf114
LG
20# @param Table: Inherited from Table class\r
21#\r
22class TableFunction(Table):\r
23 def __init__(self, Cursor):\r
24 Table.__init__(self, Cursor)\r
25 self.Table = 'Function'\r
f7496d71 26\r
30fdf114
LG
27 ## Create table\r
28 #\r
29 # Create table Function\r
30 #\r
31 # @param ID: ID of a Function\r
32 # @param Header: Header of a Function\r
f7496d71 33 # @param Modifier: Modifier of a Function\r
30fdf114 34 # @param Name: Name of a Function\r
fb0b35e0 35 # @param ReturnStatement: ReturnStatement of a Function\r
30fdf114
LG
36 # @param StartLine: StartLine of a Function\r
37 # @param StartColumn: StartColumn of a Function\r
38 # @param EndLine: EndLine of a Function\r
39 # @param EndColumn: EndColumn of a Function\r
40 # @param BodyStartLine: StartLine of a Function body\r
41 # @param BodyStartColumn: StartColumn of a Function body\r
42 # @param BelongsToFile: The Function belongs to which file\r
43 # @param FunNameStartLine: StartLine of a Function name\r
44 # @param FunNameStartColumn: StartColumn of a Function name\r
45 #\r
46 def Create(self):\r
47 SqlCommand = """create table IF NOT EXISTS %s (ID INTEGER PRIMARY KEY,\r
48 Header TEXT,\r
49 Modifier VARCHAR,\r
50 Name VARCHAR NOT NULL,\r
51 ReturnStatement VARCHAR,\r
52 StartLine INTEGER NOT NULL,\r
53 StartColumn INTEGER NOT NULL,\r
54 EndLine INTEGER NOT NULL,\r
55 EndColumn INTEGER NOT NULL,\r
56 BodyStartLine INTEGER NOT NULL,\r
57 BodyStartColumn INTEGER NOT NULL,\r
58 BelongsToFile SINGLE NOT NULL,\r
59 FunNameStartLine INTEGER NOT NULL,\r
60 FunNameStartColumn INTEGER NOT NULL\r
61 )""" % self.Table\r
62 Table.Create(self, SqlCommand)\r
63\r
64 ## Insert table\r
65 #\r
66 # Insert a record into table Function\r
67 #\r
68 # @param ID: ID of a Function\r
69 # @param Header: Header of a Function\r
f7496d71 70 # @param Modifier: Modifier of a Function\r
30fdf114 71 # @param Name: Name of a Function\r
fb0b35e0 72 # @param ReturnStatement: ReturnStatement of a Function\r
30fdf114
LG
73 # @param StartLine: StartLine of a Function\r
74 # @param StartColumn: StartColumn of a Function\r
75 # @param EndLine: EndLine of a Function\r
76 # @param EndColumn: EndColumn of a Function\r
77 # @param BodyStartLine: StartLine of a Function body\r
78 # @param BodyStartColumn: StartColumn of a Function body\r
79 # @param BelongsToFile: The Function belongs to which file\r
80 # @param FunNameStartLine: StartLine of a Function name\r
81 # @param FunNameStartColumn: StartColumn of a Function name\r
82 #\r
83 def Insert(self, Header, Modifier, Name, ReturnStatement, StartLine, StartColumn, EndLine, EndColumn, BodyStartLine, BodyStartColumn, BelongsToFile, FunNameStartLine, FunNameStartColumn):\r
84 self.ID = self.ID + 1\r
85 (Header, Modifier, Name, ReturnStatement) = ConvertToSqlString((Header, Modifier, Name, ReturnStatement))\r
86 SqlCommand = """insert into %s values(%s, '%s', '%s', '%s', '%s', %s, %s, %s, %s, %s, %s, %s, %s, %s)""" \\r
87 % (self.Table, self.ID, Header, Modifier, Name, ReturnStatement, StartLine, StartColumn, EndLine, EndColumn, BodyStartLine, BodyStartColumn, BelongsToFile, FunNameStartLine, FunNameStartColumn)\r
88 Table.Insert(self, SqlCommand)\r
89\r
90 return self.ID\r