/*
* Copyright (C) 2018 The Android Open Source Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*/
#pragma once
#include <regex>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <vector>
namespace fastboot {
namespace extension {
enum Expect { OKAY = 0, FAIL, DATA };
static const std::unordered_map<std::string, Expect> CMD_EXPECTS = {
{"okay", OKAY},
{"fail", FAIL},
{"data", DATA},
};
static const std::unordered_map<Expect, std::string> EXPECTS_STR = {
{OKAY, "okay"},
{FAIL, "fail"},
{DATA, "data"},
};
struct Configuration {
struct GetVar {
std::string regex_str;
std::regex regex;
int line_num;
// So gtest can print me
friend ::std::ostream& operator<<(::std::ostream& os, const GetVar& self) {
return os << "<regex='" << self.regex_str << "' line_num=" << self.line_num << ">";
}
};
struct PartitionInfo {
enum TestConfig { NO = 0, NO_WRITES, YES };
bool hashable;
bool slots; // Does it have slots
bool parsed; // Does the bootloader do parsing on the img?
TestConfig test;
// So gtest can print me
friend ::std::ostream& operator<<(::std::ostream& os, const PartitionInfo& pinfo) {
return os << "<hashable=" << pinfo.hashable << " slots=" << pinfo.slots
<< " parsed=" << pinfo.parsed << ">";
}
};
struct PackedInfoTest {
Expect expect; // Does it have slots
std::string packed_img;
std::string unpacked_dir;
// So gtest can print me
friend ::std::ostream& operator<<(::std::ostream& os, const PackedInfoTest& pinfo) {
return os << "<"
<< "expect=" << EXPECTS_STR.at(pinfo.expect)
<< " packed_img=" << pinfo.packed_img
<< " unpacked_dir=" << pinfo.unpacked_dir << ">";
}
};
struct PackedInfo {
bool slots; // Does it have slots
std::unordered_set<std::string> children;
std::vector<PackedInfoTest> tests;
};
struct CommandTest {
std::string name;
int line_num;
std::string arg;
Expect expect;
std::string regex_str;
std::regex regex;
std::string input;
std::string output;
std::string validator;
// So gtest can print me
friend ::std::ostream& operator<<(::std::ostream& os, const CommandTest& self) {
return os << "test: " << self.name << " (line: " << self.line_num << ")";
}
};
struct OemCommand {
bool restricted; // Does device need to be unlocked?
std::vector<CommandTest> tests;
};
std::unordered_map<std::string, GetVar> getvars;
std::unordered_map<std::string, PartitionInfo> partitions;
std::unordered_map<std::string, PackedInfo> packed;
std::unordered_map<std::string, OemCommand> oem;
std::string checksum;
std::string checksum_parser;
};
bool ParseXml(const std::string& file, Configuration* config);
} // namespace extension
} // namespace fastboot