blob: 8c2fa1e01db7b1ab535cb2a8962d6d682fe4f5bd [file] [log] [blame]
# -*- 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)