国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

[譯] 使用 Sami 生成 PHP 文檔

banana_pi / 3539人閱讀

摘要:原文地址為方法類函數生成文檔已經成為了程序員的習慣所以需要知道通過源代碼生成獨立的文檔本文中我會介紹一款新的文檔生成工具什么是是插入到類接口方法屬性頂部的多行注釋為了闡明這個我們看下中的代碼片段開始于結束于每行之間使用當定義一個類屬性或者

原文地址: Generating PHP Documentation with Sami

為方法, 類, 函數生成文檔已經成為了程序員的習慣, 所以需要知道通過源代碼生成獨立的文檔. 本文中我會介紹 Sami, 一款 新的 API 文檔生成工具.

什么是 DocBlock?

DocBlock 是插入到 類, 接口, 方法, 屬性頂部的多行注釋, 為了闡明這個, 我們看下 Laravel 中的代碼片段

abstract class Manager
{
  /**
   * The application instance.
   *
   * @var IlluminateFoundationApplication
   */
  protected $app;
  

  /**
   * Create a new manager instance.
   *
   * @param IlluminateFoundationApplication $app
   * @return void
   */
  public function __construct($app)
  {
    $this->app = $app;
  }
}

DocBlock 開始于 /**, 結束于 */, 每行之間使用 *. 當定義一個類屬性或者方法的時候, 我們會寫一個描述或者多個注釋來描述這個功能. 在這些示例中 @param 和@var 會被用到. 你可以訪問 phpDocumentor 官方網站來熟悉每個標簽的用法.

API 文檔生成器

世界上充滿許多文檔生成器, 但是最好的一個是 phpDocumentor, 我喜歡 Sami 的主要原因是能夠使用github 上版本控制的文檔, 并且可以使用 Twig 來生成模版

安裝 Sami

有兩種方式來安裝 Sami. 第一個是 下載 Phar 壓縮包并且使用php來運行

php sami.phar

第二個方式是通過 Composer. 你可以運行 composer require sami/sami:3.0.* 命令來添加 sami 包到你的項目中.

php vendor/sami/sami/sami.php

復制 Laravel’s 文檔

本示例中, 我會生成 Laravel Illuminate package 的文檔

git clone git@github.com:laravel/framework.git docs

現在我們的文件結構如下所示:

docs/
vendor/
composer.json

update 命令用來更新文檔, 下面是使用方法:

php vendor/sami/sami/sami.php update config/config.php

config.php 文件來描述你的文檔結構并且告知如何渲染輸出.

Configuration / 配置

配置文件必須返回 SamiSami 實例, 他接受 SymfonyComponentFinderFinder 實例和一系列的選擇項.

// config/config.php
    
$dir = __DIR__ . "/../docs";

$iterator = SymfonyComponentFinderFinder::create()
    ->files()
    ->name("*.php")
    ->exclude("build")
    ->exclude("tests")
    ->in($dir);

$options = [
    "theme"                => "default",
    "title"                => "Laravel API Documentation",
    "build_dir"            => __DIR__ . "/../build/laravel",
    "cache_dir"            => __DIR__ . "/../cache/laravel",
];

$sami = new SamiSami($iterator, $options);

return $sami;

$dir 變量保存源代碼的路徑. $iterator 獲取所有文件并且選擇 *.php 并且排除 buildtest 目錄. $options 變量里邊的內容比較顯而易見. theme設置成 default , 我們稍后講如何建立自己的主題. build_dir 保存輸出文件. cache_dir 放置 Twig 緩存, title 是生成文檔的標題

現在, 打開命令行并運行如下命令

php vendor/sami/sami/sami.php update config/config.php

命令執行完之后, 你可以運行內置的PHP服務器來查看文檔, 運行 php -S localhost:8000 -t build/, 并且訪問 http://localhost:8000/laravel/ 來查看運行結果

使用 Git 版本控制

我提到了使用 Sami 的一個重要原因就是他的版本控制. options["versions"] 參數接受一個 SamiVersionGitVersionCollection 實例來保存你的 Git 庫配置. 如下, 讓我們創建 5.04.2 分支的文檔.

