「Office」のクロスプラットフォーム開発を成功へ--開発者が明かすマイクロソフトの挑戦

Mary Jo Foley (Special to ZDNet.com) 翻訳校正: 石橋啓一郎 2014年10月29日 06時00分

  • このエントリーをはてなブックマークに追加

 「われわれの課題は、どうやって飛行中のジャンボジェットを組み立て直すかだ」

 「Microsoft Office」に取り組むMicrosoftのディスティングイッシュドエンジニアIgor Zaika氏は、同社のOfficeチームが直面する難問をこう説明した。Microsoftは、どのように10億人のOfficeユーザーのサポートを継続し、混乱させないようにしながら、Officeの核となるインフラを再構築して「Windows」以外のOSでも動くようにしたのだろうか。

 Zaika氏は最近、Facebookの@Scaleカンファレンスで、Officeのクロスプラットフォームアーキテクチャ戦略について語ったTwitterユーザーWalking Cat氏の、同氏のプレゼンテーションへのリンクに感謝する)。その50分間のセッションで、Zaika氏はMicrosoftがどのようにC++を使ってOfficeをWindows、Apple、「Android」、ウェブで構築しているかについて詳しく説明した。

 同社が30年前に作り始めたOfficeは、現在では数千万行のコードからなっている。Officeは、Cで書かれた数多くの独立したアプリケーションからスタートした。Microsoftは1990年にこれをひとまとめにしたが、Zaika氏によれば、当時はアプリケーション間で共有されているコードはほとんどなかったという。開発チームは当時、Officeを書き直して、Windows用OfficeとMac用Officeの共通コードベースを作るのが望ましいと考えた(Microsoftは1985年にMac版を別個に発売している)。

 「非常に困ったことに、これはうまくいかなかった」とZaika氏は話す。

 開発チームはWindowsとMacの共通のコードを一部は救い出したが、Macユーザーは、他のMacのアプリケーションとは見た目も動作も異なるOfficeを好まなかった。


 Officeチームは2年前からこの課題に新たな形で取り組んでおり、コードの共有はいいが、共有コードが多すぎるのはよくないと考えているとZaika氏は語った。

 今回、Officeチームは複数の小規模なプラットフォーム抽象化層(PAL)を設計し、サポートするさまざまなOSで、ユーザー体験を実現するコードを、どのように、どの程度共有するかという問題について、賢明な選択をしようとしている。

 社内にはMicrosoftがOfficeのコードベースをフォークさせて、異なるブランチと各OSをサポートする専門のチームを作るべきだと考える者もいたが、Zaika氏によれば、Offceチームは現在このアプローチを採っていない。Microsoftは、1997年にWindowsとMacでOfficeのコードベースを分離した際にこの手法を用いたが、現在はやっていないという。またOfficeチームは、「最小公倍数」的アプローチも選択しなかった。ユーザーは、各OSが持つプラットフォーム独自の機能を、最大限に利用したいと考えているのだ。

 Officeチームはこれを実現しようとしている。同チームは、可能な場合には機械的なリファクタリングを行い、そうでない場合にはユニットテストを行いながら、明確に定義された、組み合わせ可能なコンポーネントを作っている。重視しているのは、すべてのプラットフォームで常にすべてが正常に動作する状態を維持することだと、Zaika氏は言う。開発チームは、どのプラットフォームでもリグレッションを一切許容せず、すべてのプラットフォームに関して、社内で大規模にコードベースのドッグフーディング(訳注:社内で実際に試用させること)を行っている。

ZDNet Japan 記事を毎朝メールでまとめ読み(登録無料)

  • このエントリーをはてなブックマークに追加

この記事を読んだ方に

関連ホワイトペーパー

SpecialPR

連載

CIO
ハードから読み解くITトレンド放談
大木豊成「仕事で使うアップルのトリセツ」
研究現場から見たAI
ITは「ひみつ道具」の夢を見る
内製化とユーザー体験の関係
米ZDNet編集長Larryの独り言
今週の明言
「プロジェクトマネジメント」の解き方
田中克己「2020年のIT企業」
松岡功「一言もの申す」
林 雅之「デジタル未来からの手紙」
谷川耕一「エンプラITならこれは知っとけ」
Fintechの正体
内山悟志「IT部門はどこに向かうのか」
情報通信技術の新しい使い方
三国大洋のスクラップブック
大河原克行のエンプラ徒然
コミュニケーション
情報系システム最適化
モバイル
通信のゆくえを追う
セキュリティ
企業セキュリティの歩き方
サイバーセキュリティ未来考
セキュリティの論点
ネットワークセキュリティ
スペシャル
Gartner Symposium
企業決算
ソフトウェア開発パラダイムの進化
座談会@ZDNet
Dr.津田のクラウドトップガン対談
CSIRT座談会--バンダイナムコや大成建設、DeNAに聞く
創造的破壊を--次世代SIer座談会
「SD-WAN」の現在
展望2017
IBM World of Watson
de:code
Sapphire Now
VMworld
Microsoft WPC
HPE Discover
Oracle OpenWorld
Dell EMC World
AWS re:Invent
AWS Summit
PTC LiveWorx
古賀政純「Dockerがもたらすビジネス変革」
さとうなおきの「週刊Azureなう」
誰もが開発者になる時代 ~業務システム開発の現場を行く~
中国ビジネス四方山話
より賢く活用するためのOSS最新動向
「Windows 10」法人導入の手引き
Windows Server 2003サポート終了へ秒読み
米株式動向
実践ビッグデータ
日本株展望
ベトナムでビジネス
アジアのIT
10の事情
エンタープライズトレンド
クラウドと仮想化