CoffeeScript
GoLand では、JavaScript にコンパイルされる CoffeeScript を使用できます。 GoLand は *.coffee ファイルを認識し、それらに のマークを付けます。 CoffeeScript コードに直接ブレークポイントを設定でき、GoLand はコンパイル時に生成されたソースマップを使ってそれらを認識します。
GoLand は、キーワード、ラベル、変数、パラメーター、関数の補完を提案することで、CoffeeScript コードの作成を支援します。 シンボルから宣言 Ctrl+B または実装 Ctrl+Alt+B に移動したり、名前 Ctrl+Alt+Shift+N のシンボルを検索したりできます。
GoLand は、CoffeeScript コードを JavaScript に変換する coffeescript コンパイラーと統合しています。 このツールは、CoffeeScript コードと生成された JavaScript コードの行間の対応を設定する ソースマップも作成するため、GoLand のデバッガーは CoffeeScript コードのブレークポイントを認識して正しく処理します。
始める前に
Node.js をダウンロードしてインストールします。
JetBrains マーケットプレイスからプラグインをインストールする説明に従って、 設定 | プラグイン ページの マーケットプレース タブに CoffeeScript プラグインをインストールして有効にします。
設定で File Watchers プラグインが有効になっていることを確認します。 Ctrl+Alt+S を押して設定を開き、 を選択します。 インストール済み タブをクリックします。 検索フィールドに File Watchers と入力します。 プラグインの詳細については、 プラグインの管理を参照してください。
CoffeeScript を JavaScript にコンパイルする
コードを自動的にコンパイルするには、ファイルへの変更を追跡してコンパイラーを実行する CoffeeScript ファイルウォッチャーを構成する必要があります。
ファイルを開くと、GoLand は現在のプロジェクトで該当するファイルウォッチャーが利用可能かを確認します。 そのようなファイルウォッチャーが設定されているが無効の場合、GoLand は構成済みのファイルウォッチャーについて通知し、有効化を提案するポップアップを表示します。
現在のプロジェクトで該当するファイルウォッチャーが構成され有効化されている場合、GoLand は New Watcher ダイアログで指定されたイベントが発生すると自動的にコンパイラーを起動します。
編集したファイルを自動保存してウォッチャーをトリガーする チェックボックスが選択されている場合、ソースウォッチに変更が加えられるとすぐに File Watcher が呼び出されます。
編集したファイルを自動保存してウォッチャーをトリガーする チェックボックスがオフの場合、保存時(、 Ctrl+S )または GoLand からフォーカスを移動したとき(フレームの非アクティブ化時)にファイルウォッチャーが開始されます。
詳しくは File Watchers をご覧ください。
コンパイラーは生成された出力を別のファイルに保存します。 ファイル名はソースファイル CoffeeScript と同じで、コンパイラーの種類に応じて拡張子は .js または .js.map となります。 生成されたファイルの場所は、 リフレッシュする出力パス フィールドがある New Watcher ダイアログで定義されます。 この設定に基づいて、GoLand はコンパイラーの出力を検出します。 ただし、 プロジェクト ツールウィンドウ (Alt+1) では、ソースファイル coffee に表示され、ソースファイルはノードとして表示されます。
CoffeeScript コンパイラーをインストールする
埋め込まれた ターミナル (Alt+F12 )で、次のいずれかのコマンドを入力します。
グローバルインストール用の
npm install --global coffeescriptCoffeeScript を 開発依存関係(英語)としてインストールする
npm install --save-dev coffeescriptCoffeeScript 公式 Web サイト(英語)の詳細を参照してください。
CoffeeScript ファイルウォッチャーを作成する
Ctrl+Alt+S を押して設定を開き、 を選択します。
をクリックするか、 Alt+Insert を押して、リストから CoffeeScript 定義済みテンプレートを選択します。 コードは JavaScript に翻訳され、生成された ソースマップ(英語)とともに提供されます。
File Watchers に記載されている手順に従ってください。
コンパイラーの動作をカスタマイズする
GoLand を使用すると、コマンドラインモードでの作業時と同様に引数を渡すことでコンパイラーを調整できます。 以下は、 CoffeeScript コンパイラーのデフォルトの出力場所をカスタマイズする例です。
次のフォルダー構造を持つプロジェクトがあるとします:

デフォルトのファイルウォッチャーでは、生成されたファイルは元のファイルの子として表示されます。

このデフォルトの場所を変更して、生成されたファイルを別の JavaScript フォルダーに保存することができます。
生成されたすべてのファイルを出力 JavaScript フォルダーに保存する
CoffeeScript ファイルウォッチャーを作成します。

引数 フィールドに入力します:
--map --compile -o $ProjectFileDir$/JavaScript $FileName$リフレッシュする出力パス フィールドに入力します:
$ProjectFileDir$/JavaScript/$FileNameWithoutExtension$.js:$ProjectFileDir$/JavaScript/$FileNameWithoutExtension$.map:$FileNameWithoutExtension$.js.map
その結果、プロジェクトツリーは次のようになります:

生成されたファイルを、 app ノードの元の構造を繰り返すフォルダー構造に格納することもできます。
出力フォルダーに元のフォルダー構造を保持する
CoffeeScript ファイルウォッチャーを作成します。
引数 フィールドに入力します:
--map --compile -o $ProjectFileDir$/JavaScript/$FileDirRelativeToProjectRoot$ $FileName$リフレッシュする出力パス フィールドに入力します:
$ProjectFileDir$/JavaScript/$FileDirRelativeToProjectRoot$/$FileNameWithoutExtension$.js:$ProjectFileDir$/JavaScript/$FileDirRelativeToProjectRoot$/$FileNameWithoutExtension$.map:$FileNameWithoutExtension$.js.map
その結果、プロジェクトツリーは次のようになります:

