| Index: tools/json_schema_compiler/cpp_util.py
|
| diff --git a/tools/json_schema_compiler/cpp_util.py b/tools/json_schema_compiler/cpp_util.py
|
| index 96a5cd36144a3beb2521e7dbbfd6497843a65a08..9ce14ca9d835b61783b5ec1267b8165d69b139a0 100644
|
| --- a/tools/json_schema_compiler/cpp_util.py
|
| +++ b/tools/json_schema_compiler/cpp_util.py
|
| @@ -1,11 +1,12 @@
|
| # Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| # Use of this source code is governed by a BSD-style license that can be
|
| # found in the LICENSE file.
|
| +
|
| """Utilies and constants specific to Chromium C++ code.
|
| """
|
|
|
| from datetime import datetime
|
| -from model import PropertyType
|
| +from model import Property, PropertyType, Type
|
| import os
|
|
|
| CHROMIUM_LICENSE = (
|
| @@ -31,7 +32,7 @@ def Classname(s):
|
| """
|
| return '_'.join([x[0].upper() + x[1:] for x in s.split('.')])
|
|
|
| -def GetAsFundamentalValue(prop, src, dst):
|
| +def GetAsFundamentalValue(type_, src, dst):
|
| """Returns the C++ code for retrieving a fundamental type from a
|
| Value into a variable.
|
|
|
| @@ -43,7 +44,7 @@ def GetAsFundamentalValue(prop, src, dst):
|
| PropertyType.BOOLEAN: '%s->GetAsBoolean(%s)',
|
| PropertyType.INTEGER: '%s->GetAsInteger(%s)',
|
| PropertyType.DOUBLE: '%s->GetAsDouble(%s)',
|
| - }[prop.type_] % (src, dst)
|
| + }[type_.property_type] % (src, dst)
|
|
|
| def GetValueType(type_):
|
| """Returns the Value::Type corresponding to the model.PropertyType.
|
| @@ -58,15 +59,18 @@ def GetValueType(type_):
|
| PropertyType.FUNCTION: 'Value::TYPE_DICTIONARY',
|
| PropertyType.ARRAY: 'Value::TYPE_LIST',
|
| PropertyType.BINARY: 'Value::TYPE_BINARY',
|
| - }[type_]
|
| + }[type_.property_type]
|
|
|
| def GetParameterDeclaration(param, type_):
|
| """Gets a parameter declaration of a given model.Property and its C++
|
| type.
|
| """
|
| - if param.type_ in (PropertyType.REF, PropertyType.OBJECT, PropertyType.ARRAY,
|
| - PropertyType.STRING, PropertyType.ANY):
|
| - arg = '%(type)s& %(name)s'
|
| + if param.type_.property_type in (PropertyType.REF,
|
| + PropertyType.OBJECT,
|
| + PropertyType.ARRAY,
|
| + PropertyType.STRING,
|
| + PropertyType.ANY):
|
| + arg = 'const %(type)s& %(name)s'
|
| else:
|
| arg = '%(type)s %(name)s'
|
| return arg % {
|
| @@ -82,40 +86,8 @@ def GenerateIfndefName(path, filename):
|
| return (('%s_%s_H__' % (path, filename))
|
| .upper().replace(os.sep, '_').replace('/', '_'))
|
|
|
| -def GenerateTypeToCompiledTypeConversion(prop, from_, to):
|
| - try:
|
| - return _GenerateTypeConversionHelper(prop.type_, prop.compiled_type, from_,
|
| - to)
|
| - except KeyError:
|
| - raise NotImplementedError('Conversion from %s to %s in %s not supported' %
|
| - (prop.type_, prop.compiled_type, prop.name))
|
| -
|
| -def GenerateCompiledTypeToTypeConversion(prop, from_, to):
|
| - try:
|
| - return _GenerateTypeConversionHelper(prop.compiled_type, prop.type_, from_,
|
| - to)
|
| - except KeyError:
|
| - raise NotImplementedError('Conversion from %s to %s in %s not supported' %
|
| - (prop.compiled_type, prop.type_, prop.name))
|
| -
|
| -def _GenerateTypeConversionHelper(from_type, to_type, from_, to):
|
| - """Converts from PropertyType from_type to PropertyType to_type.
|
| -
|
| - from_type: The PropertyType to be converted from.
|
| - to_type: The PropertyType to be converted to.
|
| - from_: The variable name of the type to be converted from.
|
| - to: The variable name of the type to be converted to.
|
| +def PadForGenerics(var):
|
| + """Appends a space to |var| if it ends with a >, so that it can be compiled
|
| + within generic types.
|
| """
|
| - # TODO(mwrosen): Add support for more from/to combinations as necessary.
|
| - return {
|
| - PropertyType.STRING: {
|
| - PropertyType.INTEGER: 'base::StringToInt(%(from)s, &%(to)s)',
|
| - PropertyType.INT64: 'base::StringToInt64(%(from)s, &%(to)s)',
|
| - },
|
| - PropertyType.INTEGER: {
|
| - PropertyType.STRING: '%(to)s = base::IntToString(%(from)s)',
|
| - },
|
| - PropertyType.INT64: {
|
| - PropertyType.STRING: '%(to)s = base::Int64ToString(%(from)s)',
|
| - }
|
| - }[from_type][to_type] % {'from': from_, 'to': to}
|
| + return ('%s ' % var) if var.endswith('>') else var
|
|
|