JP6494610B2 - コードの仮想化およびリモートプロセスコール生成のための方法および装置 - Google Patents

コードの仮想化およびリモートプロセスコール生成のための方法および装置 Download PDF

Info

Publication number
JP6494610B2
JP6494610B2 JP2016521518A JP2016521518A JP6494610B2 JP 6494610 B2 JP6494610 B2 JP 6494610B2 JP 2016521518 A JP2016521518 A JP 2016521518A JP 2016521518 A JP2016521518 A JP 2016521518A JP 6494610 B2 JP6494610 B2 JP 6494610B2
Authority
JP
Japan
Prior art keywords
remote
code
sdk
snippet
user device
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2016521518A
Other languages
English (en)
Other versions
JP2016525742A (ja
Inventor
トリサラ・チャンダリア
ジャン−バティスト・レオネリ
Original Assignee
チャンベッラ・リミテッド
トリサラ・チャンダリア
ジャン−バティスト・レオネリ
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by チャンベッラ・リミテッド, トリサラ・チャンダリア, ジャン−バティスト・レオネリ filed Critical チャンベッラ・リミテッド
Publication of JP2016525742A publication Critical patent/JP2016525742A/ja
Application granted granted Critical
Publication of JP6494610B2 publication Critical patent/JP6494610B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • G06F9/45516Runtime code conversion or optimisation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/31Programming languages or programming paradigms
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/34Graphical or visual programming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/547Remote procedure calls [RPC]; Web services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/34Network arrangements or protocols for supporting network services or applications involving the movement of software or configuration parameters 

Description

本発明の実施形態は、一般的に、プロセスコールコード生成のための方法およびシステムに関する。
コンピュータプログラミング言語の発達および統合により、既存の言語の多くの能力が拡張されてきた。各言語には、プラットフォームおよびデバイス内でそれぞれのサイズ、実行速度、および様々な機能に関して特定の長所および欠点がある。したがって、一部の特定の言語は、対応するデバイスのみで機能するように作られており、ユーザは、多くの場合、複数のプログラミング言語に慣れているか、またはさらには専門家である必要がある。さらに、最近のアプリケーションの構築の性質により、開発者は複数の言語を学習することを強いられてきた。そのようなことから、アプリケーションを記述するということは、もはや1つのプログラミング言語の使用に制限されるものではない。複数の言語を統合および学習することは困難な負担であり、プログラマ/開発者が十分なコーディング熟達度に到達するために、多くの場合、数か月または数年間のトレーニングを必要とする。
アプリケーションは様々な言語から構成され得、サーバ上で展開される場合、プログラマは、フロントエンド言語、サーバ言語、およびバックエンド言語を学習する必要がある。フロントエンド技術は、また、複数の異なる言語(HTML、Javascript(登録商標)など)から作られていて、プログラミングをさらに複雑にしている。
さらに、より多くの計算が、ネットワークおよび/またはインターネットを通じて発生し(すなわち「クラウドコンピューティング」)、様々なソフトウェア開発キット(SDK)およびアプリケーションプログラミングインターフェース(API)を用いたプログラミングが、開発者にとって厄介な必要事項となっている。ソーシャルメディア(ツイッター、フェイスブックなど)、データストレージ(ドロップボックス、クラウドドライブなど)、および金融取引(ペイパル、アマゾン、EBAYなど)などの新しいサービスも、プログラマへのプログラム負担を増やしている。その理由は、各サービスは、サービスによって提示されるプロセスを実装するために、それ自身のSDKまたはAPIを必要とする場合があるためである。たとえば、ツイッターでツイートするには、TUMBLRに写真を投稿するのとは異なるコードベースを必要とする。また、サービスにおいてアプリケーションが展開された後まで、これらのサービスの使用法が好都合に示されないこともあり、そのことも回復不能な結果につながる可能性がある。言い換えると、リモートサービスの付随するSDKおよびAPIを理解しながら、複数のプラットフォーム、言語、およびサービスを横断するプログラミングは、学習するのが非常に複雑な状態である。
したがって、当技術分野において、ローカルおよびリモートのプログラミング環境を統合する必要がある。
本発明の実施形態は、一般的に、コードの仮想化およびリモートプロセスコール生成のための方法、装置、およびシステムに関する。具体的には、リモートサーバに配置された、事前生成されたコードライブラリ、仮想化されたSDK、およびスニペットジェネレータを利用することによって、ユーザデバイスのプログラムは、複数のプラットフォームおよびプログラミング言語を横断して複数のサービスを活用する。ユーザデバイスは、特許請求の範囲により完全に説明するように、図の少なくとも1つに関して図示および/または記述したように、リモートサーバ上で少なくとも1つのリモートプロセスコールを実行し、また次に、本質的に、異なるリモートサーバのネイティブ言語でプロセスを展開するために、コードスニペットおよび/または仮想化されたSDKを受信する。
本開示のこれらおよび他の特徴および利点は、全体を通じて同様の参照番号は同様の部分を示している添付の図とともに、本開示の以下の詳細な説明を検討することから理解され得る。
本発明の上に詳しく述べられた特徴が詳細に理解され得る方法、上に要約された、本発明のより特定の記述は、実施形態を参照することによって得られ、その一部は添付された図に示されている。しかし、添付された図は、本発明の典型的な実施形態を示しているにすぎず、したがって、その範囲を制限するものと考えるべきではなく、本発明は、他の同様に効果的な実施形態を認めるものであることに留意されたい。
本発明の1つまたは複数の例示的な実施形態によるコード仮想化システムを示す図である。 本発明の1つまたは複数の例示的な実施形態によるコード仮想コードプロバイダ(VCP)を使用する、クラウドクライアントとインターフェースがとられる従来型の(classical)サービス構成要素を実行するためのプラットフォームを示す図である。 本発明の1つまたは複数の例示的な実施形態による総合開発環境とインターフェースをとる、図2に開示された仮想コードプロバイダを使用する全体的な方法を示す図である。 本発明の1つまたは複数の例示的な実施形態によるプロセスコールスニペットを作成する方法を示す流れ図である。 本発明の1つまたは複数の例示的な実施形態による追加のリモートプロセスを用いるローカル開発環境を拡張するための方法を示す流れ図である。 本発明の1つまたは複数の例示的な実施形態による様々なプログラミング言語のための仮想化されたプロセスコールコードジェネレータの方法を示す流れ図である。 本発明の1つまたは複数の例示的な実施形態による例示的なコンピューティングサーバ内のモジュールを示すブロック図である。
記述された以下の実施形態では、「プロセス」は、実行コンピュータ(たとえば、サーバ、パーソナルコンピュータ、モバイルデバイスなど)にすでに格納されている、すぐに実行可能なコードベースまたは事前生成されたプロセスコードを表すものとする。各プロセスは、総合開発環境(IDE)のユーザに対して、名前、プロセスID、アイコン、または他の識別子によって一意に識別される。「実行」は、コンピュータ(ローカルもしくはリモート、またはクラウドベース)上のプロセスの開始を表すものとする。「バンドル」は、共通する属性(API名、共通のパラメータ、SDK、パラメータ名など)によって整理されたプロセスまたは機能の集合を表すものとする。「スニペット」は、リモートプロセスを呼び出すためにユーザによって選択された対応するプログラミング言語を用いてプログラムに挿入されるカスタマイズされたコードの生成されたブロックを表すものとする。多くの場合、選択された言語は、ユーザデバイスのアプリケーションおよび/またはIDEに実装されるためにユーザによって指定されたプログラミング言語のものである。
本明細書に開示された実施形態は、リモートサーバ(たとえば「クラウド」)のコードライブラリに関し、ユーザは、プロセスをリモートから選択し、次いで、ローカルアプリケーションまたはソフトウェアプログラムからプロセスにアクセスするために、対応するスニペットおよび/またはSDKをダウンロードすることができる。スニペットは、リモートサーバ上のリモートプロセスコールが、サーバ上のプロセスを実行すること、または異なるリモートサーバまたはリモートでプロセスを展開することを可能にする。スニペットが実行コンピュータ上のリモートプラットフォームと通信できるように、ユーザデバイスは仮想化されたSDKを使用する。リモートプラットフォームは、追加的なサービスの仮想化された構成要素(たとえば、コンパイラ、電子メール、アマゾン、ツイッター、EBAY、ドロップボックスなど)とともに、サービスに対する対応するSDKおよびAPIを含む。コンピューティングプラットフォームは、ハードウェアアーキテクチャおよびソフトウェアフレームワーク(アプリケーションフレームワークを含む)を含み、組合せによりソフトウェアの実行が可能になる。典型的なプラットフォームは、コンピュータアーキテクチャ、オペレーティングシステム、およびランタイムライブラリを含む。
典型的なSDKは、プログラマがソフトウェアパッケージ、ソフトウェアフレームワーク、ハードウェアプラットフォーム、コンピュータシステム、ビデオゲーム機、オペレーティングシステム、または同様の開発プラットフォームのためのアプリケーションを開発するのに役立つであろう多数のツール、ライブラリ、文書、およびサンプルコードを含む。APIは、相互に通信するためにプログラムが従うべきルールの組を規定している。ルールは、2つのアプリケーションが相互に通信するために、ルーチン、データ構造などがどのように規定されるべきかを指定している。APIは、ソフトウェアプログラムが相互に対話することを可能にするインターフェースである一方、SDKは、特定のプラットフォームを対象とするソフトウェアアプリケーションを開発するために使用され得るツールの組である。一部の例では、SDKはAPIを含む場合がある。
図1は、本発明の1つまたは複数の実施形態によるコード仮想化システム100を示す図である。システム100は、少なくとも1つのユーザデバイス(102a…102n)、ネットワーク110、および少なくとも1つのリモートサーバ(104a…104n)を含む。少なくとも1つのユーザデバイス(102a…102n)は、パーソナルコンピュータ、サーバ、仮想サーバ、マイクロコントローラ(MCU)およびコントローラ、センサ、アクチュエータ、ゲートウェイに接続されたエッジデバイス、特定用途向け集積回路(ASIC)、マイクロプロセッサおよびプロセッサ、セル式電話、スマートフォン、タブレット、ラップトップなどプログラムを格納および実行できる電子デバイスを含む。
各ユーザデバイス(102a…102n)は、少なくとも1つのリモートサーバ(104a…104n)に接続するために、ネットワーク110に接続および認証するのに必要なコードを格納する対応するメモリ(112a…112n)を含む。一部の実施形態では、メモリ(112a…112n)は、少なくとも1つのリモートサーバ(104a…104n)からスニペットを受信および展開するためのIDEを格納する。
ネットワーク110は、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)、ワイヤレスローカルエリアネットワークWLAN、セルラーネットワーク、Wi-Fi、インターネット、またはイントラネットネットワークなど、有線および/または無線のネットワークの少なくとも1つまたは組合せを含むことができる。少なくとも1つのリモートサーバ(104a…104n)は、リモートアプリケーションサーバ、ウェブサーバ、メールサーバ、ホストサーバ、データベースサーバ、ストレージサーバなどを含むことができる。少なくとも1つのリモートサーバ(104a…104n)は、プラットフォーム120を格納し、SDKジェネレータ122、スニペットジェネレータ124、および実行エンジン126を通じてなど特定のプロセスコールを実行するために、メモリ(114a…114n)を含む。一部の実施形態では、スニペットジェネレータ124は、また、ユーザデバイス(102a…102n)でのローカルスニペット生成のためにユーザデバイス(102a…102n)に格納され得る。メモリ(114a…114n)は、また、ネットワーク110上で他のサーバ104n(たとえばフェイスブック、ツイッター、電子メール、SMS、MMS、FTPなど)を横断してプロセスをリンクおよび実行するために、ユーザインターフェースモジュール、ユーザプロフィール/アカウントのデータベース、プロセスの集合、SDK、および関連するパラメータを格納することができる。
実行エンジン126は、呼び出された、識別されたルーチンを相関させ、コールパラメータを使用してプロセスを実行する(running/executing)ことによって、ライブラリのルーチンへのコールを処理する。一部の実施形態では、実行エンジン126は、別のプロセスコールまたはオリジナルのプロセスコールに出力を送ることができる。
一部の実施形態では、プロセスコールパラメータは、ユーザデバイス102aまたはリモートサーバ104aのいずれかに格納される。他の実施形態では、プロセスコールのパラメータは、グラフィカルユーザインターフェースで指定されたユーザに提示される事前生成され事前定義されたフィールドを介してユーザによって直接的に指定される。一部の実施形態では、グラフィカルユーザインターフェースは、IDEの一部である。IDEは、ユーザデバイス102aでユーザに選択されたプログラミング言語のプログラムへの統合のためにリモートサーバ104aによって生成されたスニペットを利用する。
一部の実施形態では、IDEは、また、追加的なプロセスを展開し、他のサーバ104n上で提示されたサービスにアクセスするために、サーバ104a上でスニペットを使用して、リモートプロセスコールを実行する。実行は、リモートプロセスコールを以下に図2でさらに記述する対応する仮想コードプロバイダにリンクする、共通の仮想化されたSDKおよびプラットフォームによって促進される。
図2は、本発明の1つまたは複数の実施形態により、コード仮想コードプロバイダ(VCP)2451…245Nを使用して、クラウドクライアント205とインターフェースがとられる従来型のサービス構成要素(CSC)2101…210Nを実行するためのプラットフォーム200を示している。プラットフォームは、リモートサーバ104a上に格納され得るプラットフォーム120に対応する。以下に、従来型のサービス構成要素2101…210Nは、CSC210としてまとめて表され、同様に仮想コードプロバイダ2451…245Nは、VCP245としてまとめて表される。プラットフォーム200は、クラウドクライアント205およびVCP245を介してリモートプロセスコールのためのユーザデバイス102をCSC2101…210Nにリンクする、仮想化されたSDKを効果的に使用する。
CSC2101は、リモートインターフェース2061、アプリケーションレイヤ2081、仮想化レイヤ2121、および物理装置2151を含む。各CSC210は、プラットフォーム200によって提示される特定のサービスを表している。たとえば、CSC2101は、インターネットサービスおよび対応するサーバの場合があり(たとえば、フェイスブック、EBAY、POP3電子メール、ツイッター、アマゾン、SMS、FTP、HTTPなど)、CSC2102は、従来のローカルデータ情報処理を提供するコンピュータの場合がある(たとえば、画像レンダリング、コードのコンパイル、データ分析、データ記憶など)。
物理装置2151またはマシン(CPU、メモリ、ネットワークルータなど)は、処理およびストレージのリソースをアプリケーションレイヤ2081で利用可能にするために、仮想化レイヤ2121において仮想化される。仮想化により、単一のコンピュータにおいて、およびさらに複数のマシンが仮想化されている実施形態において、冗長性および動作帯域幅の増加が生じる。そのような実施形態では、処理の作業負荷は、また、優先度に基づいて、および物理的位置と無関係に、様々な装置に割り当てられ得る。
アプリケーションレイヤ2081は、仮想化されたマシンでのデータベース動作(たとえば、アカウントプロフィールの格納、データの保管など)など、プログラムおよび機能の実行ランタイムを可能にする。リモートインターフェースレイヤ2061は、ウェブサーバにアクセスし、APIを利用するためのコードを含む。リモートインターフェース2061は、クラウドクライアント205と通信する(たとえば、シンクライアント、ウェブブラウザ、モバイルアプリケーション、ターミナルエミュレータプログラムなど)。
クラウドクライアント205は、アプリケーションレイヤ2081を用いてVCP245との間のデータの通信を促進する。クラウドクライアント205は、ウェブブラウザ、ターミナルエミュレータ、または他のクライアントのインターフェースを提示することによって、レイヤインターフェース2061、2081、2121、および2151を簡素化する。本発明の前述の実施形態は、仮想化されたSDKを使用して、プラットフォーム200でのスニペットのリモートプロセスコールコード生成を促進するために、クラウドクライアント205を利用することができる。仮想化されたSDKは、アプリケーションレイヤ2081に、VCP245によって生成および提示されたプロセスコールをリンクする。
VCP245は、仮想サンドボックス、正規化、汎用言語、結果解析、自動的な資格情報検証、簡素化された宣言プロセス、プラットフォームの維持、および監視を可能にする、拡張されたホストされたコードライブラリである。リモートサーバにプロセスおよびアプリケーション/プログラムを完全に展開する前に、プログラムをテストまたは「サンドボックス」することは、プログラム内に含まれる複数のリモートプロセスおよびサービスの追加に伴い、ますます重要になってきた。VCP245は、ユーザデバイス102aにダウンロードされる仮想化されたSDKを使用して、スニペットプロセスコールを調整する。
ユーザデバイス102aの観点から、VCP245は、言語をテンプレート化(templating)することによって、仮想化されたSDKを通じて提示された汎用プログラミング言語を可能にするため、構成要素のパラメータだけが必要であり、事前生成されたコードに挿入される。したがって、処理結果も迅速に解析され得る。アクセスは、また、リモートサービスにアクセスするために鍵の事前認証および格納された集中化された管理を使用して、プラットフォーム200によって円滑化される。事前認証は、また、機密にまつわる情報を露出する可能性がある、ユーザデバイス102aとプラットフォーム200との間で通信されるコードのリバースエンジニアを防ぐことによって、より安全なコードを生成する。VCP245は、また、スニペット形式へとプロセスを減らすことによってプログラミングを正規化する。したがって、スニペットは、コードを記述する標準化された方法を表している。
たとえば、クラウドで任意のプロセスを呼び出すための5行のコードは、コードの正規化と考えられる。VCP245は、プラットフォーム200が、作成されたアプリケーションがどのように実行されているかのリアルタイムの監視およびログ記録を表示することを可能にする(たとえば、使用統計、エラー処理など)。プラットフォーム200は、また、それぞれのVCPのSDKを維持するために監視を使用するため、プロセスプール230のAPIは、新しい方法、バージョン、およびパラメータを含めるために継続的に改善されている。
VCP2451は、プロセスプール2301、認証モジュール2281、SDKリンクモジュール2251、スニペットジェネレータ1241、ユーザデータベース2321、および実行エンジン1261を含む。一部の実施形態では、単一の実行エンジン126は、すべてのプロセスを展開することができる。
説明を簡単にするために、VCP245の各々は、1対1の対応でCSC210に対応している。しかしながら、代替実施形態は、異なる比率またはすべてのCSC210によって提示されたすべてのプロセスを表す単一のVCP245を含むことができる。VCP245は、本発明の1つまたは複数の実施形態によりリモートサーバ104aに格納される。VCP245は、CSC210のプラットフォーム200で提示されるリモートサービスをプロセスプール230に格納された、限られた数の実行可能な事前に決定されたリモートプロセスへと減らす。
リモートプロセスは、所与のCSC210Nで実行され得る望まれる動作に対応する。たとえば、フェイスブックのCSC2101に対するプロセスは、コメントの投稿、写真の投稿、コメントまたは写真へのいいね(liking)、友達要求の拒否、友達要求の開始、投稿の削除、およびユーザによって望まれる他の動作の制限されたプロセスプール2301を持つであろう。所与のプロセスプール230のプロセスの数は、したがって、CSC2101に関連するサービスによって使用可能な動作に制限される。例について続けると、プラットフォーム200には、フェイスブックに製品のレビューを配置するプロセスはないであろう。しかしながら、そのようなプロセスは、アマゾンで使用可能なようにプラットフォーム200によって処理されるであろう。
プロセスプール2301、これはリモートプラットフォーム200および対応するCSC210によって提示される各プロセスに関連するすべての事前生成されたコードを格納する。一部の実施形態では、事前生成されたコードは、事前生成されたコードプロセスを認識するために、リモートアプリケーションレイヤ2081に必要なネイティブ言語である。他の実施形態では、プログラミング言語は、IDEについてユーザデバイス102aにネイティブな場合がある。
スニペットジェネレータ1241は、スニペットがプロセスプール2301から関連するプロセスを呼び出すことができるように、対応するSDKを用いてスニペットを作成するために、ユーザによって入力されたパラメータだけでなく、プロセス名を挿入することによって、スニペットを生成する。スニペットパラメータは、選択されたリモートプロセスに関連する事前に定めたフィールドを含むGUIを使用して入力され得る。スニペットパラメータは、また、以前にユーザデータベース2321に格納されたように取得され得る。ユーザデータベース2321は、様々なサービスバンドルに対するユーザプロフィール、履歴、および格納された資格情報を含む。他の実施形態では、スニペットは、ユーザデバイス102aでローカルに生成され得る。
代替的実施形態では、スニペットジェネレータ1241は、簡易オブジェクトアクセスプロトコル(SOAP)、表現的状態転送(REST:representational state transfer)モデル、またはcURLを通じてなど、API呼び出しを使用して呼び出されたときにスニペットを生成する。
生成されたスニペットは、ユーザによって指定されたか、またはプラットフォーム200によって必要とされるプログラミング言語である。たとえば、ユーザは、JAVA(登録商標)で記述された、ユーザデバイス102aに前から存在するプログラムを持つことができる。関連するスニペットは、前から存在するプログラムにスニペットを直接的に挿入するために、ユーザデバイス102aに、JAVA(登録商標)構文の仮想化されたSDKおよびプラットフォーム200、ならびに対応するライブラリへのプロセスコールを持つ必要があるであろう。
認証モジュール2281は、ユーザから資格情報を受信するか、またはVCP2451に関連するCSC2101にアクセスするために、ユーザから以前に入力および格納された資格情報を使用する。認証モジュール2281は、また、プラットフォーム200へと認証することができる。ユーザデータベース2321は、CSC2101の所与のサービスに対するアカウントデータベースである。他の実施形態では、ユーザデータベース2321は、プラットフォーム200への認証のためのユーザアカウントの集合である。次に、プラットフォーム200は、複数のVCP245および関連するCSC210を横断して認証を調整する。たとえば、リモートサーバ(たとえばTEMBOOサーバ)のプラットフォーム200に同様にログインするユーザは、以前にユーザによって提出されたリモートサーバ104aに格納された事前定義された資格情報を使用して、電子メールサーバおよびEBAYアカウントへと認証する。
SDKリンクモジュール2251は、リモートプロセスの様々なバンドルを形成するために、ユーザデバイス102aおよびAPIで通信するだけでなく、認証モジュール2281が、ネットワーク110とインターフェースをとることを可能にするためのコードで構成される。SDKリンクモジュール2251は、また、クロスプラットフォームおよびクロスサービスの対話のために、複数のVCP245を横断して複数のSDKおよびAPIとの通信を調整する。たとえば、SDKリンクモジュール2251は、仮想化されたSDKで組み合わせられた単一のプロセスコールを形成するために、プロセスプール230および対応するSDK(たとえばEBAY SDK、ツイッターSDK、SMS SDKなど)を調整する。例について続けると、それぞれのプロセスプールからプロセスをリンクすることによって、仮想化されたSDKを用いる単一のプロセスコールは、アマゾンで売られている製品に一致するEBAY価格での落札されたオークションを本質的に同時にツイートおよびSMSテキスト送信することができる。
最後に、実行エンジン1261は、プロセスプール2301から選択されたプロセスを実行し、リモートプロセスを実行するために、別のリモートサーバ104nまたは対応するCSC2101にプロセスを展開する。一部の実施形態では、実行エンジン1261は、また、ユーザデータベースまたはユーザデバイス102aに結果を返すことができる。他の実施形態では、実行エンジン1261は、また、ユーザデバイス102aのローカルコードベースまたは前から存在するプログラムに埋め込まれた場合、作成されたスニペットがプロセスを呼び出すために使用されたときに、プロセスプール2301からリモートプロセスを実行する。さらに他の実施形態では、複数のリモートプロセスコールをリンクおよび実行するためなど、複数のVCP245の中での通信を調整するために、異なるSDKSを使用するために、実行エンジン1261が、SDKリンクモジュール2251と動作することを必要とする。
図3は、本発明の1つまたは複数の実施形態により、総合開発環境(IDE)305とインターフェースをとる図2に開示された仮想コードプロバイダ245を使用する全体的な方法300を示す図である。方法300は、ユーザデバイス102nでIDE305、およびリモートサーバ104n格納されたVCP245を利用する。方法300は、リモートプロセスを実行するのに必要な対応するCSC210の様々なプログラミング言語およびプラットフォームでリモートプロセスを呼び出すために、IDE305にネイティブの選択されたプログラミング言語で言語スニペットをダウンロードする。記述した実施形態では、単一のVCP245NおよびCSC210Nに対応する単一の例示的なスニペットが示されているが、他の実施形態は、複数のスニペットならびに対応するVCP245およびCSC210を含む。
IDE305は、リモートコードベースを用いてローカルコードベースを調整し、プログラムまたはアプリケーションがローカルで記述されながら、仮想化されたSDKを使用して、リモートプロセスコールを含めることを可能にする。一部の実施形態では、仮想化されたSDKは、ユーザデバイス102nにダウンロードおよび格納され得る。
ユーザデバイス102aが表示され、プロセスの使用可能なバンドルがVCP245Nを提示し、リモートプロセスが選択される。一部の実施形態では、IDE305のユーザは、特定のプログラミング言語で記述された既存のプログラムを持つことができる。そのような実施形態では、ユーザは、また、スニペットに対して既存のプログラムと同じプログラミング言語を選択する。
次に、スニペットはIDE305にダウンロードされる。一部の実施形態では、スニペットは、スニペットジェネレータ124Nによって生成される。他の実施形態では、スニペットは、VCP245Nに位置するユーザアカウントへの認証を用いて以前に生成およびリコールされ得る。一部の実施形態では、スニペットは、プロセスに対するパラメータを含めるためにIDE305のユーザによって編集される。あるいは、パラメータは、プロセスプール230Nからプロセスを選択するときにユーザによって提出され得るため、スニペットは、スニペットにすでに挿入されたパラメータを用いてダウンロードされる。
次に、IDE305は、SDKリンクモジュール225Nにスニペットを展開する。一部の実施形態では、スニペットは、対応するVCP245にスニペットのリモートプロセスコールを関連させるために、仮想化されたSDKを使用して展開される。他の実施形態では、展開されたスニペットは、対応するVCP245に直接的に展開される。
SDKリンクモジュール225Nは、CSC210Nの選択されたプロセスおよび関連するSDKに関連する事前生成されたコードを取得する。たとえば、アマゾンサーバに対応するCSC210Nについて、プロセスはアイテムを購入する予定であり、SDKリンクモジュール225Nは、スニペットから解析されたユーザから提出されたパラメータを使用して、アマゾンサーバの購入にアクセスおよび実行するために使用されたネイティブ言語でプロセスプール230Nから事前生成されたコードを取得する。例について続けると、アマゾン購入の解析されたパラメータは、製品名およびシリアル番号、ユーザの名前、送付先、ならびにクレジットカード情報を含むであろう。パラメータが挿入された事前生成されたコードは、対応するCSC2101でリモートプロセスを次に展開する実行エンジン126Nに送られる。
図4は、本発明の1つまたは複数の実施形態によるプロセスコールスニペットを作成する方法を示す流れ図である。方法は、図1のシステム100および上記の図2で記述したプラットフォーム200によって実装され得る。方法400は、リモートプロセスコールを生成する。
方法400は、ステップ405で始まり、ステップ410へと継続し、CSC210によって提示されたサービスに関連するプロセスコードは、メモリ(たとえば、プロセスプール230)に格納される。プロセスコードは、CSCNに特有のネイティブ言語の場合がある。一部の実施形態では、VCP245は、プロセスコードを生成するか、あるいはプロセスコードは事前生成され、パラメータデータの挿入のために準備され得る。
次に、ステップ415で、プロセスコードは、属性が分析される。属性は、パラメータ(たとえば変数)、プログラミング言語のタイプだけでなく、CSC210でプロセスコードとインターフェースをとり実行するために必要なSDKまたはAPIを含む。属性は、また、パラメータと所与のプロセスに対するパラメータの機能とのそれぞれの関係に基づいて区別するパラメータを含む。たとえば、電子メール送信(send e-mail)プロセスは、発信元の電子メールアドレス、宛先の電子メールアドレス、件名、現在の時刻、送るべき時間、およびメッセージ本文などのパラメータを必要とする。
次に、ステップ420で、パラメータは、CSC210でプロセスを実行する際に、提示されたプロセスおよび役割への相対的関係に基づいて相関される。例では、パラメータの各々は、プロセスにおいて特定のそれぞれの機能および他のパラメータとの関係を持っている。宛先の電子メールアドレスは、電子メールの著者として発信元の電子メールアドレスを用いる、対応するメッセージの件名および本文に関係する宛先の電子メールを必要とするプロセスコードの一部に割り当てられる。送るべき時間(time to send)パラメータは、電子メールがいつ送られるべきかに関する値を含み、それに応じて、電子メール送信プロセス内で実行の時間の機能に相関される。代替的実施形態では、分析されたプロセスコードは、それぞれのCSC210のSDKおよびAPIにネイティブである(たとえば、アマゾン、ツイッターなど)。一部の実施形態では、関係情報は、また、生のパラメータ構成要素のソースを含む。パラメータデータは、ユーザによって手作業で入力する、自動的に入力する(たとえば、格納された認証鍵)、別のプロセスの結果に条件付きに基づく、または別のプロセスのパラメータに関係することができる。
ステップ425で、パラメータはプロセスプール230の少なくとも1つのプロセスに割り当てられる。以前の例について続けると、発信元の電子メールアドレスは、電子メールを送るためのプロセスだけでなく、別のプロセスが電子メールサーバへと認証するために必要なPOP3サーバへのログイン資格情報に割り当てられ得る。
ステップ430で、プロセスプール320のプロセスは、仮想化されたSDKにリンクされる。仮想化されたSDKは、プロセスプール230のプロセスを呼び出すために、ユーザデバイスにダウンロードされ得る。一部の実施形態では、プロセスを呼び出すステップは、リコールされた格納されたプロセスコードへと挿入されたスニペットからパラメータデータを受信するステップと、仮想化されたSDKにリンクされたCSC210に対してAPIおよびSDKを使用して、対応するCSC210で挿入されたパラメータを用いてプロセスコードを実行するステップとを含む。そのような実施形態では、必要とされるAPIおよびSDKは、また、プロセスプール320の関連するプロセスコードにリンクされる。
ステップ435で、方法400は、選択された言語に対して前から存在する言語テンプレートを使用して、複数のプログラミング言語でプロセスプール230の各プロセスに対してプロセスコールスニペットを生成する。次に、方法400は、ステップ440で終了する。
図5は、本発明の1つまたは複数の実施形態による追加的なリモートプロセスを用いるローカル開発環境を拡張するための方法500を示す流れ図である。仮想化されたSDKを通じて、方法500は、ユーザデバイス102aのコードベースが小さく、ユーザによって実装されるSDKのみを含むことを可能にする。方法500は、仮想化されたSDKのリモートプロセスコールを処理するリモートプログラミングプラットフォーム200に認証するステップを含む。
方法500は、ステップ505で始まり、ステップ510へと継続し、ユーザデバイス102aは、リモートプラットフォーム200にログインする。ユーザのアカウントは認証され、CSC210の様々なリモートサービスに対する以前に格納された鍵および資格情報に関連される(たとえば、データストレージ、電子メール、ウェブサイト、ソーシャルメディア、仲介(brokerage)、バンキングなど)。認証モジュール228は、VCP245の関連する様々なCSC210に認証するために、相互に調整する。一部の実施形態では、プラットフォーム200は、一般的に使用されるルーチン、プロセス、SDK、およびAPIのプロフィール履歴を用いる集中化されたユーザアカウントを含む。プロフィール履歴は、プラットフォーム200ならびに関連するVCP245およびCSC210に対応するユーザデータベース232の両方に対して記録および更新される。
方法500は、ステップ515に継続し、リモートプロセスはポピュレートされ、かつ/またはユーザデバイス102aに表示される。ユーザデバイス102aがディスプレイを持っている実施形態では、使用可能なプロセスは、IDE305を介してユーザに表示される。プロセスプール230のリモートプロセスは、特定のCSC210に対して提示された動作に対応するプロセスのバンドルとして表示され得る。たとえば、ツイッターに対応するCSC210は、FOLLOWING機能を使用するすべての下位動作(たとえばFOLLOW、FOLLOW停止、FOLLOW状態など)に対するFOLLOWバンドル、およびTWEETを使用する副次機能に対するTWEETバンドルを含むであろう。
方法500は、ステップ520に継続し、選択されたリモートプロセスに関連する仮想化されたSDKが、リモートサーバ104aから要求される。仮想化されたSDKは、すべてのリモートプロセスコールを含むことができるか、または選択されたプロセスへのコールを処理するコードを含むようにカスタマイズされ得る。一部の実施形態では、仮想化されたSDKは、ユーザデバイス102aのプログラミング言語に特有である。仮想化されたSDKは、対応するVCP245で選択されたリモートプロセスを呼び出すために、すべての必要なヘルパー/ツールをコードスニペットに提供する。
ディスプレイが使用可能ではない実施形態では、方法500は、選択されたプロセスの対応するSDKをダウンロードするステップを自動化することができる。仮想化されたSDKは、プロセスプールからのプロセスをCSC210の少なくとも1つのリモートサービスに関連する対応するSDKおよびAPIにリンクするSDKリンクモジュール225を介して、リモートプロセスコールを可能にする。たとえば、CSC210がグーグルである場合、仮想化されたSDKは、グーグル検索を実施し、特定のクエリに対して検索の結果を特定のコンピュータに返すためのコマンドを持つグーグルSDKおよびAPIにリンクするステップを含む。
ステップ525で、IDE305はリモートプロセスにアクセスし、ユーザデバイス102aの既存のローカルコードベースに仮想化されたSDKを統合するように、関連する仮想化されたSDKをローカルのIDE305にダウンロードおよびインストールすること。仮想化されたSDKは、開発者が彼女/彼のローカルコードベースに(次に、生産のために展開されたコードに)インストールしておく必要がある言語に特有のローカルコードライブラリである。
次に、ステップ530で、ダウンロードされた仮想化されたSDKは、(たとえば、ユーザデバイス102aで作成された)ローカルプログラムが、IDE305でユーザによって入力されたパラメータを使用して、サーバ104a上の対応するリモートプロセスを呼び出し実行することを可能にするために使用される。パラメータは、グラフィカルユーザインターフェースを介してユーザに提示される事前定義されたフィールドを介して入力され得る。事前定義されたフィールドは、リモートコールスニペットを作成するのに必要な情報を制限および簡素化する。次に、パラメータのデータは、リモートサーバ104aに送信され、リモートプロセスを含むプロセスプール230の事前生成されたコードに挿入される。
以下に図6でさらに記述するように、仮想化されたSDKは、また、生成されたスニペットに対するサポートを提供する。スニペットは、ユーザデバイス102の動作および/またはプログラミングの環境(たとえばIDE305)にネイティブの選択されたプログラミング言語で生成される。
ステップ535で、リモートサーバ104aは、VCP245および実行エンジン125を通じて、リモートプロセスに関連するCSC210およびVCP245に、相関されたリモートプロセスを展開する。
ステップ540で、実行されたプロセスのリアルタイムの結果が、また、IDE305のリモートサーバ104aから表示される。したがって、フェイスブック投稿に成功すると、IDE305に通知するために応答を処理するリモートサーバ104aにメッセージを返すことができる。一部の実施形態では、結果は、プロセスコールに関連するCSC210から直接的に返される。たとえば、フェイスブック投稿からの結果は、IDE305に直接的に返され得る。次に、方法500はステップ545で終了する。
図6は、本発明の1つまたは複数の実施形態による、様々なプログラミング言語に対する仮想化されたプロセスコールコードジェネレータの方法600を示す流れ図である。方法600は、仮想化されたSDKを適用し、CSC210でリモートプロセスを呼び出すために、ユーザデバイス102aおよび/またはIDE305に対して調整されたスニペットを生成することによって、様々なプログラミング言語間の変換を可能にする。一部の実施形態では、方法600は、仮想化されたSDKを用いてリモートプロセスを呼び出す際の方法500の続きである。
方法600はステップ605で始まり、ステップ610に継続し、ユーザデバイス102aに対してリモートプロセスの集合がポピュレートされる。一部の実施形態では、ユーザデバイス102aは、ユーザアカウントがリモートプロセスにアクセスするために、リモートプラットフォーム200にログインする必要がある。ログインプロセスについて、図5に関してさらに詳細に上に記述している。
次に、ステップ615で、少なくとも1つのリモートプロセスが選択される。一部の実施形態では、リモートプロセスは、ユーザデバイス102aのグラフィカルユーザインターフェース(GUI)を通じて選択される。他の実施形態では、リモートプロセスは、ユーザデバイス102aにダウンロードされた仮想化されたSDKの機能を通じてリモートプロセスを呼び出すことによって指定される。
ステップ620で、パラメータは、ユーザデバイス102aの選択されたプロセスに対するユーザからの入力である。パラメータは、サービス、タイミング情報、ペイロードデータ、ファイル拡張、およびリモートプロセスを正しく実行するのに必要な他の情報のための認証鍵を含む。パラメータは、リモートプロセスに関連して生成されたスニペットに挿入される。一部の実施形態では、パラメータは、ローカルIDE305を介してユーザによって入力され、他の実施形態では、一部のパラメータエントリは、リモートサーバ104aの格納された資格情報またはデータをリモートで使用して完了され得る。IDE305は、リモートサーバ104a上に格納されたプラットフォーム200と通信する。
ステップ625で、ユーザデバイス102aのプログラム(たとえばIDE305)は、関連するプロセスパラメータを用いる選択されたリモートプロセスのリモートプラットフォーム200への展開をローカルにトリガーする。展開は、リモートプラットフォーム200で適切なVCP245およびプロセスプール230を呼び出すために、スニペットおよび仮想化されたSDKを利用する。
ステップ626で、パラメータは、スニペットから解析される。解析は、仮想化されたSDKを通じてリンクされるように、選択されたプロセスに対してVCPにパラメータを向けるステップを含む。
ステップ628で、解析されたパラメータは、事前生成されたコードに挿入される。一部の実施形態では、CSC210のネイティブ言語、およびプロセスプール230において事前生成されたコード。
ステップ630で、プロセスは、CSC210など実際のリモート環境で実行される。たとえば、アマゾンサーバを使用する購入、またはPOP3電子メールの送信など。しかしながら、代替実施形態は、リモートサーバにプロセスおよびプログラムを完全に展開する前に、プログラムをテストまたは「サンドボックス」するためにテスト環境で選択されたプロセスを実行することができる。サンドボックスは、プログラム内における複数のリモートプロセスおよびサービスの追加においてますます重要になってきている。
次に、ステップ635で、結果は、ユーザIDEにリアルタイムに表示される。一部の実施形態では、CSC210で展開されたプロセスコールに結果は、また、VCP245へのリモートプラットフォーム200を使用して監視および維持を提供する。ネイティブコードは、スニペットからのパラメータデータを使用して、リモートサーバ(たとえばCSC210)で実行されるように、アプリケーションのスニペットが処理される。そのような実施形態では、次に、プラットフォーム200は、使用およびエラーデータなどの統計をIDE305に返し、VCP245においてAPIおよびSDKを更新するために、アプリケーションを監視およびログオンする。次に、更新は、次のランタイムエラーを減らすために、プロセスプール235の対応する事前生成されたコードに統合される。
ステップ640で、選択されたリモートプロセスコールをトリガーするためのコードスニペットは、対応するVCP245によって第1のデフォルトプログラミング言語で生成される。一部の実施形態では、コードスニペットは、CSC210で選択されたリモートプロセスの展開と同時で生成され得る。さらに他の実施形態では、コードスニペットは、プロセスの展開または実行なしで生成され得る。
一部の実施形態では、コードスニペットは、また、ネットワーク110のリモートサービスを呼び出し/アクセスすることができる。たとえば、プログラムは、関連するユーザアカウントの事前認証された鍵/資格情報を使用して、同時に、ユーザが指定したメッセージをツイートし、FOURSQUAREでチェックインするために使用されるECLIPSEで記述され得る。そのようなサービスにアクセスするために、スニペットジェネレータは、リモートのツイッターおよびFOURSQUAREのサービスを呼び出し、前述のプロセスを実行するために、ECLIPSEに挿入されるコードスニペットを生成する。以下にさらに記述するように、一部の実施形態では、IDEからのパラメータは、次に、スニペットジェネレータ124を介してスニペット形式を構築するために抽出され得る。
一部の実施形態では、コードスニペットは、また、実行タイミング情報を含むことができる。コードスニペットは、インストールされた仮想化されたSDKを使用して、リモートプラットフォーム200にプロセスコールを通信するユーザデバイス102aで、特定のプログラミング言語に対して事前定義されたテンプレートから形成される。
ステップ645で、方法600は、ユーザがIDE305で異なるプログラミング言語を選択したかどうかを決定する。一部の実施形態では、方法600は、ユーザによってだけでなく、プラットフォーム200による格納されたユーザプロフィールの個別設定または履歴を介して入力された、既存のプログラミングコードを比較することによって、望まれるプログラミング言語を自動的に検出することができる。他の言語が選択されていない、またはデフォルト言語が正しい言語であると方法600が決定した場合、ステップ655で、スニペットはユーザデバイス102aに送った。しかしながら、別の言語が選択されているか、または検出されたと方法600が決定した場合、ステップ650で、スニペットは、対応する選択された言語に対してテンプレートを使用して、再生成または形式変更される。一部の実施形態では、テンプレートは、変数、リモートAPIへのアクセス鍵、トークン、資格情報など、ユーザデバイス102aまたはサーバ104a上で以前に格納されたパラメータで、ユーザに入力されたパラメータを補足する。
ステップ650から、方法は、また、ステップ655に継続し、ユーザデバイス102aおよび/またはIDE305に新しいスニペットを送る。次に、ステップ660で、スニペットは、ローカルコードベースに挿入されるため、ユーザによって記述されたローカルプログラムは、マシンで(たとえば、ユーザデバイス102aのみで)ローカルに実行されることになっているコードに加えて、ネットワーク110を通じてサーバ104a上でリモートプロセスを呼び出すことができる。一部の実施形態では、ローカルコードベースは、また、他のネットワーク化されたマシンにアクセスすることができる。他の実施形態では、ローカルコードベースは、開発者のワークステーションにあるか、または(直接的に、またはGITHUBなどのコード管理システムを通じて)サーバ上ですでに展開されている可能性がある。
ステップ665で、ローカルコードおよびリモートプロセスコールは、ユーザIDE内で、またはユーザによって選択されたネイティブ開発環境で実行され得る。次に、方法600は、ステップ670で終了する。
図7は、本発明の1つまたは複数の実施形態による例示的なコンピューティングサーバ内のモジュールを示す簡略化されたブロック図である。コンピュータシステム700は、前述の実施形態のサーバまたは電子デバイスを含む本質的に同様の構造を含む。
本明細書に記述した、スニペット生成およびリモートプロセスコールのための方法およびシステムの様々な実施形態は、様々な他のデバイスと対話することができる、1つまたは複数のコンピュータシステムで実行され得る。そのようなコンピュータシステムの1つは、図7に示されているコンピュータシステム700であり、これは様々な実施形態において、図1〜図6に示された要素または機能のいずれかを実装することができる。様々な実施形態において、コンピュータシステム700は、上に記述した方法を実装するように構成され得る。コンピュータシステム700は、上記の実施形態の他のシステム、デバイス、要素、機能、または方法を実装するために使用され得る。図示した実施形態では、コンピュータシステム700は、様々な実施形態において、プロセッサで実行可能な実行可能プログラム命令722として(たとえば、プロセッサ710によって実行可能なプログラム命令)、方法400、500、および600を実装するように構成され得る。
図示する実施形態では、コンピュータシステム700は、入力/出力(I/O)インターフェース730を介してシステムメモリ720に結合された1つまたは複数のプロセッサ710a〜710nを含む。コンピュータシステム700は、I/Oインターフェース730に結合されたネットワークインターフェース740、およびカーソル制御デバイス760、キーボード770、およびディスプレイ780など1つまたは複数の入力/出力デバイス750をさらに含む。一部の実施形態では、キーボード770は、タッチスクリーン入力デバイスの場合がある。
様々な実施形態において、構成要素のいずれも、上記のようにリモートプロセスコールをルーティングおよび実行するために、システムによって利用され得る。様々な実施形態において、ユーザインターフェースは、ディスプレイ780に生成および表示され得る。場合によっては、実施形態は、コンピュータシステム700の単一のインスタンスを使用して実装され得る一方、他の実施形態では、複数のそのようなシステム、またはコンピュータシステム700を構築する複数のノードは、様々な実施形態の異なる部分またはインスタンスをホストするように構成され得ることが考えられる。たとえば、一実施形態では、一部の要素は、他の要素を実装するノードとは異なるコンピュータシステム700の1つまたは複数のノードを介して実装され得る。別の例では、複数のノードは、分散的な方法でコンピュータシステム700を実装することができる。
異なる実施形態で、コンピュータシステム700は、限定しないが、パーソナルコンピュータシステム、メインフレームコンピュータシステム、ハンドヘルドコンピュータ、ワークステーション、ネットワークコンピュータ、アプリケーションサーバ、ストレージデバイス、スイッチ、モデム、ルータなどのなど周辺機器、または一般的に任意のタイプのコンピューティングデバイスまたは電子デバイスを含む様々なタイプのデバイスのいずれかの場合がある。
様々な実施形態において、コンピュータシステム700は、1つのプロセッサ710を含むユニプロセッサシステム、または複数のプロセッサ710を含むマルチプロセッサシステムの場合がある(たとえば、2、4、8、または別の適切な数)。1つのプロセッサ710を含むユニプロセッサシステムは、プログラムの同時データを処理および実行するために、複数のプロセッサに見えるようにシングルプロセッサの機能を分割することができる。プロセッサ710は、命令を実行することができる任意の適切なプロセッサの場合がある。たとえば、様々な実施形態において、プロセッサ610は、様々な命令セットアーキテクチャ(ISA)のいずれかを実装する汎用プロセッサまたは組み込まれたプロセッサの場合がある。マルチプロセッサシステムでは、プロセッサ710の各々は、一般に、必ずではないが、同じISAを実装する。
システムメモリ720は、プロセッサ710によってアクセス可能なプログラム命令722および/またはデータ732を格納するように構成され得る。様々な実施形態において、システムメモリ720は、静的ランダムアクセスメモリ(SRAM)、シンクロナス動的RAM(SDRAM:synchronous dynamic RAM)、不揮発性/フラッシュ型メモリ、または他のタイプのメモリなど適切なメモリ技術を使用して実装され得る。図示する実施形態では、上に記述した実施形態の要素のいずれかを実装するプログラム命令およびデータは、システムメモリ720内に格納され得る。他の実施形態では、プログラム命令および/またはデータは、異なるタイプのコンピュータでアクセス可能な媒体、またはシステムメモリ720もしくはコンピュータシステム700から離れた同様の媒体で受信、送信、または格納され得る。
一実施形態では、I/Oインターフェース730は、入力/出力デバイス750など、ネットワークインターフェース740または他の周辺インターフェースを含む、デバイスのプロセッサ710、システムメモリ720、および任意の周辺機器の間のI/Oトラフィックを調整するように構成され得る。一部の実施形態では、I/Oインターフェース730は、ある構成要素(たとえばシステムメモリ720)から別の構成要素(たとえばプロセッサ710)による使用に適した形式にデータ信号を変換するために、必要なプロトコル、タイミング、または他のデータ変換を実行することができる。一部の実施形態では、I/Oインターフェース730は、たとえば、ペリフェラルコンポーネントインターコネクト(PCI)バス標準またはユニバーサルシリアルバス(USB)標準の変形など、様々なタイプの周辺バスを通じて接続されたデバイスに対するサポートを含むことができる。一部の実施形態では、I/Oインターフェース730の機能は、たとえば、ノースブリッジおよびサウスブリッジなど2つ以上の個別の構成要素へと分割され得る。また、一部の実施形態では、システムメモリ720へのインターフェースなど、I/Oインターフェース730の機能の一部またはすべては、プロセッサ710に直接的に組み込まれ得る。
ネットワークインターフェース740は、データが、コンピュータシステム700と1つまたは複数の外部システムなどネットワーク(たとえばネットワーク790)に接続された他のデバイスとの間、またはコンピュータシステム700のノードの間で交換されることを可能にするように構成され得る。様々な実施形態において、ネットワーク790は、限定しないが、ローカルエリアネットワーク(LAN)(たとえばイーサネット(登録商標)または企業ネットワーク)、ワイドエリアネットワーク(WAN)(たとえばインターネット)、ワイヤレスデータネットワーク、セルラーネットワーク、Wi-Fi、他の何らかの電子データネットワーク、またはそれらの組合せを含む1つまたは複数のネットワークを含むことができる。様々な実施形態において、ネットワークインターフェース740は、たとえば、適切なタイプのイーサネット(登録商標)ネットワークなど、有線もしくは無線の一般的なデータネットワークを介して、アナログ音声ネットワークまたはデジタルファイバ通信ネットワークなど、電気通信/電話通信ネットワークを介して、ファイバチャネルSANなど、ストレージエリアネットワークを介して、または他の適切なタイプのネットワークおよび/またはプロトコルを介して、通信をサポートすることができる。
入力/出力デバイス750は、一部の実施形態では、1つまたは複数のディスプレイ端末、キーボード、キーパッド、タッチパッド、タッチスクリーン、スキャンデバイス、音声または光学による認識装置、または1つまたは複数のコンピュータシステム700によってデータを入力もしくはアクセスするのに適した他のデバイスを含む。複数の入力/出力デバイス750は、コンピュータシステム700に存在する場合があるか、またはコンピュータシステム700の様々なノードに分散され得る。一部の実施形態では、同様の入力/出力デバイスは、コンピュータシステム700から離れている場合があり、ネットワークインターフェース740を通じてなど有線または無線の接続を通じてコンピュータシステム700の1つまたは複数のノードと対話することができる。
一部の実施形態では、図示するコンピュータシステムは、図3〜図6の流れ図によって示された方法など、上に記述された方法のいずれかを実装することができる。他の実施形態では、異なる要素およびデータが含まれ得る。
コンピュータシステム700は、単に説明のためのものであり、実施形態の範囲を制限することを意図するものではないことを当業者は理解されるであろう。特に、コンピュータシステムおよびデバイスは、コンピュータ、ネットワークデバイス、インターネット家電、スマートフォン、タブレット、PDA、ワイヤレス電話、ポケットベルなどを含む、様々な実施形態の示された機能を実行することができるハードウェアまたはソフトウェアの任意の組合せを含むことができる。コンピュータシステム700は、図示されていない他のデバイスに接続され得るか、または代わりにスタンドアロンのシステムとして動作することができる。さらに、図示する構成要素によって提供される機能は、一部の実施形態では、より少数の構成要素で組み合わせられ得るか、または追加の構成要素に分散され得る。同様に、一部の実施形態では、図示する構成要素の一部の機能は、提供されない場合があるか、かつ/または他の追加的な機能が使用可能な場合がある。
当業者は、また、様々なアイテムは、使用される間にメモリまたはストレージに格納されるものとして示されているが、それらのアイテムまたはそれらの一部は、メモリ管理およびデータ完全性の目的のために、メモリと他のストレージデバイスとの間で転送され得ることを理解されるであろう。あるいは、他の実施形態では、ソフトウェア構成要素の一部またはすべては、別のデバイスのメモリで実行され、コンピュータ間通信を介して図示したコンピュータシステムと通信することができる。システム構成要素またはデータ構造の一部またはすべては、(たとえば命令または構造化データとして)コンピュータでアクセス可能な媒体または適切なドライブによって読み込まれる携帯用の物品に格納され得て、その様々な実例については上に記述されている。一部の実施形態では、コンピュータシステム700から離れているコンピュータでアクセス可能な媒体に格納された命令は、送信媒体またはネットワークおよび/もしくはワイヤレスリンクなどの通信媒体を介して伝達される、電気信号、電磁気信号、もしくはデジタル信号など信号を介して、コンピュータシステム700に送信され得る。様々な実施形態は、コンピュータでアクセス可能な媒体で、または通信媒体を介して、前述の記述により実装された命令および/またはデータの受信、送信、または格納をさらに含むことができる。一般的に、コンピュータでアクセス可能な媒体は、たとえばディスクまたはDVD/CD-ROMなど磁気的または光学的な媒体、RAM(たとえばSDRAM、DDR、RDRAM、SRAMなど)、ROMなど揮発性または不揮発性の媒体など記憶媒体またはメモリ媒体を含むことができる。
JAVA(登録商標)プログラムに挿入するために生成された例示的なスニペットは、TEMBOO仮想化されたSDKを呼び出す、以下を含む
package TembooDemoECOs;
import com.temboo.Library.NYTimes.ArticleSearch.QueryArticles;
import com.temboo.Library.NYTimes.ArticleSearch.QueryArticles.QueryArticlesInputSet;
import com.temboo.Library.NYTimes.ArticleSearch.QueryArticles.QueryArticlesResultSet;
import com.temboo.core.TembooException;
import com.temboo.core.TembooSession;
public class TembooDemoECOs{
/**
*@param args
*@throws TembooException
*/
public static void main(String[] args) throws TembooException {
//Tembooセッションをインスタンス化する
TembooSession session = new TembooSession("demo", "myFirstApp", "6d975bf6-e761-47c7-8");
//以前にインスタンス化されたTembooSessionオブジェクトを使用してChoreoをインスタンス化する
QueryArticles queryArticlesChoreo = new QueryArticles(session);
//choreoに対してInputSetオブジェクトを取得する
QueryArticlesInputSet queryArticlesInputs = queryArticlesChoreo.newInputSet();
//実行に使用するために資格情報を設定する
queryArticlesInputs.setCredential("NYTimesCred");
//入力を設定する
queryArticlesInputs.set_Query("obama");
//Choreoを実行する
QueryArticlesResultSetqueryArticlesResults = queryArticlesChoreo.execute(queryArticlesInputs);
//ECOを使用して結果をプリントする
for (int i = 0; i < queryArticlesResults.getArticles().length; i++) {System.out.println(queryArticlesResults.getArticles()[i].getTitle() + " :: " + queryArticlesResults.getArticles()[i].getByLine());
}
}
}
上記の例では、スニペットは、任意のJava(登録商標)プログラムに挿入され得るコードを5行含む。「Tembooセッションをインスタンス化する」ためのコードから始まり、「Choreoを実行する」ためのコードで終わる。コードのこれらの行は、テキストとしてローカルIDEで編集され得て、ユーザが、彼または彼女が呼び出したいchoreoの名前を知っているように将来的に編集される。「package TembooDemoECOs;」行は、特定のクラス:QueryArticlesのインポートを行うことによって仮想化されたSDKを呼び出す。上記の実例は、QueryArticlesに対するコードを含むこの例示的なSDKのインストールで可能である。
public class QueryArticles extends Choreography {
/** QueryArticles Choreoの新しいインスタンスを作成する。Temboo資格情報の有効な組を含むTembooSessionオブジェクトが供給されなければならない。
*/
public QueryArticles(TembooSession session) {
super(session,
TembooPath.pathFromStringNoException("/Library/NYTimes/ArticleSearch/QueryArticles"));
}
/** このChoreoの実行のための入力を規定するために使用されるInputSetオブジェクトを取得する。
@return QueryArticlesInputSet
*/
public QueryArticlesInputSet newInputSet() {
return new QueryArticlesInputSet();
}
/**
*パラメータとして指定されたInputSetを使用してChoreoを実行し、Choreoが完了するのを待ち
*そして実行結果を含むResultSetを返す。
*@param choreoInputs
*@return
*@throws TembooException
*/
@Override
public QueryArticlesResultSet execute(InputSet choreoInputs) throws TembooException {
JSONObject result = super.executeWithResults(choreoInputs);
return new QueryArticlesResultSet(result);
}
/** QueryArticles Choreoへの入力を指定するのに適切な方法を備えたInputSet。InputSetオブジェクトは、このchoreoを実行するときに入力パラメータを指定するために使用される。
*/
public static class QueryArticlesInputSet extends InputSet {
/** このChoreoに対してAPIKey入力の値を設定する。
@param String - (required, string) NYTimesによって提供されるAPI鍵。
*/
public void set_APIKey(String value) {
this.setInput("APIKey", value);
}
/** このChoreoに対するBeginDate入力の値を設定する。
@param String - (optional, date) 返すべき発行日の範囲の始点(包含的)を設定する。EndDateとともに使用されなければならない。日付はYYYYMMDDのような形式であるべきである。
*/
public void set_BeginDate(String value) {
this.setInput("BeginDate", value);
}
/** このChoreoに対するEndDate入力の値を設定する。
@param String - (optional, date) 返すべき発行日の範囲の終点(包含的)を設定する。BeginDateとともに使用されなければならない。日付はYYYYMMDDのような形式であるべきである。
*/
public void set_EndDate(String value) {
this.setInput("EndDate", value);
}
/** このChoreoに対するファセット(Facets)入力の値を設定する。
@param String - (optional, string) 5ファセットまでのカンマ区切りのリスト。これは、応答に含めるべきファセット値の組を示している。この入力に対する承認された値の詳細については、Choreoの文書を参照すること。
*/
public void set_Facets(String value) {
this.setInput("Facets", value);
}
/** このChoreoに対するフィールド(Fields)の入力の値を設定する。
@param String - (optional, string) 返すべきフィールドのカンマ区切りのリスト。これらのフィールドがデフォルトで返される:body、byline、date、title、およびurl。
*/
public void set_Fields(String value) {
this.setInput("Fields", value);
}
/** このChoreoに対するオフセット(Offset)入力の値を設定する。
@param Integer - (optional, integer) これは10の結果の組が返されることに対応する。結果に目を通すために使用される。レコード0〜9を返すために0に設定する、レコード10〜19を返すために1に設定するなど。
*/
public void set_Offset(Integer value) {
this.setInput("Offset", value);
}
/** StringとしてこのChoreoに対するオフセット入力の値を設定する。
@param String - (optional, integer) これは10の結果の組が返されることに対応する。結果に目を通すために使用される。レコード0〜9を返すために0に設定する、レコード10〜19を返すために1に設定するなど。
*/
public void set_Offset(String value) {
this.setInput("Offset", value);
}
/** このChoreoに対するクエリ(Query)入力の値を設定する。
@param String - (required, string) (オプションとして特定のフィールドに適用された)キーワードおよび/またはファセットを検索する。構文の実例については、Choreoの文書を参照すること。
*/
public void set_Query(String value) {
this.setInput("Query", value);
}
/** このChoreoに対するランク(Rank)入力の値を設定する。
@param String - (optional, string) 結果の順序を設定する。承認された値は、次のとおりである:newest(デフォルト)、oldest、またはclosest。
*/
public void set_Rank(String value) {
this.setInput("Rank", value);
}
}
/** QueryArticles Choreoによって返された値に調整された方法を用いるResultSet。
ResultSetオブジェクトは、Choreo実行の結果を取得するために使用される。
*/
public static class QueryArticlesResultSet extends ResultSet {
public QueryArticlesResultSet(JSONObject doc) throws TembooException {
super(doc);
}
/** このChoreo実行から「Response」出力に対する値を取得する。
@return String - (json) NY Times APIからの応答。
*/
public String get_Response() {
return this.getResult("Response");
}
/** オフセットの値は、10の結果の組に対応する(すなわち、結果0〜9に対してoffset=0、結果10〜19に対してoffset=1など)
*/
public String getOffset() {
return (String)
((JSONObject)getJSONFromString(this.getResult("Response"))).opt("offset");
}
/** 検索基準に一致するアーティクル(article)を取得する。
*/
public NYTimesArticle[] getArticles() {
JSONArray list = (JSONArray)
((JSONObject)getJSONFromString(this.getResult("Response"))).opt("results");
NYTimesArticle[] resultArray = new NYTimesArticle[(list != null) ? list.length() : 0];
if(list != null) {
for(int i=0; i<list.length(); i++) {
try {
resultArray[i] = new NYTimesArticle(list.get(i));
} catch (JSONException e) {}
}
}
return resultArray;
}
/** クエリに提供される検索トークンを含む。
*/
public String[] getTokens() {
JSONArray list = (JSONArray)
((JSONObject)getJSONFromString(this.getResult("Response"))).opt("tokens");
String[] resultArray = new String[(list != null) ? list.length() : 0];
if(list != null) {
for(int i=0; i<list.length(); i++) {
try {
resultArray[i] = (String) list.get(i);
} catch (JSONException e) {}
}
}
return resultArray;
}
/** この検索に対するアーティクルの総数
*/
public Number getTotal() {
return (Number)
((JSONObject)getJSONFromString(this.getResult("Response"))).opt("total");
}
}
}
上記の例示的な仮想化されたSDKをインストールすることによって、スニペットは、ここでリモートプロセスへのコールを実行することができる。コードスニペットは、関連するVCP245を通じてリモートサーバ104a上の実際のプロセスを呼び出すために仮想化されたSDKコードにリンクする。一部の実施形態では、SDKは、入力パラメータが適切な形式にあることを保証し、次いで、対応するリモートプロセスを呼び出すことを含む。上記の実例では、「choreo」は、ユーザデバイス102aおよび/またはローカルIDE305でのリモートプロセスのグラフィック表示である。
本明細書に記述した方法は、異なる実施形態では、ソフトウェア、ハードウェア、またはそれらの組合せにおいて実装され得る。さらに、方法の順序は変更され得て、また、様々な要素を追加、並べ替え、組み合わせ、省略、あるいは修正され得る。本明細書に記述したすべての実例は、限定を目的とせずに提示されている。本開示の利益を受ける当業者には明白なように、様々な修正および変更が行われ得る。特定の実施形態に関連して、実施形態による実現について記述してきた。これらの実施形態は、説明を目的とするものであり、限定を目的としていない。多数の変形形態、修正、追加、および改善が可能である。したがって、単一のインスタンスとして本明細書に記述された構成要素について、複数のインスタンスを提供され得る。様々な構成要素、動作、およびデータストアの間の境界はある程度は自由に決めてよく、また、特定の動作は、特定の説明的な構成に関連して示されている。機能の他の割り当てが想像され、後述する特許請求の範囲の範囲以内に該当する場合がある。最後に、例示的な構成における個別の構成要素として提示されている構造および機能は、組み合わせられた構造または構成要素として実装され得る。これらおよび他の変形形態、修正、追加、および改善は、後述する特許請求の範囲に規定される実施形態の範囲内に該当する場合がある。
前述の内容は、本発明の実施形態に関するものであるが、その基本的な範囲から逸脱することなく、本発明の他の実施形態およびさらなる実施形態が考案され得て、その範囲は、後述する特許請求の範囲によって決定される。
102a ユーザデバイス
102n ユーザデバイス
104a リモートサーバ
104n リモートサーバ
110 ネットワーク
1241 スニペットジェネレータ
124N スニペットジェネレータ
1261 実行エンジン
126N 実行エンジン
200 プラットフォーム
205 クラウドクライアント
2061 インターフェース
2062 インターフェース
206N インターフェース
2081 アプリケーションレイヤ
2082 アプリケーションレイヤ
208N アプリケーションレイヤ
2101〜210N 従来型のサービス構成要素
2121 仮想化レイヤ
2122 仮想化レイヤ
212N 仮想化レイヤ
2151 物理サーバおよびネットワーク装置
2152 物理サーバおよびネットワーク装置
215N 物理サーバおよびネットワーク装置
2251 SDKリンクモジュール
225N SDKリンクモジュール
2281 認証モジュール
228N 認証モジュール
2301 プロセスプール
230N プロセスプール
2321 ユーザデータベース
232N ユーザデータベース
2451…245N 仮想コードプロバイダ(VCP)
305 IDE
700 コンピューティングシステム
710a プロセッサ
710b プロセッサ
710n プロセッサ
720 メモリ
722 プログラム命令
730 I/Oインターフェース
732 データ
740 ネットワークインターフェース
750 入力/出力デバイス
760 カーソル制御デバイス
770 キーボード
780 ディスプレイ
790 ネットワーク