コンパイラーを実行せずにコンパイル結果をプレビューする
GoLand は実際にコンパイラーを実行せずに CoffeeScript コードの静的解析を行い、専用の読み取り専用ビューアーで予測されるコンパイル出力を表示できます。
エディターで目的の CoffeeScript ファイルを開き、エディターの背景を右クリックします。
コンテキストメニューから を選択します。 プレビューは専用の読み取り専用ビューアーで開きます。左ペインに元の CoffeeScript ソースコード、右ペインにコンパイラーが実行時に生成する JavaScript コードが表示されます。
CoffeeScript の実行
GoLand で CoffeeScript を実行する方法は 2 つあります:
CoffeeScript コードを手動でコンパイルし、出力された JavaScript コードを Node.js アプリケーションのように実行します。
元の CoffeeScript コードを Node.js 実行構成で実行し、GoLand にオンザフライでコンパイルさせます。
CoffeeScript を手動でコンパイルし、生成された JavaScript コードを実行する
Node.js の実行構成の作成を開始するを次の必須設定で使用します。
使用する Node.js エンジン。 デフォルトでは、このフィールドには Node.js 構成時に JavaScript ランタイムページで指定したランタイムへのパスが表示されます。
作業ディレクトリ フィールドには、起動する CoffeeScript ファイルから参照するファイルの場所を指定します(例: includes)。 このファイルが他のファイルを参照していない場合は、フィールドを空のままにしてください。
ノードアプリケーション JS ファイルへのパス フィールドに、コンパイル中に元の CoffeeScript ファイルから生成された JavaScript ファイルへの絶対パスを指定します。
設定を保存し、ダイアログで 実行 をクリックします。
あるいは、メインツールバーのリストから新しく作成した実行構成を選択し、
をクリックします。
Node.js アプリケーションの実行の間に進みます。
実行中にオンザフライで CoffeeScript をコンパイルする
このモードでは、
coffeescriptパッケージの一部である register.js ファイルがプロジェクト内にある必要があります。エディターで開始用の CoffeeScript ファイルを開くか、 プロジェクト ツールウィンドウ (Alt+1) でファイルを選択し、コンテキストメニューから を選択します。 GoLand は、自動生成された実行/デバッグ構成でファイルを実行します。
または、コンテキストメニューから を選択し、開いた 実行/デバッグ構成:Node.jsダイアログで次の必須設定を確認します:
使用する Node.js ランタイム。 適切なランタイム構成を選択するか、新しい構成を作成してください。 デフォルトでは、このフィールドには Node.js 構成時に JavaScript ランタイムページで指定したランタイムへのパスが表示されます。
Linux および macOS では、この設定は CoffeeScript コンパイラー実行可能ファイルへのパスの Node.js でオーバーライドされます。
「ノード パラメーター 」フィールドに
--require coffeescript/registerと入力します。作業ディレクトリ フィールドで、アプリケーションの 作業ディレクトリ(英語)を指定します。 デフォルトでは、フィールドには プロジェクトのルートフォルダーが表示されます。
ファイル フィールドで、実行する CoffeeScript ファイルへのフルパスを指定します。
設定を保存し、ツールバーの
をクリックします。
あるいは、メインツールバーのリストから新しく作成した実行構成を選択し、
をクリックします。
Node.js アプリケーションの実行の間に進みます。
CoffeeScript のデバッグ
GoLand で CoffeeScript をデバッグするには、JavaScript コードに加えて ソースマップ を生成する必要があります。 ソースマップは CoffeeScript コードと生成された JavaScript コードの各行の対応付けを設定します。そうしないとブレークポイントが正しく認識・処理されません。 JavaScript およびソースマップは、 CoffeeScript タイプのファイルウォッチャーを使って CoffeeScript コードを手動でコンパイルすることで生成されます。 その後、出力された JavaScript コードを Node.js アプリケーションのようにデバッグできます。
CoffeeScript のデバッグは、 ローカルモードでのみサポートされています。 これは、GoLand が実行構成に従い Node.js エンジンとターゲットアプリケーションを起動してセッションを完全に制御することを意味します。
Node.js アプリケーションのデバッグの詳細については、「Node.js の実行とデバッグ 」を参照してください。
CoffeeScript コードをデバッグする
必要に応じて CoffeeScript コードに ブレークポイント を設定します。
タイプ CoffeeScript の File Watcher を使用する CoffeeScript コードを Javascript にコンパイルします。
Node.js の実行構成の作成を開始するを次の必須設定で使用します。
使用する Node.js エンジン。 デフォルトでは、このフィールドには Node.js 構成時に JavaScript ランタイムページで指定したランタイムへのパスが表示されます。
作業ディレクトリ フィールドには、起動する CoffeeScript ファイルから参照するファイルの場所を指定します(例: includes)。 このファイルが他のファイルを参照していない場合は、フィールドを空のままにしてください。
ノードアプリケーション JS ファイルへのパス フィールドに、コンパイル中に元の CoffeeScript ファイルから生成された JavaScript ファイルへの絶対パスを指定します。
設定を保存し、ツールバーの
をクリックします。
構文ハイライトの構成
好みや習慣に合わせて、CoffeeScript 用の構文ハイライトを設定できます。
設定 ダイアログ(Ctrl+Alt+S )で に移動します。
カラースキームを選択するか、デフォルトから継承されたハイライト設定を受け入れるか、 色とフォント で説明されているようにカスタマイズします。