is_registered( $source_name ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Block binding source name. */ sprintf( __( 'Block binding source "%s" already registered.' ), $source_name ), '6.5.0' ); return false; } $source = array_merge( array( 'name' => $source_name ), $source_properties ); $this->sources[ $source_name ] = $source; return $source; } /** * Unregisters a block binding source. * * @since 6.5.0 * * @param string $source_name Block binding source name including namespace. * @return array|false The unregistred block binding source on success and `false` otherwise. */ public function unregister( $source_name ) { if ( ! $this->is_registered( $source_name ) ) { _doing_it_wrong( __METHOD__, /* translators: %s: Block binding source name. */ sprintf( __( 'Block binding "%s" not found.' ), $source_name ), '6.5.0' ); return false; } $unregistered_source = $this->sources[ $source_name ]; unset( $this->sources[ $source_name ] ); return $unregistered_source; } /** * Retrieves the list of all registered block bindings sources. * * @since 6.5.0 * * @return array The array of registered sources. */ public function get_all_registered() { return $this->sources; } /** * Retrieves a registered block bindings source. * * @since 6.5.0 * * @param string $source_name The name of the source. * @return array|null The registered block binding source, or `null` if it is not registered. */ public function get_registered( $source_name ) { if ( ! $this->is_registered( $source_name ) ) { return null; } return $this->sources[ $source_name ]; } /** * Checks if a block binding source is registered. * * @since 6.5.0 * * @param string $source_name The name of the source. * @return bool `true` if the block binding source is registered, `false` otherwise. */ public function is_registered( $source_name ) { return isset( $this->sources[ $source_name ] ); } /** * Utility method to retrieve the main instance of the class. * * The instance will be created if it does not exist yet. * * @since 6.5.0 * * @return WP_Block_Bindings_Registry The main instance. */ public static function get_instance() { if ( null === self::$instance ) { self::$instance = new self(); } return self::$instance; } }