OSDN Git Service

Version 0.6.205, bug fixes X.Net.Form, update X.HTMLAudio for iOS7+.
[pettanr/clientJs.git] / 0.6.x / js / 06_net / 00_XNet.js
index 3073cf3..469669d 100644 (file)
@@ -7,25 +7,25 @@
 \r
 \r
 /**\r
- * <p>busy() メソッドだけを持つ。通信用のプロパティは X.Pair によって隠蔽される\r
+ * <p>state() メソッドだけを持つ。通信用のプロパティは X.Pair によって隠蔽されています\r
  * <h4>通信のキャンセル</h4>\r
- * <p>kill() で通信待ち中はキャンセル&破棄、通信中の場合は通信の中断&破棄を行う。SUCCESS, ERROR, TIMEOUT イベント以降は kill() は無視される。\r
+ * <p>kill() で通信待ち中はキャンセル&破棄、通信中の場合は通信の中断&破棄を行う。\r
  * <h4>イベント</h4>\r
  * <dl>\r
  * <dt>X.Event.PROGRESS<dd>通信進行状況\r
  * <dt>X.Event.SUCCESS<dd>通信成功\r
- * <dt>X.Event.ERROR<dd>通信エラー\r
- * <dt>X.Event.TIMEOUT<dd>通信タイムアウト\r
- * <dt>X.Event.CANCELED<dd>通信のユーザー、プログラムによるキャンセル\r
- * <dt>X.Event.COMPLETE<dd>通信完了。SUCCESS, ERROR, TIMEOUT, CANCELED 後に発生。\r
+ * <dt>X.Event.ERROR<dd>通信エラー タイムアウトの場合、e.timeout == true で分かる。\r
+ * <dt>X.Event.CANCELED<dd>通信のユーザー、プログラムによるキャンセル。SUCCESS, ERROR, COMPLETE 後に kill()してもCANCELEDは呼ばれません。\r
+ * <dt>X.Event.COMPLETE<dd>通信完了。SUCCESS, ERROR, CANCELED 後に発生。\r
  * </dl>\r
  * <p>X.Net インスタンスは COMPLETE 後に自動で破棄される。\r
  * <h4>必須プロパティ</h4>\r
  * <dl>\r
  * <dt>url<dd>URL\r
- * <dt>type<dd>'xhr', 'jsonp', 'image', 'img'\r
+ * <dt>type<dd>'xhr', 'jsonp', 'form', 'image', 'img'\r
  * <dt>xhr<dd>URL { url : 'hoge', type : 'xhr' } の省略形\r
  * <dt>jsonp<dd>URL { url : 'hoge', type : 'jsonp' } の省略形\r
+ * <dt>form<dd>URL { url : 'hoge', type : 'form' } の省略形\r
  * <dt>image, img<dd>URL { url : 'hoge', type : 'image' } の省略形\r
  * </dl>\r
  * <h4>XHR 用プロパティ</h4>\r
  * <dt>params<dd>url パラメータを object で渡すことが出来る。\r
  * <dt>callbackName<dd>callback(json) コールバック名が固定されている際に指定。または &callback=hoge 以外の名前でコールバックを指定する場合に params と callbackName に書いておく。url パラメータに callback が無く、callbackName もない場合、フレームワーク内で自動で設定される\r
  * <dt>charset<dd>ページと異なるjsonpを読み込む場合に指定 'EUC-JP', 'Shift-JIS' 等 script タグの charset に入る。https://code.google.com/p/ajaxzip3/issues/detail?id=5\r
- * <dt>useFireWall<dd>異なるドメインに jsonp を読み込んだ後、xdomain iframe 通信を使ってデータを受け取る。不正なコードの実行を防ぐことが出来る、未実装\r
+ * <dt>useFireWall<dd>異なるドメインに jsonp を読み込んだ後、xdomain iframe 通信を使ってデータを受け取る。不正なコードの実行を防ぐことが出来る(はず)、未実装\r
  * </dl>\r
  * \r
  * <h4>Form 用プロパティ</h4>\r
  * <dl>\r
- * <dt>params<dd>url パラメータを object で渡すことが出来る。\r
  * <dt>method<dd>'GET' or 'POST'\r
- * <dt>target<dd>'_self', '_parent', '_top' の場合、ページから離脱する。target を指定せず同一ドメインの場合 response に body.innerHTML が返る。\r
+ * <dt>params<dd>パラメータ object は input タグの name & value に展開される。object を入れ子にすることはできない。\r
+ * <dt>target<dd>'_self', '_parent', '_top' の場合、ページから離脱する。target を指定せず同一ドメインの場合 response に body.innerHTML が返る。TODO X.Window\r
+ * <dt>timeout<dd>ms タイムアウト時間、省略可能\r
+ * <dt>charset<dd>未実装\r
  * </dl>\r
  * \r
  * @alias X.Net\r
@@ -91,9 +93,6 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
                'X.Net',\r
                X_Class.NONE,\r
                {\r
-                       'netType'    : '',\r
-                       'netName'    : '',\r
-                       'netVersion' : 0,\r
                        \r
                        'Constructor' : function( urlOrObject, opt_options ){\r
                                var opt, url, type, auth;\r
@@ -159,8 +158,8 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
                                        opt[ 'auth' ] = auth; // auth は deep copy されるとまずい\r
                                };\r
                                \r
-                               // params を url に追加\r
-                               if( opt[ 'params' ] ){\r
+                               // params を url に追加 但し form は除く\r
+                               if( opt[ 'params' ] && type !== X_NET_TYPE_FORM ){\r
                                        url = X_URL_create( url, opt[ 'params' ] );\r
                                        delete opt[ 'params' ];\r
                                };                              \r
@@ -170,7 +169,7 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
 \r
                                        // XDomain 不可 -> Flash, Gears, Silverlight, canUseGadget なら gadget に切替?\r
                                        // PUT DELETE UPDATE 不可 -> Flash, Gears, Silverlight, canUseGadget なら gadget に切替?\r
-                                       // xプロトコル な binary のロード -> gadget 内で proxyURL による XHR\r
+                                       // xプロトコル(X_URL_isSameProtocol) な binary のロード -> gadget 内で proxyURL による XHR\r
                                        //  or X_EVENT_ERROR\r
                                        \r
                                        opt[ 'dataType' ] = opt[ 'dataType' ] || X_URL_getEXT( url );\r
@@ -186,17 +185,9 @@ X[ 'Net' ] = X_EventDispatcher[ 'inherits' ](
                                X_NET_QUEUE_LIST[ X_NET_QUEUE_LIST.length ] = this;\r
                                !X_NET_currentQueue && X_NET_shiftQueue();\r
                        },\r
-                       \r
-               /**\r
-                * 現在通信中か?調べる。false の場合、通信の順番待ちか、通信が終了している。\r
-                * @alias Net.prototype.busy\r
-                */\r
-                       'busy' : function(){\r
-                               return this === X_NET_currentQueue && X_NET_currentWrapper._busy;\r
-                       },\r
 \r
                /**\r
-                * 現在の状態。1:待機中 2:通信中 3:通信完了フェーズ\r
+                * 現在の状態。1:順番待ち, 2:通信中, 3:通信完了フェーズ\r
                 * @alias Net.prototype.state\r
                 */\r
                        'state' : function(){\r
@@ -230,11 +221,11 @@ var X_NET_TYPE_XHR   = 1,
 \r
        X_NET_QUEUE_LIST = [],\r
 \r
-       X_NET_XHRWrapper,\r
-       X_NET_JSONPWrapper,\r
-       X_NET_FormWrapper,\r
-       X_NET_ImageWrapper,\r
-       X_NET_GIMRWrapper,\r
+       X_XHR,\r
+       X_JSONP,\r
+       X_FormSender,\r
+       X_ImgLoader,\r
+       X_GadgetXHR,\r
 \r
        X_NET_currentWrapper,\r
        X_NET_currentQueue,\r
@@ -247,9 +238,13 @@ function X_NET_proxyDispatch( e ){
        switch( e.type ){\r
                case X_EVENT_KILL_INSTANCE :\r
                        if( this === X_NET_currentQueue && X_NET_completePhase ){\r
-                               X_Pair_release( this );\r
+                               if( X_NET_completePhase === 1 ){\r
+                                       this[ 'unlisten' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
+                                               [ 'dispatch' ]( X_EVENT_COMPLETE );\r
+                               };\r
                                X_NET_shiftQueue();\r
-                               X_NET_completePhase = false;\r
+                               X_Pair_release( this );\r
+                               X_NET_completePhase = 0;\r
                        } else\r
                        if( this === X_NET_currentQueue ){\r
                                X_NET_currentWrapper.cancel();\r
@@ -275,22 +270,20 @@ function X_NET_proxyDispatch( e ){
                        if( e.status === 401 ){\r
                                if( auth = X_Pair_get( this )[ 'auth' ] ){\r
                                        X_Pair_get( auth ).onAuthError( auth, e );\r
+                                       // TODO 破棄しないで待機。\r
                                };\r
                        };\r
                        \r
                case X_EVENT_SUCCESS :\r
-                       X_NET_completePhase = true;\r
-                       this\r
-                               [ 'listenOnce' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
-                               [ 'asyncDispatch' ]( e );\r
-                       this[ 'asyncDispatch' ]( 32, { type : X_EVENT_COMPLETE, 'lastEventType' : e.type } );\r
+                       X_NET_completePhase = 1;\r
+                       this[ 'listenOnce' ]( X_EVENT_COMPLETE, X_NET_proxyDispatch )\r
+                               [ 'asyncDispatch' ]( 32, { type : X_EVENT_COMPLETE, 'lastEventType' : e.type } );\r
+\r
+                       this[ 'asyncDispatch' ]( e );\r
                        break;\r
 \r
                case X_EVENT_COMPLETE :\r
-                       X_Pair_release( this );\r
-                       X_NET_shiftQueue();\r
-                       X_NET_completePhase = false;\r
-                       this[ 'unlisten' ]( X_EVENT_KILL_INSTANCE, X_NET_proxyDispatch );\r
+                       X_NET_completePhase = 2;\r
                        this[ 'kill' ]();\r
                        break;\r
        };\r
@@ -301,14 +294,19 @@ function X_NET_shiftQueue(){
 \r
        if( X_NET_currentQueue ){\r
                if( X_NET_currentWrapper._busy ) return;\r
+               \r
                X_NET_currentWrapper\r
                        [ 'unlisten' ]( [ X_EVENT_PROGRESS, X_EVENT_SUCCESS, X_EVENT_ERROR ], X_NET_currentQueue, X_NET_proxyDispatch )\r
                        .reset();\r
+\r
                X_NET_currentQueue = X_NET_currentWrapper = X_NET_currentData = null;\r
        };\r
        \r
+       console.log( '■■------------ X_NET_shiftQueue ' + X_NET_QUEUE_LIST.length );\r
+       \r
        if( !X_NET_QUEUE_LIST.length ) return;\r
 \r
+\r
        X_NET_currentQueue = X_NET_QUEUE_LIST.shift();\r
        X_NET_currentData  = X_Pair_get( X_NET_currentQueue );\r
        \r
@@ -319,13 +317,13 @@ function X_NET_shiftQueue(){
                        // force 'gadget', 'flash'\r
                        switch( X_NET_currentData[ 'test' ] ){\r
                                case 'gadget' :\r
-                                       X_NET_currentWrapper = X_NET_GIMRWrapper || X_TEMP.X_Net_GIMR_init();\r
+                                       X_NET_currentWrapper = X_GadgetXHR || X_TEMP.X_GadgetXHR_init();\r
                                        break;\r
                                case 'flash'  :\r
                                        break;\r
                                \r
                                default :\r
-                                       X_NET_currentWrapper = X_NET_XHRWrapper || X_TEMP.X_Net_XHR_init();\r
+                                       X_NET_currentWrapper = X_XHR || X_TEMP.X_XHR_init();\r
                        };\r
                        \r
                        \r
@@ -336,8 +334,9 @@ function X_NET_shiftQueue(){
                                        case 0 :\r
                                        case 1 :\r
                                        case 2 :\r
-                                               if( !( auth[ 'dispatch' ]( X_EVENT_NEED_AUTH ) & X_Callback_PREVENT_DEFAULT ) ){\r
-                                                       authSettings.lazyReq = X_NET_currentQueue;\r
+                                               if( !( auth[ 'dispatch' ]( X_EVENT_NEED_AUTH ) & X_CALLBACK_PREVENT_DEFAULT ) ){\r
+                                                       authSettings.lazyRequests = authSettings.lazyRequests || [];\r
+                                                       authSettings.lazyRequests.indexOf( X_NET_currentQueue ) === -1 && authSettings.lazyRequests.push( X_NET_currentQueue );\r
                                                };\r
                                                X_NET_currentQueue = null;\r
                                                X_NET_shiftQueue();\r
@@ -352,13 +351,13 @@ function X_NET_shiftQueue(){
                        };\r
                        break;\r
                case X_NET_TYPE_JSONP :\r
-                       X_NET_currentWrapper = X_NET_JSONPWrapper || X_TEMP.X_NET_JSONP_init();\r
+                       X_NET_currentWrapper = X_JSONP || X_TEMP.X_JSONP_init();\r
                        break;\r
                case X_NET_TYPE_FORM :\r
-                       X_NET_currentWrapper = X_NET_FormWrapper  || X_TEMP.X_NET_Form_init();\r
+                       X_NET_currentWrapper = X_FormSender  || X_TEMP.X_FormSender_init();\r
                        break;\r
                case X_NET_TYPE_IMAGE :\r
-                       X_NET_currentWrapper = X_NET_ImageWrapper || X_TEMP.X_NET_Image_init();\r
+                       X_NET_currentWrapper = X_ImgLoader || X_TEMP.X_ImgLoader_init();\r
                        break;\r
        };\r
        \r