Claims (15)

  1. ユーザデバイスにおけるコード仮想化のための方法であって、
    リモートサーバ上のリモートプロセスを選択するステップであって、前記リモートプロセスは、少なくとも1つのリモートサービスに相関される、ステップと、
    前記リモートサーバ上の少なくとも1つの仮想コードプロバイダ(VCP)から、前記リモートプロセスを呼び出すために事前定義されたフィールドからのパラメータを用いるコードスニペットを受信するステップと、
    前記リモートサーバからダウンロードされたソフトウェア開発キット(SDK)を前記ユーザデバイスにインストールするステップと、
    前記ユーザデバイスのローカルコードベースに前記SDKに基づいて前記コードスニペットを挿入するステップと、
    前記コードスニペットにパラメータ値を挿入するとともに、前記コードスニペットを展開するステップであって、これにより、前記コードスニペットが、前記ユーザデバイスから前記SDKを用いてリモートプロセスを呼び出す、ステップとを含む、方法。
  2. 前記コードスニペットは、前記ローカルコードベースのプログラミング言語と同じであるプログラミング言語で前記VCP上で生成される、請求項1に記載の方法。
  3. 前記SDKをインストールするステップは、前記ユーザデバイスの総合開発環境(IDE)に前記SDKをインストールするステップをさらに含む、請求項1に記載の方法。
  4. 前記コードスニペットは、前記リモートサーバ上の少なくとも1つのVCPに、パラメータ値を用いるスニペットを展開することによって、前記リモートプロセスを呼び出す、請求項1に記載の方法。
  5. 前記少なくとも1つのVCPをホストしているリモートプラットフォームへ認証するステップをさらに含む、請求項1に記載の方法。
  6. 前記リモートプロセスを呼び出すための前記スニペットを展開するリアルタイムの結果を、前記ユーザデバイス上で表示する、請求項1に記載の方法。
  7. 前記リモートプロセスを選択するステップは、前記コードスニペットを生成するためにプログラミング言語を選択するステップをさらに含む、請求項1に記載の方法。
  8. 前記コードスニペットは、前記ユーザデバイス上で生成される、請求項1に記載の方法。
  9. 前記コードスニペットを展開するステップは、前記VCPにアクセスするために前記インストールされたSDKを用いて調整するステップをさらに含む、請求項1に記載の方法。
  10. 前記インストールされたSDKは、従来型のサービス構成要素(CSC)に対応するSDKをさらに調整する、請求項9に記載の方法。
  11. パラメータ値は、前記ユーザデバイスに表示された事前定義されたフィールドから挿入される、請求項1に記載の方法。
  12. ユーザデバイスにおけるリモートプロセスコールの仮想化のためのシステムであって、
    a)少なくとも1つのプロセッサと、
    b)少なくとも1つのネットワークに結合された少なくとも1つの入力デバイスと、
    c)前記少なくとも1つのプロセッサによって実行されたときに、
    i.リモートサーバ上のリモートプロセスを選択するステップであって、前記リモートプロセスは、少なくとも1つのリモートサービスと相関される、ステップと、
    ii.前記リモートサーバ上の少なくとも1つの仮想コードプロバイダ(VCP)から、前記リモートプロセスを呼び出すために事前定義されたフィールドからのパラメータを用いるコードスニペットを受信するステップと、
    iii.前記リモートサーバからダウンロードされたソフトウェア開発キット(SDK)を前記ユーザデバイスにインストールするステップと、
    iv.前記ユーザデバイスのローカルコードベースに前記SDKに基づいて前記コードスニペットを挿入するステップと、
    v.前記コードスニペットにパラメータ値を挿入するとともに、前記コードスニペットを展開するステップであって、これにより、前記コードスニペットが、前記ユーザデバイスから前記SDKを用いてリモートプロセスを呼び出す、ステップと
    を含む方法を実行するプロセッサで実行可能な命令を格納する少なくとも1つのストレージデバイスと
    を含む、システム。
  13. 前記コードスニペットは、前記ローカルコードベースのプログラミング言語と同じであるプログラミング言語で前記VCP上で生成される、請求項12に記載のシステム。
  14. 前記SDKをインストールするステップは、前記ユーザデバイスの総合開発環境(IDE)に前記SDKをインストールするステップをさらに含む、請求項12に記載のシステム。
  15. 前記コードスニペットは、前記リモートサーバ上の少なくとも1つのVCPに、パラメータ値を用いるスニペットを展開することによって、前記リモートプロセスを呼び出す、請求項12に記載のシステム。
