ここでは現在も稼働しているVisualBasic6.0のシステムのリスクと、どのように.NETへ移行したらよいかを考察します。
このドキュメントをPowerPointで表現したものは下記にあります。
http://www.nicovideo.jp/watch/sm22232272
http://needtec.sakura.ne.jp/doc/VisualBasic6system.pdf
VisualBasic6.0を使用し続ける場合のリスク
VisualBasic6.0を使用したリスクには大きくわけて以下のリスクが存在します。
・サポートに関するリスク
・開発要員に関するリスク
サポートに関するリスク
VB6ランタイムはWindows8まで保障されていますが、Grid32.dll,graph32.ocxなどの一部のランタイムは非サポートになりました。
IDE(統合開発環境)はWindows7以降で非サポートです。実験結果として動作するという報告はありますが、あくまで非サポートです。
WindowsVista,WindowsServer2008,Windows7,Windows8に関するVisualBasicのサポート状況は下記を参考にしてください。
http://msdn.microsoft.com/ja-jp/vstudio/ms788708.aspx
開発環境が非サポートになったということは、サードパーティが提供するOCX,DLLのサポート状況が不透明になります。
マイクロソフトがVB6の開発環境を非サポートにしている状況で、サードパーティが、OCXやDLLのサポートを続けるとは考えづらいです。
また、64ビットプロセスのサポートも行いません。
64ビットマシンであっても32ビットプロセスとして動作することを義務付けられます。このことはプロセスのメモリの上限が最大4Gになることを意味しており、どんなにメモリを積んだとしてもそれ以上のメモリを1プロセスで使用することができなくなります。
開発要員のリスク
今後はVisualBasic6.0の開発要員を確保しづらくなることが予想されます。
以下の図は2012/4/27にIPA独立法人情報処理推進機構が発表した、ソフトウェア産業の実態把握に関する調査の結果です。
これは新規で人手で作成したプログラミング言語の比率をあらわします。
VB6はCOBOLの0.4%以下のその他に分類されています。
このことより、新規案件でVisualBasic6.0が採用されていないことを表します。
このことにより、新規に業界に入った人間は、VisualBasic6.0を扱うことが少なくなることになります。つまり、VisualBasic6.0を扱える人材の年齢が上がっていくことになり、これは単価の上昇を意味します。
このことより、将来、安価な労働力の確保ができなくなることが想像できます。
対応策
VisualBasic6.0でシステムを開発し続けることにはいくつかのリスクがあることを説明しました。
ここでは、今後どのようにすべきかを考察します。
考えるられる方法として3つの方法が存在します。
・リスクを把握した上で使い続ける
・.NETに移行する
・新規機能のみ.NETに置き換える
リスクを把握した上で使い続ける
OSのバージョンアップやWindows Updateを行わない前提であれば可能な選択肢です。
たとえば、工場の機械を制御するシステムのように、インターネットにつながず、他のOfficeなどのアプリケーションを使用しない閉じた環境であれば、OSのバージョンアップやWindowsUpdateなどのセキュリティを考慮しないですむので、VB6を使い続けることができるかもしれません。
ただし、更新しないつもりでも、マシンが壊れて新しいマシンを入れる場合に古いOSを入手できないというリスクや、和暦をつかっている場合は元号が変わった場合にOSに対してなんらかのパッチを当てなければならないリスクが存在します。
.NETに移行する
これはMicrosoftが推奨している方法で技術的には正しい選択肢でしょう。
しかし、コストの問題が発生します。
VB6のソースコードから.NETのソースコードに変換する、コンバートツールは存在しますが、その精度は低く、最終的には人間が確認する必要があります。
仮にうまくいっても全テストを実施しなければなりません。
潤沢な予算がなければ選択するのは難しいでしょう。
新規機能のみ.NETにおきかえる
上記2案の折衷案です。
現状のコードをなるべくいじらずにいかしつつ、問題が発生した箇所や、新規機能を.NETに置き換えていきます。
これにより、段階的な.NETへの移行作業を行えます。
基本的にはCOMで.NETの機能をラップしてVBから使用します。
.NETでCOMを作成する方法については以下と同様の手順で作成することができます。
VBAまたはVBSからCOM経由で使用できる.NETのライブラリの作成方法
http://qiita.com/mima_ita/items/efcd1a6ea86f09047984
もし、フォームやコントロールを作成する必要がある場合、Microsoftより提供されているInterop Forms Toolkit を利用すれば、.NETで作成したコントロールやフォームをCOM経由でVBから使用することが簡単になるでしょう。
Interop Forms Toolkit 2.0 Tutorial
http://www.codeproject.com/Articles/18954/Interop-Forms-Toolkit-2-0-Tutorial
http://www.microsoft.com/en-us/download/details.aspx?id=3264
Windows7 + VB2008.NETでのInterop Forms Toolkitの使用方法
COMの作成方法
以下でInterop Forms Toolkitを使用してVB2008.NETのCOMを作成してみます。
1.Interop Forms Toolkitをインストールして、管理者権限としてVisualStudioを起動します。これはCOMの登録に管理者権限が必要だからです。
2.新規プロジェクトで[VB6 Interop UserControl]のテンプレートを選択します。
3.テンプレートを選択してプロジェクトを作成すると、VBB.NETでCOMのコントロールやインターフェイスを実装できるようになります。
4.VB6から使用したい機能をCOM参照可能なクラスのCOM参照可能なパブリックプロシージャとして実装してください。
5.実装が終わり、ビルドを行う時に、COMとして登録されるように、プロジェクトの設定で「COM相互運用機能の登録」を選択してください。
もし、VisualStudioのない環境でCOMを登録するにはRegasmコマンドを使用します。
Regasm AssemblyName.dll /tlb: FileName.tlb /codebase
http://support.microsoft.com/kb/817248/ja
COMの使用方法
1.VB6やVBAでCOMを使用するには「参照設定」で作成したDLLを選択します。
コントロールとして使いたい場合は、ツールボックスから、その他のコントロールで追加できます。
2.VB6やVBA側でオブジェクトを作成して使用することが可能になります。
デバッグの方法
デバッグの方法としてはCOMを実装したソリューションにテストようのプロジェクトを追加してそこで単体テストをすると楽です。
同じソリューションであれば、ブレイクやウォッチが使用できてデバッグが楽です。
あるいは、VisualStudioでVB6.0で作成したプロセスにアタッチすることで、.NETで作成したCOMのデバッグが行えます。
VB6.0側と.NET側のどちらにバグの原因があるかわからない場合はこの方法がよいでしょう。
注意点
Interop Forms Toolkit2.1を動かした際に気になった点を以下に示します。
・Interop Forms Toolkit 2.1インストール時にHelp Fileのショートカットがプログラムファイルに作成できない場合がある。(インストールは正常にできる)
VB6で32bitを超えるメモリ空間にアクセスしたい場合
1プロセスではむりです。
.NETで64ビットのアウトプロセスのCOMサーバを作成して、別プロセスとして独立させ、それをVB6から操作してください。
.NETにおける64ビットプロセスと32ビットプロセスについて
http://qiita.com/mima_ita/items/57d7c1101543e214b1d6
まとめ
このようにCOMを利用することで一部の機能の.NET化を行うことができるので、移行の作業量を抑えながら,段階的な.NETへの移行が可能になります。
なお、COMから.NETを使用する場合、.NET フレームワークをCOMを使用する際に読み込むのでVB6.0単体の時より起動時間が掛かる可能性があるので注意してください。
参考
Windows Vista、Windows Server 2008、Windows 7、および Windows 8 に対するVisual Basic 6.0 のサポートに関する声明
http://msdn.microsoft.com/ja-jp/vstudio/ms788708.aspx
Visual Basic 6.0 から Visual Basic .NET または Visual Basic 2005 アセンブリを呼び出す方法
http://support.microsoft.com/kb/817248/ja
COM 相互運用 (Visual Basic)
http://msdn.microsoft.com/ja-jp/library/6bw51z5z.aspx
Yuya Yamaki’s blog Microsoft InteropForms Toolkit 1.0
http://d.hatena.ne.jp/Yamaki/20061101
Interop Forms Toolkit 2.0 Tutorial
http://www.codeproject.com/Articles/18954/Interop-Forms-Toolkit-2-0-Tutorial