35
32

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

知識ゼロからXcodeのプラグインを開発してみた

Posted at

iOSアプリの開発経験はありますが、OS XアプリやXcodeプラグインに関する知識はゼロから始めたので開発の仕方をまとめてみました。
長々と書いていますがやってみると意外と簡単です。
※とりあえず動く簡単なプラグインを開発しただけです。
#はじめに
いろいろ調べているとXcodeのプラグインはAppleが公式でサポートしている機能ではないそうで公式のドキュメントやAPIは公開されていないそうです。
なのでネットに転がっている記事や公開されているプラグインのソースコードを参考に開発してみました。
####参考にしたページ
Xcode Plugin を試しに作ってみた
Xcode Plugin が盛り上がっているらしい
VVDocumenter-Xcode
#Xcode-Plugin-Templateの導入
Xcodeプラグインの作り方を調べているとInfo.plistの設定やBuild Settingの設定が色々と出てくるのですがその辺りのめんどうな設定をまとめて設定してくれているTemplateです。
###1.Xcode-Plugin-Templateの取得
こちら↓からgit clone https://github.com/kattrali/Xcode-Plugin-Template.gitするかZIPファイルをダウンロードします。
Xcode-Plugin-Template
###2.TemplateファイルをXcodeで使用できるようにする
取得したファイルの中からXcodePlugin.xctemplateディレクトリ
(Xcode-Plugin-Template/Project Templates/Application Plug-in/Xcode Plugin.xctemplate)

~/Library/Developer/Xcode/Templates/File Templates/
ディレクトリ以下に移動します。
Templates, File Templatesディレクトリが存在しない場合は自分で作成してください。
###3.XcodePluginテンプレートファイルを使用してプロジェクトを作成
Xcodeの新規プロジェクト作成でOS X->File Templates->Xcode Pluginを選択してプロジェクトを作成します。(File Templatesがない場合は1,2のTemplatesの追加がうまく行えていないと思います)
スクリーンショット 2015-08-08 4.30.52.png

今回はObjective-Cで作成しましたが、Swiftも使用できるようです。
スクリーンショット 2015-08-08 4.39.46.png
#プロジェクトをビルド〜プラグインを実行
###1.プロジェクトをビルド
作成したプロジェクトをビルド(Command+B)します。
特になにも変更しなくともそのままビルドが通りました。
ビルドが成功すると~/Library/Application Support/Developer/Shared/Xcode/Plug-insディレクトリに{プロジェクト名}.xcpluginというディレクトリが作成されていれば成功のようです。
###2.Xcodeを再起動してプラグインを実行する
ビルドが成功したらXcodeを再起動し、メニューのEdit->Do Actionをクリックします。
スクリーンショット 2015-08-09 4.05.20.png

すると「Hello, World」というアラートが表示されました。
スクリーンショット 2015-08-09 4.03.46.png
これでひとまずプラグインが正常に実行されるようになりました。
###3.正常に動作しなかったら
再起動時にこんなアラートが表示された場合は「Load Bundle」を選択すればOKです。
スクリーンショット 2015-08-09 3.49.33.png

メニューに「Do Action」が追加されていなかったり正常に動作しない場合は、
/var/log/system.logのログの中から「Xcode」を含むログを確認すれば原因が書かれていたりします。
#プラグインの削除
プラグインの削除は削除したいプラグインのプロジェクトをXcodeで開いてプロジェクトをクリーンするか作成されたファイルを直接削除し、Xcodeを再起動すれば削除されるようです。プラグインの影響でXcodeに問題が発生したらこの方法でプラグインを削除してみてください。

プロジェクトのクリーンはメニューの「Product->Clean」を選択(Command+Shift+K)するとクリーンされます。
ファイルの直接削除はプラグインが作成された~/Library/Application Support/Developer/Shared/Xcode/Plug-insディレクトリから削除したいプラグインのディレクトリを削除でOKです。

#コードを解読してみる
プロジェクト名.m(今回はXcodePluginText.m)をみてみると、didApplicationFinishLaunchingNotificationでメニューを追加しているのがわかります。そしてメニューが選択されたらアラートを表示するというすごく簡単なコードです。


- (void)didApplicationFinishLaunchingNotification:(NSNotification*)noti
{
    //removeObserver
    [[NSNotificationCenter defaultCenter] removeObserver:self name:NSApplicationDidFinishLaunchingNotification object:nil];
    
    // Create menu items, initialize UI, etc.
    // Sample Menu Item:
    // メインメニューのEditメニューを取得
    NSMenuItem *menuItem = [[NSApp mainMenu] itemWithTitle:@"Edit"];
    if (menuItem) {
        // メニューに区切りを追加
        [[menuItem submenu] addItem:[NSMenuItem separatorItem]];
        // 新しく「Do Action」というメニューを作成
        NSMenuItem *actionMenuItem = [[NSMenuItem alloc] initWithTitle:@"Do Action" action:@selector(doMenuAction) keyEquivalent:@""];
        //[actionMenuItem setKeyEquivalentModifierMask:NSAlphaShiftKeyMask | NSControlKeyMask];
        [actionMenuItem setTarget:self];
        // 「Edit」のサブメニューとして「Do Action」を追加
        [[menuItem submenu] addItem:actionMenuItem];
    }
    
}

