| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169 |
- //
- // Copyright (c) 2014-2016 THUNDERBEAST GAMES LLC
- //
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be included in
- // all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- // THE SOFTWARE.
- //
- #include <Atomic/IO/Log.h>
- #include <Atomic/IO/File.h>
- #include <Atomic/Resource/JSONFile.h>
- #include "../ToolSystem.h"
- #include "Project.h"
- #include "ProjectFile.h"
- namespace ToolCore
- {
- ProjectFile::ProjectFile(Context* context) : Object(context)
- {
- }
- ProjectFile::~ProjectFile()
- {
- }
- void ProjectFile::WriteNewProject(const String& fullpath)
- {
- SharedPtr<JSONFile> jsonFile(new JSONFile(context_));
- JSONValue root = jsonFile->GetRoot();
- root.Set("version", PROJECTFILE_VERSION);
- // project object
- JSONValue jproject;
- jproject.Set("version", "1.0.0");
- root.Set("project", jproject);
- // platforms
- JSONValue platforms(JSONValue::emptyArray);
- root.Set("platforms", platforms);
- SharedPtr<File> file(new File(context_, fullpath, FILE_WRITE));
- jsonFile->Save(*file, String(" "));
- file->Close();
- }
- void ProjectFile::Save(Project* project)
- {
- project_ = project;
- ToolSystem* tsystem = GetSubsystem<ToolSystem>();
- String fullpath = project->GetProjectFilePath();
- SharedPtr<JSONFile> jsonFile(new JSONFile(context_));
- JSONValue root = jsonFile->GetRoot();
- root.Set("version", PROJECTFILE_VERSION);
- // project object
- JSONValue jproject;
- jproject.Set("version", project_->GetVersion());
- root.Set("project", jproject);
- // platforms
- JSONArray platforms;
- for (List<PlatformID>::ConstIterator i = project_->platforms_.Begin(); i != project_->platforms_.End(); ++i)
- {
- Platform* platform = tsystem->GetPlatformByID(*i);
- if (platform)
- {
- platforms.Push(JSONValue(platform->GetName().ToLower()));
- }
- }
- root.Set("platforms", platforms);
- // Save to file
- SharedPtr<File> file(new File(context_, fullpath, FILE_WRITE));
- jsonFile->Save(*file, String(" "));
- file->Close();
- }
- bool ProjectFile::Load(Project* project)
- {
- project_ = project;
- ToolSystem* tsystem = GetSubsystem<ToolSystem>();
- String fullpath = project->GetProjectFilePath();
- SharedPtr<File> file(new File(context_, fullpath, FILE_READ));
- if (file->GetSize() != 0)
- {
- SharedPtr<JSONFile> jsonFile(new JSONFile(context_));
- if (!jsonFile->BeginLoad(*file))
- return false;
- JSONValue root = jsonFile->GetRoot();
- int version = root.Get("version").GetInt();
- if (version != PROJECTFILE_VERSION)
- return false;
- // project object
- JSONValue jproject = root.Get("project");
- if (jproject.IsObject())
- {
- String pversion = jproject.Get("version").GetString();
- project_->SetVersion(pversion);
- }
- JSONValue platforms = root.Get("platforms");
- if (!platforms.IsArray())
- return false;
- }
- // for now, every project gets all platforms
- project_->AddPlatform(PLATFORMID_WINDOWS);
- project_->AddPlatform(PLATFORMID_MAC);
- project_->AddPlatform(PLATFORMID_ANDROID);
- project_->AddPlatform(PLATFORMID_IOS);
- project_->AddPlatform(PLATFORMID_WEB);
- /*
- for (unsigned i = 0; i < platforms.GetSize(); i++)
- {
- String jplatform = platforms.GetString(i);
- Platform* platform = tsystem->GetPlatformByName(jplatform);
- if (platform)
- project_->AddPlatform(platform->GetPlatformID());
- }
- */
- return true;
- }
- }
|