$dir = __DIR__ . "/../docs/src";

$iterator = SymfonyComponentFinderFinder::create()
    ->files()
    ->name("*.php")
    ->in($dir);

$versions = SamiVersionGitVersionCollection::create($dir)
    ->add("5.0", "Master")
    ->add("4.2", "4.2");


$options = [
    "theme"                => "default",
    "versions"             => $versions,
    "title"                => "Laravel API Documentation",
    "build_dir"            => __DIR__ . "/../build/laravel/%version%",
    "cache_dir"            => __DIR__ . "/../cache/laravel/%version%",
];

$sami = new SamiSami($iterator, $options);

return $sami;

當使用版本的時候, 你的 build_dircache_dir 必須包含 %version% 標簽, add 方法的第二個參數是顯示在下拉選項中的標簽. 你可以使用 addFromTags, setFilter 方法來過濾版本號

php vendor/sami/sami/sami.php update config/config.php

現在你生成的文檔目錄將會包含每個版本的說明文檔. 用戶也能夠選擇去閱讀他想要的版本.

創建主題

現在, 我們僅僅使用了 default 主題, 但是 Sami 是可以擴展的, 讓我們能夠創建自己的主題.

這個 vendor/sami/sami/Sami/Resources/themes 文件夾存儲了默認主題. 然而你并不能夠把你的主題文件放到這里. Sami 提供了一個方法來添加自定義主題

// config/config.php
    
$templates = $sami["template_dirs"];
$templates[] = __DIR__ . "/../themes/";

$sami["template_dirs"] = $templates;

現在, 我們在應用程序的根目錄存在 themes 文件夾, 創建一個新主題, 我們需要創建一個文件夾, 并且在文件夾中放置一個 manifest.yml

// themes/laravel/manifest.yml
    
name: laravel
parent: default

我們的新主題的文件名是 laravel , 他繼承于 default 主題屬性. 作為示例, 我們添加一些資源文件, 并且覆蓋掉默認模版的一些樣式.

添加資源

我們在創建的主題文件夾中創建一個 css 文件夾, 并且在 css 文件夾中創建一個 laravel.css 文件.

// themes/laravel/css/laravel.css
...  
#api-tree a {
    color: #F4645F;
}
// themes/laravel/manifest.yml
...
static:
    "css/laravel.css": "css/laravel.css"

這個靜態文件配置塊, 告訴 Sami , 復制文件到指定的目錄, 新的構建目錄中會包含新的文件 build/laravel/%version%/css/laravel.css.

// themes/laravel/manifest.yml
...
global:
    "layout/base.twig": "layout/base.twig"


// themes/laravel/layout/base.twig
...
{% extends "default/layout/base.twig" %}

{% block head %}
    {{ parent()  }}
    
{% endblock %}

每次 Sami 想加載 base 布局, 他會使用你主題中定義的文件. 我們擴展默認的基本布局來保持默認的外觀. 然后我們插入自定義樣式到 head 部分. 調用 parent() 函數將保持已經存在的內容在 head 區塊中, 并且在 link 標簽前輸出.

// config/config.php
    
$options = [
    "theme"  => "laravel",
    //...
];
php vendor/sami/sami/sami.php render config/config.php --force

默認 , Sami 不會在文檔未發生任何變化的時候重載. 然而使用 --force 標記會強制輸出文件. 在瀏覽器查看文檔頁面, 注意下左側導航的顏色是不是已經改變.

變更標記
// themes/laravel/manifest.yml
    
global:
    "namespaces.twig": "namespaces.twig"

作為推薦名稱, namespaces 文件定義了我們的命名空間內容是怎么被渲染的.

// themes/laravel/namespaces.twig

{% extends "default/namespaces.twig" %}
{% from "macros.twig" %}

如果你打開 default/namespaces.twig 頁面, 你會發現 Sami 正在使用 macros 來簡化擴展模版的進度. 我們會創建我們自己的 macros.twig 文件來覆蓋默認的標記.

因為 Twig 不支持在 macro 中繼承和覆蓋重寫, 我們將復制并且粘貼默認的主題 macros 并開始編輯他們

