@@ 234-262 (lines=29) @@ | ||
231 | * |
|
232 | * @return array |
|
233 | */ |
|
234 | function jetpack_json_wrap( &$any, $seen_nodes = array() ) { |
|
235 | if ( is_object( $any ) ) { |
|
236 | $input = get_object_vars( $any ); |
|
237 | $input['__o'] = 1; |
|
238 | } else { |
|
239 | $input = &$any; |
|
240 | } |
|
241 | ||
242 | if ( is_array( $input ) ) { |
|
243 | $seen_nodes[] = &$any; |
|
244 | ||
245 | $return = array(); |
|
246 | ||
247 | foreach ( $input as $k => &$v ) { |
|
248 | if ( ( is_array( $v ) || is_object( $v ) ) ) { |
|
249 | if ( in_array( $v, $seen_nodes, true ) ) { |
|
250 | continue; |
|
251 | } |
|
252 | $return[ $k ] = jetpack_json_wrap( $v, $seen_nodes ); |
|
253 | } else { |
|
254 | $return[ $k ] = $v; |
|
255 | } |
|
256 | } |
|
257 | ||
258 | return $return; |
|
259 | } |
|
260 | ||
261 | return $any; |
|
262 | } |
|
263 | ||
264 | /** |
|
265 | * Checks if the mime_content_type function is available and return it if so. |
@@ 83-111 (lines=29) @@ | ||
80 | * @param array $seen_nodes Seen nodes. |
|
81 | * @return array |
|
82 | */ |
|
83 | private function json_wrap( &$any, $seen_nodes = array() ) { |
|
84 | if ( is_object( $any ) ) { |
|
85 | $input = get_object_vars( $any ); |
|
86 | $input['__o'] = 1; |
|
87 | } else { |
|
88 | $input = &$any; |
|
89 | } |
|
90 | ||
91 | if ( is_array( $input ) ) { |
|
92 | $seen_nodes[] = &$any; |
|
93 | ||
94 | $return = array(); |
|
95 | ||
96 | foreach ( $input as $k => &$v ) { |
|
97 | if ( ( is_array( $v ) || is_object( $v ) ) ) { |
|
98 | if ( in_array( $v, $seen_nodes, true ) ) { |
|
99 | continue; |
|
100 | } |
|
101 | $return[ $k ] = $this->json_wrap( $v, $seen_nodes ); |
|
102 | } else { |
|
103 | $return[ $k ] = $v; |
|
104 | } |
|
105 | } |
|
106 | ||
107 | return $return; |
|
108 | } |
|
109 | ||
110 | return $any; |
|
111 | } |
|
112 | ||
113 | /** |
|
114 | * Unwraps a json_decode return. |