// 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. #ifndef TOOLS_JSON_SCHEMA_COMPILER_UTIL_H__ #define TOOLS_JSON_SCHEMA_COMPILER_UTIL_H__ #include #include #include "base/memory/linked_ptr.h" #include "base/memory/scoped_ptr.h" #include "base/values.h" namespace json_schema_compiler { namespace util { // Populates the item |out| from the value |from|. These are used by template // specializations of |Get(Optional)ArrayFromList|. bool PopulateItem(const base::Value& from, linked_ptr* out); bool PopulateItem(const base::Value& from, int* out); bool PopulateItem(const base::Value& from, int* out, base::string16* error); bool PopulateItem(const base::Value& from, bool* out); bool PopulateItem(const base::Value& from, bool* out, base::string16* error); bool PopulateItem(const base::Value& from, double* out); bool PopulateItem(const base::Value& from, double* out, base::string16* error); bool PopulateItem(const base::Value& from, std::string* out); bool PopulateItem(const base::Value& from, std::string* out, base::string16* error); bool PopulateItem(const base::Value& from, std::vector* out); bool PopulateItem(const base::Value& from, std::vector* out, base::string16* error); bool PopulateItem(const base::Value& from, linked_ptr* out, base::string16* error); bool PopulateItem(const base::Value& from, linked_ptr* out); bool PopulateItem(const base::Value& from, linked_ptr* out); bool PopulateItem(const base::Value& from, linked_ptr* out, base::string16* error); // This template is used for types generated by tools/json_schema_compiler. template bool PopulateItem(const base::Value& from, linked_ptr* out) { const base::DictionaryValue* dict = nullptr; if (!from.GetAsDictionary(&dict)) return false; scoped_ptr obj(new T()); if (!T::Populate(*dict, obj.get())) return false; *out = linked_ptr(obj.release()); return true; } // This template is used for types generated by tools/json_schema_compiler. template bool PopulateItem(const base::Value& from, T* out) { const base::DictionaryValue* dict = nullptr; if (!from.GetAsDictionary(&dict)) return false; T obj; if (!T::Populate(*dict, &obj)) return false; *out = std::move(obj); return true; } // This template is used for types generated by tools/json_schema_compiler with // error generation enabled. template bool PopulateItem(const base::Value& from, linked_ptr* out, base::string16* error) { const base::DictionaryValue* dict = nullptr; if (!from.GetAsDictionary(&dict)) return false; scoped_ptr obj(new T()); if (!T::Populate(*dict, obj.get(), error)) return false; *out = linked_ptr(obj.release()); return true; } // Populates |out| with |list|. Returns false if there is no list at the // specified key or if the list has anything other than |T|. template bool PopulateArrayFromList(const base::ListValue& list, std::vector* out) { out->clear(); T item; for (const base::Value* value : list) { if (!PopulateItem(*value, &item)) return false; // T might not be movable, but in that case it should be copyable, and this // will still work. out->push_back(std::move(item)); } return true; } // Populates |out| with |list|. Returns false and sets |error| if there is no // list at the specified key or if the list has anything other than |T|. template bool PopulateArrayFromList(const base::ListValue& list, std::vector* out, base::string16* error) { out->clear(); T item; for (const base::Value* value : list) { if (!PopulateItem(*value, &item, error)) return false; out->push_back(item); } return true; } // Creates a new vector containing |list| at |out|. Returns // true on success or if there is nothing at the specified key. Returns false // if anything other than a list of |T| is at the specified key. template bool PopulateOptionalArrayFromList(const base::ListValue& list, scoped_ptr>* out) { out->reset(new std::vector()); if (!PopulateArrayFromList(list, out->get())) { out->reset(); return false; } return true; } template bool PopulateOptionalArrayFromList(const base::ListValue& list, scoped_ptr>* out, base::string16* error) { out->reset(new std::vector()); if (!PopulateArrayFromList(list, out->get(), error)) { out->reset(); return false; } return true; } // Appends a Value newly created from |from| to |out|. These used by template // specializations of |Set(Optional)ArrayToList|. void AddItemToList(const int from, base::ListValue* out); void AddItemToList(const bool from, base::ListValue* out); void AddItemToList(const double from, base::ListValue* out); void AddItemToList(const std::string& from, base::ListValue* out); void AddItemToList(const std::vector& from, base::ListValue* out); void AddItemToList(const linked_ptr& from, base::ListValue* out); void AddItemToList(const linked_ptr& from, base::ListValue* out); // This template is used for types generated by tools/json_schema_compiler. template void AddItemToList(const linked_ptr& from, base::ListValue* out) { out->Append(from->ToValue().release()); } // This template is used for types generated by tools/json_schema_compiler. template void AddItemToList(const T& from, base::ListValue* out) { out->Append(from.ToValue()); } // Set |out| to the the contents of |from|. Requires PopulateItem to be // implemented for |T|. template void PopulateListFromArray(const std::vector& from, base::ListValue* out) { out->Clear(); for (const T& item : from) AddItemToList(item, out); } // Set |out| to the the contents of |from| if |from| is not null. Requires // PopulateItem to be implemented for |T|. template void PopulateListFromOptionalArray(const scoped_ptr>& from, base::ListValue* out) { if (from.get()) PopulateListFromArray(*from, out); } template scoped_ptr CreateValueFromArray(const std::vector& from) { base::ListValue* list = new base::ListValue(); PopulateListFromArray(from, list); return scoped_ptr(list); } template scoped_ptr CreateValueFromOptionalArray( const scoped_ptr>& from) { if (from.get()) return CreateValueFromArray(*from); return scoped_ptr(); } std::string ValueTypeToString(base::Value::Type type); } // namespace util } // namespace json_schema_compiler #endif // TOOLS_JSON_SCHEMA_COMPILER_UTIL_H__