bdcontract-web-ide/doc/markdown/YJSInDepth.html

457 lines
26 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html class="writer-html5" lang="zh-CN" >
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>YJS语法 &mdash; 北大数瑞大数据区块链 V1.0 文档</title>
<link rel="stylesheet" href="../_static/css/theme.css" type="text/css" />
<link rel="stylesheet" href="../_static/pygments.css" type="text/css" />
<link rel="shortcut icon" href="../_static/favicon.ico"/>
<!--[if lt IE 9]>
<script src="../_static/js/html5shiv.min.js"></script>
<![endif]-->
<script type="text/javascript" id="documentation_options" data-url_root="../" src="../_static/documentation_options.js"></script>
<script src="../_static/jquery.js"></script>
<script src="../_static/underscore.js"></script>
<script src="../_static/doctools.js"></script>
<script src="../_static/translations.js"></script>
<script type="text/javascript" src="../_static/js/theme.js"></script>
<link rel="index" title="索引" href="../genindex.html" />
<link rel="search" title="搜索" href="../search.html" />
</head>
<body class="wy-body-for-nav">
<div class="wy-grid-for-nav">
<nav data-toggle="wy-nav-shift" class="wy-nav-side">
<div class="wy-side-scroll">
<div class="wy-side-nav-search" >
<a href="../index.html">
<img src="../_static/logo.png" class="logo" alt="Logo"/>
</a>
<div role="search">
<form id="rtd-search-form" class="wy-form" action="../search.html" method="get">
<input type="text" name="q" placeholder="在文档中搜索" />
<input type="hidden" name="check_keywords" value="yes" />
<input type="hidden" name="area" value="default" />
</form>
</div>
</div>
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
<p class="caption"><span class="caption-text">目录</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../Introduction.html">BDContract介绍</a></li>
<li class="toctree-l1"><a class="reference internal" href="../InstallTips.html">BDContract安装说明</a></li>
<li class="toctree-l1"><a class="reference internal" href="../IDEUsage.html">BDContract管理界面</a></li>
<li class="toctree-l1"><a class="reference internal" href="../ContractAPI.html">BDContract SDK</a></li>
<li class="toctree-l1"><a class="reference internal" href="../YJSInDepth.html">YJS语法</a></li>
<li class="toctree-l1"><a class="reference internal" href="../YJSAPI.html">YJS SDK</a></li>
</ul>
</div>
</div>
</nav>
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
<nav class="wy-nav-top" aria-label="top navigation">
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
<a href="../index.html">北大数瑞大数据区块链</a>
</nav>
<div class="wy-nav-content">
<div class="rst-content">
<div role="navigation" aria-label="breadcrumbs navigation">
<ul class="wy-breadcrumbs">
<li><a href="../index.html" class="icon icon-home"></a> &raquo;</li>
<li>YJS语法</li>
<li class="wy-breadcrumbs-aside">
<a href="../_sources/markdown/YJSInDepth.md.txt" rel="nofollow"> 查看页面源码</a>
</li>
</ul>
<hr/>
</div>
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
<div itemprop="articleBody">
<div class="section" id="yjs">
<h1>YJS语法<a class="headerlink" href="#yjs" title="永久链接至标题"></a></h1>
<hr class="docutils" />
<div class="section" id="id1">
<h2>概述<a class="headerlink" href="#id1" title="永久链接至标题"></a></h2>
<p>YJS源文件包括任意数量的<strong>import声明</strong>和一个<strong>contract定义</strong></p>
</div>
<hr class="docutils" />
<div class="section" id="import">
<h2>import声明<a class="headerlink" href="#import" title="永久链接至标题"></a></h2>
<p>与JavaScriptES6类似YJS也支持import声明语句在全局层面开发者可以使用如下import声明来导入其他文件。</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="s2">&quot;filename&quot;</span><span class="p">;</span>
</pre></div>
</div>
<div class="section" id="id2">
<h3>内容<a class="headerlink" href="#id2" title="永久链接至标题"></a></h3>
<p>import声明语句将包含在“filename”文件中的所有全局符号单元导入到当前文件且全局范围内有效。</p>
</div>
<div class="section" id="id3">
<h3>路径<a class="headerlink" href="#id3" title="永久链接至标题"></a></h3>
<p><strong>filename</strong>通常用**/<strong>做目录分隔符来表示文件的路径,例如,从同一目录下导入</strong>x.yjs<strong>文件到当前文件,可以使用</strong>import “x.yjs”<strong>语句;从其他目录下导入</strong>x.yjs<strong>使用</strong>import “lib/x.yjs”**语句。</p>
</div>
</div>
<hr class="docutils" />
<div class="section" id="contract">
<h2>Contract定义<a class="headerlink" href="#contract" title="永久链接至标题"></a></h2>
<div class="section" id="id4">
<h3>示例<a class="headerlink" href="#id4" title="永久链接至标题"></a></h3>
<p>以下是一个合约示例用于JSON处理此YJS源文件以合约名称命名。</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">contract</span> <span class="n">ScoreAdder</span><span class="p">{</span>
<span class="o">//</span><span class="n">arg</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;action&quot;</span><span class="p">:</span><span class="s2">&quot;main&quot;</span><span class="p">,</span><span class="s2">&quot;arg&quot;</span><span class="p">:</span><span class="s2">&quot;[{</span><span class="se">\&quot;</span><span class="s2">score</span><span class="se">\&quot;</span><span class="s2">:20},{</span><span class="se">\&quot;</span><span class="s2">score</span><span class="se">\&quot;</span><span class="s2">:20}]&quot;</span><span class="p">}</span>
<span class="n">export</span> <span class="n">function</span> <span class="n">main</span><span class="p">(</span><span class="n">arg</span><span class="p">){</span>
<span class="o">//</span><span class="n">JSON</span> <span class="ow">is</span> <span class="n">a</span> <span class="n">build</span><span class="o">-</span><span class="ow">in</span> <span class="nb">object</span><span class="o">.</span>
<span class="n">var</span> <span class="n">point</span> <span class="o">=</span> <span class="n">JSON</span><span class="o">.</span><span class="n">parse</span><span class="p">(</span><span class="n">arg</span><span class="p">);</span>
<span class="n">var</span> <span class="n">s</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="nb">print</span><span class="p">(</span><span class="n">point</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">score</span><span class="p">);</span>
<span class="nb">print</span><span class="p">(</span><span class="n">point</span><span class="o">.</span><span class="n">length</span><span class="p">);</span>
<span class="k">for</span> <span class="p">(</span><span class="n">var</span> <span class="n">i</span><span class="o">=</span><span class="mi">0</span><span class="p">;</span><span class="n">i</span><span class="o">&lt;</span><span class="n">point</span><span class="o">.</span><span class="n">length</span><span class="p">;</span><span class="n">i</span><span class="o">++</span><span class="p">){</span>
<span class="n">s</span><span class="o">+=</span><span class="n">point</span><span class="p">[</span><span class="n">i</span><span class="p">]</span><span class="o">.</span><span class="n">score</span><span class="o">/</span><span class="mf">1.0</span><span class="p">;</span>
<span class="p">}</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;total score= &quot;</span><span class="o">+</span><span class="n">s</span><span class="p">);</span>
<span class="k">return</span> <span class="n">s</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
</pre></div>
</div>
</div>
<div class="section" id="id5">
<h3>注释<a class="headerlink" href="#id5" title="永久链接至标题"></a></h3>
<p>YJS源文件支持以<strong>//</strong>)表示的单行注释和以(<strong>/*…*/</strong>)表示的多行注释,如下所示:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="o">//</span> <span class="n">这是一个单行注释</span>
<span class="o">/*</span>
<span class="o">*</span> <span class="n">这是一个</span>
<span class="o">*</span> <span class="n">多行注释</span>
<span class="o">*/</span>
</pre></div>
</div>
</div>
<div class="section" id="id6">
<h3>注解<a class="headerlink" href="#id6" title="永久链接至标题"></a></h3>
<p>与Java类似YJS也支持注解声明合约和函数。</p>
<p>在YJS中有几种内建注解LogType、LogLocation、Access、Permission。
当然,可以自定义注解。
内建注解的详细使用方式可以通过YJS内置API文档查看。
开发者可以使用如下注解来声明合约和函数。</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="nd">@LogType</span><span class="p">(</span><span class="s2">&quot;Arg&quot;</span><span class="p">,</span><span class="s2">&quot;Result&quot;</span><span class="p">,</span><span class="s2">&quot;Branch&quot;</span><span class="p">)</span>
<span class="nd">@SelfDefinedAnntation</span><span class="p">(</span><span class="s2">&quot;dad&quot;</span><span class="p">,</span><span class="mi">1</span><span class="p">)</span>
<span class="nd">@Access</span>
<span class="n">function</span> <span class="n">xxx</span><span class="p">(){}</span>
</pre></div>
</div>
</div>
<div class="section" id="id7">
<h3>结构<a class="headerlink" href="#id7" title="永久链接至标题"></a></h3>
<p>YJS中的合约类似于Java中的类。每个合约都定义了一定数量的<strong>变量</strong><strong>函数</strong><strong>事件</strong></p>
<div class="section" id="id8">
<h4>变量<a class="headerlink" href="#id8" title="永久链接至标题"></a></h4>
<p>YJS中的变量类似于JavaScriptES6中的变量分为<strong>全局变量</strong><strong>局部变量</strong></p>
<p>全局变量:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">judge</span> <span class="o">=</span> <span class="n">true</span><span class="p">;</span>
</pre></div>
</div>
<p>局部变量:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">var</span> <span class="n">vs</span> <span class="o">=</span> <span class="s2">&quot;This is a string&quot;</span><span class="p">;</span>
</pre></div>
</div>
<p>所有的变量都是<strong>动态类型</strong>因为变量的具体类型是根据变量值来决定的。如上示例中全局变量judge是bool类型局部变量vs是字符串类型。</p>
</div>
<div class="section" id="id9">
<h4>函数<a class="headerlink" href="#id9" title="永久链接至标题"></a></h4>
<p>函数是合约中的可执行单元。YJS中有两种类型的函数普通函数和用<strong>export</strong>关键字修饰的exported函数。</p>
<p>以下是exported函数和普通函数的区别</p>
<ol class="simple">
<li><p>只有exported函数能被其他合约调用。</p></li>
<li><p>exported函数只能有一个参数且参数类型必须为String。</p></li>
<li><p>exported函数的返回类型必须是String。</p></li>
<li><p>内置对象requester请求者的公钥只能存在于exported函数或onCreate函数因为onCreate()虽然没被<strong>export</strong>关键字修饰但它自带requester对象且该函数可以自动执行。</p></li>
</ol>
</div>
<div class="section" id="id10">
<h4>事件<a class="headerlink" href="#id10" title="永久链接至标题"></a></h4>
<p>YJS中的事件类似于Solidity中的事件。</p>
<p><strong>发布者</strong>定义一个包含事件发布函数的事件,然后通过调用事件发布函数发布事件。</p>
<p><strong>订阅者</strong>订阅并处理事件。</p>
<p>事件示例如下:</p>
<p>EventPuber.yjs</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">contract</span> <span class="n">EventPuber</span><span class="p">{</span>
<span class="n">event</span> <span class="n">abcEvent</span><span class="p">;</span>
<span class="n">export</span> <span class="n">function</span> <span class="n">pub</span><span class="p">(</span><span class="n">arg</span><span class="p">){</span>
<span class="n">abcEvent</span><span class="p">(</span><span class="n">arg</span><span class="p">);</span>
<span class="k">return</span> <span class="s2">&quot;done!&quot;</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
</pre></div>
</div>
<p>EventSuber.yjs</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">contract</span> <span class="n">EventSuber</span><span class="p">{</span>
<span class="n">export</span> <span class="n">function</span> <span class="n">init</span><span class="p">(</span><span class="n">arg</span><span class="p">){</span>
<span class="n">YancloudUtil</span><span class="o">.</span><span class="n">subscribe</span><span class="p">(</span><span class="s2">&quot;EventPuber&quot;</span><span class="p">,</span><span class="s2">&quot;abcEvent&quot;</span><span class="p">,</span><span class="n">handler</span><span class="p">);</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Handler:&quot;</span><span class="o">+</span><span class="n">handler</span><span class="p">);</span>
<span class="p">}</span>
<span class="n">function</span> <span class="n">handler</span><span class="p">(</span><span class="n">e</span><span class="p">){</span>
<span class="n">var</span> <span class="n">ret</span> <span class="o">=</span> <span class="s2">&quot;ReceiveEvent:&quot;</span><span class="o">+</span><span class="p">(</span><span class="n">e</span><span class="o">.</span><span class="n">type</span><span class="p">)</span><span class="o">+</span><span class="s2">&quot; &quot;</span><span class="o">+</span><span class="p">(</span><span class="n">e</span><span class="o">.</span><span class="n">content</span><span class="p">);</span>
<span class="nb">print</span><span class="p">(</span><span class="n">ret</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
</pre></div>
</div>
</div>
</div>
</div>
<hr class="docutils" />
<div class="section" id="id11">
<h2>YJS项目<a class="headerlink" href="#id11" title="永久链接至标题"></a></h2>
<p>除了只包含一个contract定义的YJS源文件YJS引擎还支持<strong>YJS项目</strong></p>
<p>每个YJS project包含了合约执行过程中需用到的各种文件包括yjs源文件**”.yjs”<strong>和其他资源文件,如</strong>”mainfest.json”<strong>, <strong>“.js”</strong>, <strong>“.txt”</strong>,</strong>”.jar”**, …</p>
<div class="section" id="manifest-json">
<h3>Manifest.json<a class="headerlink" href="#manifest-json" title="永久链接至标题"></a></h3>
<p>每个YJS项目在项目的根目录下必须有一个<strong>mainfest.json</strong>文件此文件描述了合约对于YJS的编译工具YJS引擎所需的必要信息。</p>
<div class="section" id="manifest">
<h4>Manifest结构<a class="headerlink" href="#manifest" title="永久链接至标题"></a></h4>
<p>manifest文件需包含以下信息</p>
<ol class="simple">
<li><p><strong>main</strong>: 项目中将要被执行的合约文件。</p></li>
<li><p><strong>type</strong>: 合约的类型,如数据合约/算法合约…</p></li>
<li><p><strong>builder</strong>: 构建YJS项目的开发者姓名。</p></li>
<li><p><strong>insnLimit</strong>: 运行合约需要消耗的值。</p></li>
<li><p><strong>pyDependences</strong>: 项目所需的Python依赖。</p></li>
</ol>
</div>
<div class="section" id="id12">
<h4>Manifest示例<a class="headerlink" href="#id12" title="永久链接至标题"></a></h4>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="p">{</span>
<span class="s2">&quot;main&quot;</span><span class="p">:</span> <span class="s2">&quot;contract.js&quot;</span><span class="p">,</span>
<span class="s2">&quot;type&quot;</span><span class="p">:</span> <span class="s2">&quot;Data&quot;</span><span class="p">,</span>
<span class="s2">&quot;builder&quot;</span><span class="p">:</span> <span class="s2">&quot;caihq&quot;</span><span class="p">,</span>
<span class="s2">&quot;permissions&quot;</span><span class="p">:</span> <span class="mi">0</span><span class="n">L</span><span class="p">,</span>
<span class="s2">&quot;pyDependences&quot;</span><span class="p">:</span> <span class="p">[</span>
<span class="p">{</span>
<span class="s2">&quot;name&quot;</span><span class="p">:</span> <span class="s2">&quot;yjsexample&quot;</span><span class="p">,</span>
<span class="s2">&quot;modules&quot;</span><span class="p">:</span> <span class="p">[</span>
<span class="p">{</span>
<span class="s2">&quot;name&quot;</span><span class="p">:</span> <span class="s2">&quot;sample&quot;</span>
<span class="p">}</span>
<span class="p">]</span>
<span class="p">}</span>
<span class="p">]</span>
<span class="p">}</span>
</pre></div>
</div>
</div>
</div>
<div class="section" id="yjs-java">
<h3>YJS-Java<a class="headerlink" href="#yjs-java" title="永久链接至标题"></a></h3>
<p>Jar文件实现了YJS与其他编程语言间的<strong>跨语言调用</strong>如YJS-Java, YJS-Python, … 通过将Java文件包成jar包的方式使得合约可直接调用Java中的方法。</p>
<p>Java class:</p>
<div class="highlight-java notranslate"><div class="highlight"><pre><span></span><span class="kn">package</span> <span class="nn">your.own.pkg</span><span class="o">;</span>
<span class="kd">public</span> <span class="kd">class</span> <span class="nc">HelloWorld</span> <span class="o">{</span>
<span class="kd">public</span> <span class="kd">static</span> <span class="kt">int</span> <span class="nf">fun</span><span class="o">(</span><span class="n">String</span> <span class="n">arg</span><span class="o">){</span>
<span class="k">return</span> <span class="n">arg</span><span class="o">.</span><span class="na">length</span><span class="o">;</span>
<span class="o">}</span>
<span class="kd">public</span> <span class="kt">int</span> <span class="nf">fun2</span><span class="o">(</span><span class="n">String</span> <span class="n">arg</span><span class="o">){</span>
<span class="k">return</span> <span class="n">arg</span><span class="o">.</span><span class="na">length</span><span class="o">;</span>
<span class="o">}</span>
<span class="o">}</span>
</pre></div>
</div>
<p>InvokeJava.yjs</p>
<div class="highlight-javascript notranslate"><div class="highlight"><pre><span></span><span class="nx">contract</span> <span class="nx">InvokeJava</span><span class="p">{</span>
<span class="kr">export</span> <span class="kd">function</span> <span class="nx">main</span><span class="p">(</span><span class="nx">arg</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">Hello</span> <span class="o">=</span> <span class="nx">Java</span><span class="p">.</span><span class="nx">type</span><span class="p">(</span><span class="s2">&quot;your.own.package.HelloWorld&quot;</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">hello</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">Hello</span><span class="p">();</span>
<span class="k">return</span> <span class="nx">Hello</span><span class="p">.</span><span class="nx">fun</span><span class="p">(</span><span class="nx">arg</span><span class="p">)</span><span class="o">+</span><span class="nx">hello</span><span class="p">.</span><span class="nx">fun2</span><span class="p">(</span><span class="nx">arg</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
</pre></div>
</div>
</div>
<div class="section" id="id13">
<h3>YJS-前端<a class="headerlink" href="#id13" title="永久链接至标题"></a></h3>
<p>使用数瑞客户端来访问智能合约支持从智能合约中获取html/js/css等资源文件
并在<a class="reference external" href="./_static/BDWareWebClient.zip">BDWareWebClient</a>中渲染。
首先在合约中import以下模块。</p>
<div class="highlight-javascript notranslate"><div class="highlight"><pre><span></span><span class="nx">module</span> <span class="nx">Viewable</span><span class="p">{</span>
<span class="kr">export</span> <span class="kd">function</span> <span class="nx">loadResource</span><span class="p">(</span><span class="nx">arg</span><span class="p">){</span>
<span class="k">return</span> <span class="nx">Global</span><span class="p">.</span><span class="nx">Resources</span><span class="p">.</span><span class="nx">loadAsString</span><span class="p">(</span><span class="nx">arg</span><span class="p">);</span>
<span class="p">}</span>
<span class="kr">export</span> <span class="kd">function</span> <span class="nx">needRender</span><span class="p">(</span><span class="nx">arg</span><span class="p">){</span>
<span class="k">return</span> <span class="kc">true</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
</pre></div>
</div>
<p>同时import以后定义一个getMainFrame方法以便数瑞客户端识别主页</p>
<div class="highlight-javascript notranslate"><div class="highlight"><pre><span></span><span class="kr">export</span> <span class="kd">function</span> <span class="nx">getMainFrame</span><span class="p">(</span><span class="nx">arg</span><span class="p">){</span>
<span class="k">return</span> <span class="s2">&quot;/html/main.html&quot;</span><span class="p">;</span>
<span class="p">}</span>
</pre></div>
</div>
<p>该方法的返回结果为一个资源文件的路径。
示例的资源文件”/html/main.html”如下</p>
<div class="highlight-html notranslate"><div class="highlight"><pre><span></span><span class="p">&lt;</span><span class="nt">div</span><span class="p">&gt;</span>
<span class="p">&lt;</span><span class="nt">button</span> <span class="na">onclick</span><span class="o">=</span><span class="s">&quot;queryDataFromContract()&quot;</span><span class="p">&gt;</span>Hello,<span class="p">&lt;/</span><span class="nt">button</span><span class="p">&gt;</span> Data from contract:
<span class="p">&lt;</span><span class="nt">span</span> <span class="na">id</span><span class="o">=</span><span class="s">&quot;resultText&quot;</span><span class="p">&gt;&lt;/</span><span class="nt">span</span><span class="p">&gt;</span>
<span class="p">&lt;</span><span class="nt">script</span> <span class="na">fromContract</span><span class="o">=</span><span class="s">&quot;/html/hello.js&quot;</span><span class="p">&gt;&lt;/</span><span class="nt">script</span><span class="p">&gt;</span>
<span class="p">&lt;</span><span class="nt">link</span> <span class="na">fromContract</span><span class="o">=</span><span class="s">&quot;/html/hello.css&quot;</span><span class="p">/&gt;</span>
<span class="p">&lt;/</span><span class="nt">div</span><span class="p">&gt;</span>
</pre></div>
</div>
<p>示例的资源文件”/html/hello.js”如下</p>
<div class="highlight-javascript notranslate"><div class="highlight"><pre><span></span><span class="kd">var</span> <span class="nx">queryDataFromContract</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(){</span>
<span class="c1">//第一个参数为函数名,第二个为参数,第三个参数为回调。</span>
<span class="kd">var</span> <span class="nx">data</span> <span class="o">=</span> <span class="nx">executeCurrentContract</span><span class="p">(</span><span class="s2">&quot;query&quot;</span><span class="p">,</span><span class="s2">&quot;abc&quot;</span><span class="p">,</span><span class="kd">function</span><span class="p">(</span><span class="nx">argg</span><span class="p">){</span>
<span class="nx">$</span><span class="p">(</span><span class="s2">&quot;#resultText&quot;</span><span class="p">)[</span><span class="mi">0</span><span class="p">].</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="nx">argg</span><span class="p">.</span><span class="nx">result</span><span class="p">;</span>
<span class="p">});</span>
<span class="p">}</span>
</pre></div>
</div>
<p>参考示例:</p>
</div>
<div class="section" id="yjs-python">
<h3>YJS-Python<a class="headerlink" href="#yjs-python" title="永久链接至标题"></a></h3>
<p>TODO</p>
</div>
</div>
</div>
</div>
</div>
<footer>
<hr/>
<div role="contentinfo">
<p>
&#169; 版权所有 2021, Peking University.
</p>
</div>
利用 <a href="https://www.sphinx-doc.org/">Sphinx</a> 构建,使用了
<a href="https://github.com/readthedocs/sphinx_rtd_theme">主题</a>
<a href="https://readthedocs.org">Read the Docs</a>开发.
</footer>
</div>
</div>
</section>
</div>
<script type="text/javascript">
jQuery(function () {
SphinxRtdTheme.Navigation.enable(true);
});
</script>
</body>
</html>