2 * @fileOverview BusInOutクラスを定義します。
\r
10 * <a href="https://mbed.org/handbook/BusInOut">mbed::BusInOut</a>と同等の機能を持ちます。
\r
11 * @name mbedJS.BusInOut
\r
13 * @param {mbedJS.Mcu} i_mcu
\r
14 * インスタンスをバインドするMCUオブジェクトです。
\r
15 * @param {[PinName...]} i_params
\r
16 * ピンIDの配列を指定します。要素数の最大値は16です。
\r
17 * @param {HashMap|Generator|function} i_handler
\r
18 * 非同期イベントハンドラの連想配列、Generator、コールバック関数の何れかを指定します。
\r
20 * 非同期イベントハンドラの場合、関数はイベントハンドラで結果を通知します。
\r
22 * <li>{function()} onNew -
\r
23 * インスタンスが使用可能になった時に呼び出されます。
\r
25 * <li>{function(v)} onRead -
\r
26 * read関数のコールバック関数です。
\r
28 * <li>{int} v - 現在のピンの値です。</li>
\r
31 * <li>{function()} onWrite -
\r
32 * write関数のコールバック関数です。
\r
35 * <li>{function()} onOutput -
\r
36 * output関数のコールバック関数です。
\r
38 * <li>{function()} onInput -
\r
39 * input関数のコールバック関数です。
\r
41 * <li>{function()} onMode -
\r
42 * mode関数のコールバック関数です。
\r
46 * Generatorを指定した場合、コールバック関数の引数はyiledの戻り値として取得できます。
\r
49 * コールバック関数を指定した場合、RPCが完了したときに呼び出されます。メンバ関数のイベントハンドラは個別に設定する必要があります。
\r
51 * @return {mbedJS.BusIn}
\r
52 * @example //Callback
\r
53 * var mcu=new mbedJS.Mcu("192.168.128.39",
\r
56 * var bus=new mbedJS.BusInOut(mcu,[mbedJS.PinName.P0_21,mbedJS.PinName.P0_22],{
\r
58 * bus.mode(mbedJS.PinMode.PullDown);
\r
64 * onOutput:function()
\r
68 * onWrite:function()
\r
72 * onInput:function(){
\r
75 * onRead:function(v)
\r
80 * onClose:function(){
\r
82 * onError:function(){
\r
86 * @example //Generator
\r
87 * var g=function*(){
\r
89 * var mcu=new mbedJS.Mcu("192.168.128.39",g);
\r
90 * yield mcu.waitForNew();
\r
91 * var bus=new mbedJS.BusInOut(mcu,[mbedJS.PinName.P0_21,mbedJS.PinName.P0_22],g);
\r
92 * yield bus.waitForNew();
\r
93 * yield bus.mode(mbedJS.PinMode.PullDown);
\r
94 * yield bus.output();
\r
95 * yield bus.write(1);
\r
96 * yield bus.input();
\r
97 * var v=yield bus.read();
\r
98 * yield mcu.close();
\r
105 var CLASS=function BusInOut(i_mcu,i_params,i_handler)
\r
111 var cb=MI._initHandler.call(_t,i_handler);
\r
116 if(ap.length<1 ||ap.length>16){
\r
117 throw new MI.MiMicException(MI.NG_INVALID_ARG);
\r
121 for(;i<i_params.length;i++){
\r
125 pins+=","+NS.PinName.NC;
\r
127 _t._mcu.rpc(_t.RPC_NS+":_new1",pins,
\r
130 _t._oid=j.result[0];
\r
132 if(_t._gen){_t._gen.next(_t);}
\r
137 throw new MI.MiMicException(e);
\r
143 RPC_NS:"mbedJS:BusInOut",
\r
144 /** @private 最後にコールしたAPIです。*/
\r
146 /** @private Generatorモードの場合にGeneratorオブジェクトを保持します。*/
\r
148 /** @private コールバック関数の連想配列です。要素はコンストラクタを参照してください。*/
\r
150 /** @private リモートインスタンスのオブジェクトIDです。*/
\r
153 * Generatorモードのときに使用する関数です。
\r
154 * Generatorモードの時は、yieldと併用してnew BusInOut()の完了を待ちます。
\r
155 * @name mbedJS.BusInOut#waitForNew
\r
158 waitForNew:function BusInOut_waitForNew()
\r
161 if(this._lc!=CLASS){throw new MI.MiMicException(MI.Error.NG_ILLEGAL_CALL);}
\r
162 this._lc=CLASS.waitForNew;
\r
164 throw new MI.MiMicException(e);
\r
169 * 関数の完了時にonWriteイベントが発生します。
\r
170 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
171 * @name mbedJS.BusInOut#write
\r
173 * @param {int} i_value
\r
175 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
177 write:function BusInOut_write(i_value)
\r
181 var cb=MI._getCb(arguments,_t._event.onWrite);
\r
182 MI._assertYield.call(_t);
\r
183 _t._lc=CLASS.write;
\r
184 MI.assertInt(i_value);
\r
185 return _t._mcu.rpc(_t.RPC_NS+":write",_t._oid+","+i_value,
\r
188 if(_t._gen){_t._gen.next();}
\r
193 throw new MI.MiMicException(e);
\r
198 * 関数の完了時にonReadイベントが発生します。
\r
199 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
200 * @name mbedJS.BusInOut#read
\r
203 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
205 * Generatorモードの時はピンの値を返します。
\r
207 read:function BusInOut_read()
\r
211 var cb=MI._getCb(arguments,_t._event.onRead);
\r
212 MI._assertYield.call(_t);
\r
214 return _t._mcu.rpc(_t.RPC_NS+":read",_t._oid,
\r
219 if(_t._gen){_t._gen.next(v);}
\r
224 throw new MI.MiMicException(e);
\r
229 * 関数の完了時にonModeイベントが発生します。
\r
230 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
231 * @name mbedJS.BusInOut#mode
\r
233 * @param {PinMode} i_value
\r
236 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
238 mode:function BusInOut_mode(i_value)
\r
242 var cb=MI._getCb(arguments,_t._event.onMode);
\r
243 MI._assertYield.call(_t);
\r
245 MI.assertInt(i_value);
\r
246 return _t._mcu.rpc(_t.RPC_NS+":mode",_t._oid+","+i_value,
\r
251 if(_t._gen){_t._gen.next(v);}
\r
256 throw new MI.MiMicException(e);
\r
261 * 関数の完了時にonInputイベントが発生します。
\r
262 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
263 * @name mbedJS.BusInOut#input
\r
266 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
268 input:function BusInOut_input()
\r
272 var cb=MI._getCb(arguments,_t._event.onInput);
\r
273 MI._assertYield.call(_t);
\r
274 _t._lc=CLASS.input;
\r
275 return _t._mcu.rpc(_t.RPC_NS+":input",_t._oid,
\r
279 if(_t._gen){_t._gen.next();}
\r
283 throw new MI.MiMicException(e);
\r
288 * 関数の完了時にonOutputイベントが発生します。
\r
289 * Generatorモードの時は、yieldと併用して完了を待機できます。
\r
290 * @name mbedJS.BusInOut#output
\r
293 * Callbackモードの時はRPCメソッドのインデクスを返します。
\r
295 output:function BusInOut_output()
\r
299 var cb=MI._getCb(arguments,_t._event.onOutput);
\r
300 MI._assertYield.call(_t);
\r
302 return _t._mcu.rpc(_t.RPC_NS+":output",_t._oid,
\r
306 if(_t._gen){_t._gen.next();}
\r
310 throw new MI.MiMicException(e);
\r
314 * MCUに生成されているオブジェクトを破棄します。
\r
315 * @name mbedJS.BusInOut#dispose
\r
318 dispose:function BusInOut_dispose()
\r
320 return this._mcu._dispose.apply(this,arguments);
\r