122 lines
3.2 KiB
Python
122 lines
3.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
#-------------------------------------------------------------------------
|
|
# drawElements Quality Program utilities
|
|
# --------------------------------------
|
|
#
|
|
# Copyright 2015 The Android Open Source Project
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
#-------------------------------------------------------------------------
|
|
|
|
import os
|
|
import sys
|
|
from itertools import chain
|
|
|
|
INL_HEADER_TMPL = """\
|
|
/* WARNING: This is auto-generated file. Do not modify, since changes will
|
|
* be lost! Modify the generating script instead.
|
|
*
|
|
* Generated from {registryName} revision {revision}.
|
|
*/\
|
|
"""
|
|
|
|
def genInlHeader (registryName, revision):
|
|
return INL_HEADER_TMPL.format(
|
|
registryName = registryName,
|
|
revision = str(revision))
|
|
|
|
def genInlHeaderForSource (registrySource):
|
|
return genInlHeaderForSource(registrySource.getFilename(), registrySource.getRevision())
|
|
|
|
def nextMod (val, mod):
|
|
if val % mod == 0:
|
|
return val + mod
|
|
else:
|
|
return int(val/mod)*mod + mod
|
|
|
|
def indentLines (lines):
|
|
tabSize = 4
|
|
|
|
# Split into columns
|
|
lineColumns = [line.split("\t") for line in lines if line is not None]
|
|
if len(lineColumns) == 0:
|
|
return
|
|
|
|
numColumns = max(len(line) for line in lineColumns)
|
|
|
|
# Figure out max length per column
|
|
columnLengths = [nextMod(max(len(line[ndx]) for line in lineColumns if len(line) > ndx), tabSize) for ndx in range(numColumns)]
|
|
|
|
for line in lineColumns:
|
|
indented = []
|
|
for columnNdx, col in enumerate(line[:-1]):
|
|
colLen = len(col)
|
|
while colLen < columnLengths[columnNdx]:
|
|
col += "\t"
|
|
colLen = nextMod(colLen, tabSize)
|
|
indented.append(col)
|
|
|
|
# Append last col
|
|
indented.append(line[-1])
|
|
yield "".join(indented)
|
|
|
|
def readFile (filename):
|
|
f = open(filename, 'rb')
|
|
data = f.read()
|
|
f.close()
|
|
return data
|
|
|
|
def writeFileIfChanged (filename, data):
|
|
if not os.path.exists(filename) or readFile(filename) != data:
|
|
if (sys.version_info < (3, 0)):
|
|
f = open(filename, 'wt')
|
|
else:
|
|
f = open(filename, 'wt', newline='\n')
|
|
f.write(data)
|
|
f.close()
|
|
|
|
def writeLines (filename, lines):
|
|
text = ""
|
|
for line in lines:
|
|
text += line
|
|
text += "\n"
|
|
|
|
writeFileIfChanged(filename, text)
|
|
print(filename)
|
|
|
|
def writeInlFile (filename, header, source):
|
|
writeLines(filename, chain([header], source))
|
|
|
|
def normalizeConstant (constant):
|
|
value = int(constant, base=0)
|
|
if value >= 1 << 63:
|
|
suffix = 'ull'
|
|
elif value >= 1 << 32:
|
|
suffix = 'll'
|
|
elif value >= 1 << 31:
|
|
suffix = 'u'
|
|
else:
|
|
suffix = ''
|
|
return constant + suffix
|
|
|
|
def commandParams (command):
|
|
if len(command.params) > 0:
|
|
return ", ".join(param.declaration for param in command.params)
|
|
else:
|
|
return "void"
|
|
|
|
def commandArgs (command):
|
|
return ", ".join(param.name for param in command.params)
|