refactor outputdriverfactory
This commit is contained in:
@@ -23,7 +23,15 @@ namespace OutputDriverFactory
|
||||
{
|
||||
|
||||
using namespace nlohmann;
|
||||
|
||||
namespace config {
|
||||
namespace
|
||||
{
|
||||
json solenoids;
|
||||
json lamps;
|
||||
json sounds;
|
||||
json displays;
|
||||
}
|
||||
}
|
||||
std::shared_ptr<OutputDriver> get_OutputDriver(std::istream& solenoid_config,
|
||||
std::istream& lamp_config,
|
||||
std::istream& sound_config,
|
||||
@@ -31,38 +39,37 @@ std::shared_ptr<OutputDriver> get_OutputDriver(std::istream& solenoid_config,
|
||||
{
|
||||
utility::LoggerFactory::CreateOutputLogger();
|
||||
|
||||
solenoid_config >> config::solenoids;
|
||||
lamp_config >> config::lamps;
|
||||
sound_config >> config::sounds;
|
||||
display_config >> config::displays;
|
||||
|
||||
auto output_pin_mutex = std::make_shared<std::mutex>();
|
||||
|
||||
std::shared_ptr<DriverBoardPinController> driver_board_pin_controller(new detail::DriverBoardPinController(output_pin_mutex));
|
||||
auto solenoids = create_solenoids(solenoid_config, driver_board_pin_controller);
|
||||
auto flippers = create_flippers(solenoid_config, driver_board_pin_controller);
|
||||
auto lamps = create_lamps(lamp_config, driver_board_pin_controller);
|
||||
|
||||
uint8_t sound_fire_address = get_sound_fire_address(sound_config);
|
||||
auto solenoids = create_solenoids(driver_board_pin_controller);
|
||||
auto flippers = create_flippers(driver_board_pin_controller);
|
||||
auto lamps = create_lamps(driver_board_pin_controller);
|
||||
|
||||
std::shared_ptr<SoundBoardPinController> sound_board_pin_controller(new detail::SoundBoardPinController(output_pin_mutex, sound_fire_address));
|
||||
auto sounds = create_sounds(sound_config, sound_board_pin_controller);
|
||||
auto sound_board_pin_controller = create_SoundBoardPinController();
|
||||
auto sounds = create_sounds(sound_board_pin_controller);
|
||||
|
||||
std::unique_ptr<DisplayBoardPinController> display_board_pin_controller(new detail::DisplayBoardPinController(parse_pins_display_board(display_config)));
|
||||
auto displays = create_displays(display_config);
|
||||
auto displays = create_displays();
|
||||
std::unique_ptr<DisplayController> display_controller(new detail::DisplayController(displays, std::move(display_board_pin_controller)));
|
||||
auto display_map = map_displays(displays);
|
||||
|
||||
return std::make_shared<OutputDriver>(std::move(display_controller), solenoids, lamps, sounds, flippers, display_map);
|
||||
}
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Solenoid>> create_solenoids(std::istream & solenoid_config, std::shared_ptr<DriverBoardPinController> &pin_controller)
|
||||
std::map<std::string, std::shared_ptr<items::Solenoid>> create_solenoids(std::shared_ptr<DriverBoardPinController> &pin_controller)
|
||||
{
|
||||
solenoid_config.clear();
|
||||
json solenoid_config_json;
|
||||
solenoid_config >> solenoid_config_json;
|
||||
|
||||
json port_extenders = get_element("port_extenders", solenoid_config_json, "");
|
||||
json port_extenders = get_element("port_extenders", config::solenoids, "");
|
||||
|
||||
initialize_port_extenders(port_extenders, pin_controller.get(), "solenoid_config.json");
|
||||
|
||||
json solenoids_json = get_element("solenoids", solenoid_config_json, "solenoid_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", solenoid_config_json, "solenoid_config.json") };
|
||||
json solenoids_json = get_element("solenoids", config::solenoids, "solenoid_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", config::solenoids, "solenoid_config.json") };
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Solenoid>> solenoids;
|
||||
for(auto &solenoid_json : solenoids_json)
|
||||
@@ -75,8 +82,7 @@ std::map<std::string, std::shared_ptr<items::Solenoid>> create_solenoids(std::is
|
||||
|
||||
std::shared_ptr<items::detail::Solenoid> create_solenoid(nlohmann::json &solenoid_json, nlohmann::json &port_extenders, std::shared_ptr<DriverBoardPinController> &pin_controller, std::chrono::milliseconds deactivation_time)
|
||||
{
|
||||
solenoid_json;
|
||||
std::string config_file_name = "solenoid_config.json";
|
||||
std::string config_file_name = "config::solenoid.json";
|
||||
|
||||
uint8_t pin_base = get_pin_base(solenoid_json, port_extenders, config_file_name);
|
||||
|
||||
@@ -91,17 +97,12 @@ std::shared_ptr<items::detail::Solenoid> create_solenoid(nlohmann::json &solenoi
|
||||
return std::make_shared<items::detail::Solenoid>(pin_controller, address, pin_base, name, deactivation_time);
|
||||
}
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Flipper>> create_flippers(std::istream &solenoid_config, std::shared_ptr<DriverBoardPinController> &pin_controller)
|
||||
std::map<std::string, std::shared_ptr<items::Flipper>> create_flippers(std::shared_ptr<DriverBoardPinController> &pin_controller)
|
||||
{
|
||||
solenoid_config.clear();
|
||||
solenoid_config.seekg(0, std::ios::beg);
|
||||
json solenoid_config_json;
|
||||
solenoid_config >> solenoid_config_json;
|
||||
json port_extenders = get_element("port_extenders", config::solenoids, "solenoid_config.json");
|
||||
|
||||
json port_extenders = get_element("port_extenders", solenoid_config_json, "solenoid_config.json");
|
||||
|
||||
json flippers_json = get_element("flippers", solenoid_config_json, "solenoid_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", solenoid_config_json, "solenoid_config.json") };
|
||||
json flippers_json = get_element("flippers", config::solenoids, "solenoid_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", config::solenoids, "solenoid_config.json") };
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Flipper>> flippers;
|
||||
for(auto &flipper_json : flippers_json)
|
||||
@@ -125,17 +126,12 @@ std::shared_ptr<items::detail::Flipper> create_flipper(nlohmann::json &flipper_j
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Lamp>> create_lamps(std::istream &lamp_config, std::shared_ptr<DriverBoardPinController> &pin_controller)
|
||||
{
|
||||
lamp_config.clear();
|
||||
lamp_config.seekg(0, std::ios::beg);
|
||||
json lamp_config_json;
|
||||
lamp_config >> lamp_config_json;
|
||||
|
||||
json port_extenders = get_element("port_extenders", lamp_config_json, "lamp_config.json");
|
||||
json port_extenders = get_element("port_extenders", config::lamps, "lamp_config.json");
|
||||
initialize_port_extenders(port_extenders, pin_controller.get(), "lamp_config.json");
|
||||
json lamp_json = get_element("lamps", lamp_config_json, "lamp_config.json");
|
||||
json lamps_json = get_element("lamps", config::lamps, "lamp_config.json");
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Lamp>> lamps;
|
||||
for(auto &lamp_json : lamp_json)
|
||||
for(auto &lamp_json : lamps_json)
|
||||
{
|
||||
auto lamp = create_lamp(lamp_json, port_extenders, pin_controller);
|
||||
lamps.emplace(lamp->get_name(), lamp);
|
||||
@@ -156,15 +152,10 @@ std::shared_ptr<items::detail::Lamp> create_lamp(json &lamp_json, json & port_ex
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Sound>> create_sounds(std::istream &sound_config, std::shared_ptr<SoundBoardPinController> &pin_controller)
|
||||
{
|
||||
sound_config.clear();
|
||||
sound_config.seekg(0, std::ios::beg);
|
||||
json sound_config_json;
|
||||
sound_config >> sound_config_json;
|
||||
|
||||
json port_extenders = get_element("port_extenders", sound_config_json, "sound_config.json");
|
||||
json port_extenders = get_element("port_extenders", config::sounds, "sound_config.json");
|
||||
initialize_port_extenders(port_extenders, pin_controller.get(), "sound_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", sound_config_json, "solenoid_config.json") };
|
||||
json sounds_json = get_element("sounds", sound_config_json, "sound_config.json");
|
||||
std::chrono::milliseconds deactivation_time{ get_value<int>("deactivation_time_milliseconds", config::sounds, "solenoid_config.json") };
|
||||
json sounds_json = get_element("sounds", config::sounds, "sound_config.json");
|
||||
|
||||
std::map<std::string, std::shared_ptr<items::Sound>> sounds;
|
||||
for(auto &sound_json : sounds_json)
|
||||
@@ -187,16 +178,11 @@ std::shared_ptr<items::detail::Sound> create_sound(json &sound_json, json &port_
|
||||
return std::make_shared<items::detail::Sound>(pin_controller, address, pin_base, name, deactivation_time, id);
|
||||
}
|
||||
|
||||
uint8_t get_sound_fire_address(std::istream &sound_config)
|
||||
uint8_t get_sound_fire_address()
|
||||
{
|
||||
sound_config.clear();
|
||||
sound_config.seekg(0, std::ios::beg);
|
||||
json sound_config_json;
|
||||
sound_config >> sound_config_json;
|
||||
json port_extenders = get_element("port_extenders", config::sounds, "sound_config.json");
|
||||
|
||||
json port_extenders = get_element("port_extenders", sound_config_json, "sound_config.json");
|
||||
|
||||
json fire_pin = get_element("fire_pin", sound_config_json, "sound_config.json");
|
||||
json fire_pin = get_element("fire_pin", config::sounds, "sound_config.json");
|
||||
auto pin_base = get_pin_base(fire_pin, port_extenders, "sound_config.json");
|
||||
auto address = get_value<uint8_t>("address", fire_pin, "sound_config.json");
|
||||
|
||||
@@ -205,14 +191,9 @@ uint8_t get_sound_fire_address(std::istream &sound_config)
|
||||
|
||||
std::map<std::string, uint8_t> parse_pins_display_board(std::istream &display_config)
|
||||
{
|
||||
display_config.clear();
|
||||
display_config.seekg(0, std::ios::beg);
|
||||
std::string config_file = "display_config.json";
|
||||
|
||||
json display_config_json;
|
||||
display_config >> display_config_json;
|
||||
|
||||
json display_board_config = get_element("display_board", display_config_json, config_file);
|
||||
json display_board_config = get_element("display_board", config::displays, config_file);
|
||||
|
||||
std::map<std::string, uint8_t> pins_display;
|
||||
|
||||
@@ -240,12 +221,7 @@ std::map<std::string, uint8_t> parse_pins_display_board(std::istream &display_co
|
||||
|
||||
std::vector<std::shared_ptr<items::OutputDisplay>> create_displays(std::istream &display_config)
|
||||
{
|
||||
display_config.clear();
|
||||
display_config.seekg(0, std::ios::beg);
|
||||
json display_config_json;
|
||||
display_config >> display_config_json;
|
||||
|
||||
json displays_json = get_element("displays", display_config_json, "display_config.json");
|
||||
json displays_json = get_element("displays", config::displays, "display_config.json");
|
||||
|
||||
std::vector<std::shared_ptr<items::OutputDisplay>> displays;
|
||||
for(json &display_json : displays_json)
|
||||
|
||||
Reference in New Issue
Block a user