aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJames Huston <james@jameshuston.net>2012-10-16 14:51:54 -0400
committerDave Methvin <dave.methvin@gmail.com>2012-10-17 16:28:55 -0400
commitee9687d441d625a420dc65590bbd0b930f800b3f (patch)
tree9914cbed913dd7886393b36809ab03685058bbbf /src
parentc31539c8a21e828efb296573c0272bc21220e24c (diff)
downloadjquery-ee9687d441d625a420dc65590bbd0b930f800b3f.tar.gz
jquery-ee9687d441d625a420dc65590bbd0b930f800b3f.zip
Fix #12751. Ensure parseJson throws in the same situations as JSON.parse. Close gh-993.
Diffstat (limited to 'src')
-rw-r--r--src/core.js31
1 files changed, 18 insertions, 13 deletions
diff --git a/src/core.js b/src/core.js
index 5564a9870..2f5908b55 100644
--- a/src/core.js
+++ b/src/core.js
@@ -488,27 +488,32 @@ jQuery.extend({
},
parseJSON: function( data ) {
- if ( !data || typeof data !== "string") {
- return null;
- }
-
- // Make sure leading/trailing whitespace is removed (IE can't handle it)
- data = jQuery.trim( data );
-
// Attempt to parse using the native JSON parser first
if ( window.JSON && window.JSON.parse ) {
return window.JSON.parse( data );
}
- // Make sure the incoming data is actual JSON
- // Logic borrowed from http://json.org/json2.js
- if ( rvalidchars.test( data.replace( rvalidescape, "@" )
- .replace( rvalidtokens, "]" )
- .replace( rvalidbraces, "")) ) {
+ if ( data === null ) {
+ return data;
+ }
- return ( new Function( "return " + data ) )();
+ if ( typeof data === "string" ) {
+
+ // Make sure leading/trailing whitespace is removed (IE can't handle it)
+ data = jQuery.trim( data );
+ if ( data ) {
+ // Make sure the incoming data is actual JSON
+ // Logic borrowed from http://json.org/json2.js
+ if ( rvalidchars.test( data.replace( rvalidescape, "@" )
+ .replace( rvalidtokens, "]" )
+ .replace( rvalidbraces, "")) ) {
+
+ return ( new Function( "return " + data ) )();
+ }
+ }
}
+
jQuery.error( "Invalid JSON: " + data );
},