HEX
Server: nginx/1.28.1
System: Linux VM-0-12-opencloudos 6.6.117-45.oc9.x86_64 #1 SMP Thu Dec 4 10:26:39 CST 2025 x86_64
User: www (1000)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/www.waciwang.com/wp-content/plugins/gutenberg/lib/compat/wordpress-7.0/blocks.php
<?php
/**
 * Compatibility shims for block APIs for WordPress 7.0.
 *
 * @package gutenberg
 */

if ( ! function_exists( 'gutenberg_resolve_pattern_blocks' ) ) {
	/**
	 * Replaces patterns in a block tree with their content.
	 *
	 * @since 6.6.0
	 * @since 7.0.0 Adds metadata to attributes of single-pattern container blocks.
	 *
	 * @param array $blocks An array blocks.
	 *
	 * @return array An array of blocks with patterns replaced by their content.
	 */
	function gutenberg_resolve_pattern_blocks( $blocks ) {
		static $inner_content;
		// Keep track of seen references to avoid infinite loops.
		static $seen_refs = array();
		$i                = 0;
		while ( $i < count( $blocks ) ) {
			if ( 'core/pattern' === $blocks[ $i ]['blockName'] ) {
				$attrs = $blocks[ $i ]['attrs'];

				if ( empty( $attrs['slug'] ) ) {
					++$i;
					continue;
				}

				$slug = $attrs['slug'];

				if ( isset( $seen_refs[ $slug ] ) ) {
					// Skip recursive patterns.
					array_splice( $blocks, $i, 1 );
					continue;
				}

				$registry = WP_Block_Patterns_Registry::get_instance();
				$pattern  = $registry->get_registered( $slug );

				// Skip unknown patterns.
				if ( ! $pattern ) {
					++$i;
					continue;
				}
				//////////////////////////////
				// START CORE MODIFICATIONS //
				//////////////////////////////
				$blocks_to_insert = parse_blocks( trim( $pattern['content'] ) );

				/*
				 * For single-root patterns, add the pattern name to make this a pattern instance in the editor.
				 * If the pattern has metadata, merge it with the existing metadata.
				 */
				if ( count( $blocks_to_insert ) === 1 ) {
					$block_metadata                = $blocks_to_insert[0]['attrs']['metadata'] ?? array();
					$block_metadata['patternName'] = $slug;

					/*
					 * Merge pattern metadata with existing block metadata.
					 * Pattern metadata takes precedence, but existing block metadata
					 * is preserved as a fallback when the pattern doesn't define that field.
					 * Only the defined fields (name, description, categories) are updated;
					 * other metadata keys are preserved.
					 */
					foreach ( array(
						'name'        => 'title', // 'title' is the field in the pattern object 'name' is the field in the block metadata.
						'description' => 'description',
						'categories'  => 'categories',
					) as $key => $pattern_key ) {
						$value = $pattern[ $pattern_key ] ?? $block_metadata[ $key ] ?? null;
						if ( $value ) {
							$block_metadata[ $key ] = is_array( $value )
								? array_map( 'sanitize_text_field', $value )
								: sanitize_text_field( $value );
						}
					}

					$blocks_to_insert[0]['attrs']['metadata'] = $block_metadata;
				}
				//////////////////////////////
				// END CORE MODIFICATIONS //
				//////////////////////////////

				$seen_refs[ $slug ] = true;
				$prev_inner_content = $inner_content;
				$inner_content      = null;
				$blocks_to_insert   = gutenberg_resolve_pattern_blocks( $blocks_to_insert );
				$inner_content      = $prev_inner_content;
				unset( $seen_refs[ $slug ] );
				array_splice( $blocks, $i, 1, $blocks_to_insert );

				// If we have inner content, we need to insert nulls in the
				// inner content array, otherwise serialize_blocks will skip
				// blocks.
				if ( $inner_content ) {
					$null_indices  = array_keys( $inner_content, null, true );
					$content_index = $null_indices[ $i ];
					$nulls         = array_fill( 0, count( $blocks_to_insert ), null );
					array_splice( $inner_content, $content_index, 1, $nulls );
				}

				// Skip inserted blocks.
				$i += count( $blocks_to_insert );
			} else {
				if ( ! empty( $blocks[ $i ]['innerBlocks'] ) ) {
					$prev_inner_content           = $inner_content;
					$inner_content                = $blocks[ $i ]['innerContent'];
					$blocks[ $i ]['innerBlocks']  = gutenberg_resolve_pattern_blocks(
						$blocks[ $i ]['innerBlocks']
					);
					$blocks[ $i ]['innerContent'] = $inner_content;
					$inner_content                = $prev_inner_content;
				}
				++$i;
			}
		}
		return $blocks;
	}
}

/**
 * Update Query Loop's `taxQuery` prop to the new structure.
 *
 * @see 'query_loop_block_query_vars'
 *
 * @param array    $query The query vars.
 * @param WP_Block $block Block instance.
 * @return array   The filtered query vars.
 */
function gutenberg_update_tax_query_of_query_loop_block( $query, $block ) {
	if ( empty( $block->context['query']['taxQuery'] ) ) {
		return $query;
	}

	// If there are keys other than include/exclude, it's the old
	// format and has been handled already.
	if ( ! is_array( $block->context['query']['taxQuery'] ) || ! empty( array_diff( array_keys( $block->context['query']['taxQuery'] ), array( 'include', 'exclude' ) ) ) ) {
		return $query;
	}

	// Build with the new structure.
	$tax_query_input = $block->context['query']['taxQuery'];

	// Helper function to build tax_query conditions from taxonomy terms.
	$build_conditions = static function ( $terms, $operator = 'IN' ) {
		$conditions = array();
		foreach ( $terms as $taxonomy => $terms ) {
			if ( ! empty( $terms ) && is_taxonomy_viewable( $taxonomy ) ) {
				$conditions[] = array(
					'taxonomy'         => $taxonomy,
					'terms'            => array_filter( array_map( 'intval', $terms ) ),
					'operator'         => $operator,
					'include_children' => false,
				);
			}
		}
		return $conditions;
	};
	// Separate exclude from include terms.
	$exclude_terms = isset( $tax_query_input['exclude'] ) && is_array( $tax_query_input['exclude'] )
		? $tax_query_input['exclude']
		: array();
	$include_terms = isset( $tax_query_input['include'] ) && is_array( $tax_query_input['include'] )
		? $tax_query_input['include']
		: array();

	$tax_query = array_merge(
		$build_conditions( $include_terms ),
		$build_conditions( $exclude_terms, 'NOT IN' )
	);

	if ( ! empty( $tax_query ) ) {
		// Merge with any existing `tax_query` conditions.
		$query['tax_query'] = array_merge( $query['tax_query'], $tax_query );
	}

	return $query;
}

add_filter( 'query_loop_block_query_vars', 'gutenberg_update_tax_query_of_query_loop_block', 10, 2 );