зеркало из https://github.com/mozilla/gecko-dev.git
101 строка
3.2 KiB
Python
101 строка
3.2 KiB
Python
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
# Write out scalar information for C++. The scalars are defined
|
|
# in a file provided as a command-line argument.
|
|
|
|
from __future__ import print_function
|
|
from shared_telemetry_utils import StringTable, static_assert, ParserError
|
|
|
|
import parse_scalars
|
|
import sys
|
|
|
|
# The banner/text at the top of the generated file.
|
|
banner = """/* This file is auto-generated, only for internal use in TelemetryScalar.h,
|
|
see gen_scalar_data.py. */
|
|
"""
|
|
|
|
file_header = """\
|
|
#ifndef mozilla_TelemetryScalarData_h
|
|
#define mozilla_TelemetryScalarData_h
|
|
#include "ScalarInfo.h"
|
|
namespace {
|
|
"""
|
|
|
|
file_footer = """\
|
|
} // namespace
|
|
#endif // mozilla_TelemetryScalarData_h
|
|
"""
|
|
|
|
|
|
def write_scalar_info(scalar, output, name_index, expiration_index):
|
|
"""Writes a scalar entry to the output file.
|
|
|
|
:param scalar: a ScalarType instance describing the scalar.
|
|
:param output: the output stream.
|
|
:param name_index: the index of the scalar name in the strings table.
|
|
:param expiration_index: the index of the expiration version in the strings table.
|
|
"""
|
|
cpp_guard = scalar.cpp_guard
|
|
if cpp_guard:
|
|
print("#if defined(%s)" % cpp_guard, file=output)
|
|
|
|
print(" {{ {}, {}, {}, {}, {}, {} }},"
|
|
.format(scalar.nsITelemetry_kind,
|
|
name_index,
|
|
expiration_index,
|
|
scalar.dataset,
|
|
" | ".join(scalar.record_in_processes_enum),
|
|
"true" if scalar.keyed else "false"),
|
|
file=output)
|
|
|
|
if cpp_guard:
|
|
print("#endif", file=output)
|
|
|
|
|
|
def write_scalar_tables(scalars, output):
|
|
"""Writes the scalar and strings tables to an header file.
|
|
|
|
:param scalars: a list of ScalarType instances describing the scalars.
|
|
:param output: the output stream.
|
|
"""
|
|
string_table = StringTable()
|
|
|
|
print("const ScalarInfo gScalars[] = {", file=output)
|
|
for s in scalars:
|
|
# We add both the scalar label and the expiration string to the strings
|
|
# table.
|
|
name_index = string_table.stringIndex(s.label)
|
|
exp_index = string_table.stringIndex(s.expires)
|
|
# Write the scalar info entry.
|
|
write_scalar_info(s, output, name_index, exp_index)
|
|
print("};", file=output)
|
|
|
|
string_table_name = "gScalarsStringTable"
|
|
string_table.writeDefinition(output, string_table_name)
|
|
static_assert(output, "sizeof(%s) <= UINT32_MAX" % string_table_name,
|
|
"index overflow")
|
|
|
|
|
|
def main(output, *filenames):
|
|
# Load the scalars first.
|
|
if len(filenames) > 1:
|
|
raise Exception('We don\'t support loading from more than one file.')
|
|
|
|
try:
|
|
scalars = parse_scalars.load_scalars(filenames[0])
|
|
except ParserError as ex:
|
|
print("\nError processing scalars:\n" + str(ex) + "\n")
|
|
sys.exit(1)
|
|
|
|
# Write the scalar data file.
|
|
print(banner, file=output)
|
|
print(file_header, file=output)
|
|
write_scalar_tables(scalars, output)
|
|
print(file_footer, file=output)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main(sys.stdout, *sys.argv[1:])
|