Rework for git.tesses.org, GC* is std::shared_ptr maybe will fix crash during exit
This commit is contained in:
@@ -10,7 +10,7 @@
|
||||
#include <sstream>
|
||||
#include <variant>
|
||||
namespace Tesses::CrossLang {
|
||||
bool InterperterThread::Add(GC* gc)
|
||||
bool InterperterThread::Add(std::shared_ptr<GC> gc)
|
||||
{
|
||||
std::vector<CallStackEntry*>& cse=this->call_stack_entries;
|
||||
GCList ls(gc);
|
||||
|
||||
@@ -13,7 +13,7 @@
|
||||
|
||||
namespace Tesses::CrossLang {
|
||||
|
||||
bool Equals(GC* gc, TObject left, TObject right)
|
||||
bool Equals(std::shared_ptr<GC> gc, TObject left, TObject right)
|
||||
{
|
||||
GCList ls(gc);
|
||||
if(std::holds_alternative<std::nullptr_t>(left) && std::holds_alternative<std::nullptr_t>(right))
|
||||
|
||||
@@ -14,7 +14,7 @@
|
||||
namespace Tesses::CrossLang {
|
||||
extern bool IHttpServer_Handle(std::shared_ptr<Tesses::Framework::Http::IHttpServer> svr,std::vector<TObject>& args);
|
||||
|
||||
bool InterperterThread::ExecuteMethod2(GC* gc, TObject instance, std::string key, std::vector<TObject> args)
|
||||
bool InterperterThread::ExecuteMethod2(std::shared_ptr<GC> gc, TObject instance, std::string key, std::vector<TObject> args)
|
||||
{
|
||||
std::vector<CallStackEntry*>& cse=this->call_stack_entries;
|
||||
if(!cse.empty())
|
||||
@@ -395,7 +395,7 @@ namespace Tesses::CrossLang {
|
||||
cse.back()->Push(gc, path.GetExtension());
|
||||
return false;
|
||||
}
|
||||
if(cse.back()->env->GetRootEnvironment()->permissions.canRegisterLocalFS && key == "MakeAbsolute")
|
||||
if(cse.back()->env->GetRootEnvironment()->permissions.localfs && key == "MakeAbsolute")
|
||||
{
|
||||
Tesses::Framework::Filesystem::VFSPath p;
|
||||
if(GetArgumentAsPath(args,0,p))
|
||||
@@ -405,11 +405,11 @@ namespace Tesses::CrossLang {
|
||||
}
|
||||
else
|
||||
{
|
||||
cse.back()->Push(gc,path.MakeAbsolute());
|
||||
cse.back()->Push(gc,path.MakeAbsolute(cse.back()->env->GetRootEnvironment()->permissions.localfs->GetWorking()));
|
||||
return false;
|
||||
}
|
||||
}
|
||||
if(cse.back()->env->GetRootEnvironment()->permissions.canRegisterLocalFS && key == "MakeRelative")
|
||||
if(cse.back()->env->GetRootEnvironment()->permissions.localfs && key == "MakeRelative")
|
||||
{
|
||||
Tesses::Framework::Filesystem::VFSPath p;
|
||||
if(GetArgumentAsPath(args,0,p))
|
||||
@@ -419,7 +419,7 @@ namespace Tesses::CrossLang {
|
||||
}
|
||||
else
|
||||
{
|
||||
cse.back()->Push(gc,path.MakeRelative());
|
||||
cse.back()->Push(gc,path.MakeRelative(cse.back()->env->GetRootEnvironment()->permissions.localfs->GetWorking()));
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -1199,6 +1199,48 @@ namespace Tesses::CrossLang {
|
||||
cse.back()->Push(gc,Undefined());
|
||||
return false;
|
||||
}
|
||||
else if(std::holds_alternative<std::shared_ptr<Tesses::Framework::Http::ServerSentEvents>>(instance))
|
||||
{
|
||||
auto& sse = std::get<std::shared_ptr<Tesses::Framework::Http::ServerSentEvents>>(instance);
|
||||
if(sse != nullptr)
|
||||
{
|
||||
std::string text;
|
||||
std::string text2;
|
||||
if(key == "SendComment" && GetArgument(args, 0, text))
|
||||
{
|
||||
sse->SendComment(text);
|
||||
}
|
||||
else if(key == "SendCustomEvent" && GetArgument(args, 0, text) && GetArgument(args,1,text2)) {
|
||||
sse->SendCustomEvent(text,text2);
|
||||
}
|
||||
else if(key == "SendCustomEvent" && GetArgument(args, 0, text)) {
|
||||
if(GetArgument(args,1,text2))
|
||||
sse->SendData(text,text2);
|
||||
else
|
||||
sse->SendData(text);
|
||||
}
|
||||
else if(key == "SendId" && GetArgument(args, 0, text))
|
||||
{
|
||||
sse->SendId(text);
|
||||
}
|
||||
else if(key == "SendRetry")
|
||||
{
|
||||
std::shared_ptr<Tesses::Framework::Date::TimeSpan> ts;
|
||||
int64_t num;
|
||||
if(GetArgument(args,0,ts) && ts)
|
||||
{
|
||||
sse->SendRetry(*ts);
|
||||
}
|
||||
else if(GetArgument(args,0,num))
|
||||
{
|
||||
sse->SendRetry((uint32_t)num);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
cse.back()->Push(gc, Undefined());
|
||||
return false;
|
||||
}
|
||||
else if(std::holds_alternative<std::shared_ptr<Tesses::Framework::Streams::Stream>>(instance))
|
||||
{
|
||||
auto& strm = std::get<std::shared_ptr<Tesses::Framework::Streams::Stream>>(instance);
|
||||
@@ -1234,6 +1276,18 @@ namespace Tesses::CrossLang {
|
||||
}
|
||||
if(netStrm != nullptr)
|
||||
{
|
||||
if(key == "SetMulticastMembership")
|
||||
{
|
||||
std::string ma;
|
||||
std::string ifaceIP = "0.0.0.0";
|
||||
if(GetArgument(args,0,ma))
|
||||
{
|
||||
GetArgument(args,1,ifaceIP);
|
||||
netStrm->SetMulticastMembership(ma,ifaceIP);
|
||||
}
|
||||
cse.back()->Push(gc, Undefined());
|
||||
return false;
|
||||
}
|
||||
if(key == "GetPort")
|
||||
{
|
||||
cse.back()->Push(gc, (int64_t)netStrm->GetPort());
|
||||
@@ -2230,9 +2284,10 @@ namespace Tesses::CrossLang {
|
||||
}
|
||||
if(key == "RegisterEverything")
|
||||
{
|
||||
if(myEnv->permissions.canRegisterEverything)
|
||||
if(myEnv->permissions.canRegisterEverything && myEnv->permissions.localfs)
|
||||
{
|
||||
TStd::RegisterStd(gc, rootEnv);
|
||||
TStd::RegisterStd(gc, rootEnv, std::make_shared<RelativeFilesystem>(myEnv->permissions.localfs->GetVFS(),myEnv->permissions.localfs->GetWorking()));
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -2250,7 +2305,15 @@ namespace Tesses::CrossLang {
|
||||
|
||||
|
||||
if(myEnv->permissions.canRegisterIO && !rootEnv->permissions.locked)
|
||||
TStd::RegisterIO(gc, rootEnv, myEnv->permissions.canRegisterLocalFS);
|
||||
{
|
||||
if(myEnv->permissions.localfs)
|
||||
{
|
||||
TStd::RegisterIO(gc, rootEnv, std::make_shared<RelativeFilesystem>(myEnv->permissions.localfs->GetVFS(),myEnv->permissions.localfs->GetWorking()));
|
||||
}
|
||||
else {
|
||||
TStd::RegisterIO(gc, rootEnv, nullptr);
|
||||
}
|
||||
}
|
||||
|
||||
if(myEnv->permissions.canRegisterJSON && !rootEnv->permissions.locked)
|
||||
TStd::RegisterJson(gc, rootEnv);
|
||||
@@ -2329,7 +2392,15 @@ namespace Tesses::CrossLang {
|
||||
if(GetArgument(args,0,r))
|
||||
{
|
||||
if((myEnv->permissions.canRegisterEverything || myEnv->permissions.canRegisterIO) && !rootEnv->permissions.locked)
|
||||
TStd::RegisterIO(gc, rootEnv, myEnv->permissions.canRegisterLocalFS ? r : false);
|
||||
{
|
||||
if(myEnv->permissions.localfs)
|
||||
{
|
||||
TStd::RegisterIO(gc, rootEnv, std::make_shared<RelativeFilesystem>(myEnv->permissions.localfs->GetVFS(),myEnv->permissions.localfs->GetWorking()));
|
||||
}
|
||||
else {
|
||||
TStd::RegisterIO(gc, rootEnv, nullptr);
|
||||
}
|
||||
}
|
||||
}
|
||||
cse.back()->Push(gc,nullptr);
|
||||
return false;
|
||||
|
||||
@@ -10,7 +10,7 @@
|
||||
#include <sstream>
|
||||
#include <variant>
|
||||
namespace Tesses::CrossLang {
|
||||
bool InterperterThread::GetField(GC* gc)
|
||||
bool InterperterThread::GetField(std::shared_ptr<GC> gc)
|
||||
{
|
||||
std::vector<CallStackEntry*>& cse=this->call_stack_entries;
|
||||
|
||||
@@ -47,6 +47,25 @@ namespace Tesses::CrossLang {
|
||||
cse.back()->Push(gc, Undefined());
|
||||
return false;
|
||||
}
|
||||
if(std::holds_alternative<std::shared_ptr<Tesses::Framework::TF_Timer_Handle>>(instance))
|
||||
{
|
||||
auto timer = std::get<std::shared_ptr<Tesses::Framework::TF_Timer_Handle>>(instance);
|
||||
if(timer)
|
||||
{
|
||||
if(key == "Interval")
|
||||
{
|
||||
cse.back()->Push(gc, timer->GetIntervalMilliseconds());
|
||||
return false;
|
||||
}
|
||||
if(key == "Enabled")
|
||||
{
|
||||
cse.back()->Push(gc, timer->GetEnabled());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
cse.back()->Push(gc, Undefined());
|
||||
return false;
|
||||
}
|
||||
if(std::holds_alternative<std::shared_ptr<Tesses::Framework::Filesystem::VFS>>(instance))
|
||||
{
|
||||
auto vfs = std::get<std::shared_ptr<Tesses::Framework::Filesystem::VFS>>(instance);
|
||||
|
||||
@@ -11,7 +11,11 @@
|
||||
#include <variant>
|
||||
namespace Tesses::CrossLang {
|
||||
|
||||
bool InterperterThread::SetField(GC* gc)
|
||||
static void empty()
|
||||
{
|
||||
|
||||
}
|
||||
bool InterperterThread::SetField(std::shared_ptr<GC> gc)
|
||||
{
|
||||
std::vector<CallStackEntry*>& cse=this->call_stack_entries;
|
||||
|
||||
@@ -30,7 +34,61 @@ namespace Tesses::CrossLang {
|
||||
}
|
||||
|
||||
std::string key = std::get<std::string>(_key);
|
||||
if(std::holds_alternative<std::shared_ptr<Tesses::Framework::TextStreams::TextWriter>>(instance))
|
||||
if(std::holds_alternative<std::shared_ptr<Tesses::Framework::TF_Timer_Handle>>(instance))
|
||||
{
|
||||
auto handle = std::get<std::shared_ptr<Tesses::Framework::TF_Timer_Handle>>(instance);
|
||||
if(handle)
|
||||
{
|
||||
int64_t ms;
|
||||
bool b;
|
||||
if(key == "Enabled" && GetObject(value,b))
|
||||
{
|
||||
|
||||
handle->SetEnabled(b);
|
||||
|
||||
cse.back()->Push(gc,b);
|
||||
return false;
|
||||
}
|
||||
|
||||
if(key == "Interval" && GetObject(value, ms))
|
||||
{
|
||||
handle->SetIntervalFromMilliseconds(ms);
|
||||
|
||||
cse.back()->Push(gc,ms);
|
||||
return false;
|
||||
}
|
||||
if(key == "Callback")
|
||||
{
|
||||
TCallable* callable;
|
||||
if(GetObjectHeap(value,callable))
|
||||
{
|
||||
|
||||
auto obj = CreateMarkedTObject(ls.GetGC(), callable);
|
||||
handle->SetCallback([obj]()->void {
|
||||
TCallable* callable;
|
||||
if(GetObjectHeap(obj->GetObject(), callable))
|
||||
{
|
||||
GCList ls(obj->GetGC());
|
||||
callable->Call(ls,{});
|
||||
}
|
||||
});
|
||||
cse.back()->Push(gc, callable);
|
||||
return false;
|
||||
}
|
||||
else
|
||||
{
|
||||
handle->SetCallback(empty);
|
||||
cse.back()->Push(gc, nullptr);
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
cse.back()->Push(gc, Undefined());
|
||||
return false;
|
||||
}
|
||||
if(std::holds_alternative<std::shared_ptr<Tesses::Framework::TextStreams::TextWriter>>(instance))
|
||||
{
|
||||
auto writer = std::get<std::shared_ptr<Tesses::Framework::TextStreams::TextWriter>>(instance);
|
||||
auto stringWriter = std::dynamic_pointer_cast<Tesses::Framework::TextStreams::StringWriter>(writer);
|
||||
@@ -177,11 +235,19 @@ namespace Tesses::CrossLang {
|
||||
auto netStrm = std::dynamic_pointer_cast<Tesses::Framework::Streams::NetworkStream>(strm);
|
||||
if(netStrm != nullptr)
|
||||
{
|
||||
int64_t n0;
|
||||
bool bc;
|
||||
if(key == "Broadcast" && GetObject(value,bc))
|
||||
netStrm->SetBroadcast(bc);
|
||||
if(key == "NoDelay" && GetObject(value,bc))
|
||||
netStrm->SetNoDelay(bc);
|
||||
if(key == "ReuseAddress" && GetObject(value,bc))
|
||||
netStrm->SetReuseAddress(bc);
|
||||
if(key == "ReusePort" && GetObject(value,bc))
|
||||
netStrm->SetReusePort(bc);
|
||||
if(key == "MulticastTTL" && GetObject(value,n0))
|
||||
netStrm->SetMulticastTTL((uint8_t)n0);
|
||||
|
||||
}
|
||||
stk->Push(gc, Undefined());
|
||||
return false;
|
||||
|
||||
@@ -10,7 +10,7 @@
|
||||
#include <sstream>
|
||||
#include <variant>
|
||||
namespace Tesses::CrossLang {
|
||||
bool InterperterThread::Sub(GC* gc)
|
||||
bool InterperterThread::Sub(std::shared_ptr<GC> gc)
|
||||
{
|
||||
std::vector<CallStackEntry*>& cse=this->call_stack_entries;
|
||||
GCList ls(gc);
|
||||
|
||||
@@ -10,7 +10,7 @@
|
||||
#include <sstream>
|
||||
#include <variant>
|
||||
namespace Tesses::CrossLang {
|
||||
std::string ToString(GC* gc, TObject o)
|
||||
std::string ToString(std::shared_ptr<GC> gc, TObject o)
|
||||
{
|
||||
if(std::holds_alternative<Tesses::Framework::Filesystem::VFSPath>(o))
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user