null :
jQuery.isArray(val) ?
jQuery.map( val, function(val, i){
- return {name: elem.name, value: val};
+ return {name: elem.name, value: val.replace(/\r?\n/g, "\r\n")};
}) :
- {name: elem.name, value: val};
+ {name: elem.name, value: val.replace(/\r?\n/g, "\r\n")};
}).get();
}
});
current,
prev,
checker,
+ conv,
conv1,
conv2,
- oneConv,
convertion,
dataTypes = s.dataTypes,
converters = s.converters,
if ( prev !== "*" && current !== "*" && prev !== current ) {
- oneConv = conv1 =
- converters[ ( conversion = prev + " " + current ) ] ||
+ conv = converters[ ( conversion = prev + " " + current ) ] ||
converters[ "* " + current ];
- if ( oneConv !== true ) {
-
- if ( ! oneConv && prev !== "text" && current !== "text" ) {
- conv1 = converters[ prev + " text" ] || converters[ "* text" ];
- conv2 = converters[ "text " + current ];
- }
-
- if ( oneConv || conv1 && conv2 ) {
- response = oneConv ? conv1( response ) : conv2( conv1( response ) );
- } else {
- throw "no " + conversion;
+ conv1 = conv2 = 0;
+
+ if ( ! conv && prev !== "text" && current !== "text" ) {
+ conv1 = converters[ prev + " text" ] || converters[ "* text" ];
+ conv2 = converters[ "text " + current ];
+ if ( conv1 === true ) {
+ conv = conv2;
+ } else if ( conv2 === true ) {
+ conv = conv1;
}
}
+
+ if ( ! ( conv || conv1 && conv2 ) ) {
+ throw conversion;
+ }
+
+ if ( conv !== true ) {
+ response = conv ? conv( response ) : conv2( conv1( response ) );
+ }
}
} else if ( s.dataFilter ) {
// Attach deferreds
deferred.promise( jXHR );
- jXHR.success = jXHR.then;
+ jXHR.success = jXHR.complete;
jXHR.error = jXHR.fail;
- jXHR.complete = completeDeferred.then;
+ jXHR.complete = completeDeferred.complete;
// Remove hash character (#7531: and string promotion)
s.url = ( "" + s.url ).replace( rhash , "" );