开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
开源项目 > 程序开发 > 编程语言/脚本语言 &&
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
13 Star 69 Fork 22

johnsonyl/cpps

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
v1.0.2
分支 (1)
标签 (4)
master
v1.0.3-beta
v1.0.3
v1.0.2
v1.0.0
cpps
/
src
/
cpps_async_loop.cpp
cpps
/
src
/
cpps_async_loop.cpp
cpps_async_loop.cpp 6.40 KB
一键复制 编辑 原始数据 按行查看 历史
johnsonyl 提交于 2022年01月12日 02:17 +08:00 . 优化编译错误.增加asyncio then catch功能
#include "cpps/cpps.h"
namespace cpps {
cpps_async_loop::cpps_async_loop()
{
c = NULL;
runstate = false;
}
cpps_async_loop::~cpps_async_loop()
{
/*remove not used data*/
_tasks.clear();
}
void cpps_async_loop::setcstate(C* pc)
{
c = pc;
c->ordinator = &ordinator;
}
cpps_value cpps_async_loop::run_until_complete(C* c, cpps_value task)
{
/*
* task 可能是3种类型
* 1. cpps_async_object 类型
* 2. cpps_async_task 类型
* 3. vector<cpps_async_task> 类型 数组结构传进来,则数组结构传出去.
*/
if (isrunning()) throw(cpps_error(c->curnode->filename, c->curnode->line, cpps_error_asyncerror, "the loop is running,please use await call async function. ")); /*已经运行中,不能再次调用*/
_tasks.clear(); /*说明用户自己启用协程列表,不由默认*/
cpps_value ret;
cpps_async_task* roottask = NULL;
if (task.isdomain() && task.value.domain->domainname == "ASYNC_OBJECT") {
cpps_async_object* vobj = cpps_converter<cpps_async_object*>::apply(task);
if (vobj->get_task() == NULL) {
ret = create_task(c, vobj, &roottask);
push_task(c, ret);
}
else {
roottask = vobj->get_task();
object task(c, roottask);
ret = task.getval();
}
}
else if (task.isdomain() && task.value.domain->domainname == "ASYNC_TASK") {
roottask = cpps_converter<cpps_async_task*>::apply(task);
ret = task;
if (roottask->state()) throw(cpps_error(c->curnode->filename, c->curnode->line, cpps_error_asyncerror, "the task state is running. "));
push_task(c, ret);
}
else if (task.isdomain() && task.value.domain->domainname == "vector"){
cpps_vector* retvec;
newclass<cpps_vector>(c, &retvec,&ret);
cpps_vector* vec = cpps_converter<cpps_vector*>::apply(task);
for (auto v : vec->realvector()) {
if (v.isdomain() && v.value.domain->domainname == "ASYNC_OBJECT") {
cpps_async_object* vobj = cpps_converter<cpps_async_object*>::apply(v);
cpps_value vtask_value;
cpps_async_task* vtask;
if (vobj->get_task() == NULL) {
vtask_value = create_task(c, vobj, &vtask);
push_task(c, vtask_value);
}
else {
vtask = vobj->get_task();
object task(c, vtask);
vtask_value = task.getval();
}
retvec->push_back(vtask_value);
}
else if (v.isdomain() && task.value.domain->domainname == "ASYNC_TASK") {
cpps_async_task* vtask = cpps_converter<cpps_async_task*>::apply(v);
if (vtask->state()) throw(cpps_error(c->curnode->filename, c->curnode->line, cpps_error_asyncerror, "the task state is running."));
push_task(c,v);
retvec->push_back(v);
}
}
}
else
throw (cpps_error(c->curnode->filename, c->curnode->line, cpps_error_asyncerror, "async run_until_complete is a unknow task type."));
/*运行*/
loop(c, roottask);
/*回收协程*/
for (auto vtask : _tasks) {
cpps_async_task* task2 = cpps_converter<cpps_async_task*>::apply(vtask);
if (task2 && task2->rt != MAXUINT64)
coroutine::destroy(ordinator, task2->rt);
}
_tasks.clear();
return ret;
}
void cpps_async_loop::loop(C* c, cpps_async_task* roottask)
{
runstate = true;
std::vector<cpps_stack*> *takestacklist = c->getcallstack(); /*记录原始callstack*/
bool hasrun = true;
while (hasrun) {
hasrun = false;
/*pop empty task*/
popemptytask();
/*当主协程运行完毕,则关闭所有协程*/
if (roottask && roottask->state() != cpps_async_task_running) {
terminate_all_task();
}
for(size_t i = 0; i < _tasks.size(); i++){
auto vtask = _tasks[i];
auto task = cpps_converter<cpps_async_task*>::apply(vtask);
if (task){
if (task->rt == MAXUINT64)
{
task->runstate = cpps_async_task_done;
_tasks[i] = nil; /*可以释放了.*/
}
else if (task->state() == cpps_async_task_running){
/*将这个协程的stack设置回来*/
c->setcallstack(&task->takestacklist);
coroutine::resume(ordinator, task->rt);
vtask = _tasks[i]; /*需要恢复task*/
task = cpps_converter<cpps_async_task*>::apply(vtask);
hasrun = true;
if (task->state() == cpps_async_task_done || task->state() == cpps_async_task_thorw) {
if(task->state() == cpps_async_task_done) task->call_done_callback(c);
coroutine::destroy(ordinator, task->rt);
task->rt = MAXUINT64;
_tasks[i] = nil;
}
}
else{
//结束了但是没释放. timeout,terminate,cancel等状态.
if (task->rt != MAXUINT64) {
c->setcallstack(&task->takestacklist);
c->isterminate = true; //通知协程停止.
ordinator.isterminate = true;//通知协程停止.
coroutine::resume(ordinator, task->rt); //停止的原因是为了清理变量,否则导致GC计数永不为0 导致不能释放内存.造成内存泄露.
vtask = _tasks[i]; /*需要恢复task*/
task = cpps_converter<cpps_async_task*>::apply(vtask);
c->isterminate = false;//返回正常状态.
ordinator.isterminate = false;//返回正常状态.
coroutine::destroy(ordinator, task->rt);
}
task->rt = MAXUINT64;
_tasks[i] = nil; /*可以释放了.*/
}
}
}
}
/*恢复stack*/
popemptytask();
c->setcallstack(takestacklist);
runstate = false;
}
void cpps_async_loop::terminate_all_task()
{
for (auto vtask : _tasks) {
cpps_async_task* task = cpps_converter<cpps_async_task*>::apply(vtask);
if (task && task->state() == cpps_async_task_running) {
task->runstate = cpps_async_task_terminate;
}
}
}
void cpps_async_loop::popemptytask()
{
auto it = _tasks.begin();
auto end = _tasks.end();
for (;it != end;) {
cpps_async_task* task = cpps_converter<cpps_async_task*>::apply (*it);
if (task == NULL) {
it = _tasks.erase(it);
end = _tasks.end();
}
else
++it;
}
}
bool cpps_async_loop::isrunning()
{
return runstate;
}
void cpps_async_loop::push_task(C*c,cpps_value vtask)
{
cpps_async_task* task = cpps_converter<cpps_async_task*>::apply(vtask);
task->rt = coroutine::create(ordinator,std::bind(cpps_async_task::run, task, c));/*创建协程*/
task->start(c);
_tasks.push_back(vtask); //加入默认列表
}
cpps_value cpps_async_loop::create_task(C*c,cpps_async_object* obj, cpps_async_task**outtask)
{
cpps_async_task* task;
cpps_value ret;
newclass< cpps_async_task>(c, &task, &ret);
task->async_object = obj;
obj->set_task(task);
*outtask = task;
return ret;
}
}
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

