Apex コードのバージョン設定
パッケージ開発者は条件付きロジックを Apex クラスとトリガで使用し、異なるバージョンに異なる動作をさせることができます。こうすることで、パッケージ開発者は、コード開発を続けながら以前のパッケージバージョンのクラスとトリガでの既存の動作をサポートし続けることができます。
登録者が、複数のバージョンのパッケージをインストールし、パッケージ内の Apex クラスまたはトリガを参照するコードを記述する場合、参照しているバージョンを指定する必要があります。パッケージ内で参照している Apex コード内で、参照を作成する Apex コードのコールのバージョン設定に基づき、異なるコードパスを条件付きで実行できます。コール元のコードのパッケージバージョン設定は、パッケージコード内で System.requestVersion メソッドをコールすることによって判断できます。こうすることで、パッケージ開発者は、要求コンテキストを決定し、さまざまなバージョンのパッケージに異なる動作を指定することができます。
次の例は、異なるパッケージバージョンのトリガのさまざまな動作を示しています。
1trigger oppValidation on Opportunity (before insert, before update) {
2
3 for (Opportunity o : Trigger.new){
4
5 // Add a new validation to the package
6 // Applies to versions of the managed package greater than 1.0
7 if (System.requestVersion().compareTo(new Version(1,0)) > 0) {
8 if (o.Probability >= 50 && o.Description == null) {
9 o.addError('All deals over 50% require a description');
10 }
11 }
12
13 // Validation applies to all versions of the managed package.
14 if (o.IsWon == true && o.LeadSource == null) {
15 o.addError('A lead source must be provided for all Closed Won deals');
16 }
17 }
18}Apex クラスのさまざまなバージョンを比較するには、クラスの詳細を表示しているときに [Class Definition (クラス定義)] タブをクリックします。
System.requestVersion メソッドについての詳細は、『Force.com Apex コード開発者ガイド』を参照してください。