楽々フレームワークで楽をする【前編】
1980年代のはじめは、パソコンを使うことはBASIC言語で自分でプログラムを書くことを意味しました。日本語で使える業務パッケージは、まだ普及していませんでした。Apple IIで動作する世界初の表計算ソフトである「ビジカルク」が発売されたのは、1979年のことです。先日キーエンスの資本傘下になったジャストシステムが、PC-9801用の「一太郎」を発売したのが、1985年5月です。
当時は「ASCII」「I/O」「RAM」といったパソコン月刊誌に、毎月のようにプログラムのリストが掲載されて、パソコンマニアはそれをパソコンに打ち込みながら、プログラミングを覚えました。私はその頃からパソコンに興味を持っていて、当然のようにBASICプログラマーになりました。
1980年代後半にはUNIXとC言語を覚えて、アスキーでリレーショナルデータベースInformixのソースコードを日本語が使えるように修正する仕事をしていました。INFORMIX社が第4世代言語「Informix-4GL」を出してからは、社内の業務アプリケーションを4GLで書くようになりました。
業務用のアプリケーションは、データベースのテーブルを中心に、画面とCRUD処理で構成されるのが基本です。プログラミングは一定のパターンがあります。しかし、テーブルが異なれば、各テーブルに合わせてそれぞれ個別にプログラミングしなければいけません。
しばらくするうちに、似て非なるプログラムを毎回一つ一つ書いていくことに飽きてしまいました。ちょうどその頃、Informix-4GLで使えるCASEツールとして、米国から「FourGen CASE Tools」が入ってきました。FourGenは、Informix-4GLのソースコードを生成するソースコードジェネレータでした。(そういえば、CASEツールは死語でしょうか。)
私はFourGenにインスパイアされて、自分が作りたい業務プログラムを生成するInformix-4GLのアプリケーションを開発しました。データベースのテーブル定義を読み取って、基本的な画面とCRUD処理を自動生成する「4GLのプログラムを書く4GLのプログラム」です。これなら生成されたプログラムを少し手直しするだけで、完成させることができます。このツールを使うようになってから、生産性は飛躍的に向上しました。この時から「プログラムを書くプログラム」に興味を持つようになりました。
それから10年を経て、再びプログラムでプログラムを作ることになりました。
コマーシャルオープンソースのCRMアプリケーション、SugarCRMはPHP言語で書かれています。業務に必要な一通りの機能を備えていますので、ほとんどの場合はそのまま使えます。ただ、業務要件によってはモジュールを新規で作る場合があります。(注 SugarCRMは、取引先、取引先担当者、商談、見積などのモジュールで構成されます。モジュールはデータベースのテーブルとそのアプリケーションのセットとお考えください。)
SugarCRMに自分で開発したモジュールを追加する場合、約40ファイルのSugarCRMの作法に従ったPHPのソースコードを用意する必要がありました。実際の案件でお客様のご要望に合わせたモジュールを、一つ一つ手作業で開発するのは効率が悪いです。
私は、SugarCRMのモジュールの仕組みを解析して、作法に合わせたPHPのソースコードを自動生成するプログラムを書きました。商品名を「CandyPotモジュールビルダー」と名付けて、正式に売り出しました。
CandyPotを使えば、開発者は専用のExcelシートに新規モジュールのデータ構造を記入するだけです。後は、CandyPotが新規モジュールのソースコードを自動生成します。数十ファイルが一瞬で生成されて、そのまま動く完成品になります。
CandyPotで作ったモジュールは、SugarCRMからは既存のモジュールと全く等価に見えます。必要があれば、SugarCRMのカスタマイズツールをそのまま使えます。また、手で細かいカスタマイズをすることもできます。自分で言うのも何ですが、非常に気分爽快でクールなツールでした。
私は、CandyPotは以下のような役割の人におススメしたいと考えていました。
- プリセールス:
お客様の要件に合わせたデモを営業段階で実際に動かして見せることで、成約の可能性が高まります。 - プロジェクトマネージャ:
プロジェクトのプロトタイピングのツールとして利用できます。
複数のプログラマーによるプログラミングのスタイル・品質のバラツキをなくし、一定のスタイルと品質で管理できます。将来、プログラマーが異動してもソースコードのメンテナンスが容易です。 - プログラマー:
SugarCRM独特のフォルダ・ディレクトリ構造やプログラミングの決まりに合わせたテンプレートを短時間で作成できます。
タイプミスによるバグは基本的になくなります。より高度なカスタマイズのために時間を有効に使えます。
CandyPotはたいへんニッチなツールでしたが、ありがたいことに買っていただけるお客様がいて売れました。また、ケアブレインズ(現オープンソースCRM)経由で、米国でも売れました。少なからぬ売上になっただけでなく、クールなプログラムを書けば海外でも売れることがわかったことは収穫でした。
CandyPotの成功で、「プログラムを書くプログラム」への関心はますます高くなりました。
そして、先日出会ったのが、住友電工情報システム株式会社のJava開発ツール「楽々Framework II」です。
(後半に続く)