##はじめに
多くの大手企業や海外に強いベンチャー系企業のお仕事のお手伝いをしていた関係で、導入の黎明紀からいろいろなプロジェクトのソースコード管理方法を見ていますが、この管理方法が一番良いと言う方法は無いと思っています、選択肢のひとつと思って頂ければ幸いです。なぜなら、いまのグループ開発環境は少し前とは、比べられないくらい便利になっているからです。そしてこれからもより良く進化すると思います。
現在はゲームジャムなどの数時間程度のグループ開発でも、BitbucketとSourceTree(GitなどをGUIで扱う事ができるツール)を使いグループ開発を行うのが普通になっています。わたしは今年、武蔵野美術大学ゲームジャムに参加したのですが、そこでAsset Serverを使える機会があり、その便利さを再認識しました。ジャム初参加の学生さん達と一緒にレトロ風ゲームを作成したのですが、初めて使う学生さんには、UpdateとCommitを繰り返すだけの説明だけで良く、純正ツールなので不要なファイルは意識しなくて良い、競合の回避方法も標準的な回避方法を用意ているなど、あまりの使い勝手の良さに先日行われたOculus Game Jamで使用出来なかった(実は対応していたが、これから説明する設定をしていなかったので出来ないと思っていた)のが残念なくらいでした。
また、Jam会場では、一度に同じ場所で多くの人が初めてインターネットを使おうとするので、回線が込み合いリソースの奪い合いに発展しがちです。Unityの開発プロジェクトは、リッチなリソースをリポジトリへアップロード・ダウンロードの繰り返しが多いため、その作業が開発時間の圧迫にもつながり、終盤になればなる程、つらい状態に陥ります。
Game Jam以外の普段使いでも、有料で決して安くは無いお買い物ですが、現在は1ヶ月契約もできますのでUnityでグループ開発の開発効率をあげたいなら考えても良い純正ツールだと思います。
しかし、Asset Serverを使うにはチームライセンスを取得していないと使用できない為、金銭的なハードルが高いのは否めません。
##Asset Serverの仕組み
Asset Server専用機を用意し、ネットワーク経由でプロジェクトのリポジトリ管理を行う仕組みが基本らしいです。私は予算の関係上、開発機と同じ端末にAsset Serverをインストールしています。
Asset Serverをインストールしたい端末にUnityが入っている必要は無く、Asset Serverへ管理者がログインし新規リポジトリの作成やユーザー登録を行う形式です。
Asset Serverは、別の端末から操作するとことを前提に設計されています。
##Asset Serverを使うには
Asset Serverを使うには、Unityのチームライセンスを購入する必要があります。チームライセンスにはCache Serverも付いているので、マルチプラットフォーム開発時のプラットフォーム切り替えで待たされる時間をCache Serverから取得し回避することができます。
https://store.unity3d.com
買い切りだと500ドル、1ヶ月契約で月20ドルになります(2年と1ヶ月で買い切り値段と同額の支払いになります)。
##Asset Serverのインストール
まずはAsset Serverのインストラーをダウンロードしインストールします。
Asset Serverが対応しているプラットフォームもWindow,Mac,Linux(仮想イメージも含め一般的なLinuxディストリビューション用パッケージがあります)に対応しています。今回は予算の都合で開発機と同じマシン上にインストールしました。
ダウンロードしたMac用のパッケージファイルを実行しようとすると「セキュリティとプライバシー」の設定次第でインストールできないかもしれません。Macのシステム環境設定->セキュリティとプライバシー、一般ボタンのダウンロードしたアプリケーションの実行許可:をすべてのアプリケーションを許可にしてインストールできます。
インストールの最後にAsset Serverの管理用パスワードを何にするかがあるので、管理用のパスワードを設定します。
インストールが終了すると再起動しログイン画面にUnity Asset Serverユーザーが追加されますが、通常のユーザーでログインします。MacのAsset Serverインストール時の変更(セキュリティとプライバシー)は、元に戻しておきましょう。
##Asset Serverの初期設定
一般的にAsset Server機は少し古くなり余っている端末へインストールし使う事が多いようです。LAN上にAsset Serverが在り特殊なフィルタリング(Asset Serverが使用するポート10733を塞いでいるなど)がされていなければ、ホスト名かIPアドレスでアクセスすることができます。
Unityをインストールした端末からAsset Serverの制御を行うのですが、Unityの初期設定では制御画面を出せないようになっています。
Asset Server管理画面をだすには、UnityのメニューバーのEdit->Project Settings->Editorを選択、Version Control ModeをAsset Serverへ変更します。
Version Control ModeがAsset ServerになっているとメニューバーのWindow->Version Controlが選択できるようになりAsset Serverの管理画面を開く事ができます。
Asset Server AdministrationのAdministrationボタンを押してAsset Serverの管理画面を表示します。
同じ端末にAsset Serverをインストールしたのであれば、Server ConnectionのServer Address:は、localhostのままで大丈夫です。他の端末がAsset Serverの場合、IPアドレスかホスト名をプルダウンか入力することで選択できます。管理者名はデフォルトのままで問題無いと思います。パスワードはインストールの最後で入力したパスワードになります。
パスワードを入力してConnectボタンを押すとAsset Serverで管理しているプロジェクトの一覧を表示することができます。
Admin ActionsのCreateボタンでProject Name:を入力し、新規プロジェクトのリポジトリを作成します。
プロジェクトを選択し、New Userボタンで編集できるユーザーを追加します。
ユーザー名横のチェックボックスをチェックしないと、そのユーザーがプロジェクトを参照することができません。
##Asset Serverにアクセスしてプロジェクトをコミットする
Asset Serverへローカルのプロジェクトを登録する場合、いま開いているローカルのプロジェクトをリポジトリに登録しようとします。事前に新規プロジェクト作成をするなどし、最適な状態にしておきましょう。
管理者権限でサーバープロジェクトを作っただけの状態では、リポジトリには何も登録されていません。Local ChangesのDetailsボタンをして、ローカルの変更をリポジトリへ反映する作業をしましょう。
向かって左側のLocal ChangesからChangesetへドラッグするかAdd Allボタンで、Changeset欄へ移動させます。登録したくない不必要なファイルは<<<ボタンで選定できます。
リポジトリ管理の一般的なルールでCommit Messageを入れCommitボタンでコミットします。
##Asset Serverにアクセスしてプロジェクトをチェックアウトする
新規プロジェクトを作成します。
メニューバーのWindow->Version ControlでAsset Server画面を表示します。
Version Contorl画面が出ない人は、「Asset Serverの初期設定」のメニューバーのEdit->Project Settings->Editorを選択、Version Control ModeをAsset Serverへ変更してください。
Current ProjectのコネクトボタンでServer ConnectionのUser Nameを入力するのですが、コピーアンドペーストができないので直接入力します。パスワードを入力しShow Projectボタンを押すとProject on Server欄にあなたが関われるプロジェクト一覧が表示されます。選択しProject Nameが現れたらConnectボタンで接続します。
Updates on Serverに更新履歴が表示されるのでUpdateボタンを押し更新します。
しばらくするとAsset Serverより自分のローカル環境にプロジェクトファイルがロードされます。
##競合した場合
Asset Serverに限らず、グループ開発で作業してする場合、どうしても発生してしまうのが同じファイルを編集してしまうことによるマスターファイルとの競合です。
Asset ServerはリポジトリからプロジェクトをUpdateし競合があった場合、Updateのタブ画面で競合の問題をどうするのか指示を求めます。
競合問題のあるファイル単位に、Skip Asset(サーバーからダウンロードしない)、Dicard My Changes(自分の変更を破棄する)、Ignore Server Changes(サーバーの変更を無視しする)、**Mager(マージ)**ボタンで解決策を設定しContinueボタンを押すと処理を実行します。
##Asset Serverの更新履歴と中身をBitbucketなどのサービスへ移行する方法
###uas2gitをインストールする
GitHubにAsset Serverから他のソースコード管理へ履歴共々移行できるツールがあります。
https://github.com/tnayuki/uas2git
基本的にgitからリポジトリをクローンしrubyのgemコマンドでインストールするだけなのですが...
git clone git://github.com/tnayuki/uas2git
gem install uas2git
依存しているパッケージをインストールしていないと途中でエラーになったりします。
わたしの場合は
ERROR: Error installing uas2git:
ERROR: Failed to build gem native extension.
```で[pgパッケージをインストール](http://stackoverflow.com/questions/19625487/impossible-to-install-pg-gem-on-my-mac-with-mavericks)したら解決しました。
sudo gem install pg
sudo gem install uas2git
**2015.1.27にuas2gitが更新されたので過去バージョンをお使いの方は、アップデートするとプロジェクト名に全て小文字空白無しが解決します。**
githubからクローンしたuas2gitのインストールディレクトリにcdする。
git pullでローカルリポジトリを更新する。
![スクリーンショット 2015-02-08 9.07.07.png](https://qiita-image-store.s3.amazonaws.com/0/25895/d29e3db7-887d-0b43-2432-7d1fbee6603d.png)
sudo gem install uas2gitでインストールする。
![スクリーンショット 2015-02-07 14.54.56.png](https://qiita-image-store.s3.amazonaws.com/0/25895/f3762f53-16ee-d9cd-9e2c-478d4e723ee1.png)
わたしの環境だけかも知れませんがRuggedが古いのですこしはまりました。
上記エラーが出た場合、ruggedを"sudo gem install rugged"でインストールすると
![スクリーンショット 2015-02-07 14.48.09.png](https://qiita-image-store.s3.amazonaws.com/0/25895/2ae87ed4-b601-c47f-f8b6-661722ec4996.png)
ふぁ?よく見るとCmakeを要求していてそれが...これ前にもあったなと言う事で、portでcmakeをインストールしRuggedをインストールしてみました。
sudo port install cmake
![スクリーンショット 2015-02-07 14.34.45.png](https://qiita-image-store.s3.amazonaws.com/0/25895/87845a08-f59c-6fc4-1c71-8ccfa5f1f0e5.png)
###uas2gitを使ってAsset Serverからデータを移行する
Usage: uas2git PROJECT_NAME [options]
Specific options:
-h HOSTNAME Unity Asset Server host (default: "localhost")
-U NAME Unity Asset Server user name (default: "admin")
--help Show this message
**プロジェクト名がHIMESUKUで、同一端末にAsset Serverをインストールしている場合の手順。**
1. uas2gitコマンドをAsset Serverがインストールされている端末で実行し、gitのローカルリポジトリを作成する。
1. git logコマンドでローカルリポジトリの履歴があるか確認する。
![スクリーンショット 2015-02-08 11.41.56.png](https://qiita-image-store.s3.amazonaws.com/0/25895/e5701564-3672-c635-f7b3-6b01a821ed59.png)
1. ローカルのリポジトリが作成されるので、Bitbucktへリポジトリを移す。
1. Bitbucketのページで移行用の新規リポジトリを作成する。
1. [Bitbuckの既存プロジェクトへインポートする]( https://confluence.atlassian.co.jp/pages/viewpage.action?pageId=35815511)を行う。
![スクリーンショット 2015-02-08 12.07.49.png](https://qiita-image-store.s3.amazonaws.com/0/25895/d0295afb-6c9d-31b9-8050-060c96ffc78e.png)
1. BitbucketにGame Jamで作成したプロジェクトが反映される。
![スクリーンショット 2015-02-08 12.07.22.png](https://qiita-image-store.s3.amazonaws.com/0/25895/b7126b3b-28ee-501b-dff6-c74c04532cb0.png)
##参考にしたところ
http://japan.unity3d.com/unity/collaboration/
http://docs-jp.unity3d.com/Documentation/Manual/AssetServer.html
http://docs-jp.unity3d.com/Documentation/Manual/SettinguptheAssetServer.html
https://github.com/tnayuki/uas2git