JP2016521518A 2013-06-18 2014-06-17 コードの仮想化およびリモートプロセスコール生成のための方法および装置 Active JP6494610B2 (ja)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201361836628P 2013-06-18 2013-06-18
US61/836,628 2013-06-18
US201361842906P 2013-07-03 2013-07-03
US61/842,906 2013-07-03
PCT/US2014/042783 WO2014204989A1 (en) 2013-06-18 2014-06-17 Method and apparatus for code virtualization and remote process call generation

Publications (2)

Publication Number Publication Date
JP2016525742A JP2016525742A (ja) 2016-08-25
JP6494610B2 true JP6494610B2 (ja) 2019-04-03

Family

ID=52020422

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2016521518A Active JP6494610B2 (ja) 2013-06-18 2014-06-17 コードの仮想化およびリモートプロセスコール生成のための方法および装置
JP2016521515A Active JP6494608B2 (ja) 2013-06-18 2014-06-17 コードの仮想化およびリモートプロセスコール生成のための方法および装置

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2016521515A Active JP6494608B2 (ja) 2013-06-18 2014-06-17 コードの仮想化およびリモートプロセスコール生成のための方法および装置

Country Status (10)

Country Link
US (4) US9235383B2 (ja)
EP (2) EP3011444B1 (ja)
JP (2) JP6494610B2 (ja)
KR (2) KR102243793B1 (ja)
CN (2) CN105849691B (ja)
CA (2) CA2915620C (ja)
DK (1) DK3011444T3 (ja)
HK (2) HK1225472A1 (ja)
SG (2) SG11201510303QA (ja)
WO (2) WO2014204989A1 (ja)

