Class: Gcloud::Bigquery::Table::List
- Inherits:
-
Array
- Object
- Array
- Gcloud::Bigquery::Table::List
- Defined in:
- lib/gcloud/bigquery/table/list.rb
Overview
Table::List is a special case Array with additional values.
Instance Attribute Summary collapse
-
#etag ⇒ Object
A hash of this page of results.
-
#token ⇒ Object
If not empty, indicates that there are more records that match the request and this value should be passed to continue.
-
#total ⇒ Object
Total number of tables in this collection.
Class Method Summary collapse
Instance Method Summary collapse
- #all(request_limit: nil) {|table| ... } ⇒ Enumerator
-
#initialize(arr = []) ⇒ List
constructor
A new instance of List.
-
#next ⇒ Table::List
Retrieve the next page of tables.
-
#next? ⇒ Boolean
Whether there is a next page of tables.
Constructor Details
#initialize(arr = []) ⇒ List
Returns a new instance of List.
37 38 39 |
# File 'lib/gcloud/bigquery/table/list.rb', line 37 def initialize arr = [] super arr end |
Instance Attribute Details
#etag ⇒ Object
A hash of this page of results.
30 31 32 |
# File 'lib/gcloud/bigquery/table/list.rb', line 30 def etag @etag end |
#token ⇒ Object
If not empty, indicates that there are more records that match the request and this value should be passed to continue.
27 28 29 |
# File 'lib/gcloud/bigquery/table/list.rb', line 27 def token @token end |
#total ⇒ Object
Total number of tables in this collection.
33 34 35 |
# File 'lib/gcloud/bigquery/table/list.rb', line 33 def total @total end |
Class Method Details
.from_response(resp, conn, dataset_id = nil, max = nil) ⇒ Object
161 162 163 164 165 166 167 168 169 170 171 172 |
# File 'lib/gcloud/bigquery/table/list.rb', line 161 def self.from_response resp, conn, dataset_id = nil, max = nil tables = List.new(Array(resp.data["tables"]).map do |gapi_object| Table.from_gapi gapi_object, conn end) tables.instance_variable_set "@token", resp.data["nextPageToken"] tables.instance_variable_set "@etag", resp.data["etag"] tables.instance_variable_set "@total", resp.data["totalItems"] tables.instance_variable_set "@connection", conn tables.instance_variable_set "@dataset_id", dataset_id tables.instance_variable_set "@max", max tables end |
Instance Method Details
#all(request_limit: nil) {|table| ... } ⇒ Enumerator
Retrieves all tables by repeatedly loading #next until #next? returns false. Calls the given block once for each table, which is passed as the parameter.
An Enumerator is returned if no block is given.
This method may make several API calls until all tables are retrieved. Be sure to use as narrow a search criteria as possible. Please use with caution.
142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 |
# File 'lib/gcloud/bigquery/table/list.rb', line 142 def all request_limit: nil request_limit = request_limit.to_i if request_limit unless block_given? return enum_for(:all, request_limit: request_limit) end results = self loop do results.each { |r| yield r } if request_limit request_limit -= 1 break if request_limit < 0 end break unless results.next? results = results.next end end |
#next ⇒ Table::List
Retrieve the next page of tables.
79 80 81 82 83 84 85 86 87 88 89 |
# File 'lib/gcloud/bigquery/table/list.rb', line 79 def next return nil unless next? ensure_connection! = { token: token, max: @max } resp = @connection.list_tables @dataset_id, if resp.success? self.class.from_response resp, @connection, @dataset_id, @max else fail ApiError.from_response(resp) end end |
#next? ⇒ Boolean
Whether there is a next page of tables.
58 59 60 |
# File 'lib/gcloud/bigquery/table/list.rb', line 58 def next? !token.nil? end |