summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWe-unite <3205135446@qq.com>2025-01-07 12:36:05 +0800
committerWe-unite <3205135446@qq.com>2025-01-07 12:36:05 +0800
commit4d88ef666eee1b6f191f6e85b00acf8d5a2d1899 (patch)
tree68391846bae84f9546b0d089c012afc336a6e6bd
parent11e64c5804b696f170b9d5d881befbabc4a4e85c (diff)
downloadmyweb-4d88ef666eee1b6f191f6e85b00acf8d5a2d1899.tar.gz
myweb-4d88ef666eee1b6f191f6e85b00acf8d5a2d1899.zip
highlight don't use auto-detect but given languagenew_highlightjs
In this commit, lot's of things is changed. Hope they all runs currectly. Now highlight.js is supporting more and more proguam languages, but the auto detection always go wrong, even for common languages like c, bash, python, makefile. Use Given Language ------------------ As you know, I always write markdown and convert to html by pandoc. In the old, "```cpp" in markdown will be deleted first to keep the embeded code clean and not highlighted, then I can use highlight.js. But this causes that html document doesn't know the language. This time, md2html.sh is changed: pandoc use "--no-highlight" argument to keep code clean, and it will output like this: ```html <pre class="cpp"><code>...</code></pre> ``` Although there may be other tags between `<code></code>`, it's clear that `<pre class="xxx"><code>` is nested tightly, except some space characters or \n. Then, sed deal with the whole doc(not line by line), replace `<pre class="xxx"><code>` with `<pre><code class="language-xxx">`. That's it! Math Formula ------------ Math formular is also a problem during convertion by pandoc. In the old it's dealed menually. Now pandoc use "--mathjax=none", then formula is no longer showed by pandoc, but only `<span class="math xxx">\( formula \)</span>`. And the math tool I used will deal with it. Mermaid picture ---------------- pandoc doesn't support convert mermaid in markdown to html picture. Let's have a warning!
-rw-r--r--code/MyCodes.html (renamed from code/index.html)21
-rw-r--r--code/cpppp.html87
-rw-r--r--code/cpppp.md16
-rw-r--r--code/linux/aliyun_cloud.html50
-rw-r--r--code/linux/aliyun_cloud.md2
-rw-r--r--code/linux/gitserver.html70
-rw-r--r--code/linux/gitserver.md16
-rw-r--r--code/linux/httpmyserver.html31
-rw-r--r--code/linux/httpmyserver.md4
-rw-r--r--code/linux/keymap.html811
-rw-r--r--code/linux/keymap.md6
-rw-r--r--code/linux/vim.html391
-rw-r--r--code/linux/vim.md23
-rw-r--r--code/projects/godo.html26
-rw-r--r--code/projects/lcm_compile.html24
-rw-r--r--code/projects/ohos_compile.html60
-rw-r--r--code/zeal.html2113
-rw-r--r--code/zeal.md11
-rw-r--r--common/script4code.html1
-rw-r--r--common/script4code.js1
-rw-r--r--common/script4works.html2
-rw-r--r--common/script4works.js2
-rw-r--r--courseNotes/parallel.html169
-rw-r--r--courseNotes/parallel.md2
-rw-r--r--images/code/httpmyserver_1.pngbin0 -> 39620 bytes
-rw-r--r--images/code/httpmyserver_2.pngbin0 -> 158623 bytes
-rw-r--r--images/code/ohos_compile_gn_fail_1.png (renamed from images/code/ohos_gn_fail_1.png)bin142811 -> 142811 bytes
-rw-r--r--images/code/ohos_compile_gn_fail_2.png (renamed from images/code/ohos_gn_fail_2.png)bin364508 -> 364508 bytes
-rw-r--r--images/code/ohos_compile_gn_fail_dependencies.png (renamed from images/code/ohos_gn_fail_dependencies.png)bin91985 -> 91985 bytes
-rw-r--r--images/code/vim_mode.pngbin0 -> 9591 bytes
-rw-r--r--images/courseNotes/parallel_1.pngbin0 -> 7330 bytes
-rw-r--r--images/courseNotes/parallel_2.pngbin0 -> 6922 bytes
-rw-r--r--images/courseNotes/parallel_3.pngbin0 -> 55891 bytes
-rwxr-xr-xmd2html.sh47
34 files changed, 1056 insertions, 2930 deletions
diff --git a/code/index.html b/code/MyCodes.html
index 0550e98..0fc370f 100644
--- a/code/index.html
+++ b/code/MyCodes.html
@@ -7,25 +7,26 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>我的实用代码</title> 8 <title>我的实用代码</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">我的实用代码</p> 16 <header id="title-block-header">
17 <p class="title">我的实用代码</p>
18 </header>
18 <p>这里是英(C)语(yǔ)科(yán)听力部分。该部分有第一、第二两节。</p> 19 <p>这里是英(C)语(yǔ)科(yán)听力部分。该部分有第一、第二两节。</p>
19 <p>请注意,回答听力部分时,请先将答案写在试卷上,听力部分结束前,你将有两分钟的时间将试卷上的答案转移到答题卡上。</p> 20 <p>请注意,回答听力部分时,请先将答案写在试卷上,听力部分结束前,你将有两分钟的时间将试卷上的答案转移到答题卡上。</p>
20 <p>听力考试,现在开始!</p> 21 <p>听力考试,现在开始!</p>
21 <h1 id="光标隐藏函数">光标隐藏函数</h1> 22 <h1 id="光标隐藏函数">光标隐藏函数</h1>
22 <pre><code>void HideCursor(void) 23 <pre><code class="language-c">void HideCursor(void)
23{ 24{
24 CONSOLE_CURSOR_INFO cursor_info = {1, 0}; 25 CONSOLE_CURSOR_INFO cursor_info = {1, 0};
25 SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &amp;cursor_info); 26 SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &amp;cursor_info);
26}</code></pre> 27}</code></pre>
27 <h1 id="show_bytes">show_bytes</h1> 28 <h1 id="show_bytes">show_bytes</h1>
28 <pre><code>#include &lt;bits/stdc++.h&gt; 29 <pre><code class="language-cpp">#include &lt;bits/stdc++.h&gt;
29using namespace std; 30using namespace std;
30typedef unsigned char* bite_pointer; 31typedef unsigned char* bite_pointer;
31typedef int T;//数据类型为int,可更改 32typedef int T;//数据类型为int,可更改
@@ -56,7 +57,7 @@ int main()
56}</code></pre> 57}</code></pre>
57 <h1 id="界面设计和上色">界面设计和上色</h1> 58 <h1 id="界面设计和上色">界面设计和上色</h1>
58 <p>注意:<strong>本内容请勿改动任何参数!</strong></p> 59 <p>注意:<strong>本内容请勿改动任何参数!</strong></p>
59 <pre><code>#include &lt;windows.h&gt; 60 <pre><code class="language-c">#include &lt;windows.h&gt;
60#include &lt;conio.h&gt; 61#include &lt;conio.h&gt;
61#include &lt;time.h&gt; 62#include &lt;time.h&gt;
62 63
@@ -82,7 +83,7 @@ int color(int c)//设置颜色
82 句子上色用<code>color(c)</code>,c 为指定颜色序号。 83 句子上色用<code>color(c)</code>,c 为指定颜色序号。
83 输出后的停顿用<code>void Sleep(int t)</code>函数,在<code>&lt;windows.h&gt;</code>中,t 代表暂停的毫秒数。 使用时每个句子前都要用 gotoxy 84 输出后的停顿用<code>void Sleep(int t)</code>函数,在<code>&lt;windows.h&gt;</code>中,t 代表暂停的毫秒数。 使用时每个句子前都要用 gotoxy
84 指定位置,用 color 上色。 合起来如下:</p> 85 指定位置,用 color 上色。 合起来如下:</p>
85 <pre><code> gotoxy(hout,wide/5,high/6); 86 <pre><code class="language-c"> gotoxy(hout,wide/5,high/6);
86 color(6); 87 color(6);
87 printf(&quot;本计算器仅支持5个及以下的矩阵,分别名为A~E(大写)。&quot;); 88 printf(&quot;本计算器仅支持5个及以下的矩阵,分别名为A~E(大写)。&quot;);
88 Sleep(200); 89 Sleep(200);
@@ -91,7 +92,7 @@ int color(int c)//设置颜色
91 printf(&quot;每个矩阵阶数不超过5*5。&quot;); 92 printf(&quot;每个矩阵阶数不超过5*5。&quot;);
92 Sleep(200);</code></pre> 93 Sleep(200);</code></pre>
93 <h1 id="关于音乐效果">关于音乐效果</h1> 94 <h1 id="关于音乐效果">关于音乐效果</h1>
94 <pre><code>#include&lt;windows.h&gt; 95 <pre><code class="language-c">#include&lt;windows.h&gt;
95#include&lt;mmsystem.h&gt; 96#include&lt;mmsystem.h&gt;
96#pragma comment(lib.&quot;Winmm.lib&quot;) //头文件 97#pragma comment(lib.&quot;Winmm.lib&quot;) //头文件
97PlaySound(TEXT(&quot;音乐名.wav&quot;),NULL,SND_FILENAME | SND_ASYNC | SND_LOOP);//开始播放 98PlaySound(TEXT(&quot;音乐名.wav&quot;),NULL,SND_FILENAME | SND_ASYNC | SND_LOOP);//开始播放
@@ -99,7 +100,7 @@ PlaySound(NULL,NULL,SND_FILENAME);//结束播放</code></pre>
99 <p>注意:音频必须使用<strong>wav</strong>格式,必须放在<strong>跟代码同一个文件夹</strong>,如果不然,音乐名处<strong>应当使用其绝对地址或相对地址</strong>。 100 <p>注意:音频必须使用<strong>wav</strong>格式,必须放在<strong>跟代码同一个文件夹</strong>,如果不然,音乐名处<strong>应当使用其绝对地址或相对地址</strong>。
100 </p> 101 </p>
101 <h1 id="震动心形设计">震动心形设计</h1> 102 <h1 id="震动心形设计">震动心形设计</h1>
102 <pre><code>#define I 20 103 <pre><code class="language-c">#define I 20
103#define R 340 104#define R 340
104 105
105int wide=80,high=40;//宏常量定义,数据可变 106int wide=80,high=40;//宏常量定义,数据可变
@@ -120,7 +121,7 @@ void draw_color()//整体颜色震动效果函数
120 system(cl); 121 system(cl);
121}</code></pre> 122}</code></pre>
122 <p>颜色震动使用方法实例:</p> 123 <p>颜色震动使用方法实例:</p>
123 <pre><code>for(i=0;i&lt;6;i++,lower+=3) 124 <pre><code class="language-c">for(i=0;i&lt;6;i++,lower+=3)
124{ 125{
125 puts(data[i+15]); 126 puts(data[i+15]);
126 for(j=0;j&lt;wait;j++) 127 for(j=0;j&lt;wait;j++)
@@ -194,7 +195,7 @@ void draw_heart(int wait)//心形设计函数,传入参数为0即可
194 } 195 }
195}</code></pre> 196}</code></pre>
196 <h1 id="给代码加行号的代码">给代码加行号的代码</h1> 197 <h1 id="给代码加行号的代码">给代码加行号的代码</h1>
197 <pre><code>#include&lt;stdio.h&gt; 198 <pre><code class="language-c">#include&lt;stdio.h&gt;
198 199
199int main(void) 200int main(void)
200{ 201{
diff --git a/code/cpppp.html b/code/cpppp.html
index 2bfb80e..4bb0502 100644
--- a/code/cpppp.html
+++ b/code/cpppp.html
@@ -7,23 +7,22 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>cpppp快速基础</title> 8 <title>cpppp快速基础</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">C++ Primer Plus快速基础</p> 16 <header id="title-block-header">
17 <p class="title">C++ Primer Plus<br>快速基础</p>
18 </header>
18 <h1 id="第二章">第二章</h1> 19 <h1 id="第二章">第二章</h1>
19 <ul> 20 <ul>
20 <li>在 C++中,<span 21 <li>在 C++中,<code>main</code>函数括号中使用<code>void</code>关键字表明拒绝任何参数,而空括号表示对是否接受参数保持沉默。</li>
21 class="math inline"><em>m</em><em>a</em><em>i</em><em>n</em></span>函数括号中使用<code>void</code>关键字表明拒绝任何参数,而空括号表示对是否接受参数保持沉默。
22 </li>
23 <li>连续赋值将从右向左进行。</li> 22 <li>连续赋值将从右向左进行。</li>
24 <li>输出拼接长字符串可以如下书写:</li> 23 <li>输出拼接长字符串可以如下书写:</li>
25 </ul> 24 </ul>
26 <pre><code> //当代码很长而追求风格的时候,这样操作。 25 <pre><code class="language-cpp"> //当代码很长而追求风格的时候,这样操作。
27cout &lt;&lt; &quot;1234567&quot; 26cout &lt;&lt; &quot;1234567&quot;
28 &lt;&lt; &quot;7654321&quot; 27 &lt;&lt; &quot;7654321&quot;
29 &lt;&lt; endl;</code></pre> 28 &lt;&lt; endl;</code></pre>
@@ -34,7 +33,7 @@ cout &lt;&lt; &quot;1234567&quot;
34 <ul> 33 <ul>
35 <li>数据输入/常数可以以十进制、十六进制、二进制书写。</li> 34 <li>数据输入/常数可以以十进制、十六进制、二进制书写。</li>
36 </ul> 35 </ul>
37 <pre><code>#include &lt;iostream&gt; 36 <pre><code class="language-cpp">#include &lt;iostream&gt;
38using namespace std; 37using namespace std;
39 38
40int main() 39int main()
@@ -46,7 +45,7 @@ int main()
46 <ul> 45 <ul>
47 <li><code>cout</code>提供控制符以八进制、十进制与十六进制显示整数。</li> 46 <li><code>cout</code>提供控制符以八进制、十进制与十六进制显示整数。</li>
48 </ul> 47 </ul>
49 <pre><code>#include &lt;iostream&gt; 48 <pre><code class="language-cpp">#include &lt;iostream&gt;
50using namespace std; 49using namespace std;
51int main() 50int main()
52{ 51{
@@ -94,7 +93,7 @@ int main()
94 </li> 93 </li>
95 <li><kbd>get</kbd>与<kbd>getline</kbd>,二者使用方式基本相同,只是前者继承 cin 的特性,不会读取换行符后再从字符串中删除,而是把换行符留在输入队列中。</li> 94 <li><kbd>get</kbd>与<kbd>getline</kbd>,二者使用方式基本相同,只是前者继承 cin 的特性,不会读取换行符后再从字符串中删除,而是把换行符留在输入队列中。</li>
96 </ul> 95 </ul>
97 <pre><code>/*在没有任何参数的情况下 96 <pre><code class="language-cpp">/*在没有任何参数的情况下
98 *cin.get()会读取下一个字符,即使是换行符 97 *cin.get()会读取下一个字符,即使是换行符
99 *因此可用以清空*/ 98 *因此可用以清空*/
100cin.get(name , ArSize);// read first line 99cin.get(name , ArSize);// read first line
@@ -122,7 +121,7 @@ cin.get(dessert. Arsize ) ;// read second line
122 </ul> 121 </ul>
123 </li> 122 </li>
124 </ul> 123 </ul>
125 <pre><code>#include &lt;iostream&gt; 124 <pre><code class="language-cpp">#include &lt;iostream&gt;
126using namespace std; 125using namespace std;
127 126
128struct student 127struct student
@@ -160,7 +159,7 @@ int main()
160 </blockquote> 159 </blockquote>
161 <h2 id="共用体">共用体</h2> 160 <h2 id="共用体">共用体</h2>
162 <p>举例:一个小商品目录,一些商品 id 为字符串,另一些为数字:</p> 161 <p>举例:一个小商品目录,一些商品 id 为字符串,另一些为数字:</p>
163 <pre><code>union id 162 <pre><code class="language-cpp">union id
164{ 163{
165 long id_num; 164 long id_num;
166 char id_str[32]; 165 char id_str[32];
@@ -172,7 +171,7 @@ struct good
172 id id_val; 171 id id_val;
173};</code></pre> 172};</code></pre>
174 <p>同时,有匿名共用体:</p> 173 <p>同时,有匿名共用体:</p>
175 <pre><code> 174 <pre><code class="language-cpp">
176struct good 175struct good
177{ 176{
178 char brand[20]; 177 char brand[20];
@@ -237,7 +236,7 @@ struct good
237 </ul> 236 </ul>
238 </li> 237 </li>
239 </ul> 238 </ul>
240 <pre><code>#include &lt;array&gt; 239 <pre><code class="language-cpp">#include &lt;array&gt;
241using namespace std; 240using namespace std;
242 241
243int main() 242int main()
@@ -261,7 +260,7 @@ int main()
261 <li>写在前边,则变量先加/减,再使用</li> 260 <li>写在前边,则变量先加/减,再使用</li>
262 <li>避免使用不完整的表达式</li> 261 <li>避免使用不完整的表达式</li>
263 </ul> 262 </ul>
264 <pre><code> //完整的表达式 263 <pre><code class="language-cpp"> //完整的表达式
265 i=0 264 i=0
266 while(i++&lt;10) 265 while(i++&lt;10)
267 { 266 {
@@ -289,7 +288,7 @@ int main()
289 <h3 id="指针与递增递减">指针与递增递减</h3> 288 <h3 id="指针与递增递减">指针与递增递减</h3>
290 <p>递增递减作用不赘。</p> 289 <p>递增递减作用不赘。</p>
291 <p>前缀递增递减与解引用运算优先级相同,因而从内向外解释:</p> 290 <p>前缀递增递减与解引用运算优先级相同,因而从内向外解释:</p>
292 <pre><code> int a[2]={1,2},*pt=a; 291 <pre><code class="language-cpp"> int a[2]={1,2},*pt=a;
293 cout&lt;&lt;*++pt&lt;&lt;*(++pt)&lt;&lt;endl; 292 cout&lt;&lt;*++pt&lt;&lt;*(++pt)&lt;&lt;endl;
294 //输出结果,二者相等,即*++pt先执行递增,而后经过顺序点,再解引用,实际为a[1]=2</code></pre> 293 //输出结果,二者相等,即*++pt先执行递增,而后经过顺序点,再解引用,实际为a[1]=2</code></pre>
295 <p>后缀递增递减优先级高于解引用,因而*pt++结果与上亦同。</p> 294 <p>后缀递增递减优先级高于解引用,因而*pt++结果与上亦同。</p>
@@ -298,7 +297,7 @@ int main()
298 <blockquote> 297 <blockquote>
299 <p>普通赋值运算式的值为右值。</p> 298 <p>普通赋值运算式的值为右值。</p>
300 </blockquote> 299 </blockquote>
301 <pre><code>#include&lt;iostream&gt; 300 <pre><code class="language-cpp">#include&lt;iostream&gt;
302using namespace std; 301using namespace std;
303int main() 302int main()
304{ 303{
@@ -311,7 +310,7 @@ int main()
311}</code></pre> 310}</code></pre>
312 <h2 id="循环">循环</h2> 311 <h2 id="循环">循环</h2>
313 <p><kbd>for</kbd>循环与<kbd>while</kbd>循环的本质是相同的:</p> 312 <p><kbd>for</kbd>循环与<kbd>while</kbd>循环的本质是相同的:</p>
314 <pre><code>for(init-expression; test-expression; update-expression) 313 <pre><code class="language-cpp">for(init-expression; test-expression; update-expression)
315{ 314{
316 statements 315 statements
317} 316}
@@ -404,7 +403,7 @@ while (test-expression)
404 <h2 id="字符函数库">字符函数库</h2> 403 <h2 id="字符函数库">字符函数库</h2>
405 <p>cctype(C 语言中的 ctype.h)可以用来确定字符是否为大/小写字母、数字、标点等。其优点在于更简单、更通用(字母、数字之类在不同的编码方式之下不一定都像 ASCII 404 <p>cctype(C 语言中的 ctype.h)可以用来确定字符是否为大/小写字母、数字、标点等。其优点在于更简单、更通用(字母、数字之类在不同的编码方式之下不一定都像 ASCII
406 中一样的连续分布)。包含的函数如下:</p> 405 中一样的连续分布)。包含的函数如下:</p>
407 <pre><code>namespace std { 406 <pre><code class="language-cpp">namespace std {
408 int isalnum(int c); 407 int isalnum(int c);
409 int isalpha(int c); 408 int isalpha(int c);
410 int isblank(int c); 409 int isblank(int c);
@@ -425,7 +424,7 @@ while (test-expression)
425 <ul> 424 <ul>
426 <li>函数原型:说明函数名、形参类型/名称、返回值类型 425 <li>函数原型:说明函数名、形参类型/名称、返回值类型
427 <ul> 426 <ul>
428 <li>其实就是<span class="math inline"><em>m</em><em>a</em><em>i</em><em>n</em>()</span>之前的函数声明</li> 427 <li>其实就是<code>main()</code>之前的函数声明</li>
429 <li>函数原型中的函数特征标(参数列表)可以省略标识符(形参名称)而只是指出其类型</li> 428 <li>函数原型中的函数特征标(参数列表)可以省略标识符(形参名称)而只是指出其类型</li>
430 </ul> 429 </ul>
431 </li> 430 </li>
@@ -437,7 +436,7 @@ while (test-expression)
437 <li>函数定义:函数的本体实现</li> 436 <li>函数定义:函数的本体实现</li>
438 </ul> 437 </ul>
439 <h2 id="函数与数组">函数与数组</h2> 438 <h2 id="函数与数组">函数与数组</h2>
440 <pre><code>//函数定义 439 <pre><code class="language-cpp">//函数定义
441int sum_arr(int arr[], int n);//对数组中元素求和 440int sum_arr(int arr[], int n);//对数组中元素求和
442 441
443//函数调用 442//函数调用
@@ -447,7 +446,7 @@ int sum=sum_arr(a,10);</code></pre>
447 <p><strong>原因:</strong>C++与 C 446 <p><strong>原因:</strong>C++与 C
448 一样,将数组名视为指针,指向第一个元素地址,对应元素大小为单个元素大小,详前。(相比之下,<kbd>&amp;a</kbd>虽然也是指向首地址,但大小是整块数组的大小。)因而第一个形参实际是<kbd>int* 447 一样,将数组名视为指针,指向第一个元素地址,对应元素大小为单个元素大小,详前。(相比之下,<kbd>&amp;a</kbd>虽然也是指向首地址,但大小是整块数组的大小。)因而第一个形参实际是<kbd>int*
449 arr</kbd>,即定义应当为:</p> 448 arr</kbd>,即定义应当为:</p>
450 <pre><code>int sum_arr(int* arr, int n);</code></pre> 449 <pre><code class="language-cpp">int sum_arr(int* arr, int n);</code></pre>
451 <p>这证明两种形参声明同时正确。<strong>在 C++中,<kbd>int* arr</kbd>与<kbd>int 450 <p>这证明两种形参声明同时正确。<strong>在 C++中,<kbd>int* arr</kbd>与<kbd>int
452 arr[]</kbd>当且仅当出现在函数头或函数原型的时候,含义才相同</strong>。它们都意味着 arr 是一个<kbd>int*</kbd>。</p> 451 arr[]</kbd>当且仅当出现在函数头或函数原型的时候,含义才相同</strong>。它们都意味着 arr 是一个<kbd>int*</kbd>。</p>
453 <h2 id="使用数组区间的函数">使用数组区间的函数</h2> 452 <h2 id="使用数组区间的函数">使用数组区间的函数</h2>
@@ -457,7 +456,7 @@ int sum=sum_arr(a,10);</code></pre>
457 <h2 id="指针与-const">指针与 const</h2> 456 <h2 id="指针与-const">指针与 const</h2>
458 <h3 id="将-const-用于指针">将 const 用于指针</h3> 457 <h3 id="将-const-用于指针">将 const 用于指针</h3>
459 <ul> 458 <ul>
460 <li>指针指向<span class="math inline"><em>c</em><em>o</em><em>n</em><em>s</em><em>t</em></span>常量,防止修改</li> 459 <li>指针指向<code>const</code>常量,防止修改</li>
461 <li>传参将指针本身声明为常量,防止修改指针指向的位置,但可以修改内容</li> 460 <li>传参将指针本身声明为常量,防止修改指针指向的位置,但可以修改内容</li>
462 </ul> 461 </ul>
463 <p>优点:</p> 462 <p>优点:</p>
@@ -465,7 +464,7 @@ int sum=sum_arr(a,10);</code></pre>
465 <li>避免无意见修改数据导致错误</li> 464 <li>避免无意见修改数据导致错误</li>
466 <li><kbd>const</kbd>可使函数能处理 const 与非 const 实参,否则只能接收后者。</li> 465 <li><kbd>const</kbd>可使函数能处理 const 与非 const 实参,否则只能接收后者。</li>
467 </ul> 466 </ul>
468 <pre><code>//只能防止修改pt指向的值,但pt本身可以改成新地址 467 <pre><code class="language-cpp">//只能防止修改pt指向的值,但pt本身可以改成新地址
469int age=39; 468int age=39;
470const int* pt=&amp;age; 469const int* pt=&amp;age;
471int sage=80; 470int sage=80;
@@ -478,7 +477,7 @@ int* const finger=&amp;sloth;//指向int的const指针
478//前者如上例,不能修改内容,但能重新指向 477//前者如上例,不能修改内容,但能重新指向
479//后者则不能重新指向,但可以修改内容</code></pre> 478//后者则不能重新指向,但可以修改内容</code></pre>
480 <h2 id="二维数组作参数">二维数组作参数</h2> 479 <h2 id="二维数组作参数">二维数组作参数</h2>
481 <pre><code>int sum(int (*arr)[4], int size); 480 <pre><code class="language-cpp">int sum(int (*arr)[4], int size);
482//等价于以下 481//等价于以下
483int aum(int arr[][4], int size); 482int aum(int arr[][4], int size);
484 483
@@ -513,7 +512,7 @@ int sum(int *arr[4], int size);</code></pre>
513 <li>使用函数指针来调用函数</li> 512 <li>使用函数指针来调用函数</li>
514 </ul> 513 </ul>
515 <p>例程如下:</p> 514 <p>例程如下:</p>
516 <pre><code>#include &lt;iostream&gt; 515 <pre><code class="language-cpp">#include &lt;iostream&gt;
517#include &lt;string&gt; 516#include &lt;string&gt;
518using namespace std; 517using namespace std;
519 518
@@ -549,7 +548,7 @@ int main()
549 <p>我又要骂人了,这什么东西,类型声明这么复杂?不用了不用了,享受不来。</p> 548 <p>我又要骂人了,这什么东西,类型声明这么复杂?不用了不用了,享受不来。</p>
550 <p>没事,C++11 还有个特性叫<kbd>auto</kbd>,不是么?</p> 549 <p>没事,C++11 还有个特性叫<kbd>auto</kbd>,不是么?</p>
551 <p>上边的例程可以被改写成如下形式:</p> 550 <p>上边的例程可以被改写成如下形式:</p>
552 <pre><code>#include &lt;iostream&gt; 551 <pre><code class="language-cpp">#include &lt;iostream&gt;
553#include &lt;string&gt; 552#include &lt;string&gt;
554using namespace std; 553using namespace std;
555 554
@@ -568,7 +567,7 @@ int main()
568}</code></pre> 567}</code></pre>
569 <p><del>这自动推断类型,多是一件美逝了!</del>让我们一起说,<strong>谢谢<kbd>auto</kbd>!</strong></p> 568 <p><del>这自动推断类型,多是一件美逝了!</del>让我们一起说,<strong>谢谢<kbd>auto</kbd>!</strong></p>
570 <p>另外,如果有若干函数返回类型和特征标都相同,都需要调用的话,何不考虑一下函数指针数组呢?更进一步地,为什么不选择创建一个指向整个函数指针数组的指针呢?</p> 569 <p>另外,如果有若干函数返回类型和特征标都相同,都需要调用的话,何不考虑一下函数指针数组呢?更进一步地,为什么不选择创建一个指向整个函数指针数组的指针呢?</p>
571 <pre><code>#include &lt;iostream&gt; 570 <pre><code class="language-cpp">#include &lt;iostream&gt;
572using namespace std; 571using namespace std;
573 572
574// 没错,函数原型可以不写形参名称的 573// 没错,函数原型可以不写形参名称的
@@ -630,7 +629,7 @@ const double *f3(int i)
630 </ul> 629 </ul>
631 <p>程序员做出内联请求时,编译器不一定同意(p.s.到底是我写代码还是编译器写代码?气抖冷!),它可能认为函数过大或者注意到有递归(众所周知,内敛这个形式不能递归的),或者有些编译器没有启用或实现内联这一功能。 630 <p>程序员做出内联请求时,编译器不一定同意(p.s.到底是我写代码还是编译器写代码?气抖冷!),它可能认为函数过大或者注意到有递归(众所周知,内敛这个形式不能递归的),或者有些编译器没有启用或实现内联这一功能。
632 </p> 631 </p>
633 <pre><code>#include &lt;iostream&gt; 632 <pre><code class="language-cpp">#include &lt;iostream&gt;
634using namespace std; 633using namespace std;
635 634
636// 这是一个内联函数 635// 这是一个内联函数
@@ -662,7 +661,7 @@ int main()
662 <p>输出表明,内联函数与普通函数一样,按值传递参数,参数为表达式则传递表达式的值。</p> 661 <p>输出表明,内联函数与普通函数一样,按值传递参数,参数为表达式则传递表达式的值。</p>
663 <p>C 语言中也可以像这样,不写函数原型,直接以函数定义充当函数原型。</p> 662 <p>C 语言中也可以像这样,不写函数原型,直接以函数定义充当函数原型。</p>
664 <h2 id="内联的原始实现c-中的define">内联的原始实现:C 中的<kbd>#define</kbd></h2> 663 <h2 id="内联的原始实现c-中的define">内联的原始实现:C 中的<kbd>#define</kbd></h2>
665 <pre><code>#include &lt;stdio.h&gt; 664 <pre><code class="language-c">#include &lt;stdio.h&gt;
666#define square(x) x*x 665#define square(x) x*x
667 666
668int main() 667int main()
@@ -674,14 +673,14 @@ int main()
674 printf(&quot;a = %lf\nb = %lf\nd = %lf\n&quot;, a, b, d); 673 printf(&quot;a = %lf\nb = %lf\nd = %lf\n&quot;, a, b, d);
675 return 0; 674 return 0;
676}</code></pre> 675}</code></pre>
677 <p>这并不是通过传递参数实现,而是通过文本替换实现的——<span class="math inline"><em>x</em></span>是“参数”的符号标记。</p> 676 <p>这并不是通过传递参数实现,而是通过文本替换实现的——<code>x</code>是“参数”的符号标记。</p>
678 <p>上例只有<span class="math inline"><em>a</em></span>输出正确,可以用括号进行改进:</p> 677 <p>上例只有<code>a</code>输出正确,可以用括号进行改进:</p>
679 <pre><code>#define square(x) ((x) * (x))</code></pre> 678 <pre><code class="language-c">#define square(x) ((x) * (x))</code></pre>
680 <p>即使如此,后两者依然输出错误,即无法实现按值传递。所以,使用内联函数应当尽可能考虑使用 C++的内联,而不是 C 的宏。</p> 679 <p>即使如此,后两者依然输出错误,即无法实现按值传递。所以,使用内联函数应当尽可能考虑使用 C++的内联,而不是 C 的宏。</p>
681 <h2 id="引用变量">引用变量</h2> 680 <h2 id="引用变量">引用变量</h2>
682 <h3 id="引用变量是什么能吃吗">引用变量是什么?能吃吗?</h3> 681 <h3 id="引用变量是什么能吃吗">引用变量是什么?能吃吗?</h3>
683 <p>引用变量是已定义变量的一个别名。话不多说,上例程。</p> 682 <p>引用变量是已定义变量的一个别名。话不多说,上例程。</p>
684 <pre><code>#include &lt;iostream&gt; 683 <pre><code class="language-cpp">#include &lt;iostream&gt;
685using namespace std; 684using namespace std;
686int main() 685int main()
687{ 686{
@@ -710,7 +709,7 @@ Addr n is 0x7ffce76ff48c</code></pre>
710 一份送到调用函数里使,即使做出了更改也不会直接影响原函数里的值,除非用返回值将其返回。有时候一个函数本来有自己需要返回的东西,又想把这个量修改了,就不好办了(用<kbd>pair</kbd>或者结构体,多少有点麻烦,还要为此创建一个类型)。这时候就可以考虑引用变量。 709 一份送到调用函数里使,即使做出了更改也不会直接影响原函数里的值,除非用返回值将其返回。有时候一个函数本来有自己需要返回的东西,又想把这个量修改了,就不好办了(用<kbd>pair</kbd>或者结构体,多少有点麻烦,还要为此创建一个类型)。这时候就可以考虑引用变量。
711 </p> 710 </p>
712 <h3 id="c-风格字符串作-string-对象引用参数">C-风格字符串作 string 对象引用参数</h3> 711 <h3 id="c-风格字符串作-string-对象引用参数">C-风格字符串作 string 对象引用参数</h3>
713 <pre><code>#include &lt;iostream&gt; 712 <pre><code class="language-cpp">#include &lt;iostream&gt;
714using namespace std; 713using namespace std;
715 714
716const string &amp;fuck(string &amp;s1, const string &amp;s2) 715const string &amp;fuck(string &amp;s1, const string &amp;s2)
@@ -763,7 +762,7 @@ int main()
763 </ul> 762 </ul>
764 <h3 id="默认参数">默认参数</h3> 763 <h3 id="默认参数">默认参数</h3>
765 <p>默认参数指函数调用中省略实参时自动使用的实参值。</p> 764 <p>默认参数指函数调用中省略实参时自动使用的实参值。</p>
766 <pre><code>// 一个使用默认参数的例子 765 <pre><code class="language-cpp">// 一个使用默认参数的例子
767#include &lt;iostream&gt; 766#include &lt;iostream&gt;
768using namespace std; 767using namespace std;
769int add(int a, int b = 1, int c = 2) 768int add(int a, int b = 1, int c = 2)
@@ -780,7 +779,7 @@ int main()
780 <p><strong>对于带参数列表(有形参)的函数,必须从右向左添加默认值,即所有有默认值的形参必须在所有无默认值形参的右边。使用时,传递的实参被从左到右依次赋给形参,而不得跳过任何形参。</strong></p> 779 <p><strong>对于带参数列表(有形参)的函数,必须从右向左添加默认值,即所有有默认值的形参必须在所有无默认值形参的右边。使用时,传递的实参被从左到右依次赋给形参,而不得跳过任何形参。</strong></p>
781 <h3 id="函数重载">函数重载</h3> 780 <h3 id="函数重载">函数重载</h3>
782 <p>函数重载指可以有多个同名函数,它们<strong>以参数列表(形参,不包括返回值类型)为区别</strong>。C++使用上下文来确定要使用的重载函数版本。</p> 781 <p>函数重载指可以有多个同名函数,它们<strong>以参数列表(形参,不包括返回值类型)为区别</strong>。C++使用上下文来确定要使用的重载函数版本。</p>
783 <pre><code>//一个函数重载示例程序 782 <pre><code class="language-cpp">//一个函数重载示例程序
784#include &lt;iostream&gt; 783#include &lt;iostream&gt;
785using namespace std; 784using namespace std;
786 785
@@ -810,7 +809,7 @@ int main()
810 <blockquote> 809 <blockquote>
811 <p>少扯淡,一个代码就明白了</p> 810 <p>少扯淡,一个代码就明白了</p>
812 </blockquote> 811 </blockquote>
813 <pre><code>//一个使用函数模板的历次 812 <pre><code class="language-cpp">//一个使用函数模板的历次
814#include &lt;iostream&gt; 813#include &lt;iostream&gt;
815using namespace std; 814using namespace std;
816 815
@@ -840,7 +839,7 @@ int main()
840 <p>常见用法为<strong>将模板放在头文件中,在需要使用的地方包含头文件</strong>。</p> 839 <p>常见用法为<strong>将模板放在头文件中,在需要使用的地方包含头文件</strong>。</p>
841 <h3 id="模板重载">模板重载</h3> 840 <h3 id="模板重载">模板重载</h3>
842 <p>模板满足了对不同类型使用同一种算法函数的需求,但并非所有类型都是用完全相同的算法。为满足此种需求,可以像重载常规函数一样重载模板定义,仍然需要满足参数列表不同便是了。</p> 841 <p>模板满足了对不同类型使用同一种算法函数的需求,但并非所有类型都是用完全相同的算法。为满足此种需求,可以像重载常规函数一样重载模板定义,仍然需要满足参数列表不同便是了。</p>
843 <pre><code>template&lt;class T&gt;//一个模板 842 <pre><code class="language-cpp">template&lt;class T&gt;//一个模板
844void swap(T &amp;a,T &amp;b); 843void swap(T &amp;a,T &amp;b);
845 844
846template&lt;class T&gt;//另一个模板 845template&lt;class T&gt;//另一个模板
@@ -909,7 +908,7 @@ void swap(T* a,T* b,int n);</code></pre>
909 </tbody> 908 </tbody>
910 </table> 909 </table>
911 </blockquote> 910 </blockquote>
912 <pre><code>//调用函数 911 <pre><code class="language-cpp">//调用函数
913may(&#39;B&#39;); 912may(&#39;B&#39;);
914 913
915//所有同名 914//所有同名
@@ -941,7 +940,7 @@ void may(T *); // 7</code></pre>
941 <h2 id="头文件">头文件</h2> 940 <h2 id="头文件">头文件</h2>
942 <p>C++文件操作头文件 fstream,也就是“文件流”。</p> 941 <p>C++文件操作头文件 fstream,也就是“文件流”。</p>
943 <h2 id="对象声明">对象声明</h2> 942 <h2 id="对象声明">对象声明</h2>
944 <pre><code>ofstream ofs;//执行写操作 943 <pre><code class="language-cpp">ofstream ofs;//执行写操作
945ifstream ifs;//执行读操作 944ifstream ifs;//执行读操作
946fstream file;//读写都可以</code></pre> 945fstream file;//读写都可以</code></pre>
947 <h2 id="文件打开关闭">文件打开、关闭</h2> 946 <h2 id="文件打开关闭">文件打开、关闭</h2>
@@ -997,7 +996,7 @@ fstream file;//读写都可以</code></pre>
997 <h2 id="文本文件">文本文件</h2> 996 <h2 id="文本文件">文本文件</h2>
998 <h3 id="读取">读取</h3> 997 <h3 id="读取">读取</h3>
999 <p>五种方法。例程如下:</p> 998 <p>五种方法。例程如下:</p>
1000 <pre><code>#include &lt;iostream&gt; 999 <pre><code class="language-cpp">#include &lt;iostream&gt;
1001#include &lt;string&gt; 1000#include &lt;string&gt;
1002#include &lt;fstream&gt; 1001#include &lt;fstream&gt;
1003using namespace std; 1002using namespace std;
@@ -1043,7 +1042,7 @@ int main()
1043}</code></pre> 1042}</code></pre>
1044 <h3 id="文件写入">文件写入</h3> 1043 <h3 id="文件写入">文件写入</h3>
1045 <p>格式如下: <code>对象名 &lt;&lt; 写入的内容;</code> 如需换行,在写入内容后加 endl 即可。例程如下:</p> 1044 <p>格式如下: <code>对象名 &lt;&lt; 写入的内容;</code> 如需换行,在写入内容后加 endl 即可。例程如下:</p>
1046 <pre><code>#include &lt;iostream&gt; 1045 <pre><code class="language-cpp">#include &lt;iostream&gt;
1047#include &lt;string&gt; 1046#include &lt;string&gt;
1048#include &lt;fstream&gt; 1047#include &lt;fstream&gt;
1049using namespace std; 1048using namespace std;
@@ -1071,7 +1070,7 @@ int main()
1071 <h3 id="读取-1">读取</h3> 1070 <h3 id="读取-1">读取</h3>
1072 <p>利用流对象调用成员函数<code>read</code>。 函数原型:<code>istream&amp; read(char* buffer, int len)</code> 参数解释:字符指针 buffer 1071 <p>利用流对象调用成员函数<code>read</code>。 函数原型:<code>istream&amp; read(char* buffer, int len)</code> 参数解释:字符指针 buffer
1073 指向内存中一段存储空间。len 是读写的字节数。 例程如下:</p> 1072 指向内存中一段存储空间。len 是读写的字节数。 例程如下:</p>
1074 <pre><code>#include &lt;iostream&gt; 1073 <pre><code class="language-cpp">#include &lt;iostream&gt;
1075#include &lt;string&gt; 1074#include &lt;string&gt;
1076#include &lt;fstream&gt; 1075#include &lt;fstream&gt;
1077using namespace std; 1076using namespace std;
@@ -1092,7 +1091,7 @@ int main()
1092 <h3 id="写入">写入</h3> 1091 <h3 id="写入">写入</h3>
1093 <p>使用流对象成员函数<code>write</code>。 函数原型:<code>ostream&amp; write(const char* buffer, int len)</code> 参数解释:字符指针 1092 <p>使用流对象成员函数<code>write</code>。 函数原型:<code>ostream&amp; write(const char* buffer, int len)</code> 参数解释:字符指针
1094 buffer 指向内存中一段存储空间。len 是读写的字节数。 例程如下:</p> 1093 buffer 指向内存中一段存储空间。len 是读写的字节数。 例程如下:</p>
1095 <pre><code>#include &lt;iostream&gt; 1094 <pre><code class="language-cpp">#include &lt;iostream&gt;
1096#include &lt;string&gt; 1095#include &lt;string&gt;
1097#include &lt;fstream&gt; 1096#include &lt;fstream&gt;
1098using namespace std; 1097using namespace std;
diff --git a/code/cpppp.md b/code/cpppp.md
index 50f5cba..046fcad 100644
--- a/code/cpppp.md
+++ b/code/cpppp.md
@@ -1,6 +1,6 @@
1# 第二章 1# 第二章
2 2
3- 在 C++中,$main$函数括号中使用`void`关键字表明拒绝任何参数,而空括号表示对是否接受参数保持沉默。 3- 在 C++中,`main`函数括号中使用`void`关键字表明拒绝任何参数,而空括号表示对是否接受参数保持沉默。
4- 连续赋值将从右向左进行。 4- 连续赋值将从右向左进行。
5- 输出拼接长字符串可以如下书写: 5- 输出拼接长字符串可以如下书写:
6 6
@@ -410,7 +410,7 @@ namespace std {
410## 基础知识 410## 基础知识
411 411
412- 函数原型:说明函数名、形参类型/名称、返回值类型 412- 函数原型:说明函数名、形参类型/名称、返回值类型
413 - 其实就是$main()$之前的函数声明 413 - 其实就是`main()`之前的函数声明
414 - 函数原型中的函数特征标(参数列表)可以省略标识符(形参名称)而只是指出其类型 414 - 函数原型中的函数特征标(参数列表)可以省略标识符(形参名称)而只是指出其类型
415 415
416> ~其实就是那个二锅头,兑的那个白开水~ 416> ~其实就是那个二锅头,兑的那个白开水~
@@ -446,7 +446,7 @@ int sum_arr(int* arr, int n);
446 446
447### 将 const 用于指针 447### 将 const 用于指针
448 448
449- 指针指向$const$常量,防止修改 449- 指针指向`const`常量,防止修改
450- 传参将指针本身声明为常量,防止修改指针指向的位置,但可以修改内容 450- 传参将指针本身声明为常量,防止修改指针指向的位置,但可以修改内容
451 451
452优点: 452优点:
@@ -693,9 +693,9 @@ int main()
693} 693}
694``` 694```
695 695
696这并不是通过传递参数实现,而是通过文本替换实现的——$x$是“参数”的符号标记。 696这并不是通过传递参数实现,而是通过文本替换实现的——`x`是“参数”的符号标记。
697 697
698上例只有$a$输出正确,可以用括号进行改进: 698上例只有`a`输出正确,可以用括号进行改进:
699 699
700```c 700```c
701#define square(x) ((x) * (x)) 701#define square(x) ((x) * (x))
@@ -981,7 +981,7 @@ C++文件操作头文件 fstream,也就是“文件流”。
981 981
982## 对象声明 982## 对象声明
983 983
984```C++ 984```cpp
985ofstream ofs;//执行写操作 985ofstream ofs;//执行写操作
986ifstream ifs;//执行读操作 986ifstream ifs;//执行读操作
987fstream file;//读写都可以 987fstream file;//读写都可以
@@ -1021,7 +1021,7 @@ fstream file;//读写都可以
1021 1021
1022五种方法。例程如下: 1022五种方法。例程如下:
1023 1023
1024```C++ 1024```cpp
1025#include <iostream> 1025#include <iostream>
1026#include <string> 1026#include <string>
1027#include <fstream> 1027#include <fstream>
@@ -1074,7 +1074,7 @@ int main()
1074`对象名 << 写入的内容;` 1074`对象名 << 写入的内容;`
1075如需换行,在写入内容后加 endl 即可。例程如下: 1075如需换行,在写入内容后加 endl 即可。例程如下:
1076 1076
1077```C++ 1077```cpp
1078#include <iostream> 1078#include <iostream>
1079#include <string> 1079#include <string>
1080#include <fstream> 1080#include <fstream>
diff --git a/code/linux/aliyun_cloud.html b/code/linux/aliyun_cloud.html
index f430bae..aa2fd3a 100644
--- a/code/linux/aliyun_cloud.html
+++ b/code/linux/aliyun_cloud.html
@@ -7,15 +7,15 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>我的免费云服</title> 8 <title>我的免费云服</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">我的免费云服</p> 16 <header id="title-block-header">
18 <p class="metto">谁不想要个免费的云服呢?</p> 17 <p class="title">我的免费云服</p>
18 </header>
19 <h1 id="阿里云服务器">阿里云服务器</h1> 19 <h1 id="阿里云服务器">阿里云服务器</h1>
20 <p>自从开始做自己的网页,越来越发现<strong>干啥都需要一个服务器</strong>。先是和大佬<a 20 <p>自从开始做自己的网页,越来越发现<strong>干啥都需要一个服务器</strong>。先是和大佬<a
21 href="https://user.qzone.qq.com/2506370693">黄四郎</a>一起在自己的电脑上搞服务,利用 VSCode 插件<a 21 href="https://user.qzone.qq.com/2506370693">黄四郎</a>一起在自己的电脑上搞服务,利用 VSCode 插件<a
@@ -40,7 +40,7 @@
40 <h2 id="创建新用户">创建新用户</h2> 40 <h2 id="创建新用户">创建新用户</h2>
41 <p>众所周知,<strong>为了安全起见,我们需要一个非 root 但具有 sudo 41 <p>众所周知,<strong>为了安全起见,我们需要一个非 root 但具有 sudo
42 权限的用户来进行日常操作</strong>。这里我创建了一个名为<kbd>player</kbd>的用户并设置了密码,然后将其加入 sudo 组。</p> 42 权限的用户来进行日常操作</strong>。这里我创建了一个名为<kbd>player</kbd>的用户并设置了密码,然后将其加入 sudo 组。</p>
43 <pre><code># 创建新用户,-m参数创建用户,-d参数手动指定用户的主目录 43 <pre><code class="language-bash"># 创建新用户,-m参数创建用户,-d参数手动指定用户的主目录
44sudo useradd -m player -d /home/player 44sudo useradd -m player -d /home/player
45# 如需指定默认shell,可以加上-s参数。 45# 如需指定默认shell,可以加上-s参数。
46# 这里需要注意,一般意义上bash是sh的超集,因此sh能干的bash一般都能干,所以这里一般需要指定为bash。 46# 这里需要注意,一般意义上bash是sh的超集,因此sh能干的bash一般都能干,所以这里一般需要指定为bash。
@@ -59,7 +59,7 @@ sudo vim sudoers
59# 新开一行然后写一份一样的,把root改成player,保存退出</code></pre> 59# 新开一行然后写一份一样的,把root改成player,保存退出</code></pre>
60 <h2 id="安装软件">安装软件</h2> 60 <h2 id="安装软件">安装软件</h2>
61 <p>经历了上边的配置,现在我们拥有了一台可以正常使用的服务器。服务器是为了什么?开发!开发!开发!所以,我们需要安装一些开发所需的软件。</p> 61 <p>经历了上边的配置,现在我们拥有了一台可以正常使用的服务器。服务器是为了什么?开发!开发!开发!所以,我们需要安装一些开发所需的软件。</p>
62 <pre><code># 如需添加软件源,可以先执行下边的命令 62 <pre><code class="language-bash"># 如需添加软件源,可以先执行下边的命令
63# 备份软件源 63# 备份软件源
64sudo cp /etc/apt/sources.list /etc/apt/sources.list.old 64sudo cp /etc/apt/sources.list /etc/apt/sources.list.old
65# 修改软件源 65# 修改软件源
@@ -86,7 +86,7 @@ sudo apt install make cmake
86# 剩下需要安装的软件,可以自行搜索</code></pre> 86# 剩下需要安装的软件,可以自行搜索</code></pre>
87 <h2 id="简单美化一下命令行">简单美化一下命令行</h2> 87 <h2 id="简单美化一下命令行">简单美化一下命令行</h2>
88 <p>配到这里,我们会发现一个很操蛋的事情,“为啥命令提示符之前不显示当前用户名和当前路径嘞?这岂不是每次看路径都需要<kbd>pwd</kbd>吗?烦不烦啊!”别急,问题很好修改。</p> 88 <p>配到这里,我们会发现一个很操蛋的事情,“为啥命令提示符之前不显示当前用户名和当前路径嘞?这岂不是每次看路径都需要<kbd>pwd</kbd>吗?烦不烦啊!”别急,问题很好修改。</p>
89 <pre><code>cd ~ 89 <pre><code class="language-bash">cd ~
90vim .bashrc 90vim .bashrc
91# 找到PS1=,将其修改为PS1=&quot;\u@\h:\w\$&quot; 91# 找到PS1=,将其修改为PS1=&quot;\u@\h:\w\$&quot;
92 92
@@ -94,7 +94,7 @@ vim .bashrc
94source .bashrc</code></pre> 94source .bashrc</code></pre>
95 <p>改好之后也许还是没有变化,我就是这样的。后来在处理其它问题的时候,我发现了根本原因所在:我 TM 创建用户的时候忘了加<kbd>-s</kbd>参数,导致新用户的默认 shell 95 <p>改好之后也许还是没有变化,我就是这样的。后来在处理其它问题的时候,我发现了根本原因所在:我 TM 创建用户的时候忘了加<kbd>-s</kbd>参数,导致新用户的默认 shell
96 是<kbd>sh</kbd>而不是<kbd>bash</kbd>。所以,我们需要修改一下新用户的默认 shell。</p> 96 是<kbd>sh</kbd>而不是<kbd>bash</kbd>。所以,我们需要修改一下新用户的默认 shell。</p>
97 <pre><code># 查看当前用户的默认shell 97 <pre><code class="language-bash"># 查看当前用户的默认shell
98echo $SHELL 98echo $SHELL
99 99
100# 修改默认shell 100# 修改默认shell
@@ -102,7 +102,7 @@ sudo chsh -s /bin/bash player</code></pre>
102 <p>这时再重新加载,就会发现,一切都正常了,一切是那么美好。</p> 102 <p>这时再重新加载,就会发现,一切都正常了,一切是那么美好。</p>
103 <p>除此之外,我们也许想要调整命令行显示的用户名、路径之类内容的颜色,会想让命令行像 git bash 一样当我们进入 git 仓库的时候显示当前在什么分支。针对这两项需求,我修改了一下我的.bashrc 103 <p>除此之外,我们也许想要调整命令行显示的用户名、路径之类内容的颜色,会想让命令行像 git bash 一样当我们进入 git 仓库的时候显示当前在什么分支。针对这两项需求,我修改了一下我的.bashrc
104 文件,现在其内容如下:</p> 104 文件,现在其内容如下:</p>
105 <pre><code># ~/.bashrc: executed by bash(1) for non-login shells. 105 <pre><code class="language-bash"># ~/.bashrc: executed by bash(1) for non-login shells.
106# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc) 106# see /usr/share/doc/bash/examples/startup-files (in the package bash-doc)
107# for examples 107# for examples
108 108
@@ -254,7 +254,7 @@ export https_proxy=http://127.0.0.1:7890</code></pre>
254 <li>将上述.pem 文件移动到家目录<code>C:\用户\当前用户名</code>的<kbd>.ssh</kbd>文件夹下</li> 254 <li>将上述.pem 文件移动到家目录<code>C:\用户\当前用户名</code>的<kbd>.ssh</kbd>文件夹下</li>
255 <li>在<kbd>.ssh</kbd>文件夹下创建文件<kbd>config</kbd>,内容如下:</li> 255 <li>在<kbd>.ssh</kbd>文件夹下创建文件<kbd>config</kbd>,内容如下:</li>
256 </ul> 256 </ul>
257 <pre><code># 给服务器起的别名,这里是aliyun 257 <pre><code class="language-plaintext"># 给服务器起的别名,这里是aliyun
258Host aliyun 258Host aliyun
259# IP地址,这里以127.0.0.1代替,但真实操作需要换成服务器的公网ip,在控制台就能看到 259# IP地址,这里以127.0.0.1代替,但真实操作需要换成服务器的公网ip,在控制台就能看到
260IP 127.0.0.1 260IP 127.0.0.1
@@ -265,7 +265,7 @@ User player
265# 密钥位置 265# 密钥位置
266……</code></pre> 266……</code></pre>
267 <p>在写好之后,我们就可以在本地命令行远程 ssh 连接云服务器操作了!</p> 267 <p>在写好之后,我们就可以在本地命令行远程 ssh 连接云服务器操作了!</p>
268 <pre><code># 登陆,这里的aliyun是上边config里边起的别名 268 <pre><code class="language-bash"># 登陆,这里的aliyun是上边config里边起的别名
269ssh aliyun</code></pre> 269ssh aliyun</code></pre>
270 <h1 id="拥抱-vim">拥抱 vim</h1> 270 <h1 id="拥抱-vim">拥抱 vim</h1>
271 <p>既然我们选择了在命令行里使用,编辑文件当然是比较常用 vim 了。当然 neovim 与其他命令行编辑器也很好,但我不熟悉,请参照网上其他教程进行配置。</p> 271 <p>既然我们选择了在命令行里使用,编辑文件当然是比较常用 vim 了。当然 neovim 与其他命令行编辑器也很好,但我不熟悉,请参照网上其他教程进行配置。</p>
@@ -293,26 +293,26 @@ ssh aliyun</code></pre>
293 href="https://github.com/coder/code-server">链接</a>。官方也有安装教程,这里浅浅说几句吧。</p> 293 href="https://github.com/coder/code-server">链接</a>。官方也有安装教程,这里浅浅说几句吧。</p>
294 <h2 id="安装">安装</h2> 294 <h2 id="安装">安装</h2>
295 <p>官方提供了安装脚本,一条命令直接完成安装:</p> 295 <p>官方提供了安装脚本,一条命令直接完成安装:</p>
296 <pre><code>curl -fsSL https://code-server.dev/install.sh | sh</code></pre> 296 <pre><code class="language-bash">curl -fsSL https://code-server.dev/install.sh | sh</code></pre>
297 <p>但是我这里 curl 不知何故一直不能用,wget 也不好使,只能在 gayhub 仓库的<a 297 <p>但是我这里 curl 不知何故一直不能用,wget 也不好使,只能在 gayhub 仓库的<a
298 href="https://github.com/coder/code-server/releases">Releases</a>里找到最新版适合的安装包手动安装了。我是 298 href="https://github.com/coder/code-server/releases">Releases</a>里找到最新版适合的安装包手动安装了。我是
299 Ubuntu22.04LTS,系统架构 amd64,所以下载了对应的.deb 安装包。</p> 299 Ubuntu22.04LTS,系统架构 amd64,所以下载了对应的.deb 安装包。</p>
300 <pre><code># 本地命令行中运行 300 <pre><code class="language-bash"># 本地命令行中运行
301scp code-server-4.13.0-linux-amd64.deb aliyun:code-server-4.13.0-linux-amd64.deb</code></pre> 301scp code-server-4.13.0-linux-amd64.deb aliyun:code-server-4.13.0-linux-amd64.deb</code></pre>
302 <pre><code># 云服务器命令行中运行 302 <pre><code class="language-bash"># 云服务器命令行中运行
303 303
304# 安装 304# 安装
305sudo dpkg -i code-server-4.13.0-linux-amd64.deb</code></pre> 305sudo dpkg -i code-server-4.13.0-linux-amd64.deb</code></pre>
306 <p>默认安装目录在<code>~/.local/share/code-server</code>下。暂且不管。</p> 306 <p>默认安装目录在<code>~/.local/share/code-server</code>下。暂且不管。</p>
307 <h2 id="运行">运行</h2> 307 <h2 id="运行">运行</h2>
308 <p>安装完成后,就可以直接运行了。</p> 308 <p>安装完成后,就可以直接运行了。</p>
309 <pre><code>code-server</code></pre> 309 <pre><code class="language-bash">code-server</code></pre>
310 <p>就可以直接运行了,但是这样只能在本地浏览器运行,而我们需要的是远程运行。算了,直接上脚本!</p> 310 <p>就可以直接运行了,但是这样只能在本地浏览器运行,而我们需要的是远程运行。算了,直接上脚本!</p>
311 <pre><code>#!/bin/sh 311 <pre><code class="language-bash">#!/bin/sh
312code-server --host &quot;0.0.0.0&quot;&gt; /home/player/useful/codeserver-out.txt 2&gt;&amp;1 &amp;</code></pre> 312code-server --host &quot;0.0.0.0&quot;&gt; /home/player/useful/codeserver-out.txt 2&gt;&amp;1 &amp;</code></pre>
313 <p>其中第一条指令是设置允许外界访问,并指定了由后台运行、所有输出写进<code>/home/player/useful/codeserver.txt</code>文件中。后续均为输出信息。</p> 313 <p>其中第一条指令是设置允许外界访问,并指定了由后台运行、所有输出写进<code>/home/player/useful/codeserver.txt</code>文件中。后续均为输出信息。</p>
314 <p>初次这样设置,直接打开会有密码,密码的存储文件在<code>~/.config/code-server/config.yaml</code>中,可以直接修改,也可以使用命令行修改。比如我当前的设置为:</p> 314 <p>初次这样设置,直接打开会有密码,密码的存储文件在<code>~/.config/code-server/config.yaml</code>中,可以直接修改,也可以使用命令行修改。比如我当前的设置为:</p>
315 <pre><code>bind-addr: 127.0.0.1:8080 315 <pre><code class="language-yaml">bind-addr: 127.0.0.1:8080
316auth: password 316auth: password
317password: player 317password: player
318cert: false</code></pre> 318cert: false</code></pre>
@@ -321,7 +321,7 @@ cert: false</code></pre>
321 <h2 id="杀死">杀死</h2> 321 <h2 id="杀死">杀死</h2>
322 <p>设置好之后会需要重新启动程序,我一般选择杀死然后重新运行启动脚本。</p> 322 <p>设置好之后会需要重新启动程序,我一般选择杀死然后重新运行启动脚本。</p>
323 <p>杀死的方法:</p> 323 <p>杀死的方法:</p>
324 <pre><code>$ ps -ef | grep code-server 324 <pre><code class="language-plaintext">$ ps -ef | grep code-server
325player 2621 1 0 May29 ? 00:00:00 /usr/lib/code-server/lib/node /usr/lib/code-server --host 0.0.0.0 325player 2621 1 0 May29 ? 00:00:00 /usr/lib/code-server/lib/node /usr/lib/code-server --host 0.0.0.0
326player 2646 2621 0 May29 ? 00:03:31 /usr/lib/code-server/lib/node /usr/lib/code-server/out/node/entry 326player 2646 2621 0 May29 ? 00:03:31 /usr/lib/code-server/lib/node /usr/lib/code-server/out/node/entry
327player 3079 2646 0 May29 ? 00:00:57 /usr/lib/code-server/lib/node /usr/lib/code-server/lib/vscode/out/bootstrap-fork --type=ptyHost --logsPath /home/player/.local/share/code-server/logs/20230529T211752 327player 3079 2646 0 May29 ? 00:00:57 /usr/lib/code-server/lib/node /usr/lib/code-server/lib/vscode/out/bootstrap-fork --type=ptyHost --logsPath /home/player/.local/share/code-server/logs/20230529T211752
@@ -389,7 +389,7 @@ $ kill -9 2621</code></pre>
389 默认端口 443,都和上边 code-server 指定的端口 8080 不一样。</p> 389 默认端口 443,都和上边 code-server 指定的端口 8080 不一样。</p>
390 <p>没错,我们需要一个代理,根据访问的网址来对应到指定端口。</p> 390 <p>没错,我们需要一个代理,根据访问的网址来对应到指定端口。</p>
391 <h3 id="安装运行与常用操作">安装、运行与常用操作</h3> 391 <h3 id="安装运行与常用操作">安装、运行与常用操作</h3>
392 <pre><code>sudo apt install nginx 392 <pre><code class="language-bash">sudo apt install nginx
393# 安装完成后如果服务器重启,nginx会自动启动,手动启动命令如下 393# 安装完成后如果服务器重启,nginx会自动启动,手动启动命令如下
394sudo nginx 394sudo nginx
395 395
@@ -401,9 +401,9 @@ sudo nginx -s reload</code></pre>
401 <h3 id="ssl-证书">SSL 证书</h3> 401 <h3 id="ssl-证书">SSL 证书</h3>
402 <p>想要使用 https 方式,还需要一个 SSL 证书,每个域名一个证。腾讯云比较坑,必须花钱。这里我用的是 Certbot 免费发放的证书。</p> 402 <p>想要使用 https 方式,还需要一个 SSL 证书,每个域名一个证。腾讯云比较坑,必须花钱。这里我用的是 Certbot 免费发放的证书。</p>
403 <p>首先,下载 Certbot:</p> 403 <p>首先,下载 Certbot:</p>
404 <pre><code>sudo apt install certbot</code></pre> 404 <pre><code class="language-bash">sudo apt install certbot</code></pre>
405 <p>在申请证书之前,需要停止 nginx 的工作,如果正在运行,按照上边说的方法杀死,而后就可以申请证书辣!</p> 405 <p>在申请证书之前,需要停止 nginx 的工作,如果正在运行,按照上边说的方法杀死,而后就可以申请证书辣!</p>
406 <pre><code># 申请证书 406 <pre><code class="language-bash"># 申请证书
407sudo certbot certonly --standalone --email example@qq.com -d code.player.com 407sudo certbot certonly --standalone --email example@qq.com -d code.player.com
408 408
409# 除了使用参数方式外,也可以使用交互的方式 409# 除了使用参数方式外,也可以使用交互的方式
@@ -416,7 +416,7 @@ sudo certbot certonly</code></pre>
416 默认下载目录在<code>/etc/nginx</code>,该目录下有个<code>.conf</code>文件,但不建议直接改,建议在<code>/etc/nginx/conf.d</code>文件夹下为每个需要转发的域名添加单独的设置文件,这样方便管理和修改。运行过程中 416 默认下载目录在<code>/etc/nginx</code>,该目录下有个<code>.conf</code>文件,但不建议直接改,建议在<code>/etc/nginx/conf.d</code>文件夹下为每个需要转发的域名添加单独的设置文件,这样方便管理和修改。运行过程中
417 Nginx 会自动将该目录下所有配置文件全部加载的,不需要手动设置。</p> 417 Nginx 会自动将该目录下所有配置文件全部加载的,不需要手动设置。</p>
418 <p>在<code>/etc/nginx/conf.d</code>中,新建文件<code>vscode.conf</code>,内容如下:</p> 418 <p>在<code>/etc/nginx/conf.d</code>中,新建文件<code>vscode.conf</code>,内容如下:</p>
419 <pre><code>server 419 <pre><code class="language-nginx">server
420{ 420{
421 # 这段是一个常用的http重定向到https的方法,用了都说好 421 # 这段是一个常用的http重定向到https的方法,用了都说好
422 listen 80; 422 listen 80;
@@ -449,12 +449,12 @@ server
449 # } 449 # }
450}</code></pre> 450}</code></pre>
451 <p>编写完文件之后,需要重新加载配置文件(不必重启 Nginx):</p> 451 <p>编写完文件之后,需要重新加载配置文件(不必重启 Nginx):</p>
452 <pre><code>sudo nginx -s reload</code></pre> 452 <pre><code class="language-bash">sudo nginx -s reload</code></pre>
453 <p>再次提醒:一定记得把域名换成自己的域名、证书路径换成自己的证书路径、端口换成自己在提供服务的应用(如 code-server)中指定的端口!</p> 453 <p>再次提醒:一定记得把域名换成自己的域名、证书路径换成自己的证书路径、端口换成自己在提供服务的应用(如 code-server)中指定的端口!</p>
454 <h1 id="服务器上的文件浏览">服务器上的文件浏览</h1> 454 <h1 id="服务器上的文件浏览">服务器上的文件浏览</h1>
455 <p>我们已经学会了设置 nginx 的 webroot,但也有很多情况我们需要能在各种设备上直接地看到服务器上有哪些文件,既能方便文件传输,也能覆盖对大多数只需要看不需要改的场景。</p> 455 <p>我们已经学会了设置 nginx 的 webroot,但也有很多情况我们需要能在各种设备上直接地看到服务器上有哪些文件,既能方便文件传输,也能覆盖对大多数只需要看不需要改的场景。</p>
456 <p>python3 为我们提供了一个简单的 http 文件浏览服务,默认安装目录为<code>/usr/lib/python3.x/http/server.py</code>,一般情况下我们可以直接运行它:</p> 456 <p>python3 为我们提供了一个简单的 http 文件浏览服务,默认安装目录为<code>/usr/lib/python3.x/http/server.py</code>,一般情况下我们可以直接运行它:</p>
457 <pre><code>python3 -m http.server</code></pre> 457 <pre><code class="language-bash">python3 -m http.server</code></pre>
458 <p>但是 python 提供的这份文件存在一些问题:</p> 458 <p>但是 python 提供的这份文件存在一些问题:</p>
459 <ul> 459 <ul>
460 <li>响应头没有规定文件编码,让浏览器自己看着办,容易出现乱码</li> 460 <li>响应头没有规定文件编码,让浏览器自己看着办,容易出现乱码</li>
@@ -487,7 +487,7 @@ server
487 clash。但是每次重启系统之后,这许多服务都需要自己手动拉起的话未免太过麻烦了,所以我们需要一个在系统加载完成后就能自动以 root 身份执行的脚本。经过查询,我找到了处理办法。</p> 487 clash。但是每次重启系统之后,这许多服务都需要自己手动拉起的话未免太过麻烦了,所以我们需要一个在系统加载完成后就能自动以 root 身份执行的脚本。经过查询,我找到了处理办法。</p>
488 <p>在 Linux 系统下,开机启动一般使用的是<code>/etc/rc.local</code>文件(但也有很多发行版不再使用这种操作方式)。ubuntu20.04 系统已经默认安装了 488 <p>在 Linux 系统下,开机启动一般使用的是<code>/etc/rc.local</code>文件(但也有很多发行版不再使用这种操作方式)。ubuntu20.04 系统已经默认安装了
489 rc-local.service 服务,但是不知什么原因系统把这个服务给“隐蔽”了,所以如果不做一番操作是无法使用的。</p> 489 rc-local.service 服务,但是不知什么原因系统把这个服务给“隐蔽”了,所以如果不做一番操作是无法使用的。</p>
490 <pre><code># 以下所有命令需要root身份执行 490 <pre><code class="language-bash"># 以下所有命令需要root身份执行
491 491
492cp /usr/lib/systemd/system/rc-local.service /etc/systemd/system/ 492cp /usr/lib/systemd/system/rc-local.service /etc/systemd/system/
493# 修改rc-local.service文件,在文件末尾添加以下内容(注意删去前边的注释符): 493# 修改rc-local.service文件,在文件末尾添加以下内容(注意删去前边的注释符):
@@ -516,7 +516,7 @@ systemctl status rc-local.service
516# 文件的最后,可以用exec &amp;&gt; /var/log/rc-local.log将脚本的输出重定向到日志文件中</code></pre> 516# 文件的最后,可以用exec &amp;&gt; /var/log/rc-local.log将脚本的输出重定向到日志文件中</code></pre>
517 <p>除此之外,我们可能还需要为所有用户默认开启魔法。这个功能在开机脚本和<code>/etc/profile</code>中都无法实现,应当放在<code>/etc/environment</code>中。在其中添加以下内容: 517 <p>除此之外,我们可能还需要为所有用户默认开启魔法。这个功能在开机脚本和<code>/etc/profile</code>中都无法实现,应当放在<code>/etc/environment</code>中。在其中添加以下内容:
518 </p> 518 </p>
519 <pre><code>PATH=&quot;/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin&quot; 519 <pre><code class="language-plaintext">PATH=&quot;/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin&quot;
520http_proxy=http://127.0.0.1:7890 520http_proxy=http://127.0.0.1:7890
521https_proxy=http://127.0.0.1:7890 521https_proxy=http://127.0.0.1:7890
522no_proxy=127.0.0.1,localhost 522no_proxy=127.0.0.1,localhost
diff --git a/code/linux/aliyun_cloud.md b/code/linux/aliyun_cloud.md
index d059571..9eea6f3 100644
--- a/code/linux/aliyun_cloud.md
+++ b/code/linux/aliyun_cloud.md
@@ -498,7 +498,7 @@ Nginx 默认下载目录在`/etc/nginx`,该目录下有个`.conf`文件,但
498 498
499在`/etc/nginx/conf.d`中,新建文件`vscode.conf`,内容如下: 499在`/etc/nginx/conf.d`中,新建文件`vscode.conf`,内容如下:
500 500
501```conf 501```nginx
502server 502server
503{ 503{
504 # 这段是一个常用的http重定向到https的方法,用了都说好 504 # 这段是一个常用的http重定向到https的方法,用了都说好
diff --git a/code/linux/gitserver.html b/code/linux/gitserver.html
index 8c97999..40c3cb8 100644
--- a/code/linux/gitserver.html
+++ b/code/linux/gitserver.html
@@ -7,14 +7,15 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>自己的 git 托管</title> 8 <title>自己的 git 托管</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">自己的 git 托管</p> 16 <header id="title-block-header">
17 <p class="title">自己的 git 托管</p>
18 </header>
18 <!-- git 远程存储 --> 19 <!-- git 远程存储 -->
19 <blockquote> 20 <blockquote>
20 <p>争名夺利几时休,早起迟眠不自由。</p> 21 <p>争名夺利几时休,早起迟眠不自由。</p>
@@ -49,13 +50,13 @@
49 <p>首先,本方法要求有一个本地 git 存储库,并且已经有 commit。如果是本地新建的仓库,需要先有一个 commit,然后继续操作。这个 commit 50 <p>首先,本方法要求有一个本地 git 存储库,并且已经有 commit。如果是本地新建的仓库,需要先有一个 commit,然后继续操作。这个 commit
50 可以用编写<code>.gitignore</code>或者<code>push.sh</code>等不甚重要的文件来凑数。</p> 51 可以用编写<code>.gitignore</code>或者<code>push.sh</code>等不甚重要的文件来凑数。</p>
51 <h2 id="远程仓库">远程仓库</h2> 52 <h2 id="远程仓库">远程仓库</h2>
52 <pre><code># 创建远程仓库,这里也叫test吧 53 <pre><code class="language-bash"># 创建远程仓库,这里也叫test吧
53ssh git@127.0.0.1 git init --bare test.git</code></pre> 54ssh git@127.0.0.1 git init --bare test.git</code></pre>
54 <p>注意,本处指明的 git 为远程用户名,127.0.0.1 代表云服务器的公网 ip,test.git 55 <p>注意,本处指明的 git 为远程用户名,127.0.0.1 代表云服务器的公网 ip,test.git
55 为远程仓库名。使用的时候都需要换成自己的。如果仓库不想直接存储在用户目录下,需要指出其存储路径,如<code>code/fuck/test.git</code></p> 56 为远程仓库名。使用的时候都需要换成自己的。如果仓库不想直接存储在用户目录下,需要指出其存储路径,如<code>code/fuck/test.git</code></p>
56 <h2 id="本地与远程连接">本地与远程连接</h2> 57 <h2 id="本地与远程连接">本地与远程连接</h2>
57 <p>本地和远程都有了,下一步就是建立联系了。</p> 58 <p>本地和远程都有了,下一步就是建立联系了。</p>
58 <pre><code># 本地添加远程库信息 59 <pre><code class="language-bash"># 本地添加远程库信息
59git remote add origin git@127.0.0.1:test.git 60git remote add origin git@127.0.0.1:test.git
60 61
61# 此时尚不能直接推送,因为并未指定上游对应分支,需要指定 62# 此时尚不能直接推送,因为并未指定上游对应分支,需要指定
@@ -65,7 +66,7 @@ git push --set-upstream origin master
65bash push.sh</code></pre> 66bash push.sh</code></pre>
66 <h2 id="自动化">自动化</h2> 67 <h2 id="自动化">自动化</h2>
67 <p>整体操作过程可以说比较简单了。既然如此,<strong>脚本,启动!</strong></p> 68 <p>整体操作过程可以说比较简单了。既然如此,<strong>脚本,启动!</strong></p>
68 <pre><code>#!/bin/bash 69 <pre><code class="language-bash">#!/bin/bash
69 70
70read -p &quot;Local repo name: &quot; local_name 71read -p &quot;Local repo name: &quot; local_name
71read -p &quot;Remote repo name: &quot; remote_name 72read -p &quot;Remote repo name: &quot; remote_name
@@ -136,7 +137,7 @@ echo &quot;Success!&quot;</code></pre>
136 </ul> 137 </ul>
137 <h2 id="nginx-配置与说明">nginx 配置与说明</h2> 138 <h2 id="nginx-配置与说明">nginx 配置与说明</h2>
138 <p>最初的设置是这样的:</p> 139 <p>最初的设置是这样的:</p>
139 <pre><code>server 140 <pre><code class="language-nginx">server
140{ 141{
141 # 这里用于将 http 请求重定向到 https,是一种常用的方式 142 # 这里用于将 http 请求重定向到 https,是一种常用的方式
142 listen 80; 143 listen 80;
@@ -167,7 +168,7 @@ server
167 } 168 }
168}</code></pre> 169}</code></pre>
169 <p>nginx 重新加载配置之后,我们就可以正常<code>git clone https://git.player.com/test.git</code>了。但当我们 push 时,会出现 403 错误:</p> 170 <p>nginx 重新加载配置之后,我们就可以正常<code>git clone https://git.player.com/test.git</code>了。但当我们 push 时,会出现 403 错误:</p>
170 <pre><code>$ git push 171 <pre><code class="language-bash">$ git push
171fatal: unable to access &#39;https://git.player.com/test.git/&#39;: The requested URL returned error: 403</code></pre> 172fatal: unable to access &#39;https://git.player.com/test.git/&#39;: The requested URL returned error: 403</code></pre>
172 <p>为了解决这个错误,我们可以在 <code>git-http-backend</code> 的官网文档 上找到这样的一段描述:</p> 173 <p>为了解决这个错误,我们可以在 <code>git-http-backend</code> 的官网文档 上找到这样的一段描述:</p>
173 <blockquote> 174 <blockquote>
@@ -181,7 +182,7 @@ fatal: unable to access &#39;https://git.player.com/test.git/&#39;: The requeste
181 <p>我们可以在仓库中执行 <code>git config http.receivepack true</code> 来开启 push 权限,但是这样的话,所有人都可以 push 182 <p>我们可以在仓库中执行 <code>git config http.receivepack true</code> 来开启 push 权限,但是这样的话,所有人都可以 push
182 代码了,这显然不是我们想要的。我们可以通过 <code>git config http.receivepack false</code> 来关闭 push 权限,这样的话,所有人都不能 push 183 代码了,这显然不是我们想要的。我们可以通过 <code>git config http.receivepack false</code> 来关闭 push 权限,这样的话,所有人都不能 push
183 代码了,这也不是我们想要的。那么,我们应该怎么做呢?更好的做法是这样的:</p> 184 代码了,这也不是我们想要的。那么,我们应该怎么做呢?更好的做法是这样的:</p>
184 <pre><code>$HTTP[&quot;querystring&quot;] =~ &quot;service=git-receive-pack&quot; { 185 <pre><code class="language-nginx">$HTTP[&quot;querystring&quot;] =~ &quot;service=git-receive-pack&quot; {
185 include &quot;git-auth.conf&quot; 186 include &quot;git-auth.conf&quot;
186} 187}
187$HTTP[&quot;url&quot;] =~ &quot;^/git/.*/git-receive-pack$&quot; { 188$HTTP[&quot;url&quot;] =~ &quot;^/git/.*/git-receive-pack$&quot; {
@@ -189,16 +190,15 @@ $HTTP[&quot;url&quot;] =~ &quot;^/git/.*/git-receive-pack$&quot; {
189}</code></pre> 190}</code></pre>
190 <p>看上去挺简单,但是想要理解为什么这样配置,就必须了解下 Git 的内部原理。正如上面 git-http-backend 文档上的那段描述,当 Git 客户端执行 191 <p>看上去挺简单,但是想要理解为什么这样配置,就必须了解下 Git 的内部原理。正如上面 git-http-backend 文档上的那段描述,当 Git 客户端执行
191 <code>git fetch/git pull/git clone</code>时,会调用 <code>upload-pack</code> 服务,当执行 <code>git push</code> 192 <code>git fetch/git pull/git clone</code>时,会调用 <code>upload-pack</code> 服务,当执行 <code>git push</code>
192 时,会调用 <code>receive-pack</code> 服务。我们可以查看 nginx 的访问日志,目录在<code>/var/log/nginx/access.log</code>: 193 时,会调用 <code>receive-pack</code> 服务。我们可以查看 nginx 的访问日志,目录在<code>/var/log/nginx/access.log</code>:</p>
193 </p>
194 <p>执行 git clone:</p> 194 <p>执行 git clone:</p>
195 <pre><code>[27/Nov/2018:22:18:00] &quot;GET /test.git/info/refs?service=git-upload-pack HTTP/1.1&quot; 200 363 &quot;-&quot; &quot;git/1.9.1&quot; 195 <pre><code class="language-plaintext">[27/Nov/2018:22:18:00] &quot;GET /test.git/info/refs?service=git-upload-pack HTTP/1.1&quot; 200 363 &quot;-&quot; &quot;git/1.9.1&quot;
196[27/Nov/2018:22:18:00] &quot;POST /test.git/git-upload-pack HTTP/1.1&quot; 200 306 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre> 196[27/Nov/2018:22:18:00] &quot;POST /test.git/git-upload-pack HTTP/1.1&quot; 200 306 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre>
197 <p>执行 git pull:</p> 197 <p>执行 git pull:</p>
198 <pre><code>[27/Nov/2018:22:20:25] &quot;GET /test.git/info/refs?service=git-upload-pack HTTP/1.1&quot; 200 363 &quot;-&quot; &quot;git/1.9.1&quot; 198 <pre><code class="language-plaintext">[27/Nov/2018:22:20:25] &quot;GET /test.git/info/refs?service=git-upload-pack HTTP/1.1&quot; 200 363 &quot;-&quot; &quot;git/1.9.1&quot;
199[27/Nov/2018:22:20:25] &quot;POST /test.git/git-upload-pack HTTP/1.1&quot; 200 551 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre> 199[27/Nov/2018:22:20:25] &quot;POST /test.git/git-upload-pack HTTP/1.1&quot; 200 551 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre>
200 <p>执行 git push:</p> 200 <p>执行 git push:</p>
201 <pre><code>[27/Nov/2018:22:19:33] &quot;GET /test.git/info/refs?service=git-receive-pack HTTP/1.1&quot; 401 204 &quot;-&quot; &quot;git/1.9.1&quot; 201 <pre><code class="language-plaintext">[27/Nov/2018:22:19:33] &quot;GET /test.git/info/refs?service=git-receive-pack HTTP/1.1&quot; 401 204 &quot;-&quot; &quot;git/1.9.1&quot;
202admin [27/Nov/2018:22:19:33] &quot;GET /test.git/info/refs?service=git-receive-pack HTTP/1.1&quot; 200 193 &quot;-&quot; &quot;git/1.9.1&quot; 202admin [27/Nov/2018:22:19:33] &quot;GET /test.git/info/refs?service=git-receive-pack HTTP/1.1&quot; 200 193 &quot;-&quot; &quot;git/1.9.1&quot;
203admin [27/Nov/2018:22:19:33] &quot;POST /test.git/git-receive-pack HTTP/1.1&quot; 200 63 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre> 203admin [27/Nov/2018:22:19:33] &quot;POST /test.git/git-receive-pack HTTP/1.1&quot; 200 63 &quot;-&quot; &quot;git/1.9.1&quot;</code></pre>
204 <p>可以看到执行 clone 和 pull 请求的接口是一样的,先请求 <code>/info/refs?service=git-upload-pack</code>,然后再请求 204 <p>可以看到执行 clone 和 pull 请求的接口是一样的,先请求 <code>/info/refs?service=git-upload-pack</code>,然后再请求
@@ -206,10 +206,9 @@ admin [27/Nov/2018:22:19:33] &quot;POST /test.git/git-receive-pack HTTP/1.1&quot
206 <code>/git-receive-pack</code>,所以在上面的的配置中我们看到了两条记录,如果要对 push 做访问控制,那么对这两个请求都要限制。关于 Git 传输的原理可以参考 《Pro 206 <code>/git-receive-pack</code>,所以在上面的的配置中我们看到了两条记录,如果要对 push 做访问控制,那么对这两个请求都要限制。关于 Git 传输的原理可以参考 《Pro
207 Git》的 <a 207 Git》的 <a
208 href="https://git-scm.com/book/zh/v2/Git-%E5%86%85%E9%83%A8%E5%8E%9F%E7%90%86-%E4%BC%A0%E8%BE%93%E5%8D%8F%E8%AE%AE">Git 208 href="https://git-scm.com/book/zh/v2/Git-%E5%86%85%E9%83%A8%E5%8E%9F%E7%90%86-%E4%BC%A0%E8%BE%93%E5%8D%8F%E8%AE%AE">Git
209 内部原理 - 传输协议</a> 这一节。 209 内部原理 - 传输协议</a> 这一节。</p>
210 </p>
211 <p>于是,我们对 nginx 的配置文件进行修改:</p> 210 <p>于是,我们对 nginx 的配置文件进行修改:</p>
212 <pre><code>server 211 <pre><code class="language-nginx">server
213{ 212{
214 listen 80; 213 listen 80;
215 server_name git.player.com; 214 server_name git.player.com;
@@ -274,21 +273,21 @@ server
274 </blockquote> 273 </blockquote>
275 <h2 id="认证文件">认证文件</h2> 274 <h2 id="认证文件">认证文件</h2>
276 <p>nginx 的配置中我们用到了认证文件,它的生成是这样的:</p> 275 <p>nginx 的配置中我们用到了认证文件,它的生成是这样的:</p>
277 <pre><code># 创建认证文件并添加第一个用户 276 <pre><code class="language-bash"># 创建认证文件并添加第一个用户
278htpasswd -cd &lt;文件名&gt; &lt;用户名&gt; &lt;密码&gt; 277htpasswd -cd &lt;文件名&gt; &lt;用户名&gt; &lt;密码&gt;
279# 在已有的文件中继续添加用户 278# 在已有的文件中继续添加用户
280htpasswd -d &lt;文件名&gt; &lt;用户名&gt; &lt;密码&gt;</code></pre> 279htpasswd -d &lt;文件名&gt; &lt;用户名&gt; &lt;密码&gt;</code></pre>
281 <p>到了这里,我们重启 nginx 然后进行测试,也许就可以正常使用了……吗?</p> 280 <p>到了这里,我们重启 nginx 然后进行测试,也许就可以正常使用了……吗?</p>
282 <h2 id="问题">问题</h2> 281 <h2 id="问题">问题</h2>
283 <p>我在测试的时候发现了一个问题:</p> 282 <p>我在测试的时候发现了一个问题:</p>
284 <pre><code>$ git clone https://git.player.com/test.git 283 <pre><code class="language-bash">$ git clone https://git.player.com/test.git
285Cloning into &#39;test&#39;... 284Cloning into &#39;test&#39;...
286fatal: repository &#39;https://git.player.com/test.git/&#39; not found</code></pre> 285fatal: repository &#39;https://git.player.com/test.git/&#39; not found</code></pre>
287 <p>看起来很匪夷所思:我们明明把仓库放进了指定目录啊,nginx 也已经配置好了,为什么就是找不到呢?我在网上找了很久也没找到答案。最后自己发现了问题所在:<strong>仓库文件夹权限不对</strong>。 286 <p>看起来很匪夷所思:我们明明把仓库放进了指定目录啊,nginx 也已经配置好了,为什么就是找不到呢?我在网上找了很久也没找到答案。最后自己发现了问题所在:<strong>仓库文件夹权限不对</strong>。
288 </p> 287 </p>
289 <h3 id="linux-权限描述">Linux 权限描述</h3> 288 <h3 id="linux-权限描述">Linux 权限描述</h3>
290 <p>当我们使用<code>ls -l</code>命令查看文件夹时,会看到类似这样的输出:</p> 289 <p>当我们使用<code>ls -l</code>命令查看文件夹时,会看到类似这样的输出:</p>
291 <pre><code>drwxr-xr-x 2 git git 4096 Nov 27 22:19 test.git</code></pre> 290 <pre><code class="language-bash">drwxr-xr-x 2 git git 4096 Nov 27 22:19 test.git</code></pre>
292 <p>其中前 10 个字符就是用来描述该目录权限的。</p> 291 <p>其中前 10 个字符就是用来描述该目录权限的。</p>
293 <ul> 292 <ul>
294 <li>第一位字符代表文件类型 293 <li>第一位字符代表文件类型
@@ -334,7 +333,7 @@ fatal: repository &#39;https://git.player.com/test.git/&#39; not found</code></p
334 </li> 333 </li>
335 </ul> 334 </ul>
336 <p><strong>这也就是上文我推荐为 git 仓库托管设立单独用户的原因。</strong>因而,最后我选择了第三种方案。具体操作如下:</p> 335 <p><strong>这也就是上文我推荐为 git 仓库托管设立单独用户的原因。</strong>因而,最后我选择了第三种方案。具体操作如下:</p>
337 <pre><code>usermod -aG git root 336 <pre><code class="language-bash">usermod -aG git root
338usermod -aG git www-data</code></pre> 337usermod -aG git www-data</code></pre>
339 <p>此时再进行测试,应该就可以正常使用了。</p> 338 <p>此时再进行测试,应该就可以正常使用了。</p>
340 <h1 id="cgit-拥抱图形化">cgit 拥抱图形化</h1> 339 <h1 id="cgit-拥抱图形化">cgit 拥抱图形化</h1>
@@ -349,7 +348,7 @@ usermod -aG git www-data</code></pre>
349 </p> 348 </p>
350 <h2 id="依赖">依赖</h2> 349 <h2 id="依赖">依赖</h2>
351 <p><code>nginx</code>/<code>git</code>/<code>vim</code>等工具不必赘述,还有一些依赖项需要安装:</p> 350 <p><code>nginx</code>/<code>git</code>/<code>vim</code>等工具不必赘述,还有一些依赖项需要安装:</p>
352 <pre><code># apache2-utils是用其htpasswd命令创建认证文件的 351 <pre><code class="language-bash"># apache2-utils是用其htpasswd命令创建认证文件的
353# fcgiwrap是用于将 FastCGI 转换为 HTTP 协议的工具 352# fcgiwrap是用于将 FastCGI 转换为 HTTP 协议的工具
354# 这两个工具上文均已提到和使用,不再赘述 353# 这两个工具上文均已提到和使用,不再赘述
355sudo apt update 354sudo apt update
@@ -363,14 +362,14 @@ sudo apt install -y libssl-dev
363sudo apt install liblua5.1-0 liblua5.1-0-dbg liblua5.1-dev lua5.1</code></pre> 362sudo apt install liblua5.1-0 liblua5.1-0-dbg liblua5.1-dev lua5.1</code></pre>
364 <h2 id="cgit-安装">cgit 安装</h2> 363 <h2 id="cgit-安装">cgit 安装</h2>
365 <p>cgit 最近的正式发行版已经好几年了,但是它的开发仍然很活跃,所以建议从它的 git 仓库中获取最新的代码,而非直接安装:</p> 364 <p>cgit 最近的正式发行版已经好几年了,但是它的开发仍然很活跃,所以建议从它的 git 仓库中获取最新的代码,而非直接安装:</p>
366 <pre><code>git clone https://git.zx2c4.com/cgit 365 <pre><code class="language-bash">git clone https://git.zx2c4.com/cgit
367cd cgit 366cd cgit
368git submodule init 367git submodule init
369git submodule update</code></pre> 368git submodule update</code></pre>
370 <p>在仓库目录下创建<code>cgit.conf</code>文件,用来存放 cgit 构建时可以覆盖的配置:</p> 369 <p>在仓库目录下创建<code>cgit.conf</code>文件,用来存放 cgit 构建时可以覆盖的配置:</p>
371 <pre><code>sed -n &#39;3,31p&#39; Makefile &gt; cgit.conf</code></pre> 370 <pre><code class="language-bash">sed -n &#39;3,31p&#39; Makefile &gt; cgit.conf</code></pre>
372 <p>我们可以按需编辑之:</p> 371 <p>我们可以按需编辑之:</p>
373 <pre><code>CGIT_VERSION = v1.2.3 372 <pre><code class="language-plaintext">CGIT_VERSION = v1.2.3
374CGIT_SCRIPT_NAME = cgit.cgi 373CGIT_SCRIPT_NAME = cgit.cgi
375CGIT_SCRIPT_PATH = /var/www/cgit # 本文只改了这里 374CGIT_SCRIPT_PATH = /var/www/cgit # 本文只改了这里
376CGIT_DATA_PATH = $(CGIT_SCRIPT_PATH) 375CGIT_DATA_PATH = $(CGIT_SCRIPT_PATH)
@@ -400,7 +399,7 @@ ASCIIDOC_HTML = xhtml11
400ASCIIDOC_COMMON = $(ASCIIDOC) $(ASCIIDOC_EXTRA) 399ASCIIDOC_COMMON = $(ASCIIDOC) $(ASCIIDOC_EXTRA)
401TXT_TO_HTML = $(ASCIIDOC_COMMON) -b $(ASCIIDOC_HTML)</code></pre> 400TXT_TO_HTML = $(ASCIIDOC_COMMON) -b $(ASCIIDOC_HTML)</code></pre>
402 <p>编译 &amp;&amp; 安装:</p> 401 <p>编译 &amp;&amp; 安装:</p>
403 <pre><code># 如果不需要lua支持 402 <pre><code class="language-bash"># 如果不需要lua支持
404make NO_LUA=1 403make NO_LUA=1
405# 有lua支持的话 404# 有lua支持的话
406make LUA_PKGCONFIG=lua5.1 405make LUA_PKGCONFIG=lua5.1
@@ -411,7 +410,7 @@ sudo make install | tee install.log</code></pre>
411 <h2 id="nginx-配置">nginx 配置</h2> 410 <h2 id="nginx-配置">nginx 配置</h2>
412 <p>首先,参照<a href="认证文件">这里</a>生成一个自己的认证文件,再继续往下看。</p> 411 <p>首先,参照<a href="认证文件">这里</a>生成一个自己的认证文件,再继续往下看。</p>
413 <p>在<code>/etc/nginx/git-http-backend.conf</code>中写入以下内容,注意把域名、ssl 路径、htpasswd 认证文件换成自己的:</p> 412 <p>在<code>/etc/nginx/git-http-backend.conf</code>中写入以下内容,注意把域名、ssl 路径、htpasswd 认证文件换成自己的:</p>
414 <pre><code># /etc/nginx/git-http-backend.conf 413 <pre><code class="language-nginx"># /etc/nginx/git-http-backend.conf
415fastcgi_pass unix:/var/run/fcgiwrap.socket; 414fastcgi_pass unix:/var/run/fcgiwrap.socket;
416include fastcgi_params; 415include fastcgi_params;
417fastcgi_param SCRIPT_FILENAME /usr/lib/git-core/git-http-backend; 416fastcgi_param SCRIPT_FILENAME /usr/lib/git-core/git-http-backend;
@@ -420,7 +419,7 @@ fastcgi_param GIT_PROJECT_ROOT /home/git;
420fastcgi_param PATH_INFO $1; 419fastcgi_param PATH_INFO $1;
421fastcgi_param REMOTE_USER $remote_user;</code></pre> 420fastcgi_param REMOTE_USER $remote_user;</code></pre>
422 <p>而后,在<code>/etc/nginx/conf.d/cgit.conf</code>中写:</p> 421 <p>而后,在<code>/etc/nginx/conf.d/cgit.conf</code>中写:</p>
423 <pre><code># /etc/nginx/conf.d/cgit.conf 422 <pre><code class="language-nginx"># /etc/nginx/conf.d/cgit.conf
424server { 423server {
425 listen 80; 424 listen 80;
426 server_name git.player.com; 425 server_name git.player.com;
@@ -491,11 +490,11 @@ server {
491 } 490 }
492}</code></pre> 491}</code></pre>
493 <p>最后,重启 nginx 服务:</p> 492 <p>最后,重启 nginx 服务:</p>
494 <pre><code>sudo nginx -s reload</code></pre> 493 <pre><code class="language-bash">sudo nginx -s reload</code></pre>
495 <p><em>看吧,一个个仓库,向我们列队走来!</em></p> 494 <p><em>看吧,一个个仓库,向我们列队走来!</em></p>
496 <h2 id="cgit-高级配置">cgit 高级配置</h2> 495 <h2 id="cgit-高级配置">cgit 高级配置</h2>
497 <p>可以安装一些包,用于 cgit 的代码高亮、Markdown 渲染、Gravatar 头像渲染等:</p> 496 <p>可以安装一些包,用于 cgit 的代码高亮、Markdown 渲染、Gravatar 头像渲染等:</p>
498 <pre><code>sudo apt install -y python3-docutils python3-markdown highlight python3-pygments 497 <pre><code class="language-bash">sudo apt install -y python3-docutils python3-markdown highlight python3-pygments
499 498
500# 编译安装 LuaoSSL 499# 编译安装 LuaoSSL
501# https://25thandclement.com/~william/projects/luaossl.html 500# https://25thandclement.com/~william/projects/luaossl.html
@@ -511,7 +510,7 @@ sudo chown -R www-data:www-data /usr/local/share/cgit/
511sudo chmod +x /usr/local/share/cgit/filters/email-gravatar.lua</code></pre> 510sudo chmod +x /usr/local/share/cgit/filters/email-gravatar.lua</code></pre>
512 <p>然后编辑上边我们已经指定的配置文件<code>/etc/cgitrc</code>,更多配置项参见<a 511 <p>然后编辑上边我们已经指定的配置文件<code>/etc/cgitrc</code>,更多配置项参见<a
513 href="https://git.zx2c4.com/cgit/tree/cgitrc.5.txt">cgitrc.5.txt</a>。</p> 512 href="https://git.zx2c4.com/cgit/tree/cgitrc.5.txt">cgitrc.5.txt</a>。</p>
514 <pre><code># /etc/cgitrc 513 <pre><code class="language-plaintext"># /etc/cgitrc
515# 包含 cgit 的所有运行时设置 514# 包含 cgit 的所有运行时设置
516# 格式 NAME=VALUE 515# 格式 NAME=VALUE
517# 以 &quot;#&quot; 开头的行是注释 516# 以 &quot;#&quot; 开头的行是注释
@@ -595,7 +594,7 @@ scan-path=/home/git
595 <p>在上面的配置文件里,我们使用了<a href="https://pygments.org/styles/">Pygments</a>的代码高亮。其默认使用的高亮是 594 <p>在上面的配置文件里,我们使用了<a href="https://pygments.org/styles/">Pygments</a>的代码高亮。其默认使用的高亮是
596 pastie,我们可以根据自己的喜好修改高亮风格。</p> 595 pastie,我们可以根据自己的喜好修改高亮风格。</p>
597 <p>首先,看看有哪些可用的高亮风格。</p> 596 <p>首先,看看有哪些可用的高亮风格。</p>
598 <pre><code># 查看可用的高亮风格 597 <pre><code class="language-bash"># 查看可用的高亮风格
599pygmentize -L styles 598pygmentize -L styles
600 599
601# 编辑我们使用的代码高亮脚本 600# 编辑我们使用的代码高亮脚本
@@ -617,9 +616,9 @@ sudo vim /usr/local/share/cgit/filters/syntax-highlighting.py</code></pre>
617 <p>cgit 的<a href="https://git.zx2c4.com/cgit/">官网</a>上不仅能实现 Gravatar 头像,还能在鼠标移动到头像上的时候以大图显示。这不是原生功能,而是需要动 616 <p>cgit 的<a href="https://git.zx2c4.com/cgit/">官网</a>上不仅能实现 Gravatar 头像,还能在鼠标移动到头像上的时候以大图显示。这不是原生功能,而是需要动
618 lua 脚本自己实现。原博客大佬在 cgit 的<a 617 lua 脚本自己实现。原博客大佬在 cgit 的<a
619 href="https://lists.zx2c4.com/pipermail/cgit/2014-March/002036.html">邮件列表</a>找到了实现方式。</p> 618 href="https://lists.zx2c4.com/pipermail/cgit/2014-March/002036.html">邮件列表</a>找到了实现方式。</p>
620 <pre><code>sudo vim /usr/local/share/cgit/filters/email-libravatar-korg.lua</code></pre> 619 <pre><code class="language-bash">sudo vim /usr/local/share/cgit/filters/email-libravatar-korg.lua</code></pre>
621 <p>在脚本中写入以下内容:</p> 620 <p>在脚本中写入以下内容:</p>
622 <pre><code>-- This script may be used with the email-filter or repo.email-filter settings in cgitrc. 621 <pre><code class="language-lua">-- This script may be used with the email-filter or repo.email-filter settings in cgitrc.
623-- It adds gravatar icons to author names. It is designed to be used with the lua: 622-- It adds gravatar icons to author names. It is designed to be used with the lua:
624-- prefix in filters. It is much faster than the corresponding python script. 623-- prefix in filters. It is much faster than the corresponding python script.
625-- 624--
@@ -656,7 +655,7 @@ function filter_write(str)
656 buffer = buffer .. str 655 buffer = buffer .. str
657end</code></pre> 656end</code></pre>
658 <p>只有 lua 还不够,我们需要将以下内容添加到<code>/var/www/cgit/cgit.css</code>中:</p> 657 <p>只有 lua 还不够,我们需要将以下内容添加到<code>/var/www/cgit/cgit.css</code>中:</p>
659 <pre><code>/* libgravatar */ 658 <pre><code class="language-css">/* libgravatar */
660div#cgit span.libravatar img.onhover { 659div#cgit span.libravatar img.onhover {
661 display: none; 660 display: none;
662 border: 1px solid gray; 661 border: 1px solid gray;
@@ -697,7 +696,7 @@ div#cgit span.libravatar:hover &gt; img.onhover {
697 <p>对于 cgit 显示出来的界面,你可能并不太满意(比如我就嫌界面的字太小、颜色不舒适啥的)。修改办法也很简单,找到<code>/var/www/cgit/cgit.css</code>文件,然后修改之。</p> 696 <p>对于 cgit 显示出来的界面,你可能并不太满意(比如我就嫌界面的字太小、颜色不舒适啥的)。修改办法也很简单,找到<code>/var/www/cgit/cgit.css</code>文件,然后修改之。</p>
698 <p>而对于我们的 Markdown 或者别的什么语言写的 README,如果觉得渲染效果不好,都是可以自己去修改的。</p> 697 <p>而对于我们的 Markdown 或者别的什么语言写的 README,如果觉得渲染效果不好,都是可以自己去修改的。</p>
699 <p>找到<code>/usr/local/share/cgit/filters/about-formatting.sh</code>文件,我们会看到以下内容:</p> 698 <p>找到<code>/usr/local/share/cgit/filters/about-formatting.sh</code>文件,我们会看到以下内容:</p>
700 <pre><code>#!/bin/sh 699 <pre><code class="language-bash">#!/bin/sh
701 700
702# This may be used with the about-filter or repo.about-filter setting in cgitrc. 701# This may be used with the about-filter or repo.about-filter setting in cgitrc.
703# It passes formatting of about pages to differing programs, depending on the usage. 702# It passes formatting of about pages to differing programs, depending on the usage.
@@ -741,6 +740,7 @@ esac</code></pre>
741 </ul> 740 </ul>
742 <p>这篇博客前前后后有二十多天了,有空再折腾吧。看电视去也~</p> 741 <p>这篇博客前前后后有二十多天了,有空再折腾吧。看电视去也~</p>
743 <!-- 2024.1.3 --> 742 <!-- 2024.1.3 -->
743 <p class="time">2024.1.3</p>
744 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script> 744 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
745 </div> 745 </div>
746 </div> 746 </div>
diff --git a/code/linux/gitserver.md b/code/linux/gitserver.md
index 53add30..b687fdc 100644
--- a/code/linux/gitserver.md
+++ b/code/linux/gitserver.md
@@ -135,7 +135,7 @@ echo "Success!"
135 135
136最初的设置是这样的: 136最初的设置是这样的:
137 137
138```conf 138```nginx
139server 139server
140{ 140{
141 # 这里用于将 http 请求重定向到 https,是一种常用的方式 141 # 这里用于将 http 请求重定向到 https,是一种常用的方式
@@ -183,7 +183,7 @@ fatal: unable to access 'https://git.player.com/test.git/': The requested URL re
183 183
184我们可以在仓库中执行 `git config http.receivepack true` 来开启 push 权限,但是这样的话,所有人都可以 push 代码了,这显然不是我们想要的。我们可以通过 `git config http.receivepack false` 来关闭 push 权限,这样的话,所有人都不能 push 代码了,这也不是我们想要的。那么,我们应该怎么做呢?更好的做法是这样的: 184我们可以在仓库中执行 `git config http.receivepack true` 来开启 push 权限,但是这样的话,所有人都可以 push 代码了,这显然不是我们想要的。我们可以通过 `git config http.receivepack false` 来关闭 push 权限,这样的话,所有人都不能 push 代码了,这也不是我们想要的。那么,我们应该怎么做呢?更好的做法是这样的:
185 185
186```conf 186```nginx
187$HTTP["querystring"] =~ "service=git-receive-pack" { 187$HTTP["querystring"] =~ "service=git-receive-pack" {
188 include "git-auth.conf" 188 include "git-auth.conf"
189} 189}
@@ -196,21 +196,21 @@ $HTTP["url"] =~ "^/git/.*/git-receive-pack$" {
196 196
197执行 git clone: 197执行 git clone:
198 198
199```log 199```plaintext
200[27/Nov/2018:22:18:00] "GET /test.git/info/refs?service=git-upload-pack HTTP/1.1" 200 363 "-" "git/1.9.1" 200[27/Nov/2018:22:18:00] "GET /test.git/info/refs?service=git-upload-pack HTTP/1.1" 200 363 "-" "git/1.9.1"
201[27/Nov/2018:22:18:00] "POST /test.git/git-upload-pack HTTP/1.1" 200 306 "-" "git/1.9.1" 201[27/Nov/2018:22:18:00] "POST /test.git/git-upload-pack HTTP/1.1" 200 306 "-" "git/1.9.1"
202``` 202```
203 203
204执行 git pull: 204执行 git pull:
205 205
206```log 206```plaintext
207[27/Nov/2018:22:20:25] "GET /test.git/info/refs?service=git-upload-pack HTTP/1.1" 200 363 "-" "git/1.9.1" 207[27/Nov/2018:22:20:25] "GET /test.git/info/refs?service=git-upload-pack HTTP/1.1" 200 363 "-" "git/1.9.1"
208[27/Nov/2018:22:20:25] "POST /test.git/git-upload-pack HTTP/1.1" 200 551 "-" "git/1.9.1" 208[27/Nov/2018:22:20:25] "POST /test.git/git-upload-pack HTTP/1.1" 200 551 "-" "git/1.9.1"
209``` 209```
210 210
211执行 git push: 211执行 git push:
212 212
213```log 213```plaintext
214[27/Nov/2018:22:19:33] "GET /test.git/info/refs?service=git-receive-pack HTTP/1.1" 401 204 "-" "git/1.9.1" 214[27/Nov/2018:22:19:33] "GET /test.git/info/refs?service=git-receive-pack HTTP/1.1" 401 204 "-" "git/1.9.1"
215admin [27/Nov/2018:22:19:33] "GET /test.git/info/refs?service=git-receive-pack HTTP/1.1" 200 193 "-" "git/1.9.1" 215admin [27/Nov/2018:22:19:33] "GET /test.git/info/refs?service=git-receive-pack HTTP/1.1" 200 193 "-" "git/1.9.1"
216admin [27/Nov/2018:22:19:33] "POST /test.git/git-receive-pack HTTP/1.1" 200 63 "-" "git/1.9.1" 216admin [27/Nov/2018:22:19:33] "POST /test.git/git-receive-pack HTTP/1.1" 200 63 "-" "git/1.9.1"
@@ -220,7 +220,7 @@ admin [27/Nov/2018:22:19:33] "POST /test.git/git-receive-pack HTTP/1.1" 200 63 "
220 220
221于是,我们对 nginx 的配置文件进行修改: 221于是,我们对 nginx 的配置文件进行修改:
222 222
223```conf 223```nginx
224server 224server
225{ 225{
226 listen 80; 226 listen 80;
@@ -452,7 +452,7 @@ sudo make install | tee install.log
452 452
453在`/etc/nginx/git-http-backend.conf`中写入以下内容,注意把域名、ssl 路径、htpasswd 认证文件换成自己的: 453在`/etc/nginx/git-http-backend.conf`中写入以下内容,注意把域名、ssl 路径、htpasswd 认证文件换成自己的:
454 454
455```conf 455```nginx
456# /etc/nginx/git-http-backend.conf 456# /etc/nginx/git-http-backend.conf
457fastcgi_pass unix:/var/run/fcgiwrap.socket; 457fastcgi_pass unix:/var/run/fcgiwrap.socket;
458include fastcgi_params; 458include fastcgi_params;
@@ -465,7 +465,7 @@ fastcgi_param REMOTE_USER $remote_user;
465 465
466而后,在`/etc/nginx/conf.d/cgit.conf`中写: 466而后,在`/etc/nginx/conf.d/cgit.conf`中写:
467 467
468```conf 468```nginx
469# /etc/nginx/conf.d/cgit.conf 469# /etc/nginx/conf.d/cgit.conf
470server { 470server {
471 listen 80; 471 listen 80;
diff --git a/code/linux/httpmyserver.html b/code/linux/httpmyserver.html
index d1e14a7..f86641b 100644
--- a/code/linux/httpmyserver.html
+++ b/code/linux/httpmyserver.html
@@ -7,30 +7,27 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>http浏览服务器文件</title> 8 <title>http浏览服务器文件</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">http浏览服务器文件</p> 16 <header id="title-block-header">
17 <p class="title">http浏览服务器文件</p>
18 </header>
18 <!-- python实现服务器文件浏览 --> 19 <!-- python实现服务器文件浏览 -->
19 <p>有了服务器,我们自然会有这样的需求:<strong>把一些内容传到服务器上,方便其他人访问或自己在其他设备(如手机)上,通过浏览器直接访问</strong>。我们需要它能完成以下功能:</p> 20 <p>有了服务器,我们自然会有这样的需求:<strong>把一些内容传到服务器上,方便其他人访问或自己在其他设备(如手机)上,通过浏览器直接访问</strong>。我们需要它能完成以下功能:</p>
20 <ul> 21 <ul>
21 <li>能让我们自己点进(或退出)层层文件夹,展示当前文件夹下的所有文件/文件夹</li> 22 <li>能让我们自己点进(或退出)层层文件夹,展示当前文件夹下的所有文件/文件夹</li>
22 <li>点击文件,能够看到文件内容</li> 23 <li>点击文件,能够看到文件内容</li>
23 </ul> 24 </ul>
24 <p><img 25 <p><img src="http://www.qin-juan-ge-zhu.top/images/code/httpmyserver_1.png" /></p>
25 src="" />
26 </p>
27 <p>点击进入文件<code>nginx.txt</code>,我们要求看到文件的内容:</p> 26 <p>点击进入文件<code>nginx.txt</code>,我们要求看到文件的内容:</p>
28 <p><img 27 <p><img src="http://www.qin-juan-ge-zhu.top/images/code/httpmyserver_2.png" /></p>
29 src="" />
30 </p>
31 <p>既要看文件内容,又要能浏览不同的文件夹。这个功能如果直接用程序或 nginx 实现似乎有些新手不友好。没事,python3 28 <p>既要看文件内容,又要能浏览不同的文件夹。这个功能如果直接用程序或 nginx 实现似乎有些新手不友好。没事,python3
32 为我们提供了这个功能,脚本为<code>/usr/lib/python3.x/http/server.py</code>。使用时执行以下命令即可:</p> 29 为我们提供了这个功能,脚本为<code>/usr/lib/python3.x/http/server.py</code>。使用时执行以下命令即可:</p>
33 <pre><code>python3 -m http.server</code></pre> 30 <pre><code class="language-bash">python3 -m http.server</code></pre>
34 <p>但 python 提供的脚本有些不尽人意:</p> 31 <p>但 python 提供的脚本有些不尽人意:</p>
35 <ul> 32 <ul>
36 <li>遇到当前路径有<code>index.html</code>就展示网页,而不是展示当前路径下的文件</li> 33 <li>遇到当前路径有<code>index.html</code>就展示网页,而不是展示当前路径下的文件</li>
@@ -42,7 +39,7 @@
42 <p>处于以上种种原因,我对该程序做了一点点修改。修改后的脚本我选择放在<code>/usr/lib/python3.x/http/myserver.py</code>(和原有<code>server.py</code>放在一起)。代码全文我放在了<a 39 <p>处于以上种种原因,我对该程序做了一点点修改。修改后的脚本我选择放在<code>/usr/lib/python3.x/http/myserver.py</code>(和原有<code>server.py</code>放在一起)。代码全文我放在了<a
43 href="https://file.qin-juan-ge-zhu.top/useful/myserver.py">这里</a>。在这里仅对修改的部分加以说明。</p> 40 href="https://file.qin-juan-ge-zhu.top/useful/myserver.py">这里</a>。在这里仅对修改的部分加以说明。</p>
44 <p>首先,为了完成以下功能,需要引入几个新的模块:</p> 41 <p>首先,为了完成以下功能,需要引入几个新的模块:</p>
45 <pre><code>import cgi 42 <pre><code class="language-python">import cgi
46import pwd 43import pwd
47import grp 44import grp
48import time 45import time
@@ -51,7 +48,7 @@ import math</code></pre>
51 <h1 id="遇到-index.html-时">遇到 index.html 时</h1> 48 <h1 id="遇到-index.html-时">遇到 index.html 时</h1>
52 <p>在<code>http.server</code>(源码路径<code>/usr/lib/python3.x/http/server.py</code>)第 710 49 <p>在<code>http.server</code>(源码路径<code>/usr/lib/python3.x/http/server.py</code>)第 710
53 行(<code>def send_head</code>函数)中有这样一段:</p> 50 行(<code>def send_head</code>函数)中有这样一段:</p>
54 <pre><code>for index in &quot;index.html&quot;, &quot;index.htm&quot;: 51 <pre><code class="language-python">for index in &quot;index.html&quot;, &quot;index.htm&quot;:
55 index = os.path.join(path, index) 52 index = os.path.join(path, index)
56 if os.path.isfile(index): 53 if os.path.isfile(index):
57 path = index 54 path = index
@@ -61,7 +58,7 @@ import math</code></pre>
61 <h1 id="浏览文件出现乱码">浏览文件出现乱码</h1> 58 <h1 id="浏览文件出现乱码">浏览文件出现乱码</h1>
62 <p>你可能会问,上边看到的 html 模板不是已经明文规定编码是<code>utf-8</code>了吗,,怎么还会乱码?没错,html 是说明编码了,但我们除了浏览以 html 59 <p>你可能会问,上边看到的 html 模板不是已经明文规定编码是<code>utf-8</code>了吗,,怎么还会乱码?没错,html 是说明编码了,但我们除了浏览以 html
63 形式展示的目录连接之外,还是要看文件内容的,文件里或多或少都会有点中文不是吗?对于文件而言,编码必须由 http 的响应头指出,否则客户端就会根据文件内容猜测其编码然后展示出来,就成了乱码。</p> 60 形式展示的目录连接之外,还是要看文件内容的,文件里或多或少都会有点中文不是吗?对于文件而言,编码必须由 http 的响应头指出,否则客户端就会根据文件内容猜测其编码然后展示出来,就成了乱码。</p>
64 <pre><code># http.server, line 763 61 <pre><code class="language-python"># http.server, line 763
65# also in the function &#39;send_head&#39; 62# also in the function &#39;send_head&#39;
66# this line and its context are about http response header 63# this line and its context are about http response header
67self.send_header(&quot;Content-type&quot;, ctype) 64self.send_header(&quot;Content-type&quot;, ctype)
@@ -70,7 +67,7 @@ self.send_header(&quot;Content-type&quot;, ctype + &quot;; charset=utf-8&quot;)<
70 <h1 id="展示所有文件和文件夹">展示所有文件和文件夹</h1> 67 <h1 id="展示所有文件和文件夹">展示所有文件和文件夹</h1>
71 <p>在<code>server.py</code>第 772 68 <p>在<code>server.py</code>第 772
72 行,有一个<code>list_directory</code>函数,是用来展示当前路径下有哪些文件或文件夹的,但是这有个缺陷,就是只能点进下一级文件夹,但无法返回上一级。为此,我们需要做一些修改:</p> 69 行,有一个<code>list_directory</code>函数,是用来展示当前路径下有哪些文件或文件夹的,但是这有个缺陷,就是只能点进下一级文件夹,但无法返回上一级。为此,我们需要做一些修改:</p>
73 <pre><code>def list_directory(self, path): 70 <pre><code class="language-python">def list_directory(self, path):
74 try: 71 try:
75 list = os.listdir(path) 72 list = os.listdir(path)
76 except OSError: 73 except OSError:
@@ -103,7 +100,7 @@ self.send_header(&quot;Content-type&quot;, ctype + &quot;; charset=utf-8&quot;)<
103 <li>为了美观,目录超链接的样式我做了一些修改,主要是去除了其下划线、设置无论是否访问过都显示为同一个颜色</li> 100 <li>为了美观,目录超链接的样式我做了一些修改,主要是去除了其下划线、设置无论是否访问过都显示为同一个颜色</li>
104 <li>还做了其他一些小的样式修改</li> 101 <li>还做了其他一些小的样式修改</li>
105 </ul> 102 </ul>
106 <pre><code>enc = sys.getfilesystemencoding() 103 <pre><code class="language-python">enc = sys.getfilesystemencoding()
107title = f&#39;Directory listing for {displaypath}&#39; 104title = f&#39;Directory listing for {displaypath}&#39;
108r.append(&#39;&lt;!DOCTYPE HTML&gt;&#39;) 105r.append(&#39;&lt;!DOCTYPE HTML&gt;&#39;)
109r.append(&#39;&lt;html lang=&quot;en&quot;&gt;&#39;) 106r.append(&#39;&lt;html lang=&quot;en&quot;&gt;&#39;)
@@ -181,7 +178,7 @@ return f</code></pre>
181 <p>首先,我们需要一个按钮来供使用者上传文件。为了整体页面协调,我选择将上传表单与 h1 放在同一行,都在分割线上方,表单靠右显示;且由于 h1 178 <p>首先,我们需要一个按钮来供使用者上传文件。为了整体页面协调,我选择将上传表单与 h1 放在同一行,都在分割线上方,表单靠右显示;且由于 h1
182 与表单大小不一,表单太靠上不好看,于是设置二者对齐方式为基线对齐,并取消了 h1 与表单的内外留白。</p> 179 与表单大小不一,表单太靠上不好看,于是设置二者对齐方式为基线对齐,并取消了 h1 与表单的内外留白。</p>
183 <p>涉及的 html 模板修改情况如下:</p> 180 <p>涉及的 html 模板修改情况如下:</p>
184 <pre><code>title = f&#39;Directory listing for {displaypath}&#39; 181 <pre><code class="language-python">title = f&#39;Directory listing for {displaypath}&#39;
185r.append(&#39;&lt;!DOCTYPE HTML&gt;&#39;) 182r.append(&#39;&lt;!DOCTYPE HTML&gt;&#39;)
186r.append(&#39;&lt;html lang=&quot;en&quot;&gt;&#39;) 183r.append(&#39;&lt;html lang=&quot;en&quot;&gt;&#39;)
187r.append(&#39;&lt;head&gt;&#39;) 184r.append(&#39;&lt;head&gt;&#39;)
@@ -199,7 +196,7 @@ r.append(&#39;&lt;hr&gt;&#39;)</code></pre>
199 <p>修改的内容主要是 css 样式和添加了上传表单。</p> 196 <p>修改的内容主要是 css 样式和添加了上传表单。</p>
200 <p>接下来,我们需要在<code>do_POST</code>函数中处理上传的文件。这里我使用了<code>cgi</code>模块,该模块可以帮助我们处理上传的文件。在<code>do_POST</code>函数中,我们需要添加以下代码: 197 <p>接下来,我们需要在<code>do_POST</code>函数中处理上传的文件。这里我使用了<code>cgi</code>模块,该模块可以帮助我们处理上传的文件。在<code>do_POST</code>函数中,我们需要添加以下代码:
201 </p> 198 </p>
202 <pre><code># 注意是class SimpleHTTPRequestHandler的do_POST函数 199 <pre><code class="language-python"># 注意是class SimpleHTTPRequestHandler的do_POST函数
203# 不要搞错了 200# 不要搞错了
204def do_POST(self): 201def do_POST(self):
205 # 获取请求路径 202 # 获取请求路径
@@ -264,7 +261,7 @@ def do_POST(self):
264 <p>在经历以上的修改之后,原来的<code>http.server</code>改造成为了一个更加适合免登录浏览服务器文件的工具。再次说明,我修改后的文件<a 261 <p>在经历以上的修改之后,原来的<code>http.server</code>改造成为了一个更加适合免登录浏览服务器文件的工具。再次说明,我修改后的文件<a
265 href="https://file.qin-juan-ge-zhu.top/useful/myserver.py">在这里</a>。如果你想要使用,可以将其放在<code>/usr/lib/python3.x/http/myserver.py</code>,然后使用以下命令启动: 262 href="https://file.qin-juan-ge-zhu.top/useful/myserver.py">在这里</a>。如果你想要使用,可以将其放在<code>/usr/lib/python3.x/http/myserver.py</code>,然后使用以下命令启动:
266 </p> 263 </p>
267 <pre><code>python -m http.myserver &gt; py_menu.log 2&gt;&amp;1 &amp;</code></pre> 264 <pre><code class="language-bash">python -m http.myserver &gt; py_menu.log 2&gt;&amp;1 &amp;</code></pre>
268 <p>这条命令会让这个进程在后台运行,并且将运行时的日志和报错信息输出到日志文件中,以备查看和随时确认是否有人在通过这个服务攻击你的服务器(服务连续运行三天,查看日志,你一定会被如此多数量的陌生 ip 访问吓到的)。 265 <p>这条命令会让这个进程在后台运行,并且将运行时的日志和报错信息输出到日志文件中,以备查看和随时确认是否有人在通过这个服务攻击你的服务器(服务连续运行三天,查看日志,你一定会被如此多数量的陌生 ip 访问吓到的)。
269 </p> 266 </p>
270 <p>这个服务默认运行在 8000 端口,你可以按照文件最后的<code>main</code>函数里的参数来修改运行端口。到了这一步,你也可以像为其他网络服务配置 https 一样,使用你的网络服务软件(如 267 <p>这个服务默认运行在 8000 端口,你可以按照文件最后的<code>main</code>函数里的参数来修改运行端口。到了这一步,你也可以像为其他网络服务配置 https 一样,使用你的网络服务软件(如
diff --git a/code/linux/httpmyserver.md b/code/linux/httpmyserver.md
index 2f9f621..b39b266 100644
--- a/code/linux/httpmyserver.md
+++ b/code/linux/httpmyserver.md
@@ -5,11 +5,11 @@
5- 能让我们自己点进(或退出)层层文件夹,展示当前文件夹下的所有文件/文件夹 5- 能让我们自己点进(或退出)层层文件夹,展示当前文件夹下的所有文件/文件夹
6- 点击文件,能够看到文件内容 6- 点击文件,能够看到文件内容
7 7
8![]() 8![](http://www.qin-juan-ge-zhu.top/images/code/httpmyserver_1.png)
9 9
10点击进入文件`nginx.txt`,我们要求看到文件的内容: 10点击进入文件`nginx.txt`,我们要求看到文件的内容:
11 11
12![]() 12![](http://www.qin-juan-ge-zhu.top/images/code/httpmyserver_2.png)
13 13
14既要看文件内容,又要能浏览不同的文件夹。这个功能如果直接用程序或 nginx 实现似乎有些新手不友好。没事,python3 为我们提供了这个功能,脚本为`/usr/lib/python3.x/http/server.py`。使用时执行以下命令即可: 14既要看文件内容,又要能浏览不同的文件夹。这个功能如果直接用程序或 nginx 实现似乎有些新手不友好。没事,python3 为我们提供了这个功能,脚本为`/usr/lib/python3.x/http/server.py`。使用时执行以下命令即可:
15 15
diff --git a/code/linux/keymap.html b/code/linux/keymap.html
index a21a19a..3fa8464 100644
--- a/code/linux/keymap.html
+++ b/code/linux/keymap.html
@@ -3,17 +3,19 @@
3 3
4<head> 4<head>
5 <meta charset="utf-8" /> 5 <meta charset="utf-8" />
6 <meta name="generator" content="pandoc" />
6 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
7 <title>键盘映射</title> 8 <title>键盘映射</title>
8 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
9 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
11</head> 11</head>
12 12
13<body> 13<body>
14 <p class="title">键盘映射</p>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
16 <header id="title-block-header">
17 <p class="title">键盘映射</p>
18 </header>
17 <!-- 键盘映射更改 --> 19 <!-- 键盘映射更改 -->
18 <p>在开发过程中,硬件键盘许多键位十分不便,因而我们需要对系统的键盘映射加以更改。</p> 20 <p>在开发过程中,硬件键盘许多键位十分不便,因而我们需要对系统的键盘映射加以更改。</p>
19 <h1 id="windows-键盘映射">Windows 键盘映射</h1> 21 <h1 id="windows-键盘映射">Windows 键盘映射</h1>
@@ -23,8 +25,7 @@
23 <p>打开该项,按照以下内容的规则对二进制项内容进行设置。</p> 25 <p>打开该项,按照以下内容的规则对二进制项内容进行设置。</p>
24 <h2 id="scancode-map-规则">ScanCode Map 规则</h2> 26 <h2 id="scancode-map-规则">ScanCode Map 规则</h2>
25 <p>首先需要注意,以下所有数据都是小端党(<del>格列佛被欺负即视感</del>),即数据高位写在高地址。如十六进制数据 0x007f365a,应当写为 5a 36 7f 00。如出现位数不足,数据高位以 0 27 <p>首先需要注意,以下所有数据都是小端党(<del>格列佛被欺负即视感</del>),即数据高位写在高地址。如十六进制数据 0x007f365a,应当写为 5a 36 7f 00。如出现位数不足,数据高位以 0
26 补足即可。 28 补足即可。</p>
27 </p>
28 <ul> 29 <ul>
29 <li>输入 8 个 00 作为开头标识符。</li> 30 <li>输入 8 个 00 作为开头标识符。</li>
30 <li>4 个字节,表示映射键的总数,即所要做的键盘映射涉及几个按键(左右 Ctrl/Alt 均属于不同按键)。</li> 31 <li>4 个字节,表示映射键的总数,即所要做的键盘映射涉及几个按键(左右 Ctrl/Alt 均属于不同按键)。</li>
@@ -34,416 +35,406 @@
34 <h2 id="按键码值表">按键码值表</h2> 35 <h2 id="按键码值表">按键码值表</h2>
35 <p>以下内容为上述 ScanCode Map 所需的按键码值表。</p> 36 <p>以下内容为上述 ScanCode Map 所需的按键码值表。</p>
36 <h3 id="主键盘">主键盘</h3> 37 <h3 id="主键盘">主键盘</h3>
37 <div class="table-div"> 38 <table>
38 <table> 39 <thead>
39 <thead> 40 <tr class="header">
40 <tr class="header"> 41 <th>key</th>
41 <th>key</th> 42 <th>mark</th>
42 <th>mark</th> 43 <th>key</th>
43 <th>key</th> 44 <th>mark</th>
44 <th>mark</th> 45 <th>key</th>
45 <th>key</th> 46 <th>mark</th>
46 <th>mark</th> 47 <th>key</th>
47 <th>key</th> 48 <th>mark</th>
48 <th>mark</th> 49 </tr>
49 </tr> 50 </thead>
50 </thead> 51 <tbody>
51 <tbody> 52 <tr class="odd">
52 <tr class="odd"> 53 <td>~/`</td>
53 <td>~/`</td> 54 <td>29</td>
54 <td>29</td> 55 <td>Tab</td>
55 <td>Tab</td> 56 <td>0f</td>
56 <td>0f</td> 57 <td>CapsLock</td>
57 <td>CapsLock</td> 58 <td>3a</td>
58 <td>3a</td> 59 <td>L-Shift</td>
59 <td>L-Shift</td> 60 <td>2a</td>
60 <td>2a</td> 61 </tr>
61 </tr> 62 <tr class="even">
62 <tr class="even"> 63 <td>!/1</td>
63 <td>!/1</td> 64 <td>2</td>
64 <td>2</td> 65 <td>q</td>
65 <td>q</td> 66 <td>10</td>
66 <td>10</td> 67 <td>a</td>
67 <td>a</td> 68 <td>1e</td>
68 <td>1e</td> 69 <td>z</td>
69 <td>z</td> 70 <td>2c</td>
70 <td>2c</td> 71 </tr>
71 </tr> 72 <tr class="odd">
72 <tr class="odd"> 73 <td>@/2</td>
73 <td>@/2</td> 74 <td>3</td>
74 <td>3</td> 75 <td>w</td>
75 <td>w</td> 76 <td>11</td>
76 <td>11</td> 77 <td>s</td>
77 <td>s</td> 78 <td>1f</td>
78 <td>1f</td> 79 <td>x</td>
79 <td>x</td> 80 <td>2d</td>
80 <td>2d</td> 81 </tr>
81 </tr> 82 <tr class="even">
82 <tr class="even"> 83 <td>#/3</td>
83 <td>#/3</td> 84 <td>4</td>
84 <td>4</td> 85 <td>e</td>
85 <td>e</td> 86 <td>12</td>
86 <td>12</td> 87 <td>d</td>
87 <td>d</td> 88 <td>20</td>
88 <td>20</td> 89 <td>c</td>
89 <td>c</td> 90 <td>2e</td>
90 <td>2e</td> 91 </tr>
91 </tr> 92 <tr class="odd">
92 <tr class="odd"> 93 <td>$/4</td>
93 <td>$/4</td> 94 <td>5</td>
94 <td>5</td> 95 <td>r</td>
95 <td>r</td> 96 <td>13</td>
96 <td>13</td> 97 <td>f</td>
97 <td>f</td> 98 <td>21</td>
98 <td>21</td> 99 <td>v</td>
99 <td>v</td> 100 <td>2f</td>
100 <td>2f</td> 101 </tr>
101 </tr> 102 <tr class="even">
102 <tr class="even"> 103 <td>%/5</td>
103 <td>%/5</td> 104 <td>6</td>
104 <td>6</td> 105 <td>t</td>
105 <td>t</td> 106 <td>14</td>
106 <td>14</td> 107 <td>g</td>
107 <td>g</td> 108 <td>22</td>
108 <td>22</td> 109 <td>b</td>
109 <td>b</td> 110 <td>30</td>
110 <td>30</td> 111 </tr>
111 </tr> 112 <tr class="odd">
112 <tr class="odd"> 113 <td>^/6</td>
113 <td>^/6</td> 114 <td>7</td>
114 <td>7</td> 115 <td>y</td>
115 <td>y</td> 116 <td>15</td>
116 <td>15</td> 117 <td>h</td>
117 <td>h</td> 118 <td>23</td>
118 <td>23</td> 119 <td>n</td>
119 <td>n</td> 120 <td>31</td>
120 <td>31</td> 121 </tr>
121 </tr> 122 <tr class="even">
122 <tr class="even"> 123 <td>&amp;/7</td>
123 <td>&amp;/7</td> 124 <td>8</td>
124 <td>8</td> 125 <td>u</td>
125 <td>u</td> 126 <td>16</td>
126 <td>16</td> 127 <td>j</td>
127 <td>j</td> 128 <td>24</td>
128 <td>24</td> 129 <td>m</td>
129 <td>m</td> 130 <td>32</td>
130 <td>32</td> 131 </tr>
131 </tr> 132 <tr class="odd">
132 <tr class="odd"> 133 <td>*/8</td>
133 <td>*/8</td> 134 <td>9</td>
134 <td>9</td> 135 <td>i</td>
135 <td>i</td> 136 <td>17</td>
136 <td>17</td> 137 <td>k</td>
137 <td>k</td> 138 <td>25</td>
138 <td>25</td> 139 <td>&lt;/,</td>
139 <td>&lt;/,</td> 140 <td>33</td>
140 <td>33</td> 141 </tr>
141 </tr> 142 <tr class="even">
142 <tr class="even"> 143 <td>(/9</td>
143 <td>(/9</td> 144 <td>0a</td>
144 <td>0a</td> 145 <td>o</td>
145 <td>o</td> 146 <td>18</td>
146 <td>18</td> 147 <td>l</td>
147 <td>l</td> 148 <td>26</td>
148 <td>26</td> 149 <td>&gt;/.</td>
149 <td>&gt;/.</td> 150 <td>34</td>
150 <td>34</td> 151 </tr>
151 </tr> 152 <tr class="odd">
152 <tr class="odd"> 153 <td>)/0</td>
153 <td>)/0</td> 154 <td>0b</td>
154 <td>0b</td> 155 <td>p</td>
155 <td>p</td> 156 <td>19</td>
156 <td>19</td> 157 <td>:/;</td>
157 <td>:/;</td> 158 <td>27</td>
158 <td>27</td> 159 <td>?</td>
159 <td>?</td> 160 <td>35</td>
160 <td>35</td> 161 </tr>
161 </tr> 162 <tr class="even">
162 <tr class="even"> 163 <td>_/-</td>
163 <td>_/-</td> 164 <td>0c</td>
164 <td>0c</td> 165 <td>{/[</td>
165 <td>{/[</td> 166 <td>1a</td>
166 <td>1a</td> 167 <td>"/’</td>
167 <td>"/’</td> 168 <td>28</td>
168 <td>28</td> 169 <td>R-Shift</td>
169 <td>R-Shift</td> 170 <td>36</td>
170 <td>36</td> 171 </tr>
171 </tr> 172 <tr class="odd">
172 <tr class="odd"> 173 <td>+/=</td>
173 <td>+/=</td> 174 <td>0d</td>
174 <td>0d</td> 175 <td>}/]</td>
175 <td>}/]</td> 176 <td>1b</td>
176 <td>1b</td> 177 <td>Enter</td>
177 <td>Enter</td> 178 <td>1c</td>
178 <td>1c</td> 179 <td>L-Ctrl</td>
179 <td>L-Ctrl</td> 180 <td>1d</td>
180 <td>1d</td> 181 </tr>
181 </tr> 182 <tr class="even">
182 <tr class="even"> 183 <td>|/\</td>
183 <td>|/\</td> 184 <td></td>
184 <td></td> 185 <td></td>
185 <td></td> 186 <td></td>
186 <td></td> 187 <td></td>
187 <td></td> 188 <td></td>
188 <td></td> 189 <td>L-Alt</td>
189 <td>L-Alt</td> 190 <td>38</td>
190 <td>38</td> 191 </tr>
191 </tr> 192 <tr class="odd">
192 <tr class="odd"> 193 <td></td>
193 <td></td> 194 <td></td>
194 <td></td> 195 <td></td>
195 <td></td> 196 <td></td>
196 <td></td> 197 <td></td>
197 <td></td> 198 <td></td>
198 <td></td> 199 <td>Sace</td>
199 <td>Sace</td> 200 <td>39</td>
200 <td>39</td> 201 </tr>
201 </tr> 202 <tr class="even">
202 <tr class="even"> 203 <td></td>
203 <td></td> 204 <td></td>
204 <td></td> 205 <td></td>
205 <td></td> 206 <td></td>
206 <td></td> 207 <td></td>
207 <td></td> 208 <td></td>
208 <td></td> 209 <td>R-Alt</td>
209 <td>R-Alt</td> 210 <td>e0 38</td>
210 <td>e0 38</td> 211 </tr>
211 </tr> 212 <tr class="odd">
212 <tr class="odd"> 213 <td></td>
213 <td></td> 214 <td></td>
214 <td></td> 215 <td></td>
215 <td></td> 216 <td></td>
216 <td></td> 217 <td></td>
217 <td></td> 218 <td></td>
218 <td></td> 219 <td>R-Ctrl</td>
219 <td>R-Ctrl</td> 220 <td>e0 1d</td>
220 <td>e0 1d</td> 221 </tr>
221 </tr> 222 </tbody>
222 </tbody> 223 </table>
223 </table>
224 </div>
225 <h3 id="小键盘">小键盘</h3> 224 <h3 id="小键盘">小键盘</h3>
226 <div class="table-div"> 225 <table>
227 <table> 226 <thead>
228 <thead> 227 <tr class="header">
229 <tr class="header"> 228 <th>key</th>
230 <th>key</th> 229 <th>mark</th>
231 <th>mark</th> 230 <th>key</th>
232 <th>key</th> 231 <th>mark</th>
233 <th>mark</th> 232 <th>key</th>
234 <th>key</th> 233 <th>mark</th>
235 <th>mark</th> 234 <th>key</th>
236 <th>key</th> 235 <th>mark</th>
237 <th>mark</th> 236 </tr>
238 </tr> 237 </thead>
239 </thead> 238 <tbody>
240 <tbody> 239 <tr class="odd">
241 <tr class="odd"> 240 <td>NumLock</td>
242 <td>NumLock</td> 241 <td>45</td>
243 <td>45</td> 242 <td>8</td>
244 <td>8</td> 243 <td>48</td>
245 <td>48</td> 244 <td>1</td>
246 <td>1</td> 245 <td>4f</td>
247 <td>4f</td> 246 <td>+</td>
248 <td>+</td> 247 <td>4e</td>
249 <td>4e</td> 248 </tr>
250 </tr> 249 <tr class="even">
251 <tr class="even"> 250 <td>/</td>
252 <td>/</td> 251 <td>e0 35</td>
253 <td>e0 35</td> 252 <td>9</td>
254 <td>9</td> 253 <td>49</td>
255 <td>49</td> 254 <td>2</td>
256 <td>2</td> 255 <td>50</td>
257 <td>50</td> 256 <td>Enter</td>
258 <td>Enter</td> 257 <td>e0 1c</td>
259 <td>e0 1c</td> 258 </tr>
260 </tr> 259 <tr class="odd">
261 <tr class="odd"> 260 <td>*</td>
262 <td>*</td> 261 <td>37</td>
263 <td>37</td> 262 <td>4</td>
264 <td>4</td> 263 <td>4b</td>
265 <td>4b</td> 264 <td>3</td>
266 <td>3</td> 265 <td>51</td>
267 <td>51</td> 266 <td></td>
268 <td></td> 267 <td></td>
269 <td></td> 268 </tr>
270 </tr> 269 <tr class="even">
271 <tr class="even"> 270 <td>-</td>
272 <td>-</td> 271 <td>4a</td>
273 <td>4a</td> 272 <td>5</td>
274 <td>5</td> 273 <td>4c</td>
275 <td>4c</td> 274 <td>0</td>
276 <td>0</td> 275 <td>52</td>
277 <td>52</td> 276 <td></td>
278 <td></td> 277 <td></td>
279 <td></td> 278 </tr>
280 </tr> 279 <tr class="odd">
281 <tr class="odd"> 280 <td>7</td>
282 <td>7</td> 281 <td>47</td>
283 <td>47</td> 282 <td>6</td>
284 <td>6</td> 283 <td>4d</td>
285 <td>4d</td> 284 <td>.</td>
286 <td>.</td> 285 <td>53</td>
287 <td>53</td> 286 <td></td>
288 <td></td> 287 <td></td>
289 <td></td> 288 </tr>
290 </tr> 289 </tbody>
291 </tbody> 290 </table>
292 </table>
293 </div>
294 <h3 id="附加键盘">附加键盘</h3> 291 <h3 id="附加键盘">附加键盘</h3>
295 <div class="table-div"> 292 <table>
296 <table> 293 <thead>
297 <thead> 294 <tr class="header">
298 <tr class="header"> 295 <th>key</th>
299 <th>key</th> 296 <th>mark</th>
300 <th>mark</th> 297 <th>key</th>
301 <th>key</th> 298 <th>mark</th>
302 <th>mark</th> 299 <th>key</th>
303 <th>key</th> 300 <th>mark</th>
304 <th>mark</th> 301 <th>key</th>
305 <th>key</th> 302 <th>mark</th>
306 <th>mark</th> 303 </tr>
307 </tr> 304 </thead>
308 </thead> 305 <tbody>
309 <tbody> 306 <tr class="odd">
310 <tr class="odd"> 307 <td>Scroll Lock</td>
311 <td>Scroll Lock</td> 308 <td>46</td>
312 <td>46</td> 309 <td>Page Up</td>
313 <td>Page Up</td> 310 <td>e0 49</td>
314 <td>e0 49</td> 311 <td>Page Down</td>
315 <td>Page Down</td> 312 <td>e0 51</td>
316 <td>e0 51</td> 313 <td>Up</td>
317 <td>Up</td> 314 <td>e0 48</td>
318 <td>e0 48</td> 315 </tr>
319 </tr> 316 <tr class="even">
320 <tr class="even"> 317 <td>Insert</td>
321 <td>Insert</td> 318 <td>e0 52</td>
322 <td>e0 52</td> 319 <td>Delete</td>
323 <td>Delete</td> 320 <td>e0 53</td>
324 <td>e0 53</td> 321 <td>Left</td>
325 <td>Left</td> 322 <td>e0 46</td>
326 <td>e0 46</td> 323 <td>Down</td>
327 <td>Down</td> 324 <td>e0 50</td>
328 <td>e0 50</td> 325 </tr>
329 </tr> 326 <tr class="odd">
330 <tr class="odd"> 327 <td>Home</td>
331 <td>Home</td> 328 <td>e0 47</td>
332 <td>e0 47</td> 329 <td>End</td>
333 <td>End</td> 330 <td>e0 4f</td>
334 <td>e0 4f</td> 331 <td>Right</td>
335 <td>Right</td> 332 <td>e0 4d</td>
336 <td>e0 4d</td> 333 <td></td>
337 <td></td> 334 <td></td>
338 <td></td> 335 </tr>
339 </tr> 336 </tbody>
340 </tbody> 337 </table>
341 </table>
342 </div>
343 <h3 id="功能键">功能键</h3> 338 <h3 id="功能键">功能键</h3>
344 <div class="table-div"> 339 <table>
345 <table> 340 <thead>
346 <thead> 341 <tr class="header">
347 <tr class="header"> 342 <th>key</th>
348 <th>key</th> 343 <th>mark</th>
349 <th>mark</th> 344 <th>key</th>
350 <th>key</th> 345 <th>mark</th>
351 <th>mark</th> 346 <th>key</th>
352 <th>key</th> 347 <th>mark</th>
353 <th>mark</th> 348 <th>key</th>
354 <th>key</th> 349 <th>mark</th>
355 <th>mark</th> 350 </tr>
356 </tr> 351 </thead>
357 </thead> 352 <tbody>
358 <tbody> 353 <tr class="odd">
359 <tr class="odd"> 354 <td>Esc</td>
360 <td>Esc</td> 355 <td>1</td>
361 <td>1</td> 356 <td>F1</td>
362 <td>F1</td> 357 <td>3b</td>
363 <td>3b</td> 358 <td>F5</td>
364 <td>F5</td> 359 <td>3f</td>
365 <td>3f</td> 360 <td>F9</td>
366 <td>F9</td> 361 <td>43</td>
367 <td>43</td> 362 </tr>
368 </tr> 363 <tr class="even">
369 <tr class="even"> 364 <td></td>
370 <td></td> 365 <td></td>
371 <td></td> 366 <td>F2</td>
372 <td>F2</td> 367 <td>3c</td>
373 <td>3c</td> 368 <td>F6</td>
374 <td>F6</td> 369 <td>40</td>
375 <td>40</td> 370 <td>F10</td>
376 <td>F10</td> 371 <td>44</td>
377 <td>44</td> 372 </tr>
378 </tr> 373 <tr class="odd">
379 <tr class="odd"> 374 <td></td>
380 <td></td> 375 <td></td>
381 <td></td> 376 <td>F3</td>
382 <td>F3</td> 377 <td>3d</td>
383 <td>3d</td> 378 <td>F7</td>
384 <td>F7</td> 379 <td>41</td>
385 <td>41</td> 380 <td>F11</td>
386 <td>F11</td> 381 <td>57</td>
387 <td>57</td> 382 </tr>
388 </tr> 383 <tr class="even">
389 <tr class="even"> 384 <td></td>
390 <td></td> 385 <td></td>
391 <td></td> 386 <td>F4</td>
392 <td>F4</td> 387 <td>3e</td>
393 <td>3e</td> 388 <td>F8</td>
394 <td>F8</td> 389 <td>42</td>
395 <td>42</td> 390 <td>F12</td>
396 <td>F12</td> 391 <td>58</td>
397 <td>58</td> 392 </tr>
398 </tr> 393 </tbody>
399 </tbody> 394 </table>
400 </table>
401 </div>
402 <h3 id="媒体键">媒体键</h3> 395 <h3 id="媒体键">媒体键</h3>
403 <div class="table-div"> 396 <table>
404 <table> 397 <thead>
405 <thead> 398 <tr class="header">
406 <tr class="header"> 399 <th>key</th>
407 <th>key</th> 400 <th>mark</th>
408 <th>mark</th> 401 <th>key</th>
409 <th>key</th> 402 <th>mark</th>
410 <th>mark</th> 403 <th>key</th>
411 <th>key</th> 404 <th>mark</th>
412 <th>mark</th> 405 <th>key</th>
413 <th>key</th> 406 <th>mark</th>
414 <th>mark</th> 407 </tr>
415 </tr> 408 </thead>
416 </thead> 409 <tbody>
417 <tbody> 410 <tr class="odd">
418 <tr class="odd"> 411 <td>Mute</td>
419 <td>Mute</td> 412 <td>e0 20</td>
420 <td>e0 20</td> 413 <td>Paly/Pasue</td>
421 <td>Paly/Pasue</td> 414 <td>e0 22</td>
422 <td>e0 22</td> 415 <td>Volume Down</td>
423 <td>Volume Down</td> 416 <td>e0 2e</td>
424 <td>e0 2e</td> 417 <td>Stop</td>
425 <td>Stop</td> 418 <td>e0 24</td>
426 <td>e0 24</td> 419 </tr>
427 </tr> 420 <tr class="even">
428 <tr class="even"> 421 <td>Next Track</td>
429 <td>Next Track</td> 422 <td>e0 19</td>
430 <td>e0 19</td> 423 <td>Prev Track</td>
431 <td>Prev Track</td> 424 <td>e0 10</td>
432 <td>e0 10</td> 425 <td>Volume Up</td>
433 <td>Volume Up</td> 426 <td>e0 30</td>
434 <td>e0 30</td> 427 <td></td>
435 <td></td> 428 <td></td>
436 <td></td> 429 </tr>
437 </tr> 430 </tbody>
438 </tbody> 431 </table>
439 </table>
440 </div>
441 <h2 id="windows-其他热键映射">Windows 其他热键映射</h2> 432 <h2 id="windows-其他热键映射">Windows 其他热键映射</h2>
442 <p>除了简单的键位位置调换,我们可能还需要一些快捷键的映射。这里采用 Autohotkeys,注意下载合适版本(p.s.即使不合适,编写好了之后运行,也会提醒你版本不对,然后提示下载对应版本的)</p> 433 <p>除了简单的键位位置调换,我们可能还需要一些快捷键的映射。这里采用 Autohotkeys,注意下载合适版本(p.s.即使不合适,编写好了之后运行,也会提醒你版本不对,然后提示下载对应版本的)</p>
443 <p>下载安装之后,打开应用,创建一个新脚本,路径自己设置,按以下方式进行编写。</p> 434 <p>下载安装之后,打开应用,创建一个新脚本,路径自己设置,按以下方式进行编写。</p>
444 <h3 id="简单更换按键">简单更换按键</h3> 435 <h3 id="简单更换按键">简单更换按键</h3>
445 <p>方法极为简单,如下:</p> 436 <p>方法极为简单,如下:</p>
446 <pre class="vim"><code>A::B 437 <pre><code class="language-plaintext">A::B
447B::A</code></pre> 438B::A</code></pre>
448 <p>其中 A 与 B 是需要更换位置的按键。</p> 439 <p>其中 A 与 B 是需要更换位置的按键。</p>
449 <h3 id="脚本运行">脚本运行</h3> 440 <h3 id="脚本运行">脚本运行</h3>
@@ -452,8 +443,7 @@ B::A</code></pre>
452 </p> 443 </p>
453 <h3 id="一个复杂设计">一个复杂设计</h3> 444 <h3 id="一个复杂设计">一个复杂设计</h3>
454 <p>在<a href="https://csdiy.wiki">CS 自学指南</a>中提到,这个<a 445 <p>在<a href="https://csdiy.wiki">CS 自学指南</a>中提到,这个<a
455 href="https://gist.github.com/sedm0784/4443120">Autohotkey 446 href="https://gist.github.com/sedm0784/4443120">Autohotkey gist</a>将 CapsLock 设置为以下功能:</p>
456 gist</a>将 CapsLock 设置为以下功能:</p>
457 <ul> 447 <ul>
458 <li>在单独按下时,相当于 Escape</li> 448 <li>在单独按下时,相当于 Escape</li>
459 <li>在与其他按键一起按下时,相当于 Ctrl</li> 449 <li>在与其他按键一起按下时,相当于 Ctrl</li>
@@ -470,7 +460,7 @@ B::A</code></pre>
470 vim 中可行。</p> 460 vim 中可行。</p>
471 <h2 id="更换按键位置">更换按键位置</h2> 461 <h2 id="更换按键位置">更换按键位置</h2>
472 <p>如下:</p> 462 <p>如下:</p>
473 <pre><code># 进入对应文件夹 463 <pre><code class="language-bash"># 进入对应文件夹
474cd /usr/shared/X11/xkb/symbols 464cd /usr/shared/X11/xkb/symbols
475 465
476# 查看一下 466# 查看一下
@@ -486,10 +476,9 @@ cp pc pc_bkup
486vim pc 476vim pc
487 477
488# 退出root用户 478# 退出root用户
489exit 479exit</code></pre>
490</code></pre>
491 <p>在编辑 pc 文件时,可以看到,每一行的构成如下:</p> 480 <p>在编辑 pc 文件时,可以看到,每一行的构成如下:</p>
492 <pre class="vim"><code>key&lt;Esc&gt; { [ Escape ] }</code></pre> 481 <pre><code class="language-plaintext">key&lt;Esc&gt; { [ Escape ] }</code></pre>
493 <p>可以理解为键盘上的 Esc 键位是 Esc 键的功能。需要修改时,将中括号中内容修改。如:</p> 482 <p>可以理解为键盘上的 Esc 键位是 Esc 键的功能。需要修改时,将中括号中内容修改。如:</p>
494 <p>调换两个案件(如 Esc 与 CapsLock ),即将二者(本处分别在第 4、第 22 行)中括号中内容互换即可。</p> 483 <p>调换两个案件(如 Esc 与 CapsLock ),即将二者(本处分别在第 4、第 22 行)中括号中内容互换即可。</p>
495 <p class="time">2023.7.5</p> 484 <p class="time">2023.7.5</p>
diff --git a/code/linux/keymap.md b/code/linux/keymap.md
index 2df0f22..6cf8dd1 100644
--- a/code/linux/keymap.md
+++ b/code/linux/keymap.md
@@ -90,7 +90,7 @@
90 90
91方法极为简单,如下: 91方法极为简单,如下:
92 92
93```vim 93```plaintext
94A::B 94A::B
95B::A 95B::A
96``` 96```
@@ -128,7 +128,7 @@ B::A
128 128
129如下: 129如下:
130 130
131``` 131```bash
132# 进入对应文件夹 132# 进入对应文件夹
133cd /usr/shared/X11/xkb/symbols 133cd /usr/shared/X11/xkb/symbols
134 134
@@ -150,7 +150,7 @@ exit
150 150
151在编辑 pc 文件时,可以看到,每一行的构成如下: 151在编辑 pc 文件时,可以看到,每一行的构成如下:
152 152
153```vim 153```plaintext
154key<Esc> { [ Escape ] } 154key<Esc> { [ Escape ] }
155``` 155```
156 156
diff --git a/code/linux/vim.html b/code/linux/vim.html
index 75e0075..efff915 100644
--- a/code/linux/vim.html
+++ b/code/linux/vim.html
@@ -7,14 +7,16 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>vim学习与我的配置</title> 8 <title>vim学习与我的配置</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">vim学习与我的配置</p> 16 <header id="title-block-header">
17 <p class="title">vim学习与我的配置</p>
18 </header>
19 <!-- 我的vim设置 -->
18 <h1 id="vim-那是个什么-jb-东西">vim? 那是个什么 JB 东西?</h1> 20 <h1 id="vim-那是个什么-jb-东西">vim? 那是个什么 JB 东西?</h1>
19 <p>Enjoy coding 的你,是否时常痛恨鼠标点来点去、方向键远离字母,耽误码字?可曾詈骂手动批量重复处理的痛苦?Debug 21 <p>Enjoy coding 的你,是否时常痛恨鼠标点来点去、方向键远离字母,耽误码字?可曾詈骂手动批量重复处理的痛苦?Debug
20 时代码上下反复跳转,令你烦闷否?别人写的编辑器设置种种不便,是否想过有一个自己私人订制的编辑器?如果你有以上苦恼,那么 vim 将是你的绝佳选择。</p> 22 时代码上下反复跳转,令你烦闷否?别人写的编辑器设置种种不便,是否想过有一个自己私人订制的编辑器?如果你有以上苦恼,那么 vim 将是你的绝佳选择。</p>
@@ -52,355 +54,7 @@
52 </tbody> 54 </tbody>
53 </table> 55 </table>
54 <p>其关系如下:</p> 56 <p>其关系如下:</p>
55 <div class="md-diagram-panel md-fences-adv-panel" lang="mermaid"><svg id="mermaidChart0" width="100%" 57 <img src="https://www.qin-juan-ge-zhu.top/images/code/vim_mode.png">
56 xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
57 style="max-width: 262.825px; margin: auto;" viewBox="-8 -8 262.82501220703125 235.02500915527344"
58 role="graphics-document document" aria-roledescription="flowchart-v2">
59 <style>
60 #mermaidChart0 {
61 font-family: sans-serif;
62 font-size: 16px;
63 fill: #333;
64 }
65
66 #mermaidChart0 .error-icon {
67 fill: #552222;
68 }
69
70 #mermaidChart0 .error-text {
71 fill: #552222;
72 stroke: #552222;
73 }
74
75 #mermaidChart0 .edge-thickness-normal {
76 stroke-width: 2px;
77 }
78
79 #mermaidChart0 .edge-thickness-thick {
80 stroke-width: 3.5px;
81 }
82
83 #mermaidChart0 .edge-pattern-solid {
84 stroke-dasharray: 0;
85 }
86
87 #mermaidChart0 .edge-pattern-dashed {
88 stroke-dasharray: 3;
89 }
90
91 #mermaidChart0 .edge-pattern-dotted {
92 stroke-dasharray: 2;
93 }
94
95 #mermaidChart0 .marker {
96 fill: #333333;
97 stroke: #333333;
98 }
99
100 #mermaidChart0 .marker.cross {
101 stroke: #333333;
102 }
103
104 #mermaidChart0 svg {
105 font-family: sans-serif;
106 font-size: 16px;
107 }
108
109 #mermaidChart0 .label {
110 font-family: sans-serif;
111 color: #333;
112 }
113
114 #mermaidChart0 .cluster-label text {
115 fill: #333;
116 }
117
118 #mermaidChart0 .cluster-label span,
119 #mermaidChart0 p {
120 color: #333;
121 }
122
123 #mermaidChart0 .label text,
124 #mermaidChart0 span,
125 #mermaidChart0 p {
126 fill: #333;
127 color: #333;
128 }
129
130 #mermaidChart0 .node rect,
131 #mermaidChart0 .node circle,
132 #mermaidChart0 .node ellipse,
133 #mermaidChart0 .node polygon,
134 #mermaidChart0 .node path {
135 fill: #ECECFF;
136 stroke: #9370DB;
137 stroke-width: 1px;
138 }
139
140 #mermaidChart0 .flowchart-label text {
141 text-anchor: middle;
142 }
143
144 #mermaidChart0 .node .label {
145 text-align: center;
146 }
147
148 #mermaidChart0 .node.clickable {
149 cursor: pointer;
150 }
151
152 #mermaidChart0 .arrowheadPath {
153 fill: #333333;
154 }
155
156 #mermaidChart0 .edgePath .path {
157 stroke: #333333;
158 stroke-width: 2.0px;
159 }
160
161 #mermaidChart0 .flowchart-link {
162 stroke: #333333;
163 fill: none;
164 }
165
166 #mermaidChart0 .edgeLabel {
167 background-color: #e8e8e8;
168 text-align: center;
169 }
170
171 #mermaidChart0 .edgeLabel rect {
172 opacity: 0.5;
173 background-color: #e8e8e8;
174 fill: #e8e8e8;
175 }
176
177 #mermaidChart0 .labelBkg {
178 background-color: rgba(232, 232, 232, 0.5);
179 }
180
181 #mermaidChart0 .cluster rect {
182 fill: #ffffde;
183 stroke: #aaaa33;
184 stroke-width: 1px;
185 }
186
187 #mermaidChart0 .cluster text {
188 fill: #333;
189 }
190
191 #mermaidChart0 .cluster span,
192 #mermaidChart0 p {
193 color: #333;
194 }
195
196 #mermaidChart0 div.mermaidTooltip {
197 position: absolute;
198 text-align: center;
199 max-width: 200px;
200 padding: 2px;
201 font-family: sans-serif;
202 font-size: 12px;
203 background: hsl(80, 100%, 96.2745098039%);
204 border: 1px solid #aaaa33;
205 border-radius: 2px;
206 pointer-events: none;
207 z-index: 100;
208 }
209
210 #mermaidChart0 .flowchartTitleText {
211 text-anchor: middle;
212 font-size: 18px;
213 fill: #333;
214 }
215
216 #mermaidChart0 :root {
217 --mermaid-alt-font-family: sans-serif;
218 }
219 </style>
220 <g>
221 <marker id="mermaidChart0_flowchart-pointEnd" class="marker flowchart" viewBox="0 0 10 10"
222 refX="6" refY="5" markerUnits="userSpaceOnUse" markerWidth="12" markerHeight="12"
223 orient="auto">
224 <path d="M 0 0 L 10 5 L 0 10 z" class="arrowMarkerPath"
225 style="stroke-width: 1; stroke-dasharray: 1, 0;"></path>
226 </marker>
227 <marker id="mermaidChart0_flowchart-pointStart" class="marker flowchart" viewBox="0 0 10 10"
228 refX="4.5" refY="5" markerUnits="userSpaceOnUse" markerWidth="12" markerHeight="12"
229 orient="auto">
230 <path d="M 0 5 L 10 10 L 10 0 z" class="arrowMarkerPath"
231 style="stroke-width: 1; stroke-dasharray: 1, 0;"></path>
232 </marker>
233 <marker id="mermaidChart0_flowchart-circleEnd" class="marker flowchart" viewBox="0 0 10 10"
234 refX="11" refY="5" markerUnits="userSpaceOnUse" markerWidth="11" markerHeight="11"
235 orient="auto">
236 <circle cx="5" cy="5" r="5" class="arrowMarkerPath"
237 style="stroke-width: 1; stroke-dasharray: 1, 0;"></circle>
238 </marker>
239 <marker id="mermaidChart0_flowchart-circleStart" class="marker flowchart" viewBox="0 0 10 10"
240 refX="-1" refY="5" markerUnits="userSpaceOnUse" markerWidth="11" markerHeight="11"
241 orient="auto">
242 <circle cx="5" cy="5" r="5" class="arrowMarkerPath"
243 style="stroke-width: 1; stroke-dasharray: 1, 0;"></circle>
244 </marker>
245 <marker id="mermaidChart0_flowchart-crossEnd" class="marker cross flowchart" viewBox="0 0 11 11"
246 refX="12" refY="5.2" markerUnits="userSpaceOnUse" markerWidth="11" markerHeight="11"
247 orient="auto">
248 <path d="M 1,1 l 9,9 M 10,1 l -9,9" class="arrowMarkerPath"
249 style="stroke-width: 2; stroke-dasharray: 1, 0;"></path>
250 </marker>
251 <marker id="mermaidChart0_flowchart-crossStart" class="marker cross flowchart"
252 viewBox="0 0 11 11" refX="-1" refY="5.2" markerUnits="userSpaceOnUse" markerWidth="11"
253 markerHeight="11" orient="auto">
254 <path d="M 1,1 l 9,9 M 10,1 l -9,9" class="arrowMarkerPath"
255 style="stroke-width: 2; stroke-dasharray: 1, 0;"></path>
256 </marker>
257 <g class="root">
258 <g class="clusters"></g>
259 <g class="edgePaths">
260 <path d="M48.358,89.675L97.363,9.837L122.363,9.837L147.363,9.837L175.048,14.286"
261 id="L-N-I-0"
262 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-N LE-I"
263 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
264 <path d="M71.02,89.675L97.363,74.675L122.363,74.675L147.363,74.675L174.744,90.003"
265 id="L-N-V-0"
266 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-N LE-V"
267 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
268 <path d="M58.314,129.35L97.363,164.35L122.363,164.35L147.363,164.35L169.533,176.761"
269 id="L-N-R-0"
270 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-N LE-R"
271 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
272 <path d="M180.281,36.247L147.363,54.675L122.363,54.675L97.363,54.675L62.26,86.138"
273 id="L-I-N-0"
274 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-I LE-N"
275 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
276 <path d="M179.369,126.433L147.363,144.35L122.363,144.35L97.363,144.35L75.625,131.973"
277 id="L-V-N-0"
278 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-V LE-N"
279 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
280 <path d="M172.363,205.17L147.363,209.187L122.363,209.187L97.363,209.187L51.13,133.867"
281 id="L-R-N-0"
282 class=" edge-thickness-normal edge-pattern-solid flowchart-link LS-R LE-N"
283 style="fill:none;" marker-end="url(#mermaidChart0_flowchart-pointEnd)"></path>
284 </g>
285 <g class="edgeLabels">
286 <g class="edgeLabel">
287 <g class="label" transform="translate(0, 0)">
288 <foreignObject width="0" height="0">
289 <div xmlns="http://www.w3.org/1999/xhtml"
290 style="display: inline-block; white-space: nowrap;"><span
291 class="edgeLabel"></span></div>
292 </foreignObject>
293 </g>
294 </g>
295 <g class="edgeLabel">
296 <g class="label" transform="translate(0, 0)">
297 <foreignObject width="0" height="0">
298 <div xmlns="http://www.w3.org/1999/xhtml"
299 style="display: inline-block; white-space: nowrap;"><span
300 class="edgeLabel"></span></div>
301 </foreignObject>
302 </g>
303 </g>
304 <g class="edgeLabel">
305 <g class="label" transform="translate(0, 0)">
306 <foreignObject width="0" height="0">
307 <div xmlns="http://www.w3.org/1999/xhtml"
308 style="display: inline-block; white-space: nowrap;"><span
309 class="edgeLabel"></span></div>
310 </foreignObject>
311 </g>
312 </g>
313 <g class="edgeLabel">
314 <g class="label" transform="translate(0, 0)">
315 <foreignObject width="0" height="0">
316 <div xmlns="http://www.w3.org/1999/xhtml"
317 style="display: inline-block; white-space: nowrap;"><span
318 class="edgeLabel"></span></div>
319 </foreignObject>
320 </g>
321 </g>
322 <g class="edgeLabel">
323 <g class="label" transform="translate(0, 0)">
324 <foreignObject width="0" height="0">
325 <div xmlns="http://www.w3.org/1999/xhtml"
326 style="display: inline-block; white-space: nowrap;"><span
327 class="edgeLabel"></span></div>
328 </foreignObject>
329 </g>
330 </g>
331 <g class="edgeLabel">
332 <g class="label" transform="translate(0, 0)">
333 <foreignObject width="0" height="0">
334 <div xmlns="http://www.w3.org/1999/xhtml"
335 style="display: inline-block; white-space: nowrap;"><span
336 class="edgeLabel"></span></div>
337 </foreignObject>
338 </g>
339 </g>
340 </g>
341 <g class="nodes">
342 <g class="node default default flowchart-label" id="flowchart-N-0"
343 transform="translate(36.181251525878906, 109.51249885559082)">
344 <rect class="basic label-container" style="" rx="5" ry="5" x="-36.18124961853027"
345 y="-19.83750057220459" width="72.36249923706055" height="39.67500114440918">
346 </rect>
347 <g class="label" style=""
348 transform="translate(-28.681249618530273, -12.33750057220459)">
349 <rect></rect>
350 <foreignObject width="57.36249923706055" height="24.67500114440918">
351 <div xmlns="http://www.w3.org/1999/xhtml"
352 style="display: inline-block; white-space: nowrap;"><span
353 class="nodeLabel">Normal</span></div>
354 </foreignObject>
355 </g>
356 </g>
357 <g class="node default default flowchart-label" id="flowchart-I-1"
358 transform="translate(209.59375381469727, 19.837499618530273)">
359 <rect class="basic label-container" style="" rx="5" ry="5" x="-29.3125"
360 y="-19.83750057220459" width="58.625" height="39.67500114440918"></rect>
361 <g class="label" style="" transform="translate(-21.8125, -12.33750057220459)">
362 <rect></rect>
363 <foreignObject width="43.625" height="24.67500114440918">
364 <div xmlns="http://www.w3.org/1999/xhtml"
365 style="display: inline-block; white-space: nowrap;"><span
366 class="nodeLabel">Insert</span></div>
367 </foreignObject>
368 </g>
369 </g>
370 <g class="node default default flowchart-label" id="flowchart-V-3"
371 transform="translate(209.59375381469727, 109.51249885559082)">
372 <rect class="basic label-container" style="" rx="5" ry="5" x="-30.225000381469727"
373 y="-19.83750057220459" width="60.45000076293945" height="39.67500114440918">
374 </rect>
375 <g class="label" style=""
376 transform="translate(-22.725000381469727, -12.33750057220459)">
377 <rect></rect>
378 <foreignObject width="45.45000076293945" height="24.67500114440918">
379 <div xmlns="http://www.w3.org/1999/xhtml"
380 style="display: inline-block; white-space: nowrap;"><span
381 class="nodeLabel">Visual</span></div>
382 </foreignObject>
383 </g>
384 </g>
385 <g class="node default default flowchart-label" id="flowchart-R-5"
386 transform="translate(209.59375381469727, 199.18749809265137)">
387 <rect class="basic label-container" style="" rx="5" ry="5" x="-37.23125076293945"
388 y="-19.83750057220459" width="74.4625015258789" height="39.67500114440918">
389 </rect>
390 <g class="label" style=""
391 transform="translate(-29.731250762939453, -12.33750057220459)">
392 <rect></rect>
393 <foreignObject width="59.462501525878906" height="24.67500114440918">
394 <div xmlns="http://www.w3.org/1999/xhtml"
395 style="display: inline-block; white-space: nowrap;"><span
396 class="nodeLabel">Replace</span></div>
397 </foreignObject>
398 </g>
399 </g>
400 </g>
401 </g>
402 </g>
403 </svg></div>
404 <h1 id="我的-vim-学习路线">我的 vim 学习路线</h1> 58 <h1 id="我的-vim-学习路线">我的 vim 学习路线</h1>
405 <p>不幸的是 Vim 的学习曲线确实相当陡峭,最开始你会觉得非常不适应,但一旦熬过了初始阶段,你会爱上 Vim。以我而言,现在离开了 vim 的模式几乎已经快不会写材料了,前几天交作业要求 59 <p>不幸的是 Vim 的学习曲线确实相当陡峭,最开始你会觉得非常不适应,但一旦熬过了初始阶段,你会爱上 Vim。以我而言,现在离开了 vim 的模式几乎已经快不会写材料了,前几天交作业要求
406 word,我保存文件居然不是<kbd>Ctrl+s</kbd>,而是顺手来了个<kbd>:wq</kbd>。</p> 60 word,我保存文件居然不是<kbd>Ctrl+s</kbd>,而是顺手来了个<kbd>:wq</kbd>。</p>
@@ -446,11 +100,11 @@
446 </ul> 100 </ul>
447 <h2 id="清理干净">清理干净</h2> 101 <h2 id="清理干净">清理干净</h2>
448 <p>下载的第一步当然是卸载当前系统具有的 vim 了。除此之外,由于 Python2 过于老旧,我选择不支持 Python2 仅支持 Python3 的 vim,因此也将 Python2 卸载。</p> 102 <p>下载的第一步当然是卸载当前系统具有的 vim 了。除此之外,由于 Python2 过于老旧,我选择不支持 Python2 仅支持 Python3 的 vim,因此也将 Python2 卸载。</p>
449 <pre><code>sudo apt autoremove vim rvim gvim vim-runtime 103 <pre><code class="language-bash">sudo apt autoremove vim rvim gvim vim-runtime
450sudo apt autoremove python2*</code></pre> 104sudo apt autoremove python2*</code></pre>
451 <h2 id="做好准备">做好准备</h2> 105 <h2 id="做好准备">做好准备</h2>
452 <p>为了编译能够支持 python3/rust/perl/lua 等语言的 vim,我们需要安装一些包。</p> 106 <p>为了编译能够支持 python3/rust/perl/lua 等语言的 vim,我们需要安装一些包。</p>
453 <pre><code>sudo apt install -y git \ 107 <pre><code class="language-bash">sudo apt install -y git \
454 libatk1.0-dev \ 108 libatk1.0-dev \
455 libcairo2-dev \ 109 libcairo2-dev \
456 liblua5.1-0-dev \ 110 liblua5.1-0-dev \
@@ -470,7 +124,7 @@ sudo apt autoremove python2*</code></pre>
470 <h2 id="下载源码">下载源码</h2> 124 <h2 id="下载源码">下载源码</h2>
471 <p>vim 源码可以通过其<a href="https://github.com/vim/vim">GitHub 仓库</a>下载,也可以在其<a 125 <p>vim 源码可以通过其<a href="https://github.com/vim/vim">GitHub 仓库</a>下载,也可以在其<a
472 href="https://www.vim.org/download.php">官网</a>下载。我选择了前者。</p> 126 href="https://www.vim.org/download.php">官网</a>下载。我选择了前者。</p>
473 <pre><code>git clone https://github.com/vim/vim 127 <pre><code class="language-bash">git clone https://github.com/vim/vim
474 128
475# 后续处理过程都在源码目录下的src目录内进行,因而切换过去 129# 后续处理过程都在源码目录下的src目录内进行,因而切换过去
476cd vim/src 130cd vim/src
@@ -482,7 +136,7 @@ sudo make distclean</code></pre>
482 <p>vim 136 <p>vim
483 的编译过程中,需要先运行<code>configure</code>脚本,该脚本会检查当前系统的环境,并以参数形式接收你需要哪些功能。可以通过<code>./configure --help</code>查看所有可选参数及其功能说明。我选择的参数如下: 137 的编译过程中,需要先运行<code>configure</code>脚本,该脚本会检查当前系统的环境,并以参数形式接收你需要哪些功能。可以通过<code>./configure --help</code>查看所有可选参数及其功能说明。我选择的参数如下:
484 </p> 138 </p>
485 <pre><code>sudo ./configure\ 139 <pre><code class="language-bash">sudo ./configure\
486 --with-features=huge \ 140 --with-features=huge \
487 --enable-multibyte \ 141 --enable-multibyte \
488 --enable-rubyinterp=dynamic \ 142 --enable-rubyinterp=dynamic \
@@ -522,7 +176,7 @@ sudo make distclean</code></pre>
522 </p> 176 </p>
523 <h3 id="编译安装">编译安装</h3> 177 <h3 id="编译安装">编译安装</h3>
524 <p>编译安装过程简单到无以复加,就几句话的事。</p> 178 <p>编译安装过程简单到无以复加,就几句话的事。</p>
525 <pre><code># 编译 179 <pre><code class="language-bash"># 编译
526sudo make 180sudo make
527# 安装 181# 安装
528sudo make install</code></pre> 182sudo make install</code></pre>
@@ -537,7 +191,7 @@ sudo make install</code></pre>
537 的配置文件放置在<code>/etc/vim</code>下,这样不论是普通用户还是 root 191 的配置文件放置在<code>/etc/vim</code>下,这样不论是普通用户还是 root
538 用户,都会使用这份文件,保证观感一致。另外,由于该文件位置较远,我选择在<code>~/useful</code>下创建软链接,方便使用。</p> 192 用户,都会使用这份文件,保证观感一致。另外,由于该文件位置较远,我选择在<code>~/useful</code>下创建软链接,方便使用。</p>
539 <p>除此之外,出于同样的目的(保证当前用户与 root 用户观感一致),建议将插件也指定一个专门的绝对路径。我放在了<code>/home/player/useful/bundle</code>。</p> 193 <p>除此之外,出于同样的目的(保证当前用户与 root 用户观感一致),建议将插件也指定一个专门的绝对路径。我放在了<code>/home/player/useful/bundle</code>。</p>
540 <pre><code># 创建软链接 194 <pre><code class="language-bash"># 创建软链接
541# 我习惯把有用的文件放在~/useful下 195# 我习惯把有用的文件放在~/useful下
542mkdir useful 196mkdir useful
543cd useful 197cd useful
@@ -551,20 +205,17 @@ mkdir bundle</code></pre>
551 <p>这里原本记录着我的旧版 vim 配置,但随着<a href="https://www.qin-juan-ge-zhu.top/code/linux/httpmyserver.html">http 205 <p>这里原本记录着我的旧版 vim 配置,但随着<a href="https://www.qin-juan-ge-zhu.top/code/linux/httpmyserver.html">http
552 浏览服务器文件</a>的完成,再保留旧版然后每隔三四个月更新一次,对于我这种没事就折腾的人来说说,就显得不那么必要了。因此,这里只简单说一下。</p> 206 浏览服务器文件</a>的完成,再保留旧版然后每隔三四个月更新一次,对于我这种没事就折腾的人来说说,就显得不那么必要了。因此,这里只简单说一下。</p>
553 <p>配置的整体结构如下:</p> 207 <p>配置的整体结构如下:</p>
554 <pre><code>/etc/vim 208 <pre><code class="language-plaintext">/etc/vim
555├── vimrc # vim配置文件,负责引入不同的配置模块 209├── vimrc # vim配置文件,负责引入不同的配置模块
556├── vimrc_origin # 原有配置脚本备份 210└── vimrcs # 我的配置文件夹,里边是不同的配置模块
557├── vimrcs # 我的配置文件夹,里边是不同的配置模块 211    ├── autocmd.vim
558│   ├── autocmd.vim 212    ├── codecmd.vim
559│   ├── codecmd.vim 213    ├── keybind.vim
560│   ├── keybind.vim 214    ├── match.vim
561│   ├── match.vim 215    ├── myset.vim
562│   ├── myset.vim 216    ├── plugs.vim
563│   ├── plugs.vim 217    └── statusline.vim</code></pre>
564│   └── statusline.vim 218 <p>我直接把我服务器上的配置文件<a href="https://git.qin-juan-ge-zhu.top/vimrc">放在这里</a>,以供查看。</p>
565├── vimrc.tiny # 原有脚本,无用
566└── vimscript.vim # 原有脚本,无用</code></pre>
567 <p>我直接把我服务器上的配置文件<a href="https://file.qin-juan-ge-zhu.top/useful/vim/">放在这里</a>,以供查看。</p>
568 <p class="time">2023.7.5<br>2023.9.6<br>2024.1.3</p> 219 <p class="time">2023.7.5<br>2023.9.6<br>2024.1.3</p>
569 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script> 220 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
570 </div> 221 </div>
diff --git a/code/linux/vim.md b/code/linux/vim.md
index 4d21b25..616d5c5 100644
--- a/code/linux/vim.md
+++ b/code/linux/vim.md
@@ -169,7 +169,7 @@ sudo make install
169 169
170除此之外,出于同样的目的(保证当前用户与 root 用户观感一致),建议将插件也指定一个专门的绝对路径。我放在了`/home/player/useful/bundle`。 170除此之外,出于同样的目的(保证当前用户与 root 用户观感一致),建议将插件也指定一个专门的绝对路径。我放在了`/home/player/useful/bundle`。
171 171
172``` 172```bash
173# 创建软链接 173# 创建软链接
174# 我习惯把有用的文件放在~/useful下 174# 我习惯把有用的文件放在~/useful下
175mkdir useful 175mkdir useful
@@ -191,17 +191,14 @@ mkdir bundle
191```plaintext 191```plaintext
192/etc/vim 192/etc/vim
193├── vimrc # vim配置文件,负责引入不同的配置模块 193├── vimrc # vim配置文件,负责引入不同的配置模块
194├── vimrc_origin # 原有配置脚本备份 194└── vimrcs # 我的配置文件夹,里边是不同的配置模块
195├── vimrcs # 我的配置文件夹,里边是不同的配置模块 195    ├── autocmd.vim
196│   ├── autocmd.vim 196    ├── codecmd.vim
197│   ├── codecmd.vim 197    ├── keybind.vim
198│   ├── keybind.vim 198    ├── match.vim
199│   ├── match.vim 199    ├── myset.vim
200│   ├── myset.vim 200    ├── plugs.vim
201│   ├── plugs.vim 201    └── statusline.vim
202│   └── statusline.vim
203├── vimrc.tiny # 原有脚本,无用
204└── vimscript.vim # 原有脚本,无用
205``` 202```
206 203
207我直接把我服务器上的配置文件[放在这里](https://file.qin-juan-ge-zhu.top/useful/vim/),以供查看。 204我直接把我服务器上的配置文件[放在这里](https://git.qin-juan-ge-zhu.top/vimrc),以供查看。
diff --git a/code/projects/godo.html b/code/projects/godo.html
index ed64840..c967797 100644
--- a/code/projects/godo.html
+++ b/code/projects/godo.html
@@ -6,15 +6,16 @@
6 <meta name="generator" content="pandoc" /> 6 <meta name="generator" content="pandoc" />
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>godo知识总结</title> 8 <title>godo知识总结</title>
9 <link rel="stylesheet" href="https://test.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://test.qin-juan-ge-zhu.top/common/js/myhighlight.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
11 <script type="text/javascript" src="https://test.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">godo知识总结</p> 16 <header id="title-block-header">
17 <p class="title">godo知识总结</p>
18 </header>
18 <h1 id="背景说明">背景说明</h1> 19 <h1 id="背景说明">背景说明</h1>
19 <p>本文档对<a href="https://git.qin-juan-ge-zhu.top/godo">godo</a>编写过程中新了解到的技术、遇到的问题进行简要说明,以备所需。</p> 20 <p>本文档对<a href="https://git.qin-juan-ge-zhu.top/godo">godo</a>编写过程中新了解到的技术、遇到的问题进行简要说明,以备所需。</p>
20 <h1 id="系统调用">系统调用</h1> 21 <h1 id="系统调用">系统调用</h1>
@@ -31,7 +32,7 @@
31 <li>在 C 语言中直接调用同名函数,但大概率经过了 glibc 的封装</li> 32 <li>在 C 语言中直接调用同名函数,但大概率经过了 glibc 的封装</li>
32 <li>手动封装。如下:</li> 33 <li>手动封装。如下:</li>
33 </ul> 34 </ul>
34 <pre><code>#include &lt;stdio.h&gt; 35 <pre><code class="language-c">#include &lt;stdio.h&gt;
35#include &lt;sys/syscall.h&gt; 36#include &lt;sys/syscall.h&gt;
36#include &lt;sys/types.h&gt; 37#include &lt;sys/types.h&gt;
37#include &lt;sys/wait.h&gt; 38#include &lt;sys/wait.h&gt;
@@ -50,7 +51,7 @@ int main(){
50 return 0; 51 return 0;
51}</code></pre> 52}</code></pre>
52 <p>这种封装方式与经常被用来当作 os 教材的 Linux-0.11/0.12 有所区别。Linux-0.11 环境上,unistd.h 大致如下:</p> 53 <p>这种封装方式与经常被用来当作 os 教材的 Linux-0.11/0.12 有所区别。Linux-0.11 环境上,unistd.h 大致如下:</p>
53 <pre><code>#ifndef _UNISTD_H 54 <pre><code class="language-c">#ifndef _UNISTD_H
54#define _UNISTD_H 55#define _UNISTD_H
55 56
56... 57...
@@ -102,7 +103,7 @@ return -1; \
102 103
103#endif</code></pre> 104#endif</code></pre>
104 <p>可以看到,Linux-0.11 上,封装的一般方法为:</p> 105 <p>可以看到,Linux-0.11 上,封装的一般方法为:</p>
105 <pre><code>#define __LIBRARY__ // 一定要在unistd.h之前 106 <pre><code class="language-c">#define __LIBRARY__ // 一定要在unistd.h之前
106#include &lt;unistd.h&gt; 107#include &lt;unistd.h&gt;
107#include &lt;stdio.h&gt; 108#include &lt;stdio.h&gt;
108 109
@@ -124,13 +125,13 @@ int main() {
124 tasks 表里的一个 task,而每个 task 才具有独一无二的 id</strong>。</p> 125 tasks 表里的一个 task,而每个 task 才具有独一无二的 id</strong>。</p>
125 <h3 id="常见系统调用的分析">常见系统调用的分析</h3> 126 <h3 id="常见系统调用的分析">常见系统调用的分析</h3>
126 <p>看看这个:</p> 127 <p>看看这个:</p>
127 <pre><code>extern int pthread_create (pthread_t *__restrict __newthread, 128 <pre><code class="language-c">extern int pthread_create (pthread_t *__restrict __newthread,
128 const pthread_attr_t *__restrict __attr, 129 const pthread_attr_t *__restrict __attr,
129 void *(*__start_routine) (void *), 130 void *(*__start_routine) (void *),
130 void *__restrict __arg) __THROWNL __nonnull ((1, 3));</code></pre> 131 void *__restrict __arg) __THROWNL __nonnull ((1, 3));</code></pre>
131 <p><code>pthread_create</code>函数的第一个参数,就是一个 pthread_t 类型的指针,处理后将 task 的 id 写到指针指向的区域。</p> 132 <p><code>pthread_create</code>函数的第一个参数,就是一个 pthread_t 类型的指针,处理后将 task 的 id 写到指针指向的区域。</p>
132 <p>让我们来看一段简单的代码:</p> 133 <p>让我们来看一段简单的代码:</p>
133 <pre><code>// test.c 134 <pre><code class="language-c">// test.c
134#include &lt;stdio.h&gt; 135#include &lt;stdio.h&gt;
135#include &lt;pthread.h&gt; 136#include &lt;pthread.h&gt;
136#include &lt;sys/syscall.h&gt; 137#include &lt;sys/syscall.h&gt;
@@ -160,7 +161,7 @@ int main() {
160 return 0; 161 return 0;
161}</code></pre> 162}</code></pre>
162 <p>当我们使用<code>strace ./test</code>来查看上述代码时,会发现情况如下:</p> 163 <p>当我们使用<code>strace ./test</code>来查看上述代码时,会发现情况如下:</p>
163 <pre><code>clone(child_stack=0x7f3dd28bbff0, flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM|CLONE_SETTLS|CLONE_PARENT_SETTID|CLONE_CHILD_CLEARTID, parent_tidptr=0x7f3dd28bc9d0, tls=0x7f3dd28bc700, child_tidptr=0x7f3dd28bc9d0) = 21756 164 <pre><code class="language-c">clone(child_stack=0x7f3dd28bbff0, flags=CLONE_VM|CLONE_FS|CLONE_FILES|CLONE_SIGHAND|CLONE_THREAD|CLONE_SYSVSEM|CLONE_SETTLS|CLONE_PARENT_SETTID|CLONE_CHILD_CLEARTID, parent_tidptr=0x7f3dd28bc9d0, tls=0x7f3dd28bc700, child_tidptr=0x7f3dd28bc9d0) = 21756
164write(1, &quot;main: thread 139903502108416\n&quot;, 29) = 29 165write(1, &quot;main: thread 139903502108416\n&quot;, 29) = 29
165clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7f3dd308e9d0) = 21757 166clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7f3dd308e9d0) = 21757
166--- SIGCHLD {si_signo=SIGCHLD, si_code=CLD_EXITED, si_pid=21757, si_uid=1000, si_status=0, si_utime=0, si_stime=0} --- 167--- SIGCHLD {si_signo=SIGCHLD, si_code=CLD_EXITED, si_pid=21757, si_uid=1000, si_status=0, si_utime=0, si_stime=0} ---
@@ -173,7 +174,7 @@ exit_group(0) = ?
173 <p>从这样的输出里,我们可以清晰地看到,<strong>无论是<code>pthread_create</code>还是<code>fork</code>(指库函数),本质上都是封装了<code>clone</code>系统调用,即使 174 <p>从这样的输出里,我们可以清晰地看到,<strong>无论是<code>pthread_create</code>还是<code>fork</code>(指库函数),本质上都是封装了<code>clone</code>系统调用,即使
174 Linux 本身提供了专门的 fork 系统调用。</strong>也许这是 glibc 和 Linux 都想在添加功能的基础上保证代码兼容性?花开两朵各表一枝了属于是。</p> 175 Linux 本身提供了专门的 fork 系统调用。</strong>也许这是 glibc 和 Linux 都想在添加功能的基础上保证代码兼容性?花开两朵各表一枝了属于是。</p>
175 <p>这一结论也可以从 glibc 的代码中得到验证:</p> 176 <p>这一结论也可以从 glibc 的代码中得到验证:</p>
176 <pre><code>// 文件 glibc-2.18/nptl/sysdeps/unix/sysv/linux/pt-fork.c 177 <pre><code class="language-c">// 文件 glibc-2.18/nptl/sysdeps/unix/sysv/linux/pt-fork.c
177pid_t 178pid_t
178__fork (void) 179__fork (void)
179{ 180{
@@ -354,7 +355,8 @@ PSEUDO_END (syscall)</code></pre>
354 <li>gcc 技术大全</li> 355 <li>gcc 技术大全</li>
355 <li>黑客调试技术大全</li> 356 <li>黑客调试技术大全</li>
356 </ul> 357 </ul>
357 <script src="https://test.qin-juan-ge-zhu.top/common/js/comment.js"></script> 358 <p class="time">2024.8</p>
359 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
358 </div> 360 </div>
359 </div> 361 </div>
360</body> 362</body>
diff --git a/code/projects/lcm_compile.html b/code/projects/lcm_compile.html
index d889b58..7aa390a 100644
--- a/code/projects/lcm_compile.html
+++ b/code/projects/lcm_compile.html
@@ -7,14 +7,15 @@
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>LCM 交叉编译</title> 8 <title>LCM 交叉编译</title>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">LCM 交叉编译</p> 16 <header id="title-block-header">
17 <p class="title">LCM 交叉编译</p>
18 </header>
18 <!-- 编译集成lcm模块 --> 19 <!-- 编译集成lcm模块 -->
19 <h1 id="lcm-简介">LCM 简介</h1> 20 <h1 id="lcm-简介">LCM 简介</h1>
20 <p>LCM(Lightweight Communications and 21 <p>LCM(Lightweight Communications and
@@ -28,13 +29,13 @@
28 <li><a href="https://zhuanlan.zhihu.com/p/621943685">一篇博客</a></li> 29 <li><a href="https://zhuanlan.zhihu.com/p/621943685">一篇博客</a></li>
29 </ul> 30 </ul>
30 <h1 id="依赖项安装">依赖项安装</h1> 31 <h1 id="依赖项安装">依赖项安装</h1>
31 <pre><code>sudo apt update 32 <pre><code class="language-bash">sudo apt update
32sudo apt upgrade 33sudo apt upgrade
33sudo apt install build-essential cmake libglib2.0-dev 34sudo apt install build-essential cmake libglib2.0-dev
34sudo apt install openjdk-8-jdk # lcm仅支持jdk8</code></pre> 35sudo apt install openjdk-8-jdk # lcm仅支持jdk8</code></pre>
35 <h1 id="x86-的-lcm">x86 的 lcm</h1> 36 <h1 id="x86-的-lcm">x86 的 lcm</h1>
36 <p>如果我们仅仅需要 x86 架构的 lcm,执行下列命令即可:</p> 37 <p>如果我们仅仅需要 x86 架构的 lcm,执行下列命令即可:</p>
37 <pre><code>git clone https://github.com/lcm-proj/lcm 38 <pre><code class="language-bash">git clone https://github.com/lcm-proj/lcm
38cd lcm 39cd lcm
39mkdir build &amp;&amp; cd build 40mkdir build &amp;&amp; cd build
40cmake .. 41cmake ..
@@ -48,14 +49,14 @@ sudo make install</code></pre>
48 <p>lcm-spy 是 LCM 配套的数据可视化工具。 可以通过 lcm-spy 监视 lcm 数据发送频率、数据量、数据结构,甚至实时画图。 如果安装了 JAVA,则 lcm-spy 会连同 LCM 一同被安装。 49 <p>lcm-spy 是 LCM 配套的数据可视化工具。 可以通过 lcm-spy 监视 lcm 数据发送频率、数据量、数据结构,甚至实时画图。 如果安装了 JAVA,则 lcm-spy 会连同 LCM 一同被安装。
49 </p> 50 </p>
50 <p>启动 lcm-spy:</p> 51 <p>启动 lcm-spy:</p>
51 <pre><code>export CLASSPATH=${your lcm-type class path} 52 <pre><code class="language-bash">export CLASSPATH=${your lcm-type class path}
52lcm-spy</code></pre> 53lcm-spy</code></pre>
53 <h1 id="交叉编译">交叉编译</h1> 54 <h1 id="交叉编译">交叉编译</h1>
54 <p>既然 lcm 用的是 cmake,何不交叉编译到 OHOS 里用呢?</p> 55 <p>既然 lcm 用的是 cmake,何不交叉编译到 OHOS 里用呢?</p>
55 <p>首先,我们可以设置一下 Native Development Kit(NDK)的路径:</p> 56 <p>首先,我们可以设置一下 Native Development Kit(NDK)的路径:</p>
56 <pre><code># 设置成自己的NDK工具目录 57 <pre><code class="language-bash"># 设置成自己的NDK工具目录
57export OHOS_ROOT=~/app/native</code></pre> 58export OHOS_ROOT=~/app/native</code></pre>
58 <pre><code>$OHOS_ROOT/build-tools/cmake/bin/cmake \ 59 <pre><code class="language-bash">$OHOS_ROOT/build-tools/cmake/bin/cmake \
59 -DOHOS_STL=c++_shared \ 60 -DOHOS_STL=c++_shared \
60 -DOHOS_ARCH=armv8-a \ 61 -DOHOS_ARCH=armv8-a \
61 -DOHOS_PLATFORM=OHOS \ 62 -DOHOS_PLATFORM=OHOS \
@@ -66,7 +67,7 @@ export OHOS_ROOT=~/app/native</code></pre>
66 <p>解决方案自然是自己手动交叉编译<code>libglib2.0-dev</code>。</p> 67 <p>解决方案自然是自己手动交叉编译<code>libglib2.0-dev</code>。</p>
67 <h2 id="glib2.0-交叉编译">Glib2.0 交叉编译</h2> 68 <h2 id="glib2.0-交叉编译">Glib2.0 交叉编译</h2>
68 <p>从<a href="https://download.gnome.org/sources/glib/">官网</a>下载 glib-2.79.2 源码,解压后进入源码目录。</p> 69 <p>从<a href="https://download.gnome.org/sources/glib/">官网</a>下载 glib-2.79.2 源码,解压后进入源码目录。</p>
69 <pre><code>mkdir glib &amp;&amp; cd glib 70 <pre><code class="language-bash">mkdir glib &amp;&amp; cd glib
70wget https://download.gnome.org/sources/glib/2.79/glib-2.79.2.tar.xz 71wget https://download.gnome.org/sources/glib/2.79/glib-2.79.2.tar.xz
71tar -xvf glib-2.79.2.tar.xz 72tar -xvf glib-2.79.2.tar.xz
72mkdir build</code></pre> 73mkdir build</code></pre>
@@ -78,7 +79,7 @@ mkdir build</code></pre>
78 <p>接着,参考博客<a 79 <p>接着,参考博客<a
79 href="https://t.csdnimg.cn/YfSJC">这篇博客</a>,撰写如下<kbd>meson_ohos.txt</kbd>(友情提醒,使用该文件时把<kbd>native</kbd>也就是 80 href="https://t.csdnimg.cn/YfSJC">这篇博客</a>,撰写如下<kbd>meson_ohos.txt</kbd>(友情提醒,使用该文件时把<kbd>native</kbd>也就是
80 NDK 的路径修改为自己的路径、源平台与目标平台按需修改):</p> 81 NDK 的路径修改为自己的路径、源平台与目标平台按需修改):</p>
81 <pre><code>[binaries] 82 <pre><code class="language-meson">[binaries]
82c = &#39;$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang&#39; 83c = &#39;$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang&#39;
83cpp = &#39;$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang++&#39; 84cpp = &#39;$OHOS_ROOT/llvm/bin/aarch64-unknown-linux-ohos-clang++&#39;
84ar = &#39;$OHOS_ROOT/llvm/bin/llvm-ar&#39; 85ar = &#39;$OHOS_ROOT/llvm/bin/llvm-ar&#39;
@@ -102,15 +103,16 @@ cpu_family = &#39;aarch64&#39;
102cpu = &#39;armv8a&#39; 103cpu = &#39;armv8a&#39;
103endian = &#39;little&#39;</code></pre> 104endian = &#39;little&#39;</code></pre>
104 <p>将该文件放置在<kbd>glib-2.79.2</kbd>源码目录下,而后在<kbd>build</kbd>目录下执行以下命令:</p> 105 <p>将该文件放置在<kbd>glib-2.79.2</kbd>源码目录下,而后在<kbd>build</kbd>目录下执行以下命令:</p>
105 <pre><code>meson --cross-file=../glib-2.79.2/meson_ohos.txt .. 106 <pre><code class="language-bash">meson --cross-file=../glib-2.79.2/meson_ohos.txt ..
106ninja</code></pre> 107ninja</code></pre>
107 <p>编译完成,正确地安装 glib2 到交叉编译工具链中(???),之后我们回到 lcm 的源码目录,重新执行 cmake 命令:</p> 108 <p>编译完成,正确地安装 glib2 到交叉编译工具链中(???),之后我们回到 lcm 的源码目录,重新执行 cmake 命令:</p>
108 <pre><code>$OHOS_ROOT/build-tools/cmake/bin/cmake \ 109 <pre><code class="language-bash">$OHOS_ROOT/build-tools/cmake/bin/cmake \
109 -DOHOS_STL=c++_shared \ 110 -DOHOS_STL=c++_shared \
110 -DOHOS_ARCH=armv8-a \ 111 -DOHOS_ARCH=armv8-a \
111 -DOHOS_PLATFORM=OHOS \ 112 -DOHOS_PLATFORM=OHOS \
112 -DCMAKE_TOOLCHAIN_FILE=$(find $OHOS_ROOT -name &quot;ohos.toolchain.cmake&quot;)</code></pre> 113 -DCMAKE_TOOLCHAIN_FILE=$(find $OHOS_ROOT -name &quot;ohos.toolchain.cmake&quot;)</code></pre>
113 <p>这次,编译成功了。万岁!</p> 114 <p>这次,编译成功了。万岁!</p>
115 <p class="time">2024.4</p>
114 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script> 116 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
115 </div> 117 </div>
116 </div> 118 </div>
diff --git a/code/projects/ohos_compile.html b/code/projects/ohos_compile.html
index fd52643..c9d240d 100644
--- a/code/projects/ohos_compile.html
+++ b/code/projects/ohos_compile.html
@@ -5,16 +5,17 @@
5 <meta charset="utf-8" /> 5 <meta charset="utf-8" />
6 <meta name="generator" content="pandoc" /> 6 <meta name="generator" content="pandoc" />
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>OHOS全量编译记录</title> 8 <title>OHOS 全量编译记录</title>
9 <link rel="stylesheet" href="https://test.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://test.qin-juan-ge-zhu.top/common/js/myhighlight.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
11 <script type="text/javascript" src="https://test.qin-juan-ge-zhu.top/common/script4code.js"></script>
12</head> 11</head>
13 12
14<body> 13<body>
15 <div class="pandoc"> 14 <div class="pandoc">
16 <div class="main"> 15 <div class="main">
17 <p class="title">OHOS 全量编译记录</p> 16 <header id="title-block-header">
17 <p class="title">OHOS 全量编译记录</p>
18 </header>
18 <!-- 鸿蒙开发环境搭建 --> 19 <!-- 鸿蒙开发环境搭建 -->
19 <blockquote> 20 <blockquote>
20 <p>本次编译环境搭建参考了以下博客:</p> 21 <p>本次编译环境搭建参考了以下博客:</p>
@@ -36,8 +37,7 @@
36 <h2 id="硬件环境">硬件环境</h2> 37 <h2 id="硬件环境">硬件环境</h2>
37 <p>编译过程使用的是 38 <p>编译过程使用的是
38 <code>Ubuntu</code>,经测试,<code>Ubuntu 22.04 LTS</code>/<code>Ubuntu 20.04 LTS</code>/<code>Ubuntu 18.04 LTS</code> 39 <code>Ubuntu</code>,经测试,<code>Ubuntu 22.04 LTS</code>/<code>Ubuntu 20.04 LTS</code>/<code>Ubuntu 18.04 LTS</code>
39 均可用。 40 均可用。</p>
40 </p>
41 <p>网上的大多数博客里没有对编译的硬件限制作出说明,现根据我们的情况,给出一个大概的范围:</p> 41 <p>网上的大多数博客里没有对编译的硬件限制作出说明,现根据我们的情况,给出一个大概的范围:</p>
42 <ul> 42 <ul>
43 <li><strong>内存必须在 10G 以上</strong>,我使用的是 13G,编译成功(8G 时编译失败了,下文会说明)</li> 43 <li><strong>内存必须在 10G 以上</strong>,我使用的是 13G,编译成功(8G 时编译失败了,下文会说明)</li>
@@ -53,7 +53,7 @@
53 <p>这里我用的是 VMWare+Ubuntu22.04 虚拟机。</p> 53 <p>这里我用的是 VMWare+Ubuntu22.04 虚拟机。</p>
54 <h2 id="软件包依赖">软件包依赖</h2> 54 <h2 id="软件包依赖">软件包依赖</h2>
55 <p>安装依赖在博客中都有讲,但<strong>少了一部分依赖项</strong>,我因而将所有必要的依赖项整理到一个脚本里了:</p> 55 <p>安装依赖在博客中都有讲,但<strong>少了一部分依赖项</strong>,我因而将所有必要的依赖项整理到一个脚本里了:</p>
56 <pre><code>#!/bin/bash 56 <pre><code class="language-bash">#!/bin/bash
57set -e # 一旦出错立刻停止执行,不会执行后续指令 57set -e # 一旦出错立刻停止执行,不会执行后续指令
58 58
59# 更新软件源 59# 更新软件源
@@ -87,7 +87,7 @@ fi</code></pre>
87 <h1 id="配置-git">配置 git</h1> 87 <h1 id="配置-git">配置 git</h1>
88 <h2 id="git-基础设置">git 基础设置</h2> 88 <h2 id="git-基础设置">git 基础设置</h2>
89 <p>在上边我们已经下载了本次所需要的<code>git</code>与<code>git-lfs</code>,接下来我们需要对<code>git</code>进行基础设置。</p> 89 <p>在上边我们已经下载了本次所需要的<code>git</code>与<code>git-lfs</code>,接下来我们需要对<code>git</code>进行基础设置。</p>
90 <pre><code># 设置用户名与密码,新用户必做 90 <pre><code class="language-bash"># 设置用户名与密码,新用户必做
91# 这里的用户名与密码只是一个写在git提交记录中的标识,可以与gitee/github账号无关 91# 这里的用户名与密码只是一个写在git提交记录中的标识,可以与gitee/github账号无关
92git config --global user.name &quot;yourname&quot; 92git config --global user.name &quot;yourname&quot;
93git config --global user.email &quot;your-email-address&quot; 93git config --global user.email &quot;your-email-address&quot;
@@ -99,7 +99,7 @@ git config --global core.editor vim</code></pre>
99 <p>由于 OpenHarmony 的源码托管在 gitee 上,所以我们需要在 gitee 上注册一个帐户。注册的方法在此不复赘述。</p> 99 <p>由于 OpenHarmony 的源码托管在 gitee 上,所以我们需要在 gitee 上注册一个帐户。注册的方法在此不复赘述。</p>
100 <p>本次编译过程中,我们并不需要提交代码,因而可以仅通过 http 方式从 gitee 下载源码——如果是这样的话,<strong>就不需要进行 git 与 gitee 100 <p>本次编译过程中,我们并不需要提交代码,因而可以仅通过 http 方式从 gitee 下载源码——如果是这样的话,<strong>就不需要进行 git 与 gitee
101 关联</strong>;如果想要提交代码,那么需要将本地的 git 与 gitee 账号关联起来,具体操作如下:</p> 101 关联</strong>;如果想要提交代码,那么需要将本地的 git 与 gitee 账号关联起来,具体操作如下:</p>
102 <pre><code># 在本地执行 102 <pre><code class="language-bash"># 在本地执行
103ssh-keygen -t rsa -C &quot;your-email-address&quot;</code></pre> 103ssh-keygen -t rsa -C &quot;your-email-address&quot;</code></pre>
104 <p>命令执行后,每次需要输入都直接回车,<strong>连续有三个回车</strong>,执行就会结束,ssh 104 <p>命令执行后,每次需要输入都直接回车,<strong>连续有三个回车</strong>,执行就会结束,ssh
105 密钥对的公钥和私钥分别保存在<code>~/.ssh/id_rsa.pub</code>和<code>~/.ssh/id_rsa</code>中。</p> 105 密钥对的公钥和私钥分别保存在<code>~/.ssh/id_rsa.pub</code>和<code>~/.ssh/id_rsa</code>中。</p>
@@ -107,7 +107,7 @@ ssh-keygen -t rsa -C &quot;your-email-address&quot;</code></pre>
107 <p>此时,我们就可以通过 ssh 的方式与 gitee 进行交互、也可以免密提交代码了。</p> 107 <p>此时,我们就可以通过 ssh 的方式与 gitee 进行交互、也可以免密提交代码了。</p>
108 <h1 id="系统源码编译">系统源码编译</h1> 108 <h1 id="系统源码编译">系统源码编译</h1>
109 <h2 id="配置-repo-工具">配置 repo 工具</h2> 109 <h2 id="配置-repo-工具">配置 repo 工具</h2>
110 <pre><code>curl -s https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 &gt; ~/repo 110 <pre><code class="language-bash">curl -s https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 &gt; ~/repo
111chmod a+x ~/repo 111chmod a+x ~/repo
112sudo mv ~/repo /usr/local/bin/repo 112sudo mv ~/repo /usr/local/bin/repo
113sudo chown root:root /usr/local/bin/repo 113sudo chown root:root /usr/local/bin/repo
@@ -121,7 +121,7 @@ pip3 install -i https://repo.huaweicloud.com/repository/pypi/simple requests</co
121 的区别,如<code>OpenHarmony-v4.0-Release</code>和<code>OpenHarmony-4.0-Release</code>。二者的区别主要在于,不带 v 121 的区别,如<code>OpenHarmony-v4.0-Release</code>和<code>OpenHarmony-4.0-Release</code>。二者的区别主要在于,不带 v
122 的是官方维护的稳定版,也会更新代码,厂商的补丁一般只针对带 v 的使用。</p> 122 的是官方维护的稳定版,也会更新代码,厂商的补丁一般只针对带 v 的使用。</p>
123 <p>通过 repo + https/ssh 下载:</p> 123 <p>通过 repo + https/ssh 下载:</p>
124 <pre><code># 如果需要的是特定分支,-b后边改成对应分支名 124 <pre><code class="language-bash"># 如果需要的是特定分支,-b后边改成对应分支名
125# repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify 125# repo init -u https://gitee.com/openharmony/manifest.git -b master --no-repo-verify
126# 如果是tag,-b后的参数比较复杂,要在网页上提前确定好需要的tag名字, 126# 如果是tag,-b后的参数比较复杂,要在网页上提前确定好需要的tag名字,
127# 如下载的是tag为OpenHarmony-v3.2-Release的版本,命令如下: 127# 如下载的是tag为OpenHarmony-v3.2-Release的版本,命令如下:
@@ -133,11 +133,11 @@ repo sync -c
133repo forall -c &#39;git lfs pull&#39;</code></pre> 133repo forall -c &#39;git lfs pull&#39;</code></pre>
134 <h2 id="补丁与编译">补丁与编译</h2> 134 <h2 id="补丁与编译">补丁与编译</h2>
135 <p>首先,打上厂商的补丁。下载对应版本补丁后,将补丁文件放到源码根目录下,执行:</p> 135 <p>首先,打上厂商的补丁。下载对应版本补丁后,将补丁文件放到源码根目录下,执行:</p>
136 <pre><code>unzip purple_pi_oh_patch.zip 136 <pre><code class="language-bash">unzip purple_pi_oh_patch.zip
137cd purple_pi_oh_patch 137cd purple_pi_oh_patch
138./ido_patch.sh</code></pre> 138./ido_patch.sh</code></pre>
139 <p>看到<code>patch complete</code>字样,说明补丁成功。接下来进行 prebuilts 和编译:</p> 139 <p>看到<code>patch complete</code>字样,说明补丁成功。接下来进行 prebuilts 和编译:</p>
140 <pre><code># 先在源码根目录下执行脚本,安装编译器及二进制工具 140 <pre><code class="language-bash"># 先在源码根目录下执行脚本,安装编译器及二进制工具
141bash build/prebuilts_download.sh 141bash build/prebuilts_download.sh
142 142
143# 编译 143# 编译
@@ -181,22 +181,22 @@ sudo ./build.sh --product-name purple_pi_oh --ccache --no-prebuilt-sdk --target-
181 <li>右键该分区,查看挂载到什么位置了。一般是挂载到<code>/</code>与<code>/var/snap/firefox/common/host-hunspell</code></li> 181 <li>右键该分区,查看挂载到什么位置了。一般是挂载到<code>/</code>与<code>/var/snap/firefox/common/host-hunspell</code></li>
182 <li>执行以下命令:</li> 182 <li>执行以下命令:</li>
183 </ul> 183 </ul>
184 <pre><code># 对于这个设备挂载到的每一个分区,都执行以下命令,以此类推 184 <pre><code class="language-bash"># 对于这个设备挂载到的每一个分区,都执行以下命令,以此类推
185sudo mount -o remount -rw / 185sudo mount -o remount -rw /
186sudo mount -o remount -rw /var/snap/firefox/common/host-hunspell</code></pre> 186sudo mount -o remount -rw /var/snap/firefox/common/host-hunspell</code></pre>
187 <p>而后在 gparted 中点击<code>gparted-&gt;刷新设备</code>,即可进行分区扩展。</p> 187 <p>而后在 gparted 中点击<code>gparted-&gt;刷新设备</code>,即可进行分区扩展。</p>
188 <h2 id="ninja-编译报错-code-4000">Ninja 编译报错 <code>Code 4000</code></h2> 188 <h2 id="ninja-编译报错-code-4000">Ninja 编译报错 <code>Code 4000</code></h2>
189 <p>编译 rk3568 过程中可能会出现以下报错:</p> 189 <p>编译 rk3568 过程中可能会出现以下报错:</p>
190 <pre><code>[OHOS ERROR] Code: 4000 190 <pre><code class="language-plaintext">[OHOS ERROR] Code: 4000
191[OHOS ERROR] Reason: ninja phase failed</code></pre> 191[OHOS ERROR] Reason: ninja phase failed</code></pre>
192 <p>详细的报错信息已经丢失,将就着看吧。反正别的办法都不好使的时候试试这个。</p> 192 <p>详细的报错信息已经丢失,将就着看吧。反正别的办法都不好使的时候试试这个。</p>
193 <p>此时执行以下内容即可:</p> 193 <p>此时执行以下内容即可:</p>
194 <pre><code>rm -rf out 194 <pre><code class="language-bash">rm -rf out
195sed -i &#39;s/CONFIG_DEBUG_INFO_BTF=y/# CONFIG_DEBUG_INFO_BTF=y/g&#39; kernel/linux/config/linux-5.10/rk3568/arch/arm64_defconfig</code></pre> 195sed -i &#39;s/CONFIG_DEBUG_INFO_BTF=y/# CONFIG_DEBUG_INFO_BTF=y/g&#39; kernel/linux/config/linux-5.10/rk3568/arch/arm64_defconfig</code></pre>
196 <p>而后重新编译。</p> 196 <p>而后重新编译。</p>
197 <h2 id="另一个code-4000">另一个<code>Code 4000</code></h2> 197 <h2 id="另一个code-4000">另一个<code>Code 4000</code></h2>
198 <p>编译时报错如下:</p> 198 <p>编译时报错如下:</p>
199 <pre><code>ninja: build stopped: subcommand failed. 199 <pre><code class="language-plaintext">ninja: build stopped: subcommand failed.
200[OHOS ERROR] Traceback (most recent call last): 200[OHOS ERROR] Traceback (most recent call last):
201[OHOS ERROR] File &quot;/home/player/Desktop/ohos/src/build/hb/services/ninja.py&quot;, line 49, in _execute_ninja_cmd 201[OHOS ERROR] File &quot;/home/player/Desktop/ohos/src/build/hb/services/ninja.py&quot;, line 49, in _execute_ninja_cmd
202[OHOS ERROR] SystemUtil.exec_command( 202[OHOS ERROR] SystemUtil.exec_command(
@@ -250,13 +250,13 @@ sed -i &#39;s/CONFIG_DEBUG_INFO_BTF=y/# CONFIG_DEBUG_INFO_BTF=y/g&#39; kernel/li
250 <p>这是一个很奇怪的报错,我们尚未找到真正的原因所在,只知道如何暂时地绕过去。</p> 250 <p>这是一个很奇怪的报错,我们尚未找到真正的原因所在,只知道如何暂时地绕过去。</p>
251 <h3 id="问题描述与复现">问题描述与复现</h3> 251 <h3 id="问题描述与复现">问题描述与复现</h3>
252 <p>问题复现方法为在编译过程中,执行以下命令:</p> 252 <p>问题复现方法为在编译过程中,执行以下命令:</p>
253 <pre><code>./build.sh --product-name rk3568 --ccache</code></pre> 253 <pre><code class="language-bash">./build.sh --product-name rk3568 --ccache</code></pre>
254 <p>该命令是指导书中写的编译命令,但执行时候会出错;<strong>与上文所述的经确认无误的编译命令不同在于没加<code>sudo</code></strong>。</p> 254 <p>该命令是指导书中写的编译命令,但执行时候会出错;<strong>与上文所述的经确认无误的编译命令不同在于没加<code>sudo</code></strong>。</p>
255 <p>如果按照指导书的命令来,不出意外编译将会报错: <img src="https://www.qin-juan-ge-zhu.top/images/code/ohos_gn_fail_1.png" /> <img 255 <p>如果按照指导书的命令来,不出意外编译将会报错: <img src="https://www.qin-juan-ge-zhu.top/images/code/ohos_compile_gn_fail_1.png" /> <img
256 src="https://www.qin-juan-ge-zhu.top/images/code/ohos_gn_fail_2.png" /></p> 256 src="https://www.qin-juan-ge-zhu.top/images/code/ohos_compile_gn_fail_2.png" /></p>
257 <p><strong>以下是该问题的具体描述:</strong></p> 257 <p><strong>以下是该问题的具体描述:</strong></p>
258 <p><code>build.log</code>如下:</p> 258 <p><code>build.log</code>如下:</p>
259 <pre><code>Set cache size limit to 100.0 GB 259 <pre><code class="language-plaintext">Set cache size limit to 100.0 GB
260[OHOS INFO] loader args:[&#39;platforms_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/platforms.build&quot;&#39;, &#39;subsystem_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/subsystem_config.json&quot;&#39;, &#39;example_subsystem_file=&quot;&quot;&#39;, &#39;exclusion_modules_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/exclusion_modules.json&quot;&#39;, &#39;source_root_dir=&quot;/home/axiomer/桌面/&quot;&#39;, &#39;gn_root_out_dir=&quot;out/sdk&quot;&#39;, &#39;build_platform_name=phone&#39;, &#39;build_xts=False&#39;, &#39;load_test_config=False&#39;, &#39;target_os=ohos&#39;, &#39;target_cpu=arm64&#39;, &#39;os_level=standard&#39;, &quot;ignore_api_check=[&#39;xts&#39;, &#39;common&#39;, &#39;testfwk&#39;]&quot;, &#39;scalable_build=False&#39;, &#39;skip_partlist_check=False&#39;] 260[OHOS INFO] loader args:[&#39;platforms_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/platforms.build&quot;&#39;, &#39;subsystem_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/subsystem_config.json&quot;&#39;, &#39;example_subsystem_file=&quot;&quot;&#39;, &#39;exclusion_modules_config_file=&quot;/home/axiomer/桌面/out/preloader/ohos-sdk/exclusion_modules.json&quot;&#39;, &#39;source_root_dir=&quot;/home/axiomer/桌面/&quot;&#39;, &#39;gn_root_out_dir=&quot;out/sdk&quot;&#39;, &#39;build_platform_name=phone&#39;, &#39;build_xts=False&#39;, &#39;load_test_config=False&#39;, &#39;target_os=ohos&#39;, &#39;target_cpu=arm64&#39;, &#39;os_level=standard&#39;, &quot;ignore_api_check=[&#39;xts&#39;, &#39;common&#39;, &#39;testfwk&#39;]&quot;, &#39;scalable_build=False&#39;, &#39;skip_partlist_check=False&#39;]
261[OHOS INFO] Excuting gn command: /home/axiomer/桌面/prebuilts/build-tools/linux-x86/bin/gn gen --args=&quot;product_name=\&quot;ohos-sdk\&quot; product_path=\&quot;/home/axiomer/桌面/productdefine/common/products\&quot; product_config_path=\&quot;/home/axiomer/桌面/productdefine/common/products\&quot; device_name=\&quot;sdk\&quot; device_path=\&quot;/home/axiomer/桌面/device/board/ohos/sdk\&quot; device_company=\&quot;ohos\&quot; device_config_path=\&quot;/home/axiomer/桌面/device/board/ohos/sdk\&quot; target_cpu=\&quot;arm64\&quot; is_standard_system=true ohos_build_compiler_specified=\&quot;\&quot; ohos_build_time=1707374188101 ohos_build_datetime=\&quot;2024-02-08 22:36:28\&quot; build_ohos_sdk=true build_ohos_ndk=true ohos_build_enable_ccache=true ohos_build_type=\&quot;debug\&quot; device_type=\&quot;default\&quot; build_variant=\&quot;root\&quot; use_thin_lto=false ndk_platform=\&quot;linux\&quot; sdk_for_hap_build=true skip_generate_module_list_file=true enable_lto_O0=true archive_ndk=false enable_ndk_doxygen=false use_cfi=false sdk_check_flag=false sdk_platform=\&quot;linux\&quot; root_perf_main=\&quot;main\&quot; runtime_mode=\&quot;release\&quot;&quot; --args=product_name=&quot;ohos-sdk&quot; product_path=&quot;/home/axiomer/桌面/productdefine/common/products&quot; product_config_path=&quot;/home/axiomer/桌面/productdefine/common/products&quot; device_name=&quot;sdk&quot; device_path=&quot;/home/axiomer/桌面/device/board/ohos/sdk&quot; device_company=&quot;ohos&quot; device_config_path=&quot;/home/axiomer/桌面/device/board/ohos/sdk&quot; target_cpu=&quot;arm64&quot; is_standard_system=true ohos_build_compiler_specified=&quot;&quot; ohos_build_time=1707374188101 ohos_build_datetime=&quot;2024-02-08 22:36:28&quot; build_ohos_sdk=true build_ohos_ndk=true ohos_build_enable_ccache=true ohos_build_type=&quot;debug&quot; device_type=&quot;default&quot; build_variant=&quot;root&quot; use_thin_lto=false ndk_platform=&quot;linux&quot; sdk_for_hap_build=true skip_generate_module_list_file=true enable_lto_O0=true archive_ndk=false enable_ndk_doxygen=false use_cfi=false sdk_check_flag=false sdk_platform=&quot;linux&quot; root_perf_main=&quot;main&quot; runtime_mode=&quot;release&quot; /home/axiomer/桌面/out/sdk 261[OHOS INFO] Excuting gn command: /home/axiomer/桌面/prebuilts/build-tools/linux-x86/bin/gn gen --args=&quot;product_name=\&quot;ohos-sdk\&quot; product_path=\&quot;/home/axiomer/桌面/productdefine/common/products\&quot; product_config_path=\&quot;/home/axiomer/桌面/productdefine/common/products\&quot; device_name=\&quot;sdk\&quot; device_path=\&quot;/home/axiomer/桌面/device/board/ohos/sdk\&quot; device_company=\&quot;ohos\&quot; device_config_path=\&quot;/home/axiomer/桌面/device/board/ohos/sdk\&quot; target_cpu=\&quot;arm64\&quot; is_standard_system=true ohos_build_compiler_specified=\&quot;\&quot; ohos_build_time=1707374188101 ohos_build_datetime=\&quot;2024-02-08 22:36:28\&quot; build_ohos_sdk=true build_ohos_ndk=true ohos_build_enable_ccache=true ohos_build_type=\&quot;debug\&quot; device_type=\&quot;default\&quot; build_variant=\&quot;root\&quot; use_thin_lto=false ndk_platform=\&quot;linux\&quot; sdk_for_hap_build=true skip_generate_module_list_file=true enable_lto_O0=true archive_ndk=false enable_ndk_doxygen=false use_cfi=false sdk_check_flag=false sdk_platform=\&quot;linux\&quot; root_perf_main=\&quot;main\&quot; runtime_mode=\&quot;release\&quot;&quot; --args=product_name=&quot;ohos-sdk&quot; product_path=&quot;/home/axiomer/桌面/productdefine/common/products&quot; product_config_path=&quot;/home/axiomer/桌面/productdefine/common/products&quot; device_name=&quot;sdk&quot; device_path=&quot;/home/axiomer/桌面/device/board/ohos/sdk&quot; device_company=&quot;ohos&quot; device_config_path=&quot;/home/axiomer/桌面/device/board/ohos/sdk&quot; target_cpu=&quot;arm64&quot; is_standard_system=true ohos_build_compiler_specified=&quot;&quot; ohos_build_time=1707374188101 ohos_build_datetime=&quot;2024-02-08 22:36:28&quot; build_ohos_sdk=true build_ohos_ndk=true ohos_build_enable_ccache=true ohos_build_type=&quot;debug&quot; device_type=&quot;default&quot; build_variant=&quot;root&quot; use_thin_lto=false ndk_platform=&quot;linux&quot; sdk_for_hap_build=true skip_generate_module_list_file=true enable_lto_O0=true archive_ndk=false enable_ndk_doxygen=false use_cfi=false sdk_check_flag=false sdk_platform=&quot;linux&quot; root_perf_main=&quot;main&quot; runtime_mode=&quot;release&quot; /home/axiomer/桌面/out/sdk
262ERROR at //build/config/BUILDCONFIG.gn:92:15: Could not read file. 262ERROR at //build/config/BUILDCONFIG.gn:92:15: Could not read file.
@@ -296,7 +296,7 @@ current_toolchain=
296 <p>在此,我进行了许多尝试,但都无一例外失败了;以下是我的尝试点,或许会有帮助:</p> 296 <p>在此,我进行了许多尝试,但都无一例外失败了;以下是我的尝试点,或许会有帮助:</p>
297 <ul> 297 <ul>
298 <li>根据<a href="">一个相似提问</a>,对相关依赖进行安装,失败了: <img 298 <li>根据<a href="">一个相似提问</a>,对相关依赖进行安装,失败了: <img
299 src="https://www.qin-juan-ge-zhu.top/images/code/ohos_gn_fail_dependencies.png" /></li> 299 src="https://www.qin-juan-ge-zhu.top/images/code/ohos_compile_gn_fail_dependencies.png" /></li>
300 <li>根据报错信息,在编译命令中添加<code>--no-prebuilt-sdk</code>选项对 ohos-sdk 的构建进行跳过,依然失败</li> 300 <li>根据报错信息,在编译命令中添加<code>--no-prebuilt-sdk</code>选项对 ohos-sdk 的构建进行跳过,依然失败</li>
301 </ul> 301 </ul>
302 <p>尝试未果 T^T</p> 302 <p>尝试未果 T^T</p>
@@ -304,7 +304,7 @@ current_toolchain=
304 <p>报错信息如下所示:</p> 304 <p>报错信息如下所示:</p>
305 <p>在上述报错信息中提到<code>Permission denied</code>,即权限不够;于是尝试添加<code>sudo</code>,居然跑通了!!!!</p> 305 <p>在上述报错信息中提到<code>Permission denied</code>,即权限不够;于是尝试添加<code>sudo</code>,居然跑通了!!!!</p>
306 <p>在指导书的编译指令<code>./build.sh --product-name rk3568 --ccache</code>前添加权限设置<code>sudo</code>,即指令更改为:</p> 306 <p>在指导书的编译指令<code>./build.sh --product-name rk3568 --ccache</code>前添加权限设置<code>sudo</code>,即指令更改为:</p>
307 <pre><code>sudo ./build.sh --product-name rk3568 --ccache</code></pre> 307 <pre><code class="language-bash">sudo ./build.sh --product-name rk3568 --ccache</code></pre>
308 <p>不知道为什么,编译过程中始终没有向我提出权限要求,但是不加<code>sudo</code>开权限就是跑不通,很奇怪 @ _ <span class="citation" 308 <p>不知道为什么,编译过程中始终没有向我提出权限要求,但是不加<code>sudo</code>开权限就是跑不通,很奇怪 @ _ <span class="citation"
309 data-cites="也许是">@也许是</span> OHOS 内敛不好意思申请权限呢……</p> 309 data-cites="也许是">@也许是</span> OHOS 内敛不好意思申请权限呢……</p>
310 <h2 id="另一个奇怪的报错failed-load-btf-from-vmlinux-unknown-error--22"> 310 <h2 id="另一个奇怪的报错failed-load-btf-from-vmlinux-unknown-error--22">
@@ -312,7 +312,7 @@ current_toolchain=
312 <p>关于这个报错,当时的错误日志、运行日志、聊天截图均已丢失,但时日不久,记忆还算清楚,加上这个报错困扰了我好些天,因而必须记录。</p> 312 <p>关于这个报错,当时的错误日志、运行日志、聊天截图均已丢失,但时日不久,记忆还算清楚,加上这个报错困扰了我好些天,因而必须记录。</p>
313 <h3 id="问题简要描述">问题简要描述</h3> 313 <h3 id="问题简要描述">问题简要描述</h3>
314 <p>正常按照<code>sudo ./build.sh --product-name rk3568 --ccache</code>编译时,报错,主要报错信息如下:</p> 314 <p>正常按照<code>sudo ./build.sh --product-name rk3568 --ccache</code>编译时,报错,主要报错信息如下:</p>
315 <pre><code>die__process_unit: DW_TAG_label (0xa) @ &lt;0x3adc&gt; not handled! 315 <pre><code class="language-plaintext">die__process_unit: DW_TAG_label (0xa) @ &lt;0x3adc&gt; not handled!
316die__process_unit: DW_TAG_label (0xa) @ &lt;0x3bdc&gt; not handled! 316die__process_unit: DW_TAG_label (0xa) @ &lt;0x3bdc&gt; not handled!
317die__process_unit: DW_TAG_label (0xa) @ &lt;0x3bef&gt; not handled! 317die__process_unit: DW_TAG_label (0xa) @ &lt;0x3bef&gt; not handled!
318die__process_unit: DW_TAG_label (0xa) @ &lt;0x3ce5&gt; not handled! 318die__process_unit: DW_TAG_label (0xa) @ &lt;0x3ce5&gt; not handled!
@@ -333,7 +333,7 @@ make[1]: *** [arch/arm64/Makefile:208: rk3568-toybrick-x0-linux.img]错误2
333make[1]: 离开目录&quot;/home/player/harmony/out/kernel/OBJ/linux-5.10&quot; 333make[1]: 离开目录&quot;/home/player/harmony/out/kernel/OBJ/linux-5.10&quot;
334make: *** [Makefile:192:__sub-make]错误 2</code></pre> 334make: *** [Makefile:192:__sub-make]错误 2</code></pre>
335 <p>可以看到,报错的关键点在于<code>FAILED: load BTF from vmlinux: Unknown error -22</code>这里。查看 Makefile 对应报错位置:</p> 335 <p>可以看到,报错的关键点在于<code>FAILED: load BTF from vmlinux: Unknown error -22</code>这里。查看 Makefile 对应报错位置:</p>
336 <pre><code>vmlinux: scripts/link-vmlinux.sh autoksyms_recursive $(vmlinux-deps) FORCE 336 <pre><code class="language-makefile">vmlinux: scripts/link-vmlinux.sh autoksyms_recursive $(vmlinux-deps) FORCE
337 +$(call if_changed,link-vmlinux) 337 +$(call if_changed,link-vmlinux)
338 338
339targets := vmlinux</code></pre> 339targets := vmlinux</code></pre>
@@ -362,7 +362,7 @@ targets := vmlinux</code></pre>
362 时候推荐的最大虚拟机内存)是能编译完成的,编译时长 6h。最终解决。</p> 362 时候推荐的最大虚拟机内存)是能编译完成的,编译时长 6h。最终解决。</p>
363 <h1 id="ohos-的-ndk">ohos 的 NDK</h1> 363 <h1 id="ohos-的-ndk">ohos 的 NDK</h1>
364 <p>NDK 编译方式比较简单,在源码根目录下执行如下命令:</p> 364 <p>NDK 编译方式比较简单,在源码根目录下执行如下命令:</p>
365 <pre><code># 安装依赖 365 <pre><code class="language-bash"># 安装依赖
366./build/build_scripts/env_setup.sh 366./build/build_scripts/env_setup.sh
367 367
368# 执行完上述命令后记得执行source ~/.bashrc或者重启终端 368# 执行完上述命令后记得执行source ~/.bashrc或者重启终端
@@ -377,7 +377,7 @@ sudo apt-get install libxcursor-dev libxrandr-dev libxinerama-dev
377 <p>注意,NDK 包提供的交叉编译工具是 cmake 和 ninja,编译器是 clang 和 clang++,并没有我们熟悉的 gcc/g++和 make。除此之外,NDK 377 <p>注意,NDK 包提供的交叉编译工具是 cmake 和 ninja,编译器是 clang 和 clang++,并没有我们熟悉的 gcc/g++和 make。除此之外,NDK
378 还未我们提供编译所需的全套服务,如编译工具链配置文件<code>ohos.toolchain.cmake</code>、头文件、库文件等。快说,谢谢 ohos~</p> 378 还未我们提供编译所需的全套服务,如编译工具链配置文件<code>ohos.toolchain.cmake</code>、头文件、库文件等。快说,谢谢 ohos~</p>
379 <p>为了更方便地使用 NDK,鄙人不才,写了两个脚本,分别用于 cmake 编译和单文件编译:</p> 379 <p>为了更方便地使用 NDK,鄙人不才,写了两个脚本,分别用于 cmake 编译和单文件编译:</p>
380 <pre><code>#!/bin/bash 380 <pre><code class="language-bash">#!/bin/bash
381 381
382####################################################################### 382#######################################################################
383# File Name : compile.sh 383# File Name : compile.sh
@@ -418,7 +418,7 @@ cmake -B build -D OHOS_STL=c++_$link -D OHOS_ARCH=$arch \
418 -D OHOS_PLATFORM=OHOS \ 418 -D OHOS_PLATFORM=OHOS \
419 -D CMAKE_TOOLCHAIN_FILE=$(find $native_path -name ohos.toolchain.cmake) 419 -D CMAKE_TOOLCHAIN_FILE=$(find $native_path -name ohos.toolchain.cmake)
420cmake --build build</code></pre> 420cmake --build build</code></pre>
421 <pre><code>#!/bin/bash 421 <pre><code class="language-bash">#!/bin/bash
422 422
423####################################################################### 423#######################################################################
424# File Name : compile-tiny.sh 424# File Name : compile-tiny.sh
@@ -492,7 +492,7 @@ $compiler -o $targetFile $file -Wall \
492 </ul> 492 </ul>
493 <p>不说了,抓紧攒点钱开学升级电脑配置要紧……磁盘快炸了……</p> 493 <p>不说了,抓紧攒点钱开学升级电脑配置要紧……磁盘快炸了……</p>
494 <p class="time">2024.2.12,甲辰年正月初三<br>2024.4.24改<br>2024.11.19改</p> 494 <p class="time">2024.2.12,甲辰年正月初三<br>2024.4.24改<br>2024.11.19改</p>
495 <script src="https://test.qin-juan-ge-zhu.top/common/js/comment.js"></script> 495 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
496 </div> 496 </div>
497 </div> 497 </div>
498</body> 498</body>
diff --git a/code/zeal.html b/code/zeal.html
index 768c35f..10c81b4 100644
--- a/code/zeal.html
+++ b/code/zeal.html
@@ -1,1834 +1,313 @@
1<!doctype html> 1<!DOCTYPE html>
2<html> 2<html xmlns="http://www.w3.org/1999/xhtml" lang="" xml:lang="">
3 3
4<head> 4<head>
5 <meta charset='UTF-8'> 5 <meta charset="utf-8" />
6 <meta name='viewport' content='width=device-width initial-scale=1'> 6 <meta name="generator" content="pandoc" />
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
7 <title>Zeal使用</title> 8 <title>Zeal使用</title>
8 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/academic_zh.css"> 9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
9 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 10 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
10</head> 11</head>
11 12
12<body class='typora-export os-windows'> 13<body>
13 <div class='typora-export-content'> 14 <div class="pandoc">
14 <div id='write' class=''> 15 <div class="main">
15 <p class="title">Zeal离线文档快速下载</p> 16 <header id="title-block-header">
16 <p class="time" style="text-align:right;"><a href="https://www.jianshu.com/p/364cbfd947b4">原文网址</a></p> 17 <p class="title">Zeal使用</p>
17 <p><a href='https://zealdocs.org'><span>Zeal</span></a><span>支持200多种常见技术文档的离线下载和安装,并可以离线搜索查看,支持Windows、Linux、MacOS,Windows 版支持免安装的 Portable版本。这对于需要经常访问国外技术文档但网络环境不好的小伙伴来说,Zeal 是绝对真香。</span></p> 18 </header>
18 <h1 id='基本使用'><span>基本使用</span></h1> 19 <p><a href="https://zealdocs.org">Zeal</a>支持 200 多种常见技术文档的离线下载和安装,并可以离线搜索查看,支持 Windows、Linux、MacOS,Windows
20 版支持免安装的 Portable 版本。这对于需要经常访问国外技术文档但网络环境不好的小伙伴来说,Zeal 是绝对真香。</p>
21 <h1 id="基本使用">基本使用</h1>
19 <ul> 22 <ul>
20 <li><p><strong><span>下载完成后</span></strong><span>,点击</span><kbd><span>Edit--&gt;Preferences</span></kbd><span>,选择</span><kbd><span>Global</span></kbd><span>,在</span><kbd><span>Docset 23 <li><strong>下载完成后</strong>,点击<kbd>Edit–&gt;Preferences</kbd>,选择<kbd>Global</kbd>,在<kbd>Docset
21 storage</span></kbd><span>中设置文档存储位置(空路径),保存</span></p></li> 24 storage</kbd>中设置文档存储位置(空路径),保存</li>
22 </ul> 25 </ul>
23 <blockquote> 26 <blockquote>
24 <p><span>推荐在下载之前就设置好,文档下载下来如果没有专门记录的话很难想到找对应位置。所以墙裂推荐在设置好之后,在显眼的地方留一个快捷方式。</span></p> 27 <p>推荐在下载之前就设置好,文档下载下来如果没有专门记录的话很难想到找对应位置。所以墙裂推荐在设置好之后,在显眼的地方留一个快捷方式。</p>
25 </blockquote> 28 </blockquote>
26 <ul> 29 <ul>
27 <li><p><span>在</span><kbd><span>Tools--&gt;Docsets</span></kbd><span>中查看已经下载的文档和可选择的文档,选择下载。</span></p></li> 30 <li>在<kbd>Tools–&gt;Docsets</kbd>中查看已经下载的文档和可选择的文档,选择下载。</li>
28 <li><p><span>下载到本地后,在左上角即可搜索本地离线文档。</span></p></li> 31 <li>下载到本地后,在左上角即可搜索本地离线文档。</li>
29 </ul> 32 </ul>
30 <p><strong><span>就是这么方便!</span></strong></p> 33 <p><strong>就是这么方便!</strong></p>
31 <h1 id='下载速度'><span>下载速度</span></h1> 34 <h1 id="下载速度">下载速度</h1>
32 <p><span>Zeal在国内的访问速度,不能说是快如闪电吧,好歹也跟蚂蚁爬有的一拼。因而,介绍如何手动下载文档。</span></p> 35 <p>Zeal 在国内的访问速度,不能说是快如闪电吧,好歹也跟蚂蚁爬有的一拼。因而,介绍如何手动下载文档。</p>
33 <h2 id='获取可用列表'><span>获取可用列表</span></h2> 36 <h2 id="获取可用列表">获取可用列表</h2>
34 <p><span>访问链接:</span><a 37 <p>访问链接:<a href="http://api.zealdocs.org/v1/docsets">http://api.zealdocs.org/v1/docsets</a></p>
35 href='http://api.zealdocs.org/v1/docsets'><span>http://api.zealdocs.org/v1/docsets</span></a></p> 38 <p>这是 Zeal 可用文档列表信息,是一个 json 文件。如果访问较慢,可以访问这里:<a href="上山打老虎">12345</a>,这是 2023 年 3 月 26 日的列表。</p>
36 <p><span>这是Zeal可用文档列表信息,是一个json文件。如果访问较慢,可以访问这里:</span><a 39 <h2 id="下载">下载</h2>
37 href="https://www.qin-juan-ge-zhu.top/code/others'code/zeal_docsets.json"><span>https://www.qin-juan-ge-zhu.top/code/others'code/zeal_docsets.json</span></a><span>,这是2023年3月26日的列表。</span></p> 40 <p>首先,在可用列表查找需要的内容的名字,如查找 C++:</p>
38 <h2 id='下载'><span>下载</span></h2> 41 <pre><code class="language-json">{
39 <p><span>首先,在可用列表查找需要的内容的名字,如查找C++:</span></p> 42 &quot;sourceId&quot;: &quot;com.kapeli&quot;,
40 <pre class="md-fences md-end-block md-fences-with-lineno ty-contain-cm modeLoaded" spellcheck="false" 43 &quot;name&quot;: &quot;C++&quot;,
41 lang="json"><div class="CodeMirror cm-s-inner cm-s-null-scroll CodeMirror-wrap" lang="json"><div style="overflow: hidden; position: relative; width: 3px; height: 0px; top: 10.4px; left: 48px;"><textarea autocorrect="off" autocapitalize="off" spellcheck="false" tabindex="0" style="position: absolute; bottom: -1em; padding: 0px; width: 1000px; height: 1em; outline: none;"></textarea></div><div class="CodeMirror-scrollbar-filler" cm-not-content="true"></div><div class="CodeMirror-gutter-filler" cm-not-content="true"></div><div class="CodeMirror-scroll" tabindex="-1"><div class="CodeMirror-sizer" style="margin-left: 36px; margin-bottom: 0px; border-right-width: 0px; padding-right: 0px; padding-bottom: 0px;"><div style="position: relative; top: 0px;"><div class="CodeMirror-lines" role="presentation"><div role="presentation" style="position: relative; outline: none;"><div class="CodeMirror-measure"><pre><span>xxxxxxxxxx</span></pre> 44 &quot;title&quot;: &quot;C++&quot;,
42 <div class="CodeMirror-linenumber CodeMirror-gutter-elt"> 45 &quot;versions&quot;: [],
43 <div>12</div> 46 &quot;revision&quot;: &quot;73&quot;,
44 </div> 47 &quot;icon&quot;: ……,//这是一串编码,不重要
45 </div> 48 &quot;icon2x&quot;: ……//也还是一串编码
46 <div class="CodeMirror-measure"></div> 49 &quot;extra&quot;: {
47 <div style="position: relative; z-index: 1;"></div> 50 &quot;indexFilePath&quot;: &quot;output/en.cppreference.com/w/cpp.html&quot;
48 <div class="CodeMirror-code" role="presentation" style=""> 51 }
49 <div class="CodeMirror-activeline" style="position: relative;"> 52}</code></pre>
50 <div class="CodeMirror-activeline-background CodeMirror-linebackground"></div> 53 <p>而后,查看对应的“name”值。</p>
51 <div class="CodeMirror-gutter-background CodeMirror-activeline-gutter" 54 <h2 id="链接拼接">链接拼接</h2>
52 style="left: -36px; width: 36px;"></div> 55 <p>Zeal 文档下载链接格式:</p>
53 <div class="CodeMirror-gutter-wrapper CodeMirror-activeline-gutter" style="left: -36px;"> 56 <pre><code class="language-cpp">http://{city_name}.kapeli.com/feeds/{name}.tgz</code></pre>
54 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 57 <ul>
55 style="left: 0px; width: 27px;">1</div> 58 <li>
56 </div> 59 <p>city_anme 是服务器所在的城市</p>
57 <pre class=" CodeMirror-line " 60 </li>
58 role="presentation"><span role="presentation" style="padding-right: 0.1px;">{</span></pre> 61 <li>
59 </div> 62 <p>name 是刚刚找好的要下载文档的 name 值</p>
60 <div style="position: relative;"> 63 </li>
61 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 64 </ul>
62 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">2</div> 65 <p>其中,服务器分布城市有:</p>
63 </div> 66 <table>
64 <pre class=" CodeMirror-line " 67 <thead>
65 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"sourceId"</span>: <span class="cm-string">"com.kapeli"</span>,</span></pre> 68 <tr class="header">
66 </div> 69 <th>frankfurt</th>
67 <div style="position: relative;"> 70 <th>london</th>
68 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 71 <th>newyork</th>
69 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">3</div> 72 </tr>
70 </div> 73 </thead>
71 <pre class=" CodeMirror-line " 74 <tbody>
72 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"name"</span>: <span class="cm-string">"C++"</span>,</span></pre> 75 <tr class="odd">
73 </div> 76 <td>sanfrancisco</td>
74 <div style="position: relative;"> 77 <td>singapore</td>
75 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 78 <td>tokyo</td>
76 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">4</div> 79 </tr>
77 </div> 80 </tbody>
78 <pre class=" CodeMirror-line " 81 </table>
79 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"title"</span>: <span class="cm-string">"C++"</span>,</span></pre> 82 <p>根据测试,得到结果:</p>
80 </div> 83 <pre><code>快——&gt; 慢排序
81 <div style="position: relative;"> 84
82 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 85http://tokyo.kapeli.com/feeds/{name}.tgz
83 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">5</div> 86
84 </div> 87http://singapore.kapeli.com/feeds/{name}.tgz
85 <pre class=" CodeMirror-line " 88
86 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"versions"</span>: [],</span></pre> 89http://sanfrancisco.kapeli.com/feeds/{name}.tgz
87 </div> 90
88 <div style="position: relative;"> 91http://frankfurt.kapeli.com/feeds/{name}.tgz
89 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 92
90 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">6</div> 93http://newyork.kapeli.com/feeds/{name}.tgz
91 </div> 94
92 <pre class=" CodeMirror-line " 95http://sydney.kapeli.com/feeds/{name}.tgz
93 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"revision"</span>: <span class="cm-string">"73"</span>,</span></pre> 96
94 </div> 97http://london.kapeli.com/feeds/{name}.tgz</code></pre>
95 <div style="position: relative;"> 98 <p>此时,把所需文档的 name 替换掉链接中的{name}即可,得到下载链接如下:</p>
96 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 99 <pre><code>http://tokyo.kapeli.com/feeds/ActionScript.tgz
97 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">7</div> 100http://tokyo.kapeli.com/feeds/Akka.tgz
98 </div> 101http://tokyo.kapeli.com/feeds/Android.tgz
99 <pre class=" CodeMirror-line " 102http://tokyo.kapeli.com/feeds/Angular.tgz
100 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"icon"</span>: <span class="cm-variable">……</span>,<span class="cm-comment">//这是一串编码,不重要</span></span></pre> 103http://tokyo.kapeli.com/feeds/AngularJS.tgz
101 </div> 104http://tokyo.kapeli.com/feeds/Ansible.tgz
102 <div style="position: relative;"> 105http://tokyo.kapeli.com/feeds/Apache_HTTP_Server.tgz
103 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 106http://tokyo.kapeli.com/feeds/Appcelerator_Titanium.tgz
104 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">8</div> 107http://tokyo.kapeli.com/feeds/AppleScript.tgz
105 </div> 108http://tokyo.kapeli.com/feeds/Arduino.tgz
106 <pre class=" CodeMirror-line " 109http://tokyo.kapeli.com/feeds/AWS_JavaScript.tgz
107 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string cm-property">"icon2x"</span>: <span class="cm-variable">……</span><span class="cm-comment">//也还是一串编码</span></span></pre> 110http://tokyo.kapeli.com/feeds/BackboneJS.tgz
108 </div> 111http://tokyo.kapeli.com/feeds/Bash.tgz
109 <div style="position: relative;"> 112http://tokyo.kapeli.com/feeds/Boost.tgz
110 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 113http://tokyo.kapeli.com/feeds/Bootstrap_2.tgz
111 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">9</div> 114http://tokyo.kapeli.com/feeds/Bootstrap_3.tgz
112 </div> 115http://tokyo.kapeli.com/feeds/Bootstrap_4.tgz
113 <pre class=" CodeMirror-line " 116http://tokyo.kapeli.com/feeds/Bootstrap_5.tgz
114 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string">"extra"</span>: {</span></pre> 117http://tokyo.kapeli.com/feeds/Bourbon.tgz
115 </div> 118http://tokyo.kapeli.com/feeds/C.tgz
116 <div style="position: relative;"> 119http://tokyo.kapeli.com/feeds/C++.tgz
117 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 120http://tokyo.kapeli.com/feeds/CakePHP.tgz
118 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 121http://tokyo.kapeli.com/feeds/Cappuccino.tgz
119 style="left: 0px; width: 27px;">10</div> 122http://tokyo.kapeli.com/feeds/Chai.tgz
120 </div> 123http://tokyo.kapeli.com/feeds/Chef.tgz
121 <pre class=" CodeMirror-line " 124http://tokyo.kapeli.com/feeds/Clojure.tgz
122 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span class="cm-string">"indexFilePath"</span>: <span class="cm-string">"output/en.cppreference.com/w/cpp.html"</span></span></pre> 125http://tokyo.kapeli.com/feeds/CMake.tgz
123 </div> 126http://tokyo.kapeli.com/feeds/Cocos2D.tgz
124 <div style="position: relative;"> 127http://tokyo.kapeli.com/feeds/Cocos2D-X.tgz
125 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 128http://tokyo.kapeli.com/feeds/Cocos3D.tgz
126 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">11</div> 129http://tokyo.kapeli.com/feeds/CodeIgniter.tgz
127 </div> 130http://tokyo.kapeli.com/feeds/CoffeeScript.tgz
128 <pre class=" CodeMirror-line " 131http://tokyo.kapeli.com/feeds/ColdFusion.tgz
129 role="presentation"><span role="presentation" style="padding-right: 0.1px;"> &nbsp; &nbsp; &nbsp; }</span></pre> 132http://tokyo.kapeli.com/feeds/Common_Lisp.tgz
130 </div> 133http://tokyo.kapeli.com/feeds/Compass.tgz
131 <div style="position: relative;"> 134http://tokyo.kapeli.com/feeds/Cordova.tgz
132 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 135http://tokyo.kapeli.com/feeds/Corona.tgz
133 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 136http://tokyo.kapeli.com/feeds/CouchDB.tgz
134 style="left: 0px; width: 27px;">12</div> 137http://tokyo.kapeli.com/feeds/Craft.tgz
135 </div> 138http://tokyo.kapeli.com/feeds/CSS.tgz
136 <pre class=" CodeMirror-line " 139http://tokyo.kapeli.com/feeds/D3JS.tgz
137 role="presentation"><span role="presentation" style="padding-right: 0.1px;">}</span></pre> 140http://tokyo.kapeli.com/feeds/Dart.tgz
138 </div> 141http://tokyo.kapeli.com/feeds/Django.tgz
139 </div> 142http://tokyo.kapeli.com/feeds/Docker.tgz
140 </div> 143http://tokyo.kapeli.com/feeds/Doctrine_ORM.tgz
141 </div> 144http://tokyo.kapeli.com/feeds/Dojo.tgz
142 </div> 145http://tokyo.kapeli.com/feeds/Drupal_7.tgz
143 </div> 146http://tokyo.kapeli.com/feeds/Drupal_8.tgz
144 <div style="position: absolute; height: 0px; width: 1px; border-bottom: 0px solid transparent; top: 298px;"></div> 147http://tokyo.kapeli.com/feeds/Drupal_9.tgz
145 <div class="CodeMirror-gutters" style="height: 298px; left: 0px;"> 148http://tokyo.kapeli.com/feeds/ElasticSearch.tgz
146 <div class="CodeMirror-gutter CodeMirror-linenumbers" style="width: 35px;"></div> 149http://tokyo.kapeli.com/feeds/Elixir.tgz
147 </div> 150http://tokyo.kapeli.com/feeds/Emacs_Lisp.tgz
148 </div> 151http://tokyo.kapeli.com/feeds/EmberJS.tgz
149 </div> 152http://tokyo.kapeli.com/feeds/Emmet.tgz
150 </pre> 153http://tokyo.kapeli.com/feeds/Erlang.tgz
151 <p><span>而后,查看对应的&quot;name&quot;值。</span></p> 154http://tokyo.kapeli.com/feeds/Express.tgz
152 <h2 id='链接拼接'><span>链接拼接</span></h2> 155http://tokyo.kapeli.com/feeds/ExpressionEngine.tgz
153 <p><span>Zeal文档下载链接格式:</span></p> 156http://tokyo.kapeli.com/feeds/ExtJS.tgz
154 <pre class="md-fences md-end-block md-fences-with-lineno ty-contain-cm modeLoaded" spellcheck="false" 157http://tokyo.kapeli.com/feeds/Flask.tgz
155 lang="cpp"><div class="CodeMirror cm-s-inner cm-s-null-scroll CodeMirror-wrap" lang="cpp"><div style="overflow: hidden; position: relative; width: 3px; height: 0px; top: 10.4px; left: 48px;"><textarea autocorrect="off" autocapitalize="off" spellcheck="false" tabindex="0" style="position: absolute; bottom: -1em; padding: 0px; width: 1000px; height: 1em; outline: none;"></textarea></div><div class="CodeMirror-scrollbar-filler" cm-not-content="true"></div><div class="CodeMirror-gutter-filler" cm-not-content="true"></div><div class="CodeMirror-scroll" tabindex="-1"><div class="CodeMirror-sizer" style="margin-left: 36px; margin-bottom: 0px; border-right-width: 0px; padding-right: 0px; padding-bottom: 0px;"><div style="position: relative; top: 0px;"><div class="CodeMirror-lines" role="presentation"><div role="presentation" style="position: relative; outline: none;"><div class="CodeMirror-measure"><pre><span>xxxxxxxxxx</span></pre> 158http://tokyo.kapeli.com/feeds/Font_Awesome.tgz
156 <div class="CodeMirror-linenumber CodeMirror-gutter-elt"> 159http://tokyo.kapeli.com/feeds/Foundation.tgz
157 <div>1</div> 160http://tokyo.kapeli.com/feeds/GLib.tgz
158 </div> 161http://tokyo.kapeli.com/feeds/Go.tgz
159 </div> 162http://tokyo.kapeli.com/feeds/Gradle_DSL.tgz
160 <div class="CodeMirror-measure"></div> 163http://tokyo.kapeli.com/feeds/Gradle_Java_API.tgz
161 <div style="position: relative; z-index: 1;"></div> 164http://tokyo.kapeli.com/feeds/Gradle_User_Guide.tgz
162 <div class="CodeMirror-code" role="presentation" style=""> 165http://tokyo.kapeli.com/feeds/Grails.tgz
163 <div class="CodeMirror-activeline" style="position: relative;"> 166http://tokyo.kapeli.com/feeds/Groovy.tgz
164 <div class="CodeMirror-activeline-background CodeMirror-linebackground"></div> 167http://tokyo.kapeli.com/feeds/Groovy_JDK.tgz
165 <div class="CodeMirror-gutter-background CodeMirror-activeline-gutter" style="left: -36px; width: 36px;"> 168http://tokyo.kapeli.com/feeds/Grunt.tgz
166 </div> 169http://tokyo.kapeli.com/feeds/Gulp.tgz
167 <div class="CodeMirror-gutter-wrapper CodeMirror-activeline-gutter" style="left: -36px;"> 170http://tokyo.kapeli.com/feeds/Haml.tgz
168 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 171http://tokyo.kapeli.com/feeds/Handlebars.tgz
169 style="left: 0px; width: 27px;">1</div> 172http://tokyo.kapeli.com/feeds/Haskell.tgz
170 </div> 173http://tokyo.kapeli.com/feeds/HTML.tgz
171 <pre class=" CodeMirror-line " 174http://tokyo.kapeli.com/feeds/Ionic.tgz
172 role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span class="cm-variable">http</span>:<span class="cm-comment">//{city_name}.kapeli.com/feeds/{name}.tgz</span></span></pre> 175http://tokyo.kapeli.com/feeds/Jasmine.tgz
173 </div> 176http://tokyo.kapeli.com/feeds/Java_EE6.tgz
174 </div> 177http://tokyo.kapeli.com/feeds/Java_EE7.tgz
175 </div> 178http://tokyo.kapeli.com/feeds/Java_EE8.tgz
176 </div> 179http://tokyo.kapeli.com/feeds/Java_SE10.tgz
177 </div> 180http://tokyo.kapeli.com/feeds/Java_SE11.tgz
178 </div> 181http://tokyo.kapeli.com/feeds/Java_SE12.tgz
179 <div style="position: absolute; height: 0px; width: 1px; border-bottom: 0px solid transparent; top: 25px;"></div> 182http://tokyo.kapeli.com/feeds/Java_SE13.tgz
180 <div class="CodeMirror-gutters" style="height: 25px; left: 0px;"> 183http://tokyo.kapeli.com/feeds/Java_SE14.tgz
181 <div class="CodeMirror-gutter CodeMirror-linenumbers" style="width: 35px;"></div> 184http://tokyo.kapeli.com/feeds/Java_SE15.tgz
182 </div> 185http://tokyo.kapeli.com/feeds/Java_SE16.tgz
183 </div> 186http://tokyo.kapeli.com/feeds/Java_SE6.tgz
184 </div> 187http://tokyo.kapeli.com/feeds/Java_SE7.tgz
185 </pre> 188http://tokyo.kapeli.com/feeds/Java_SE8.tgz
186 <ul> 189http://tokyo.kapeli.com/feeds/Java_SE9.tgz
187 <li><p><span>city_anme是服务器所在的城市</span></p></li> 190http://tokyo.kapeli.com/feeds/JavaFX.tgz
188 <li><p><span>name是刚刚找好的要下载文档的name值</span></p></li> 191http://tokyo.kapeli.com/feeds/JavaScript.tgz
189 </ul> 192http://tokyo.kapeli.com/feeds/Jekyll.tgz
190 <p><span>其中,服务器分布城市有:</span></p> 193http://tokyo.kapeli.com/feeds/Jinja.tgz
191 <figure> 194http://tokyo.kapeli.com/feeds/Joomla.tgz
192 <table> 195http://tokyo.kapeli.com/feeds/jQuery.tgz
193 <thead> 196http://tokyo.kapeli.com/feeds/jQuery_Mobile.tgz
194 <tr> 197http://tokyo.kapeli.com/feeds/jQuery_UI.tgz
195 <th><span>frankfurt</span></th> 198http://tokyo.kapeli.com/feeds/Julia.tgz
196 <th><span>london</span></th> 199http://tokyo.kapeli.com/feeds/KnockoutJS.tgz
197 <th><span>newyork</span></th> 200http://tokyo.kapeli.com/feeds/Kobold2D.tgz
198 </tr> 201http://tokyo.kapeli.com/feeds/Laravel.tgz
199 </thead> 202http://tokyo.kapeli.com/feeds/LaTeX.tgz
200 <tbody> 203http://tokyo.kapeli.com/feeds/Less.tgz
201 <tr> 204http://tokyo.kapeli.com/feeds/Lo-Dash.tgz
202 <td><span>sanfrancisco</span></td> 205http://tokyo.kapeli.com/feeds/Lua_5.1.tgz
203 <td><span>singapore</span></td> 206http://tokyo.kapeli.com/feeds/Lua_5.2.tgz
204 <td><span>tokyo</span></td> 207http://tokyo.kapeli.com/feeds/Lua_5.3.tgz
205 </tr> 208http://tokyo.kapeli.com/feeds/Lua_5.4.tgz
206 </tbody> 209http://tokyo.kapeli.com/feeds/MarionetteJS.tgz
207 </table> 210http://tokyo.kapeli.com/feeds/Markdown.tgz
208 </figure> 211http://tokyo.kapeli.com/feeds/Matplotlib.tgz
209 <p><span>根据测试,得到结果:</span></p> 212http://tokyo.kapeli.com/feeds/Meteor.tgz
210 <pre class="md-fences md-end-block md-fences-with-lineno ty-contain-cm modeLoaded" spellcheck="false" lang="" 213http://tokyo.kapeli.com/feeds/Mocha.tgz
211 style="break-inside: unset;"><div class="CodeMirror cm-s-inner cm-s-null-scroll CodeMirror-wrap" lang=""><div style="overflow: hidden; position: relative; width: 3px; height: 0px; top: 10.4px; left: 48px;"><textarea autocorrect="off" autocapitalize="off" spellcheck="false" tabindex="0" style="position: absolute; bottom: -1em; padding: 0px; width: 1000px; height: 1em; outline: none;"></textarea></div><div class="CodeMirror-scrollbar-filler" cm-not-content="true"></div><div class="CodeMirror-gutter-filler" cm-not-content="true"></div><div class="CodeMirror-scroll" tabindex="-1"><div class="CodeMirror-sizer" style="margin-left: 36px; margin-bottom: 0px; border-right-width: 0px; padding-right: 0px; padding-bottom: 0px;"><div style="position: relative; top: 0px;"><div class="CodeMirror-lines" role="presentation"><div role="presentation" style="position: relative; outline: none;"><div class="CodeMirror-measure"><pre><span>xxxxxxxxxx</span></pre> 214http://tokyo.kapeli.com/feeds/MomentJS.tgz
212 <div class="CodeMirror-linenumber CodeMirror-gutter-elt"> 215http://tokyo.kapeli.com/feeds/MongoDB.tgz
213 <div>15</div> 216http://tokyo.kapeli.com/feeds/Mongoose.tgz
214 </div> 217http://tokyo.kapeli.com/feeds/Mono.tgz
215 </div> 218http://tokyo.kapeli.com/feeds/MooTools.tgz
216 <div class="CodeMirror-measure"></div> 219http://tokyo.kapeli.com/feeds/MySQL.tgz
217 <div style="position: relative; z-index: 1;"></div> 220http://tokyo.kapeli.com/feeds/Neat.tgz
218 <div class="CodeMirror-code" role="presentation" style=""> 221http://tokyo.kapeli.com/feeds/NET_Framework.tgz
219 <div class="CodeMirror-activeline" style="position: relative;"> 222http://tokyo.kapeli.com/feeds/Nginx.tgz
220 <div class="CodeMirror-activeline-background CodeMirror-linebackground"></div> 223http://tokyo.kapeli.com/feeds/NodeJS.tgz
221 <div class="CodeMirror-gutter-background CodeMirror-activeline-gutter" style="left: -36px; width: 36px;"> 224http://tokyo.kapeli.com/feeds/NumPy.tgz
222 </div> 225http://tokyo.kapeli.com/feeds/OCaml.tgz
223 <div class="CodeMirror-gutter-wrapper CodeMirror-activeline-gutter" style="left: -36px;"> 226http://tokyo.kapeli.com/feeds/OpenCV.tgz
224 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 227http://tokyo.kapeli.com/feeds/OpenGL_2.tgz
225 style="left: 0px; width: 27px;">1</div> 228http://tokyo.kapeli.com/feeds/OpenGL_3.tgz
226 </div> 229http://tokyo.kapeli.com/feeds/OpenGL_4.tgz
227 <pre class=" CodeMirror-line " 230http://tokyo.kapeli.com/feeds/Pandas.tgz
228 role="presentation"><span role="presentation" style="padding-right: 0.1px;">快——&gt; 慢排序</span></pre> 231http://tokyo.kapeli.com/feeds/Perl.tgz
229 </div> 232http://tokyo.kapeli.com/feeds/Phalcon.tgz
230 <div style="position: relative;"> 233http://tokyo.kapeli.com/feeds/PhoneGap.tgz
231 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 234http://tokyo.kapeli.com/feeds/PHP.tgz
232 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">2</div> 235http://tokyo.kapeli.com/feeds/PHPUnit.tgz
233 </div> 236http://tokyo.kapeli.com/feeds/Play_Java.tgz
234 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 237http://tokyo.kapeli.com/feeds/Play_Scala.tgz
235</span></span></pre> 238http://tokyo.kapeli.com/feeds/Polymer.dart.tgz
236 </div> 239http://tokyo.kapeli.com/feeds/PostgreSQL.tgz
237 <div style="position: relative;"> 240http://tokyo.kapeli.com/feeds/Processing.tgz
238 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 241http://tokyo.kapeli.com/feeds/PrototypeJS.tgz
239 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">3</div> 242http://tokyo.kapeli.com/feeds/Pug.tgz
240 </div> 243http://tokyo.kapeli.com/feeds/Puppet.tgz
241 <pre class=" CodeMirror-line " 244http://tokyo.kapeli.com/feeds/Python_2.tgz
242 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/{name}.tgz</span></pre> 245http://tokyo.kapeli.com/feeds/Python_3.tgz
243 </div> 246http://tokyo.kapeli.com/feeds/Qt_4.tgz
244 <div style="position: relative;"> 247http://tokyo.kapeli.com/feeds/Qt_5.tgz
245 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 248http://tokyo.kapeli.com/feeds/Qt_6.tgz
246 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">4</div> 249http://tokyo.kapeli.com/feeds/R.tgz
247 </div> 250http://tokyo.kapeli.com/feeds/Racket.tgz
248 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 251http://tokyo.kapeli.com/feeds/React.tgz
249</span></span></pre> 252http://tokyo.kapeli.com/feeds/Redis.tgz
250 </div> 253http://tokyo.kapeli.com/feeds/RequireJS.tgz
251 <div style="position: relative;"> 254http://tokyo.kapeli.com/feeds/Ruby.tgz
252 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 255http://tokyo.kapeli.com/feeds/Ruby_2.tgz
253 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">5</div> 256http://tokyo.kapeli.com/feeds/Ruby_3.tgz
254 </div> 257http://tokyo.kapeli.com/feeds/Ruby_on_Rails_3.tgz
255 <pre class=" CodeMirror-line " 258http://tokyo.kapeli.com/feeds/Ruby_on_Rails_4.tgz
256 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://singapore.kapeli.com/feeds/{name}.tgz </span></pre> 259http://tokyo.kapeli.com/feeds/Ruby_on_Rails_5.tgz
257 </div> 260http://tokyo.kapeli.com/feeds/Ruby_on_Rails_6.tgz
258 <div style="position: relative;"> 261http://tokyo.kapeli.com/feeds/RubyMotion.tgz
259 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 262http://tokyo.kapeli.com/feeds/Rust.tgz
260 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">6</div> 263http://tokyo.kapeli.com/feeds/SailsJS.tgz
261 </div> 264http://tokyo.kapeli.com/feeds/SaltStack.tgz
262 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 265http://tokyo.kapeli.com/feeds/Sass.tgz
263</span></span></pre> 266http://tokyo.kapeli.com/feeds/Scala.tgz
264 </div> 267http://tokyo.kapeli.com/feeds/SciPy.tgz
265 <div style="position: relative;"> 268http://tokyo.kapeli.com/feeds/Semantic_UI.tgz
266 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 269http://tokyo.kapeli.com/feeds/Sencha_Touch.tgz
267 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">7</div> 270http://tokyo.kapeli.com/feeds/Sinon.tgz
268 </div> 271http://tokyo.kapeli.com/feeds/Smarty.tgz
269 <pre class=" CodeMirror-line " 272http://tokyo.kapeli.com/feeds/Sparrow.tgz
270 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://sanfrancisco.kapeli.com/feeds/{name}.tgz &nbsp; </span></pre> 273http://tokyo.kapeli.com/feeds/Spring_Framework.tgz
271 </div> 274http://tokyo.kapeli.com/feeds/SQLAlchemy.tgz
272 <div style="position: relative;"> 275http://tokyo.kapeli.com/feeds/SQLite.tgz
273 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 276http://tokyo.kapeli.com/feeds/Statamic.tgz
274 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">8</div> 277http://tokyo.kapeli.com/feeds/Stylus.tgz
275 </div> 278http://tokyo.kapeli.com/feeds/Susy.tgz
276 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 279http://tokyo.kapeli.com/feeds/SVG.tgz
277</span></span></pre> 280http://tokyo.kapeli.com/feeds/Swift.tgz
278 </div> 281http://tokyo.kapeli.com/feeds/Symfony.tgz
279 <div style="position: relative;"> 282http://tokyo.kapeli.com/feeds/Tcl.tgz
280 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 283http://tokyo.kapeli.com/feeds/Tornado.tgz
281 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">9</div> 284http://tokyo.kapeli.com/feeds/Twig.tgz
282 </div> 285http://tokyo.kapeli.com/feeds/Twisted.tgz
283 <pre class=" CodeMirror-line " 286http://tokyo.kapeli.com/feeds/TypeScript.tgz
284 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://frankfurt.kapeli.com/feeds/{name}.tgz </span></pre> 287http://tokyo.kapeli.com/feeds/TYPO3.tgz
285 </div> 288http://tokyo.kapeli.com/feeds/UnderscoreJS.tgz
286 <div style="position: relative;"> 289http://tokyo.kapeli.com/feeds/Unity_3D.tgz
287 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 290http://tokyo.kapeli.com/feeds/Vagrant.tgz
288 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show" 291http://tokyo.kapeli.com/feeds/Vim.tgz
289 style="left: 0px; width: 27px;">10</div> 292http://tokyo.kapeli.com/feeds/VMware_vSphere.tgz
290 </div> 293http://tokyo.kapeli.com/feeds/VueJS.tgz
291 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 294http://tokyo.kapeli.com/feeds/WordPress.tgz
292</span></span></pre> 295http://tokyo.kapeli.com/feeds/Xamarin.tgz
293 </div> 296http://tokyo.kapeli.com/feeds/Xojo.tgz
294 <div style="position: relative;"> 297http://tokyo.kapeli.com/feeds/XSLT.tgz
295 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 298http://tokyo.kapeli.com/feeds/Yii.tgz
296 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">11</div> 299http://tokyo.kapeli.com/feeds/YUI.tgz
297 </div> 300http://tokyo.kapeli.com/feeds/Zend_Framework_1.tgz
298 <pre class=" CodeMirror-line " 301http://tokyo.kapeli.com/feeds/Zend_Framework_2.tgz
299 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://newyork.kapeli.com/feeds/{name}.tgz </span></pre> 302http://tokyo.kapeli.com/feeds/Zend_Framework_3.tgz
300 </div> 303http://tokyo.kapeli.com/feeds/ZeptoJS.tgz</code></pre>
301 <div style="position: relative;"> 304 <h2 id="移动">移动</h2>
302 <div class="CodeMirror-gutter-wrapper" style="left: -36px;"> 305 <p>下载完成后,对压缩包进行解压,并将解压所得文件夹整体放入上文规定的 Zeal 文档存储路径之下。</p>
303 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">12</div> 306 <p>重启 Zeal,即可在左侧看到信息,可以在左上角搜索了。</p>
304 </div> 307 <p class="time">2023.3.26</p>
305 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp=""> 308 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
306</span></span></pre>
307 </div>
308 <div style="position: relative;">
309 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
310 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">13</div>
311 </div>
312 <pre class=" CodeMirror-line "
313 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://sydney.kapeli.com/feeds/{name}.tgz </span></pre>
314 </div>
315 <div style="position: relative;">
316 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
317 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">14</div>
318 </div>
319 <pre class=" CodeMirror-line " role="presentation"><span role="presentation" style="padding-right: 0.1px;"><span cm-text="" cm-zwsp="">
320</span></span></pre>
321 </div>
322 <div style="position: relative;">
323 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
324 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
325 style="left: 0px; width: 27px;">15</div>
326 </div>
327 <pre class=" CodeMirror-line "
328 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://london.kapeli.com/feeds/{name}.tgz</span></pre>
329 </div>
330 </div>
331 </div>
332 </div>
333 </div>
334 </div>
335 <div style="position: absolute; height: 0px; width: 1px; border-bottom: 0px solid transparent; top: 372px;"></div>
336 <div class="CodeMirror-gutters" style="height: 372px; left: 0px;">
337 <div class="CodeMirror-gutter CodeMirror-linenumbers" style="width: 35px;"></div>
338 </div>
339 </div>
340 </div>
341 </pre>
342 <p><span>此时,把所需文档的name替换掉链接中的{name}即可,得到下载链接如下:</span></p>
343 <pre class="md-fences md-end-block md-fences-with-lineno ty-contain-cm modeLoaded" spellcheck="false" lang=""
344 style="break-inside: unset;"><div class="CodeMirror cm-s-inner cm-s-null-scroll CodeMirror-wrap" lang=""><div style="overflow: hidden; position: relative; width: 3px; height: 0px; top: 10.4px; left: 48px;"><textarea autocorrect="off" autocapitalize="off" spellcheck="false" tabindex="0" style="position: absolute; bottom: -1em; padding: 0px; width: 1000px; height: 1em; outline: none;"></textarea></div><div class="CodeMirror-scrollbar-filler" cm-not-content="true"></div><div class="CodeMirror-gutter-filler" cm-not-content="true"></div><div class="CodeMirror-scroll" tabindex="-1"><div class="CodeMirror-sizer" style="margin-left: 36px; margin-bottom: 0px; border-right-width: 0px; padding-right: 0px; padding-bottom: 0px;"><div style="position: relative; top: 0px;"><div class="CodeMirror-lines" role="presentation"><div role="presentation" style="position: relative; outline: none;"><div class="CodeMirror-measure"><pre><span>xxxxxxxxxx</span></pre>
345 <div class="CodeMirror-linenumber CodeMirror-gutter-elt">
346 <div>205</div>
347 </div>
348 </div>
349 <div class="CodeMirror-measure"></div>
350 <div style="position: relative; z-index: 1;"></div>
351 <div class="CodeMirror-code" role="presentation" style="">
352 <div class="CodeMirror-activeline" style="position: relative;">
353 <div class="CodeMirror-activeline-background CodeMirror-linebackground"></div>
354 <div class="CodeMirror-gutter-background CodeMirror-activeline-gutter" style="left: -36px; width: 36px;">
355 </div>
356 <div class="CodeMirror-gutter-wrapper CodeMirror-activeline-gutter" style="left: -36px;">
357 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
358 style="left: 0px; width: 27px;">1</div>
359 </div>
360 <pre class=" CodeMirror-line "
361 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ActionScript.tgz</span></pre>
362 </div>
363 <div style="position: relative;">
364 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
365 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">2</div>
366 </div>
367 <pre class=" CodeMirror-line "
368 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Akka.tgz</span></pre>
369 </div>
370 <div style="position: relative;">
371 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
372 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">3</div>
373 </div>
374 <pre class=" CodeMirror-line "
375 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Android.tgz</span></pre>
376 </div>
377 <div style="position: relative;">
378 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
379 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">4</div>
380 </div>
381 <pre class=" CodeMirror-line "
382 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Angular.tgz</span></pre>
383 </div>
384 <div style="position: relative;">
385 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
386 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">5</div>
387 </div>
388 <pre class=" CodeMirror-line "
389 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/AngularJS.tgz</span></pre>
390 </div>
391 <div style="position: relative;">
392 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
393 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">6</div>
394 </div>
395 <pre class=" CodeMirror-line "
396 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ansible.tgz</span></pre>
397 </div>
398 <div style="position: relative;">
399 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
400 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">7</div>
401 </div>
402 <pre class=" CodeMirror-line "
403 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Apache_HTTP_Server.tgz</span></pre>
404 </div>
405 <div style="position: relative;">
406 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
407 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">8</div>
408 </div>
409 <pre class=" CodeMirror-line "
410 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Appcelerator_Titanium.tgz</span></pre>
411 </div>
412 <div style="position: relative;">
413 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
414 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">9</div>
415 </div>
416 <pre class=" CodeMirror-line "
417 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/AppleScript.tgz</span></pre>
418 </div>
419 <div style="position: relative;">
420 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
421 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
422 style="left: 0px; width: 27px;">10</div>
423 </div>
424 <pre class=" CodeMirror-line "
425 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Arduino.tgz</span></pre>
426 </div>
427 <div style="position: relative;">
428 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
429 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">11</div>
430 </div>
431 <pre class=" CodeMirror-line "
432 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/AWS_JavaScript.tgz</span></pre>
433 </div>
434 <div style="position: relative;">
435 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
436 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">12</div>
437 </div>
438 <pre class=" CodeMirror-line "
439 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/BackboneJS.tgz</span></pre>
440 </div>
441 <div style="position: relative;">
442 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
443 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">13</div>
444 </div>
445 <pre class=" CodeMirror-line "
446 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bash.tgz</span></pre>
447 </div>
448 <div style="position: relative;">
449 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
450 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">14</div>
451 </div>
452 <pre class=" CodeMirror-line "
453 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Boost.tgz</span></pre>
454 </div>
455 <div style="position: relative;">
456 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
457 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">15</div>
458 </div>
459 <pre class=" CodeMirror-line "
460 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bootstrap_2.tgz</span></pre>
461 </div>
462 <div style="position: relative;">
463 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
464 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">16</div>
465 </div>
466 <pre class=" CodeMirror-line "
467 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bootstrap_3.tgz</span></pre>
468 </div>
469 <div style="position: relative;">
470 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
471 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">17</div>
472 </div>
473 <pre class=" CodeMirror-line "
474 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bootstrap_4.tgz</span></pre>
475 </div>
476 <div style="position: relative;">
477 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
478 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">18</div>
479 </div>
480 <pre class=" CodeMirror-line "
481 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bootstrap_5.tgz</span></pre>
482 </div>
483 <div style="position: relative;">
484 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
485 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">19</div>
486 </div>
487 <pre class=" CodeMirror-line "
488 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Bourbon.tgz</span></pre>
489 </div>
490 <div style="position: relative;">
491 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
492 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
493 style="left: 0px; width: 27px;">20</div>
494 </div>
495 <pre class=" CodeMirror-line "
496 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/C.tgz</span></pre>
497 </div>
498 <div style="position: relative;">
499 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
500 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">21</div>
501 </div>
502 <pre class=" CodeMirror-line "
503 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/C++.tgz</span></pre>
504 </div>
505 <div style="position: relative;">
506 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
507 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">22</div>
508 </div>
509 <pre class=" CodeMirror-line "
510 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CakePHP.tgz</span></pre>
511 </div>
512 <div style="position: relative;">
513 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
514 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">23</div>
515 </div>
516 <pre class=" CodeMirror-line "
517 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Cappuccino.tgz</span></pre>
518 </div>
519 <div style="position: relative;">
520 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
521 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">24</div>
522 </div>
523 <pre class=" CodeMirror-line "
524 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Chai.tgz</span></pre>
525 </div>
526 <div style="position: relative;">
527 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
528 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">25</div>
529 </div>
530 <pre class=" CodeMirror-line "
531 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Chef.tgz</span></pre>
532 </div>
533 <div style="position: relative;">
534 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
535 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">26</div>
536 </div>
537 <pre class=" CodeMirror-line "
538 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Clojure.tgz</span></pre>
539 </div>
540 <div style="position: relative;">
541 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
542 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">27</div>
543 </div>
544 <pre class=" CodeMirror-line "
545 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CMake.tgz</span></pre>
546 </div>
547 <div style="position: relative;">
548 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
549 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">28</div>
550 </div>
551 <pre class=" CodeMirror-line "
552 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Cocos2D.tgz</span></pre>
553 </div>
554 <div style="position: relative;">
555 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
556 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">29</div>
557 </div>
558 <pre class=" CodeMirror-line "
559 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Cocos2D-X.tgz</span></pre>
560 </div>
561 <div style="position: relative;">
562 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
563 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
564 style="left: 0px; width: 27px;">30</div>
565 </div>
566 <pre class=" CodeMirror-line "
567 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Cocos3D.tgz</span></pre>
568 </div>
569 <div style="position: relative;">
570 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
571 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">31</div>
572 </div>
573 <pre class=" CodeMirror-line "
574 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CodeIgniter.tgz</span></pre>
575 </div>
576 <div style="position: relative;">
577 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
578 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">32</div>
579 </div>
580 <pre class=" CodeMirror-line "
581 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CoffeeScript.tgz</span></pre>
582 </div>
583 <div style="position: relative;">
584 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
585 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">33</div>
586 </div>
587 <pre class=" CodeMirror-line "
588 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ColdFusion.tgz</span></pre>
589 </div>
590 <div style="position: relative;">
591 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
592 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">34</div>
593 </div>
594 <pre class=" CodeMirror-line "
595 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Common_Lisp.tgz</span></pre>
596 </div>
597 <div style="position: relative;">
598 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
599 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">35</div>
600 </div>
601 <pre class=" CodeMirror-line "
602 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Compass.tgz</span></pre>
603 </div>
604 <div style="position: relative;">
605 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
606 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">36</div>
607 </div>
608 <pre class=" CodeMirror-line "
609 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Cordova.tgz</span></pre>
610 </div>
611 <div style="position: relative;">
612 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
613 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">37</div>
614 </div>
615 <pre class=" CodeMirror-line "
616 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Corona.tgz</span></pre>
617 </div>
618 <div style="position: relative;">
619 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
620 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">38</div>
621 </div>
622 <pre class=" CodeMirror-line "
623 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CouchDB.tgz</span></pre>
624 </div>
625 <div style="position: relative;">
626 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
627 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">39</div>
628 </div>
629 <pre class=" CodeMirror-line "
630 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Craft.tgz</span></pre>
631 </div>
632 <div style="position: relative;">
633 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
634 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
635 style="left: 0px; width: 27px;">40</div>
636 </div>
637 <pre class=" CodeMirror-line "
638 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/CSS.tgz</span></pre>
639 </div>
640 <div style="position: relative;">
641 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
642 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">41</div>
643 </div>
644 <pre class=" CodeMirror-line "
645 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/D3JS.tgz</span></pre>
646 </div>
647 <div style="position: relative;">
648 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
649 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">42</div>
650 </div>
651 <pre class=" CodeMirror-line "
652 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Dart.tgz</span></pre>
653 </div>
654 <div style="position: relative;">
655 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
656 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">43</div>
657 </div>
658 <pre class=" CodeMirror-line "
659 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Django.tgz</span></pre>
660 </div>
661 <div style="position: relative;">
662 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
663 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">44</div>
664 </div>
665 <pre class=" CodeMirror-line "
666 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Docker.tgz</span></pre>
667 </div>
668 <div style="position: relative;">
669 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
670 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">45</div>
671 </div>
672 <pre class=" CodeMirror-line "
673 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Doctrine_ORM.tgz</span></pre>
674 </div>
675 <div style="position: relative;">
676 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
677 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">46</div>
678 </div>
679 <pre class=" CodeMirror-line "
680 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Dojo.tgz</span></pre>
681 </div>
682 <div style="position: relative;">
683 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
684 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">47</div>
685 </div>
686 <pre class=" CodeMirror-line "
687 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Drupal_7.tgz</span></pre>
688 </div>
689 <div style="position: relative;">
690 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
691 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">48</div>
692 </div>
693 <pre class=" CodeMirror-line "
694 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Drupal_8.tgz</span></pre>
695 </div>
696 <div style="position: relative;">
697 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
698 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">49</div>
699 </div>
700 <pre class=" CodeMirror-line "
701 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Drupal_9.tgz</span></pre>
702 </div>
703 <div style="position: relative;">
704 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
705 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
706 style="left: 0px; width: 27px;">50</div>
707 </div>
708 <pre class=" CodeMirror-line "
709 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ElasticSearch.tgz</span></pre>
710 </div>
711 <div style="position: relative;">
712 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
713 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">51</div>
714 </div>
715 <pre class=" CodeMirror-line "
716 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Elixir.tgz</span></pre>
717 </div>
718 <div style="position: relative;">
719 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
720 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">52</div>
721 </div>
722 <pre class=" CodeMirror-line "
723 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Emacs_Lisp.tgz</span></pre>
724 </div>
725 <div style="position: relative;">
726 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
727 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">53</div>
728 </div>
729 <pre class=" CodeMirror-line "
730 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/EmberJS.tgz</span></pre>
731 </div>
732 <div style="position: relative;">
733 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
734 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">54</div>
735 </div>
736 <pre class=" CodeMirror-line "
737 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Emmet.tgz</span></pre>
738 </div>
739 <div style="position: relative;">
740 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
741 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">55</div>
742 </div>
743 <pre class=" CodeMirror-line "
744 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Erlang.tgz</span></pre>
745 </div>
746 <div style="position: relative;">
747 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
748 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">56</div>
749 </div>
750 <pre class=" CodeMirror-line "
751 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Express.tgz</span></pre>
752 </div>
753 <div style="position: relative;">
754 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
755 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">57</div>
756 </div>
757 <pre class=" CodeMirror-line "
758 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ExpressionEngine.tgz</span></pre>
759 </div>
760 <div style="position: relative;">
761 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
762 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">58</div>
763 </div>
764 <pre class=" CodeMirror-line "
765 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ExtJS.tgz</span></pre>
766 </div>
767 <div style="position: relative;">
768 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
769 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">59</div>
770 </div>
771 <pre class=" CodeMirror-line "
772 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Flask.tgz</span></pre>
773 </div>
774 <div style="position: relative;">
775 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
776 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
777 style="left: 0px; width: 27px;">60</div>
778 </div>
779 <pre class=" CodeMirror-line "
780 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Font_Awesome.tgz</span></pre>
781 </div>
782 <div style="position: relative;">
783 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
784 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">61</div>
785 </div>
786 <pre class=" CodeMirror-line "
787 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Foundation.tgz</span></pre>
788 </div>
789 <div style="position: relative;">
790 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
791 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">62</div>
792 </div>
793 <pre class=" CodeMirror-line "
794 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/GLib.tgz</span></pre>
795 </div>
796 <div style="position: relative;">
797 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
798 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">63</div>
799 </div>
800 <pre class=" CodeMirror-line "
801 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Go.tgz</span></pre>
802 </div>
803 <div style="position: relative;">
804 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
805 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">64</div>
806 </div>
807 <pre class=" CodeMirror-line "
808 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Gradle_DSL.tgz</span></pre>
809 </div>
810 <div style="position: relative;">
811 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
812 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">65</div>
813 </div>
814 <pre class=" CodeMirror-line "
815 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Gradle_Java_API.tgz</span></pre>
816 </div>
817 <div style="position: relative;">
818 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
819 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">66</div>
820 </div>
821 <pre class=" CodeMirror-line "
822 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Gradle_User_Guide.tgz</span></pre>
823 </div>
824 <div style="position: relative;">
825 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
826 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">67</div>
827 </div>
828 <pre class=" CodeMirror-line "
829 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Grails.tgz</span></pre>
830 </div>
831 <div style="position: relative;">
832 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
833 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">68</div>
834 </div>
835 <pre class=" CodeMirror-line "
836 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Groovy.tgz</span></pre>
837 </div>
838 <div style="position: relative;">
839 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
840 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">69</div>
841 </div>
842 <pre class=" CodeMirror-line "
843 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Groovy_JDK.tgz</span></pre>
844 </div>
845 <div style="position: relative;">
846 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
847 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
848 style="left: 0px; width: 27px;">70</div>
849 </div>
850 <pre class=" CodeMirror-line "
851 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Grunt.tgz</span></pre>
852 </div>
853 <div style="position: relative;">
854 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
855 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">71</div>
856 </div>
857 <pre class=" CodeMirror-line "
858 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Gulp.tgz</span></pre>
859 </div>
860 <div style="position: relative;">
861 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
862 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">72</div>
863 </div>
864 <pre class=" CodeMirror-line "
865 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Haml.tgz</span></pre>
866 </div>
867 <div style="position: relative;">
868 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
869 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">73</div>
870 </div>
871 <pre class=" CodeMirror-line "
872 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Handlebars.tgz</span></pre>
873 </div>
874 <div style="position: relative;">
875 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
876 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">74</div>
877 </div>
878 <pre class=" CodeMirror-line "
879 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Haskell.tgz</span></pre>
880 </div>
881 <div style="position: relative;">
882 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
883 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">75</div>
884 </div>
885 <pre class=" CodeMirror-line "
886 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/HTML.tgz</span></pre>
887 </div>
888 <div style="position: relative;">
889 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
890 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">76</div>
891 </div>
892 <pre class=" CodeMirror-line "
893 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ionic.tgz</span></pre>
894 </div>
895 <div style="position: relative;">
896 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
897 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">77</div>
898 </div>
899 <pre class=" CodeMirror-line "
900 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Jasmine.tgz</span></pre>
901 </div>
902 <div style="position: relative;">
903 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
904 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">78</div>
905 </div>
906 <pre class=" CodeMirror-line "
907 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_EE6.tgz</span></pre>
908 </div>
909 <div style="position: relative;">
910 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
911 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">79</div>
912 </div>
913 <pre class=" CodeMirror-line "
914 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_EE7.tgz</span></pre>
915 </div>
916 <div style="position: relative;">
917 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
918 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
919 style="left: 0px; width: 27px;">80</div>
920 </div>
921 <pre class=" CodeMirror-line "
922 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_EE8.tgz</span></pre>
923 </div>
924 <div style="position: relative;">
925 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
926 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">81</div>
927 </div>
928 <pre class=" CodeMirror-line "
929 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE10.tgz</span></pre>
930 </div>
931 <div style="position: relative;">
932 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
933 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">82</div>
934 </div>
935 <pre class=" CodeMirror-line "
936 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE11.tgz</span></pre>
937 </div>
938 <div style="position: relative;">
939 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
940 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">83</div>
941 </div>
942 <pre class=" CodeMirror-line "
943 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE12.tgz</span></pre>
944 </div>
945 <div style="position: relative;">
946 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
947 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">84</div>
948 </div>
949 <pre class=" CodeMirror-line "
950 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE13.tgz</span></pre>
951 </div>
952 <div style="position: relative;">
953 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
954 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">85</div>
955 </div>
956 <pre class=" CodeMirror-line "
957 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE14.tgz</span></pre>
958 </div>
959 <div style="position: relative;">
960 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
961 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">86</div>
962 </div>
963 <pre class=" CodeMirror-line "
964 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE15.tgz</span></pre>
965 </div>
966 <div style="position: relative;">
967 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
968 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">87</div>
969 </div>
970 <pre class=" CodeMirror-line "
971 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE16.tgz</span></pre>
972 </div>
973 <div style="position: relative;">
974 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
975 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">88</div>
976 </div>
977 <pre class=" CodeMirror-line "
978 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE6.tgz</span></pre>
979 </div>
980 <div style="position: relative;">
981 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
982 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">89</div>
983 </div>
984 <pre class=" CodeMirror-line "
985 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE7.tgz</span></pre>
986 </div>
987 <div style="position: relative;">
988 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
989 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
990 style="left: 0px; width: 27px;">90</div>
991 </div>
992 <pre class=" CodeMirror-line "
993 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE8.tgz</span></pre>
994 </div>
995 <div style="position: relative;">
996 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
997 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">91</div>
998 </div>
999 <pre class=" CodeMirror-line "
1000 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Java_SE9.tgz</span></pre>
1001 </div>
1002 <div style="position: relative;">
1003 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1004 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">92</div>
1005 </div>
1006 <pre class=" CodeMirror-line "
1007 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/JavaFX.tgz</span></pre>
1008 </div>
1009 <div style="position: relative;">
1010 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1011 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">93</div>
1012 </div>
1013 <pre class=" CodeMirror-line "
1014 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/JavaScript.tgz</span></pre>
1015 </div>
1016 <div style="position: relative;">
1017 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1018 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">94</div>
1019 </div>
1020 <pre class=" CodeMirror-line "
1021 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Jekyll.tgz</span></pre>
1022 </div>
1023 <div style="position: relative;">
1024 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1025 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">95</div>
1026 </div>
1027 <pre class=" CodeMirror-line "
1028 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Jinja.tgz</span></pre>
1029 </div>
1030 <div style="position: relative;">
1031 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1032 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">96</div>
1033 </div>
1034 <pre class=" CodeMirror-line "
1035 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Joomla.tgz</span></pre>
1036 </div>
1037 <div style="position: relative;">
1038 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1039 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">97</div>
1040 </div>
1041 <pre class=" CodeMirror-line "
1042 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/jQuery.tgz</span></pre>
1043 </div>
1044 <div style="position: relative;">
1045 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1046 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">98</div>
1047 </div>
1048 <pre class=" CodeMirror-line "
1049 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/jQuery_Mobile.tgz</span></pre>
1050 </div>
1051 <div style="position: relative;">
1052 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1053 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">99</div>
1054 </div>
1055 <pre class=" CodeMirror-line "
1056 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/jQuery_UI.tgz</span></pre>
1057 </div>
1058 <div style="position: relative;">
1059 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1060 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1061 style="left: 0px; width: 27px;">100</div>
1062 </div>
1063 <pre class=" CodeMirror-line "
1064 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Julia.tgz</span></pre>
1065 </div>
1066 <div style="position: relative;">
1067 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1068 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">101</div>
1069 </div>
1070 <pre class=" CodeMirror-line "
1071 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/KnockoutJS.tgz</span></pre>
1072 </div>
1073 <div style="position: relative;">
1074 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1075 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">102</div>
1076 </div>
1077 <pre class=" CodeMirror-line "
1078 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Kobold2D.tgz</span></pre>
1079 </div>
1080 <div style="position: relative;">
1081 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1082 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">103</div>
1083 </div>
1084 <pre class=" CodeMirror-line "
1085 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Laravel.tgz</span></pre>
1086 </div>
1087 <div style="position: relative;">
1088 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1089 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">104</div>
1090 </div>
1091 <pre class=" CodeMirror-line "
1092 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/LaTeX.tgz</span></pre>
1093 </div>
1094 <div style="position: relative;">
1095 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1096 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">105</div>
1097 </div>
1098 <pre class=" CodeMirror-line "
1099 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Less.tgz</span></pre>
1100 </div>
1101 <div style="position: relative;">
1102 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1103 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">106</div>
1104 </div>
1105 <pre class=" CodeMirror-line "
1106 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Lo-Dash.tgz</span></pre>
1107 </div>
1108 <div style="position: relative;">
1109 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1110 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">107</div>
1111 </div>
1112 <pre class=" CodeMirror-line "
1113 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Lua_5.1.tgz</span></pre>
1114 </div>
1115 <div style="position: relative;">
1116 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1117 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">108</div>
1118 </div>
1119 <pre class=" CodeMirror-line "
1120 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Lua_5.2.tgz</span></pre>
1121 </div>
1122 <div style="position: relative;">
1123 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1124 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">109</div>
1125 </div>
1126 <pre class=" CodeMirror-line "
1127 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Lua_5.3.tgz</span></pre>
1128 </div>
1129 <div style="position: relative;">
1130 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1131 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1132 style="left: 0px; width: 27px;">110</div>
1133 </div>
1134 <pre class=" CodeMirror-line "
1135 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Lua_5.4.tgz</span></pre>
1136 </div>
1137 <div style="position: relative;">
1138 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1139 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">111</div>
1140 </div>
1141 <pre class=" CodeMirror-line "
1142 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/MarionetteJS.tgz</span></pre>
1143 </div>
1144 <div style="position: relative;">
1145 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1146 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">112</div>
1147 </div>
1148 <pre class=" CodeMirror-line "
1149 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Markdown.tgz</span></pre>
1150 </div>
1151 <div style="position: relative;">
1152 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1153 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">113</div>
1154 </div>
1155 <pre class=" CodeMirror-line "
1156 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Matplotlib.tgz</span></pre>
1157 </div>
1158 <div style="position: relative;">
1159 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1160 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">114</div>
1161 </div>
1162 <pre class=" CodeMirror-line "
1163 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Meteor.tgz</span></pre>
1164 </div>
1165 <div style="position: relative;">
1166 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1167 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">115</div>
1168 </div>
1169 <pre class=" CodeMirror-line "
1170 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Mocha.tgz</span></pre>
1171 </div>
1172 <div style="position: relative;">
1173 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1174 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">116</div>
1175 </div>
1176 <pre class=" CodeMirror-line "
1177 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/MomentJS.tgz</span></pre>
1178 </div>
1179 <div style="position: relative;">
1180 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1181 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">117</div>
1182 </div>
1183 <pre class=" CodeMirror-line "
1184 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/MongoDB.tgz</span></pre>
1185 </div>
1186 <div style="position: relative;">
1187 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1188 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">118</div>
1189 </div>
1190 <pre class=" CodeMirror-line "
1191 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Mongoose.tgz</span></pre>
1192 </div>
1193 <div style="position: relative;">
1194 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1195 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">119</div>
1196 </div>
1197 <pre class=" CodeMirror-line "
1198 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Mono.tgz</span></pre>
1199 </div>
1200 <div style="position: relative;">
1201 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1202 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1203 style="left: 0px; width: 27px;">120</div>
1204 </div>
1205 <pre class=" CodeMirror-line "
1206 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/MooTools.tgz</span></pre>
1207 </div>
1208 <div style="position: relative;">
1209 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1210 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">121</div>
1211 </div>
1212 <pre class=" CodeMirror-line "
1213 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/MySQL.tgz</span></pre>
1214 </div>
1215 <div style="position: relative;">
1216 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1217 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">122</div>
1218 </div>
1219 <pre class=" CodeMirror-line "
1220 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Neat.tgz</span></pre>
1221 </div>
1222 <div style="position: relative;">
1223 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1224 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">123</div>
1225 </div>
1226 <pre class=" CodeMirror-line "
1227 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/NET_Framework.tgz</span></pre>
1228 </div>
1229 <div style="position: relative;">
1230 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1231 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">124</div>
1232 </div>
1233 <pre class=" CodeMirror-line "
1234 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Nginx.tgz</span></pre>
1235 </div>
1236 <div style="position: relative;">
1237 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1238 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">125</div>
1239 </div>
1240 <pre class=" CodeMirror-line "
1241 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/NodeJS.tgz</span></pre>
1242 </div>
1243 <div style="position: relative;">
1244 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1245 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">126</div>
1246 </div>
1247 <pre class=" CodeMirror-line "
1248 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/NumPy.tgz</span></pre>
1249 </div>
1250 <div style="position: relative;">
1251 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1252 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">127</div>
1253 </div>
1254 <pre class=" CodeMirror-line "
1255 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/OCaml.tgz</span></pre>
1256 </div>
1257 <div style="position: relative;">
1258 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1259 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">128</div>
1260 </div>
1261 <pre class=" CodeMirror-line "
1262 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/OpenCV.tgz</span></pre>
1263 </div>
1264 <div style="position: relative;">
1265 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1266 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">129</div>
1267 </div>
1268 <pre class=" CodeMirror-line "
1269 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/OpenGL_2.tgz</span></pre>
1270 </div>
1271 <div style="position: relative;">
1272 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1273 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1274 style="left: 0px; width: 27px;">130</div>
1275 </div>
1276 <pre class=" CodeMirror-line "
1277 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/OpenGL_3.tgz</span></pre>
1278 </div>
1279 <div style="position: relative;">
1280 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1281 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">131</div>
1282 </div>
1283 <pre class=" CodeMirror-line "
1284 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/OpenGL_4.tgz</span></pre>
1285 </div>
1286 <div style="position: relative;">
1287 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1288 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">132</div>
1289 </div>
1290 <pre class=" CodeMirror-line "
1291 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Pandas.tgz</span></pre>
1292 </div>
1293 <div style="position: relative;">
1294 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1295 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">133</div>
1296 </div>
1297 <pre class=" CodeMirror-line "
1298 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Perl.tgz</span></pre>
1299 </div>
1300 <div style="position: relative;">
1301 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1302 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">134</div>
1303 </div>
1304 <pre class=" CodeMirror-line "
1305 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Phalcon.tgz</span></pre>
1306 </div>
1307 <div style="position: relative;">
1308 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1309 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">135</div>
1310 </div>
1311 <pre class=" CodeMirror-line "
1312 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/PhoneGap.tgz</span></pre>
1313 </div>
1314 <div style="position: relative;">
1315 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1316 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">136</div>
1317 </div>
1318 <pre class=" CodeMirror-line "
1319 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/PHP.tgz</span></pre>
1320 </div>
1321 <div style="position: relative;">
1322 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1323 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">137</div>
1324 </div>
1325 <pre class=" CodeMirror-line "
1326 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/PHPUnit.tgz</span></pre>
1327 </div>
1328 <div style="position: relative;">
1329 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1330 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">138</div>
1331 </div>
1332 <pre class=" CodeMirror-line "
1333 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Play_Java.tgz</span></pre>
1334 </div>
1335 <div style="position: relative;">
1336 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1337 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">139</div>
1338 </div>
1339 <pre class=" CodeMirror-line "
1340 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Play_Scala.tgz</span></pre>
1341 </div>
1342 <div style="position: relative;">
1343 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1344 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1345 style="left: 0px; width: 27px;">140</div>
1346 </div>
1347 <pre class=" CodeMirror-line "
1348 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Polymer.dart.tgz</span></pre>
1349 </div>
1350 <div style="position: relative;">
1351 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1352 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">141</div>
1353 </div>
1354 <pre class=" CodeMirror-line "
1355 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/PostgreSQL.tgz</span></pre>
1356 </div>
1357 <div style="position: relative;">
1358 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1359 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">142</div>
1360 </div>
1361 <pre class=" CodeMirror-line "
1362 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Processing.tgz</span></pre>
1363 </div>
1364 <div style="position: relative;">
1365 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1366 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">143</div>
1367 </div>
1368 <pre class=" CodeMirror-line "
1369 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/PrototypeJS.tgz</span></pre>
1370 </div>
1371 <div style="position: relative;">
1372 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1373 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">144</div>
1374 </div>
1375 <pre class=" CodeMirror-line "
1376 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Pug.tgz</span></pre>
1377 </div>
1378 <div style="position: relative;">
1379 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1380 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">145</div>
1381 </div>
1382 <pre class=" CodeMirror-line "
1383 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Puppet.tgz</span></pre>
1384 </div>
1385 <div style="position: relative;">
1386 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1387 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">146</div>
1388 </div>
1389 <pre class=" CodeMirror-line "
1390 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Python_2.tgz</span></pre>
1391 </div>
1392 <div style="position: relative;">
1393 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1394 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">147</div>
1395 </div>
1396 <pre class=" CodeMirror-line "
1397 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Python_3.tgz</span></pre>
1398 </div>
1399 <div style="position: relative;">
1400 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1401 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">148</div>
1402 </div>
1403 <pre class=" CodeMirror-line "
1404 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Qt_4.tgz</span></pre>
1405 </div>
1406 <div style="position: relative;">
1407 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1408 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">149</div>
1409 </div>
1410 <pre class=" CodeMirror-line "
1411 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Qt_5.tgz</span></pre>
1412 </div>
1413 <div style="position: relative;">
1414 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1415 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1416 style="left: 0px; width: 27px;">150</div>
1417 </div>
1418 <pre class=" CodeMirror-line "
1419 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Qt_6.tgz</span></pre>
1420 </div>
1421 <div style="position: relative;">
1422 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1423 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">151</div>
1424 </div>
1425 <pre class=" CodeMirror-line "
1426 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/R.tgz</span></pre>
1427 </div>
1428 <div style="position: relative;">
1429 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1430 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">152</div>
1431 </div>
1432 <pre class=" CodeMirror-line "
1433 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Racket.tgz</span></pre>
1434 </div>
1435 <div style="position: relative;">
1436 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1437 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">153</div>
1438 </div>
1439 <pre class=" CodeMirror-line "
1440 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/React.tgz</span></pre>
1441 </div>
1442 <div style="position: relative;">
1443 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1444 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">154</div>
1445 </div>
1446 <pre class=" CodeMirror-line "
1447 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Redis.tgz</span></pre>
1448 </div>
1449 <div style="position: relative;">
1450 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1451 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">155</div>
1452 </div>
1453 <pre class=" CodeMirror-line "
1454 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/RequireJS.tgz</span></pre>
1455 </div>
1456 <div style="position: relative;">
1457 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1458 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">156</div>
1459 </div>
1460 <pre class=" CodeMirror-line "
1461 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby.tgz</span></pre>
1462 </div>
1463 <div style="position: relative;">
1464 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1465 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">157</div>
1466 </div>
1467 <pre class=" CodeMirror-line "
1468 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_2.tgz</span></pre>
1469 </div>
1470 <div style="position: relative;">
1471 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1472 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">158</div>
1473 </div>
1474 <pre class=" CodeMirror-line "
1475 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_3.tgz</span></pre>
1476 </div>
1477 <div style="position: relative;">
1478 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1479 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">159</div>
1480 </div>
1481 <pre class=" CodeMirror-line "
1482 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_on_Rails_3.tgz</span></pre>
1483 </div>
1484 <div style="position: relative;">
1485 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1486 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1487 style="left: 0px; width: 27px;">160</div>
1488 </div>
1489 <pre class=" CodeMirror-line "
1490 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_on_Rails_4.tgz</span></pre>
1491 </div>
1492 <div style="position: relative;">
1493 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1494 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">161</div>
1495 </div>
1496 <pre class=" CodeMirror-line "
1497 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_on_Rails_5.tgz</span></pre>
1498 </div>
1499 <div style="position: relative;">
1500 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1501 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">162</div>
1502 </div>
1503 <pre class=" CodeMirror-line "
1504 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Ruby_on_Rails_6.tgz</span></pre>
1505 </div>
1506 <div style="position: relative;">
1507 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1508 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">163</div>
1509 </div>
1510 <pre class=" CodeMirror-line "
1511 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/RubyMotion.tgz</span></pre>
1512 </div>
1513 <div style="position: relative;">
1514 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1515 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">164</div>
1516 </div>
1517 <pre class=" CodeMirror-line "
1518 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Rust.tgz</span></pre>
1519 </div>
1520 <div style="position: relative;">
1521 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1522 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">165</div>
1523 </div>
1524 <pre class=" CodeMirror-line "
1525 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SailsJS.tgz</span></pre>
1526 </div>
1527 <div style="position: relative;">
1528 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1529 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">166</div>
1530 </div>
1531 <pre class=" CodeMirror-line "
1532 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SaltStack.tgz</span></pre>
1533 </div>
1534 <div style="position: relative;">
1535 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1536 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">167</div>
1537 </div>
1538 <pre class=" CodeMirror-line "
1539 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Sass.tgz</span></pre>
1540 </div>
1541 <div style="position: relative;">
1542 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1543 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">168</div>
1544 </div>
1545 <pre class=" CodeMirror-line "
1546 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Scala.tgz</span></pre>
1547 </div>
1548 <div style="position: relative;">
1549 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1550 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">169</div>
1551 </div>
1552 <pre class=" CodeMirror-line "
1553 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SciPy.tgz</span></pre>
1554 </div>
1555 <div style="position: relative;">
1556 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1557 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1558 style="left: 0px; width: 27px;">170</div>
1559 </div>
1560 <pre class=" CodeMirror-line "
1561 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Semantic_UI.tgz</span></pre>
1562 </div>
1563 <div style="position: relative;">
1564 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1565 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">171</div>
1566 </div>
1567 <pre class=" CodeMirror-line "
1568 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Sencha_Touch.tgz</span></pre>
1569 </div>
1570 <div style="position: relative;">
1571 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1572 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">172</div>
1573 </div>
1574 <pre class=" CodeMirror-line "
1575 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Sinon.tgz</span></pre>
1576 </div>
1577 <div style="position: relative;">
1578 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1579 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">173</div>
1580 </div>
1581 <pre class=" CodeMirror-line "
1582 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Smarty.tgz</span></pre>
1583 </div>
1584 <div style="position: relative;">
1585 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1586 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">174</div>
1587 </div>
1588 <pre class=" CodeMirror-line "
1589 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Sparrow.tgz</span></pre>
1590 </div>
1591 <div style="position: relative;">
1592 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1593 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">175</div>
1594 </div>
1595 <pre class=" CodeMirror-line "
1596 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Spring_Framework.tgz</span></pre>
1597 </div>
1598 <div style="position: relative;">
1599 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1600 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">176</div>
1601 </div>
1602 <pre class=" CodeMirror-line "
1603 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SQLAlchemy.tgz</span></pre>
1604 </div>
1605 <div style="position: relative;">
1606 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1607 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">177</div>
1608 </div>
1609 <pre class=" CodeMirror-line "
1610 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SQLite.tgz</span></pre>
1611 </div>
1612 <div style="position: relative;">
1613 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1614 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">178</div>
1615 </div>
1616 <pre class=" CodeMirror-line "
1617 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Statamic.tgz</span></pre>
1618 </div>
1619 <div style="position: relative;">
1620 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1621 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">179</div>
1622 </div>
1623 <pre class=" CodeMirror-line "
1624 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Stylus.tgz</span></pre>
1625 </div>
1626 <div style="position: relative;">
1627 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1628 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1629 style="left: 0px; width: 27px;">180</div>
1630 </div>
1631 <pre class=" CodeMirror-line "
1632 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Susy.tgz</span></pre>
1633 </div>
1634 <div style="position: relative;">
1635 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1636 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">181</div>
1637 </div>
1638 <pre class=" CodeMirror-line "
1639 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/SVG.tgz</span></pre>
1640 </div>
1641 <div style="position: relative;">
1642 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1643 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">182</div>
1644 </div>
1645 <pre class=" CodeMirror-line "
1646 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Swift.tgz</span></pre>
1647 </div>
1648 <div style="position: relative;">
1649 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1650 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">183</div>
1651 </div>
1652 <pre class=" CodeMirror-line "
1653 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Symfony.tgz</span></pre>
1654 </div>
1655 <div style="position: relative;">
1656 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1657 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">184</div>
1658 </div>
1659 <pre class=" CodeMirror-line "
1660 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Tcl.tgz</span></pre>
1661 </div>
1662 <div style="position: relative;">
1663 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1664 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">185</div>
1665 </div>
1666 <pre class=" CodeMirror-line "
1667 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Tornado.tgz</span></pre>
1668 </div>
1669 <div style="position: relative;">
1670 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1671 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">186</div>
1672 </div>
1673 <pre class=" CodeMirror-line "
1674 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Twig.tgz</span></pre>
1675 </div>
1676 <div style="position: relative;">
1677 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1678 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">187</div>
1679 </div>
1680 <pre class=" CodeMirror-line "
1681 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Twisted.tgz</span></pre>
1682 </div>
1683 <div style="position: relative;">
1684 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1685 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">188</div>
1686 </div>
1687 <pre class=" CodeMirror-line "
1688 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/TypeScript.tgz</span></pre>
1689 </div>
1690 <div style="position: relative;">
1691 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1692 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">189</div>
1693 </div>
1694 <pre class=" CodeMirror-line "
1695 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/TYPO3.tgz</span></pre>
1696 </div>
1697 <div style="position: relative;">
1698 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1699 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1700 style="left: 0px; width: 27px;">190</div>
1701 </div>
1702 <pre class=" CodeMirror-line "
1703 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/UnderscoreJS.tgz</span></pre>
1704 </div>
1705 <div style="position: relative;">
1706 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1707 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">191</div>
1708 </div>
1709 <pre class=" CodeMirror-line "
1710 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Unity_3D.tgz</span></pre>
1711 </div>
1712 <div style="position: relative;">
1713 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1714 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">192</div>
1715 </div>
1716 <pre class=" CodeMirror-line "
1717 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Vagrant.tgz</span></pre>
1718 </div>
1719 <div style="position: relative;">
1720 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1721 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">193</div>
1722 </div>
1723 <pre class=" CodeMirror-line "
1724 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Vim.tgz</span></pre>
1725 </div>
1726 <div style="position: relative;">
1727 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1728 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">194</div>
1729 </div>
1730 <pre class=" CodeMirror-line "
1731 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/VMware_vSphere.tgz</span></pre>
1732 </div>
1733 <div style="position: relative;">
1734 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1735 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">195</div>
1736 </div>
1737 <pre class=" CodeMirror-line "
1738 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/VueJS.tgz</span></pre>
1739 </div>
1740 <div style="position: relative;">
1741 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1742 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">196</div>
1743 </div>
1744 <pre class=" CodeMirror-line "
1745 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/WordPress.tgz</span></pre>
1746 </div>
1747 <div style="position: relative;">
1748 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1749 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">197</div>
1750 </div>
1751 <pre class=" CodeMirror-line "
1752 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Xamarin.tgz</span></pre>
1753 </div>
1754 <div style="position: relative;">
1755 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1756 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">198</div>
1757 </div>
1758 <pre class=" CodeMirror-line "
1759 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Xojo.tgz</span></pre>
1760 </div>
1761 <div style="position: relative;">
1762 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1763 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">199</div>
1764 </div>
1765 <pre class=" CodeMirror-line "
1766 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/XSLT.tgz</span></pre>
1767 </div>
1768 <div style="position: relative;">
1769 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1770 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1771 style="left: 0px; width: 27px;">200</div>
1772 </div>
1773 <pre class=" CodeMirror-line "
1774 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Yii.tgz</span></pre>
1775 </div>
1776 <div style="position: relative;">
1777 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1778 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">201</div>
1779 </div>
1780 <pre class=" CodeMirror-line "
1781 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/YUI.tgz</span></pre>
1782 </div>
1783 <div style="position: relative;">
1784 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1785 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">202</div>
1786 </div>
1787 <pre class=" CodeMirror-line "
1788 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Zend_Framework_1.tgz</span></pre>
1789 </div>
1790 <div style="position: relative;">
1791 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1792 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">203</div>
1793 </div>
1794 <pre class=" CodeMirror-line "
1795 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Zend_Framework_2.tgz</span></pre>
1796 </div>
1797 <div style="position: relative;">
1798 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1799 <div class="CodeMirror-linenumber CodeMirror-gutter-elt" style="left: 0px; width: 27px;">204</div>
1800 </div>
1801 <pre class=" CodeMirror-line "
1802 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/Zend_Framework_3.tgz</span></pre>
1803 </div>
1804 <div style="position: relative;">
1805 <div class="CodeMirror-gutter-wrapper" style="left: -36px;">
1806 <div class="CodeMirror-linenumber CodeMirror-gutter-elt CodeMirror-linenumber-show"
1807 style="left: 0px; width: 27px;">205</div>
1808 </div>
1809 <pre class=" CodeMirror-line "
1810 role="presentation"><span role="presentation" style="padding-right: 0.1px;">http://tokyo.kapeli.com/feeds/ZeptoJS.tgz</span></pre>
1811 </div> 309 </div>
1812 </div> 310 </div>
1813 </div>
1814 </div>
1815 </div>
1816 </div>
1817 <div style="position: absolute; height: 0px; width: 1px; border-bottom: 0px solid transparent; top: 5084px;"></div>
1818 <div class="CodeMirror-gutters" style="height: 5084px; left: 0px;">
1819 <div class="CodeMirror-gutter CodeMirror-linenumbers" style="width: 35px;"></div>
1820 </div>
1821 </div>
1822 </div>
1823 </pre>
1824 <h2 id='移动'><span>移动</span></h2>
1825 <p><span>下载完成后,对压缩包进行解压,并将解压所得文件夹整体放入上文规定的Zeal文档存储路径之下。</span></p>
1826 <p><span>重启Zeal,即可在左侧看到信息,可以在左上角搜索了。</span></p>
1827 <p>&nbsp;</p>
1828 <p class="time">2023.3.26</p>
1829 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
1830 </div>
1831 </div>
1832</body> 311</body>
1833 312
1834</html> \ No newline at end of file 313</html> \ No newline at end of file
diff --git a/code/zeal.md b/code/zeal.md
index eeccf7c..db552af 100644
--- a/code/zeal.md
+++ b/code/zeal.md
@@ -295,14 +295,3 @@ http://tokyo.kapeli.com/feeds/ZeptoJS.tgz
295下载完成后,对压缩包进行解压,并将解压所得文件夹整体放入上文规定的 Zeal 文档存储路径之下。 295下载完成后,对压缩包进行解压,并将解压所得文件夹整体放入上文规定的 Zeal 文档存储路径之下。
296 296
297重启 Zeal,即可在左侧看到信息,可以在左上角搜索了。 297重启 Zeal,即可在左侧看到信息,可以在左上角搜索了。
298
299# test
300
301```mermaid
302graph LR
303A[1]-->B[2]
304```
305
306$$
307\int_0^\frac \pi 2 \sin x =1
308$$
diff --git a/common/script4code.html b/common/script4code.html
index 9de3349..c0f9b12 100644
--- a/common/script4code.html
+++ b/common/script4code.html
@@ -11,6 +11,7 @@
11 <!-- <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/js/click4code.js"></script> --> 11 <!-- <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/js/click4code.js"></script> -->
12 <script src="https://www.qin-juan-ge-zhu.top/common/js/click4notes.js"></script> 12 <script src="https://www.qin-juan-ge-zhu.top/common/js/click4notes.js"></script>
13 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/js/pandoc-menu.js"></script> 13 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/js/pandoc-menu.js"></script>
14 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
14</head> 15</head>
15 16
16<body class='typora-export os-windows'> 17<body class='typora-export os-windows'>
diff --git a/common/script4code.js b/common/script4code.js
index 19fda0e..cb8efc5 100644
--- a/common/script4code.js
+++ b/common/script4code.js
@@ -11,6 +11,7 @@ document.writeln(" <script type=\"text/javascript\" src=\"https://www.qin-jua
11document.writeln(" <!-- <script type=\"text/javascript\" src=\"https://www.qin-juan-ge-zhu.top/common/js/click4code.js\"></script> -->"); 11document.writeln(" <!-- <script type=\"text/javascript\" src=\"https://www.qin-juan-ge-zhu.top/common/js/click4code.js\"></script> -->");
12document.writeln(" <script src=\"https://www.qin-juan-ge-zhu.top/common/js/click4notes.js\"></script>"); 12document.writeln(" <script src=\"https://www.qin-juan-ge-zhu.top/common/js/click4notes.js\"></script>");
13document.writeln(" <script type=\"text/javascript\" src=\"https://www.qin-juan-ge-zhu.top/common/js/pandoc-menu.js\"></script>"); 13document.writeln(" <script type=\"text/javascript\" src=\"https://www.qin-juan-ge-zhu.top/common/js/pandoc-menu.js\"></script>");
14document.writeln(" <script type=\"text/javascript\" src=\"https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js\"></script>");
14document.writeln("</head>"); 15document.writeln("</head>");
15document.writeln(""); 16document.writeln("");
16document.writeln("<body class=\'typora-export os-windows\'>"); 17document.writeln("<body class=\'typora-export os-windows\'>");
diff --git a/common/script4works.html b/common/script4works.html
index d6759a2..19d206d 100644
--- a/common/script4works.html
+++ b/common/script4works.html
@@ -150,7 +150,7 @@
150 <a onclick="clickit('grandson22')">-一些小玩意儿</a> 150 <a onclick="clickit('grandson22')">-一些小玩意儿</a>
151 <div class="grandson" id="grandson22" style="display: none;"> 151 <div class="grandson" id="grandson22" style="display: none;">
152 <a href="https://www.qin-juan-ge-zhu.top/code/highlight.html">代码高亮与复制</a> 152 <a href="https://www.qin-juan-ge-zhu.top/code/highlight.html">代码高亮与复制</a>
153 <a href="https://www.qin-juan-ge-zhu.top/code/index.html">C的小零件</a> 153 <a href="https://www.qin-juan-ge-zhu.top/code/MyCodes.html">C的小零件</a>
154 <a href="https://www.qin-juan-ge-zhu.top/code/cpppp.html">C++ Primer Plus基础</a> 154 <a href="https://www.qin-juan-ge-zhu.top/code/cpppp.html">C++ Primer Plus基础</a>
155 <a href="https://www.qin-juan-ge-zhu.top/code/experiment.html">大物实验MATLAB</a> 155 <a href="https://www.qin-juan-ge-zhu.top/code/experiment.html">大物实验MATLAB</a>
156 <a href="https://www.qin-juan-ge-zhu.top/code/zeal.html">Zeal文档下载</a> 156 <a href="https://www.qin-juan-ge-zhu.top/code/zeal.html">Zeal文档下载</a>
diff --git a/common/script4works.js b/common/script4works.js
index 8d5f6d5..93f40b6 100644
--- a/common/script4works.js
+++ b/common/script4works.js
@@ -151,7 +151,7 @@ document.writeln(" </div>");
151document.writeln(" <a onclick=\"clickit(\'grandson22\')\">-一些小玩意儿</a>"); 151document.writeln(" <a onclick=\"clickit(\'grandson22\')\">-一些小玩意儿</a>");
152document.writeln(" <div class=\"grandson\" id=\"grandson22\" style=\"display: none;\">"); 152document.writeln(" <div class=\"grandson\" id=\"grandson22\" style=\"display: none;\">");
153document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/highlight.html\">代码高亮与复制</a>"); 153document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/highlight.html\">代码高亮与复制</a>");
154document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/index.html\">C的小零件</a>"); 154document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/MyCodes.html\">C的小零件</a>");
155document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/cpppp.html\">C++ Primer Plus基础</a>"); 155document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/cpppp.html\">C++ Primer Plus基础</a>");
156document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/experiment.html\">大物实验MATLAB</a>"); 156document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/experiment.html\">大物实验MATLAB</a>");
157document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/zeal.html\">Zeal文档下载</a>"); 157document.writeln(" <a href=\"https://www.qin-juan-ge-zhu.top/code/zeal.html\">Zeal文档下载</a>");
diff --git a/courseNotes/parallel.html b/courseNotes/parallel.html
index ebd09d4..0c822fd 100644
--- a/courseNotes/parallel.html
+++ b/courseNotes/parallel.html
@@ -6,25 +6,27 @@
6 <meta name="generator" content="pandoc" /> 6 <meta name="generator" content="pandoc" />
7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> 7 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
8 <title>并行计算大法好</title> 8 <title>并行计算大法好</title>
9 <script src="none" type="text/javascript"></script>
9 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css"> 10 <link rel="stylesheet" href="https://www.qin-juan-ge-zhu.top/common/CSS/pandoc.css">
10 <script type="text/javascript" src="https://hl.qin-juan-ge-zhu.top/myset/myhighlight.js"></script>
11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script> 11 <script type="text/javascript" src="https://www.qin-juan-ge-zhu.top/common/script4code.js"></script>
12 <script type="text/javascript" async 12 <script type="text/javascript" async
13 src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/MathJax.js?config=TeX-MML-AM_CHTML"></script> 13 src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/MathJax.js?config=TeX-MML-AM_CHTML"></script>
14 <script type="text/x-mathjax-config"> 14 <script type="text/x-mathjax-config">
15 MathJax.Hub.Config({ 15 MathJax.Hub.Config({
16 tex2jax: { 16 tex2jax: {
17 inlineMath: [['$','$'], ['\\(','\\)']], 17 inlineMath: [["$","$"], ["\\(","\\)"]],
18 processEscapes: true 18 processEscapes: true
19 } 19 }
20 }); 20 });
21 </script> 21 </script>
22</head> 22</head>
23 23
24<body> 24<body>
25 <div class="pandoc"> 25 <div class="pandoc">
26 <div class="main"> 26 <div class="main">
27 <p class="title">并行计算大法好</p> 27 <header id="title-block-header">
28 <p class="title">并行计算大法好</p>
29 </header>
28 <h1 id="基于共享内存的并行编程">基于共享内存的并行编程</h1> 30 <h1 id="基于共享内存的并行编程">基于共享内存的并行编程</h1>
29 <h2 id="pthreads的多线程并行"><code>Pthreads</code>的多线程并行</h2> 31 <h2 id="pthreads的多线程并行"><code>Pthreads</code>的多线程并行</h2>
30 <h3 id="简介">简介</h3> 32 <h3 id="简介">简介</h3>
@@ -39,7 +41,7 @@
39 <li>条件变量</li> 41 <li>条件变量</li>
40 </ul> 42 </ul>
41 <h3 id="线程管理">线程管理</h3> 43 <h3 id="线程管理">线程管理</h3>
42 <pre><code>#include &lt;stdio.h&gt; 44 <pre><code class="language-c">#include &lt;stdio.h&gt;
43#include &lt;stdlib.h&gt; 45#include &lt;stdlib.h&gt;
44#include &lt;pthread.h&gt; 46#include &lt;pthread.h&gt;
45 47
@@ -102,17 +104,18 @@ int main()
102 </ul> 104 </ul>
103 <h4 id="忙等待">忙等待</h4> 105 <h4 id="忙等待">忙等待</h4>
104 <p>可以通过空循环的方法实现当一个线程在用的时候另一个线程禁止访问。</p> 106 <p>可以通过空循环的方法实现当一个线程在用的时候另一个线程禁止访问。</p>
105 <p>空口白话不好使,看代码吧,利用泰勒公式求$\pi$的值。</p> 107 <p>空口白话不好使,看代码吧,利用泰勒公式求<span class="math inline">\(\pi\)</span>的值。</p>
106 <p>已知:</p> 108 <p>已知:</p>
107 <ul> 109 <ul>
108 <li>$arctan(1)=\frac \pi 4$</li> 110 <li><span class="math inline">\(arctan(1)=\frac \pi 4\)</span></li>
109 <li>$arctan(x)=\Sigma_{i=0}^{+\infty}(-1)^i \frac 1 {2x+1}$,收敛域为$[-1, 1]$</li> 111 <li><span class="math inline">\(arctan(x)=\Sigma_{i=0}^{+\infty}(-1)^i \frac 1 {2x+1}\)</span>,收敛域为<span
112 class="math inline">\([-1,1]\)</span></li>
110 </ul> 113 </ul>
111 <blockquote> 114 <blockquote>
112 <p>哪个大佬知道收敛更快的算法啊,这个办法<strong>收敛实在是太慢辣</strong>!</p> 115 <p>哪个大佬知道收敛更快的算法啊,这个办法<strong>收敛实在是太慢辣</strong>!</p>
113 </blockquote> 116 </blockquote>
114 <p>编程如下:</p> 117 <p>编程如下:</p>
115 <pre><code>#include &lt;stdio.h&gt; 118 <pre><code class="language-c">#include &lt;stdio.h&gt;
116#include &lt;stdlib.h&gt; 119#include &lt;stdlib.h&gt;
117#include &lt;pthread.h&gt; 120#include &lt;pthread.h&gt;
118 121
@@ -171,7 +174,7 @@ int main()
171 <p>上述<strong>通过循环的办法实现的忙等待,优点在于实现比较简单好理解,缺点在于空循环浪费 CPU 174 <p>上述<strong>通过循环的办法实现的忙等待,优点在于实现比较简单好理解,缺点在于空循环浪费 CPU
172 资源,且当线程数较多时,线程切换的开销也会增大</strong>。因此我们可以调用<code>Pthreads</code>提供的互斥锁来实现临界区的功能。互斥锁是一个变量,通过调用函数来实现锁定临界区实现忙等待。 175 资源,且当线程数较多时,线程切换的开销也会增大</strong>。因此我们可以调用<code>Pthreads</code>提供的互斥锁来实现临界区的功能。互斥锁是一个变量,通过调用函数来实现锁定临界区实现忙等待。
173 </p> 176 </p>
174 <pre><code>#include &lt;stdio.h&gt; 177 <pre><code class="language-c">#include &lt;stdio.h&gt;
175#include &lt;stdlib.h&gt; 178#include &lt;stdlib.h&gt;
176#include &lt;pthread.h&gt; 179#include &lt;pthread.h&gt;
177 180
@@ -260,7 +263,7 @@ int main()
260 <li>信号量为 0 时,试图访问共享资源的线程将处于等待状态</li> 263 <li>信号量为 0 时,试图访问共享资源的线程将处于等待状态</li>
261 </ul> 264 </ul>
262 <p>需要注意的是,上述的信号量只是一种管理方法,与<code>Pthreads</code>中的信号量似乎区别不小,这一点从<code>sem_t</code>的大小上就能看出来。凑合看吧,知道原理就行。</p> 265 <p>需要注意的是,上述的信号量只是一种管理方法,与<code>Pthreads</code>中的信号量似乎区别不小,这一点从<code>sem_t</code>的大小上就能看出来。凑合看吧,知道原理就行。</p>
263 <pre><code>#include &lt;semaphore.h&gt; // 信号量头文件 266 <pre><code class="language-c">#include &lt;semaphore.h&gt; // 信号量头文件
264 267
265// 定义信号量 268// 定义信号量
266sem_t sem; 269sem_t sem;
@@ -296,7 +299,7 @@ int sem_destroy(sem_t *sem);</code></pre>
296 <li>主线程将共享数组初始化为<code>NULL</code></li> 299 <li>主线程将共享数组初始化为<code>NULL</code></li>
297 <li>信号量初始化为 0</li> 300 <li>信号量初始化为 0</li>
298 </ul> 301 </ul>
299 <pre><code>#include &lt;stdio.h&gt; 302 <pre><code class="language-c">#include &lt;stdio.h&gt;
300#include &lt;pthread.h&gt; 303#include &lt;pthread.h&gt;
301#include &lt;semaphore.h&gt; 304#include &lt;semaphore.h&gt;
302#define MSG_MAX_LEN 50 305#define MSG_MAX_LEN 50
@@ -360,7 +363,7 @@ int main()
360 <h3 id="路障">路障</h3> 363 <h3 id="路障">路障</h3>
361 <p>路障也称同步点,指线程到达此处进入阻塞状态,等所有进程到达后才能继续进行,主要应用于程序计时/调试等。</p> 364 <p>路障也称同步点,指线程到达此处进入阻塞状态,等所有进程到达后才能继续进行,主要应用于程序计时/调试等。</p>
362 <p>路障使用有以下几步:</p> 365 <p>路障使用有以下几步:</p>
363 <pre><code>#include &lt;pthread.h&gt; 366 <pre><code class="language-c">#include &lt;pthread.h&gt;
364 367
365// 定义路障 368// 定义路障
366pthread_barrier_t barrier; 369pthread_barrier_t barrier;
@@ -379,7 +382,7 @@ int pthread_barrier_wait(pthread_barrier_t *barrier);
379// 销毁路障 382// 销毁路障
380int pthread_barrier_destroy(pthread_barrier_t *barrier);</code></pre> 383int pthread_barrier_destroy(pthread_barrier_t *barrier);</code></pre>
381 <p>示例程序如下:</p> 384 <p>示例程序如下:</p>
382 <pre><code>#include &lt;stdio.h&gt; 385 <pre><code class="language-c">#include &lt;stdio.h&gt;
383#include &lt;stdlib.h&gt; 386#include &lt;stdlib.h&gt;
384#include &lt;pthread.h&gt; 387#include &lt;pthread.h&gt;
385#include &lt;time.h&gt; 388#include &lt;time.h&gt;
@@ -427,7 +430,7 @@ int main()
427}</code></pre> 430}</code></pre>
428 <h3 id="条件变量">条件变量</h3> 431 <h3 id="条件变量">条件变量</h3>
429 <p>条件变量使线程在特定条件或事件之前处于挂起状态。</p> 432 <p>条件变量使线程在特定条件或事件之前处于挂起状态。</p>
430 <pre><code>#include &lt;pthread.h&gt; 433 <pre><code class="language-c">#include &lt;pthread.h&gt;
431 434
432// 定义条件变量 435// 定义条件变量
433pthread_cond_t cond; 436pthread_cond_t cond;
@@ -456,7 +459,7 @@ int pthread_cond_broadcast(pthread_cond_t *cond);
456 */ 459 */
457int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);</code></pre> 460int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);</code></pre>
458 <p>示例程序,这个程序真没看明白:</p> 461 <p>示例程序,这个程序真没看明白:</p>
459 <pre><code>#include &lt;stdio.h&gt; 462 <pre><code class="language-c">#include &lt;stdio.h&gt;
460#include &lt;stdlib.h&gt; 463#include &lt;stdlib.h&gt;
461#include &lt;pthread.h&gt; 464#include &lt;pthread.h&gt;
462#include &lt;unistd.h&gt; 465#include &lt;unistd.h&gt;
@@ -517,7 +520,7 @@ int main()
517}</code></pre> 520}</code></pre>
518 <h3 id="读写锁">读写锁</h3> 521 <h3 id="读写锁">读写锁</h3>
519 <p>读写锁在互斥量的基础上,<strong>把对共享资源的访问分为读者和写者</strong>,读者只能读、写者只能写,读者之间不互斥,写者之间互斥,读者和写者之间互斥。</p> 522 <p>读写锁在互斥量的基础上,<strong>把对共享资源的访问分为读者和写者</strong>,读者只能读、写者只能写,读者之间不互斥,写者之间互斥,读者和写者之间互斥。</p>
520 <pre><code>#include &lt;pthread.h&gt; // 哈哈,没想到吧 523 <pre><code class="language-c">#include &lt;pthread.h&gt; // 哈哈,没想到吧
521 524
522// 定义读写锁 525// 定义读写锁
523pthread_rwlock_t rwlock; 526pthread_rwlock_t rwlock;
@@ -541,7 +544,7 @@ int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);
541// 销毁 544// 销毁
542int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);</code></pre> 545int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);</code></pre>
543 <p>示例程序:</p> 546 <p>示例程序:</p>
544 <pre><code>#include &lt;stdio.h&gt; 547 <pre><code class="language-c">#include &lt;stdio.h&gt;
545#include &lt;stdlib.h&gt; 548#include &lt;stdlib.h&gt;
546#include &lt;string.h&gt; 549#include &lt;string.h&gt;
547#include &lt;pthread.h&gt; 550#include &lt;pthread.h&gt;
@@ -646,8 +649,9 @@ int main(int argc,char *argv[])
646 采用<code>Fork-Join</code>的并行编程方式,开始于一个单独的主线程,一直串行执行(串行域),直到遇见并行域;在并行域中,根据指定的线程数,多线程并行执行;并行域结束后,所有线程汇合,继续串行执行。如此在串行域和并行域中循环往复,直到程序结束。 649 采用<code>Fork-Join</code>的并行编程方式,开始于一个单独的主线程,一直串行执行(串行域),直到遇见并行域;在并行域中,根据指定的线程数,多线程并行执行;并行域结束后,所有线程汇合,继续串行执行。如此在串行域和并行域中循环往复,直到程序结束。
647 </p> 650 </p>
648 <p>需要注意的是,在并行域中,可以划分出更小的并行域,也就是一个线程再次划分为多个线程执行。</p> 651 <p>需要注意的是,在并行域中,可以划分出更小的并行域,也就是一个线程再次划分为多个线程执行。</p>
652 <img src="https://www.qin-juan-ge-zhu.top/images/courseNotes/parallel_1.png">
649 <h3 id="使用指南">使用指南</h3> 653 <h3 id="使用指南">使用指南</h3>
650 <pre><code>// 头文件必不可少 654 <pre><code class="language-c">// 头文件必不可少
651#include &lt;omp.h&gt; 655#include &lt;omp.h&gt;
652 656
653// 指定线程数,这是一个函数,参数就是线程数 657// 指定线程数,这是一个函数,参数就是线程数
@@ -666,17 +670,14 @@ omp_set_num_threads(4);
666 // some codes here. 670 // some codes here.
667}</code></pre> 671}</code></pre>
668 <p>编译的时候,使用<code>-fopenmp</code>选项是万万不能忘记的:</p> 672 <p>编译的时候,使用<code>-fopenmp</code>选项是万万不能忘记的:</p>
669 <div class="sourceCode" id="cb14"> 673 <pre><code class="language-bash">gcc -g -o test test.c -fopenmp</code></pre>
670 <pre
671 class="sourceCode bash"><code class="sourceCode bash"><span id="cb14-1"><a href="#cb14-1" aria-hidden="true"></a><span class="fu">gcc</span> -g -o test test.c -fopenmp</span></code></pre>
672 </div>
673 <p>在 OpenMP 程序编写中,需要注意以下几点:</p> 674 <p>在 OpenMP 程序编写中,需要注意以下几点:</p>
674 <ul> 675 <ul>
675 <li>通常采用增量并行,也局势每次只对部分代码并行化,这样可以<strong>逐步改造</strong>,方便调试</li> 676 <li>通常采用增量并行,也局势每次只对部分代码并行化,这样可以<strong>逐步改造</strong>,方便调试</li>
676 <li>OpenMP 指令<strong>区分大小写</strong></li> 677 <li>OpenMP 指令<strong>区分大小写</strong></li>
677 </ul> 678 </ul>
678 <p>先来一段小实例:</p> 679 <p>先来一段小实例:</p>
679 <pre><code>#include &lt;stdio.h&gt; 680 <pre><code class="language-c">#include &lt;stdio.h&gt;
680#include &lt;omp.h&gt; 681#include &lt;omp.h&gt;
681 682
682int main() 683int main()
@@ -688,7 +689,7 @@ int main()
688 return 0; 689 return 0;
689}</code></pre> 690}</code></pre>
690 <p>可以看到一般的结果为:</p> 691 <p>可以看到一般的结果为:</p>
691 <pre class="plain"><code>Hello World! I&#39;m thread 1 692 <pre><code class="language-plain">Hello World! I&#39;m thread 1
692Hello World! I&#39;m thread 2 693Hello World! I&#39;m thread 2
693Hello World! I&#39;m thread 3 694Hello World! I&#39;m thread 3
694Hello World! I&#39;m thread 5 695Hello World! I&#39;m thread 5
@@ -772,7 +773,7 @@ Hello World! I&#39;m the master thread</code></pre>
772 <p>再次说明,不支持 OpenMP 的编译器也能编译 OpenMP 程序,不过是忽略了这部分语句,也就是直接串行执行。</p> 773 <p>再次说明,不支持 OpenMP 的编译器也能编译 OpenMP 程序,不过是忽略了这部分语句,也就是直接串行执行。</p>
773 <h4 id="并行域指令">并行域指令</h4> 774 <h4 id="并行域指令">并行域指令</h4>
774 <p>并行域指令前边写了,就不废话了。需要注意的是结尾处有隐式同步(等待所有线程结束才进入下一个串行域)。另外,可用的字句包括以下几种:</p> 775 <p>并行域指令前边写了,就不废话了。需要注意的是结尾处有隐式同步(等待所有线程结束才进入下一个串行域)。另外,可用的字句包括以下几种:</p>
775 <pre><code>if(scalar-logical-expression) 776 <pre><code class="language-c">if(scalar-logical-expression)
776num_threads(scalar-integer-expression) 777num_threads(scalar-integer-expression)
777default(shared|none) 778default(shared|none)
778private(list) 779private(list)
@@ -790,7 +791,7 @@ reduction(operator:list)</code></pre>
790 <li><code>task</code>指令</li> 791 <li><code>task</code>指令</li>
791 </ul> 792 </ul>
792 <h5 id="for-指令">for 指令</h5> 793 <h5 id="for-指令">for 指令</h5>
793 <pre><code>/* 794 <pre><code class="language-c">/*
794 * for指令,自动划分和分配循环任务 795 * for指令,自动划分和分配循环任务
795 * 需要注意,循环变量只能是整形或指针 796 * 需要注意,循环变量只能是整形或指针
796 */ 797 */
@@ -807,7 +808,7 @@ reduction(operator:list)</code></pre>
807 * nowait 808 * nowait
808 */</code></pre> 809 */</code></pre>
809 <p>示例程序:</p> 810 <p>示例程序:</p>
810 <pre><code>#include &lt;omp.h&gt; 811 <pre><code class="language-c">#include &lt;omp.h&gt;
811#include &lt;stdio.h&gt; 812#include &lt;stdio.h&gt;
812#define N 10000 813#define N 10000
813 814
@@ -857,7 +858,7 @@ int main()
857 </li> 858 </li>
858 </ul> 859 </ul>
859 <p>OpenMP 提供了以下几种调度方式(<code>schedule</code>子句):</p> 860 <p>OpenMP 提供了以下几种调度方式(<code>schedule</code>子句):</p>
860 <pre><code>schedule(static,chunk_size) // 静态分配,chunk_size为任务块大小 861 <pre><code class="language-c">schedule(static,chunk_size) // 静态分配,chunk_size为任务块大小
861schedule(dynamic,chunk_size) // 动态分配,chunk_size为任务块大小,按照先来先服务原则分配 862schedule(dynamic,chunk_size) // 动态分配,chunk_size为任务块大小,按照先来先服务原则分配
862schedule(guided,chunk_size) // 动态分配。任务块大小可变,先大后小,chunk_size为最小任务块大小 863schedule(guided,chunk_size) // 动态分配。任务块大小可变,先大后小,chunk_size为最小任务块大小
863schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`OMP_SCHEDULE`指定</code></pre> 864schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`OMP_SCHEDULE`指定</code></pre>
@@ -891,7 +892,7 @@ schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`O
891 <li>每个子任务<strong>只会</strong>被一个线程执行</li> 892 <li>每个子任务<strong>只会</strong>被一个线程执行</li>
892 <li>结尾处隐式同步,除非有子句<code>nowait</code></li> 893 <li>结尾处隐式同步,除非有子句<code>nowait</code></li>
893 </ul> 894 </ul>
894 <pre><code>/* 895 <pre><code class="language-c">/*
895 * 可用子句: 896 * 可用子句:
896 * private(list) 897 * private(list)
897 * firstprivate(list) 898 * firstprivate(list)
@@ -926,7 +927,7 @@ schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`O
926 <li><code>copyprivate(list)</code></li> 927 <li><code>copyprivate(list)</code></li>
927 <li><code>nowait</code></li> 928 <li><code>nowait</code></li>
928 </ul> 929 </ul>
929 <pre><code>#pragma omp parallel 930 <pre><code class="language-c">#pragma omp parallel
930{ 931{
931 // 代码 932 // 代码
932 #pragma omp single [clause [clause]...] 933 #pragma omp single [clause [clause]...]
@@ -939,7 +940,7 @@ schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`O
939 <p>master 940 <p>master
940 块仅由线程组之中的<strong>主线程执行</strong>,其他线程<strong>跳过并继续执行后续代码</strong>,即结尾处<strong>没有隐式同步</strong>。该结构通常用于 941 块仅由线程组之中的<strong>主线程执行</strong>,其他线程<strong>跳过并继续执行后续代码</strong>,即结尾处<strong>没有隐式同步</strong>。该结构通常用于
941 I/O。注意其与 single 结构的区别。</p> 942 I/O。注意其与 single 结构的区别。</p>
942 <pre><code>#pragmaomp parallel private(tid) 943 <pre><code class="language-c">#pragmaomp parallel private(tid)
943{ 944{
944 tid=omp_get_thread_num(); 945 tid=omp_get_thread_num();
945 printf(&quot;Thread %d is here!\n&quot;,tid); 946 printf(&quot;Thread %d is here!\n&quot;,tid);
@@ -952,7 +953,7 @@ schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`O
952}</code></pre> 953}</code></pre>
953 <h5 id="task-结构">task 结构</h5> 954 <h5 id="task-结构">task 结构</h5>
954 <p>task 指令主要用于不规则循环迭代(如<code>do-while</code>循环)和递归的函数调用。</p> 955 <p>task 指令主要用于不规则循环迭代(如<code>do-while</code>循环)和递归的函数调用。</p>
955 <pre><code>#pragma omp parallel 956 <pre><code class="language-c">#pragma omp parallel
956{ 957{
957 #pragma omp single 958 #pragma omp single
958 { 959 {
@@ -969,9 +970,9 @@ schedule(runtime) // 具体调度方式在运行时才确定,由环境变量`O
969}</code></pre> 970}</code></pre>
970 <h4 id="变量作用域与属性">变量作用域与属性</h4> 971 <h4 id="变量作用域与属性">变量作用域与属性</h4>
971 <p>变量作用域可以通过如下方式修改:</p> 972 <p>变量作用域可以通过如下方式修改:</p>
972 <pre><code>default(shared|none)</code></pre> 973 <pre><code class="language-c">default(shared|none)</code></pre>
973 <p>作用域属性语句:</p> 974 <p>作用域属性语句:</p>
974 <pre><code>shared(varname,...) 975 <pre><code class="language-c">shared(varname,...)
975private(varname,...)</code></pre> 976private(varname,...)</code></pre>
976 <p>变量究竟应该是共享的还是私有的?</p> 977 <p>变量究竟应该是共享的还是私有的?</p>
977 <ul> 978 <ul>
@@ -1011,8 +1012,7 @@ private(varname,...)</code></pre>
1011 <tr class="odd"> 1012 <tr class="odd">
1012 <td style="text-align: left;">lastprivate(list)</td> 1013 <td style="text-align: left;">lastprivate(list)</td>
1013 <td style="text-align: left;">private 的扩展,推出并行域时,将制定的私有拷贝的“最后”值赋值给主线程变量。“最后”指循环的最后一次迭代、sections 1014 <td style="text-align: left;">private 的扩展,推出并行域时,将制定的私有拷贝的“最后”值赋值给主线程变量。“最后”指循环的最后一次迭代、sections
1014 的最后一个 1015 的最后一个 section 等。可能会增加额外开销,一般不建议使用,可用共享变量等方式实现</td>
1015 section 等。可能会增加额外开销,一般不建议使用,可用共享变量等方式实现</td>
1016 <td></td> 1016 <td></td>
1017 </tr> 1017 </tr>
1018 <tr class="even"> 1018 <tr class="even">
@@ -1089,18 +1089,13 @@ private(varname,...)</code></pre>
1089 </tr> 1089 </tr>
1090 </tbody> 1090 </tbody>
1091 </table> 1091 </table>
1092 <p>我们仍然以计算$\pi$为例子:</p> 1092 <p>我们仍然以计算<span class="math inline">\(pi\)</span>为例子:</p>
1093 <!-- <p><br /><span class="math display">$$ 1093 <p><span class="math display">\[
1094 \begin{align*}
1095 \pi = 4\Sigma_{i=0}^{+\infty}\frac {(-1)^i}{2i+1}
1096 \end{align*}
1097 $$</span><br /></p> -->
1098 <p><br />$$
1099 \begin{align*} 1094 \begin{align*}
1100 \pi = 4\Sigma_{i=0}^{+\infty}\frac {(-1)^i}{2i+1} 1095 \pi = 4\Sigma_{i=0}^{+\infty}\frac {(-1)^i}{2i+1}
1101 \end{align*} 1096 \end{align*}
1102 $$<br /></p> 1097 \]</span></p>
1103 <pre><code>#include &lt;stdio.h&gt; 1098 <pre><code class="language-c">#include &lt;stdio.h&gt;
1104#include &lt;omp.h&gt; 1099#include &lt;omp.h&gt;
1105#define NUM_OF_CYCLES 1000000000 1100#define NUM_OF_CYCLES 1000000000
1106 1101
@@ -1157,9 +1152,10 @@ int main()
1157 MPI 的支持。</p> 1152 MPI 的支持。</p>
1158 <p><strong>MPI 是一个库,不是一门语言</strong>,其最终目的是服务于进程间通信。</p> 1153 <p><strong>MPI 是一个库,不是一门语言</strong>,其最终目的是服务于进程间通信。</p>
1159 <h3 id="一般结构">一般结构</h3> 1154 <h3 id="一般结构">一般结构</h3>
1160 <p>MPI 程序的一般结构为: 包含MPI头文件-->初始化MPI环境-->信息交换处理及计算等-->退出MPI环境。</p> 1155 <p>MPI 程序的一般结构为:</p>
1156 <img src="https://www.qin-juan-ge-zhu.top/images/courseNotes/parallel_2.png">
1161 <p>写程序罢。</p> 1157 <p>写程序罢。</p>
1162 <pre><code>// hello.c 1158 <pre><code class="language-c">// hello.c
1163#include &lt;stdio.h&gt; 1159#include &lt;stdio.h&gt;
1164#include &lt;mpi.h&gt; // MPI的头文件 1160#include &lt;mpi.h&gt; // MPI的头文件
1165 1161
@@ -1172,16 +1168,14 @@ int main(int argc,char *argv[])
1172 return 0; 1168 return 0;
1173}</code></pre> 1169}</code></pre>
1174 <p>编译运行:</p> 1170 <p>编译运行:</p>
1175 <div class="sourceCode" id="cb30"> 1171 <pre><code class="language-bash"># 编译MPI程序,需要专用的编译器mpicc
1176 <pre 1172mpicc -O2 hello hello.c
1177 class="sourceCode bash"><code class="sourceCode bash"><span id="cb30-1"><a href="#cb30-1" aria-hidden="true"></a><span class="co"># 编译MPI程序,需要专用的编译器mpicc</span></span> 1173
1178<span id="cb30-2"><a href="#cb30-2" aria-hidden="true"></a><span class="ex">mpicc</span> -O2 hello hello.c</span> 1174# 运行的命令也比较特别
1179<span id="cb30-3"><a href="#cb30-3" aria-hidden="true"></a></span> 1175mpirun -np 4 ./hello</code></pre>
1180<span id="cb30-4"><a href="#cb30-4" aria-hidden="true"></a><span class="co"># 运行的命令也比较特别</span></span>
1181<span id="cb30-5"><a href="#cb30-5" aria-hidden="true"></a><span class="ex">mpirun</span> -np 4 ./hello</span></code></pre>
1182 </div>
1183 <h3 id="mpi-通信器">MPI 通信器</h3> 1176 <h3 id="mpi-通信器">MPI 通信器</h3>
1184 <p>现在我们已经学会了$1+1=2$,让我们来<del>手搓一下$e^\pi$的值</del>看看第二个程序罢。</p> 1177 <p>现在我们已经学会了<span class="math inline">\(1+1=2\)</span>,让我们来<del>手搓一下<span
1178 class="math inline">\(e^{\pi}\)</span>的值</del>看看第二个程序罢。</p>
1185 <p>通信器/通信子是什么?</p> 1179 <p>通信器/通信子是什么?</p>
1186 <ul> 1180 <ul>
1187 <li>一个通信器定义一个通信域,也就是一组允许相互通信的进程</li> 1181 <li>一个通信器定义一个通信域,也就是一组允许相互通信的进程</li>
@@ -1195,9 +1189,9 @@ int main(int argc,char *argv[])
1195 <li>MPI 进程是 MPI 程序中一个独立参与通信的个体</li> 1189 <li>MPI 进程是 MPI 程序中一个独立参与通信的个体</li>
1196 <li>MPI 进程组事由一些进程构成的有序集合</li> 1190 <li>MPI 进程组事由一些进程构成的有序集合</li>
1197 <li>进程号是相对于进程组或通信器而言的,同一进程在不同的进程组可以有不同的进程号</li> 1191 <li>进程号是相对于进程组或通信器而言的,同一进程在不同的进程组可以有不同的进程号</li>
1198 <li>进程号在进程组或通信器被创建时赋予,取值范围为$[0, np-1]$</li> 1192 <li>进程号在进程组或通信器被创建时赋予,取值范围为<span class="math inline">\([0,np-1]\)</span></li>
1199 </ul> 1193 </ul>
1200 <pre><code>#include &lt;stdio.h&gt; 1194 <pre><code class="language-c">#include &lt;stdio.h&gt;
1201#include &lt;math.h&gt; 1195#include &lt;math.h&gt;
1202#include &lt;mpi.h&gt; 1196#include &lt;mpi.h&gt;
1203int main(int argc,char *argv[]) 1197int main(int argc,char *argv[])
@@ -1251,7 +1245,7 @@ int main(int argc,char *argv[])
1251 <p>Talking is cheap, show me the code.</p> 1245 <p>Talking is cheap, show me the code.</p>
1252 <p>Read the fxxking source code!</p> 1246 <p>Read the fxxking source code!</p>
1253 </blockquote> 1247 </blockquote>
1254 <pre><code>#include &lt;stdio.h&gt; 1248 <pre><code class="language-c">#include &lt;stdio.h&gt;
1255#include &lt;string.h&gt; 1249#include &lt;string.h&gt;
1256#include &lt;mpi.h&gt; 1250#include &lt;mpi.h&gt;
1257 1251
@@ -1374,7 +1368,7 @@ int main()
1374 </tbody> 1368 </tbody>
1375 </table> 1369 </table>
1376 <p>现在我们已经学会了六个最基本的 MPI 函数:</p> 1370 <p>现在我们已经学会了六个最基本的 MPI 函数:</p>
1377 <pre><code>int MPI_Init(int *argc,char ***argv); 1371 <pre><code class="language-c">int MPI_Init(int *argc,char ***argv);
1378int MPI_Comm_size(MPI_Comm comm,int *size); 1372int MPI_Comm_size(MPI_Comm comm,int *size);
1379int MPI_Comm_rank(MPI_Comm comm,int *rank); 1373int MPI_Comm_rank(MPI_Comm comm,int *rank);
1380int MPI_Send(const void *buf,int count,MPI_Datatype datatype,int dest,int tag,MPI_Comm comm); 1374int MPI_Send(const void *buf,int count,MPI_Datatype datatype,int dest,int tag,MPI_Comm comm);
@@ -1397,9 +1391,10 @@ int MPI_Finalize();</code></pre>
1397 <p>非阻塞通信返回就不意味着通信完成。MPI 提供了对非阻塞通信是否完成的检测,主要是<code>MPI_Wait</code>与<code>MPI_Test</code>函数。</p> 1391 <p>非阻塞通信返回就不意味着通信完成。MPI 提供了对非阻塞通信是否完成的检测,主要是<code>MPI_Wait</code>与<code>MPI_Test</code>函数。</p>
1398 <p>换言之,阻塞通信就是需要等待通讯结束再继续进行,而非阻塞则是<strong>计算与通信时间重叠</strong>,从而提高了系统性能。</p> 1392 <p>换言之,阻塞通信就是需要等待通讯结束再继续进行,而非阻塞则是<strong>计算与通信时间重叠</strong>,从而提高了系统性能。</p>
1399 <!-- 这幅图记得改,改成非阻塞通信的发送方与接收方的时序图 --> 1393 <!-- 这幅图记得改,改成非阻塞通信的发送方与接收方的时序图 -->
1394 <img src="https://www.qin-juan-ge-zhu.top/images/courseNotes/parallel_2.png">
1400 <h4 id="非阻塞通信">非阻塞通信</h4> 1395 <h4 id="非阻塞通信">非阻塞通信</h4>
1401 <p>no bb:</p> 1396 <p>no bb:</p>
1402 <pre><code>/* 1397 <pre><code class="language-c">/*
1403 * 非阻塞发送 1398 * 非阻塞发送
1404 * buf: 发送缓冲区的地址 1399 * buf: 发送缓冲区的地址
1405 * count: 发送数据的个数 1400 * count: 发送数据的个数
@@ -1420,7 +1415,7 @@ int MPI_Irecv(void *buf, int count, MPI_Datatype datatype, int source, int tag,
1420 <li>发送完成:发送缓冲区的数据已送出,缓冲区可以重新使用(并不代表数据已被接收方接受)。数据有可能被缓冲。</li> 1415 <li>发送完成:发送缓冲区的数据已送出,缓冲区可以重新使用(并不代表数据已被接收方接受)。数据有可能被缓冲。</li>
1421 <li>接收完成:数据已经写入接收缓冲区,可以正常访问与使用</li> 1416 <li>接收完成:数据已经写入接收缓冲区,可以正常访问与使用</li>
1422 </ul> 1417 </ul>
1423 <pre><code>// 阻塞型函数,必须等待指定通信请求完成后才能返回和继续执行下一步 1418 <pre><code class="language-c">// 阻塞型函数,必须等待指定通信请求完成后才能返回和继续执行下一步
1424int MPI_Wait(MPI_Request *request, MPI_Status *status); 1419int MPI_Wait(MPI_Request *request, MPI_Status *status);
1425// 检测指定的通信请求,不论是否完成都立刻返回,若完成则返回flag=true,反之返回false 1420// 检测指定的通信请求,不论是否完成都立刻返回,若完成则返回flag=true,反之返回false
1426int MPI_Test(MPI_Request *request, int *flag, MPI_Status *status);</code></pre> 1421int MPI_Test(MPI_Request *request, int *flag, MPI_Status *status);</code></pre>
@@ -1510,19 +1505,14 @@ int MPI_Test(MPI_Request *request, int *flag, MPI_Status *status);</code></pre>
1510 <h3 id="聚合通信">聚合通信</h3> 1505 <h3 id="聚合通信">聚合通信</h3>
1511 <p>内容和图片都太多,这里写不下。</p> 1506 <p>内容和图片都太多,这里写不下。</p>
1512 <h3 id="示例程序">示例程序</h3> 1507 <h3 id="示例程序">示例程序</h3>
1513 <p>我们还是算算可爱的$\pi$罢,这次利用另一个柿子:</p> 1508 <p>我们还是算算可爱的<span class="math inline">\(\pi\)</span>罢,这次利用另一个柿子:</p>
1514 <!-- <p><br /><span class="math display">$$ 1509 <p><span class="math display">\[
1515 \begin{align*}
1516 \pi = \int_0^1 \frac 4 {1+x^2} \mathrm{d}x
1517 \end{align*}
1518 $$</span><br /></p> -->
1519 <p><br />$$
1520 \begin{align*} 1510 \begin{align*}
1521 \pi = \int_0^1 \frac 4 {1+x^2} \mathrm{d}x 1511 \pi = \int_0^1 \frac 4 {1+x^2} \mathrm{d}x
1522 \end{align*} 1512 \end{align*}
1523 $$<br /></p> 1513 \]</span></p>
1524 <h4 id="串行程序">串行程序</h4> 1514 <h4 id="串行程序">串行程序</h4>
1525 <pre><code>#include &lt;stdio.h&gt; 1515 <pre><code class="language-c">#include &lt;stdio.h&gt;
1526 1516
1527int num_steps=1000; 1517int num_steps=1000;
1528double width; 1518double width;
@@ -1543,7 +1533,7 @@ int main()
1543 return 0; 1533 return 0;
1544}</code></pre> 1534}</code></pre>
1545 <h4 id="并行程序">并行程序</h4> 1535 <h4 id="并行程序">并行程序</h4>
1546 <pre><code>#include &lt;stdio.h&gt; 1536 <pre><code class="language-c">#include &lt;stdio.h&gt;
1547#include &lt;math.h&gt; 1537#include &lt;math.h&gt;
1548#include &lt;mpi.h&gt; 1538#include &lt;mpi.h&gt;
1549 1539
@@ -1657,7 +1647,7 @@ int main(int argc,char *argv[])
1657 <li>将结果从 device 内存复制到 host,释放 device 和 host 上分配的内存</li> 1647 <li>将结果从 device 内存复制到 host,释放 device 和 host 上分配的内存</li>
1658 </ul> 1648 </ul>
1659 <p>在编写代码时,需要使用 NVIDIA 的编译器 nvcc。它也可以用于编译没有 device 代码的程序(也就是 1 一般的 C 程序)。</p> 1649 <p>在编写代码时,需要使用 NVIDIA 的编译器 nvcc。它也可以用于编译没有 device 代码的程序(也就是 1 一般的 C 程序)。</p>
1660 <pre><code>// hello.cu 1650 <pre><code class="language-c">// hello.cu
1661#include &lt;stdio.h&gt; 1651#include &lt;stdio.h&gt;
1662 1652
1663__global__ void helloFromGPU(void) 1653__global__ void helloFromGPU(void)
@@ -1675,12 +1665,10 @@ int main()
1675 return 0; 1665 return 0;
1676}</code></pre> 1666}</code></pre>
1677 <p>编译运行:</p> 1667 <p>编译运行:</p>
1678 <div class="sourceCode" id="cb40"> 1668 <pre><code class="language-bash"># nvcc编译为hello
1679 <pre class="sourceCode bash"><code class="sourceCode bash"><span id="cb40-1"><a href="#cb40-1" aria-hidden="true"></a><span class="co"># nvcc编译为hello</span></span> 1669nvcc -o hello hello.cu
1680<span id="cb40-2"><a href="#cb40-2" aria-hidden="true"></a><span class="ex">nvcc</span> -o hello hello.cu</span> 1670# 运行
1681<span id="cb40-3"><a href="#cb40-3" aria-hidden="true"></a><span class="co"># 运行</span></span> 1671./hello</code></pre>
1682<span id="cb40-4"><a href="#cb40-4" aria-hidden="true"></a><span class="ex">./hello</span></span></code></pre>
1683 </div>
1684 <p>在这段示例程序里,我们需要明白:</p> 1672 <p>在这段示例程序里,我们需要明白:</p>
1685 <ul> 1673 <ul>
1686 <li>nvcc 将源码分为 host 和 device 两部分,其中 device 部分由 nvcc 编译,host 由标准的主机编译器(如 gcc)编译</li> 1674 <li>nvcc 将源码分为 host 和 device 两部分,其中 device 部分由 nvcc 编译,host 由标准的主机编译器(如 gcc)编译</li>
@@ -1741,7 +1729,7 @@ int main()
1741 <li>device 指针指向 GPU 内存</li> 1729 <li>device 指针指向 GPU 内存</li>
1742 </ul> 1730 </ul>
1743 <p>因而,在处理 device 内存时候,需要调用 CUDA 的内存管理函数:</p> 1731 <p>因而,在处理 device 内存时候,需要调用 CUDA 的内存管理函数:</p>
1744 <pre><code>/* 1732 <pre><code class="language-c">/*
1745 * 第一个参数是指向指针的指针,也就是指针地址 1733 * 第一个参数是指向指针的指针,也就是指针地址
1746 * 因为函数返回值是void,需要把申请下来的内存指针写到这个指针地址里 1734 * 因为函数返回值是void,需要把申请下来的内存指针写到这个指针地址里
1747 * 所以只有申请的时候使用二级指针,使用的时候使用一级指针 1735 * 所以只有申请的时候使用二级指针,使用的时候使用一级指针
@@ -1760,9 +1748,9 @@ cudaError_t cudaFree(void *devPtr);
1760cudaError_t cudaMemcpy(void *dst, const void *src, size_t count, cudaMemcpyKind kind);</code></pre> 1748cudaError_t cudaMemcpy(void *dst, const void *src, size_t count, cudaMemcpyKind kind);</code></pre>
1761 <p>需要注意的是,<code>cudaMemcpy</code>函数是同步的,也就是说,只有当数据复制完成后,才会返回。若需要异步,也就是调用函数之后立刻返回而不是等待数据传输完成,则可以使用<code>cudaMemcpyAsync</code>函数: 1749 <p>需要注意的是,<code>cudaMemcpy</code>函数是同步的,也就是说,只有当数据复制完成后,才会返回。若需要异步,也就是调用函数之后立刻返回而不是等待数据传输完成,则可以使用<code>cudaMemcpyAsync</code>函数:
1762 </p> 1750 </p>
1763 <pre><code>cudaError_t cudaMemcpyAsync(void *dst, const void *src, size_t count, cudaMemcpyKind kind, cudaStream_t stream = 0);</code></pre> 1751 <pre><code class="language-c">cudaError_t cudaMemcpyAsync(void *dst, const void *src, size_t count, cudaMemcpyKind kind, cudaStream_t stream = 0);</code></pre>
1764 <p>简单的示例程序:</p> 1752 <p>简单的示例程序:</p>
1765 <pre><code>#include &lt;stdio.h&gt; 1753 <pre><code class="language-c">#include &lt;stdio.h&gt;
1766#include &lt;cuda_runtime.h&gt; 1754#include &lt;cuda_runtime.h&gt;
1767 1755
1768__global__ void add(int *a,int *b,int *c) 1756__global__ void add(int *a,int *b,int *c)
@@ -1812,7 +1800,7 @@ int main()
1812 <p>在任何时间,warp 中所有线程必须执行相同的指令,但如果遇到条件控制就会出现问题,这时候可以选择为块中的线程创建一个不同的控制路径,将执行相同分支行为的线程放在同一个 warp 1800 <p>在任何时间,warp 中所有线程必须执行相同的指令,但如果遇到条件控制就会出现问题,这时候可以选择为块中的线程创建一个不同的控制路径,将执行相同分支行为的线程放在同一个 warp
1813 中,从而减少分支分歧/提高性能。</p> 1801 中,从而减少分支分歧/提高性能。</p>
1814 <h3 id="向量加法">向量加法</h3> 1802 <h3 id="向量加法">向量加法</h3>
1815 <pre><code>#define N 512 1803 <pre><code class="language-c">#define N 512
1816 1804
1817__global__ void add(int *a,int *b,int *c) 1805__global__ void add(int *a,int *b,int *c)
1818{ 1806{
@@ -1857,8 +1845,9 @@ int main()
1857 1845
1858 return 0; 1846 return 0;
1859}</code></pre> 1847}</code></pre>
1860 <p>CUDA 后续的理论讲解较多,恕不能一一列举于此。直接看 PPT 罢。</p> 1848 <p>CUDA后续的理论讲解较多,恕不能一一列举于此。直接看PPT罢。</p>
1861 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment4works.js"></script> 1849 <p class="time">2023.7.8</p>
1850 <script src="https://www.qin-juan-ge-zhu.top/common/js/comment.js"></script>
1862 </div> 1851 </div>
1863 </div> 1852 </div>
1864</body> 1853</body>
diff --git a/courseNotes/parallel.md b/courseNotes/parallel.md
index 7938119..551c1dc 100644
--- a/courseNotes/parallel.md
+++ b/courseNotes/parallel.md
@@ -1320,7 +1320,7 @@ MPI 点对点通信提供了阻塞和非阻塞两种通信机制,也支持多
1320<!-- 这幅图记得改,改成非阻塞通信的发送方与接收方的时序图 --> 1320<!-- 这幅图记得改,改成非阻塞通信的发送方与接收方的时序图 -->
1321 1321
1322```mermaid 1322```mermaid
1323graph LR 1323graph TD
1324subgraph 阻塞通信 1324subgraph 阻塞通信
1325A[发送]-->B[等待] 1325A[发送]-->B[等待]
1326B-->C[接收] 1326B-->C[接收]
diff --git a/images/code/httpmyserver_1.png b/images/code/httpmyserver_1.png
new file mode 100644
index 0000000..0e7eb82
--- /dev/null
+++ b/images/code/httpmyserver_1.png
Binary files differ
diff --git a/images/code/httpmyserver_2.png b/images/code/httpmyserver_2.png
new file mode 100644
index 0000000..9fb6be4
--- /dev/null
+++ b/images/code/httpmyserver_2.png
Binary files differ
diff --git a/images/code/ohos_gn_fail_1.png b/images/code/ohos_compile_gn_fail_1.png
index 96bb911..96bb911 100644
--- a/images/code/ohos_gn_fail_1.png
+++ b/images/code/ohos_compile_gn_fail_1.png
Binary files differ
diff --git a/images/code/ohos_gn_fail_2.png b/images/code/ohos_compile_gn_fail_2.png
index 7066632..7066632 100644
--- a/images/code/ohos_gn_fail_2.png
+++ b/images/code/ohos_compile_gn_fail_2.png
Binary files differ
diff --git a/images/code/ohos_gn_fail_dependencies.png b/images/code/ohos_compile_gn_fail_dependencies.png
index df3e4a6..df3e4a6 100644
--- a/images/code/ohos_gn_fail_dependencies.png
+++ b/images/code/ohos_compile_gn_fail_dependencies.png
Binary files differ
diff --git a/images/code/vim_mode.png b/images/code/vim_mode.png
new file mode 100644
index 0000000..3d10fc5
--- /dev/null
+++ b/images/code/vim_mode.png
Binary files differ
diff --git a/images/courseNotes/parallel_1.png b/images/courseNotes/parallel_1.png
new file mode 100644
index 0000000..05e1dca
--- /dev/null
+++ b/images/courseNotes/parallel_1.png
Binary files differ
diff --git a/images/courseNotes/parallel_2.png b/images/courseNotes/parallel_2.png
new file mode 100644
index 0000000..4fc5305
--- /dev/null
+++ b/images/courseNotes/parallel_2.png
Binary files differ
diff --git a/images/courseNotes/parallel_3.png b/images/courseNotes/parallel_3.png
new file mode 100644
index 0000000..c27b8f3
--- /dev/null
+++ b/images/courseNotes/parallel_3.png
Binary files differ
diff --git a/md2html.sh b/md2html.sh
index 7aaee04..13f2670 100755
--- a/md2html.sh
+++ b/md2html.sh
@@ -8,21 +8,50 @@
8# Created Time : 2023-12-15 8# Created Time : 2023-12-15
9########################################################################## 9##########################################################################
10 10
11# origin是输入的第一个参数,指源文件名 11origin=$1 # 源文件名
12# src是原文件名前边加一个.,是源文件的复制 12src="."$origin # 源文件的复制
13# dst是原文件名的md后缀改成html 13dst=${origin%.*}".html" # 目标文件
14origin=$1 14
15src="."$origin 15if [ $# -ne 2 ] || [ ${origin##*.} != "md" ]; then
16dst=${origin%.*}".html" 16 echo "Usage: $0 <markdown file> <html title>"
17 exit 1
18elif [ ! -f $origin ]; then
19 echo "Error: $1 does not exist"
20 exit 1
21fi
17 22
18cp $origin $src 23cp $origin $src
19# src中所有的“```...”替换成“```”,其中...指换行前的所有内容 24pandoc --no-highlight --mathjax=none -s $src -o $dst --metadata title="$2"
20sed -i 's/```.*$/```/g' $src
21pandoc -s $src -o $dst
22rm $src 25rm $src
23 26
27# 处理多行代码块,将<pre class="xxx"><code>替换为<pre class="language-xxx">
28sed -i -E ':a;N;$!ba;s|<pre[^>]*class="([^"]+)"[^>]*>[[:space:]]*<code[^>]*>|<pre><code class="language-\1">|g' $dst
24sed -i '/<style/,/<\/style>/d' $dst 29sed -i '/<style/,/<\/style>/d' $dst
30# 修改body的样式
25sed -i 's/<body>/<body>\n<div class="pandoc">\n<div class="main">/' $dst 31sed -i 's/<body>/<body>\n<div class="pandoc">\n<div class="main">/' $dst
32# 添加评论区
26sed -i 's/<\/body>/<script src="https:\/\/www.qin-juan-ge-zhu.top\/common\/js\/comment.js"><\/script>\n<\/div>\n<\/div>\n<\/body>/' $dst 33sed -i 's/<\/body>/<script src="https:\/\/www.qin-juan-ge-zhu.top\/common\/js\/comment.js"><\/script>\n<\/div>\n<\/div>\n<\/body>/' $dst
27sed -i 's/\t/ /g' $dst 34sed -i 's/\t/ /g' $dst
35# 添加样式
28sed -i 's/<\/head>/<link rel="stylesheet" href="https:\/\/www.qin-juan-ge-zhu.top\/common\/CSS\/pandoc.css">\n<script type="text\/javascript" src="https:\/\/www.qin-juan-ge-zhu.top\/common\/script4code.js"><\/script><\/head>/' $dst 36sed -i 's/<\/head>/<link rel="stylesheet" href="https:\/\/www.qin-juan-ge-zhu.top\/common\/CSS\/pandoc.css">\n<script type="text\/javascript" src="https:\/\/www.qin-juan-ge-zhu.top\/common\/script4code.js"><\/script><\/head>/' $dst
37
38# 检查是否有数学公式,有则添加mathjax
39if grep -Eq "math inline|math display" $dst; then
40 sed -i 's|</head>|<script type="text/javascript" async\
41 src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/MathJax.js?config=TeX-MML-AM_CHTML"></script>\
42 <script type="text/x-mathjax-config">\
43 MathJax.Hub.Config({\
44 tex2jax: {\
45 inlineMath: [["$","$"], ["\\\\(","\\\\)"]],\
46 processEscapes: true\
47 }\
48 });\
49 </script>\
50 </head>|' "$dst"
51fi
52
53# 检查是否有mermaid有则告警
54grep -n "language-mermaid" $dst
55if [ $? -eq 0 ]; then
56 echo "Convertion Warning: mermaid is included, may you need to replace it with a picture???"
57fi