| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- //
- // Copyright (c) 2014-2015, THUNDERBEAST GAMES LLC All rights reserved
- // LICENSE: Atomic Game Engine Editor and Tools EULA
- // Please see LICENSE_ATOMIC_EDITOR_AND_TOOLS.md in repository root for
- // license information: https://github.com/AtomicGameEngine/AtomicGameEngine
- //
- #include <Atomic/IO/Log.h>
- #include <Atomic/IO/File.h>
- #include <Atomic/IO/FileSystem.h>
- #include <Atomic/Resource/JSONFile.h>
- #include "JSBind.h"
- #include "JSBModule.h"
- #include "JSBPackage.h"
- #include "JSBDoc.h"
- #include "JSBPackageWriter.h" // Atomic JavaScript
- #include "JSBTypeScript.h" // Atomic TypeScript
- #include "JSBHaxe.h" // Atomic Haxe
- #include "CSharp/CSBPackageWriter.h" // Atomic C#
- namespace ToolCore
- {
- Vector<SharedPtr<JSBPackage> > JSBPackage::allPackages_;
- JSBPackage::JSBPackage(Context* context) : Object(context)
- {
- }
- JSBPackage::~JSBPackage()
- {
- }
- void JSBPackage::PreprocessModules()
- {
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->PreprocessHeaders();
- }
- }
- void JSBPackage::ProcessModules()
- {
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->VisitHeaders();
- }
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->PreprocessClasses();
- }
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->ProcessClasses();
- }
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->PostProcessClasses();
- }
- }
- void JSBPackage::GenerateCSharpSource(const String &outPath)
- {
- CSBPackageWriter writer(this);
- writer.GenerateSource(source_);
- String filepath = outPath + "/CSPackage" + name_ + ".cpp";
- File file(context_);
- file.Open(filepath, FILE_WRITE);
- file.Write(source_.CString(), source_.Length());
- file.Close();
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->GenerateCSharpSource(outPath);
- }
- }
- void JSBPackage::GenerateSource(const String &outPath)
- {
- JSBPackageWriter writer(this);
- writer.GenerateSource(source_);
- String filepath = outPath + "/JSPackage" + name_ + ".cpp";
- File file(context_);
- file.Open(filepath, FILE_WRITE);
- file.Write(source_.CString(), source_.Length());
- file.Close();
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- modules_[i]->GenerateSource(outPath);
- }
- JSBind* jsbind = GetSubsystem<JSBind>();
- if (jsbind->GetPlatform() == "MACOSX" || jsbind->GetPlatform() == "WINDOWS" || jsbind->GetPlatform() == "LINUX")
- {
- JSBDoc jdoc;
- jdoc.Emit(this, jsbind->GetSourceRootFolder() + "Artifacts/JSDoc/" + name_ + ".js");
- JSBTypeScript ts;
- ts.Emit(this, jsbind->GetSourceRootFolder() + "Script/TypeScript/" + name_ + ".d.ts");
- JSBHaxe hx;
- hx.Emit(this, jsbind->GetSourceRootFolder() + "Script/Haxe/" + name_ + ".hx");
- }
- }
- JSBClass* JSBPackage::GetClass(const String& name)
- {
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- JSBClass* cls = modules_[i]->GetClass(name);
- if (cls)
- return cls;
- }
- return 0;
- }
- JSBClass* JSBPackage::GetClassAllPackages(const String& name)
- {
- for (unsigned i = 0; i < allPackages_.Size(); i++)
- {
- JSBClass* cls = allPackages_[i]->GetClass(name);
- if (cls)
- return cls;
- }
- return 0;
- }
- JSBEnum* JSBPackage::GetEnum(const String& name)
- {
- for (unsigned i = 0; i < modules_.Size(); i++)
- {
- JSBEnum* cls = modules_[i]->GetEnum(name);
- if (cls)
- return cls;
- }
- return 0;
- }
- JSBEnum* JSBPackage::GetEnumAllPackages(const String& name)
- {
- for (unsigned i = 0; i < allPackages_.Size(); i++)
- {
- JSBEnum* cls = allPackages_[i]->GetEnum(name);
- if (cls)
- return cls;
- }
- return 0;
- }
- bool JSBPackage::ContainsConstant(const String& constantName)
- {
- for (unsigned i = 0; i < modules_.Size(); i++)
- if (modules_[i]->ContainsConstant(constantName))
- return true;
- return false;
- }
- bool JSBPackage::ContainsConstantAllPackages(const String& constantName)
- {
- for (unsigned i = 0; i < allPackages_.Size(); i++)
- {
- if (allPackages_[i]->ContainsConstant(constantName))
- return true;
- }
- return false;
- }
- bool JSBPackage::Load(const String& packageFolder)
- {
- LOGINFOF("Loading Package: %s", packageFolder.CString());
- JSBind* jsbind = GetSubsystem<JSBind>();
- SharedPtr<File> jsonFile(new File(context_, packageFolder + "Package.json"));
- if (!jsonFile->IsOpen())
- {
- LOGERRORF("Unable to open package json: %s", (packageFolder + "Package.json").CString());
- return false;
- }
- SharedPtr<JSONFile> packageJSON(new JSONFile(context_));
- if (!packageJSON->BeginLoad(*jsonFile))
- {
- LOGERRORF("Unable to parse package json: %s", (packageFolder + "Package.json").CString());
- return false;
- }
- JSONValue root = packageJSON->GetRoot();
- // first load dependencies
- JSONValue deps = root.Get("dependencies");
- if (deps.IsArray())
- {
- for (unsigned i = 0; i < deps.GetArray().Size(); i++)
- {
- String dpackageFolder = AddTrailingSlash(deps.GetArray()[i].GetString());
- SharedPtr<JSBPackage> depPackage (new JSBPackage(context_));
- if (!depPackage->Load(jsbind->GetSourceRootFolder() + dpackageFolder))
- {
- LOGERRORF("Unable to load package dependency: %s", dpackageFolder.CString());
- return false;
- }
- }
- }
- JSONValue jmodulesExclude = root.Get("moduleExclude");
- if (jmodulesExclude.IsObject())
- {
- Vector<String> platforms = jmodulesExclude.GetObject().Keys();
- for (unsigned i = 0; i < platforms.Size(); i++)
- {
- const String& platform = platforms[i];
- if (!moduleExcludes_.Contains(platform))
- {
- moduleExcludes_[platform] = Vector<String>();
- }
- JSONValue mods = jmodulesExclude.Get(platform);
- if (mods.IsArray())
- {
- for (unsigned j = 0; j < mods.GetArray().Size(); j++)
- {
- moduleExcludes_[platform].Push(mods.GetArray()[j].GetString());
- }
- }
- }
- }
- name_ = root.Get("name").GetString();
- namespace_ = root.Get("namespace").GetString();
- JSONValue modules = root.Get("modules");
- for (unsigned i = 0; i < modules.GetArray().Size(); i++)
- {
- String moduleName = modules.GetArray()[i].GetString();
- if (moduleExcludes_.Contains(jsbind->GetPlatform()))
- {
- if (moduleExcludes_[jsbind->GetPlatform()].Contains(moduleName))
- continue;
- }
- SharedPtr<JSBModule> module(new JSBModule(context_, this));
- if (!module->Load(packageFolder + moduleName + ".json"))
- {
- LOGERRORF("Unable to load module json: %s", (packageFolder + moduleName + ".json").CString());
- return false;
- }
- modules_.Push(module);
- }
- allPackages_.Push(SharedPtr<JSBPackage>(this));
- PreprocessModules();
- ProcessModules();
- return true;
- }
- }
|