// themes/laravel/macros.twig

{% macro render_classes(classes) -%}
    
{% for class in classes %}
{% if class.isInterface %} I {% else %} C {% endif %} {{ _self.class_link(class, true) }}
{{ class.shortdesc|desc(class) }}
{% endfor %}
{%- endmacro %}

我們僅僅在這個 macro 中改變了一件事, 就是區分了 ClassInterface . Sami 用來重點標識接口但是我們在每一個條目前都標識了一個帶顏色的標簽.
我們沒有在這個頁面改變很多東西. 但是你可能會在你的頁面中使用 bootstrap 樣式, 讓菜單更加響應化或者其他的.
現在, 在重新生成文檔之后你會發現你列出了一個 namespace, class 和 interface 都使用標簽標識出來了.

概述

在這個文檔中, 我們介紹了一個新的 Symfony 工具來幫助你管理包文檔. 你同樣可以創建一個獨一無二的主題. 你可以找到我們文檔的最終例子 -> Github.如果有什么問題可以給我們留言. 謝謝

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/25747.html

相關文章

  • PHP:40+開發工具推薦

    摘要:今天,就為開發者介紹個方便的工具。對開發者來說,是一個非常有用的工具,它提供了超過個有用的函數。該工具檢查輸入源代碼和報告任何違反給定的標準。框架是一個開發的工具。它側重于安全性和性能,絕對是最安全的開發框架之一。 PHP是為Web開發設計的服務器腳本語言,但也是一種通用的編程語言。超過2.4億個索引域使用PHP,包括很多重要的網站,例如Facebook、Digg和WordPress。...

    dreambei 評論0 收藏0
  • [] 給PHP開發者的PHP源碼-第一部分-源碼結構

    摘要:另一個說明我叫它做宏。你可以為函數定義寫一個宏事實上,就是這么做的,但我們會在后面的文章中深入了解這個。我想說的是,宏允許在預處理編譯時使用更簡單的代碼。或者說頭文件定義了在文件中可以被其他文件看到的函數,包括預處理宏。 文章來自:http://www.hoohack.me/2016/02/04/phps-source-code-for-php-developers-ch 原文:ht...

    wenzi 評論0 收藏0
  • 】CodeIgniter HMVC模塊擴展使用文檔

    摘要:和模塊分離類似,模塊擴展使得模塊變得可便攜的。模塊化意味著模塊化。但是,模塊擴展更進一步,它允許這些模塊互相通信。 CodeIgniter HMVC擴展說明 原文地址:Modular Extensions - HMVC 模塊擴展——HMVC 模塊擴展讓CodeIgniter框架模塊化。模塊是一組獨立的組件(通常有模型、控制器和視圖),它們被分類在應用模塊的子文件夾中,并且能夠直接拖到其...

    teren 評論0 收藏0
  • PHP中的隨機性——你覺得自己幸運嗎?

    摘要:本文分析了生成用于加密的隨機數的相關問題。沒有提供一種簡單的機制來生成密碼學上強壯的隨機數,但是通過引入幾個函數來解決了這個問題。呢缺省情況下,不提供強壯的隨機數發生器。如果你想要使用可靠的隨機數據源,如你在本文所見,建議盡快使用和 本文分析了生成用于加密的隨機數的相關問題。 PHP 5沒有提供一種簡單的機制來生成密碼學上強壯的隨機數,但是PHP 7通過引入幾個CSPRNG函數來解決了...

    鄒強 評論0 收藏0
  • PHP中的隨機性——你覺得自己幸運嗎?

    摘要:本文分析了生成用于加密的隨機數的相關問題。沒有提供一種簡單的機制來生成密碼學上強壯的隨機數,但是通過引入幾個函數來解決了這個問題。呢缺省情況下,不提供強壯的隨機數發生器。如果你想要使用可靠的隨機數據源,如你在本文所見,建議盡快使用和 本文分析了生成用于加密的隨機數的相關問題。 PHP 5沒有提供一種簡單的機制來生成密碼學上強壯的隨機數,但是PHP 7通過引入幾個CSPRNG函數來解決了...

    Eric 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<