Added parsing of plugin json files for machine_manager (nw)

This commit is contained in:
Miodrag Milanovic 2016-03-24 21:06:49 +01:00
parent 5e23c377cf
commit 315612190b
8 changed files with 145 additions and 4 deletions

View File

@ -1,9 +1,10 @@
{
"plugin": {
"name": "dummy",
"description": "Dummy test plugin",
"version": "0.0.1",
"author": "Miodrag Milanovic",
"type": "plugin",
"start": "false",
"start": "false"
}
}

View File

@ -1,9 +1,10 @@
{
"plugin": {
"name": "hiscore",
"description": "Hiscore support",
"version": "1.0.0",
"author": "borgar@borgar.net",
"type": "plugin",
"start": "false",
"start": "false"
}
}

View File

@ -1,8 +1,9 @@
{
"plugin": {
"name": "json",
"description": "json library",
"version": "2.5.0",
"author": "David Kolf",
"type": "library",
"type": "library"
}
}

View File

@ -25,6 +25,7 @@ includedirs {
MAME_DIR .. "src/devices", -- till deps are fixed
MAME_DIR .. "src/lib",
MAME_DIR .. "src/lib/util",
MAME_DIR .. "3rdparty/rapidjson/include",
MAME_DIR .. "3rdparty",
GEN_DIR .. "emu",
GEN_DIR .. "emu/layout",
@ -169,6 +170,8 @@ files {
MAME_DIR .. "src/emu/network.h",
MAME_DIR .. "src/emu/parameters.cpp",
MAME_DIR .. "src/emu/parameters.h",
MAME_DIR .. "src/emu/pluginopts.cpp",
MAME_DIR .. "src/emu/pluginopts.h",
MAME_DIR .. "src/emu/output.cpp",
MAME_DIR .. "src/emu/output.h",
MAME_DIR .. "src/emu/render.cpp",

View File

@ -110,6 +110,7 @@ machine_manager* machine_manager::instance()
machine_manager::machine_manager(emu_options &options,osd_interface &osd)
: m_osd(osd),
m_options(options),
m_plugins(std::make_unique<plugin_options>()),
m_lua(global_alloc(lua_engine)),
m_new_driver_pending(nullptr),
m_machine(nullptr)
@ -157,6 +158,12 @@ void machine_manager::start_luaengine()
{
m_lua->initialize();
{
path_iterator iter(options().plugins_path());
std::string pluginpath;
while (iter.next(pluginpath, ""))
{
m_plugins->parse_json(pluginpath);
}
emu_file file(options().plugins_path(), OPEN_FLAG_READ);
osd_file::error filerr = file.open("boot.lua");
if (filerr == osd_file::error::NONE)

View File

@ -17,6 +17,7 @@
#define __MAME_H__
#include <time.h>
#include "pluginopts.h"
class osd_interface;
@ -76,6 +77,7 @@ public:
osd_interface &osd() const;
emu_options &options() const { return m_options; }
plugin_options &plugins() const { return *m_plugins; }
lua_engine *lua() { return m_lua; }
running_machine *machine() { return m_machine; }
@ -91,7 +93,7 @@ public:
private:
osd_interface & m_osd; // reference to OSD system
emu_options & m_options; // reference to options
std::unique_ptr<plugin_options> m_plugins; // pointer to plugin options
lua_engine * m_lua;
const game_driver * m_new_driver_pending; // pointer to the next pending driver

97
src/emu/pluginopts.cpp Normal file
View File

@ -0,0 +1,97 @@
// license:BSD-3-Clause
// copyright-holders:Miodrag Milanovic
/***************************************************************************
pluginopts.cpp
Plugin options manager.
***************************************************************************/
#include <fstream>
#include "emu.h"
#include "pluginopts.h"
#include <rapidjson/document.h>
#include <rapidjson/error/en.h>
#include <rapidjson/istreamwrapper.h>
#include <fstream>
//**************************************************************************
// PLUGIN OPTIONS
//**************************************************************************
const options_entry plugin_options::s_option_entries[] =
{
{ nullptr, nullptr, OPTION_HEADER, "PLUGINS OPTIONS" },
{ nullptr }
};
//-------------------------------------------------
// plugin_options - constructor
//-------------------------------------------------
plugin_options::plugin_options()
: core_options()
{
add_entries(plugin_options::s_option_entries);
}
void plugin_options::parse_json(std::string path)
{
// first try to open as a directory
osd_directory *directory = osd_opendir(path.c_str());
if (directory != nullptr)
{
// iterate over all files in the directory
for (const osd_directory_entry *entry = osd_readdir(directory); entry != nullptr; entry = osd_readdir(directory))
{
if (entry->type == ENTTYPE_FILE)
{
std::string name = entry->name;
if (name == "plugin.json")
{
std::string curfile = std::string(path).append(PATH_SEPARATOR).append(entry->name);
std::ifstream ifs(curfile);
rapidjson::IStreamWrapper isw(ifs);
rapidjson::Document document;
document.ParseStream<0>(isw);
if (document.HasParseError()) {
std::string error(GetParseError_En(document.GetParseError()));
osd_printf_error("Unable to parse plugin definition file %s. Errors returned:\n", curfile.c_str());
osd_printf_error("%s\n", error.c_str());
return;
}
if (document["plugin"].IsObject())
{
std::string name = document["plugin"]["name"].GetString();
std::string description = document["plugin"]["description"].GetString();
std::string type = document["plugin"]["type"].GetString();
bool start = false;
if (document["plugin"].HasMember("start") && (std::string(document["plugin"]["start"].GetString()) == "true"))
start = true;
if (type=="plugin")
{
add_entry(core_strdup(name.c_str()),core_strdup(description.c_str()), OPTION_BOOLEAN, start ? "1" : "0");
}
}
}
}
else if (entry->type == ENTTYPE_DIR)
{
std::string name = entry->name;
if (!(name == "." || name == ".."))
{
parse_json(path + PATH_SEPARATOR + name);
}
}
}
// close the directory and be done
osd_closedir(directory);
}
}

29
src/emu/pluginopts.h Normal file
View File

@ -0,0 +1,29 @@
// license:BSD-3-Clause
// copyright-holders:Miodrag Milanovic
/***************************************************************************
pluginopts.cpp
Plugin options manager.
***************************************************************************/
#pragma once
#ifndef __PLUGIN_OPTS_H__
#define __PLUGIN_OPTS_H__
#include "options.h"
class plugin_options : public core_options
{
public:
// construction/destruction
plugin_options();
void parse_json(std::string path);
private:
static const options_entry s_option_entries[];
};
#endif /* __PLUGIN_OPTS_H__ */