plugin_development.html 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>xmake</title>
  6. <link rel="icon" href="/assets/img/favicon.ico">
  7. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
  8. <meta name="description" content="Description">
  9. <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  10. <link href="/assets/npm/github-markdown/github-markdown.min.css" rel="stylesheet">
  11. <style>
  12. .markdown-body {
  13. box-sizing: border-box;
  14. min-width: 200px;
  15. max-width: 980px;
  16. margin: 0 auto;
  17. padding: 45px;
  18. }
  19. @media (max-width: 767px) {
  20. .markdown-body {
  21. padding: 15px;
  22. }
  23. }
  24. </style>
  25. </head>
  26. <body>
  27. <article class="markdown-body">
  28. <h4>This is a mirror page, please see the original page: </h4><a href="https://xmake.io/#/zh-cn/plugin/plugin_development">https://xmake.io/#/zh-cn/plugin/plugin_development</a>
  29. </br>
  30. <script async type="text/javascript" src="//cdn.carbonads.com/carbon.js?serve=CE7I52QU&placement=xmakeio" id="_carbonads_js"></script>
  31. <style>
  32. #carbonads {
  33. font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu,
  34. Cantarell, "Helvetica Neue", Helvetica, Arial, sans-serif;
  35. }
  36. #carbonads {
  37. display: flex;
  38. max-width: 330px;
  39. background-color: hsl(0, 0%, 98%);
  40. box-shadow: 0 1px 4px 1px hsla(0, 0%, 0%, .1);
  41. }
  42. #carbonads a {
  43. color: inherit;
  44. text-decoration: none;
  45. }
  46. #carbonads a:hover {
  47. color: inherit;
  48. }
  49. #carbonads span {
  50. position: relative;
  51. display: block;
  52. overflow: hidden;
  53. }
  54. #carbonads .carbon-wrap {
  55. display: flex;
  56. }
  57. .carbon-img {
  58. display: block;
  59. margin: 0;
  60. line-height: 1;
  61. }
  62. .carbon-img img {
  63. display: block;
  64. }
  65. .carbon-text {
  66. font-size: 13px;
  67. padding: 10px;
  68. line-height: 1.5;
  69. text-align: left;
  70. }
  71. .carbon-poweredby {
  72. display: block;
  73. padding: 8px 10px;
  74. background: repeating-linear-gradient(-45deg, transparent, transparent 5px, hsla(0, 0%, 0%, .025) 5px, hsla(0, 0%, 0%, .025) 10px) hsla(203, 11%, 95%, .4);
  75. text-align: center;
  76. text-transform: uppercase;
  77. letter-spacing: .5px;
  78. font-weight: 600;
  79. font-size: 9px;
  80. line-height: 1;
  81. }
  82. </style>
  83. <h2 id="">简介</h2>
  84. <p>XMake完全支持插件模式,我们可以很方便的扩展实现自己的插件,并且xmake也提供了一些内建的使用插件。</p>
  85. <p>我们可以执行下 <code>xmake -h</code> 看下当前支持的插件:</p>
  86. <pre><code>Plugins:
  87. l, lua Run the lua script.
  88. m, macro Run the given macro.
  89. doxygen Generate the doxygen document.
  90. hello Hello xmake!
  91. project Create the project file.
  92. </code></pre><ul>
  93. <li>lua: 运行lua脚本的插件</li>
  94. <li>macro: 这个很实用,宏脚本插件,可以手动录制多条xmake命令并且回放,也可以通过脚本实现一些复杂的宏脚本,这个我们后续会更加详细的介绍</li>
  95. <li>doxygen:一键生成doxygen文档的插件</li>
  96. <li>hello: 插件demo,仅仅显示一句话:&#39;hello xmake!&#39;</li>
  97. <li>project: 生成工程文件的插件,目前仅支持(makefile),后续还会支持(vs,xcode等工程)的生成</li>
  98. </ul>
  99. <h2 id="">快速开始</h2>
  100. <p>接下来我们介绍下本文的重点,一个简单的hello xmake插件的开发,代码如下:</p>
  101. <pre><code class="lang-lua">-- 定义一个名叫hello的插件任务
  102. task("hello")
  103. -- 设置类型为插件
  104. set_category("plugin")
  105. -- 插件运行的入口
  106. on_run(function ()
  107. -- 显示hello xmake!
  108. print("hello xmake!")
  109. end)
  110. -- 设置插件的命令行选项,这里没有任何参数选项,仅仅显示插件描述
  111. set_menu {
  112. -- usage
  113. usage = "xmake hello [options]"
  114. -- description
  115. , description = "Hello xmake!"
  116. -- options
  117. , options = {}
  118. }
  119. </code></pre>
  120. <p>这个插件的文件结构如下:</p>
  121. <pre><code>plugins
  122. |-- hello
  123. | |-- xmake.lua
  124. |...
  125. | plugins目录下无需xmake.lua
  126. </code></pre><p>现在一个最简单的插件写完了,那怎么让它被xmake检测到呢,有三种方式:</p>
  127. <ol>
  128. <li>把 hello 这个文件夹放置在 xmake的插件安装目录 <code>xmake/plugins</code>,这个里面都是些内建的插件</li>
  129. <li>把 hello 文件夹放置在 <code>~/.xmake/plugins</code> 用户全局目录,这样对当前xmake 全局生效</li>
  130. <li>把 hello 文件夹放置在当前工程的<code>./plugins</code>目录下,通过在工程描述文件xmake.lua中调用<code>add_plugindirs("plugins")</code> 添加当前的工程的插件搜索目录,这样只对当前工程生效</li>
  131. </ol>
  132. <h2 id="">运行插件</h2>
  133. <p>接下来,我们尝试运行下这个插件:</p>
  134. <pre><code class="lang-console">xmake hello
  135. </code></pre>
  136. <p>显示结果:</p>
  137. <pre><code>hello xmake!
  138. </code></pre><p>最后我们还可以在target自定义的脚本中运行这个插件:</p>
  139. <pre><code class="lang-lua">target("demo")
  140. -- 构建之后运行插件
  141. after_build(function (target)
  142. -- 导入task模块
  143. import("core.project.task")
  144. -- 运行插件任务
  145. task.run("hello")
  146. end)
  147. </code></pre>
  148. </article>
  149. </body>
  150. </html>