本cpprefjpサイトは、GitHub Pagesのサービス上に構築されていますが、編集自体はGitHubリポジトリにあるMarkdown形式のプレーンテキストで行います。
cpprefjpサイトのGitHubリポジトリは、以下になります:
また、cpprefjpサイト上に掲載する画像ファイルのようなリソースも、GitHubリポジトリで管理しています。
GitHubからcpprefjpサイトへの自動反映
GitHub上で記述したMarkdown(.md)形式のリファレンスは、GitHub Actionsによって自動的にHTMLに変換されて、cpprefjpサイトに反映されます。
反映間隔
cpprefjp/site へ push すると、すぐに反映されます。
毎日深夜0時ころに全ページの変換を行います。ページを追加したときのサイドバーの更新や、GLOBAL_QUALIFY_LIST.txt
を編集した場合の適用は、そのときの変換で全ページに変更が適用されます。
日次の変換中にコミットした変更は、日次の変換がおわったあと (だいたい1時間30分〜2時間くらい) に自動で変換・反映されます。
自動デプロイ、自動テスト
本リポジトリでは、GitHub Actionsを使用して、自動デプロイと自動テストを行っています。
自動デプロイ
buildアクションで、MarkdownからHTMLへの変換と、GitHub Pagesへのデプロイを行っています。
変換時になんらかのエラーが発生した場合には、GitHub Actionsが失敗します。その場合、手元で修正して再度git pushを行うことになります
変換エラーではなく、GitHub Pagesリポジトリへのgit pushに失敗した場合 (buildアクションの実行中に新たなコミットがgit pushされた場合など) には、そのbuildアクションに対してRe-run jobを実行し、再度変換を行ってください。
自動テスト
- 禁止文字の検出 (detect forbidden charactersアクション)
- 説明はdetect_forbidden_characters.ymlのコメントを参照
- 内部リンクの誤り検出 (inner link checkアクション)
- サイト内のリンクが存在しない、または存在しているのに.nolinkを指定している場合にエラーが発生する
- GitHub Actionsの実行ログで、どのページのどのリンクが不正かがわかるので、それを修正すること
- 外部リンク切れを検出 (outer link checkアクション)
- 日本時間で日曜日の23:30に実行される
- 外部リンクのページにアクセスできない (ページが消滅したか、一時的にアクセスできない、などの理由) 場合にエラーとなる
- エラーが発生した場合は、本リポジトリにissueが発行される
- ページが消滅した場合は、代替となるものがあれば差し替え、なければInternet Archiveに変更する
- 一時的にアクセスできない場合は、時間を置いてアクセスできるようになったらissueを閉じる
- 海外からのアクセス (GitHub Actions) を拒否しているページもあるため、そのようなページは個別にチェックから外す (link_check.pyの
IGNORE_LIST
に追加する)
- コード修飾の誤り検出 (code qualify checkアクション)
- コードブロック中のコードを修飾しているのに、その修飾対象がない場合に、エラーが発生する
- GitHub Actionsの実行ログで、どのページのどのコード修飾が不正かがわかるので、それを修正すること
自動反映ツール
自動反映ツールも、GitHub上で開発が進められています。
機能要望やpull request等がありましたら、こちらにお願いします。
編集権限を得るには
push権限を持っていない方は、pull requestで何らかの編集を行うところからはじめてください。タスクを引き取っていただける場合には、タスクのissueに「やります」とコメントを書いていただければ、担当をお渡しします。
本サイトに対してpull requestを提出していただければ、取り込んだあとに管理者から編集権限をお渡しします。
pull requestに慣れていない場合には、issueでの相談からはじめていただければと思います。
管理者からpush権限をお渡しする申請が届いた場合には、引き受けていただけると幸いです。
Markdown形式による編集方法
cpprefjpサイトは、Markdown(.md)形式でリファレンスを記述します。
Markdownは、GitHubサービス上でドキュメントを記述するフォーマットとして広く使用されている形式です。
Markdownの記述方法をわかりやすく解説してくれているWebサイトは、すでに数多く存在しますので、詳細はそちらを参照してください。
ただし、cpprefjp特有の拡張構文もあります。 以下のページにまとめてあるので、そちらを参照して下さい。
Markdown形式では、HTMLのタグも併用できますが、cpprefjpサイトでは積極的にはHTMLタグを使用しない方針です。できるだけ、Markdown形式でできる範囲内で解決するようにしてください。
ただし、注釈・出典を貼るためにHTMLタグを利用します。
それ以外に本サイト内で使用しているHTMLタグは以下です:
- アンカーを貼るために、
<a id="アンカー名">対象文字列</a>
のようなHTML5に基づく記法を利用している - 表内での改行のために、
<br/>
タグを利用している - 値の大きさを表現するために、上付き文字を表す
<sup>
タグを利用している - 添字を表現するために、下付き文字を表す
<sub>
タグを利用している
また、Markdownパーサーの制限を回避し、表内で |
(縦線、vertical line) を使用するために、文字参照 |
を使用してます。
新規リファレンスを書くにあたって、雛形ページを用意していますので、そちらをベースにして編集作業を行ってください。
また、リポジトリのトップディレクトリにGLOBAL_QUALIFY_LIST.txt
というファイルがあります。サイト全体のコードブロックに対して適用したい識別子の修飾があれば、ここに列挙していきます。書き方は各雛形ページに書いてあるコードブロックの修飾と同じです。
初めての人は見ておいたほうがよいページ
その他、cpprefjpを編集するにあたってのドキュメント
Pull Requestのレビューとマージ
push権限を持っている方は、Pull Requestのレビューとマージもぜひお願いします。
Pull Requestを送っていただいた方には、管理者から後ほどpush権限をお渡しします。権限の譲渡は管理者がする必要がありますが、レビューとマージは、ほかのpush権限保持者がしていただいてかまいません。
Pull Requestのレビューが滞っていた場合、Pull Requestの提出者の方は、cpprefjpのpush権限保持者に対して、個人的にレビューを依頼してもかまいません。push権限保持者がだれかは、以下のページから確認できます:
- cpprefjp people
- 権限保持者の確認に使用できます
- cpprefjp contributors
- 各人が本サイトにどれくらいコントリビュートしているかを確認できます
ただし可能な限り、レビュアーとの技術的な議論はPull Request上で行っていただけると助かります。これは、議論を記録として残すことが目的です。
Git関係のルール
- コミットメッセージに厳密な書式は設けない
- 人によっては「〜を修正」のように書き、またある人は「fix ...」のように書きます。コミットメッセージは修正内容がわかることが大事で、書式はそれほど重要ではないという考えです
- また、本リポジトリが、英語の情報を元に日本語情報を提供する、という特性上、コミットメッセージが日本語と英語どちらであっても編集者が困ることはないはずですので、日本語か英語であれば、どちらで書いてもよいものとします
- コミットメッセージの内容としては、とくに自分以外の人が書いた文章を編集する際には、コミットメッセージに「なぜそのように編集したのか」をできるだけ書いたほうがよいです。これは、経緯を振り返りやすくすることが目的です
- 強制プッシュ
git push -f
やgit push --force
といったコマンドは、リポジトリの設定で、masterブランチに対してはできないようにしてあります。これは、masterブランチは壊してはならないという理由によるものです- masterブランチ以外には強制プッシュできますので、Pull Request用のトピックブランチのコミットを整理する、といった目的などで使用していただいて大丈夫です
求められる編集作業
誤字・脱字を修正する (難易度★)
本サイトは編集者が手入力で解説を書いているため、誤字・脱字はどうしても発生してしまいます。
誤字・脱字があったら、積極的に修正してください。
動作確認できたコンパイラバージョンを記載する (難易度★★)
本サイトのライブラリリファレンスでは、機能ごとに動作確認ができたコンパイラバージョンを記載しています。
各ページを書いた時点での動作確認できたコンパイラバージョンは記載していますが、その後の更新は十分に行えていません。
サンプルコードの下に以下のように動作確認できたコンパイラバージョンを記載する項目がありますので、「??」になっている項目がありましたら、動作確認して埋めていっていただきたいです。
## 処理系
### バージョン
- [Clang](/implementation.md#clang): ??
- [GCC](/implementation.md#gcc): 9, <span role="img" aria-label="未実装" title="未実装">❌</span>, 10 <span role="img" aria-label="検証済" title="検証済">✅</span>
- [Visual C++](/implementation.md#visual_cpp): 2019 Update 1 <span role="img" aria-label="実装済" title="実装済">⭕</span>
- mark noimpl : 未実装を表す絵文字
- mark impl : 動作確認はできていないけど、リリースノートやそれに類するドキュメントには実装済みと書かれていることを表す絵文字
- mark verified : 動作検証済み
バージョンの表記としては、とくにVisual C++は本サイト独自の表記法がありますので、以下のページを確認してください。
対応バージョンは、動作確認できたコンパイラのうち、最小のバージョンを知りたいので、記載されているものより古いコンパイラバージョンで動作確認ができた場合は、記載されているバージョンを修正してください。
動作確認の方法としては、対象ページのサンプルコードを、お手元のコンパイラでコンパイル・実行し、出力が記載されているものと一致しているかを確認してください。
ただし、「出力例」のように記載されている場合、プラットフォームごとに出力が異なる可能性があります。その場合は仕様と実装を確認していただく必要があるかもしれません。
動作確認は、Webブラウザ上で行える場合があります。オンラインコンパイラとして、以下のサービスの使用も検討してください。
関連項目を追加する (難易度★★★)
各ページには、「## 関連項目
」という見出し以下に本サイト内の関連ページを記載できます。
読者が関連する情報を追いやすいように、関連ページへのリンク追加をお願いしたいです。
関連項目としては、以下のようなものを記載します:
- 言語機能であれば、その機能への仕様変更・拡張など
- ライブラリであれば、
- 組み合わせて使うことが多いもの
- 特定のデータ構造に特化した関数と、汎用の関数
- その機能の代わりに使用を検討したほうがよいもの
関連項目を書く場所については、各雛形ページを参照してください。
サンプルコードを追加する (難易度★★★★)
本サイトは、すべての機能にひとつ以上のサンプルコードを付けることを大きな価値としています。
サンプルコードをひとつは (ほぼ) 必ず付けるようにしていますが、ユースケースをカバーできていない場合があります。
良質なサンプルコードを作ることはむずかしいですが、機能の有用性を説明する最小サンプルコードを書くことに慣れている方や挑戦したい方にお願いしたいです。
サンプルコードを追加する場合、以下の要件を満たすようお願いします:
- 既存サンプルコードとは異なるユースケースや、異なる観点を与えるものであること
- 標準の範囲内でその機能の有用性を説明しにくい場合を除き、プラットフォーム非依存であること
- 十分に小さいこと
新仕様に対応する (難易度★★★★★★)
C++の規格書を読み慣れている方向けになります。
C++の新仕様やCWG/LWGのissueへの対応作業が多く求められます。対応がまだ行われていない作業は、以下で確認できます。
- cpprefjp/siteリポジトリのタスクissue
- 担当をとりやすいようタスクissueにしているものがある
- cpprefjp/siteリポジトリのWiki
- CWG (Core Working Group) や LWG (Library Working Group) へのissue (Defect Report) など、タスクissueにしていない未対応タスクがすべて記載されている
C++の次のバージョンで入ることが決まった機能については、以下の方針で対応を行います。
- 次のバージョンの言語機能・ライブラリ機能の解説は、随時許可する
- ただし、Working Draftに採択された機能のみを対象とする。まだ提案中の機能は、本サイトでの解説の対象外とする
- 例外は、機能テストマクロのようなコンパイラへの推奨機能
- 採択された機能は、Wikiの各言語バージョンのページに記載されているが、されていなかったらC++ Standards Committee PapersのEditor's Reportで確認できる
優先度が低くなっている古くからある機能を記載する (難易度★★★★★★)
本サイトはなるべくすべての機能の解説を書くことを目標にしてはいますが、記載が追いついていないものがいくつかあります。
- iostream系
- C互換ライブラリ
- ロケール
これらはタスクissueにもできていませんが、手が足りず作業できていません。
貢献ポイント
cpprefjpおよびboostjpでの作業は、以下のように貢献ポイントを割り振った上で、年間の貢献 (12月から翌年11月) を集計して収益をコントリビューターの方々に分配します。
分配の手順は以下のようになります:
- コアメンバーが集計用のPull Requestを立てる
- コントリビューターの方々からの追加・修正の指摘を募集する
- 各コントリビューターの年間貢献ポイントと分配率を仮決定
- 貢献ポイントの追加・修正指摘、および分配の受け入れ、または辞退の申し出を受け付ける (1週間程度)
- 期間内に分配の受け入れ申し出がない場合は、貢献ポイントを次年繰り越す (前年まで保持)
- 辞退者を除いて分配率および分配額を決定する
- 入金先の情報をコアメンバー宛に伝える
- cpprefjpの銀行口座から支払う場合は、Googleフォームを用意する予定
- Open Collectiveから支払う場合は、後述する手順で経費申請する
お金での分配を辞退された方にも、ステッカーの配布などでお返しができればと考えています。
なお、マージされずにクローズされたPull Requestについては貢献ポイントの対象外とさせていただきます。
また、masterブランチにマージされずオープンなままのPull Requestについては、マージされた年に貢献ポイントをつけさせていただきます。
貢献ポイントとして含めないものには、以下があります
- 議論への参加、問題提起、問題報告
- Issueの発行
- Issue / Pull Request / コミットへのコメント
- SNS上での当Webサイトへの問題報告
- GitHub Wikiの編集
- 貢献ポイントの集計作業
- 集計ツールの開発
- 貢献ポイントの調整・ルール作り
start_editing/contribution_stats_*.md
の編集
貢献ポイントの集計方法として、以下の注意事項があります
- 同年内の当人による同ページへの複数の修正は、貢献ポイントをまとめる場合がある
- 連続した作業が複数コミットになった場合などにまとめる
- 複数の仕様変更による複数の修正の場合などはまとめない
- 同ページ内に対する複数の修正は、大きい貢献ポイントにまとめる場合がある
- リンク追加・修正を含む説明修正は、fixmやfixlなどにまとめる
cpprefjp
タグ | ポイント | 説明 |
---|---|---|
cpprefjp/typo | 1 | 誤字・脱字の修正 (ページ単位)。サンプルコードの非コメントの修正はfixs |
cpprefjp/link | 2 | 関連項目・参照リンクなどの追加・修正、nolinkの解除 (ページ単位) |
cpprefjp/addref | 20 | リファレンスを1ページ追加 |
cpprefjp/addlang | 20 | 言語機能を1ページ追加 |
cpprefjp/addpage | 20 | その他ページ追加 (articleや編集者向けページなど) |
cpprefjp/fixs | 2 | 既存ページへの修正 : small 軽微な修正、コード修飾追加 (ページ単位) |
cpprefjp/fixm | 5 | 既存ページへの修正 : medium 追加説明、サンプルコード追加、訳語追加 (ページ単位) |
cpprefjp/fixl | 10 | 既存ページへの修正 : large 仕様変更への対応 (ページ単位) |
cpprefjp/compiler | 2 | 動作確認できたコンパイラバージョンの記載。ライブラリ機能はページ単位、言語機能は件数単位 |
機能追加での機能表への列の追加は、linkではなくfixlにあたる。
boostjp
タグ | ポイント | 説明 |
---|---|---|
boostjp/typo | 1 | 誤字・脱字の修正 (ページ単位) |
boostjp/link | 2 | 関連項目・参照リンクなどの追加・修正、nolinkの解除 (ページ単位) |
boostjp/releases | 5 | Boostリリースノート1件追加 small : maintenance workなどの軽微で小さなリリースノート |
boostjp/releasem | 10 | Boostリリースノート 1件追加 medium : 10行以下の中程度の大きさ |
boostjp/releasel | 20 | Boostリリースノート 1件追加 large : mediumを超える大きさ |
boostjp/fixs | 2 | 既存ページへの修正 : small 軽微な修正、コード修飾追加 (ページ単位) |
boostjp/fixm | 5 | 既存ページへの修正 : medium 追加説明、訳語追加 (ページ単位) |
boostjp/addrefs | 10 | Boost逆引きリファレンス : small (1例追加) |
boostjp/addrefm | 20 | Boost逆引きリファレンス : medium (標準C++のバージョンアップ対応1例単位、Boostのバージョンアップ対応1例単位) |
ツール類
CIスクリプト、site_generator、kunaiなど。
タグ | ポイント | 説明 |
---|---|---|
tool/fixbug | 30 | バグ修正 |
tool/improves | 10 | コード改善 : small |
tool/improvem | 30 | コード改善 : medium |
tool/improvem | 50 | コード改善 : large |
tool/updatelib | 20 | 依存ライブラリのアップデート (直接使用のライブラリ単位) |
tool/updatelang | 10 | 使用言語のアップデート : small (とくにコード変更なく更新できた) |
tool/updatelang | 30 | 使用言語のアップデート : medium (多少のコード修正で更新できた) |
tool/updatelang | 50 | 使用言語のアップデート : large (大きいまたはむずかしいコード修正をして更新できた) |
tool/adds | 30 | 新たな仕組みの導入 small : (C++バージョン追加、カテゴリ追加など) |
tool/addm | 50 | 新たな仕組みの導入 medium |
tool/addl | 100〜 | 新たな仕組みの導入 large : キーワード自動リンク、相対リンク対応など |