このページの本文へ

前へ 1 2 次へ

Windows Info 第57回

ビルドやブランチなど、Windows 10に使われる用語を整理する

2016年01月22日 12時00分更新

文● 塩田紳二 編集● ASCII.jp

  • この記事をはてなブックマークに追加
  • 本文印刷

プロジェクト管理されるソフトウェア開発

 Windows 10の文書やマイクロソフトのブログでは、「ビルド」や「ブランチ」などの聞き慣れない用語が使われている。これらは、ソフトウェア開発関係の用語だ。今回は、こうした用語を整理しておく。

 現在のソフトウェア開発では、ソースコードを世代ごとに記録/管理していく「ソースコード管理システム」を使うのが一般的で、ソフトウェアの状態などは、ソースコード管理という視点で表現されることが多い。

 ソースコード管理システムとは、ソフトウェアを構成するソースコードや関連のファイルを世代ごとに記録し、いつでも前の状態に戻したり、複数の変更を並行して行うことなどを可能にするシステムだ。

 ソフトウェアは単純にソースコードだけでできているわけではなく、たとえば、付属の文書(オンラインソフトでReadMeという名前のファイルを見たことはないだろうか? こうしたものがリリースに必要なファイルとなる)や、インストーラーの制御スクリプトなど、多数の「ファイル」から構成されている。こうしたファイルを管理するのが「ソースコード管理システム」だ。

 開発者は、変更したソースコードでテストを行ない、きちんと動作することを確認した「正しい状態」のソースコードを「ソースコード管理システム」に登録する。これを「チェックイン」などという。1つのソースコードについてみると、過去のチェックインが存在し、一本の線のようになる。

 ソースコード管理システムでは、1つのソフトウェア製品を「プロジェクト」として、関連するファイルをすべて管理する。大規模なソフトウェアでは、1つのプロジェクトが複数のサブプロジェクトから構成されることもある。

 おそらくWindowsでは、全体が1つのプロジェクトになっているが、たとえばメモ帳や電卓といった標準付属のアプリなどはサブプロジェクトとして管理されている。また、Internet ExplorerやEdgeといったソフトウェアもサブプロジェクトになるが、この規模になると、さらにサブプロジェクトに分かれている可能性もある。

 こうした「プロジェクト」に属するソースコードなどを使い、配布可能な状態を作ることを「ビルド」という。もちろんサブプロジェクトは個々にビルドが行なわれ、全体のビルドを行うときにビルドされたサブプロジェクトが組み込まれていく。

ソフトウェアを構成するソースコードやファイルなどは、対応するプログラムや製品ごとに「プロジェクト」として管理されている。大規模なソフトウェアでは、1つのプロジェクトは複数のサブプロジェクトに分かれている。プロジェクト単位でソフトウェアを配布可能な状態に組み上げることを「ビルド」と言う

 ビルドを行うとき、ビルド番号が割り当てられ、自動的にソフトウェアに組み込まれていく。一般にこうしたビルド番号には、単調増加するような数字や、日付などから作られた数字を使う。Windows 10のビルド番号は、TH2までは単調増加する番号が使われてた。

複数のビルドが並行して開発されている状態で
必要となる処理がブランチ

 しかし、ソフトウェアの開発では、現在バージョンのメンテナンス(バグの修正など)を行ないつつ、次世代バージョンの開発を進める。このような場合、ソースコードは現在のバージョンのバグ修正のために変更され、次世代の新機能を組み込むために修正されることがある。このような場合、ソースコードのコピーを作り、一方を現行バージョンの修正用に、もう1つを次世代用にしてそれぞれで修正を行う。こうした処理を「ブランチ」という。