// 追加した「Do Action」メニューが選択されたら呼ばれる
- (void)doMenuAction
{
    // アラートで「Hello, World」を表示
    NSAlert *alert = [[NSAlert alloc] init];
    [alert setMessageText:@"Hello, World"];
    [alert runModal];
}

#コードを変更してみる
今回は16進数のカラーコードからUIColorのコードを生成するプラグインを開発してみました。
###主な変更箇所
####1.メニューのタイトルを変更
「Do Action」を「ConvertUIColor」に変更しただけです。

NSMenuItem *actionMenuItem = [[NSMenuItem alloc] initWithTitle:@"ConvertUIColor" action:@selector(doMenuAction) keyEquivalent:@""];

####2.WindowControllerクラスとxibファイルを作成
スクリーンショット 2015-08-11 2.00.45.png

####3.メニュー選択時のアクションをアラートから2.で作成したWindowControllerを表示に変更

- (void)doMenuAction
{
    // 色変換用のWindowを表示
    self.windowController = [[ConvertColorWindowController alloc] initWithWindowNibName:@"ConvertColorWindowController"];
    [self.windowController showWindow:self.windowController];

}

####4.WindowControllerのボタン押下時の処理を記述
UITextFieldではなくNSTextFieldなのでiOSとは若干の違いがあります。

// 変換ボタン押下時
- (IBAction)convert:(id)sender {
    // 入力された文字列を取得
    NSString* hexString = self.hexTextField.stringValue;
    // 文字列を変換
    NSString* uiColorString = [self stringUIColorFromColorCode:hexString];
    // 出力用のTextFieldに出力
    self.uicolorTextField.stringValue = uiColorString;
}
// クリアボタン押下時
- (IBAction)clear:(id)sender {
    // TextFieldの値をリセット
    self.hexTextField.stringValue = @"";
    self.uicolorTextField.stringValue = @"";
}

/**
 *  16進数の文字列をUIColorに変換
 *
 *  @param colorCode 16進数のカラーコード
 *
 *  @return UIColorの文字列
 */
- (NSString*)stringUIColorFromColorCode:(NSString*)colorCode
{
    // 「#」を取り除く
    NSString* hexString = [colorCode stringByReplacingOccurrencesOfString:@"#" withString:@""];
    // 長さが6未満の場合は空文字を返す
    if (hexString.length < 6) {
        return @"";
    }
    
    // 16進数をintに変換
    unsigned int color[3];
    for (int i = 0; i < 3; i++) {
        NSString *param = [hexString substringWithRange:NSMakeRange(i * 2, 2)];
        NSScanner *scanner = [NSScanner scannerWithString:param];
        [scanner scanHexInt:&color[i]];
    }
    
    // UIColorの文字列に変換
    NSString* uiColorString = [NSString stringWithFormat:@"[UIColor colorWithRed:%f green:%f blue:%f alpha:1.0f]; // #%@",
                               color[0] / 255.0f,
                               color[1] / 255.0f,
                               color[2] / 255.0f,
                               hexString];
    return uiColorString;
}

#できたもの
メニューの「Edit->ConvertUIColor」を選択するとこんな感じでWindowが表示されます。
スクリーンショット 2015-08-11 2.11.30.png
ここに16進数のカラーコードを入力して変換を押すとUIColorの文字列を生成するというものです。(とりあえず作ってみただけなのでダサくて利便性も低いですが・・・)
スクリーンショット 2015-08-11 2.13.35.png

16進数のカラーコードをUIColorのソースコードに変換してくれるWEBサービスもありますが、いちいちブラウザに切り替えるのも面倒ですし、かといってソース内で変換する処理を記述するのは無駄な処理をしている感じがして嫌だったのでプラグインで書いてみました。
ソースコード

#まとめ
今回はメニューに追加して実行するタイプでしたが、いろいろとイベントを受け取って処理をしたりすることもできるのでそのうち受け取れるイベントのまとめやそのイベントを使ったプラグインも作れればいいなと思っています。

Xcodeのプラグイン作成は敷居が高いイメージでしたが、簡単なものであれば意外とすぐに作成できるのでこんな機能がほしい!というのがあれば自分で作ってみてはいかがでしょう?

35
32
0

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
35
32

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?