docs: update YJSInDepth.rst

update docs of event mechanism
This commit is contained in:
Frank.R.Wu 2021-11-05 14:21:27 +08:00
parent 4a41bb44ca
commit d2534a9ed9
3 changed files with 78 additions and 28 deletions

1
.gitignore vendored
View File

@ -22,3 +22,4 @@
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml # virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid* hs_err_pid*
/.idea

View File

@ -128,41 +128,92 @@ YJS中的变量类似于JavaScriptES6中的变量分为\ **全局变量
事件 事件
^^^^ ^^^^
YJS中的事件类似于Solidity中的事件。 YJS中包含两种事件全局Global事件和本地Local事件
* 全局事件类似于一般事件中间件中的事件,发布的事件由事件主题进行标识,订阅者通过订阅事件主题获取相应的事件。
* 本地事件类似于以太坊Solidity中的事件由智能合约定义并发布订阅者需要使用合约名/合约ID和事件名来订阅特定合约的相应事件。
**发布者**\ 定义一个包含事件发布函数的事件,然后通过调用事件发布函数发布事件。 **发布者**\ 定义一个包含事件发布函数的事件,然后通过调用事件发布函数发布事件。
定义的事件默认为本地事件可使用global或local关键词来标识事件的类型。
**订阅者**\ 订阅并处理事件。 **订阅者**\ 订阅并处理事件。
事件示例如下: 事件示例如下:
EventPuber.yjs EventLocalPuber.yjs
:: ::
contract EventPuber{ contract EventLocalPuber {
event abcEvent; event abcEvent;
// 等价于
// event local abcEvent
export function pub(arg){ export function pub(arg){
abcEvent(arg); abcEvent(arg);
return "done!"; return "done!";
} }
} }
EventSuber.yjs EventLocalSuber.yjs
:: ::
contract EventSuber{ contract EventLocalSuber {
export function init(arg){ function onCreate() {
YancloudUtil.subscribe("EventPuber","abcEvent",handler); Global.topic2event = {};
print("Handler:"+handler);
} }
function handler(e){ export function init(arg) {
var ret = "ReceiveEvent:"+(e.type)+" "+(e.content); var topic = YancloudUtil.subscribe("EventPuber", "abcEvent", handler);
Global.topic2event[topic] = "abcEvent";
print("Handler:" + handler);
}
function handler(e) {
var ret = "ReceiveEvent: " + (Global.topic2event[e.topic]) + " " + (e.content);
print(ret); print(ret);
} }
} }
EventGlobalPuber.yjs
::
contract EventGlobalPuber {
event global globalEvent;
export function pub(arg){
globalEvent(arg);
return "done!";
}
}
EventGlobalSuber.yjs
::
contract EventGlobalSuber {
export function init(arg) {
var topic = YancloudUtil.subscribe("globalEvent", handler);
print("Handler:" + handler);
}
function handler(e) {
var ret = "ReceiveEvent: " + (e.topic) + " " + (e.content);
print(ret);
}
}
YJS的两种事件都支持事件语义
* 至少一次AT_LEAST_ONCE事件至少被处理一次该事件将被发送给所有订阅者。
* 至多一次AT_MOST_ONCE事件至多被处理一次该事件只会被发送给一个随机的订阅者。
* 只有一次ONLY_ONCE该事件被且仅被一个合约订阅者处理一次。
默认的事件语义为至少一次,其他事件语义需要在事件声明中指定,例如:
::
event local alo(AT_LEAST_ONCE);
event global amo(AT_MOST_ONCE);
event global oo(ONLY_ONCE);
-------------- --------------
YJS项目 YJS项目

View File

@ -23,7 +23,6 @@ author = 'Peking University'
# The full version, including alpha/beta/rc tags # The full version, including alpha/beta/rc tags
release = 'V1.0' release = 'V1.0'
# -- General configuration --------------------------------------------------- # -- General configuration ---------------------------------------------------
# Add any Sphinx extension module names here, as strings. They can be # Add any Sphinx extension module names here, as strings. They can be
@ -31,9 +30,9 @@ release = 'V1.0'
# ones. # ones.
html_theme = "sphinx_rtd_theme" html_theme = "sphinx_rtd_theme"
html_logo="_static/imgs/logo.png" html_logo = "_static/imgs/logo.png"
html_theme_options = { html_theme_options = {
'logo_only': True 'logo_only': True
} }
source_parsers = { source_parsers = {
@ -70,13 +69,12 @@ language = 'zh_CN'
# This pattern also affects html_static_path and html_extra_path. # This pattern also affects html_static_path and html_extra_path.
exclude_patterns = [] exclude_patterns = []
# -- Options for HTML output ------------------------------------------------- # -- Options for HTML output -------------------------------------------------
# The theme to use for HTML and HTML Help pages. See the documentation for # The theme to use for HTML and HTML Help pages. See the documentation for
# a list of builtin themes. # a list of builtin themes.
# #
#html_theme = 'alabaster' # html_theme = 'alabaster'
# Add any paths that contain custom static files (such as style sheets) here, # Add any paths that contain custom static files (such as style sheets) here,
# relative to this directory. They are copied after the builtin static files, # relative to this directory. They are copied after the builtin static files,