LoginSignup
66
52

More than 5 years have passed since last update.

xib や Storyboard をロックする

Last updated at Posted at 2015-03-03

xib や Storyboard ファイルを開いただけで勝手に変更される件

Xcode の Interface Builder は xib や Storyboard ファイルをただ開いただけで勝手にどこかを変更してくれることがあります。余計なお節介です。

ちょっと UI 構成を確認したいというだけなのに開いたらいちいち変更を取り消すというのは面倒ですし、そうでないにしても、更新するつもりのない xib を誤ってコミットしてしまいコミットログを汚し、結果いらぬ誤解を生んでしまうというのも嫌なものです。

対策として以下3案を考えてみました。

「ロック」したらいいんじゃないか

既に確定したレイアウトは後から見ることはあっても変更はしません。であればロックしてしまいましょう。少々面倒ではありますが、もし後から変更が必要になったら一旦ロックを外し、済んだら再度ロックする運用にしてみます。

1. IB のプロパティロック機能を活用する

いずれかの部品(ViewController, View など)を選択したら、右ペインの Identity Inspector タブを開きましょう。

lockib.png

"Document" セクションの中に "Lock" というポップアップボタンが見えます。初期値は Inherited (Nothing) となっているので、これを "All Properties" に変更します。
これで選択した部品以下は変更を受け付けなくなりました。不意にドラッグなどをしてしまっても frame の変更は受け付けなくなります。
xib / Storyboard ファイルはこの状態で保存するようにしましょう。

lock.png
ビューをドラッグしても変更が反映されず、錠前アイコンで知らせてくれるので安心。

これで各要素の変更は防ぐことが出来ました。とりあえずはこれで良さげな気もしますが、XMLファイルとしてみればまだ変更は可能な状態に思えます。これには次の策を考えてみます。

2. パーミッションを readonly にしてみる

-rw-r--r--   1 USER  staff  3712  3  4 03:28 LaunchScreen.xib
-rw-r--r--   1 USER  staff  2007  3  4 02:45 Main.storyboard

xib / Storyboard ファイルのパーミッションを readonly に変えてみます。

$ chmod 444 LaunchScreen.xib
-r--r--r--   1 USER  staff  3712  3  4 03:28 LaunchScreen.xib
-rw-r--r--   1 USER  staff  2007  3  4 02:45 Main.storyboard

この状態で変更を加えようとすると、ロックされている旨のダイアログが表示されます。
sheet2.png
Unlock を実行するとパーミッションが "644" に戻ります。

3. ファイルをロックしてみる

Finder にはファイルの「ロック」という機能が存在します。これを試してみます。

lockfinder.jpg

Finder で xib / Storyboard ファイルを選択したらすかさず ⌘ I。ウインドウ内 "一般情報" の下に "ロック" というチェックが見えるので、これを有効にします。これで鍵付きアイコンに出来ます。
もし大量のファイルを一度にロックしたい・外したいというのであれば、複数選択して ⌃ ⌘ I とすると一つの情報ウインドウにまとめられるので便利です。

sheet.png
ロックされた状態でファイルに変更を加えようとすると、このようなシートダイアログが表示されます。

そもそも Finder の「ロック」とは何か

このロック属性、いったいどこに保存されるのかが気になります。結論から言うとこれは BSD 系に共通するファイルフラグというもので、 chflags で変更できるフラグだそうです。

chflags ファイルのフラグを変更する

実際にコマンドから確認してみます。

flag1.png
"file" というファイルをロックしていない状態で ls -lO

flag2.png
"file" を Finder でロックしてから再度 ls -lO

Finder でロックすると uchg フラグが立つということが分かりました。

こちらの記事でも詳しく検証されていました。

[chflags]Finder上での『鍵』マークの仕組み

ファイルの属性情報を探る 権限編

Git リポジトリではどう運用するか

ここが割と肝心だったりします。

IB のロック機能

ロック属性は xib / Storyboard ファイルに書き込まれるので、ロックを変更するとファイルの変更という扱いになります。(保存するとMマークが付きます。)
m.png

パーミッションの変更を反映

filemode=true/未設定 であればファイルのパーミッションが反映されるようです。

Git でファイルパーミッションの変更(chmod)を無視する - git config core.filemode false

ファイルフラグの変更を反映

Xcode/Git 上では変更扱いにはなりませんでした。Git 側に何か設定があるのでしょうか。

リポジトリに反映できないのであれば、これを逆手にとって作業コピー環境下のみでファイルをロックしておく(コミット/プッシュしても変更の心配無し)、という運用も考えられそうです。

おわりに

結論といえる程ではありませんが、策1を講じておけばほぼ問題はないと思います。それでも不安ということであれば策2との合わせ技でしょうか。いずれにしてもロック運用にするということをチーム内で共通認識としておくことが大切だと思います。

もしこの他にも良いソリューションがありましたら教えていただけると幸いです。

関連記事

コンフリクトした xib ファイルを上手にマージする
http://qiita.com/uasi/items/a20ea86fa11484ccd1db

Don’t Modify My Nibs
http://theappcanuck.com/dont-modify-my-nibs/

XCode 5 Interface Builder Storyboard locked
https://pragmapilot.wordpress.com/2013/09/25/xcode-5-interface-builder-storyboard-locked/

66
52
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
66
52