# frozen_string_literal: true module Reality::Describers::Wikidata::Impl module Modules # List all redirects to a namespace. # # The "submodule" (MediaWiki API term) is included in action after setting some param, providing # additional tweaking for this param. Example (for {Reality::Describers::Wikidata::Impl::Actions::Query} and # its submodules): # # ```ruby # api.query # returns Actions::Query # .prop(:revisions) # adds prop=revisions to action URL, and includes Modules::Revisions into action # .limit(10) # method of Modules::Revisions, adds rvlimit=10 to URL # ``` # # All submodule's parameters are documented as its public methods, see below. # module Allredirects # When more results are available, use this to continue. # # @param value [String] # @return [self] def continue(value) merge(arcontinue: value.to_s) end # The title of the redirect to start enumerating from. # # @param value [String] # @return [self] def from(value) merge(arfrom: value.to_s) end # The title of the redirect to stop enumerating at. # # @param value [String] # @return [self] def to(value) merge(arto: value.to_s) end # Search for all target pages that begin with this value. # # @param value [String] # @return [self] def prefix(value) merge(arprefix: value.to_s) end # Only show distinct target pages. Cannot be used with arprop=ids|fragment|interwiki. When used as a generator, yields target pages instead of source pages. # # @return [self] def unique() merge(arunique: 'true') end # Which pieces of information to include: # # @param values [Array] Allowed values: "ids" (Adds the page ID of the redirecting page (cannot be used with arunique)), "title" (Adds the title of the redirect), "fragment" (Adds the fragment from the redirect, if any (cannot be used with arunique)), "interwiki" (Adds the interwiki prefix from the redirect, if any (cannot be used with arunique)). # @return [self] def prop(*values) values.inject(self) { |res, val| res._prop(val) or fail ArgumentError, "Unknown value for prop: #{val}" } end # @private def _prop(value) defined?(super) && super || ["ids", "title", "fragment", "interwiki"].include?(value.to_s) && merge(arprop: value.to_s, replace: false) end # The namespace to enumerate. # # @param value [String] One of "-2", "-1", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "120", "121", "122", "123", "828", "829", "1198", "1199", "2300", "2301", "2302", "2303", "2600". # @return [self] def namespace(value) _namespace(value) or fail ArgumentError, "Unknown value for namespace: #{value}" end # @private def _namespace(value) defined?(super) && super || ["-2", "-1", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "120", "121", "122", "123", "828", "829", "1198", "1199", "2300", "2301", "2302", "2303", "2600"].include?(value.to_s) && merge(arnamespace: value.to_s) end # How many total items to return. # # @param value [Integer, "max"] # @return [self] def limit(value) merge(arlimit: value.to_s) end # The direction in which to list. # # @param value [String] One of "ascending", "descending". # @return [self] def dir(value) _dir(value) or fail ArgumentError, "Unknown value for dir: #{value}" end # @private def _dir(value) defined?(super) && super || ["ascending", "descending"].include?(value.to_s) && merge(ardir: value.to_s) end end end end