CPPS是一种轻量级的嵌入式脚本语言,其语法类似于C++。它具有当前主流语言的许多特性,包括协程、面向对象、lambda、闭包、泛型变量、自定义模块支持、GC垃圾收集和跨平台。CPPS将程序解释为字节码,通过内置语法解析在虚拟机中运行
取消

发行版 (3)

全部

开源评估指数源自 OSS-Compass 评估体系,评估体系围绕以下三个维度对项目展开评估:

1. 开源生态

  • 生产力:来评估开源项目输出软件制品和开源价值的能力。
  • 创新力:用于评估开源软件及其生态系统的多样化程度。
  • 稳健性:用于评估开源项目面对多变的发展环境,抵御内外干扰并自我恢复的能力。

2. 协作、人、软件

  • 协作:代表了开源开发行为中协作的程度和深度。
  • 人:观察开源项目核心人员在开源项目中的影响力,并通过第三方视角考察用户和开发者对开源项目的评价。
  • 软件:从开源项目对外输出的制品评估其价值最终落脚点。也是开源评估最"古老"的主流方向之一"开源软件" 的具体表现。

3. 评估模型

    基于"开源生态"与"协作、人、软件"的维度,找到与该目标直接或间接相关的可量化指标,对开源项目健康与生态进行量化评估,最终形成开源评估指数。

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/cppscript/cpps.git
git@gitee.com:cppscript/cpps.git
cppscript
cpps
cpps
v1.0.2
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /