- はじめに
こちらのドキュメントは 事業者向けホームセンター モノトス の開発を進めるにあたり、コードのバージョン管理を行う必要があり、
社内メンバにバージョン管理の仕組みについて説明するために作成したものです。
1.バージョン管理の目的
svn - バージョン管理の目的 - Qiita より引用させていただきました。
バージョン管理システムを使う ( 主な ) 目的は下記の 4 つだと思う。
- 以前の状態に戻る
- 変更履歴を調査する
- プロジェクトを管理する
- 変更者と変更理由を知る
以下で順を追って説明する。
元々は航空機の部品管理に由来。
(ネジの装着ミスによりフロントガラスが吹っ飛んだ事件の教訓だったと思います。。)
2.バージョン管理のためのツール
ファイル名に .yyyymmdd など、変更日をつけて履歴管理することもできますが、すぐに履歴ファイルでいっぱいになってしまいます。
そのため、多くの場合はツールを利用します。
2016-01-08 現在、よく利用されている(あるいはいた)ツールをあげておきます。
- vss(Microsoft)
- CVS
- Subversion
- Mercurial
- Git
LinuxやPHP、その他有名なOSSのソースコードがGitで管理されるようになってきており、
今後よく利用されるツールはGitでほぼ間違いありません。
バージョン管理の一般常識として覚えておくべきツールです。
3.バージョン管理に必要なもの
- サーバー
- すべての変更履歴を中央集中管理するためのサーバー。
- リポジトリサーバー と呼ばれる
- 公開しても問題ないアプリケーションの開発でよく利用されるのが GitHub というサービスになります。
- クライアント
- ソースコードやイメージファイル、設計書などをバージョン管理の対象として追加したり削除したりするために必須
- 導入には Atlassian SourceTree というツールがおすすめ
- GUI
- 変更の履歴がツリーで表示され、見やすい
- Windows、Macなど、クライアント環境を選ばない
- アカウント
- リポジトリサーバーにだれでもアクセスできてしまうとソースコード資産が他者に利用されてしまう
- 閲覧権限を絞るために、アカウントごとに閲覧の可否を設定する
- 編集の可否も設定する
4.モノトスのソースコードはどうやってリポジトリサーバーから取得するの??
以降の操作では、基本的にSourceTreeを利用し行うものとしました。
clone と呼ばれる操作を行います。
GUI上は、**「+新規リポジトリ」**というボタンを押します。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-at5wFK04QJ4%2FVGA9dJV82YI%2FAAAAAAAAau4%2F2u39K6lPYAo%2Fs800%2Fvcm00.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=4159da0ee1a2ed57627b7b0aa3b64ea3)
ソースURL(あるいは、リポジトリURLと呼ばれる)には、リポジトリサーバーが提供するプロジェクトごとのURLを設定します。
詳細は後述。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-xQG_jYbWZ68%2FVGA9hSlj9XI%2FAAAAAAAAavA%2Fazo4ycEKiDc%2Fs800%2Fvcm01.gif?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=48a577c9a354d96a54af39ba6964bc43)
5.ソースURLはどうやって確認するの??
codebreak; にアクセスし、確認します。
2016-01-08 現在、 codebreak はサービス提供終了間近となっています。残念です。
事前にアカウントを取得し、ログインが出来るようにしておきましょう。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh6.ggpht.com%2F-C8bCpC6W2bk%2FVGA9k30C3jI%2FAAAAAAAAavI%2F6mP_S34tlJY%2Fs800%2Fvcm02.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=d5ffa9d1c981069976ceabadc150cbc1)
6.新規にプロジェクトを作成するにはどうするの??
- codebreak;にログインし、新規リポジトリの作成を行う
- リポジトリ一覧ページに表示されていることを確認し、設定ページヘ
- ソースURLをコピー
- SourceTreeにて、作業用PCにcloneする
2016-01-08 現在、 codebreak はサービス提供終了間近となっています。残念です。
はじめは空っぽ
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh6.ggpht.com%2F-d6PP4QcVuMA%2FVGA9rL7ZFaI%2FAAAAAAAAavY%2F2MqkfZgC4_M%2Fs800%2Fvcm03.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=0e9270b7bb7d849ab8b732dc772ca443)
7.ファイルを追加するには??
add + pushという操作を行います。
- add : ファイルに対して、間違いなく追加(あるいは変更、削除)を行ったことを確認する操作
- push : addマークを付けたファイルをリポジトリサーバーにアップ
pushの際には、必ずどのような目的で変更を行ったかをコメントとして入力しましょう!
(この点がバージョン管理で成功するプロジェクト、失敗するプロジェクトの命運を分ける)
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-22OCz8F0AY0%2FVGA9wV2LjZI%2FAAAAAAAAavg%2FQA4mBwV5_M0%2Fs800%2Fvcm04.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=b348f2feda8d2f31f1b872650a5c411e)
masterブランチを見ると、追加されていることがわかります。
-
masterブランチ : メインブランチとも呼ばれる。変更履歴のメインストリーム。。
- master以外のブランチ(幹)を作成することも可能
- 中二病風に言うと、複数の世界線が作成できる
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh3.ggpht.com%2F-E5_9ia4i6Vk%2FVGA9zIR-PhI%2FAAAAAAAAavc%2FSdVarzMrBrk%2Fs800%2Fvcm05.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=33d1225a1fc51c820a5f5ab22b01c619)
8.ファイルを変更するには??
add + pushという操作を行います。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-GYDVtqIdDMA%2FVGA91j8qK0I%2FAAAAAAAAavw%2FOsYFpwLn6sU%2Fs800%2Fvcm06.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=9dd868d8d7c864a21334a8df725548b0)
9.変更を取り消すには??
revertという操作を行います。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-9ERWQQtKitI%2FVGA94c6fTJI%2FAAAAAAAAav0%2FlsMkLNP3zX4%2Fs800%2Fvcm07.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=5d970c5828068de1ceb0cf9ce7af7ac0)
10.その他(機能の一部紹介)
branch 、 merge 機能を利用して、複数の世界線を活用します。
![](https://qiita-user-contents.imgix.net/http%3A%2F%2Flh5.ggpht.com%2F-ceHq2hwvoOA%2FVGA9-UgPF9I%2FAAAAAAAAav8%2FSh3SwcgCqAQ%2Fs800%2Fvcm08.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=b4d33f060063f810a298d2b42d904e0a)