Families Citing this family (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10997531B2 (en) 2007-09-11 2021-05-04 Ciambella Ltd. System, method and graphical user interface for workflow generation, deployment and/or execution
US10981371B2 (en) 2008-01-19 2021-04-20 Entrotech, Inc. Protected graphics and related methods
US9235383B2 (en) 2013-06-18 2016-01-12 Caimbella Ltd. Method and apparatus for code virtualization and remote process call generation
WO2015006599A1 (en) 2013-07-12 2015-01-15 Ciambella Ltd. Method and apparatus for firmware virtualization
US9697374B2 (en) * 2014-02-19 2017-07-04 Microsoft Technology Licensing, Llc Data proxy service
US10095495B2 (en) 2015-05-08 2018-10-09 Ciambella Ltd. Method and apparatus for automatic software development for a group of controller-based devices
CN108604186B (zh) 2015-12-21 2021-11-16 西安姆贝拉有限公司 用于创建和管理基于控制器的远程解决方案的方法和装置
US11087249B2 (en) 2016-05-24 2021-08-10 Ciambella Ltd. Method and apparatus for triggering execution of a workflow over a network
US10798780B2 (en) 2016-08-22 2020-10-06 Ciambella Ltd. Method and apparatus for creating and managing controller based remote solutions
CN106789740B (zh) * 2016-11-11 2019-12-10 中国人民解放军海军航空大学 按任务优先级序贯拍卖的多平台传感器协同管理方法
US10409562B2 (en) 2017-03-14 2019-09-10 Ciambella Ltd. Method and apparatus for automatically generating and incorporating code in development environments
WO2018236691A1 (en) * 2017-06-20 2018-12-27 Vfunction, Inc. SYSTEMS AND METHODS FOR PERFORMING SOFTWARE APPLICATIONS ON DISTRIBUTED APPLICATION DEVELOPMENT ENVIRONMENTS
CN108091384B (zh) * 2017-11-09 2021-07-09 南京耐久软件科技有限公司 一种基于微服务框架的医学影像处理系统
CN111417907A (zh) 2017-12-01 2020-07-14 西安姆贝拉有限公司 创建和管理智能可编程逻辑控制器解决方案的方法和装置
CN110032454A (zh) * 2018-01-12 2019-07-19 北京京东尚科信息技术有限公司 远程调用方法、系统和相关设备及计算机可读存储介质
CN110837378B (zh) * 2018-08-16 2021-07-02 腾讯科技(深圳)有限公司 软件开发工具包sdk功能的调用方法及装置
US11468158B2 (en) * 2019-04-10 2022-10-11 At&T Intellectual Property I, L.P. Authentication for functions as a service
US10628244B1 (en) * 2019-10-29 2020-04-21 Snowflake Inc. Calling external functions from a data warehouse
CN111158777B (zh) * 2019-12-12 2023-10-27 中移(杭州)信息技术有限公司 组件调用方法、装置及计算机可读存储介质
CN111949421B (zh) * 2020-08-12 2023-09-05 北京奇艺世纪科技有限公司 Sdk调用方法、装置、电子设备和计算机可读存储介质
US20230177143A1 (en) * 2021-12-03 2023-06-08 International Business Machines Corporation Operating a secure code segment on a processor core of a processing unit
KR102407940B1 (ko) * 2021-12-06 2022-06-13 주식회사 플랜티넷 Rpc에 기반하여 외부 장치의 함수 또는 프로시저를 호출하는 전자 장치가 rpc 서비스를 사용하기 위한 인터페이스를 생성하는 방법, 그 컴퓨터 프로그램 및 그 전자 장치
KR102407941B1 (ko) * 2021-12-06 2022-06-13 주식회사 플랜티넷 Rpc에 기반하여 외부 장치의 함수 또는 프로시저를 호출하는 전자 장치가 사용자 인터페이스를 생성하는 방법, 그 컴퓨터 프로그램 및 그 전자 장치

Family Cites Families (165)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5623604A (en) 1992-11-18 1997-04-22 Canon Information Systems, Inc. Method and apparatus for remotely altering programmable firmware stored in an interactive network board coupled to a network peripheral
US6108715A (en) * 1994-12-13 2000-08-22 Microsoft Corporation Method and system for invoking remote procedure calls
US5887172A (en) * 1996-01-10 1999-03-23 Sun Microsystems, Inc. Remote procedure call system and method for RPC mechanism independent client and server interfaces interoperable with any of a plurality of remote procedure call backends
US5852733A (en) 1996-12-16 1998-12-22 Chien; Yung-Ping S. Microcontroller development tool using software programs
US6366300B1 (en) 1997-03-11 2002-04-02 Mitsubishi Denki Kabushiki Kaisha Visual programming method and its system
US6266809B1 (en) 1997-08-15 2001-07-24 International Business Machines Corporation Methods, systems and computer program products for secure firmware updates
US6065053A (en) 1997-10-01 2000-05-16 Micron Electronics, Inc. System for resetting a server
US6158031A (en) 1998-09-08 2000-12-05 Lucent Technologies, Inc. Automated code generating translator for testing telecommunication system devices and method
US6324681B1 (en) 1998-10-01 2001-11-27 Unisys Corporation Automated development system for developing applications that interface with both distributed component object model (DCOM) and enterprise server environments
US6401156B1 (en) 1999-08-23 2002-06-04 Advanced Micro Devices, Inc. Flexible PC/AT-compatible microcontroller
US6490723B1 (en) * 1999-11-30 2002-12-03 Dell Products L.P. Method and system for installing files in a computing system
US6922685B2 (en) * 2000-05-22 2005-07-26 Mci, Inc. Method and system for managing partitioned data resources
US7043715B1 (en) * 2000-06-06 2006-05-09 Emc Corporation Method and apparatus for customizing software
US7376904B2 (en) 2000-06-13 2008-05-20 National Instruments Corporation Automatic generation of programs with GUI controls for interactively setting or viewing values
US20030037181A1 (en) * 2000-07-07 2003-02-20 Freed Erik J. Method and apparatus for providing process-container platforms
US7127705B2 (en) * 2000-09-06 2006-10-24 Oracle International Corporation Developing applications online
US6907446B1 (en) 2000-10-16 2005-06-14 Implicit Networks, Inc. Method and system for dynamic delivery of beads
US20020111995A1 (en) 2001-02-14 2002-08-15 Mansour Peter M. Platform-independent distributed user interface system architecture
US6931288B1 (en) 2001-04-16 2005-08-16 Rockwell Automation Technologies, Inc. User interface and system for creating function block diagrams
US20020194608A1 (en) 2001-04-26 2002-12-19 Goldhor Richard S. Method and apparatus for a playback enhancement system implementing a "Say Again" feature
US8131827B2 (en) 2001-05-09 2012-03-06 Rockwell Automation Technologies, Inc. PLC with web-accessible program development software
US7103641B2 (en) 2001-06-18 2006-09-05 Intel Corporation Method and apparatus for distributing computer platform firmware across a network
US6993642B2 (en) * 2001-07-24 2006-01-31 Microsoft Corporation Method and system for creating and employing an operating system having selected functionality
US7039892B2 (en) 2001-07-24 2006-05-02 Hewlett-Packard Development Company, L.P. Systems and methods for ensuring correct connectivity between circuit designs
US8086664B2 (en) 2001-09-24 2011-12-27 Siemens Industry, Inc. Method and apparatus for programming programmable controllers and generating configuration data from a centralized server
CA2460208A1 (en) * 2001-09-28 2003-04-10 British Telecommunications Public Limited Company An integrity manager for delaying client service requests
US6895573B2 (en) 2001-10-26 2005-05-17 Resultmaker A/S Method for generating a workflow on a computer, and a computer system adapted for performing the method
US7143360B1 (en) 2001-10-29 2006-11-28 Cypress Semiconductor Corporation Pin-out connections/drive levels direct-set by drop down list
US7320126B2 (en) 2001-11-06 2008-01-15 Sandisk Corporation Implementation of in system programming to update firmware on memory cards
US6966039B1 (en) 2001-11-19 2005-11-15 Cypress Semiconductor Corp. Method for facilitating microcontroller programming
US7086014B1 (en) 2001-11-19 2006-08-01 Cypress Semiconductor Corporation Automatic generation of application program interfaces, source code, interrupts, and datasheets for microcontroller programming
US7010773B1 (en) 2001-11-19 2006-03-07 Cypress Semiconductor Corp. Method for designing a circuit for programmable microcontrollers
US6715132B1 (en) 2001-11-19 2004-03-30 Cypress Semiconductor Corporation Datasheet browsing and creation with data-driven datasheet tabs within a microcontroller design tool
US20030120707A1 (en) 2001-12-21 2003-06-26 Sander Bogdan Systems and methods for exporting functionality of a modularized system
US7346672B2 (en) 2002-03-12 2008-03-18 Hewlett-Packard Development Company, L.P. Automatic TFTP firmware download
US20030204560A1 (en) 2002-04-26 2003-10-30 Chen Thomas C.H. Programmable Logic Controller with embedded Intelligent Web Server
US8074201B2 (en) 2002-07-10 2011-12-06 National Instruments Corporation Deployment and execution of a program on an embedded device
WO2004006299A2 (en) 2002-07-03 2004-01-15 Tokyo Electron Limited Method for dynamic sensor configuration and runtime execution
FR2841998B1 (fr) * 2002-07-04 2004-10-22 Canon Kk Procede d'execution sur une station d'un reseau de communication d'un programme informatique represente dans un langage de balisage
SE524627C2 (sv) 2002-10-07 2004-09-07 Abb Research Ltd Trådlös regulator och förfarande för styrning av en anordning anordnad relativt en robot
US7457815B2 (en) 2003-03-27 2008-11-25 Apple Inc. Method and apparatus for automatically providing network services
US7478141B2 (en) 2003-06-26 2009-01-13 Intel Corporation Accessing firmware of a remote computer system using a remote firmware interface
US7246319B2 (en) 2003-08-22 2007-07-17 Idx Systems Corporation Information system supporting customizable user interfaces and process flows
EP1530139A1 (en) 2003-11-05 2005-05-11 Sap Ag Method and computer system for workflow management
US8104043B2 (en) 2003-11-24 2012-01-24 Microsoft Corporation System and method for dynamic cooperative distributed execution of computer tasks without a centralized controller
US7331047B2 (en) 2003-11-25 2008-02-12 Microsoft Corporation Deterministic system and method for implementing software distributed between a desktop and a remote device
GB2411495A (en) 2004-02-27 2005-08-31 Cyan Holdings Ltd Method and apparatus for generating configuration data
US20050198624A1 (en) * 2004-03-02 2005-09-08 Chipman Timothy W. Method and system for program transformation
US7574512B2 (en) 2004-04-15 2009-08-11 Schneider Automation Sas MODBUS encapsulated transport interface
US20060036755A1 (en) 2004-05-07 2006-02-16 Abdullah Ibrahim S Meta-protocol
US7810099B2 (en) 2004-06-17 2010-10-05 International Business Machines Corporation Optimizing workflow execution against a heterogeneous grid computing topology
US7526534B2 (en) * 2004-07-16 2009-04-28 Cassatt Corporation Unified system services layer for a distributed processing system
US20060041854A1 (en) 2004-07-22 2006-02-23 Steven Schlanger Devices and methods for programming microcontrollers
US20060020910A1 (en) 2004-07-22 2006-01-26 Steven Schlanger Devices and methods for communicating with a microcontroller
NZ553600A (en) * 2004-08-13 2008-12-24 Remasys Pty Ltd Monitoring and management of distributed information systems
JP2006079447A (ja) 2004-09-10 2006-03-23 Fujitsu Ltd 集積回路設計支援装置、集積回路設計支援方法及び集積回路設計支援プログラム
US20060090154A1 (en) * 2004-10-07 2006-04-27 International Business Machines Corp. System and method for contributing remote object content to an integrated development environment type-ahead
US7603562B2 (en) 2005-02-02 2009-10-13 Insyde Software Corporation System and method for reducing memory requirements of firmware
US7530059B2 (en) 2005-02-18 2009-05-05 International Business Machines Corporation Method for inlining native functions into compiled java code
AU2006247999A1 (en) * 2005-04-20 2006-11-23 Videoegg, Inc. Browser enabled video manipulation
US9317259B2 (en) 2005-05-12 2016-04-19 International Business Machines Corporation Apparatus, system, and method for automatically generating a reusable software component for interfacing with a web service
US7716388B2 (en) 2005-05-13 2010-05-11 Texas Instruments Incorporated Command re-ordering in hub interface unit based on priority
US7558915B2 (en) 2005-06-06 2009-07-07 Dell Products L.P. System and method for updating the firmware of a device in a storage network
KR100714693B1 (ko) * 2005-06-07 2007-05-04 삼성전자주식회사 소프트웨어 모듈의 독립성을 보장하는 데이터베이스어플리케이션을 구현하는 시스템 및 방법
JP5618480B2 (ja) * 2005-08-19 2014-11-05 グーグル インコーポレイテッド プラグインモジュールからの情報コンテンツをユーザーインターフェース内で表示するためのソフトウエアアーキテクチャ
US8055386B2 (en) 2005-08-22 2011-11-08 Trane International Inc. Building automation system data management
US20070073771A1 (en) * 2005-09-28 2007-03-29 Baikov Chavdar S Method and system for directly mapping web services interfaces and java interfaces
US7481361B2 (en) 2005-09-29 2009-01-27 International Business Machines Corporation Method and system for identifying unsafe synthetic transactions and modifying parameters for automated playback
US20070174037A1 (en) 2005-11-10 2007-07-26 Chuan-Po Ling Multiple-microcontroller emulation system, multiple-microcontroller integrated development environment, and method for the same
US7836303B2 (en) * 2005-12-09 2010-11-16 University Of Washington Web browser operating system
US20070142929A1 (en) * 2005-12-16 2007-06-21 Microsoft Corporation Specifying optional and default values for method parameters
US8572560B2 (en) * 2006-01-10 2013-10-29 International Business Machines Corporation Collaborative software development systems and methods providing automated programming assistance
US7813909B2 (en) 2006-05-03 2010-10-12 Sony Computer Entertainment Inc. Register mapping in emulation of a target system on a host system
US7741920B2 (en) 2006-02-10 2010-06-22 Broadcom Corporation Quadrature oscillator with simplified amplitude, phase and frequency control
US8028258B1 (en) 2006-02-16 2011-09-27 Cypress Semiconductor Corporation Interactive graphical pin assignment
KR100687762B1 (ko) 2006-03-07 2007-02-27 한국전자통신연구원 코드 해석 장치, 코드정보 제공 장치 및 이를 이용한 방법
US7627838B2 (en) 2006-04-25 2009-12-01 Cypress Semiconductor Corporation Automated integrated circuit development
JP4808558B2 (ja) * 2006-07-12 2011-11-02 日本電信電話株式会社 連携シナリオ作成支援システム及びその方法並びにプログラム
US7886234B2 (en) 2006-10-13 2011-02-08 Mediatek Inc. Systems and methods for creating embedded target images
US20080109782A1 (en) 2006-10-18 2008-05-08 Utstarcom, Inc. Method and system for pin assignment
KR20080044576A (ko) 2006-11-17 2008-05-21 오종택 애드혹 통신 네트워크를 이용한 전력분산 장치 및 시스템과그 방법
JP2008165340A (ja) * 2006-12-27 2008-07-17 Fujitsu Ltd 遠隔手続呼出方式
US8645148B2 (en) * 2006-12-29 2014-02-04 The Boeing Company Methods and apparatus providing an E-enabled ground architecture
US8316427B2 (en) * 2007-03-09 2012-11-20 International Business Machines Corporation Enhanced personal firewall for dynamic computing environments
CN201017215Y (zh) 2007-03-29 2008-02-06 王忠伟 一种终端控制器
US8612972B2 (en) * 2007-06-27 2013-12-17 Microsoft Corporation Running add-on components in virtual environments
US10997531B2 (en) * 2007-09-11 2021-05-04 Ciambella Ltd. System, method and graphical user interface for workflow generation, deployment and/or execution
WO2009073932A1 (en) 2007-12-13 2009-06-18 Labtronics Technology Pty Ltd Application specific virtual real-time operating system compiler
US8230113B2 (en) * 2007-12-29 2012-07-24 Amx Llc System, method, and computer-readable medium for development and deployment of self-describing controlled device modules in a control system
US20090198770A1 (en) 2008-02-04 2009-08-06 Universal Scientific Industrial Co., Ltd. System and method of updating codes in controller
US8793662B2 (en) * 2008-03-25 2014-07-29 Microsoft Corporation Runtime code hooking for print driver and functionality testing
US8245186B2 (en) * 2008-04-03 2012-08-14 Microsoft Corporation Techniques for offering and applying code modifications
US9454390B2 (en) * 2008-04-04 2016-09-27 Intuit Inc. Executable code generated from common source code
US20090265719A1 (en) * 2008-04-18 2009-10-22 Microsoft Corporation Application macro recording utilizing method interception
US9311115B2 (en) 2008-05-13 2016-04-12 Apple Inc. Pushing a graphical user interface to a remote device with display rules provided by the remote device
US8099332B2 (en) 2008-06-06 2012-01-17 Apple Inc. User interface for application management for a mobile device
US8249950B2 (en) * 2008-07-11 2012-08-21 Ebay Inc. Payment mechanism integration wizard
US8321226B2 (en) * 2008-08-08 2012-11-27 Hewlett-Packard Development Company, L.P. Generating speech-enabled user interfaces
AU2008361120B2 (en) 2008-08-25 2015-05-28 Marici Holdings The Netherlands B.V. A hardware virtualization system
US9411864B2 (en) * 2008-08-26 2016-08-09 Zeewise, Inc. Systems and methods for collection and consolidation of heterogeneous remote business data using dynamic data handling
CN101373441B (zh) 2008-09-19 2012-04-18 苏州壹世通科技有限公司 一种基于固件的虚拟化平台系统
US8271958B2 (en) 2008-12-12 2012-09-18 Microsoft Corporation Remapping debuggable code
KR101042908B1 (ko) * 2009-02-12 2011-06-21 엔에이치엔(주) 네트워크 분리 장애 상황에서 메이저 그룹을 결정하기 위한방법, 시스템, 및 컴퓨터 판독 가능한 기록 매체
DE102009011679A1 (de) 2009-02-23 2010-08-26 Pilz Gmbh & Co. Kg Verfahren und Vorrichtung zum Erstellen eines Anwenderprogrammes für eine Sicherheitssteuerung
US8948067B2 (en) 2009-04-23 2015-02-03 Honeywell International Inc. Wireless controller grids for process control and other systems and related apparatus and method
US20100287571A1 (en) 2009-05-07 2010-11-11 Cypress Semiconductor Corporation Development, programming, and debugging environment
EP2433257A4 (en) 2009-05-19 2014-07-30 Nholdings Sa PROVIDING A LOCAL DEVICE OF COMPUTER SERVICES FROM A REMOTE HOST
CA2698066A1 (en) * 2009-07-31 2011-01-31 Nitobi Software Inc. System and method for remotely compiling multi-platform native applications for mobile devices
US8949792B2 (en) * 2009-08-18 2015-02-03 Adobe Systems Incorporated Methods and systems for data service development
US8214653B1 (en) 2009-09-04 2012-07-03 Amazon Technologies, Inc. Secured firmware updates
US8707161B2 (en) * 2009-09-30 2014-04-22 Facebook, Inc. Executing server side script code specified using PHP on a server to generate dynamic web pages
CN101697125B (zh) 2009-11-04 2013-05-08 中兴通讯股份有限公司 一种开发环境转换的方法及装置
US8533667B2 (en) * 2009-12-30 2013-09-10 International Business Machines Corporation Call wizard for information management system (IMS) applications
JP2011150430A (ja) 2010-01-19 2011-08-04 Kyocera Mita Corp Sdk配布パッケージ生成装置、sdk配布パッケージ生成方法、およびsdk配布パッケージ生成プログラム
US8869138B2 (en) 2011-11-11 2014-10-21 Wyse Technology L.L.C. Robust firmware update with recovery logic
US8775781B2 (en) 2010-03-25 2014-07-08 Microsoft Corporation Intelligent boot device selection and recovery
CN102262557B (zh) * 2010-05-25 2015-01-21 运软网络科技(上海)有限公司 通过总线架构构建虚拟机监控器的方法及性能服务框架
US8655461B2 (en) 2010-05-25 2014-02-18 Siemens Product Lifecycle Management Software Inc. Method, system, and non-transitory computer readable storage medium for generating code for a closed-loop controller
US8959363B2 (en) 2010-06-03 2015-02-17 Intel Corporation Systems, methods, and apparatus to virtualize TPM accesses
US9063753B2 (en) * 2010-06-22 2015-06-23 Sap Se Scripting framework for business objects
US8938721B2 (en) * 2010-07-21 2015-01-20 Microsoft Corporation Measuring actual end user performance and availability of web applications
US8479154B1 (en) 2010-08-20 2013-07-02 Google Inc. Interaction with partially constructed mobile device applications
CN102479079B (zh) 2010-11-29 2015-04-01 中兴通讯股份有限公司 应用生成方法和装置
US8694954B2 (en) 2010-11-29 2014-04-08 Norman Ortiz System and methods for mobile application development using mobile devices
CN103403685B (zh) * 2010-12-30 2015-05-13 艾新顿公司 在线隐私管理
US9678747B2 (en) * 2011-02-08 2017-06-13 Openspan, Inc. Code injection and code interception in an operating system with multiple subsystem environments
US20120204161A1 (en) * 2011-02-09 2012-08-09 Particle Code, Inc. Automated Code Map Generation for an Application Programming Interface of a Programming Language
US8621442B2 (en) * 2011-02-09 2013-12-31 Beek Fund B.V. L.L.C. Quicker translation of a computer program source code
US8903943B2 (en) * 2011-02-15 2014-12-02 Salesforce.Com, Inc. Integrating cloud applications and remote jobs
US20120233589A1 (en) * 2011-03-10 2012-09-13 Infosys Technologies Ltd. Software development kit for blended services
US20120233588A1 (en) * 2011-03-10 2012-09-13 Infosys Technologies Ltd. Blended service creation, test, and deployment environment for multiple service endpoints
CN102999322A (zh) 2011-09-16 2013-03-27 深圳市吉阳自动化科技有限公司 一种工业控制器软件界面设计方法
US8554150B2 (en) 2011-10-18 2013-10-08 Thomas Benjamin Smith Multi-wan module
US8959477B2 (en) * 2011-10-21 2015-02-17 Sap Se Scripting language for business applications
US8997070B2 (en) * 2011-12-15 2015-03-31 Sap Se Extension mechanism for scripting language compiler
US9571591B2 (en) * 2011-12-28 2017-02-14 Dynatrace Llc Method and system for tracing end-to-end transaction which accounts for content update requests
US20130201316A1 (en) 2012-01-09 2013-08-08 May Patents Ltd. System and method for server based control
CN104919381B (zh) 2012-01-23 2018-05-04 施耐德电气建筑有限公司 可编程的外围设备
EP2688029A1 (en) 2012-04-11 2014-01-22 Taboola.com Ltd. Click through rate estimation in varying display situations
WO2013152431A1 (en) 2012-04-12 2013-10-17 Absolute Software Corporation Configuration of third party applications in a sandboxed environment
KR20130115729A (ko) 2012-04-13 2013-10-22 삼성전자주식회사 디스플레이장치, 리모컨 및 그 제어방법
US20140013299A1 (en) * 2012-07-06 2014-01-09 Microsoft Corporation Generalization and/or specialization of code fragments
JPWO2014041623A1 (ja) 2012-09-12 2016-08-12 株式会社日立システムズ 施設ユーザインタフェース配信システム
KR101484529B1 (ko) 2012-10-08 2015-01-20 후아웨이 디바이스 컴퍼니 리미티드 터치스크린 장치 사용자 인터페이스 프로세싱 방법 및 터치스크린 장치
US9292416B2 (en) * 2012-10-12 2016-03-22 Vmware, Inc. Software development kit testing
US9015694B2 (en) 2012-10-31 2015-04-21 Aruba Networks, Inc Cloud-based firmware distribution service
CN103914018A (zh) 2012-12-31 2014-07-09 施耐德电器工业公司 可编程控制器的编程辅助系统及方法
US9104525B2 (en) * 2013-01-22 2015-08-11 Microsoft Technology Licensing, Llc API usage pattern mining
US20140215433A1 (en) * 2013-01-30 2014-07-31 Oracle International Corporation Class oriented file format for modeling and persisting bpmn scripting code
US9509745B2 (en) * 2013-02-04 2016-11-29 Oracle International Corporation Java API for programming web real-time communication applications
US9372785B2 (en) * 2013-03-07 2016-06-21 Microsoft Technology Licensing, Llc Identifying implicit assumptions associated with a software product
US9465717B2 (en) * 2013-03-14 2016-10-11 Riverbed Technology, Inc. Native code profiler framework
US20140372983A1 (en) 2013-06-14 2014-12-18 Microsoft Corporation Identifying the introduction of a software failure
JP6494609B2 (ja) 2013-06-18 2019-04-03 チャンベッラ・リミテッド カスタマイズされたソフトウェア開発キット(sdk)生成のための方法および装置
US9235383B2 (en) 2013-06-18 2016-01-12 Caimbella Ltd. Method and apparatus for code virtualization and remote process call generation
US10296297B2 (en) * 2013-08-09 2019-05-21 Oracle International Corporation Execution semantics for sub-processes in BPEL
US9451043B2 (en) * 2013-09-13 2016-09-20 Evie Labs, Inc. Remote virtualization of mobile apps
US20150127192A1 (en) 2013-11-06 2015-05-07 Hitachi, Ltd Wireless vehicle control system
US9619122B2 (en) 2014-01-10 2017-04-11 Ciambella Ltd. Method and apparatus for automatic device program generation
EP3092561A4 (en) 2014-01-10 2017-11-22 Ciambella Ltd. Method and apparatus for automatic device program generation
CN109976645B (zh) 2014-06-20 2023-04-07 华为技术有限公司 应用界面的展示方法、装置及电子设备
JP6441061B2 (ja) 2014-12-16 2018-12-19 株式会社ダイヘン 機械制御システム及び機械制御システムのユーザインタフェース設定方法
US20170045981A1 (en) 2015-08-10 2017-02-16 Apple Inc. Devices and Methods for Processing Touch Inputs Based on Their Intensities
US10067490B2 (en) 2015-05-08 2018-09-04 Ciambella Ltd. Method and apparatus for modifying behavior of code for a controller-based device
US9547482B2 (en) 2015-06-02 2017-01-17 Sap Portals Israel Ltd. Declarative design-time experience platform for code generation

Also Published As

Publication number Publication date
CA2915620C (en) 2022-12-13
EP3011443A4 (en) 2017-03-08
US20160124719A1 (en) 2016-05-05
US20140372975A1 (en) 2014-12-18
CN105849691B (zh) 2019-09-13
EP3011444A1 (en) 2016-04-27
SG11201510303QA (en) 2016-01-28
KR20160058744A (ko) 2016-05-25
CA2912852C (en) 2023-09-26
HK1225474A1 (zh) 2017-09-08
DK3011444T3 (en) 2018-04-16
US20140372972A1 (en) 2014-12-18
US20160364254A1 (en) 2016-12-15
US9235383B2 (en) 2016-01-12
WO2014204989A1 (en) 2014-12-24
US10055238B2 (en) 2018-08-21
HK1225472A1 (zh) 2017-09-08
KR102243793B1 (ko) 2021-04-26
US10853108B2 (en) 2020-12-01
JP2016525742A (ja) 2016-08-25
US9436439B2 (en) 2016-09-06
CA2912852A1 (en) 2014-12-24
KR102218995B1 (ko) 2021-02-25
EP3011444B1 (en) 2018-02-21
KR20160060023A (ko) 2016-05-27
SG11201510304TA (en) 2016-01-28
JP6494608B2 (ja) 2019-04-03
CN105814539B (zh) 2019-09-13
JP2016527610A (ja) 2016-09-08
CN105814539A (zh) 2016-07-27
WO2014204984A1 (en) 2014-12-24
EP3011443A1 (en) 2016-04-27
CN105849691A (zh) 2016-08-10
EP3011444A4 (en) 2017-01-25
CA2915620A1 (en) 2014-12-24

Similar Documents

Publication Publication Date Title
JP6494610B2 (ja) コードの仮想化およびリモートプロセスコール生成のための方法および装置
JP6494609B2 (ja) カスタマイズされたソフトウェア開発キット(sdk)生成のための方法および装置
CN111373402B (zh) 轻量去中心化应用平台
CN111386523A (zh) 用于基于区块链的去中心化应用开发的系统和方法
Colombo-Mendoza et al. MobiCloUP!: a PaaS for cloud services-based mobile applications
Kanikathottu Serverless Programming Cookbook: Practical solutions to building serverless applications using Java and AWS
Aryal MERN stack with modern web practices
Sharma Modern API Development with Spring 6 and Spring Boot 3: Design scalable, viable, and reactive APIs with REST, gRPC, and GraphQL using Java 17 and Spring Boot 3
Doglio et al. Working with Modules

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20170616

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20180613

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20180618

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180914

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20181022

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190118

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20190204

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20190305

R150 Certificate of patent or registration of utility model

Ref document number: 6494610

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250