Make sure that jQuery works even when the individual modules are loaded separately...
[jquery.git] / src / ajax.js
index ffd870c..52a5a22 100644 (file)
@@ -1,3 +1,5 @@
+(function( jQuery ) {
+
 var jsc = jQuery.now(),
        rscript = /<script(.|\s)*?\/script>/gi,
        rselectTextarea = /select|textarea/i,
@@ -238,23 +240,24 @@ jQuery.extend({
 
                        // Handle JSONP-style loading
                        var customJsonp = window[ jsonp ];
+
                        window[ jsonp ] = function( tmp ) {
                                data = tmp;
                                jQuery.ajax.handleSuccess( s, xhr, status, data );
                                jQuery.ajax.handleComplete( s, xhr, status, data );
                                
                                if ( jQuery.isFunction( customJsonp ) ) {
-                                   customJsonp( tmp );
-                           }
-                           else {
-                               // Garbage collect
-                               window[ jsonp ] = undefined;
-
-                               try {
-                                       delete window[ jsonp ];
-                               } catch( jsonpError ) {}
-                }
-                
+                                       customJsonp( tmp );
+
+                               } else {
+                                       // Garbage collect
+                                       window[ jsonp ] = undefined;
+
+                                       try {
+                                               delete window[ jsonp ];
+                                       } catch( jsonpError ) {}
+                               }
+                               
                                if ( head ) {
                                        head.removeChild( script );
                                }
@@ -444,8 +447,9 @@ jQuery.extend({
 
                                // Fire the complete handlers
                                if ( !jsonp ) {
-                                   jQuery.ajax.handleComplete( s, xhr, status, data );
-                }
+                                       jQuery.ajax.handleComplete( s, xhr, status, data );
+                               }
+
                                if ( isTimeout === "timeout" ) {
                                        xhr.abort();
                                }
@@ -482,7 +486,7 @@ jQuery.extend({
 
                // Send the data
                try {
-                       xhr.send( type === "POST" || type === "PUT" || type === "DELETE" ? s.data : null );
+                       xhr.send( (type !== "GET" && s.data) || null );
 
                } catch( sendError ) {
                        jQuery.ajax.handleError( s, xhr, null, e );
@@ -684,3 +688,5 @@ jQuery.extend( jQuery.ajax, {
 
 // For backwards compatibility
 jQuery.extend( jQuery.ajax );
+
+})( jQuery );