現行版のメンテナンスと次世代版の開発を並行して行うような場合には、ソースコードを「ブランチ」させて、個別に作業を行なう。一旦ブランチして分かれたソースコードなどの変更を統合することを「マージ」という。Windows10では、TH1とTH2は別のブランチとして開発されるだけでなく、実際の利用でも「Current Branch(CB)」(最新のアップグレード状態のもの)と、アップグレードを延期している「カレントブランチフォービジネス(CBB)」の2つの「ブランチ」に分かれる

 ブランチは、このようにバグ修正と新機能組み込みなどのようにまったく違う変更を同一のソースコードに対して行なわねばならない場合に利用する。ブランチを行なうと、プロジェクトから複数のビルドを作ることができるようになる。

 マイクロソフトほどの規模の会社であれば、TH2でバグ修正を行うチームと、次世代のアップグレードとなるRS1の開発を行うチームが別にあり、それぞれがブランチさせたソースコードで開発を行っていると思われる。RS1プレビュー版のビルド番号が「11082」となっているのは、TH2までの「10xxx」というビルド番号とは独立してビルド番号を割り振ることができるようにしたいからだ(逆に言えば、RS1の前に10999以下のビルド番号を持つTH2のアップグレードが今後リリースされる可能性があることを示す)。

 現在のWindows 10はTH2と呼ばれる「ブランチ」が現行版として使われていて、Windows UpdateはこのTH2を修正するものになる。一方で並行して、RS1の開発が行われており、すでにWindows Insiderプログラムでプレビュー版の配布が行われている。簡単にいうと、これはTH2という「ブランチ」とRS1という「ブランチ」があり、並行して作業がなされている。

 しかし、ここで疑問を持たれる方もいるだろう。ブランチするとソースコードがコピーされて、TH2とRS1では別々の修正が行われる。そうすると、TH2用に行った修正は、RS1のほうには反映されないことになる。RS1にも同じバグがあった場合、修正を最初からやらねばならないのだろうか?

 まず、プロジェクトは独立したサブプロジェクトから構成されており、1つのサブプロジェクトの修正は原則、他のサブプロジェクトにはできるだけ影響しないようになっている(そもそもプロジェクトを最初にそのように切り分ける)。たとえば、メモ帳に問題があり修正を行っても、Windows自体やソースコードを共有しない他のアプリ、たとえば「電卓」に影響が出る可能性はほとんどない。このためサブプロジェクト内のみの修正であれば、他の部分を気にする必要がない。

 ブランチしたRS1では、TH2のすべてのソースコードを修正するわけではなく、中にはTH2と同じままの部分もかなりある。このため、修正がサブプロジェクト内で閉じているならそのまま利用できる。

 他のブランチで行った修正を作業中のブランチに反映させることを「マージ」という。ソースコードの修正が片方のみで、広範囲に影響を与えない「マージ」であれば、作業はほぼ自動で行える。大半の修正はこれに当たる。万一、RS1で修正しているソースコードがTH2のバグ修正で変更された場合は、開発者が両方を見て、適切に修正する必要がある(これを手動マージなどということもある)。

 このように「ブランチ」を使うことで、現行版、次世代版などを並行して開発することが可能になる。Windows 10 Pro以上には、TH1、TH2などの「アップグレード」を延期して、一定期間は、同じものを使い続けることができる「Windows Update for Business」などの機能がある。

 現時点では、アップグレードを延期していてTH1を使い続けているマシンとTH2にアップグレードしたマシンの2種類が存在する。このように並行して利用されるアップグレードをマイクロソフトは「ブランチ」と呼ぶ。

 TH1/TH2などのアップグレードがブランチとして開発されており、リリース後もそのブランチを維持しているからだと思われる。というのは、Windows Updateによるアップデートは、TH1とTH2で違って来るからだ。実際、最近のWindows Updateで配布されるアップデートには、「Windows 10 バージョン1511」といった表記があり、TH2にはTH2用のアップデートが配布されている。

前へ 1 2 次へ

カテゴリートップへ

本記事はアフィリエイトプログラムによる収益を得ている場合があります

この連載の記事
1
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、256GB SSDストレージ、1080p FaceTime HDカメラ - シルバー
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、256GB SSDストレージ、1080p FaceTime HDカメラ - シルバー
¥95,768
2
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、日本語キーボード、Touch ID - スカイブルー
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、日本語キーボード、Touch ID - スカイブルー
¥177,333
3
【整備済み品】富士通 ARROWS Tab V727/V 12.3型 タブレットPC 第7世代 Core m3 メモリ4GB SSD128GB Windows11 Office2019搭載 1920×1280 高精細液晶 LTE対応 無線LAN タッチペン付属 カメラ搭載 初期設定済み
【整備済み品】富士通 ARROWS Tab V727/V 12.3型 タブレットPC 第7世代 Core m3 メモリ4GB SSD128GB Windows11 Office2019搭載 1920×1280 高精細液晶 LTE対応 無線LAN タッチペン付属 カメラ搭載 初期設定済み
¥9,999
4
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
¥35,129
5
【整備済み品】NEC ノートパソコン VX-9 VKT16 15.6型 FHD 第10世代Core i5-10210U(最大動作4.2GHz) /Windows11 Pro/MS Office2021/WIFI内蔵/Webカメラ/DVD-ROM/テンキー/Bluetooth/HDMI/Type-C/有線静音マウス付属 (Corei5-10210U, メモリ16GB,SSD512GB)
【整備済み品】NEC ノートパソコン VX-9 VKT16 15.6型 FHD 第10世代Core i5-10210U(最大動作4.2GHz) /Windows11 Pro/MS Office2021/WIFI内蔵/Webカメラ/DVD-ROM/テンキー/Bluetooth/HDMI/Type-C/有線静音マウス付属 (Corei5-10210U, メモリ16GB,SSD512GB)
¥49,880

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

ASCII倶楽部

注目ニュース

  • 角川アスキー総合研究所

プレミアム実機レビュー

ピックアップ
1
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥2,374
2
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥1,080
3
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
¥990
4
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
¥640
5
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ホワイト T-K6A-2630WH
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ホワイト T-K6A-2630WH
¥1,899
6
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
¥1,299
7
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
¥5,645
8
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
¥1,359
9
エレコム USB Type C ケーブル 1m 100W PD対応 高速充電 シリコン素材 なめらか やわらか 【 MacBook/iPad/Galaxy/Android スマホ タブレット 等対応 】 ブラック 【iPhone 16 シリーズ 対応検証済】 MPA-CCECSS10BK
エレコム USB Type C ケーブル 1m 100W PD対応 高速充電 シリコン素材 なめらか やわらか 【 MacBook/iPad/Galaxy/Android スマホ タブレット 等対応 】 ブラック 【iPhone 16 シリーズ 対応検証済】 MPA-CCECSS10BK
¥1,099
10
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

デジタル用語辞典

ASCII.jpメール デジタルMac/iPodマガジン