From 2da5210bef912922027f4f645feaace16e26e1c4 Mon Sep 17 00:00:00 2001 From: Thomas Schultz Date: Thu, 21 Jul 2016 13:49:32 -0400 Subject: [PATCH 1/4] Change .Net navigation order. --- index.html | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/index.html b/index.html index d62fc0bde342..a9a59becb01f 100755 --- a/index.html +++ b/index.html @@ -23,6 +23,12 @@

Googl
   <nav class= From e31d70d7a511e8699e1049035825b48f51157019 Mon Sep 17 00:00:00 2001 From: Thomas Schultz Date: Thu, 21 Jul 2016 13:51:38 -0400 Subject: [PATCH 2/4] Add PHP to navigation. --- _landing-page-static/images/icon-lang-php.svg | 47 +++++++++++++++++++ index.html | 6 +++ 2 files changed, 53 insertions(+) create mode 100644 _landing-page-static/images/icon-lang-php.svg diff --git a/_landing-page-static/images/icon-lang-php.svg b/_landing-page-static/images/icon-lang-php.svg new file mode 100644 index 000000000000..8700fd8be354 --- /dev/null +++ b/_landing-page-static/images/icon-lang-php.svg @@ -0,0 +1,47 @@ + + + + + + + + + + \ No newline at end of file diff --git a/index.html b/index.html index a9a59becb01f..20aaf45b9d13 100755 --- a/index.html +++ b/index.html @@ -41,6 +41,12 @@

Googl
           Node.js
         </a>
       </li>
+      <li>
+        <a href= + PHP icon + PHP + +
  • Python icon From 4e4d468024f528cfa9c7cfb41cc714516bf5f82a Mon Sep 17 00:00:00 2001 From: travis-ci Date: Thu, 8 Sep 2016 11:48:05 -0400 Subject: [PATCH 3/4] Update docs after merge to master. --- latest/.buildinfo | 2 +- .../_modules/gcloud/bigquery/connection.html | 255 -- latest/_modules/gcloud/bigtable/client.html | 701 ---- .../gcloud/bigtable/happybase/batch.html | 547 --- .../gcloud/bigtable/happybase/connection.html | 712 ---- .../gcloud/bigtable/happybase/pool.html | 375 --- .../gcloud/bigtable/happybase/table.html | 1199 ------- .../_modules/gcloud/datastore/connection.html | 653 ---- latest/_modules/gcloud/dns/connection.html | 254 -- .../gcloud/dns/resource_record_set.html | 287 -- latest/_modules/gcloud/monitoring/client.html | 505 --- .../gcloud/monitoring/connection.html | 268 -- .../gcloud/resource_manager/connection.html | 263 -- .../_modules/gcloud/storage/connection.html | 264 -- .../_modules/gcloud/translate/connection.html | 251 -- .../cloud}/bigquery/_helpers.html | 518 +-- .../cloud}/bigquery/client.html | 640 ++-- .../google/cloud/bigquery/connection.html | 349 ++ .../cloud}/bigquery/dataset.html | 589 ++-- .../cloud}/bigquery/job.html | 681 ++-- .../cloud}/bigquery/query.html | 563 ++-- .../google/cloud/bigquery/schema.html | 367 +++ .../cloud}/bigquery/table.html | 725 ++-- .../google/cloud/bigtable/client.html | 651 ++++ .../cloud}/bigtable/cluster.html | 685 ++-- .../cloud}/bigtable/column_family.html | 556 ++-- .../cloud}/bigtable/instance.html | 722 ++-- .../cloud}/bigtable/row.html | 580 ++-- .../cloud}/bigtable/row_data.html | 543 +-- .../cloud}/bigtable/row_filters.html | 598 ++-- .../cloud}/bigtable/table.html | 572 ++-- .../{gcloud => google/cloud}/client.html | 524 +-- .../{gcloud => google/cloud}/connection.html | 527 +-- .../{gcloud => google/cloud}/credentials.html | 530 +-- .../cloud}/datastore/batch.html | 554 ++-- .../cloud}/datastore/client.html | 644 ++-- .../google/cloud/datastore/connection.html | 988 ++++++ .../cloud}/datastore/entity.html | 530 +-- .../cloud}/datastore/helpers.html | 564 ++-- .../cloud}/datastore/key.html | 535 +-- .../cloud}/datastore/query.html | 558 ++-- .../cloud}/datastore/transaction.html | 530 +-- .../{gcloud => google/cloud}/dns/changes.html | 574 ++-- .../{gcloud => google/cloud}/dns/client.html | 532 +-- .../_modules/google/cloud/dns/connection.html | 348 ++ .../google/cloud/dns/resource_record_set.html | 381 +++ .../{gcloud => google/cloud}/dns/zone.html | 568 ++-- .../google/cloud/error_reporting/client.html | 566 ++++ .../{gcloud => google/cloud}/exceptions.html | 572 ++-- .../google/cloud/language/client.html | 416 +++ .../google/cloud/language/connection.html | 348 ++ .../google/cloud/language/document.html | 576 ++++ .../google/cloud/language/entity.html | 423 +++ .../google/cloud/language/sentiment.html | 372 +++ .../google/cloud/language/syntax.html | 518 +++ .../cloud}/logging/client.html | 596 ++-- .../cloud}/logging/connection.html | 526 +-- .../cloud}/logging/entries.html | 530 +-- .../cloud/logging/handlers/handlers.html | 448 +++ .../transports/background_thread.html | 486 +++ .../logging/handlers/transports/base.html | 350 ++ .../logging/handlers/transports/sync.html | 358 ++ .../cloud}/logging/logger.html | 575 ++-- .../cloud}/logging/metric.html | 552 ++-- .../cloud}/logging/sink.html | 552 ++-- .../google/cloud/monitoring/client.html | 812 +++++ .../google/cloud/monitoring/connection.html | 362 ++ .../google/cloud/monitoring/group.html | 811 +++++ .../cloud}/monitoring/label.html | 514 +-- .../cloud}/monitoring/metric.html | 547 +-- .../cloud}/monitoring/query.html | 603 ++-- .../cloud}/monitoring/resource.html | 531 +-- .../cloud}/monitoring/timeseries.html | 534 +-- latest/_modules/google/cloud/operation.html | 452 +++ .../cloud}/pubsub/client.html | 562 ++-- .../cloud}/pubsub/connection.html | 552 ++-- .../{gcloud => google/cloud}/pubsub/iam.html | 528 +-- .../cloud}/pubsub/message.html | 520 +-- .../cloud}/pubsub/subscription.html | 618 ++-- .../cloud}/pubsub/topic.html | 607 ++-- .../cloud}/resource_manager/client.html | 561 ++-- .../cloud/resource_manager/connection.html | 357 ++ .../cloud}/resource_manager/project.html | 558 ++-- .../{gcloud => google/cloud}/storage/acl.html | 590 ++-- .../cloud}/storage/batch.html | 530 +-- .../cloud}/storage/blob.html | 620 ++-- .../cloud}/storage/bucket.html | 641 ++-- .../cloud}/storage/client.html | 575 ++-- .../google/cloud/storage/connection.html | 358 ++ .../cloud}/translate/client.html | 522 +-- .../google/cloud/translate/connection.html | 345 ++ .../_modules/google/cloud/vision/client.html | 424 +++ .../google/cloud/vision/connection.html | 362 ++ .../_modules/google/cloud/vision/feature.html | 383 +++ .../_modules/google/cloud/vision/image.html | 381 +++ latest/_modules/index.html | 460 ++- latest/_sources/bigquery-client.txt | 4 +- latest/_sources/bigquery-dataset.txt | 2 +- latest/_sources/bigquery-job.txt | 2 +- latest/_sources/bigquery-query.txt | 2 +- latest/_sources/bigquery-schema.txt | 7 + latest/_sources/bigquery-table.txt | 2 +- latest/_sources/bigquery-usage.txt | 54 +- latest/_sources/bigtable-client-intro.txt | 38 +- latest/_sources/bigtable-client.txt | 8 +- latest/_sources/bigtable-cluster.txt | 8 +- latest/_sources/bigtable-column-family.txt | 28 +- latest/_sources/bigtable-data-api.txt | 88 +- latest/_sources/bigtable-instance-api.txt | 38 +- latest/_sources/bigtable-instance.txt | 8 +- latest/_sources/bigtable-row-data.txt | 8 +- latest/_sources/bigtable-row-filters.txt | 16 +- latest/_sources/bigtable-row.txt | 8 +- latest/_sources/bigtable-table-api.txt | 46 +- latest/_sources/bigtable-table.txt | 8 +- latest/_sources/bigtable-usage.txt | 24 +- latest/_sources/datastore-batches.txt | 2 +- latest/_sources/datastore-client.txt | 4 +- latest/_sources/datastore-entities.txt | 2 +- latest/_sources/datastore-helpers.txt | 2 +- latest/_sources/datastore-keys.txt | 2 +- latest/_sources/datastore-queries.txt | 2 +- latest/_sources/datastore-transactions.txt | 2 +- latest/_sources/dns-changes.txt | 2 +- latest/_sources/dns-client.txt | 4 +- latest/_sources/dns-resource-record-set.txt | 2 +- latest/_sources/dns-usage.txt | 24 +- latest/_sources/dns-zone.txt | 2 +- latest/_sources/error-reporting-client.txt | 7 + latest/_sources/error-reporting-usage.txt | 102 + latest/_sources/gcloud-api.txt | 10 +- latest/_sources/gcloud-auth.txt | 26 +- latest/_sources/gcloud-config.txt | 8 +- latest/_sources/happybase-batch.txt | 12 - latest/_sources/happybase-connection.txt | 12 - latest/_sources/happybase-package.txt | 12 - latest/_sources/happybase-pool.txt | 12 - latest/_sources/happybase-table.txt | 12 - latest/_sources/index.txt | 64 +- latest/_sources/language-client.txt | 13 + latest/_sources/language-document.txt | 6 + latest/_sources/language-responses.txt | 23 + latest/_sources/language-usage.txt | 278 ++ latest/_sources/logging-client.txt | 4 +- latest/_sources/logging-entries.txt | 2 +- latest/_sources/logging-handlers.txt | 6 + latest/_sources/logging-logger.txt | 2 +- latest/_sources/logging-metric.txt | 2 +- latest/_sources/logging-sink.txt | 2 +- latest/_sources/logging-transports-base.txt | 6 + latest/_sources/logging-transports-sync.txt | 6 + latest/_sources/logging-transports-thread.txt | 7 + latest/_sources/logging-usage.txt | 137 +- latest/_sources/monitoring-client.txt | 4 +- latest/_sources/monitoring-group.txt | 7 + latest/_sources/monitoring-label.txt | 2 +- latest/_sources/monitoring-metric.txt | 2 +- latest/_sources/monitoring-query.txt | 2 +- latest/_sources/monitoring-resource.txt | 2 +- latest/_sources/monitoring-timeseries.txt | 2 +- latest/_sources/monitoring-usage.txt | 128 +- latest/_sources/operation-api.txt | 7 + latest/_sources/pubsub-client.txt | 4 +- latest/_sources/pubsub-iam.txt | 2 +- latest/_sources/pubsub-message.txt | 2 +- latest/_sources/pubsub-subscription.txt | 2 +- latest/_sources/pubsub-topic.txt | 2 +- latest/_sources/pubsub-usage.txt | 25 +- latest/_sources/resource-manager-api.txt | 6 +- latest/_sources/resource-manager-client.txt | 4 +- latest/_sources/resource-manager-project.txt | 2 +- latest/_sources/storage-acl.txt | 2 +- latest/_sources/storage-batch.txt | 2 +- latest/_sources/storage-blobs.txt | 2 +- latest/_sources/storage-buckets.txt | 2 +- latest/_sources/storage-client.txt | 4 +- latest/_sources/translate-client.txt | 4 +- latest/_sources/translate-usage.txt | 24 +- latest/_sources/vision-client.txt | 18 + latest/_sources/vision-feature.txt | 10 + latest/_sources/vision-image.txt | 10 + latest/_sources/vision-usage.txt | 233 ++ latest/_static/alabaster.css | 607 ---- latest/_static/css/badge_only.css | 2 + latest/_static/css/main.css | 1432 -------- latest/_static/css/normalize.css | 527 --- latest/_static/css/theme.css | 5 + latest/_static/custom.css | 1 - latest/_static/fonts/Inconsolata-Bold.ttf | Bin 0 -> 66352 bytes latest/_static/fonts/Inconsolata-Regular.ttf | Bin 0 -> 84548 bytes latest/_static/fonts/Lato-Bold.ttf | Bin 0 -> 121788 bytes latest/_static/fonts/Lato-Regular.ttf | Bin 0 -> 120196 bytes latest/_static/fonts/RobotoSlab-Bold.ttf | Bin 0 -> 170616 bytes latest/_static/fonts/RobotoSlab-Regular.ttf | Bin 0 -> 169064 bytes latest/_static/fonts/fontawesome-webfont.eot | Bin 0 -> 56006 bytes latest/_static/fonts/fontawesome-webfont.svg | 520 +++ latest/_static/fonts/fontawesome-webfont.ttf | Bin 0 -> 112160 bytes latest/_static/fonts/fontawesome-webfont.woff | Bin 0 -> 65452 bytes latest/_static/images/datastore-logo.png | Bin 10705 -> 0 bytes latest/_static/images/icon-arrow-bullet.svg | 7 - latest/_static/images/icon-dropdown-faq.svg | 7 - latest/_static/images/icon-dropdown.svg | 7 - latest/_static/images/icon-lang-dotnet.svg | 18 - latest/_static/images/icon-lang-java-duke.svg | 49 - latest/_static/images/icon-lang-nodejs.svg | 16 - latest/_static/images/icon-lang-python.svg | 21 - latest/_static/images/icon-lang-ruby.svg | 15 - latest/_static/images/icon-link-github.svg | 19 - .../images/icon-link-package-manager.svg | 19 - .../images/icon-link-stackoverflow.svg | 16 - latest/_static/images/icon-menu.svg | 11 - latest/_static/images/icon-table-check.svg | 7 - latest/_static/images/lang-bg.png | Bin 966 -> 0 bytes latest/_static/images/logo-full.svg | 112 - latest/_static/images/logo.svg | 25 - latest/_static/images/storage-logo.png | Bin 9757 -> 0 bytes latest/_static/js/main.js | 59 - ...odernizr-2.6.2.min.js => modernizr.min.js} | 0 latest/_static/js/plugins.js | 24 - latest/_static/js/theme.js | 153 + latest/_static/js/vendor/jquery-1.10.2.min.js | 6 - latest/_static/js/vendor/prettify.js | 30 - latest/bigquery-client.html | 690 ++-- latest/bigquery-dataset.html | 667 ++-- latest/bigquery-job.html | 793 +++-- latest/bigquery-query.html | 624 ++-- latest/bigquery-schema.html | 352 ++ latest/bigquery-table.html | 760 +++-- latest/bigquery-usage.html | 589 ++-- latest/bigtable-client-intro.html | 494 +-- latest/bigtable-client.html | 664 ++-- latest/bigtable-cluster.html | 639 ++-- latest/bigtable-column-family.html | 627 ++-- latest/bigtable-data-api.html | 620 ++-- latest/bigtable-instance-api.html | 555 ++-- latest/bigtable-instance.html | 659 ++-- latest/bigtable-row-data.html | 607 ++-- latest/bigtable-row-filters.html | 797 +++-- latest/bigtable-row.html | 713 ++-- latest/bigtable-table-api.html | 573 ++-- latest/bigtable-table.html | 607 ++-- latest/bigtable-usage.html | 371 ++- latest/datastore-batches.html | 595 ++-- latest/datastore-client.html | 799 +++-- latest/datastore-entities.html | 509 +-- latest/datastore-helpers.html | 409 ++- latest/datastore-keys.html | 585 ++-- latest/datastore-queries.html | 609 ++-- latest/datastore-transactions.html | 603 ++-- latest/dns-changes.html | 609 ++-- latest/dns-client.html | 582 ++-- latest/dns-resource-record-set.html | 425 ++- latest/dns-usage.html | 554 ++-- latest/dns-zone.html | 619 ++-- latest/error-reporting-client.html | 493 +++ latest/error-reporting-usage.html | 419 +++ latest/gcloud-api.html | 857 ++--- latest/gcloud-auth.html | 575 ++-- latest/gcloud-config.html | 431 ++- latest/genindex.html | 2928 ++++++++++------- latest/happybase-batch.html | 341 -- latest/happybase-connection.html | 509 --- latest/happybase-package.html | 367 --- latest/happybase-pool.html | 305 -- latest/happybase-table.html | 768 ----- latest/index.html | 451 ++- latest/language-client.html | 478 +++ latest/language-document.html | 549 ++++ latest/language-responses.html | 694 ++++ latest/language-usage.html | 589 ++++ latest/logging-client.html | 628 ++-- latest/logging-entries.html | 451 ++- latest/logging-handlers.html | 425 +++ latest/logging-logger.html | 631 ++-- latest/logging-metric.html | 590 ++-- latest/logging-sink.html | 592 ++-- latest/logging-transports-base.html | 356 ++ latest/logging-transports-sync.html | 356 ++ latest/logging-transports-thread.html | 356 ++ latest/logging-usage.html | 660 ++-- latest/monitoring-client.html | 837 +++-- latest/monitoring-group.html | 615 ++++ latest/monitoring-label.html | 385 ++- latest/monitoring-metric.html | 576 ++-- latest/monitoring-query.html | 635 ++-- latest/monitoring-resource.html | 422 ++- latest/monitoring-timeseries.html | 496 +-- latest/monitoring-usage.html | 638 ++-- latest/objects.inv | Bin 7883 -> 9118 bytes latest/operation-api.html | 415 +++ latest/pubsub-client.html | 608 ++-- latest/pubsub-iam.html | 653 ++-- latest/pubsub-message.html | 491 +-- latest/pubsub-subscription.html | 686 ++-- latest/pubsub-topic.html | 645 ++-- latest/pubsub-usage.html | 553 ++-- latest/py-modindex.html | 841 +++-- latest/resource-manager-api.html | 466 ++- latest/resource-manager-client.html | 605 ++-- latest/resource-manager-project.html | 599 ++-- latest/search.html | 353 +- latest/searchindex.js | 2 +- latest/storage-acl.html | 685 ++-- latest/storage-batch.html | 457 ++- latest/storage-blobs.html | 735 +++-- latest/storage-buckets.html | 734 +++-- latest/storage-client.html | 621 ++-- latest/translate-client.html | 569 ++-- latest/translate-usage.html | 547 +-- latest/vision-client.html | 479 +++ latest/vision-feature.html | 414 +++ latest/vision-image.html | 372 +++ latest/vision-usage.html | 546 +++ 313 files changed, 65779 insertions(+), 42196 deletions(-) delete mode 100644 latest/_modules/gcloud/bigquery/connection.html delete mode 100644 latest/_modules/gcloud/bigtable/client.html delete mode 100644 latest/_modules/gcloud/bigtable/happybase/batch.html delete mode 100644 latest/_modules/gcloud/bigtable/happybase/connection.html delete mode 100644 latest/_modules/gcloud/bigtable/happybase/pool.html delete mode 100644 latest/_modules/gcloud/bigtable/happybase/table.html delete mode 100644 latest/_modules/gcloud/datastore/connection.html delete mode 100644 latest/_modules/gcloud/dns/connection.html delete mode 100644 latest/_modules/gcloud/dns/resource_record_set.html delete mode 100644 latest/_modules/gcloud/monitoring/client.html delete mode 100644 latest/_modules/gcloud/monitoring/connection.html delete mode 100644 latest/_modules/gcloud/resource_manager/connection.html delete mode 100644 latest/_modules/gcloud/storage/connection.html delete mode 100644 latest/_modules/gcloud/translate/connection.html rename latest/_modules/{gcloud => google/cloud}/bigquery/_helpers.html (71%) rename latest/_modules/{gcloud => google/cloud}/bigquery/client.html (54%) create mode 100644 latest/_modules/google/cloud/bigquery/connection.html rename latest/_modules/{gcloud => google/cloud}/bigquery/dataset.html (80%) rename latest/_modules/{gcloud => google/cloud}/bigquery/job.html (82%) rename latest/_modules/{gcloud => google/cloud}/bigquery/query.html (73%) create mode 100644 latest/_modules/google/cloud/bigquery/schema.html rename latest/_modules/{gcloud => google/cloud}/bigquery/table.html (79%) create mode 100644 latest/_modules/google/cloud/bigtable/client.html rename latest/_modules/{gcloud => google/cloud}/bigtable/cluster.html (51%) rename latest/_modules/{gcloud => google/cloud}/bigtable/column_family.html (73%) rename latest/_modules/{gcloud => google/cloud}/bigtable/instance.html (54%) rename latest/_modules/{gcloud => google/cloud}/bigtable/row.html (82%) rename latest/_modules/{gcloud => google/cloud}/bigtable/row_data.html (81%) rename latest/_modules/{gcloud => google/cloud}/bigtable/row_filters.html (77%) rename latest/_modules/{gcloud => google/cloud}/bigtable/table.html (73%) rename latest/_modules/{gcloud => google/cloud}/client.html (68%) rename latest/_modules/{gcloud => google/cloud}/connection.html (76%) rename latest/_modules/{gcloud => google/cloud}/credentials.html (69%) rename latest/_modules/{gcloud => google/cloud}/datastore/batch.html (70%) rename latest/_modules/{gcloud => google/cloud}/datastore/client.html (68%) create mode 100644 latest/_modules/google/cloud/datastore/connection.html rename latest/_modules/{gcloud => google/cloud}/datastore/entity.html (62%) rename latest/_modules/{gcloud => google/cloud}/datastore/helpers.html (80%) rename latest/_modules/{gcloud => google/cloud}/datastore/key.html (79%) rename latest/_modules/{gcloud => google/cloud}/datastore/query.html (80%) rename latest/_modules/{gcloud => google/cloud}/datastore/transaction.html (59%) rename latest/_modules/{gcloud => google/cloud}/dns/changes.html (68%) rename latest/_modules/{gcloud => google/cloud}/dns/client.html (57%) create mode 100644 latest/_modules/google/cloud/dns/connection.html create mode 100644 latest/_modules/google/cloud/dns/resource_record_set.html rename latest/_modules/{gcloud => google/cloud}/dns/zone.html (73%) create mode 100644 latest/_modules/google/cloud/error_reporting/client.html rename latest/_modules/{gcloud => google/cloud}/exceptions.html (58%) create mode 100644 latest/_modules/google/cloud/language/client.html create mode 100644 latest/_modules/google/cloud/language/connection.html create mode 100644 latest/_modules/google/cloud/language/document.html create mode 100644 latest/_modules/google/cloud/language/entity.html create mode 100644 latest/_modules/google/cloud/language/sentiment.html create mode 100644 latest/_modules/google/cloud/language/syntax.html rename latest/_modules/{gcloud => google/cloud}/logging/client.html (63%) rename latest/_modules/{gcloud => google/cloud}/logging/connection.html (81%) rename latest/_modules/{gcloud => google/cloud}/logging/entries.html (62%) create mode 100644 latest/_modules/google/cloud/logging/handlers/handlers.html create mode 100644 latest/_modules/google/cloud/logging/handlers/transports/background_thread.html create mode 100644 latest/_modules/google/cloud/logging/handlers/transports/base.html create mode 100644 latest/_modules/google/cloud/logging/handlers/transports/sync.html rename latest/_modules/{gcloud => google/cloud}/logging/logger.html (73%) rename latest/_modules/{gcloud => google/cloud}/logging/metric.html (61%) rename latest/_modules/{gcloud => google/cloud}/logging/sink.html (62%) create mode 100644 latest/_modules/google/cloud/monitoring/client.html create mode 100644 latest/_modules/google/cloud/monitoring/connection.html create mode 100644 latest/_modules/google/cloud/monitoring/group.html rename latest/_modules/{gcloud => google/cloud}/monitoring/label.html (58%) rename latest/_modules/{gcloud => google/cloud}/monitoring/metric.html (75%) rename latest/_modules/{gcloud => google/cloud}/monitoring/query.html (76%) rename latest/_modules/{gcloud => google/cloud}/monitoring/resource.html (66%) rename latest/_modules/{gcloud => google/cloud}/monitoring/timeseries.html (62%) create mode 100644 latest/_modules/google/cloud/operation.html rename latest/_modules/{gcloud => google/cloud}/pubsub/client.html (58%) rename latest/_modules/{gcloud => google/cloud}/pubsub/connection.html (82%) rename latest/_modules/{gcloud => google/cloud}/pubsub/iam.html (70%) rename latest/_modules/{gcloud => google/cloud}/pubsub/message.html (56%) rename latest/_modules/{gcloud => google/cloud}/pubsub/subscription.html (70%) rename latest/_modules/{gcloud => google/cloud}/pubsub/topic.html (69%) rename latest/_modules/{gcloud => google/cloud}/resource_manager/client.html (56%) create mode 100644 latest/_modules/google/cloud/resource_manager/connection.html rename latest/_modules/{gcloud => google/cloud}/resource_manager/project.html (67%) rename latest/_modules/{gcloud => google/cloud}/storage/acl.html (76%) rename latest/_modules/{gcloud => google/cloud}/storage/batch.html (78%) rename latest/_modules/{gcloud => google/cloud}/storage/blob.html (82%) rename latest/_modules/{gcloud => google/cloud}/storage/bucket.html (79%) rename latest/_modules/{gcloud => google/cloud}/storage/client.html (66%) create mode 100644 latest/_modules/google/cloud/storage/connection.html rename latest/_modules/{gcloud => google/cloud}/translate/client.html (72%) create mode 100644 latest/_modules/google/cloud/translate/connection.html create mode 100644 latest/_modules/google/cloud/vision/client.html create mode 100644 latest/_modules/google/cloud/vision/connection.html create mode 100644 latest/_modules/google/cloud/vision/feature.html create mode 100644 latest/_modules/google/cloud/vision/image.html create mode 100644 latest/_sources/bigquery-schema.txt create mode 100644 latest/_sources/error-reporting-client.txt create mode 100644 latest/_sources/error-reporting-usage.txt delete mode 100644 latest/_sources/happybase-batch.txt delete mode 100644 latest/_sources/happybase-connection.txt delete mode 100644 latest/_sources/happybase-package.txt delete mode 100644 latest/_sources/happybase-pool.txt delete mode 100644 latest/_sources/happybase-table.txt create mode 100644 latest/_sources/language-client.txt create mode 100644 latest/_sources/language-document.txt create mode 100644 latest/_sources/language-responses.txt create mode 100644 latest/_sources/language-usage.txt create mode 100644 latest/_sources/logging-handlers.txt create mode 100644 latest/_sources/logging-transports-base.txt create mode 100644 latest/_sources/logging-transports-sync.txt create mode 100644 latest/_sources/logging-transports-thread.txt create mode 100644 latest/_sources/monitoring-group.txt create mode 100644 latest/_sources/operation-api.txt create mode 100644 latest/_sources/vision-client.txt create mode 100644 latest/_sources/vision-feature.txt create mode 100644 latest/_sources/vision-image.txt create mode 100644 latest/_sources/vision-usage.txt delete mode 100644 latest/_static/alabaster.css create mode 100644 latest/_static/css/badge_only.css delete mode 100644 latest/_static/css/main.css delete mode 100644 latest/_static/css/normalize.css create mode 100644 latest/_static/css/theme.css delete mode 100644 latest/_static/custom.css create mode 100644 latest/_static/fonts/Inconsolata-Bold.ttf create mode 100644 latest/_static/fonts/Inconsolata-Regular.ttf create mode 100644 latest/_static/fonts/Lato-Bold.ttf create mode 100644 latest/_static/fonts/Lato-Regular.ttf create mode 100644 latest/_static/fonts/RobotoSlab-Bold.ttf create mode 100644 latest/_static/fonts/RobotoSlab-Regular.ttf create mode 100644 latest/_static/fonts/fontawesome-webfont.eot create mode 100644 latest/_static/fonts/fontawesome-webfont.svg create mode 100644 latest/_static/fonts/fontawesome-webfont.ttf create mode 100644 latest/_static/fonts/fontawesome-webfont.woff delete mode 100644 latest/_static/images/datastore-logo.png delete mode 100644 latest/_static/images/icon-arrow-bullet.svg delete mode 100644 latest/_static/images/icon-dropdown-faq.svg delete mode 100644 latest/_static/images/icon-dropdown.svg delete mode 100644 latest/_static/images/icon-lang-dotnet.svg delete mode 100644 latest/_static/images/icon-lang-java-duke.svg delete mode 100644 latest/_static/images/icon-lang-nodejs.svg delete mode 100644 latest/_static/images/icon-lang-python.svg delete mode 100644 latest/_static/images/icon-lang-ruby.svg delete mode 100644 latest/_static/images/icon-link-github.svg delete mode 100644 latest/_static/images/icon-link-package-manager.svg delete mode 100644 latest/_static/images/icon-link-stackoverflow.svg delete mode 100644 latest/_static/images/icon-menu.svg delete mode 100644 latest/_static/images/icon-table-check.svg delete mode 100644 latest/_static/images/lang-bg.png delete mode 100644 latest/_static/images/logo-full.svg delete mode 100644 latest/_static/images/logo.svg delete mode 100644 latest/_static/images/storage-logo.png delete mode 100644 latest/_static/js/main.js rename latest/_static/js/{vendor/modernizr-2.6.2.min.js => modernizr.min.js} (100%) delete mode 100644 latest/_static/js/plugins.js create mode 100644 latest/_static/js/theme.js delete mode 100644 latest/_static/js/vendor/jquery-1.10.2.min.js delete mode 100644 latest/_static/js/vendor/prettify.js create mode 100644 latest/bigquery-schema.html create mode 100644 latest/error-reporting-client.html create mode 100644 latest/error-reporting-usage.html delete mode 100644 latest/happybase-batch.html delete mode 100644 latest/happybase-connection.html delete mode 100644 latest/happybase-package.html delete mode 100644 latest/happybase-pool.html delete mode 100644 latest/happybase-table.html create mode 100644 latest/language-client.html create mode 100644 latest/language-document.html create mode 100644 latest/language-responses.html create mode 100644 latest/language-usage.html create mode 100644 latest/logging-handlers.html create mode 100644 latest/logging-transports-base.html create mode 100644 latest/logging-transports-sync.html create mode 100644 latest/logging-transports-thread.html create mode 100644 latest/monitoring-group.html create mode 100644 latest/operation-api.html create mode 100644 latest/vision-client.html create mode 100644 latest/vision-feature.html create mode 100644 latest/vision-image.html create mode 100644 latest/vision-usage.html diff --git a/latest/.buildinfo b/latest/.buildinfo index a1cb70e9df85..e7c0d4c4bb62 100644 --- a/latest/.buildinfo +++ b/latest/.buildinfo @@ -1,4 +1,4 @@ # Sphinx build info version 1 # This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. -config: c47f8a026362260bbd4b30e616d24b42 +config: b1abedd30578a89bbd7f5f0c1adf0729 tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/latest/_modules/gcloud/bigquery/connection.html b/latest/_modules/gcloud/bigquery/connection.html deleted file mode 100644 index 9e15efd7c8f0..000000000000 --- a/latest/_modules/gcloud/bigquery/connection.html +++ /dev/null @@ -1,255 +0,0 @@ - - - - - - - - gcloud.bigquery.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigquery.connection

    -# Copyright 2015 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with gcloud bigquery connections."""
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud BigQuery via the JSON REST API.""" - - API_BASE_URL = 'https://www.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v2' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/bigquery/{api_version}{path}' - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/bigquery', - 'https://www.googleapis.com/auth/cloud-platform') - """The scopes required for authenticating as a Cloud BigQuery consumer."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/client.html b/latest/_modules/gcloud/bigtable/client.html deleted file mode 100644 index 01d3d0552f1c..000000000000 --- a/latest/_modules/gcloud/bigtable/client.html +++ /dev/null @@ -1,701 +0,0 @@ - - - - - - - - gcloud.bigtable.client — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigtable.client

    -# Copyright 2015 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Parent client for calling the Google Cloud Bigtable API.
    -
    -This is the base from which all interactions with the API occur.
    -
    -In the hierarchy of API concepts
    -
    -* a :class:`Client` owns an :class:`.Instance`
    -* a :class:`.Instance` owns a :class:`Table <gcloud.bigtable.table.Table>`
    -* a :class:`Table <gcloud.bigtable.table.Table>` owns a
    -  :class:`ColumnFamily <.column_family.ColumnFamily>`
    -* a :class:`Table <gcloud.bigtable.table.Table>` owns a :class:`Row <.row.Row>`
    -  (and all the cells in the row)
    -"""
    -
    -
    -from pkg_resources import get_distribution
    -
    -from grpc.beta import implementations
    -
    -from gcloud.bigtable._generated_v2 import (
    -    bigtable_instance_admin_pb2 as instance_admin_v2_pb2)
    -# V1 table admin service
    -from gcloud.bigtable._generated_v2 import (
    -    bigtable_table_admin_pb2 as table_admin_v2_pb2)
    -# V1 data service
    -from gcloud.bigtable._generated_v2 import (
    -    bigtable_pb2 as data_v2_pb2)
    -
    -from gcloud.bigtable._generated_v2 import (
    -    operations_grpc_pb2 as operations_grpc_v2_pb2)
    -
    -from gcloud.bigtable.cluster import DEFAULT_SERVE_NODES
    -from gcloud.bigtable.instance import Instance
    -from gcloud.bigtable.instance import _EXISTING_INSTANCE_LOCATION_ID
    -from gcloud.client import _ClientFactoryMixin
    -from gcloud.client import _ClientProjectMixin
    -from gcloud.credentials import get_credentials
    -
    -
    -TABLE_STUB_FACTORY_V2 = (
    -    table_admin_v2_pb2.beta_create_BigtableTableAdmin_stub)
    -TABLE_ADMIN_HOST_V2 = 'bigtableadmin.googleapis.com'
    -"""Table Admin API request host."""
    -TABLE_ADMIN_PORT_V2 = 443
    -"""Table Admin API request port."""
    -
    -INSTANCE_STUB_FACTORY_V2 = (
    -    instance_admin_v2_pb2.beta_create_BigtableInstanceAdmin_stub)
    -INSTANCE_ADMIN_HOST_V2 = 'bigtableadmin.googleapis.com'
    -"""Cluster Admin API request host."""
    -INSTANCE_ADMIN_PORT_V2 = 443
    -"""Cluster Admin API request port."""
    -
    -DATA_STUB_FACTORY_V2 = data_v2_pb2.beta_create_Bigtable_stub
    -DATA_API_HOST_V2 = 'bigtable.googleapis.com'
    -"""Data API request host."""
    -DATA_API_PORT_V2 = 443
    -"""Data API request port."""
    -
    -OPERATIONS_STUB_FACTORY_V2 = operations_grpc_v2_pb2.beta_create_Operations_stub
    -OPERATIONS_API_HOST_V2 = INSTANCE_ADMIN_HOST_V2
    -OPERATIONS_API_PORT_V2 = INSTANCE_ADMIN_PORT_V2
    -
    -ADMIN_SCOPE = 'https://www.googleapis.com/auth/bigtable.admin'
    -"""Scope for interacting with the Cluster Admin and Table Admin APIs."""
    -DATA_SCOPE = 'https://www.googleapis.com/auth/bigtable.data'
    -"""Scope for reading and writing table data."""
    -READ_ONLY_SCOPE = 'https://www.googleapis.com/auth/bigtable.data.readonly'
    -"""Scope for reading table data."""
    -
    -DEFAULT_TIMEOUT_SECONDS = 10
    -"""The default timeout to use for API requests."""
    -
    -DEFAULT_USER_AGENT = 'gcloud-python/{0}'.format(
    -    get_distribution('gcloud').version)
    -"""The default user agent for API requests."""
    -
    -
    -
    [docs]class Client(_ClientFactoryMixin, _ClientProjectMixin): - """Client for interacting with Google Cloud Bigtable API. - - .. note:: - - Since the Cloud Bigtable API requires the gRPC transport, no - ``http`` argument is accepted by this class. - - :type project: :class:`str` or :func:`unicode <unicode>` - :param project: (Optional) The ID of the project which owns the - instances, tables and data. If not provided, will - attempt to determine from the environment. - - :type credentials: - :class:`OAuth2Credentials <oauth2client.client.OAuth2Credentials>` or - :data:`NoneType <types.NoneType>` - :param credentials: (Optional) The OAuth2 Credentials to use for this - client. If not provided, defaults to the Google - Application Default Credentials. - - :type read_only: bool - :param read_only: (Optional) Boolean indicating if the data scope should be - for reading only (or for writing as well). Defaults to - :data:`False`. - - :type admin: bool - :param admin: (Optional) Boolean indicating if the client will be used to - interact with the Instance Admin or Table Admin APIs. This - requires the :const:`ADMIN_SCOPE`. Defaults to :data:`False`. - - :type user_agent: str - :param user_agent: (Optional) The user agent to be used with API request. - Defaults to :const:`DEFAULT_USER_AGENT`. - - :type timeout_seconds: int - :param timeout_seconds: Number of seconds for request time-out. If not - passed, defaults to - :const:`DEFAULT_TIMEOUT_SECONDS`. - - :raises: :class:`ValueError <exceptions.ValueError>` if both ``read_only`` - and ``admin`` are :data:`True` - """ - - def __init__(self, project=None, credentials=None, - read_only=False, admin=False, user_agent=DEFAULT_USER_AGENT, - timeout_seconds=DEFAULT_TIMEOUT_SECONDS): - _ClientProjectMixin.__init__(self, project=project) - if credentials is None: - credentials = get_credentials() - - if read_only and admin: - raise ValueError('A read-only client cannot also perform' - 'administrative actions.') - - scopes = [] - if read_only: - scopes.append(READ_ONLY_SCOPE) - else: - scopes.append(DATA_SCOPE) - - if admin: - scopes.append(ADMIN_SCOPE) - - self._admin = bool(admin) - try: - credentials = credentials.create_scoped(scopes) - except AttributeError: - pass - self._credentials = credentials - self.user_agent = user_agent - self.timeout_seconds = timeout_seconds - - # These will be set in start(). - self._data_stub_internal = None - self._instance_stub_internal = None - self._operations_stub_internal = None - self._table_stub_internal = None - -
    [docs] def copy(self): - """Make a copy of this client. - - Copies the local data stored as simple types but does not copy the - current state of any open connections with the Cloud Bigtable API. - - :rtype: :class:`.Client` - :returns: A copy of the current client. - """ - credentials = self._credentials - copied_creds = credentials.create_scoped(credentials.scopes) - return self.__class__( - self.project, - copied_creds, - READ_ONLY_SCOPE in copied_creds.scopes, - self._admin, - self.user_agent, - self.timeout_seconds, - )
    - - @property - def credentials(self): - """Getter for client's credentials. - - :rtype: - :class:`OAuth2Credentials <oauth2client.client.OAuth2Credentials>` - :returns: The credentials stored on the client. - """ - return self._credentials - - @property - def project_name(self): - """Project name to be used with Instance Admin API. - - .. note:: - - This property will not change if ``project`` does not, but the - return value is not cached. - - The project name is of the form - - ``"projects/{project}"`` - - :rtype: str - :returns: The project name to be used with the Cloud Bigtable Admin - API RPC service. - """ - return 'projects/' + self.project - - @property - def _data_stub(self): - """Getter for the gRPC stub used for the Data API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - :raises: :class:`ValueError <exceptions.ValueError>` if the current - client has not been :meth:`start`-ed. - """ - if self._data_stub_internal is None: - raise ValueError('Client has not been started.') - return self._data_stub_internal - - @property - def _instance_stub(self): - """Getter for the gRPC stub used for the Instance Admin API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - :raises: :class:`ValueError <exceptions.ValueError>` if the current - client is not an admin client or if it has not been - :meth:`start`-ed. - """ - if not self._admin: - raise ValueError('Client is not an admin client.') - if self._instance_stub_internal is None: - raise ValueError('Client has not been started.') - return self._instance_stub_internal - - @property - def _operations_stub(self): - """Getter for the gRPC stub used for the Operations API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - :raises: :class:`ValueError <exceptions.ValueError>` if the current - client is not an admin client or if it has not been - :meth:`start`-ed. - """ - if not self._admin: - raise ValueError('Client is not an admin client.') - if self._operations_stub_internal is None: - raise ValueError('Client has not been started.') - return self._operations_stub_internal - - @property - def _table_stub(self): - """Getter for the gRPC stub used for the Table Admin API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - :raises: :class:`ValueError <exceptions.ValueError>` if the current - client is not an admin client or if it has not been - :meth:`start`-ed. - """ - if not self._admin: - raise ValueError('Client is not an admin client.') - if self._table_stub_internal is None: - raise ValueError('Client has not been started.') - return self._table_stub_internal - - def _make_data_stub(self): - """Creates gRPC stub to make requests to the Data API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - """ - return _make_stub(self, DATA_STUB_FACTORY_V2, - DATA_API_HOST_V2, DATA_API_PORT_V2) - - def _make_instance_stub(self): - """Creates gRPC stub to make requests to the Instance Admin API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - """ - return _make_stub(self, INSTANCE_STUB_FACTORY_V2, - INSTANCE_ADMIN_HOST_V2, INSTANCE_ADMIN_PORT_V2) - - def _make_operations_stub(self): - """Creates gRPC stub to make requests to the Operations API. - - These are for long-running operations of the Instance Admin API, - hence the host and port matching. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - """ - return _make_stub(self, OPERATIONS_STUB_FACTORY_V2, - OPERATIONS_API_HOST_V2, OPERATIONS_API_PORT_V2) - - def _make_table_stub(self): - """Creates gRPC stub to make requests to the Table Admin API. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: A gRPC stub object. - """ - return _make_stub(self, TABLE_STUB_FACTORY_V2, - TABLE_ADMIN_HOST_V2, TABLE_ADMIN_PORT_V2) - -
    [docs] def is_started(self): - """Check if the client has been started. - - :rtype: bool - :returns: Boolean indicating if the client has been started. - """ - return self._data_stub_internal is not None
    - -
    [docs] def start(self): - """Prepare the client to make requests. - - Activates gRPC contexts for making requests to the Bigtable - Service(s). - """ - if self.is_started(): - return - - # NOTE: We __enter__ the stubs more-or-less permanently. This is - # because only after entering the context managers is the - # connection created. We don't want to immediately close - # those connections since the client will make many - # requests with it over HTTP/2. - self._data_stub_internal = self._make_data_stub() - self._data_stub_internal.__enter__() - if self._admin: - self._instance_stub_internal = self._make_instance_stub() - self._operations_stub_internal = self._make_operations_stub() - self._table_stub_internal = self._make_table_stub() - - self._instance_stub_internal.__enter__() - self._operations_stub_internal.__enter__() - self._table_stub_internal.__enter__()
    - - def __enter__(self): - """Starts the client as a context manager.""" - self.start() - return self - -
    [docs] def stop(self): - """Closes all the open gRPC clients.""" - if not self.is_started(): - return - - # When exit-ing, we pass None as the exception type, value and - # traceback to __exit__. - self._data_stub_internal.__exit__(None, None, None) - if self._admin: - self._instance_stub_internal.__exit__(None, None, None) - self._operations_stub_internal.__exit__(None, None, None) - self._table_stub_internal.__exit__(None, None, None) - - self._data_stub_internal = None - self._instance_stub_internal = None - self._operations_stub_internal = None - self._table_stub_internal = None
    - - def __exit__(self, exc_type, exc_val, exc_t): - """Stops the client as a context manager.""" - self.stop() - -
    [docs] def instance(self, instance_id, location=_EXISTING_INSTANCE_LOCATION_ID, - display_name=None, serve_nodes=DEFAULT_SERVE_NODES): - """Factory to create a instance associated with this client. - - :type instance_id: str - :param instance_id: The ID of the instance. - - :type location: string - :param location: location name, in form - ``projects/<project>/locations/<location>``; used to - set up the instance's cluster. - - :type display_name: str - :param display_name: (Optional) The display name for the instance in - the Cloud Console UI. (Must be between 4 and 30 - characters.) If this value is not set in the - constructor, will fall back to the instance ID. - - :type serve_nodes: int - :param serve_nodes: (Optional) The number of nodes in the instance's - cluster; used to set up the instance's cluster. - - :rtype: :class:`.Instance` - :returns: an instance owned by this client. - """ - return Instance(instance_id, self, location, - display_name=display_name, serve_nodes=serve_nodes)
    - -
    [docs] def list_instances(self): - """List instances owned by the project. - - :rtype: tuple - :returns: A pair of results, the first is a list of - :class:`.Instance` objects returned and the second is a - list of strings (the failed locations in the request). - """ - request_pb = instance_admin_v2_pb2.ListInstancesRequest( - parent=self.project_name) - - response = self._instance_stub.ListInstances( - request_pb, self.timeout_seconds) - - instances = [Instance.from_pb(instance_pb, self) - for instance_pb in response.instances] - return instances, response.failed_locations
    - - -class _MetadataPlugin(object): - """Callable class to transform metadata for gRPC requests. - - :type client: :class:`.client.Client` - :param client: The client that owns the instance. - Provides authorization and user agent. - """ - - def __init__(self, client): - self._credentials = client.credentials - self._user_agent = client.user_agent - - def __call__(self, unused_context, callback): - """Adds authorization header to request metadata.""" - access_token = self._credentials.get_access_token().access_token - headers = [ - ('Authorization', 'Bearer ' + access_token), - ('User-agent', self._user_agent), - ] - callback(headers, None) - - -def _make_stub(client, stub_factory, host, port): - """Makes a stub for an RPC service. - - Uses / depends on the beta implementation of gRPC. - - :type client: :class:`.client.Client` - :param client: The client that owns the instance. - Provides authorization and user agent. - - :type stub_factory: callable - :param stub_factory: A factory which will create a gRPC stub for - a given service. - - :type host: str - :param host: The host for the service. - - :type port: int - :param port: The port for the service. - - :rtype: :class:`grpc.beta._stub._AutoIntermediary` - :returns: The stub object used to make gRPC requests to a given API. - """ - # Leaving the first argument to ssl_channel_credentials() as None - # loads root certificates from `grpc/_adapter/credentials/roots.pem`. - transport_creds = implementations.ssl_channel_credentials(None, None, None) - custom_metadata_plugin = _MetadataPlugin(client) - auth_creds = implementations.metadata_call_credentials( - custom_metadata_plugin, name='google_creds') - channel_creds = implementations.composite_channel_credentials( - transport_creds, auth_creds) - channel = implementations.secure_channel(host, port, channel_creds) - return stub_factory(channel) -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/happybase/batch.html b/latest/_modules/gcloud/bigtable/happybase/batch.html deleted file mode 100644 index c94c71e4a207..000000000000 --- a/latest/_modules/gcloud/bigtable/happybase/batch.html +++ /dev/null @@ -1,547 +0,0 @@ - - - - - - - - gcloud.bigtable.happybase.batch — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigtable.happybase.batch

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Google Cloud Bigtable HappyBase batch module."""
    -
    -
    -import datetime
    -import warnings
    -
    -import six
    -
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud.bigtable.row_filters import TimestampRange
    -
    -
    -_WAL_SENTINEL = object()
    -# Assumed granularity of timestamps in Cloud Bigtable.
    -_ONE_MILLISECOND = datetime.timedelta(microseconds=1000)
    -_WARN = warnings.warn
    -_WAL_WARNING = ('The wal argument (Write-Ahead-Log) is not '
    -                'supported by Cloud Bigtable.')
    -
    -
    -
    [docs]class Batch(object): - """Batch class for accumulating mutations. - - .. note:: - - When using a batch with ``transaction=False`` as a context manager - (i.e. in a ``with`` statement), mutations will still be sent as - row mutations even if the context manager exits with an error. - This behavior is in place to match the behavior in the HappyBase - HBase / Thrift implementation. - - :type table: :class:`Table <gcloud.bigtable.happybase.table.Table>` - :param table: The table where mutations will be applied. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the epoch) - that all mutations will be applied at. - - :type batch_size: int - :param batch_size: (Optional) The maximum number of mutations to allow - to accumulate before committing them. - - :type transaction: bool - :param transaction: Flag indicating if the mutations should be sent - transactionally or not. If ``transaction=True`` and - an error occurs while a :class:`Batch` is active, - then none of the accumulated mutations will be - committed. If ``batch_size`` is set, the mutation - can't be transactional. - - :type wal: object - :param wal: Unused parameter (Boolean for using the HBase Write Ahead Log). - Provided for compatibility with HappyBase, but irrelevant for - Cloud Bigtable since it does not have a Write Ahead Log. - - :raises: :class:`TypeError <exceptions.TypeError>` if ``batch_size`` - is set and ``transaction=True``. - :class:`ValueError <exceptions.ValueError>` if ``batch_size`` - is not positive. - """ - - def __init__(self, table, timestamp=None, batch_size=None, - transaction=False, wal=_WAL_SENTINEL): - if wal is not _WAL_SENTINEL: - _WARN(_WAL_WARNING) - - if batch_size is not None: - if transaction: - raise TypeError('When batch_size is set, a Batch cannot be ' - 'transactional') - if batch_size <= 0: - raise ValueError('batch_size must be positive') - - self._table = table - self._batch_size = batch_size - self._timestamp = self._delete_range = None - - # Timestamp is in milliseconds, convert to microseconds. - if timestamp is not None: - self._timestamp = _datetime_from_microseconds(1000 * timestamp) - # For deletes, we get the very next timestamp (assuming timestamp - # granularity is milliseconds). This is because HappyBase users - # expect HBase deletes to go **up to** and **including** the - # timestamp while Cloud Bigtable Time Ranges **exclude** the - # final timestamp. - next_timestamp = self._timestamp + _ONE_MILLISECOND - self._delete_range = TimestampRange(end=next_timestamp) - - self._transaction = transaction - - # Internal state for tracking mutations. - self._row_map = {} - self._mutation_count = 0 - -
    [docs] def send(self): - """Send / commit the batch of mutations to the server.""" - for row in self._row_map.values(): - # commit() does nothing if row hasn't accumulated any mutations. - row.commit() - - self._row_map.clear() - self._mutation_count = 0
    - - def _try_send(self): - """Send / commit the batch if mutations have exceeded batch size.""" - if self._batch_size and self._mutation_count >= self._batch_size: - self.send() - - def _get_row(self, row_key): - """Gets a row that will hold mutations. - - If the row is not already cached on the current batch, a new row will - be created. - - :type row_key: str - :param row_key: The row key for a row stored in the map. - - :rtype: :class:`Row <gcloud.bigtable.row.Row>` - :returns: The newly created or stored row that will hold mutations. - """ - if row_key not in self._row_map: - table = self._table._low_level_table - self._row_map[row_key] = table.row(row_key) - - return self._row_map[row_key] - -
    [docs] def put(self, row, data, wal=_WAL_SENTINEL): - """Insert data into a row in the table owned by this batch. - - :type row: str - :param row: The row key where the mutation will be "put". - - :type data: dict - :param data: Dictionary containing the data to be inserted. The keys - are columns names (of the form ``fam:col``) and the values - are strings (bytes) to be stored in those columns. - - :type wal: object - :param wal: Unused parameter (to over-ride the default on the - instance). Provided for compatibility with HappyBase, but - irrelevant for Cloud Bigtable since it does not have a - Write Ahead Log. - """ - if wal is not _WAL_SENTINEL: - _WARN(_WAL_WARNING) - - row_object = self._get_row(row) - # Make sure all the keys are valid before beginning - # to add mutations. - column_pairs = _get_column_pairs(six.iterkeys(data), - require_qualifier=True) - for column_family_id, column_qualifier in column_pairs: - value = data[column_family_id + ':' + column_qualifier] - row_object.set_cell(column_family_id, column_qualifier, - value, timestamp=self._timestamp) - - self._mutation_count += len(data) - self._try_send()
    - - def _delete_columns(self, columns, row_object): - """Adds delete mutations for a list of columns and column families. - - :type columns: list - :param columns: Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type row_object: :class:`Row <gcloud_bigtable.row.Row>` - :param row_object: The row which will hold the delete mutations. - - :raises: :class:`ValueError <exceptions.ValueError>` if the delete - timestamp range is set on the current batch, but a - column family delete is attempted. - """ - column_pairs = _get_column_pairs(columns) - for column_family_id, column_qualifier in column_pairs: - if column_qualifier is None: - if self._delete_range is not None: - raise ValueError('The Cloud Bigtable API does not support ' - 'adding a timestamp to ' - '"DeleteFromFamily" ') - row_object.delete_cells(column_family_id, - columns=row_object.ALL_COLUMNS) - else: - row_object.delete_cell(column_family_id, - column_qualifier, - time_range=self._delete_range) - -
    [docs] def delete(self, row, columns=None, wal=_WAL_SENTINEL): - """Delete data from a row in the table owned by this batch. - - :type row: str - :param row: The row key where the delete will occur. - - :type columns: list - :param columns: (Optional) Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - If not used, will delete the entire row. - - :type wal: object - :param wal: Unused parameter (to over-ride the default on the - instance). Provided for compatibility with HappyBase, but - irrelevant for Cloud Bigtable since it does not have a - Write Ahead Log. - - :raises: If the delete timestamp range is set on the - current batch, but a full row delete is attempted. - """ - if wal is not _WAL_SENTINEL: - _WARN(_WAL_WARNING) - - row_object = self._get_row(row) - - if columns is None: - # Delete entire row. - if self._delete_range is not None: - raise ValueError('The Cloud Bigtable API does not support ' - 'adding a timestamp to "DeleteFromRow" ' - 'mutations') - row_object.delete() - self._mutation_count += 1 - else: - self._delete_columns(columns, row_object) - self._mutation_count += len(columns) - - self._try_send()
    - - def __enter__(self): - """Enter context manager, no set-up required.""" - return self - - def __exit__(self, exc_type, exc_value, traceback): - """Exit context manager, no set-up required. - - :type exc_type: type - :param exc_type: The type of the exception if one occurred while the - context manager was active. Otherwise, :data:`None`. - - :type exc_value: :class:`Exception <exceptions.Exception>` - :param exc_value: An instance of ``exc_type`` if an exception occurred - while the context was active. - Otherwise, :data:`None`. - - :type traceback: ``traceback`` type - :param traceback: The traceback where the exception occurred (if one - did occur). Otherwise, :data:`None`. - """ - # If the context manager encountered an exception and the batch is - # transactional, we don't commit the mutations. - if self._transaction and exc_type is not None: - return - - # NOTE: For non-transactional batches, this will even commit mutations - # if an error occurred during the context manager. - self.send()
    - - -def _get_column_pairs(columns, require_qualifier=False): - """Turns a list of column or column families into parsed pairs. - - Turns a column family (``fam`` or ``fam:``) into a pair such - as ``['fam', None]`` and turns a column (``fam:col``) into - ``['fam', 'col']``. - - :type columns: list - :param columns: Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type require_qualifier: bool - :param require_qualifier: Boolean indicating if the columns should - all have a qualifier or not. - - :rtype: list - :returns: List of pairs, where the first element in each pair is the - column family and the second is the column qualifier - (or :data:`None`). - :raises: :class:`ValueError <exceptions.ValueError>` if any of the columns - are not of the expected format. - :class:`ValueError <exceptions.ValueError>` if - ``require_qualifier`` is :data:`True` and one of the values is - for an entire column family - """ - column_pairs = [] - for column in columns: - if isinstance(column, six.binary_type): - column = column.decode('utf-8') - # Remove trailing colons (i.e. for standalone column family). - if column.endswith(u':'): - column = column[:-1] - num_colons = column.count(u':') - if num_colons == 0: - # column is a column family. - if require_qualifier: - raise ValueError('column does not contain a qualifier', - column) - else: - column_pairs.append([column, None]) - elif num_colons == 1: - column_pairs.append(column.split(u':')) - else: - raise ValueError('Column contains the : separator more than once') - - return column_pairs -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/happybase/connection.html b/latest/_modules/gcloud/bigtable/happybase/connection.html deleted file mode 100644 index afcd3b62e3b9..000000000000 --- a/latest/_modules/gcloud/bigtable/happybase/connection.html +++ /dev/null @@ -1,712 +0,0 @@ - - - - - - - - gcloud.bigtable.happybase.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigtable.happybase.connection

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Google Cloud Bigtable HappyBase connection module."""
    -
    -
    -import datetime
    -import warnings
    -
    -import six
    -
    -from grpc.beta import interfaces
    -from grpc.framework.interfaces.face import face
    -
    -try:
    -    from happybase.hbase.ttypes import AlreadyExists
    -except ImportError:
    -    from gcloud.exceptions import Conflict as AlreadyExists
    -
    -from gcloud.bigtable.client import Client
    -from gcloud.bigtable.column_family import GCRuleIntersection
    -from gcloud.bigtable.column_family import MaxAgeGCRule
    -from gcloud.bigtable.column_family import MaxVersionsGCRule
    -from gcloud.bigtable.happybase.table import Table
    -from gcloud.bigtable.table import Table as _LowLevelTable
    -
    -
    -# Constants reproduced here for HappyBase compatibility, though values
    -# are all null.
    -COMPAT_MODES = None
    -THRIFT_TRANSPORTS = None
    -THRIFT_PROTOCOLS = None
    -DEFAULT_HOST = None
    -DEFAULT_PORT = None
    -DEFAULT_TRANSPORT = None
    -DEFAULT_COMPAT = None
    -DEFAULT_PROTOCOL = None
    -
    -_LEGACY_ARGS = frozenset(('host', 'port', 'compat', 'transport', 'protocol'))
    -_WARN = warnings.warn
    -_BASE_DISABLE = 'Cloud Bigtable has no concept of enabled / disabled tables.'
    -_DISABLE_DELETE_MSG = ('The disable argument should not be used in '
    -                       'delete_table(). ') + _BASE_DISABLE
    -_ENABLE_TMPL = 'Connection.enable_table(%r) was called, but ' + _BASE_DISABLE
    -_DISABLE_TMPL = 'Connection.disable_table(%r) was called, but ' + _BASE_DISABLE
    -_IS_ENABLED_TMPL = ('Connection.is_table_enabled(%r) was called, but ' +
    -                    _BASE_DISABLE)
    -_COMPACT_TMPL = ('Connection.compact_table(%r, major=%r) was called, but the '
    -                 'Cloud Bigtable API handles table compactions automatically '
    -                 'and does not expose an API for it.')
    -
    -
    -def _get_instance(timeout=None):
    -    """Gets instance for the default project.
    -
    -    Creates a client with the inferred credentials and project ID from
    -    the local environment. Then uses
    -    :meth:`.bigtable.client.Client.list_instances` to
    -    get the unique instance owned by the project.
    -
    -    If the request fails for any reason, or if there isn't exactly one instance
    -    owned by the project, then this function will fail.
    -
    -    :type timeout: int
    -    :param timeout: (Optional) The socket timeout in milliseconds.
    -
    -    :rtype: :class:`gcloud.bigtable.instance.Instance`
    -    :returns: The unique instance owned by the project inferred from
    -              the environment.
    -    :raises ValueError: if there is a failed location or any number of
    -                        instances other than one.
    -    """
    -    client_kwargs = {'admin': True}
    -    if timeout is not None:
    -        client_kwargs['timeout_seconds'] = timeout / 1000.0
    -    client = Client(**client_kwargs)
    -    try:
    -        client.start()
    -        instances, failed_locations = client.list_instances()
    -    finally:
    -        client.stop()
    -
    -    if len(failed_locations) != 0:
    -        raise ValueError('Determining instance via ListInstances encountered '
    -                         'failed locations.')
    -    if len(instances) == 0:
    -        raise ValueError('This client doesn\'t have access to any instances.')
    -    if len(instances) > 1:
    -        raise ValueError('This client has access to more than one instance. '
    -                         'Please directly pass the instance you\'d '
    -                         'like to use.')
    -    return instances[0]
    -
    -
    -
    [docs]class Connection(object): - """Connection to Cloud Bigtable backend. - - .. note:: - - If you pass a ``instance``, it will be :meth:`.Instance.copy`-ed before - being stored on the new connection. This also copies the - :class:`Client <gcloud.bigtable.client.Client>` that created the - :class:`Instance <gcloud.bigtable.instance.Instance>` instance and the - :class:`Credentials <oauth2client.client.Credentials>` stored on the - client. - - The arguments ``host``, ``port``, ``compat``, ``transport`` and - ``protocol`` are allowed (as keyword arguments) for compatibility with - HappyBase. However, they will not be used in any way, and will cause a - warning if passed. - - :type timeout: int - :param timeout: (Optional) The socket timeout in milliseconds. - - :type autoconnect: bool - :param autoconnect: (Optional) Whether the connection should be - :meth:`open`-ed during construction. - - :type table_prefix: str - :param table_prefix: (Optional) Prefix used to construct table names. - - :type table_prefix_separator: str - :param table_prefix_separator: (Optional) Separator used with - ``table_prefix``. Defaults to ``_``. - - :type instance: :class:`Instance <gcloud.bigtable.instance.Instance>` - :param instance: (Optional) A Cloud Bigtable instance. The instance also - owns a client for making gRPC requests to the Cloud - Bigtable API. If not passed in, defaults to creating client - with ``admin=True`` and using the ``timeout`` here for the - ``timeout_seconds`` argument to the - :class:`Client <gcloud.bigtable.client.Client>` - constructor. The credentials for the client - will be the implicit ones loaded from the environment. - Then that client is used to retrieve all the instances - owned by the client's project. - - :type kwargs: dict - :param kwargs: Remaining keyword arguments. Provided for HappyBase - compatibility. - """ - - _instance = None - - def __init__(self, timeout=None, autoconnect=True, table_prefix=None, - table_prefix_separator='_', instance=None, **kwargs): - self._handle_legacy_args(kwargs) - if table_prefix is not None: - if not isinstance(table_prefix, six.string_types): - raise TypeError('table_prefix must be a string', 'received', - table_prefix, type(table_prefix)) - - if not isinstance(table_prefix_separator, six.string_types): - raise TypeError('table_prefix_separator must be a string', - 'received', table_prefix_separator, - type(table_prefix_separator)) - - self.table_prefix = table_prefix - self.table_prefix_separator = table_prefix_separator - - if instance is None: - self._instance = _get_instance(timeout=timeout) - else: - if timeout is not None: - raise ValueError('Timeout cannot be used when an existing ' - 'instance is passed') - self._instance = instance.copy() - - if autoconnect: - self.open() - - self._initialized = True - - @staticmethod - def _handle_legacy_args(arguments_dict): - """Check legacy HappyBase arguments and warn if set. - - :type arguments_dict: dict - :param arguments_dict: Unused keyword arguments. - - :raises TypeError: if a keyword other than ``host``, ``port``, - ``compat``, ``transport`` or ``protocol`` is used. - """ - common_args = _LEGACY_ARGS.intersection(six.iterkeys(arguments_dict)) - if common_args: - all_args = ', '.join(common_args) - message = ('The HappyBase legacy arguments %s were used. These ' - 'arguments are unused by gcloud.' % (all_args,)) - _WARN(message) - for arg_name in common_args: - arguments_dict.pop(arg_name) - if arguments_dict: - unexpected_names = arguments_dict.keys() - raise TypeError('Received unexpected arguments', unexpected_names) - -
    [docs] def open(self): - """Open the underlying transport to Cloud Bigtable. - - This method opens the underlying HTTP/2 gRPC connection using a - :class:`Client <gcloud.bigtable.client.Client>` bound to the - :class:`Instance <gcloud.bigtable.instance.Instance>` owned by - this connection. - """ - self._instance._client.start()
    - -
    [docs] def close(self): - """Close the underlying transport to Cloud Bigtable. - - This method closes the underlying HTTP/2 gRPC connection using a - :class:`Client <gcloud.bigtable.client.Client>` bound to the - :class:`Instance <gcloud.bigtable.instance.Instance>` owned by - this connection. - """ - self._instance._client.stop()
    - - def __del__(self): - if self._instance is not None: - self.close() - - def _table_name(self, name): - """Construct a table name by optionally adding a table name prefix. - - :type name: str - :param name: The name to have a prefix added to it. - - :rtype: str - :returns: The prefixed name, if the current connection has a table - prefix set. - """ - if self.table_prefix is None: - return name - - return self.table_prefix + self.table_prefix_separator + name - -
    [docs] def table(self, name, use_prefix=True): - """Table factory. - - :type name: str - :param name: The name of the table to be created. - - :type use_prefix: bool - :param use_prefix: Whether to use the table prefix (if any). - - :rtype: :class:`Table <gcloud.bigtable.happybase.table.Table>` - :returns: Table instance owned by this connection. - """ - if use_prefix: - name = self._table_name(name) - return Table(name, self)
    - -
    [docs] def tables(self): - """Return a list of table names available to this connection. - - .. note:: - - This lists every table in the instance owned by this connection, - **not** every table that a given user may have access to. - - .. note:: - - If ``table_prefix`` is set on this connection, only returns the - table names which match that prefix. - - :rtype: list - :returns: List of string table names. - """ - low_level_table_instances = self._instance.list_tables() - table_names = [table_instance.table_id - for table_instance in low_level_table_instances] - - # Filter using prefix, and strip prefix from names - if self.table_prefix is not None: - prefix = self._table_name('') - offset = len(prefix) - table_names = [name[offset:] for name in table_names - if name.startswith(prefix)] - - return table_names
    - -
    [docs] def create_table(self, name, families): - """Create a table. - - .. warning:: - - The only column family options from HappyBase that are able to be - used with Cloud Bigtable are ``max_versions`` and ``time_to_live``. - - Values in ``families`` represent column family options. In HappyBase, - these are dictionaries, corresponding to the ``ColumnDescriptor`` - structure in the Thrift API. The accepted keys are: - - * ``max_versions`` (``int``) - * ``compression`` (``str``) - * ``in_memory`` (``bool``) - * ``bloom_filter_type`` (``str``) - * ``bloom_filter_vector_size`` (``int``) - * ``bloom_filter_nb_hashes`` (``int``) - * ``block_cache_enabled`` (``bool``) - * ``time_to_live`` (``int``) - - :type name: str - :param name: The name of the table to be created. - - :type families: dict - :param families: Dictionary with column family names as keys and column - family options as the values. The options can be among - - * :class:`dict` - * :class:`.GarbageCollectionRule` - - :raises TypeError: If ``families`` is not a dictionary. - :raises ValueError: If ``families`` has no entries. - :raises AlreadyExists: If creation fails due to an already - existing table. - :raises NetworkError: If creation fails for a reason other than - table exists. - """ - if not isinstance(families, dict): - raise TypeError('families arg must be a dictionary') - - if not families: - raise ValueError('Cannot create table %r (no column ' - 'families specified)' % (name,)) - - # Parse all keys before making any API requests. - gc_rule_dict = {} - for column_family_name, option in families.items(): - if isinstance(column_family_name, six.binary_type): - column_family_name = column_family_name.decode('utf-8') - if column_family_name.endswith(':'): - column_family_name = column_family_name[:-1] - gc_rule_dict[column_family_name] = _parse_family_option(option) - - # Create table instance and then make API calls. - name = self._table_name(name) - low_level_table = _LowLevelTable(name, self._instance) - column_families = ( - low_level_table.column_family(column_family_name, gc_rule=gc_rule) - for column_family_name, gc_rule in six.iteritems(gc_rule_dict) - ) - try: - low_level_table.create(column_families=column_families) - except face.NetworkError as network_err: - if network_err.code == interfaces.StatusCode.ALREADY_EXISTS: - raise AlreadyExists(name) - else: - raise
    - -
    [docs] def delete_table(self, name, disable=False): - """Delete the specified table. - - :type name: str - :param name: The name of the table to be deleted. If ``table_prefix`` - is set, a prefix will be added to the ``name``. - - :type disable: bool - :param disable: Whether to first disable the table if needed. This - is provided for compatibility with HappyBase, but is - not relevant for Cloud Bigtable since it has no concept - of enabled / disabled tables. - """ - if disable: - _WARN(_DISABLE_DELETE_MSG) - - name = self._table_name(name) - _LowLevelTable(name, self._instance).delete()
    - - @staticmethod -
    [docs] def enable_table(name): - """Enable the specified table. - - .. warning:: - - Cloud Bigtable has no concept of enabled / disabled tables so this - method does nothing. It is provided simply for compatibility. - - :type name: str - :param name: The name of the table to be enabled. - """ - _WARN(_ENABLE_TMPL % (name,))
    - - @staticmethod -
    [docs] def disable_table(name): - """Disable the specified table. - - .. warning:: - - Cloud Bigtable has no concept of enabled / disabled tables so this - method does nothing. It is provided simply for compatibility. - - :type name: str - :param name: The name of the table to be disabled. - """ - _WARN(_DISABLE_TMPL % (name,))
    - - @staticmethod -
    [docs] def is_table_enabled(name): - """Return whether the specified table is enabled. - - .. warning:: - - Cloud Bigtable has no concept of enabled / disabled tables so this - method always returns :data:`True`. It is provided simply for - compatibility. - - :type name: str - :param name: The name of the table to check enabled / disabled status. - - :rtype: bool - :returns: The value :data:`True` always. - """ - _WARN(_IS_ENABLED_TMPL % (name,)) - return True
    - - @staticmethod -
    [docs] def compact_table(name, major=False): - """Compact the specified table. - - .. warning:: - - Cloud Bigtable supports table compactions, it just doesn't expose - an API for that feature, so this method does nothing. It is - provided simply for compatibility. - - :type name: str - :param name: The name of the table to compact. - - :type major: bool - :param major: Whether to perform a major compaction. - """ - _WARN(_COMPACT_TMPL % (name, major))
    - - -def _parse_family_option(option): - """Parses a column family option into a garbage collection rule. - - .. note:: - - If ``option`` is not a dictionary, the type is not checked. - If ``option`` is :data:`None`, there is nothing to do, since this - is the correct output. - - :type option: :class:`dict`, - :data:`NoneType <types.NoneType>`, - :class:`.GarbageCollectionRule` - :param option: A column family option passes as a dictionary value in - :meth:`Connection.create_table`. - - :rtype: :class:`.GarbageCollectionRule` - :returns: A garbage collection rule parsed from the input. - """ - result = option - if isinstance(result, dict): - if not set(result.keys()) <= set(['max_versions', 'time_to_live']): - all_keys = ', '.join(repr(key) for key in result.keys()) - warning_msg = ('Cloud Bigtable only supports max_versions and ' - 'time_to_live column family settings. ' - 'Received: %s' % (all_keys,)) - _WARN(warning_msg) - - max_num_versions = result.get('max_versions') - max_age = None - if 'time_to_live' in result: - max_age = datetime.timedelta(seconds=result['time_to_live']) - - versions_rule = age_rule = None - if max_num_versions is not None: - versions_rule = MaxVersionsGCRule(max_num_versions) - if max_age is not None: - age_rule = MaxAgeGCRule(max_age) - - if versions_rule is None: - result = age_rule - else: - if age_rule is None: - result = versions_rule - else: - result = GCRuleIntersection(rules=[age_rule, versions_rule]) - - return result -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/happybase/pool.html b/latest/_modules/gcloud/bigtable/happybase/pool.html deleted file mode 100644 index 4b2f85640b41..000000000000 --- a/latest/_modules/gcloud/bigtable/happybase/pool.html +++ /dev/null @@ -1,375 +0,0 @@ - - - - - - - - gcloud.bigtable.happybase.pool — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigtable.happybase.pool

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Google Cloud Bigtable HappyBase pool module."""
    -
    -
    -import contextlib
    -import threading
    -
    -import six
    -
    -from gcloud.bigtable.happybase.connection import Connection
    -from gcloud.bigtable.happybase.connection import _get_instance
    -
    -
    -_MIN_POOL_SIZE = 1
    -"""Minimum allowable size of a connection pool."""
    -
    -
    -
    [docs]class NoConnectionsAvailable(RuntimeError): - """Exception raised when no connections are available. - - This happens if a timeout was specified when obtaining a connection, - and no connection became available within the specified timeout. - """
    - - -
    [docs]class ConnectionPool(object): - """Thread-safe connection pool. - - .. note:: - - All keyword arguments are passed unmodified to the - :class:`Connection <.happybase.connection.Connection>` constructor - **except** for ``autoconnect``. This is because the ``open`` / - ``closed`` status of a connection is managed by the pool. In addition, - if ``instance`` is not passed, the default / inferred instance is - determined by the pool and then passed to each - :class:`Connection <.happybase.connection.Connection>` that is created. - - :type size: int - :param size: The maximum number of concurrently open connections. - - :type kwargs: dict - :param kwargs: Keyword arguments passed to - :class:`Connection <.happybase.Connection>` - constructor. - - :raises: :class:`TypeError <exceptions.TypeError>` if ``size`` - is non an integer. - :class:`ValueError <exceptions.ValueError>` if ``size`` - is not positive. - """ - def __init__(self, size, **kwargs): - if not isinstance(size, six.integer_types): - raise TypeError('Pool size arg must be an integer') - - if size < _MIN_POOL_SIZE: - raise ValueError('Pool size must be positive') - - self._lock = threading.Lock() - self._queue = six.moves.queue.LifoQueue(maxsize=size) - self._thread_connections = threading.local() - - connection_kwargs = kwargs - connection_kwargs['autoconnect'] = False - if 'instance' not in connection_kwargs: - connection_kwargs['instance'] = _get_instance( - timeout=kwargs.get('timeout')) - - for _ in six.moves.range(size): - connection = Connection(**connection_kwargs) - self._queue.put(connection) - - def _acquire_connection(self, timeout=None): - """Acquire a connection from the pool. - - :type timeout: int - :param timeout: (Optional) Time (in seconds) to wait for a connection - to open. - - :rtype: :class:`Connection <.happybase.Connection>` - :returns: An active connection from the queue stored on the pool. - :raises: :class:`NoConnectionsAvailable` if ``Queue.get`` fails - before the ``timeout`` (only if a timeout is specified). - """ - try: - return self._queue.get(block=True, timeout=timeout) - except six.moves.queue.Empty: - raise NoConnectionsAvailable('No connection available from pool ' - 'within specified timeout') - - @contextlib.contextmanager -
    [docs] def connection(self, timeout=None): - """Obtain a connection from the pool. - - Must be used as a context manager, for example:: - - with pool.connection() as connection: - pass # do something with the connection - - If ``timeout`` is omitted, this method waits forever for a connection - to become available from the local queue. - - Yields an active :class:`Connection <.happybase.connection.Connection>` - from the pool. - - :type timeout: int - :param timeout: (Optional) Time (in seconds) to wait for a connection - to open. - - :raises: :class:`NoConnectionsAvailable` if no connection can be - retrieved from the pool before the ``timeout`` (only if - a timeout is specified). - """ - connection = getattr(self._thread_connections, 'current', None) - - retrieved_new_cnxn = False - if connection is None: - # In this case we need to actually grab a connection from the - # pool. After retrieval, the connection is stored on a thread - # local so that nested connection requests from the same - # thread can re-use the same connection instance. - # - # NOTE: This code acquires a lock before assigning to the - # thread local; see - # ('https://emptysqua.re/blog/' - # 'another-thing-about-pythons-threadlocals/') - retrieved_new_cnxn = True - connection = self._acquire_connection(timeout) - with self._lock: - self._thread_connections.current = connection - - # This is a no-op for connections that have already been opened - # since they just call Client.start(). - connection.open() - yield connection - - # Remove thread local reference after the outermost 'with' block - # ends. Afterwards the thread no longer owns the connection. - if retrieved_new_cnxn: - del self._thread_connections.current - self._queue.put(connection)
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/happybase/table.html b/latest/_modules/gcloud/bigtable/happybase/table.html deleted file mode 100644 index 1a998603f540..000000000000 --- a/latest/_modules/gcloud/bigtable/happybase/table.html +++ /dev/null @@ -1,1199 +0,0 @@ - - - - - - - - gcloud.bigtable.happybase.table — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.bigtable.happybase.table

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Google Cloud Bigtable HappyBase table module."""
    -
    -
    -import struct
    -import warnings
    -
    -import six
    -
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud._helpers import _microseconds_from_datetime
    -from gcloud._helpers import _to_bytes
    -from gcloud._helpers import _total_seconds
    -from gcloud.bigtable.column_family import GCRuleIntersection
    -from gcloud.bigtable.column_family import MaxAgeGCRule
    -from gcloud.bigtable.column_family import MaxVersionsGCRule
    -from gcloud.bigtable.happybase.batch import _get_column_pairs
    -from gcloud.bigtable.happybase.batch import _WAL_SENTINEL
    -from gcloud.bigtable.happybase.batch import Batch
    -from gcloud.bigtable.row_filters import CellsColumnLimitFilter
    -from gcloud.bigtable.row_filters import ColumnQualifierRegexFilter
    -from gcloud.bigtable.row_filters import FamilyNameRegexFilter
    -from gcloud.bigtable.row_filters import RowFilterChain
    -from gcloud.bigtable.row_filters import RowFilterUnion
    -from gcloud.bigtable.row_filters import RowKeyRegexFilter
    -from gcloud.bigtable.row_filters import TimestampRange
    -from gcloud.bigtable.row_filters import TimestampRangeFilter
    -from gcloud.bigtable.table import Table as _LowLevelTable
    -
    -
    -_WARN = warnings.warn
    -_PACK_I64 = struct.Struct('>q').pack
    -_UNPACK_I64 = struct.Struct('>q').unpack
    -_SIMPLE_GC_RULES = (MaxAgeGCRule, MaxVersionsGCRule)
    -
    -
    -
    [docs]def make_row(cell_map, include_timestamp): - """Make a row dict for a Thrift cell mapping. - - .. warning:: - - This method is only provided for HappyBase compatibility, but does not - actually work. - - :type cell_map: dict - :param cell_map: Dictionary with ``fam:col`` strings as keys and ``TCell`` - instances as values. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :raises: :class:`NotImplementedError <exceptions.NotImplementedError>` - always - """ - raise NotImplementedError('The Cloud Bigtable API output is not the same ' - 'as the output from the Thrift server, so this ' - 'helper can not be implemented.', 'Called with', - cell_map, include_timestamp)
    - - -
    [docs]def make_ordered_row(sorted_columns, include_timestamp): - """Make a row dict for sorted Thrift column results from scans. - - .. warning:: - - This method is only provided for HappyBase compatibility, but does not - actually work. - - :type sorted_columns: list - :param sorted_columns: List of ``TColumn`` instances from Thrift. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :raises: :class:`NotImplementedError <exceptions.NotImplementedError>` - always - """ - raise NotImplementedError('The Cloud Bigtable API output is not the same ' - 'as the output from the Thrift server, so this ' - 'helper can not be implemented.', 'Called with', - sorted_columns, include_timestamp)
    - - -
    [docs]class Table(object): - """Representation of Cloud Bigtable table. - - Used for adding data and - - :type name: str - :param name: The name of the table. - - :type connection: :class:`Connection <.happybase.connection.Connection>` - :param connection: The connection which has access to the table. - """ - - def __init__(self, name, connection): - self.name = name - # This remains as legacy for HappyBase, but only the instance - # from the connection is needed. - self.connection = connection - self._low_level_table = None - if self.connection is not None: - self._low_level_table = _LowLevelTable(self.name, - self.connection._instance) - - def __repr__(self): - return '<table.Table name=%r>' % (self.name,) - -
    [docs] def families(self): - """Retrieve the column families for this table. - - :rtype: dict - :returns: Mapping from column family name to garbage collection rule - for a column family. - """ - column_family_map = self._low_level_table.list_column_families() - result = {} - for col_fam, col_fam_obj in six.iteritems(column_family_map): - result[col_fam] = _gc_rule_to_dict(col_fam_obj.gc_rule) - return result
    - -
    [docs] def regions(self): - """Retrieve the regions for this table. - - .. warning:: - - Cloud Bigtable does not give information about how a table is laid - out in memory, so this method does not work. It is - provided simply for compatibility. - - :raises: :class:`NotImplementedError <exceptions.NotImplementedError>` - always - """ - raise NotImplementedError('The Cloud Bigtable API does not have a ' - 'concept of splitting a table into regions.')
    - -
    [docs] def row(self, row, columns=None, timestamp=None, include_timestamp=False): - """Retrieve a single row of data. - - Returns the latest cells in each column (or all columns if ``columns`` - is not specified). If a ``timestamp`` is set, then **latest** becomes - **latest** up until ``timestamp``. - - :type row: str - :param row: Row key for the row we are reading from. - - :type columns: list - :param columns: (Optional) Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). If specified, only cells returned before the - the timestamp will be returned. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :rtype: dict - :returns: Dictionary containing all the latest column values in - the row. - """ - filters = [] - if columns is not None: - filters.append(_columns_filter_helper(columns)) - # versions == 1 since we only want the latest. - filter_ = _filter_chain_helper(versions=1, timestamp=timestamp, - filters=filters) - - partial_row_data = self._low_level_table.read_row( - row, filter_=filter_) - if partial_row_data is None: - return {} - - return _partial_row_to_dict(partial_row_data, - include_timestamp=include_timestamp)
    - -
    [docs] def rows(self, rows, columns=None, timestamp=None, - include_timestamp=False): - """Retrieve multiple rows of data. - - All optional arguments behave the same in this method as they do in - :meth:`row`. - - :type rows: list - :param rows: Iterable of the row keys for the rows we are reading from. - - :type columns: list - :param columns: (Optional) Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). If specified, only cells returned before (or - at) the timestamp will be returned. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :rtype: list - :returns: A list of pairs, where the first is the row key and the - second is a dictionary with the filtered values returned. - """ - if not rows: - # Avoid round-trip if the result is empty anyway - return [] - - filters = [] - if columns is not None: - filters.append(_columns_filter_helper(columns)) - filters.append(_row_keys_filter_helper(rows)) - # versions == 1 since we only want the latest. - filter_ = _filter_chain_helper(versions=1, timestamp=timestamp, - filters=filters) - - partial_rows_data = self._low_level_table.read_rows(filter_=filter_) - # NOTE: We could use max_loops = 1000 or some similar value to ensure - # that the stream isn't open too long. - partial_rows_data.consume_all() - - result = [] - for row_key in rows: - if row_key not in partial_rows_data.rows: - continue - curr_row_data = partial_rows_data.rows[row_key] - curr_row_dict = _partial_row_to_dict( - curr_row_data, include_timestamp=include_timestamp) - result.append((row_key, curr_row_dict)) - - return result
    - -
    [docs] def cells(self, row, column, versions=None, timestamp=None, - include_timestamp=False): - """Retrieve multiple versions of a single cell from the table. - - :type row: str - :param row: Row key for the row we are reading from. - - :type column: str - :param column: Column we are reading from; of the form ``fam:col``. - - :type versions: int - :param versions: (Optional) The maximum number of cells to return. If - not set, returns all cells found. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). If specified, only cells returned before (or - at) the timestamp will be returned. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :rtype: list - :returns: List of values in the cell (with timestamps if - ``include_timestamp`` is :data:`True`). - """ - filter_ = _filter_chain_helper(column=column, versions=versions, - timestamp=timestamp) - partial_row_data = self._low_level_table.read_row(row, filter_=filter_) - if partial_row_data is None: - return [] - else: - cells = partial_row_data._cells - # We know that `_filter_chain_helper` has already verified that - # column will split as such. - column_family_id, column_qualifier = column.split(':') - # NOTE: We expect the only key in `cells` is `column_family_id` - # and the only key `cells[column_family_id]` is - # `column_qualifier`. But we don't check that this is true. - curr_cells = cells[column_family_id][column_qualifier] - return _cells_to_pairs( - curr_cells, include_timestamp=include_timestamp)
    - -
    [docs] def scan(self, row_start=None, row_stop=None, row_prefix=None, - columns=None, timestamp=None, - include_timestamp=False, limit=None, **kwargs): - """Create a scanner for data in this table. - - This method returns a generator that can be used for looping over the - matching rows. - - If ``row_prefix`` is specified, only rows with row keys matching the - prefix will be returned. If given, ``row_start`` and ``row_stop`` - cannot be used. - - .. note:: - - Both ``row_start`` and ``row_stop`` can be :data:`None` to specify - the start and the end of the table respectively. If both are - omitted, a full table scan is done. Note that this usually results - in severe performance problems. - - The keyword argument ``filter`` is also supported (beyond column and - row range filters supported here). HappyBase / HBase users will have - used this as an HBase filter string. (See the `Thrift docs`_ for more - details on those filters.) However, Google Cloud Bigtable doesn't - support those filter strings so a - :class:`~gcloud.bigtable.row.RowFilter` should be used instead. - - .. _Thrift docs: http://hbase.apache.org/0.94/book/thrift.html - - The arguments ``batch_size``, ``scan_batching`` and ``sorted_columns`` - are allowed (as keyword arguments) for compatibility with - HappyBase. However, they will not be used in any way, and will cause a - warning if passed. (The ``batch_size`` determines the number of - results to retrieve per request. The HBase scanner defaults to reading - one record at a time, so this argument allows HappyBase to increase - that number. However, the Cloud Bigtable API uses HTTP/2 streaming so - there is no concept of a batched scan. The ``sorted_columns`` flag - tells HBase to return columns in order, but Cloud Bigtable doesn't - have this feature.) - - :type row_start: str - :param row_start: (Optional) Row key where the scanner should start - (includes ``row_start``). If not specified, reads - from the first key. If the table does not contain - ``row_start``, it will start from the next key after - it that **is** contained in the table. - - :type row_stop: str - :param row_stop: (Optional) Row key where the scanner should stop - (excludes ``row_stop``). If not specified, reads - until the last key. The table does not have to contain - ``row_stop``. - - :type row_prefix: str - :param row_prefix: (Optional) Prefix to match row keys. - - :type columns: list - :param columns: (Optional) Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). If specified, only cells returned before (or - at) the timestamp will be returned. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :type limit: int - :param limit: (Optional) Maximum number of rows to return. - - :type kwargs: dict - :param kwargs: Remaining keyword arguments. Provided for HappyBase - compatibility. - - :raises: If ``limit`` is set but non-positive, or if ``row_prefix`` is - used with row start/stop, - :class:`TypeError <exceptions.TypeError>` if a string - ``filter`` is used. - """ - row_start, row_stop, filter_chain = _scan_filter_helper( - row_start, row_stop, row_prefix, columns, timestamp, limit, kwargs) - - partial_rows_data = self._low_level_table.read_rows( - start_key=row_start, end_key=row_stop, - limit=limit, filter_=filter_chain) - - # Mutable copy of data. - rows_dict = partial_rows_data.rows - while True: - try: - partial_rows_data.consume_next() - for row_key in sorted(rows_dict): - curr_row_data = rows_dict.pop(row_key) - # NOTE: We expect len(rows_dict) == 0, but don't check it. - curr_row_dict = _partial_row_to_dict( - curr_row_data, include_timestamp=include_timestamp) - yield (row_key, curr_row_dict) - except StopIteration: - break
    - -
    [docs] def put(self, row, data, timestamp=None, wal=_WAL_SENTINEL): - """Insert data into a row in this table. - - .. note:: - - This method will send a request with a single "put" mutation. - In many situations, :meth:`batch` is a more appropriate - method to manipulate data since it helps combine many mutations - into a single request. - - :type row: str - :param row: The row key where the mutation will be "put". - - :type data: dict - :param data: Dictionary containing the data to be inserted. The keys - are columns names (of the form ``fam:col``) and the values - are strings (bytes) to be stored in those columns. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch) that the mutation will be applied at. - - :type wal: object - :param wal: Unused parameter (to be passed to a created batch). - Provided for compatibility with HappyBase, but irrelevant - for Cloud Bigtable since it does not have a Write Ahead - Log. - """ - with self.batch(timestamp=timestamp, wal=wal) as batch: - batch.put(row, data)
    - -
    [docs] def delete(self, row, columns=None, timestamp=None, wal=_WAL_SENTINEL): - """Delete data from a row in this table. - - This method deletes the entire ``row`` if ``columns`` is not - specified. - - .. note:: - - This method will send a request with a single delete mutation. - In many situations, :meth:`batch` is a more appropriate - method to manipulate data since it helps combine many mutations - into a single request. - - :type row: str - :param row: The row key where the delete will occur. - - :type columns: list - :param columns: (Optional) Iterable containing column names (as - strings). Each column name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch) that the mutation will be applied at. - - :type wal: object - :param wal: Unused parameter (to be passed to a created batch). - Provided for compatibility with HappyBase, but irrelevant - for Cloud Bigtable since it does not have a Write Ahead - Log. - """ - with self.batch(timestamp=timestamp, wal=wal) as batch: - batch.delete(row, columns)
    - -
    [docs] def batch(self, timestamp=None, batch_size=None, transaction=False, - wal=_WAL_SENTINEL): - """Create a new batch operation for this table. - - This method returns a new - :class:`Batch <.happybase.batch.Batch>` instance that can be - used for mass data manipulation. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch) that all mutations will be applied at. - - :type batch_size: int - :param batch_size: (Optional) The maximum number of mutations to allow - to accumulate before committing them. - - :type transaction: bool - :param transaction: Flag indicating if the mutations should be sent - transactionally or not. If ``transaction=True`` and - an error occurs while a - :class:`Batch <.happybase.batch.Batch>` is - active, then none of the accumulated mutations will - be committed. If ``batch_size`` is set, the - mutation can't be transactional. - - :type wal: object - :param wal: Unused parameter (to be passed to the created batch). - Provided for compatibility with HappyBase, but irrelevant - for Cloud Bigtable since it does not have a Write Ahead - Log. - - :rtype: :class:`Batch <gcloud.bigtable.happybase.batch.Batch>` - :returns: A batch bound to this table. - """ - return Batch(self, timestamp=timestamp, batch_size=batch_size, - transaction=transaction, wal=wal)
    - -
    [docs] def counter_get(self, row, column): - """Retrieve the current value of a counter column. - - This method retrieves the current value of a counter column. If the - counter column does not exist, this function initializes it to ``0``. - - .. note:: - - Application code should **never** store a counter value directly; - use the atomic :meth:`counter_inc` and :meth:`counter_dec` methods - for that. - - :type row: str - :param row: Row key for the row we are getting a counter from. - - :type column: str - :param column: Column we are ``get``-ing from; of the form ``fam:col``. - - :rtype: int - :returns: Counter value (after initializing / incrementing by 0). - """ - # Don't query directly, but increment with value=0 so that the counter - # is correctly initialized if didn't exist yet. - return self.counter_inc(row, column, value=0)
    - -
    [docs] def counter_set(self, row, column, value=0): - """Set a counter column to a specific value. - - .. note:: - - Be careful using this method. It can be useful for setting the - initial value of a counter, but it defeats the purpose of using - atomic increment and decrement. - - :type row: str - :param row: Row key for the row we are setting a counter in. - - :type column: str - :param column: Column we are setting a value in; of - the form ``fam:col``. - - :type value: int - :param value: Value to set the counter to. - """ - self.put(row, {column: _PACK_I64(value)})
    - -
    [docs] def counter_inc(self, row, column, value=1): - """Atomically increment a counter column. - - This method atomically increments a counter column in ``row``. - If the counter column does not exist, it is automatically initialized - to ``0`` before being incremented. - - :type row: str - :param row: Row key for the row we are incrementing a counter in. - - :type column: str - :param column: Column we are incrementing a value in; of the - form ``fam:col``. - - :type value: int - :param value: Amount to increment the counter by. (If negative, - this is equivalent to decrement.) - - :rtype: int - :returns: Counter value after incrementing. - """ - row = self._low_level_table.row(row, append=True) - if isinstance(column, six.binary_type): - column = column.decode('utf-8') - column_family_id, column_qualifier = column.split(':') - row.increment_cell_value(column_family_id, column_qualifier, value) - # See AppendRow.commit() will return a dictionary: - # { - # u'col-fam-id': { - # b'col-name1': [ - # (b'cell-val', datetime.datetime(...)), - # ... - # ], - # ... - # }, - # } - modified_cells = row.commit() - # Get the cells in the modified column, - column_cells = modified_cells[column_family_id][column_qualifier] - # Make sure there is exactly one cell in the column. - if len(column_cells) != 1: - raise ValueError('Expected server to return one modified cell.') - column_cell = column_cells[0] - # Get the bytes value from the column and convert it to an integer. - bytes_value = column_cell[0] - int_value, = _UNPACK_I64(bytes_value) - return int_value
    - -
    [docs] def counter_dec(self, row, column, value=1): - """Atomically decrement a counter column. - - This method atomically decrements a counter column in ``row``. - If the counter column does not exist, it is automatically initialized - to ``0`` before being decremented. - - :type row: str - :param row: Row key for the row we are decrementing a counter in. - - :type column: str - :param column: Column we are decrementing a value in; of the - form ``fam:col``. - - :type value: int - :param value: Amount to decrement the counter by. (If negative, - this is equivalent to increment.) - - :rtype: int - :returns: Counter value after decrementing. - """ - return self.counter_inc(row, column, -value)
    - - -def _gc_rule_to_dict(gc_rule): - """Converts garbage collection rule to dictionary if possible. - - This is in place to support dictionary values as was done - in HappyBase, which has somewhat different garbage collection rule - settings for column families. - - Only does this if the garbage collection rule is: - - * :class:`gcloud.bigtable.column_family.MaxAgeGCRule` - * :class:`gcloud.bigtable.column_family.MaxVersionsGCRule` - * Composite :class:`gcloud.bigtable.column_family.GCRuleIntersection` - with two rules, one each of type - :class:`gcloud.bigtable.column_family.MaxAgeGCRule` and - :class:`gcloud.bigtable.column_family.MaxVersionsGCRule` - - Otherwise, just returns the input without change. - - :type gc_rule: :data:`NoneType <types.NoneType>`, - :class:`.GarbageCollectionRule` - :param gc_rule: A garbage collection rule to convert to a dictionary - (if possible). - - :rtype: dict or - :class:`gcloud.bigtable.column_family.GarbageCollectionRule` - :returns: The converted garbage collection rule. - """ - result = gc_rule - if gc_rule is None: - result = {} - elif isinstance(gc_rule, MaxAgeGCRule): - result = {'time_to_live': _total_seconds(gc_rule.max_age)} - elif isinstance(gc_rule, MaxVersionsGCRule): - result = {'max_versions': gc_rule.max_num_versions} - elif isinstance(gc_rule, GCRuleIntersection): - if len(gc_rule.rules) == 2: - rule1, rule2 = gc_rule.rules - if (isinstance(rule1, _SIMPLE_GC_RULES) and - isinstance(rule2, _SIMPLE_GC_RULES)): - rule1 = _gc_rule_to_dict(rule1) - rule2 = _gc_rule_to_dict(rule2) - key1, = rule1.keys() - key2, = rule2.keys() - if key1 != key2: - result = {key1: rule1[key1], key2: rule2[key2]} - return result - - -def _next_char(str_val, index): - """Gets the next character based on a position in a string. - - :type str_val: str - :param str_val: A string containing the character to update. - - :type index: int - :param index: An integer index in ``str_val``. - - :rtype: str - :returns: The next character after the character at ``index`` - in ``str_val``. - """ - ord_val = six.indexbytes(str_val, index) - return _to_bytes(chr(ord_val + 1), encoding='latin-1') - - -def _string_successor(str_val): - """Increment and truncate a byte string. - - Determines shortest string that sorts after the given string when - compared using regular string comparison semantics. - - Modeled after implementation in ``gcloud-golang``. - - Increments the last byte that is smaller than ``0xFF``, and - drops everything after it. If the string only contains ``0xFF`` bytes, - ``''`` is returned. - - :type str_val: str - :param str_val: String to increment. - - :rtype: str - :returns: The next string in lexical order after ``str_val``. - """ - str_val = _to_bytes(str_val, encoding='latin-1') - if str_val == b'': - return str_val - - index = len(str_val) - 1 - while index >= 0: - if six.indexbytes(str_val, index) != 0xff: - break - index -= 1 - - if index == -1: - return b'' - - return str_val[:index] + _next_char(str_val, index) - - -def _convert_to_time_range(timestamp=None): - """Create a timestamp range from an HBase / HappyBase timestamp. - - HBase uses timestamp as an argument to specify an exclusive end - deadline. Cloud Bigtable also uses exclusive end times, so - the behavior matches. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). Intended to be used as the end of an HBase - time range, which is exclusive. - - :rtype: :class:`gcloud.bigtable.row.TimestampRange`, - :data:`NoneType <types.NoneType>` - :returns: The timestamp range corresponding to the passed in - ``timestamp``. - """ - if timestamp is None: - return None - - next_timestamp = _datetime_from_microseconds(1000 * timestamp) - return TimestampRange(end=next_timestamp) - - -def _cells_to_pairs(cells, include_timestamp=False): - """Converts list of cells to HappyBase format. - - For example:: - - >>> import datetime - >>> from gcloud.bigtable.row_data import Cell - >>> cell1 = Cell(b'val1', datetime.datetime.utcnow()) - >>> cell2 = Cell(b'val2', datetime.datetime.utcnow()) - >>> _cells_to_pairs([cell1, cell2]) - [b'val1', b'val2'] - >>> _cells_to_pairs([cell1, cell2], include_timestamp=True) - [(b'val1', 1456361486255), (b'val2', 1456361491927)] - - :type cells: list - :param cells: List of :class:`gcloud.bigtable.row_data.Cell` returned - from a read request. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :rtype: list - :returns: List of values in the cell. If ``include_timestamp=True``, each - value will be a pair, with the first part the bytes value in - the cell and the second part the number of milliseconds in the - timestamp on the cell. - """ - result = [] - for cell in cells: - if include_timestamp: - ts_millis = _microseconds_from_datetime(cell.timestamp) // 1000 - result.append((cell.value, ts_millis)) - else: - result.append(cell.value) - return result - - -def _partial_row_to_dict(partial_row_data, include_timestamp=False): - """Convert a low-level row data object to a dictionary. - - Assumes only the latest value in each row is needed. This assumption - is due to the fact that this method is used by callers which use - a ``CellsColumnLimitFilter(1)`` filter. - - For example:: - - >>> import datetime - >>> from gcloud.bigtable.row_data import Cell, PartialRowData - >>> cell1 = Cell(b'val1', datetime.datetime.utcnow()) - >>> cell2 = Cell(b'val2', datetime.datetime.utcnow()) - >>> row_data = PartialRowData(b'row-key') - >>> _partial_row_to_dict(row_data) - {} - >>> row_data._cells[u'fam1'] = {b'col1': [cell1], b'col2': [cell2]} - >>> _partial_row_to_dict(row_data) - {b'fam1:col2': b'val2', b'fam1:col1': b'val1'} - >>> _partial_row_to_dict(row_data, include_timestamp=True) - {b'fam1:col2': (b'val2', 1456361724480), - b'fam1:col1': (b'val1', 1456361721135)} - - :type partial_row_data: :class:`.row_data.PartialRowData` - :param partial_row_data: Row data consumed from a stream. - - :type include_timestamp: bool - :param include_timestamp: Flag to indicate if cell timestamps should be - included with the output. - - :rtype: dict - :returns: The row data converted to a dictionary. - """ - result = {} - for column, cells in six.iteritems(partial_row_data.to_dict()): - cell_vals = _cells_to_pairs(cells, - include_timestamp=include_timestamp) - # NOTE: We assume there is exactly 1 version since we used that in - # our filter, but we don't check this. - result[column] = cell_vals[0] - return result - - -def _filter_chain_helper(column=None, versions=None, timestamp=None, - filters=None): - """Create filter chain to limit a results set. - - :type column: str - :param column: (Optional) The column (``fam:col``) to be selected - with the filter. - - :type versions: int - :param versions: (Optional) The maximum number of cells to return. - - :type timestamp: int - :param timestamp: (Optional) Timestamp (in milliseconds since the - epoch). If specified, only cells returned before (or - at) the timestamp will be matched. - - :type filters: list - :param filters: (Optional) List of existing filters to be extended. - - :rtype: :class:`RowFilter <gcloud.bigtable.row.RowFilter>` - :returns: The chained filter created, or just a single filter if only - one was needed. - :raises: :class:`ValueError <exceptions.ValueError>` if there are no - filters to chain. - """ - if filters is None: - filters = [] - - if column is not None: - if isinstance(column, six.binary_type): - column = column.decode('utf-8') - column_family_id, column_qualifier = column.split(':') - fam_filter = FamilyNameRegexFilter(column_family_id) - qual_filter = ColumnQualifierRegexFilter(column_qualifier) - filters.extend([fam_filter, qual_filter]) - if versions is not None: - filters.append(CellsColumnLimitFilter(versions)) - time_range = _convert_to_time_range(timestamp=timestamp) - if time_range is not None: - filters.append(TimestampRangeFilter(time_range)) - - num_filters = len(filters) - if num_filters == 0: - raise ValueError('Must have at least one filter.') - elif num_filters == 1: - return filters[0] - else: - return RowFilterChain(filters=filters) - - -def _scan_filter_helper(row_start, row_stop, row_prefix, columns, - timestamp, limit, kwargs): - """Helper for :meth:`scan`: build up a filter chain.""" - filter_ = kwargs.pop('filter', None) - legacy_args = [] - for kw_name in ('batch_size', 'scan_batching', 'sorted_columns'): - if kw_name in kwargs: - legacy_args.append(kw_name) - kwargs.pop(kw_name) - if legacy_args: - legacy_args = ', '.join(legacy_args) - message = ('The HappyBase legacy arguments %s were used. These ' - 'arguments are unused by gcloud.' % (legacy_args,)) - _WARN(message) - if kwargs: - raise TypeError('Received unexpected arguments', kwargs.keys()) - - if limit is not None and limit < 1: - raise ValueError('limit must be positive') - if row_prefix is not None: - if row_start is not None or row_stop is not None: - raise ValueError('row_prefix cannot be combined with ' - 'row_start or row_stop') - row_start = row_prefix - row_stop = _string_successor(row_prefix) - - filters = [] - if isinstance(filter_, six.string_types): - raise TypeError('Specifying filters as a string is not supported ' - 'by Cloud Bigtable. Use a ' - 'gcloud.bigtable.row.RowFilter instead.') - elif filter_ is not None: - filters.append(filter_) - - if columns is not None: - filters.append(_columns_filter_helper(columns)) - - # versions == 1 since we only want the latest. - filter_ = _filter_chain_helper(versions=1, timestamp=timestamp, - filters=filters) - return row_start, row_stop, filter_ - - -def _columns_filter_helper(columns): - """Creates a union filter for a list of columns. - - :type columns: list - :param columns: Iterable containing column names (as strings). Each column - name can be either - - * an entire column family: ``fam`` or ``fam:`` - * a single column: ``fam:col`` - - :rtype: :class:`RowFilter <gcloud.bigtable.row.RowFilter>` - :returns: The union filter created containing all of the matched columns. - :raises: :class:`ValueError <exceptions.ValueError>` if there are no - filters to union. - """ - filters = [] - for column_family_id, column_qualifier in _get_column_pairs(columns): - fam_filter = FamilyNameRegexFilter(column_family_id) - if column_qualifier is not None: - qual_filter = ColumnQualifierRegexFilter(column_qualifier) - combined_filter = RowFilterChain( - filters=[fam_filter, qual_filter]) - filters.append(combined_filter) - else: - filters.append(fam_filter) - - num_filters = len(filters) - if num_filters == 0: - raise ValueError('Must have at least one filter.') - elif num_filters == 1: - return filters[0] - else: - return RowFilterUnion(filters=filters) - - -def _row_keys_filter_helper(row_keys): - """Creates a union filter for a list of rows. - - :type row_keys: list - :param row_keys: Iterable containing row keys (as strings). - - :rtype: :class:`RowFilter <gcloud.bigtable.row.RowFilter>` - :returns: The union filter created containing all of the row keys. - :raises: :class:`ValueError <exceptions.ValueError>` if there are no - filters to union. - """ - filters = [] - for row_key in row_keys: - filters.append(RowKeyRegexFilter(row_key)) - - num_filters = len(filters) - if num_filters == 0: - raise ValueError('Must have at least one filter.') - elif num_filters == 1: - return filters[0] - else: - return RowFilterUnion(filters=filters) -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/connection.html b/latest/_modules/gcloud/datastore/connection.html deleted file mode 100644 index 9ee9d884141d..000000000000 --- a/latest/_modules/gcloud/datastore/connection.html +++ /dev/null @@ -1,653 +0,0 @@ - - - - - - - - gcloud.datastore.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.datastore.connection

    -# Copyright 2014 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Connections to gcloud datastore API servers."""
    -
    -import os
    -
    -from gcloud import connection
    -from gcloud.environment_vars import GCD_HOST
    -from gcloud.exceptions import make_exception
    -from gcloud.datastore._generated import datastore_pb2 as _datastore_pb2
    -from google.rpc import status_pb2
    -
    -
    -
    [docs]class Connection(connection.Connection): - """A connection to the Google Cloud Datastore via the Protobuf API. - - This class should understand only the basic types (and protobufs) - in method arguments, however should be capable of returning advanced types. - - :type credentials: :class:`oauth2client.client.OAuth2Credentials` - :param credentials: The OAuth2 Credentials to use for this connection. - - :type http: :class:`httplib2.Http` or class that defines ``request()``. - :param http: An optional HTTP object to make requests. - - :type api_base_url: string - :param api_base_url: The base of the API call URL. Defaults to - :attr:`API_BASE_URL`. - """ - - API_BASE_URL = 'https://datastore.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v1beta3' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = ('{api_base}/{api_version}/projects' - '/{project}:{method}') - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/datastore',) - """The scopes required for authenticating as a Cloud Datastore consumer.""" - - def __init__(self, credentials=None, http=None, api_base_url=None): - super(Connection, self).__init__(credentials=credentials, http=http) - if api_base_url is None: - try: - # gcd.sh has /datastore/ in the path still since it supports - # v1beta2 and v1beta3 simultaneously. - api_base_url = '%s/datastore' % (os.environ[GCD_HOST],) - except KeyError: - api_base_url = self.__class__.API_BASE_URL - self.api_base_url = api_base_url - - def _request(self, project, method, data): - """Make a request over the Http transport to the Cloud Datastore API. - - :type project: string - :param project: The project to make the request for. - - :type method: string - :param method: The API call method name (ie, ``runQuery``, - ``lookup``, etc) - - :type data: string - :param data: The data to send with the API call. - Typically this is a serialized Protobuf string. - - :rtype: string - :returns: The string response content from the API call. - :raises: :class:`gcloud.exceptions.GCloudError` if the response - code is not 200 OK. - """ - headers = { - 'Content-Type': 'application/x-protobuf', - 'Content-Length': str(len(data)), - 'User-Agent': self.USER_AGENT, - } - headers, content = self.http.request( - uri=self.build_api_url(project=project, method=method), - method='POST', headers=headers, body=data) - - status = headers['status'] - if status != '200': - error_status = status_pb2.Status.FromString(content) - raise make_exception(headers, error_status.message, use_json=False) - - return content - - def _rpc(self, project, method, request_pb, response_pb_cls): - """Make a protobuf RPC request. - - :type project: string - :param project: The project to connect to. This is - usually your project name in the cloud console. - - :type method: string - :param method: The name of the method to invoke. - - :type request_pb: :class:`google.protobuf.message.Message` instance - :param request_pb: the protobuf instance representing the request. - - :type response_pb_cls: A :class:`google.protobuf.message.Message` - subclass. - :param response_pb_cls: The class used to unmarshall the response - protobuf. - - :rtype: :class:`google.protobuf.message.Message` - :returns: The RPC message parsed from the response. - """ - response = self._request(project=project, method=method, - data=request_pb.SerializeToString()) - return response_pb_cls.FromString(response) - -
    [docs] def build_api_url(self, project, method, base_url=None, - api_version=None): - """Construct the URL for a particular API call. - - This method is used internally to come up with the URL to use when - making RPCs to the Cloud Datastore API. - - :type project: string - :param project: The project to connect to. This is - usually your project name in the cloud console. - - :type method: string - :param method: The API method to call (e.g. 'runQuery', 'lookup'). - - :type base_url: string - :param base_url: The base URL where the API lives. - You shouldn't have to provide this. - - :type api_version: string - :param api_version: The version of the API to connect to. - You shouldn't have to provide this. - - :rtype: str - :returns: The API URL created. - """ - return self.API_URL_TEMPLATE.format( - api_base=(base_url or self.api_base_url), - api_version=(api_version or self.API_VERSION), - project=project, method=method)
    - -
    [docs] def lookup(self, project, key_pbs, - eventual=False, transaction_id=None): - """Lookup keys from a project in the Cloud Datastore. - - Maps the ``DatastoreService.Lookup`` protobuf RPC. - - This uses mostly protobufs - (:class:`gcloud.datastore._generated.entity_pb2.Key` as input and - :class:`gcloud.datastore._generated.entity_pb2.Entity` as output). It - is used under the hood in - :meth:`Client.get() <.datastore.client.Client.get>`: - - >>> from gcloud import datastore - >>> client = datastore.Client(project='project') - >>> key = client.key('MyKind', 1234) - >>> client.get(key) - [<Entity object>] - - Using a :class:`Connection` directly: - - >>> connection.lookup('project', [key.to_protobuf()]) - [<Entity protobuf>] - - :type project: string - :param project: The project to look up the keys in. - - :type key_pbs: list of - :class:`gcloud.datastore._generated.entity_pb2.Key` - :param key_pbs: The keys to retrieve from the datastore. - - :type eventual: bool - :param eventual: If False (the default), request ``STRONG`` read - consistency. If True, request ``EVENTUAL`` read - consistency. - - :type transaction_id: string - :param transaction_id: If passed, make the request in the scope of - the given transaction. Incompatible with - ``eventual==True``. - - :rtype: tuple - :returns: A triple of (``results``, ``missing``, ``deferred``) where - both ``results`` and ``missing`` are lists of - :class:`gcloud.datastore._generated.entity_pb2.Entity` and - ``deferred`` is a list of - :class:`gcloud.datastore._generated.entity_pb2.Key`. - """ - lookup_request = _datastore_pb2.LookupRequest() - _set_read_options(lookup_request, eventual, transaction_id) - _add_keys_to_request(lookup_request.keys, key_pbs) - - lookup_response = self._rpc(project, 'lookup', lookup_request, - _datastore_pb2.LookupResponse) - - results = [result.entity for result in lookup_response.found] - missing = [result.entity for result in lookup_response.missing] - - return results, missing, list(lookup_response.deferred)
    - -
    [docs] def run_query(self, project, query_pb, namespace=None, - eventual=False, transaction_id=None): - """Run a query on the Cloud Datastore. - - Maps the ``DatastoreService.RunQuery`` protobuf RPC. - - Given a Query protobuf, sends a ``runQuery`` request to the - Cloud Datastore API and returns a list of entity protobufs - matching the query. - - You typically wouldn't use this method directly, in favor of the - :meth:`gcloud.datastore.query.Query.fetch` method. - - Under the hood, the :class:`gcloud.datastore.query.Query` class - uses this method to fetch data: - - >>> from gcloud import datastore - >>> client = datastore.Client() - >>> query = client.query(kind='MyKind') - >>> query.add_filter('property', '=', 'val') - - Using the query iterator's - :meth:`next_page() <.datastore.query.Iterator.next_page>` method: - - >>> query_iter = query.fetch() - >>> entities, more_results, cursor = query_iter.next_page() - >>> entities - [<list of Entity unmarshalled from protobuf>] - >>> more_results - <boolean of more results> - >>> cursor - <string containing cursor where fetch stopped> - - Under the hood this is doing: - - >>> connection.run_query('project', query.to_protobuf()) - [<list of Entity Protobufs>], cursor, more_results, skipped_results - - :type project: string - :param project: The project over which to run the query. - - :type query_pb: :class:`gcloud.datastore._generated.query_pb2.Query` - :param query_pb: The Protobuf representing the query to run. - - :type namespace: string - :param namespace: The namespace over which to run the query. - - :type eventual: bool - :param eventual: If False (the default), request ``STRONG`` read - consistency. If True, request ``EVENTUAL`` read - consistency. - - :type transaction_id: string - :param transaction_id: If passed, make the request in the scope of - the given transaction. Incompatible with - ``eventual==True``. - - :rtype: tuple - :returns: Four-tuple containing the entities returned, - the end cursor of the query, a ``more_results`` - enum and a count of the number of skipped results. - """ - request = _datastore_pb2.RunQueryRequest() - _set_read_options(request, eventual, transaction_id) - - if namespace: - request.partition_id.namespace_id = namespace - - request.query.CopyFrom(query_pb) - response = self._rpc(project, 'runQuery', request, - _datastore_pb2.RunQueryResponse) - return ( - [e.entity for e in response.batch.entity_results], - response.batch.end_cursor, # Assume response always has cursor. - response.batch.more_results, - response.batch.skipped_results, - )
    - -
    [docs] def begin_transaction(self, project): - """Begin a transaction. - - Maps the ``DatastoreService.BeginTransaction`` protobuf RPC. - - :type project: string - :param project: The project to which the transaction applies. - - :rtype: bytes - :returns: The serialized transaction that was begun. - """ - request = _datastore_pb2.BeginTransactionRequest() - response = self._rpc(project, 'beginTransaction', request, - _datastore_pb2.BeginTransactionResponse) - return response.transaction
    - -
    [docs] def commit(self, project, request, transaction_id): - """Commit mutations in context of current transation (if any). - - Maps the ``DatastoreService.Commit`` protobuf RPC. - - :type project: string - :param project: The project to which the transaction applies. - - :type request: :class:`._generated.datastore_pb2.CommitRequest` - :param request: The protobuf with the mutations being committed. - - :type transaction_id: string or None - :param transaction_id: The transaction ID returned from - :meth:`begin_transaction`. Non-transactional - batches must pass ``None``. - - .. note:: - - This method will mutate ``request`` before using it. - - :rtype: tuple - :returns: The pair of the number of index updates and a list of - :class:`._generated.entity_pb2.Key` for each incomplete key - that was completed in the commit. - """ - if transaction_id: - request.mode = _datastore_pb2.CommitRequest.TRANSACTIONAL - request.transaction = transaction_id - else: - request.mode = _datastore_pb2.CommitRequest.NON_TRANSACTIONAL - - response = self._rpc(project, 'commit', request, - _datastore_pb2.CommitResponse) - return _parse_commit_response(response)
    - -
    [docs] def rollback(self, project, transaction_id): - """Rollback the connection's existing transaction. - - Maps the ``DatastoreService.Rollback`` protobuf RPC. - - :type project: string - :param project: The project to which the transaction belongs. - - :type transaction_id: string - :param transaction_id: The transaction ID returned from - :meth:`begin_transaction`. - """ - request = _datastore_pb2.RollbackRequest() - request.transaction = transaction_id - # Nothing to do with this response, so just execute the method. - self._rpc(project, 'rollback', request, - _datastore_pb2.RollbackResponse)
    - -
    [docs] def allocate_ids(self, project, key_pbs): - """Obtain backend-generated IDs for a set of keys. - - Maps the ``DatastoreService.AllocateIds`` protobuf RPC. - - :type project: string - :param project: The project to which the transaction belongs. - - :type key_pbs: list of - :class:`gcloud.datastore._generated.entity_pb2.Key` - :param key_pbs: The keys for which the backend should allocate IDs. - - :rtype: list of :class:`gcloud.datastore._generated.entity_pb2.Key` - :returns: An equal number of keys, with IDs filled in by the backend. - """ - request = _datastore_pb2.AllocateIdsRequest() - _add_keys_to_request(request.keys, key_pbs) - # Nothing to do with this response, so just execute the method. - response = self._rpc(project, 'allocateIds', request, - _datastore_pb2.AllocateIdsResponse) - return list(response.keys)
    - - -def _set_read_options(request, eventual, transaction_id): - """Validate rules for read options, and assign to the request. - - Helper method for ``lookup()`` and ``run_query``. - - :raises: :class:`ValueError` if ``eventual`` is ``True`` and the - ``transaction_id`` is not ``None``. - """ - if eventual and (transaction_id is not None): - raise ValueError('eventual must be False when in a transaction') - - opts = request.read_options - if eventual: - opts.read_consistency = _datastore_pb2.ReadOptions.EVENTUAL - elif transaction_id: - opts.transaction = transaction_id - - -def _add_keys_to_request(request_field_pb, key_pbs): - """Add protobuf keys to a request object. - - :type request_field_pb: `RepeatedCompositeFieldContainer` - :param request_field_pb: A repeated proto field that contains keys. - - :type key_pbs: list of :class:`gcloud.datastore._generated.entity_pb2.Key` - :param key_pbs: The keys to add to a request. - """ - for key_pb in key_pbs: - request_field_pb.add().CopyFrom(key_pb) - - -def _parse_commit_response(commit_response_pb): - """Extract response data from a commit response. - - :type commit_response_pb: :class:`._generated.datastore_pb2.CommitResponse` - :param commit_response_pb: The protobuf response from a commit request. - - :rtype: tuple - :returns: The pair of the number of index updates and a list of - :class:`._generated.entity_pb2.Key` for each incomplete key - that was completed in the commit. - """ - mut_results = commit_response_pb.mutation_results - index_updates = commit_response_pb.index_updates - completed_keys = [mut_result.key for mut_result in mut_results - if mut_result.HasField('key')] # Message field (Key) - return index_updates, completed_keys -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/dns/connection.html b/latest/_modules/gcloud/dns/connection.html deleted file mode 100644 index e2e62dfb6f76..000000000000 --- a/latest/_modules/gcloud/dns/connection.html +++ /dev/null @@ -1,254 +0,0 @@ - - - - - - - - gcloud.dns.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.dns.connection

    -# Copyright 2015 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with gcloud dns connections."""
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud DNS via the JSON REST API.""" - - API_BASE_URL = 'https://www.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v1' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/dns/{api_version}{path}' - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/ndev.clouddns.readwrite',) - """The scopes required for authenticating as a Cloud DNS consumer."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/dns/resource_record_set.html b/latest/_modules/gcloud/dns/resource_record_set.html deleted file mode 100644 index 6846ebaafea7..000000000000 --- a/latest/_modules/gcloud/dns/resource_record_set.html +++ /dev/null @@ -1,287 +0,0 @@ - - - - - - - - gcloud.dns.resource_record_set — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.dns.resource_record_set

    -# Copyright 2015 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Define API ResourceRecordSets."""
    -
    -
    -
    [docs]class ResourceRecordSet(object): - """ResourceRecordSets are DNS resource records. - - RRS are owned by a :class:`gcloud.dns.zone.ManagedZone` instance. - - See: - https://cloud.google.com/dns/api/v1/resourceRecordSets - - :type name: string - :param name: the name of the record set - - :type record_type: string - :param record_type: the RR type of the zone - - :type ttl: integer - :param ttl: TTL (in seconds) for caching the record sets - - :type rrdatas: list of string - :param rrdatas: one or more lines containing the resource data - - :type zone: :class:`gcloud.dns.zone.ManagedZone` - :param zone: A zone which holds one or more record sets. - """ - - def __init__(self, name, record_type, ttl, rrdatas, zone): - self.name = name - self.record_type = record_type - self.ttl = ttl - self.rrdatas = rrdatas - self.zone = zone - - @classmethod -
    [docs] def from_api_repr(cls, resource, zone): - """Factory: construct a record set given its API representation - - :type resource: dict - :param resource: record sets representation returned from the API - - :type zone: :class:`gcloud.dns.zone.ManagedZone` - :param zone: A zone which holds one or more record sets. - - :rtype: :class:`gcloud.dns.zone.ResourceRecordSet` - :returns: RRS parsed from ``resource``. - """ - name = resource['name'] - record_type = resource['type'] - ttl = int(resource['ttl']) - rrdatas = resource['rrdatas'] - return cls(name, record_type, ttl, rrdatas, zone=zone)
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/client.html b/latest/_modules/gcloud/monitoring/client.html deleted file mode 100644 index 6f73c5c511cb..000000000000 --- a/latest/_modules/gcloud/monitoring/client.html +++ /dev/null @@ -1,505 +0,0 @@ - - - - - - - - gcloud.monitoring.client — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.monitoring.client

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Client for interacting with the `Google Stackdriver Monitoring API (V3)`_.
    -
    -Example::
    -
    -    >>> from gcloud import monitoring
    -    >>> client = monitoring.Client()
    -    >>> query = client.query(minutes=5)
    -    >>> print(query.as_dataframe())  # Requires pandas.
    -
    -At present, the client supports querying of time series, metric descriptors,
    -and monitored resource descriptors.
    -
    -.. _Google Stackdriver Monitoring API (V3):
    -    https://cloud.google.com/monitoring/api/v3/
    -"""
    -
    -from gcloud.client import JSONClient
    -from gcloud.monitoring.connection import Connection
    -from gcloud.monitoring.metric import MetricDescriptor
    -from gcloud.monitoring.metric import MetricKind
    -from gcloud.monitoring.metric import ValueType
    -from gcloud.monitoring.query import Query
    -from gcloud.monitoring.resource import ResourceDescriptor
    -
    -
    -
    [docs]class Client(JSONClient): - """Client to bundle configuration needed for API requests. - - :type project: string - :param project: The target project. If not passed, falls back to the - default inferred from the environment. - - :type credentials: :class:`oauth2client.client.OAuth2Credentials` or - :class:`NoneType` - :param credentials: The OAuth2 Credentials to use for the connection - owned by this client. If not passed (and if no ``http`` - object is passed), falls back to the default inferred - from the environment. - - :type http: :class:`httplib2.Http` or class that defines ``request()`` - :param http: An optional HTTP object to make requests. If not passed, an - ``http`` object is created that is bound to the - ``credentials`` for the current object. - """ - - _connection_class = Connection - -
    [docs] def query(self, - metric_type=Query.DEFAULT_METRIC_TYPE, - end_time=None, - days=0, hours=0, minutes=0): - """Construct a query object for retrieving metric data. - - Example:: - - >>> query = client.query(minutes=5) - >>> print(query.as_dataframe()) # Requires pandas. - - :type metric_type: string - :param metric_type: The metric type name. The default value is - :data:`Query.DEFAULT_METRIC_TYPE - <gcloud.monitoring.query.Query.DEFAULT_METRIC_TYPE>`, - but please note that this default value is provided only for - demonstration purposes and is subject to change. See the - `supported metrics`_. - - :type end_time: :class:`datetime.datetime` or None - :param end_time: The end time (inclusive) of the time interval - for which results should be returned, as a datetime object. - The default is the start of the current minute. - - The start time (exclusive) is determined by combining the - values of ``days``, ``hours``, and ``minutes``, and - subtracting the resulting duration from the end time. - - It is also allowed to omit the end time and duration here, - in which case - :meth:`~gcloud.monitoring.query.Query.select_interval` - must be called before the query is executed. - - :type days: integer - :param days: The number of days in the time interval. - - :type hours: integer - :param hours: The number of hours in the time interval. - - :type minutes: integer - :param minutes: The number of minutes in the time interval. - - :rtype: :class:`~gcloud.monitoring.query.Query` - :returns: The query object. - - :raises: :exc:`ValueError` if ``end_time`` is specified but - ``days``, ``hours``, and ``minutes`` are all zero. - If you really want to specify a point in time, use - :meth:`~gcloud.monitoring.query.Query.select_interval`. - - .. _supported metrics: https://cloud.google.com/monitoring/api/metrics - """ - return Query(self, metric_type, - end_time=end_time, - days=days, hours=hours, minutes=minutes)
    - -
    [docs] def metric_descriptor(self, type_, - metric_kind=MetricKind.METRIC_KIND_UNSPECIFIED, - value_type=ValueType.VALUE_TYPE_UNSPECIFIED, - labels=(), unit='', description='', display_name=''): - """Construct a metric descriptor object. - - Metric descriptors specify the schema for a particular metric type. - - This factory method is used most often in conjunction with the metric - descriptor :meth:`~gcloud.monitoring.metric.MetricDescriptor.create` - method to define custom metrics:: - - >>> descriptor = client.metric_descriptor( - ... 'custom.googleapis.com/my_metric', - ... metric_kind=MetricKind.GAUGE, - ... value_type=ValueType.DOUBLE, - ... description='This is a simple example of a custom metric.') - >>> descriptor.create() - - Here is an example where the custom metric is parameterized by a - metric label:: - - >>> label = LabelDescriptor('response_code', LabelValueType.INT64, - ... description='HTTP status code') - >>> descriptor = client.metric_descriptor( - ... 'custom.googleapis.com/my_app/response_count', - ... metric_kind=MetricKind.CUMULATIVE, - ... value_type=ValueType.INT64, - ... labels=[label], - ... description='Cumulative count of HTTP responses.') - >>> descriptor.create() - - :type type_: string - :param type_: - The metric type including a DNS name prefix. For example: - ``"custom.googleapis.com/my_metric"`` - - :type metric_kind: string - :param metric_kind: - The kind of measurement. It must be one of - :data:`MetricKind.GAUGE`, :data:`MetricKind.DELTA`, - or :data:`MetricKind.CUMULATIVE`. - See :class:`~gcloud.monitoring.metric.MetricKind`. - - :type value_type: string - :param value_type: - The value type of the metric. It must be one of - :data:`ValueType.BOOL`, :data:`ValueType.INT64`, - :data:`ValueType.DOUBLE`, :data:`ValueType.STRING`, - or :data:`ValueType.DISTRIBUTION`. - See :class:`ValueType`. - - :type labels: list of :class:`~gcloud.monitoring.label.LabelDescriptor` - :param labels: - A sequence of zero or more label descriptors specifying the labels - used to identify a specific instance of this metric. - - :type unit: string - :param unit: An optional unit in which the metric value is reported. - - :type description: string - :param description: An optional detailed description of the metric. - - :type display_name: string - :param display_name: An optional concise name for the metric. - - :rtype: :class:`MetricDescriptor` - :returns: The metric descriptor created with the passed-in arguments. - """ - return MetricDescriptor( - self, type_, - metric_kind=metric_kind, - value_type=value_type, - labels=labels, - unit=unit, - description=description, - display_name=display_name, - )
    - -
    [docs] def fetch_metric_descriptor(self, metric_type): - """Look up a metric descriptor by type. - - Example:: - - >>> METRIC = 'compute.googleapis.com/instance/cpu/utilization' - >>> print(client.fetch_metric_descriptor(METRIC)) - - :type metric_type: string - :param metric_type: The metric type name. - - :rtype: :class:`~gcloud.monitoring.metric.MetricDescriptor` - :returns: The metric descriptor instance. - - :raises: :class:`gcloud.exceptions.NotFound` if the metric descriptor - is not found. - """ - return MetricDescriptor._fetch(self, metric_type)
    - -
    [docs] def list_metric_descriptors(self, filter_string=None, type_prefix=None): - """List all metric descriptors for the project. - - Examples:: - - >>> for descriptor in client.list_metric_descriptors(): - ... print(descriptor.type) - - >>> for descriptor in client.list_metric_descriptors( - ... type_prefix='custom.'): - ... print(descriptor.type) - - :type filter_string: string or None - :param filter_string: - An optional filter expression describing the metric descriptors - to be returned. See the `filter documentation`_. - - :type type_prefix: string or None - :param type_prefix: An optional prefix constraining the selected - metric types. This adds ``metric.type = starts_with("<prefix>")`` - to the filter. - - :rtype: list of :class:`~gcloud.monitoring.metric.MetricDescriptor` - :returns: A list of metric descriptor instances. - - .. _filter documentation: - https://cloud.google.com/monitoring/api/v3/filters - """ - return MetricDescriptor._list(self, filter_string, - type_prefix=type_prefix)
    - -
    [docs] def fetch_resource_descriptor(self, resource_type): - """Look up a monitored resource descriptor by type. - - Example:: - - >>> print(client.fetch_resource_descriptor('gce_instance')) - - :type resource_type: string - :param resource_type: The resource type name. - - :rtype: :class:`~gcloud.monitoring.resource.ResourceDescriptor` - :returns: The resource descriptor instance. - - :raises: :class:`gcloud.exceptions.NotFound` if the resource descriptor - is not found. - """ - return ResourceDescriptor._fetch(self, resource_type)
    - -
    [docs] def list_resource_descriptors(self, filter_string=None): - """List all monitored resource descriptors for the project. - - Example:: - - >>> for descriptor in client.list_resource_descriptors(): - ... print(descriptor.type) - - :type filter_string: string or None - :param filter_string: - An optional filter expression describing the resource descriptors - to be returned. See the `filter documentation`_. - - :rtype: list of :class:`~gcloud.monitoring.resource.ResourceDescriptor` - :returns: A list of resource descriptor instances. - - .. _filter documentation: - https://cloud.google.com/monitoring/api/v3/filters - """ - return ResourceDescriptor._list(self, filter_string)
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/connection.html b/latest/_modules/gcloud/monitoring/connection.html deleted file mode 100644 index 5f51f0807a0b..000000000000 --- a/latest/_modules/gcloud/monitoring/connection.html +++ /dev/null @@ -1,268 +0,0 @@ - - - - - - - - gcloud.monitoring.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.monitoring.connection

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with Stackdriver Monitoring connections."""
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Stackdriver Monitoring via the JSON REST API. - - :type credentials: :class:`oauth2client.client.OAuth2Credentials` - :param credentials: (Optional) The OAuth2 Credentials to use for this - connection. - - :type http: :class:`httplib2.Http` or class that defines ``request()`` - :param http: (Optional) HTTP object to make requests. - - :type api_base_url: string - :param api_base_url: The base of the API call URL. Defaults to the value - :attr:`Connection.API_BASE_URL`. - """ - - API_BASE_URL = 'https://monitoring.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v3' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/{api_version}{path}' - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/monitoring.read', - 'https://www.googleapis.com/auth/monitoring', - 'https://www.googleapis.com/auth/cloud-platform') - """The scopes required for authenticating as a Monitoring consumer."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/resource_manager/connection.html b/latest/_modules/gcloud/resource_manager/connection.html deleted file mode 100644 index 820499edaa53..000000000000 --- a/latest/_modules/gcloud/resource_manager/connection.html +++ /dev/null @@ -1,263 +0,0 @@ - - - - - - - - gcloud.resource_manager.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.resource_manager.connection

    -# Copyright 2015 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with gcloud.resource_manager connections."""
    -
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud Resource Manager via the JSON REST API. - - :type credentials: :class:`oauth2client.client.OAuth2Credentials` - :param credentials: (Optional) The OAuth2 Credentials to use for this - connection. - - :type http: :class:`httplib2.Http` or class that defines ``request()``. - :param http: (Optional) HTTP object to make requests. - """ - - API_BASE_URL = 'https://cloudresourcemanager.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v1beta1' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/{api_version}{path}' - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/cloud-platform',) - """The scopes required for authenticating as a Resouce Manager consumer."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/connection.html b/latest/_modules/gcloud/storage/connection.html deleted file mode 100644 index 96e00f7de8d5..000000000000 --- a/latest/_modules/gcloud/storage/connection.html +++ /dev/null @@ -1,264 +0,0 @@ - - - - - - - - gcloud.storage.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.storage.connection

    -# Copyright 2014 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with gcloud storage connections."""
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud Storage via the JSON REST API. - - :type credentials: :class:`oauth2client.client.OAuth2Credentials` - :param credentials: (Optional) The OAuth2 Credentials to use for this - connection. - - :type http: :class:`httplib2.Http` or class that defines ``request()``. - :param http: (Optional) HTTP object to make requests. - """ - - API_BASE_URL = base_connection.API_BASE_URL - """The base of the API call URL.""" - - API_VERSION = 'v1' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/storage/{api_version}{path}' - """A template for the URL of a particular API call.""" - - SCOPE = ('https://www.googleapis.com/auth/devstorage.full_control', - 'https://www.googleapis.com/auth/devstorage.read_only', - 'https://www.googleapis.com/auth/devstorage.read_write') - """The scopes required for authenticating as a Cloud Storage consumer."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/translate/connection.html b/latest/_modules/gcloud/translate/connection.html deleted file mode 100644 index 8a57c0c034ec..000000000000 --- a/latest/_modules/gcloud/translate/connection.html +++ /dev/null @@ -1,251 +0,0 @@ - - - - - - - - gcloud.translate.connection — gcloud 47bfd0a documentation - - - - - - - - - - - - - - -
    - -
    - - -
    - -
    - -

    Source code for gcloud.translate.connection

    -# Copyright 2016 Google Inc. All rights reserved.
    -#
    -# Licensed under the Apache License, Version 2.0 (the "License");
    -# you may not use this file except in compliance with the License.
    -# You may obtain a copy of the License at
    -#
    -#     http://www.apache.org/licenses/LICENSE-2.0
    -#
    -# Unless required by applicable law or agreed to in writing, software
    -# distributed under the License is distributed on an "AS IS" BASIS,
    -# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    -# See the License for the specific language governing permissions and
    -# limitations under the License.
    -
    -"""Create / interact with Google Cloud Translate connections."""
    -
    -from gcloud import connection as base_connection
    -
    -
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud Translate via the JSON REST API.""" - - API_BASE_URL = 'https://www.googleapis.com' - """The base of the API call URL.""" - - API_VERSION = 'v2' - """The version of the API, used in building the API call's URL.""" - - API_URL_TEMPLATE = '{api_base_url}/language/translate/{api_version}{path}' - """A template for the URL of a particular API call."""
    -
    - -
    - -
    - - - - - - - \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/_helpers.html b/latest/_modules/google/cloud/bigquery/_helpers.html similarity index 71% rename from latest/_modules/gcloud/bigquery/_helpers.html rename to latest/_modules/google/cloud/bigquery/_helpers.html index 32b18e58b4e9..5b898c5d86fd 100644 --- a/latest/_modules/gcloud/bigquery/_helpers.html +++ b/latest/_modules/google/cloud/bigquery/_helpers.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery._helpers — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigquery._helpers — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery._helpers
    • +
    • -

      Source code for gcloud.bigquery._helpers

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery._helpers

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,9 +266,9 @@ 

    Source code for gcloud.bigquery._helpers

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Shared elper functions for BigQuery API classes."""
    +"""Shared helper functions for BigQuery API classes."""
     
    -from gcloud._helpers import _datetime_from_microseconds
    +from google.cloud._helpers import _datetime_from_microseconds
     
     
     def _not_null(value, field):
    @@ -248,13 +403,13 @@ 

    Source code for gcloud.bigquery._helpers

     
     
     class _EnumProperty(_ConfigurationProperty):
    -    """Psedo-enumeration class.
    +    """Pseudo-enumeration class.
     
         Subclasses must define ``ALLOWED`` as a class-level constant:  it must
         be a sequence of strings.
     
         :type name: string
    -    :param name:  name of the property
    +    :param name:  name of the property.
         """
         def _validate(self, value):
             """Check that ``value`` is one of the allowed values.
    @@ -265,123 +420,62 @@ 

    Source code for gcloud.bigquery._helpers

                 raise ValueError('Pass one of: %s' ', '.join(self.ALLOWED))
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/client.html b/latest/_modules/google/cloud/bigquery/client.html similarity index 54% rename from latest/_modules/gcloud/bigquery/client.html rename to latest/_modules/google/cloud/bigquery/client.html index b278372d9d3e..d9c708788ad0 100644 --- a/latest/_modules/gcloud/bigquery/client.html +++ b/latest/_modules/google/cloud/bigquery/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigquery.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + -
    + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.client
    • +
    • + + -

      Source code for gcloud.bigquery.client

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,17 +269,41 @@ 

    Source code for gcloud.bigquery.client

     """Client for interacting with the Google BigQuery API."""
     
     
    -from gcloud.client import JSONClient
    -from gcloud.bigquery.connection import Connection
    -from gcloud.bigquery.dataset import Dataset
    -from gcloud.bigquery.job import CopyJob
    -from gcloud.bigquery.job import ExtractTableToStorageJob
    -from gcloud.bigquery.job import LoadTableFromStorageJob
    -from gcloud.bigquery.job import QueryJob
    -from gcloud.bigquery.query import QueryResults
    +from google.cloud.client import JSONClient
    +from google.cloud.bigquery.connection import Connection
    +from google.cloud.bigquery.dataset import Dataset
    +from google.cloud.bigquery.job import CopyJob
    +from google.cloud.bigquery.job import ExtractTableToStorageJob
    +from google.cloud.bigquery.job import LoadTableFromStorageJob
    +from google.cloud.bigquery.job import QueryJob
    +from google.cloud.bigquery.query import QueryResults
    +
    +
    +
    [docs]class Project(object): + """Wrapper for resource describing a BigQuery project. + + :type project_id: str + :param project_id: Opaque ID of the project + :type numeric_id: int + :param numeric_id: Numeric ID of the project -
    [docs]class Client(JSONClient): + :type friendly_name: str + :param friendly_name: Display name of the project + """ + def __init__(self, project_id, numeric_id, friendly_name): + self.project_id = project_id + self.numeric_id = numeric_id + self.friendly_name = friendly_name + + @classmethod +
    [docs] def from_api_repr(cls, resource): + """Factory: construct an instance from a resource dict.""" + return cls( + resource['id'], resource['numericId'], resource['friendlyName'])
    + + +
    [docs]class Client(JSONClient): """Client to bundle configuration needed for API requests. :type project: str @@ -147,7 +326,43 @@

    Source code for gcloud.bigquery.client

     
         _connection_class = Connection
     
    -
    [docs] def list_datasets(self, include_all=False, max_results=None, +
    [docs] def list_projects(self, max_results=None, page_token=None): + """List projects for the project associated with this client. + + See: + https://cloud.google.com/bigquery/docs/reference/v2/projects/list + + :type max_results: int + :param max_results: maximum number of projects to return, If not + passed, defaults to a value set by the API. + + :type page_token: str + :param page_token: opaque marker for the next "page" of projects. If + not passed, the API will return the first page of + projects. + + :rtype: tuple, (list, str) + :returns: list of :class:`gcloud.bigquery.client.Project`, plus a + "next page token" string: if the token is not None, + indicates that more projects can be retrieved with another + call (pass that value as ``page_token``). + """ + params = {} + + if max_results is not None: + params['maxResults'] = max_results + + if page_token is not None: + params['pageToken'] = page_token + + path = '/projects' + resp = self.connection.api_request(method='GET', path=path, + query_params=params) + projects = [Project.from_api_repr(resource) + for resource in resp.get('projects', ())] + return projects, resp.get('nextPageToken')
    + +
    [docs] def list_datasets(self, include_all=False, max_results=None, page_token=None): """List datasets for the project associated with this client. @@ -167,8 +382,8 @@

    Source code for gcloud.bigquery.client

                                datasets.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.bigquery.dataset.Dataset`, plus a
    -                  "next page token" string:  if the token is not None,
    +        :returns: list of :class:`~google.cloud.bigquery.dataset.Dataset`,
    +                  plus a "next page token" string:  if the token is not None,
                       indicates that more datasets can be retrieved with another
                       call (pass that value as ``page_token``).
             """
    @@ -190,29 +405,29 @@ 

    Source code for gcloud.bigquery.client

                         for resource in resp.get('datasets', ())]
             return datasets, resp.get('nextPageToken')
    -
    [docs] def dataset(self, dataset_name): +
    [docs] def dataset(self, dataset_name): """Construct a dataset bound to this client. :type dataset_name: str :param dataset_name: Name of the dataset. - :rtype: :class:`gcloud.bigquery.dataset.Dataset` + :rtype: :class:`google.cloud.bigquery.dataset.Dataset` :returns: a new ``Dataset`` instance """ return Dataset(dataset_name, client=self)
    -
    [docs] def job_from_resource(self, resource): +
    [docs] def job_from_resource(self, resource): """Detect correct job type from resource and instantiate. :type resource: dict :param resource: one job resource from API response :rtype: One of: - :class:`gcloud.bigquery.job.LoadTableFromStorageJob`, - :class:`gcloud.bigquery.job.CopyJob`, - :class:`gcloud.bigquery.job.ExtractTableToStorageJob`, - :class:`gcloud.bigquery.job.QueryJob`, - :class:`gcloud.bigquery.job.RunSyncQueryJob` + :class:`google.cloud.bigquery.job.LoadTableFromStorageJob`, + :class:`google.cloud.bigquery.job.CopyJob`, + :class:`google.cloud.bigquery.job.ExtractTableToStorageJob`, + :class:`google.cloud.bigquery.job.QueryJob`, + :class:`google.cloud.bigquery.job.RunSyncQueryJob` :returns: the job instance, constructed via the resource """ config = resource['configuration'] @@ -226,7 +441,7 @@

    Source code for gcloud.bigquery.client

                 return QueryJob.from_api_repr(resource, self)
             raise ValueError('Cannot parse job resource')
    -
    [docs] def list_jobs(self, max_results=None, page_token=None, all_users=None, +
    [docs] def list_jobs(self, max_results=None, page_token=None, all_users=None, state_filter=None): """List jobs for the project associated with this client. @@ -281,7 +496,7 @@

    Source code for gcloud.bigquery.client

                     for resource in resp.get('jobs', ())]
             return jobs, resp.get('nextPageToken')
    -
    [docs] def load_table_from_storage(self, job_name, destination, *source_uris): +
    [docs] def load_table_from_storage(self, job_name, destination, *source_uris): """Construct a job for loading data into a table from CloudStorage. See: @@ -290,20 +505,20 @@

    Source code for gcloud.bigquery.client

             :type job_name: str
             :param job_name: Name of the job.
     
    -        :type destination: :class:`gcloud.bigquery.table.Table`
    +        :type destination: :class:`google.cloud.bigquery.table.Table`
             :param destination: Table into which data is to be loaded.
     
             :type source_uris: sequence of string
             :param source_uris: URIs of data files to be loaded; in format
                                 ``gs://<bucket_name>/<object_name_or_glob>``.
     
    -        :rtype: :class:`gcloud.bigquery.job.LoadTableFromStorageJob`
    +        :rtype: :class:`google.cloud.bigquery.job.LoadTableFromStorageJob`
             :returns: a new ``LoadTableFromStorageJob`` instance
             """
             return LoadTableFromStorageJob(job_name, destination, source_uris,
                                            client=self)
    -
    [docs] def copy_table(self, job_name, destination, *sources): +
    [docs] def copy_table(self, job_name, destination, *sources): """Construct a job for copying one or more tables into another table. See: @@ -312,18 +527,18 @@

    Source code for gcloud.bigquery.client

             :type job_name: str
             :param job_name: Name of the job.
     
    -        :type destination: :class:`gcloud.bigquery.table.Table`
    +        :type destination: :class:`google.cloud.bigquery.table.Table`
             :param destination: Table into which data is to be copied.
     
    -        :type sources: sequence of :class:`gcloud.bigquery.table.Table`
    +        :type sources: sequence of :class:`google.cloud.bigquery.table.Table`
             :param sources: tables to be copied.
     
    -        :rtype: :class:`gcloud.bigquery.job.CopyJob`
    +        :rtype: :class:`google.cloud.bigquery.job.CopyJob`
             :returns: a new ``CopyJob`` instance
             """
             return CopyJob(job_name, destination, sources, client=self)
    -
    [docs] def extract_table_to_storage(self, job_name, source, *destination_uris): +
    [docs] def extract_table_to_storage(self, job_name, source, *destination_uris): """Construct a job for extracting a table into Cloud Storage files. See: @@ -332,7 +547,7 @@

    Source code for gcloud.bigquery.client

             :type job_name: str
             :param job_name: Name of the job.
     
    -        :type source: :class:`gcloud.bigquery.table.Table`
    +        :type source: :class:`google.cloud.bigquery.table.Table`
             :param source: table to be extracted.
     
             :type destination_uris: sequence of string
    @@ -340,13 +555,13 @@ 

    Source code for gcloud.bigquery.client

                                      table data is to be extracted; in format
                                      ``gs://<bucket_name>/<object_name_or_glob>``.
     
    -        :rtype: :class:`gcloud.bigquery.job.ExtractTableToStorageJob`
    +        :rtype: :class:`google.cloud.bigquery.job.ExtractTableToStorageJob`
             :returns: a new ``ExtractTableToStorageJob`` instance
             """
             return ExtractTableToStorageJob(job_name, source, destination_uris,
                                             client=self)
    -
    [docs] def run_async_query(self, job_name, query): +
    [docs] def run_async_query(self, job_name, query): """Construct a job for running a SQL query asynchronously. See: @@ -358,140 +573,79 @@

    Source code for gcloud.bigquery.client

             :type query: str
             :param query: SQL query to be executed
     
    -        :rtype: :class:`gcloud.bigquery.job.QueryJob`
    +        :rtype: :class:`google.cloud.bigquery.job.QueryJob`
             :returns: a new ``QueryJob`` instance
             """
             return QueryJob(job_name, query, client=self)
    -
    [docs] def run_sync_query(self, query): +
    [docs] def run_sync_query(self, query): """Run a SQL query synchronously. :type query: str :param query: SQL query to be executed - :rtype: :class:`gcloud.bigquery.query.QueryResults` + :rtype: :class:`google.cloud.bigquery.query.QueryResults` :returns: a new ``QueryResults`` instance """ return QueryResults(query, client=self)
    -
    -
    + + + + + - - + + + + + + + - - - + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/bigquery/connection.html b/latest/_modules/google/cloud/bigquery/connection.html new file mode 100644 index 000000000000..8974f0775ee5 --- /dev/null +++ b/latest/_modules/google/cloud/bigquery/connection.html @@ -0,0 +1,349 @@ + + + + + + + + + + + google.cloud.bigquery.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.connection

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Google Cloud BigQuery connections."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud BigQuery via the JSON REST API.""" + + API_BASE_URL = 'https://www.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v2' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/bigquery/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/bigquery', + 'https://www.googleapis.com/auth/cloud-platform') + """The scopes required for authenticating as a Cloud BigQuery consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/dataset.html b/latest/_modules/google/cloud/bigquery/dataset.html similarity index 80% rename from latest/_modules/gcloud/bigquery/dataset.html rename to latest/_modules/google/cloud/bigquery/dataset.html index 56a04e2d8bcd..3a761e13c1f6 100644 --- a/latest/_modules/gcloud/bigquery/dataset.html +++ b/latest/_modules/google/cloud/bigquery/dataset.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery.dataset — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigquery.dataset — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.dataset
    • +
    • -

      Source code for gcloud.bigquery.dataset

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.dataset

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,12 +269,12 @@ 

    Source code for gcloud.bigquery.dataset

     """Define API Datasets."""
     import six
     
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud.exceptions import NotFound
    -from gcloud.bigquery.table import Table
    +from google.cloud._helpers import _datetime_from_microseconds
    +from google.cloud.exceptions import NotFound
    +from google.cloud.bigquery.table import Table
     
     
    -
    [docs]class AccessGrant(object): +
    [docs]class AccessGrant(object): """Represent grant of an access role to an entity. Every entry in the access list will have exactly one of @@ -184,7 +339,7 @@

    Source code for gcloud.bigquery.dataset

                 self.role, self.entity_type, self.entity_id)
    -
    [docs]class Dataset(object): +
    [docs]class Dataset(object): """Datasets are containers for tables. See: @@ -193,7 +348,7 @@

    Source code for gcloud.bigquery.dataset

         :type name: string
         :param name: the name of the dataset
     
    -    :type client: :class:`gcloud.bigquery.client.Client`
    +    :type client: :class:`google.cloud.bigquery.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the dataset (which requires a project).
     
    @@ -391,17 +546,17 @@ 

    Source code for gcloud.bigquery.dataset

             self._properties['location'] = value
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a dataset given its API representation :type resource: dict :param resource: dataset resource representation returned from the API - :type client: :class:`gcloud.bigquery.client.Client` + :type client: :class:`google.cloud.bigquery.client.Client` :param client: Client which holds credentials and project configuration for the dataset. - :rtype: :class:`gcloud.bigquery.dataset.Dataset` + :rtype: :class:`google.cloud.bigquery.dataset.Dataset` :returns: Dataset parsed from ``resource``. """ if ('datasetReference' not in resource or @@ -416,11 +571,12 @@

    Source code for gcloud.bigquery.dataset

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    -        :rtype: :class:`gcloud.bigquery.client.Client`
    +        :rtype: :class:`google.cloud.bigquery.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -435,10 +591,10 @@ 

    Source code for gcloud.bigquery.dataset

             type is ``view``.
     
             :type access: list of mappings
    -        :param access: each mapping represents a single access grant
    +        :param access: each mapping represents a single access grant.
     
             :rtype: list of :class:`AccessGrant`
    -        :returns: a list of parsed grants
    +        :returns: a list of parsed grants.
             :raises: :class:`ValueError` if a grant in ``access`` has more keys
                      than ``role`` and one additional key.
             """
    @@ -457,7 +613,7 @@ 

    Source code for gcloud.bigquery.dataset

             """Update properties from resource in body of ``api_response``
     
             :type api_response: httplib2.Response
    -        :param api_response: response returned from an API call
    +        :param api_response: response returned from an API call.
             """
             self._properties.clear()
             cleaned = api_response.copy()
    @@ -506,13 +662,14 @@ 

    Source code for gcloud.bigquery.dataset

     
             return resource
     
    -
    [docs] def create(self, client=None): - """API call: create the dataset via a PUT request +
    [docs] def create(self, client=None): + """API call: create the dataset via a PUT request. See: https://cloud.google.com/bigquery/docs/reference/v2/tables/insert - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -522,13 +679,14 @@

    Source code for gcloud.bigquery.dataset

                 method='POST', path=path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the dataset via a GET request See https://cloud.google.com/bigquery/docs/reference/v2/datasets/get - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. @@ -545,13 +703,14 @@

    Source code for gcloud.bigquery.dataset

             else:
                 return True
    -
    [docs] def reload(self, client=None): - """API call: refresh dataset properties via a GET request +
    [docs] def reload(self, client=None): + """API call: refresh dataset properties via a GET request. See https://cloud.google.com/bigquery/docs/reference/v2/datasets/get - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -561,13 +720,14 @@

    Source code for gcloud.bigquery.dataset

                 method='GET', path=self.path)
             self._set_properties(api_response)
    -
    [docs] def patch(self, client=None, **kw): - """API call: update individual dataset properties via a PATCH request +
    [docs] def patch(self, client=None, **kw): + """API call: update individual dataset properties via a PATCH request. See https://cloud.google.com/bigquery/docs/reference/v2/datasets/patch - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. @@ -599,13 +759,14 @@

    Source code for gcloud.bigquery.dataset

                 method='PATCH', path=self.path, data=partial)
             self._set_properties(api_response)
    -
    [docs] def update(self, client=None): - """API call: update dataset properties via a PUT request +
    [docs] def update(self, client=None): + """API call: update dataset properties via a PUT request. See https://cloud.google.com/bigquery/docs/reference/v2/datasets/update - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -614,20 +775,21 @@

    Source code for gcloud.bigquery.dataset

                 method='PUT', path=self.path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def delete(self, client=None): - """API call: delete the dataset via a DELETE request +
    [docs] def delete(self, client=None): + """API call: delete the dataset via a DELETE request. See: https://cloud.google.com/bigquery/docs/reference/v2/tables/delete - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ client = self._require_client(client) client.connection.api_request(method='DELETE', path=self.path)
    -
    [docs] def list_tables(self, max_results=None, page_token=None): +
    [docs] def list_tables(self, max_results=None, page_token=None): """List tables for the project associated with this client. See: @@ -643,7 +805,7 @@

    Source code for gcloud.bigquery.dataset

                                datasets.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.bigquery.table.Table`, plus a
    +        :returns: list of :class:`google.cloud.bigquery.table.Table`, plus a
                       "next page token" string:  if not ``None``, indicates that
                       more tables can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -664,138 +826,77 @@ 

    Source code for gcloud.bigquery.dataset

                       for resource in resp.get('tables', ())]
             return tables, resp.get('nextPageToken')
    -
    [docs] def table(self, name, schema=()): +
    [docs] def table(self, name, schema=()): """Construct a table bound to this dataset. :type name: string :param name: Name of the table. - :type schema: list of :class:`gcloud.bigquery.table.SchemaField` + :type schema: list of :class:`google.cloud.bigquery.table.SchemaField` :param schema: The table's schema - :rtype: :class:`gcloud.bigquery.table.Table` + :rtype: :class:`google.cloud.bigquery.table.Table` :returns: a new ``Table`` instance """ return Table(name, dataset=self, schema=schema)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/job.html b/latest/_modules/google/cloud/bigquery/job.html similarity index 82% rename from latest/_modules/gcloud/bigquery/job.html rename to latest/_modules/google/cloud/bigquery/job.html index 1a9d66f1a225..906c890f4c58 100644 --- a/latest/_modules/gcloud/bigquery/job.html +++ b/latest/_modules/google/cloud/bigquery/job.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery.job — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigquery.job — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + -
    + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.job
    • +
    • + + -

      Source code for gcloud.bigquery.job

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.job

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,32 +270,86 @@ 

    Source code for gcloud.bigquery.job

     
     import six
     
    -from gcloud.exceptions import NotFound
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud.bigquery.dataset import Dataset
    -from gcloud.bigquery.table import SchemaField
    -from gcloud.bigquery.table import Table
    -from gcloud.bigquery.table import _build_schema_resource
    -from gcloud.bigquery.table import _parse_schema_resource
    -from gcloud.bigquery._helpers import _EnumProperty
    -from gcloud.bigquery._helpers import _TypedProperty
    +from google.cloud.exceptions import NotFound
    +from google.cloud._helpers import _datetime_from_microseconds
    +from google.cloud.bigquery.dataset import Dataset
    +from google.cloud.bigquery.schema import SchemaField
    +from google.cloud.bigquery.table import Table
    +from google.cloud.bigquery.table import _build_schema_resource
    +from google.cloud.bigquery.table import _parse_schema_resource
    +from google.cloud.bigquery._helpers import _EnumProperty
    +from google.cloud.bigquery._helpers import _TypedProperty
    +
    +
    +
    [docs]class UDFResource(object): + """Describe a single user-defined function (UDF) resource. + :type udf_type: str + :param udf_type: the type of the resource ('inlineCode' or 'resourceUri') + + :type value: str + :param value: the inline code or resource URI. + + See + https://cloud.google.com/bigquery/user-defined-functions#api + """ + def __init__(self, udf_type, value): + self.udf_type = udf_type + self.value = value + + def __eq__(self, other): + return( + self.udf_type == other.udf_type and + self.value == other.value)
    + + +def _build_udf_resources(resources): + """ + :type resources: sequence of :class:`UDFResource` + :param resources: fields to be appended. + + :rtype: mapping + :returns: a mapping describing userDefinedFunctionResources for the query. + """ + udfs = [] + for resource in resources: + udf = {resource.udf_type: resource.value} + udfs.append(udf) + return udfs + + +
    [docs]class UDFResourcesProperty(object): + """Custom property type for :class:`QueryJob`. + + Also used by :class:`~google.cloud.bigquery.query.Query`. + """ + def __get__(self, instance, owner): + """Descriptor protocol: accessor""" + if instance is None: + return self + return list(instance._udf_resources) + + def __set__(self, instance, value): + """Descriptor protocol: mutator""" + if not all(isinstance(u, UDFResource) for u in value): + raise ValueError("udf items must be UDFResource") + instance._udf_resources = tuple(value)
    -
    [docs]class Compression(_EnumProperty): +
    [docs]class Compression(_EnumProperty): """Pseudo-enum for ``compression`` properties.""" GZIP = 'GZIP' NONE = 'NONE' ALLOWED = (GZIP, NONE)
    -
    [docs]class CreateDisposition(_EnumProperty): +
    [docs]class CreateDisposition(_EnumProperty): """Pseudo-enum for ``create_disposition`` properties.""" CREATE_IF_NEEDED = 'CREATE_IF_NEEDED' CREATE_NEVER = 'CREATE_NEVER' ALLOWED = (CREATE_IF_NEEDED, CREATE_NEVER)
    -
    [docs]class DestinationFormat(_EnumProperty): +
    [docs]class DestinationFormat(_EnumProperty): """Pseudo-enum for ``destination_format`` properties.""" CSV = 'CSV' NEWLINE_DELIMITED_JSON = 'NEWLINE_DELIMITED_JSON' @@ -148,21 +357,21 @@

    Source code for gcloud.bigquery.job

         ALLOWED = (CSV, NEWLINE_DELIMITED_JSON, AVRO)
    -
    [docs]class Encoding(_EnumProperty): +
    [docs]class Encoding(_EnumProperty): """Pseudo-enum for ``encoding`` properties.""" UTF_8 = 'UTF-8' ISO_8559_1 = 'ISO-8559-1' ALLOWED = (UTF_8, ISO_8559_1)
    -
    [docs]class QueryPriority(_EnumProperty): +
    [docs]class QueryPriority(_EnumProperty): """Pseudo-enum for ``QueryJob.priority`` property.""" INTERACTIVE = 'INTERACTIVE' BATCH = 'BATCH' ALLOWED = (INTERACTIVE, BATCH)
    -
    [docs]class SourceFormat(_EnumProperty): +
    [docs]class SourceFormat(_EnumProperty): """Pseudo-enum for ``source_format`` properties.""" CSV = 'CSV' DATASTORE_BACKUP = 'DATASTORE_BACKUP' @@ -170,7 +379,7 @@

    Source code for gcloud.bigquery.job

         ALLOWED = (CSV, DATASTORE_BACKUP, NEWLINE_DELIMITED_JSON)
    -
    [docs]class WriteDisposition(_EnumProperty): +
    [docs]class WriteDisposition(_EnumProperty): """Pseudo-enum for ``write_disposition`` properties.""" WRITE_APPEND = 'WRITE_APPEND' WRITE_TRUNCATE = 'WRITE_TRUNCATE' @@ -181,7 +390,7 @@

    Source code for gcloud.bigquery.job

     class _BaseJob(object):
         """Base class for jobs.
     
    -    :type client: :class:`gcloud.bigquery.client.Client`
    +    :type client: :class:`google.cloud.bigquery.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the dataset (which requires a project).
         """
    @@ -201,11 +410,12 @@ 

    Source code for gcloud.bigquery.job

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    -        :rtype: :class:`gcloud.bigquery.client.Client`
    +        :rtype: :class:`google.cloud.bigquery.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -219,7 +429,7 @@ 

    Source code for gcloud.bigquery.job

         :type name: string
         :param name: the name of the job
     
    -    :type client: :class:`gcloud.bigquery.client.Client`
    +    :type client: :class:`google.cloud.bigquery.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the dataset (which requires a project).
         """
    @@ -399,7 +609,8 @@ 

    Source code for gcloud.bigquery.job

             See:
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/insert
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
             """
    @@ -415,7 +626,8 @@ 

    Source code for gcloud.bigquery.job

             See
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/get
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    @@ -438,7 +650,8 @@ 

    Source code for gcloud.bigquery.job

             See
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/get
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
             """
    @@ -454,7 +667,8 @@ 

    Source code for gcloud.bigquery.job

             See
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/cancel
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
             """
    @@ -483,24 +697,24 @@ 

    Source code for gcloud.bigquery.job

         _write_disposition = None
     
     
    -
    [docs]class LoadTableFromStorageJob(_AsyncJob): +
    [docs]class LoadTableFromStorageJob(_AsyncJob): """Asynchronous job for loading data into a table from CloudStorage. :type name: string :param name: the name of the job - :type destination: :class:`gcloud.bigquery.table.Table` + :type destination: :class:`google.cloud.bigquery.table.Table` :param destination: Table into which data is to be loaded. :type source_uris: sequence of string :param source_uris: URIs of one or more data files to be loaded, in format ``gs://<bucket_name>/<object_name_or_glob>``. - :type client: :class:`gcloud.bigquery.client.Client` + :type client: :class:`google.cloud.bigquery.client.Client` :param client: A client which holds credentials and project configuration for the dataset (which requires a project). - :type schema: list of :class:`gcloud.bigquery.table.SchemaField` + :type schema: list of :class:`google.cloud.bigquery.table.SchemaField` :param schema: The job's schema """ @@ -695,7 +909,7 @@

    Source code for gcloud.bigquery.job

             self.schema = _parse_schema_resource(schema)
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a job given its API representation .. note: @@ -706,11 +920,11 @@

    Source code for gcloud.bigquery.job

             :type resource: dict
             :param resource: dataset job representation returned from the API
     
    -        :type client: :class:`gcloud.bigquery.client.Client`
    +        :type client: :class:`google.cloud.bigquery.client.Client`
             :param client: Client which holds credentials and project
                            configuration for the dataset.
     
    -        :rtype: :class:`gcloud.bigquery.job.LoadTableFromStorageJob`
    +        :rtype: :class:`google.cloud.bigquery.job.LoadTableFromStorageJob`
             :returns: Job parsed from ``resource``.
             """
             name, config = cls._get_resource_config(resource)
    @@ -732,19 +946,19 @@ 

    Source code for gcloud.bigquery.job

         _write_disposition = None
     
     
    -
    [docs]class CopyJob(_AsyncJob): +
    [docs]class CopyJob(_AsyncJob): """Asynchronous job: copy data into a table from other tables. :type name: string :param name: the name of the job - :type destination: :class:`gcloud.bigquery.table.Table` + :type destination: :class:`google.cloud.bigquery.table.Table` :param destination: Table into which data is to be loaded. - :type sources: list of :class:`gcloud.bigquery.table.Table` + :type sources: list of :class:`google.cloud.bigquery.table.Table` :param sources: Table into which data is to be loaded. - :type client: :class:`gcloud.bigquery.client.Client` + :type client: :class:`google.cloud.bigquery.client.Client` :param client: A client which holds credentials and project configuration for the dataset (which requires a project). """ @@ -805,7 +1019,7 @@

    Source code for gcloud.bigquery.job

             return resource
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a job given its API representation .. note: @@ -816,11 +1030,11 @@

    Source code for gcloud.bigquery.job

             :type resource: dict
             :param resource: dataset job representation returned from the API
     
    -        :type client: :class:`gcloud.bigquery.client.Client`
    +        :type client: :class:`google.cloud.bigquery.client.Client`
             :param client: Client which holds credentials and project
                            configuration for the dataset.
     
    -        :rtype: :class:`gcloud.bigquery.job.CopyJob`
    +        :rtype: :class:`google.cloud.bigquery.job.CopyJob`
             :returns: Job parsed from ``resource``.
             """
             name, config = cls._get_resource_config(resource)
    @@ -847,13 +1061,13 @@ 

    Source code for gcloud.bigquery.job

         _print_header = None
     
     
    -
    [docs]class ExtractTableToStorageJob(_AsyncJob): +
    [docs]class ExtractTableToStorageJob(_AsyncJob): """Asynchronous job: extract data from a table into Cloud Storage. :type name: string :param name: the name of the job - :type source: :class:`gcloud.bigquery.table.Table` + :type source: :class:`google.cloud.bigquery.table.Table` :param source: Table into which data is to be loaded. :type destination_uris: list of string @@ -861,7 +1075,7 @@

    Source code for gcloud.bigquery.job

                                  extracted data will be written, in format
                                  ``gs://<bucket_name>/<object_name_or_glob>``.
     
    -    :type client: :class:`gcloud.bigquery.client.Client`
    +    :type client: :class:`google.cloud.bigquery.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the dataset (which requires a project).
         """
    @@ -931,7 +1145,7 @@ 

    Source code for gcloud.bigquery.job

             return resource
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a job given its API representation .. note: @@ -942,11 +1156,11 @@

    Source code for gcloud.bigquery.job

             :type resource: dict
             :param resource: dataset job representation returned from the API
     
    -        :type client: :class:`gcloud.bigquery.client.Client`
    +        :type client: :class:`google.cloud.bigquery.client.Client`
             :param client: Client which holds credentials and project
                            configuration for the dataset.
     
    -        :rtype: :class:`gcloud.bigquery.job.ExtractTableToStorageJob`
    +        :rtype: :class:`google.cloud.bigquery.job.ExtractTableToStorageJob`
             :returns: Job parsed from ``resource``.
             """
             name, config = cls._get_resource_config(resource)
    @@ -975,7 +1189,7 @@ 

    Source code for gcloud.bigquery.job

         _write_disposition = None
     
     
    -
    [docs]class QueryJob(_AsyncJob): +
    [docs]class QueryJob(_AsyncJob): """Asynchronous job: query tables. :type name: string @@ -984,15 +1198,22 @@

    Source code for gcloud.bigquery.job

         :type query: string
         :param query: SQL query string
     
    -    :type client: :class:`gcloud.bigquery.client.Client`
    +    :type client: :class:`google.cloud.bigquery.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the dataset (which requires a project).
    +
    +    :type udf_resources: tuple
    +    :param udf_resources: An iterable of
    +                        :class:`google.cloud.bigquery.job.UDFResource`
    +                        (empty by default)
         """
         _JOB_TYPE = 'query'
    +    _UDF_KEY = 'userDefinedFunctionResources'
     
    -    def __init__(self, name, query, client):
    +    def __init__(self, name, query, client, udf_resources=()):
             super(QueryJob, self).__init__(name, client)
             self.query = query
    +        self.udf_resources = udf_resources
             self._configuration = _AsyncQueryConfiguration()
     
         allow_large_results = _TypedProperty('allow_large_results', bool)
    @@ -1025,6 +1246,8 @@ 

    Source code for gcloud.bigquery.job

         https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.priority
         """
     
    +    udf_resources = UDFResourcesProperty()
    +
         use_query_cache = _TypedProperty('use_query_cache', bool)
         """See:
         https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.useQueryCache
    @@ -1078,6 +1301,9 @@ 

    Source code for gcloud.bigquery.job

                 configuration['useLegacySql'] = self.use_legacy_sql
             if self.write_disposition is not None:
                 configuration['writeDisposition'] = self.write_disposition
    +        if len(self._udf_resources) > 0:
    +            configuration[self._UDF_KEY] = _build_udf_resources(
    +                self._udf_resources)
     
         def _build_resource(self):
             """Generate a resource for :meth:`begin`."""
    @@ -1119,17 +1345,17 @@ 

    Source code for gcloud.bigquery.job

                     self.destination = dataset.table(dest_remote['tableId'])
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a job given its API representation :type resource: dict :param resource: dataset job representation returned from the API - :type client: :class:`gcloud.bigquery.client.Client` + :type client: :class:`google.cloud.bigquery.client.Client` :param client: Client which holds credentials and project configuration for the dataset. - :rtype: :class:`gcloud.bigquery.job.RunAsyncQueryJob` + :rtype: :class:`google.cloud.bigquery.job.RunAsyncQueryJob` :returns: Job parsed from ``resource``. """ name, config = cls._get_resource_config(resource) @@ -1139,123 +1365,62 @@

    Source code for gcloud.bigquery.job

             return job
    -
    -
    +
    +
    + + +
    - -
    +
    +

    + © Copyright 2014, Google. - - - +

    +
    + Built with Sphinx using a theme provided by Read the Docs. + + + +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/query.html b/latest/_modules/google/cloud/bigquery/query.html similarity index 73% rename from latest/_modules/gcloud/bigquery/query.html rename to latest/_modules/google/cloud/bigquery/query.html index 52e05b8084a2..91ab0e0b7fde 100644 --- a/latest/_modules/gcloud/bigquery/query.html +++ b/latest/_modules/google/cloud/bigquery/query.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery.query — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigquery.query — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + -
    +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.query
    • +
    • -

      Source code for gcloud.bigquery.query

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.query

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,11 +270,13 @@ 

    Source code for gcloud.bigquery.query

     
     import six
     
    -from gcloud.bigquery._helpers import _TypedProperty
    -from gcloud.bigquery._helpers import _rows_from_json
    -from gcloud.bigquery.dataset import Dataset
    -from gcloud.bigquery.job import QueryJob
    -from gcloud.bigquery.table import _parse_schema_resource
    +from google.cloud.bigquery._helpers import _TypedProperty
    +from google.cloud.bigquery._helpers import _rows_from_json
    +from google.cloud.bigquery.dataset import Dataset
    +from google.cloud.bigquery.job import QueryJob
    +from google.cloud.bigquery.job import UDFResourcesProperty
    +from google.cloud.bigquery.job import _build_udf_resources
    +from google.cloud.bigquery.table import _parse_schema_resource
     
     
     class _SyncQueryConfiguration(object):
    @@ -136,21 +293,30 @@ 

    Source code for gcloud.bigquery.query

         _use_legacy_sql = None
     
     
    -
    [docs]class QueryResults(object): +
    [docs]class QueryResults(object): """Synchronous job: query tables. :type query: string :param query: SQL query string - :type client: :class:`gcloud.bigquery.client.Client` + :type client: :class:`google.cloud.bigquery.client.Client` :param client: A client which holds credentials and project configuration for the dataset (which requires a project). + + :type udf_resources: tuple + :param udf_resources: An iterable of + :class:`google.cloud.bigquery.job.UDFResource` + (empty by default) """ - def __init__(self, query, client): + + _UDF_KEY = 'userDefinedFunctionResources' + + def __init__(self, query, client, udf_resources=()): self._client = client self._properties = {} self.query = query self._configuration = _SyncQueryConfiguration() + self.udf_resources = udf_resources self._job = None @property @@ -165,11 +331,12 @@

    Source code for gcloud.bigquery.query

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    -        :rtype: :class:`gcloud.bigquery.client.Client`
    +        :rtype: :class:`google.cloud.bigquery.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -232,7 +399,7 @@ 

    Source code for gcloud.bigquery.query

         def job(self):
             """Job instance used to run the query.
     
    -        :rtype: :class:`gcloud.bigquery.job.QueryJob`, or ``NoneType``
    +        :rtype: :class:`google.cloud.bigquery.job.QueryJob`, or ``NoneType``
             :returns: Job instance used to run the query (None until
                       ``jobReference`` property is set by the server).
             """
    @@ -257,7 +424,7 @@ 

    Source code for gcloud.bigquery.query

     
         @property
         def total_rows(self):
    -        """Total number of rows returned by the query
    +        """Total number of rows returned by the query.
     
             See:
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#totalRows
    @@ -269,7 +436,7 @@ 

    Source code for gcloud.bigquery.query

     
         @property
         def total_bytes_processed(self):
    -        """Total number of bytes processed by the query
    +        """Total number of bytes processed by the query.
     
             See:
             https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#totalBytesProcessed
    @@ -328,6 +495,8 @@ 

    Source code for gcloud.bigquery.query

         https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#timeoutMs
         """
     
    +    udf_resources = UDFResourcesProperty()
    +
         use_query_cache = _TypedProperty('use_query_cache', bool)
         """See:
         https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#useQueryCache
    @@ -376,15 +545,19 @@ 

    Source code for gcloud.bigquery.query

             if self.dry_run is not None:
                 resource['dryRun'] = self.dry_run
     
    +        if len(self._udf_resources) > 0:
    +            resource[self._UDF_KEY] = _build_udf_resources(self._udf_resources)
    +
             return resource
     
    -
    [docs] def run(self, client=None): +
    [docs] def run(self, client=None): """API call: run the query via a POST request See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -394,7 +567,7 @@

    Source code for gcloud.bigquery.query

                 method='POST', path=path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def fetch_data(self, max_results=None, page_token=None, start_index=None, +
    [docs] def fetch_data(self, max_results=None, page_token=None, start_index=None, timeout_ms=None, client=None): """API call: fetch a page of query result data via a GET request @@ -414,7 +587,8 @@

    Source code for gcloud.bigquery.query

             :param timeout_ms: timeout, in milliseconds, to wait for query to
                                complete
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    @@ -460,123 +634,62 @@ 

    Source code for gcloud.bigquery.query

             return rows_data, total_rows, page_token
    -
    -
    +
    +
    + + +
    + +
    +

    + © Copyright 2014, Google. - -

    +

    +
    + Built with Sphinx using a theme provided by Read the Docs. - - - + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/bigquery/schema.html b/latest/_modules/google/cloud/bigquery/schema.html new file mode 100644 index 000000000000..1ed87423c82f --- /dev/null +++ b/latest/_modules/google/cloud/bigquery/schema.html @@ -0,0 +1,367 @@ + + + + + + + + + + + google.cloud.bigquery.schema — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.schema
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.schema

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Scheamas for BigQuery tables / queries."""
    +
    +
    +
    [docs]class SchemaField(object): + """Describe a single field within a table schema. + + :type name: str + :param name: the name of the field. + + :type field_type: str + :param field_type: the type of the field (one of 'STRING', 'INTEGER', + 'FLOAT', 'BOOLEAN', 'TIMESTAMP' or 'RECORD'). + + :type mode: str + :param mode: the type of the field (one of 'NULLABLE', 'REQUIRED', + or 'REPEATED'). + + :type description: str + :param description: optional description for the field. + + :type fields: list of :class:`SchemaField`, or None + :param fields: subfields (requires ``field_type`` of 'RECORD'). + """ + def __init__(self, name, field_type, mode='NULLABLE', description=None, + fields=None): + self.name = name + self.field_type = field_type + self.mode = mode + self.description = description + self.fields = fields + + def __eq__(self, other): + return ( + self.name == other.name and + self.field_type.lower() == other.field_type.lower() and + self.mode == other.mode and + self.description == other.description and + self.fields == other.fields)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigquery/table.html b/latest/_modules/google/cloud/bigquery/table.html similarity index 79% rename from latest/_modules/gcloud/bigquery/table.html rename to latest/_modules/google/cloud/bigquery/table.html index d650d39d3d27..2bbae21bea66 100644 --- a/latest/_modules/gcloud/bigquery/table.html +++ b/latest/_modules/google/cloud/bigquery/table.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigquery.table — google-cloud 92219b8 documentation + + + + + + + - - - - - gcloud.bigquery.table — gcloud 47bfd0a documentation - - - - + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + -
    + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigquery.table
    • +
    • + + -

      Source code for gcloud.bigquery.table

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigquery.table

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -119,58 +274,22 @@ 

    Source code for gcloud.bigquery.table

     
     import six
     
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud._helpers import _microseconds_from_datetime
    -from gcloud._helpers import _millis_from_datetime
    -from gcloud.exceptions import NotFound
    -from gcloud.streaming.http_wrapper import Request
    -from gcloud.streaming.http_wrapper import make_api_request
    -from gcloud.streaming.transfer import RESUMABLE_UPLOAD
    -from gcloud.streaming.transfer import Upload
    -from gcloud.bigquery._helpers import _rows_from_json
    +from google.cloud._helpers import _datetime_from_microseconds
    +from google.cloud._helpers import _microseconds_from_datetime
    +from google.cloud._helpers import _millis_from_datetime
    +from google.cloud.exceptions import NotFound
    +from google.cloud.streaming.http_wrapper import Request
    +from google.cloud.streaming.http_wrapper import make_api_request
    +from google.cloud.streaming.transfer import RESUMABLE_UPLOAD
    +from google.cloud.streaming.transfer import Upload
    +from google.cloud.bigquery.schema import SchemaField
    +from google.cloud.bigquery._helpers import _rows_from_json
     
     
     _MARKER = object()
     
     
    -
    [docs]class SchemaField(object): - """Describe a single field within a table schema. - - :type name: str - :param name: the name of the field - - :type field_type: str - :param field_type: the type of the field (one of 'STRING', 'INTEGER', - 'FLOAT', 'BOOLEAN', 'TIMESTAMP' or 'RECORD') - - :type mode: str - :param mode: the type of the field (one of 'NULLABLE', 'REQUIRED', - or 'REPEATED') - - :type description: str - :param description: optional description for the field - - :type fields: list of :class:`SchemaField`, or None - :param fields: subfields (requires ``field_type`` of 'RECORD'). - """ - def __init__(self, name, field_type, mode='NULLABLE', description=None, - fields=None): - self.name = name - self.field_type = field_type - self.mode = mode - self.description = description - self.fields = fields - - def __eq__(self, other): - return ( - self.name == other.name and - self.field_type.lower() == other.field_type.lower() and - self.mode == other.mode and - self.description == other.description and - self.fields == other.fields)
    - - -
    [docs]class Table(object): +
    [docs]class Table(object): """Tables represent a set of rows whose values correspond to a schema. See: @@ -179,7 +298,7 @@

    Source code for gcloud.bigquery.table

         :type name: str
         :param name: the name of the table
     
    -    :type dataset: :class:`gcloud.bigquery.dataset.Dataset`
    +    :type dataset: :class:`google.cloud.bigquery.dataset.Dataset`
         :param dataset: The dataset which contains the table.
     
         :type schema: list of :class:`SchemaField`
    @@ -329,6 +448,59 @@ 

    Source code for gcloud.bigquery.table

             """
             return self._properties.get('type')
     
    +    @property
    +    def partitioning_type(self):
    +        """Time partitioning of the table.
    +        :rtype: str, or ``NoneType``
    +        :returns: Returns type if the table is partitioned, None otherwise.
    +        """
    +        return self._properties.get('timePartitioning', {}).get('type')
    +
    +    @partitioning_type.setter
    +    def partitioning_type(self, value):
    +        """Update the partitioning type of the table
    +
    +        :type value: str
    +        :param value: partitioning type only "DAY" is currently supported
    +        """
    +        if value not in ('DAY', None):
    +            raise ValueError("value must be one of ['DAY', None]")
    +
    +        if value is None:
    +            self._properties.pop('timePartitioning', None)
    +        else:
    +            time_part = self._properties.setdefault('timePartitioning', {})
    +            time_part['type'] = value.upper()
    +
    +    @property
    +    def partition_expiration(self):
    +        """Expiration time in ms for a partition
    +        :rtype: int, or ``NoneType``
    +        :returns: Returns the time in ms for partition expiration
    +        """
    +        return self._properties.get('timePartitioning', {}).get('expirationMs')
    +
    +    @partition_expiration.setter
    +    def partition_expiration(self, value):
    +        """Update the experation time in ms for a partition
    +
    +        :type value: int
    +        :param value: partition experiation time in ms
    +        """
    +        if not isinstance(value, (int, type(None))):
    +            raise ValueError(
    +                "must be an integer representing millisseconds or None")
    +
    +        if value is None:
    +            if 'timePartitioning' in self._properties:
    +                self._properties['timePartitioning'].pop('expirationMs')
    +        else:
    +            try:
    +                self._properties['timePartitioning']['expirationMs'] = value
    +            except KeyError:
    +                self._properties['timePartitioning'] = {'type': 'DAY'}
    +                self._properties['timePartitioning']['expirationMs'] = value
    +
         @property
         def description(self):
             """Description of the table.
    @@ -447,17 +619,34 @@ 

    Source code for gcloud.bigquery.table

             """Delete SQL query defining the table as a view."""
             self._properties.pop('view', None)
     
    +
    [docs] def list_partitions(self, client=None): + """List the partitions in a table. + + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` + :param client: the client to use. If not passed, falls back to the + ``client`` stored on the current dataset. + + :rtype: list + :returns: a list of time partitions + """ + query = self._require_client(client).run_sync_query( + 'SELECT partition_id from [%s.%s$__PARTITIONS_SUMMARY__]' % + (self.dataset_name, self.name)) + query.run() + return [row[0] for row in query.rows]
    + @classmethod -
    [docs] def from_api_repr(cls, resource, dataset): +
    [docs] def from_api_repr(cls, resource, dataset): """Factory: construct a table given its API representation :type resource: dict :param resource: table resource representation returned from the API - :type dataset: :class:`gcloud.bigquery.dataset.Dataset` + :type dataset: :class:`google.cloud.bigquery.dataset.Dataset` :param dataset: The dataset containing the table. - :rtype: :class:`gcloud.bigquery.table.Table` + :rtype: :class:`google.cloud.bigquery.table.Table` :returns: Table parsed from ``resource``. """ if ('tableReference' not in resource or @@ -472,11 +661,12 @@

    Source code for gcloud.bigquery.table

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    -        :rtype: :class:`gcloud.bigquery.client.Client`
    +        :rtype: :class:`google.cloud.bigquery.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -522,6 +712,9 @@ 

    Source code for gcloud.bigquery.table

             if self.location is not None:
                 resource['location'] = self.location
     
    +        if self.partitioning_type is not None:
    +            resource['timePartitioning'] = self._properties['timePartitioning']
    +
             if self.view_query is not None:
                 view = resource['view'] = {}
                 view['query'] = self.view_query
    @@ -534,13 +727,14 @@ 

    Source code for gcloud.bigquery.table

     
             return resource
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the dataset via a PUT request See: https://cloud.google.com/bigquery/docs/reference/v2/tables/insert - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -551,13 +745,14 @@

    Source code for gcloud.bigquery.table

                 method='POST', path=path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the table via a GET request See https://cloud.google.com/bigquery/docs/reference/v2/tables/get - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. @@ -574,13 +769,14 @@

    Source code for gcloud.bigquery.table

             else:
                 return True
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: refresh table properties via a GET request See https://cloud.google.com/bigquery/docs/reference/v2/tables/get - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -590,7 +786,7 @@

    Source code for gcloud.bigquery.table

                 method='GET', path=self.path)
             self._set_properties(api_response)
    -
    [docs] def patch(self, +
    [docs] def patch(self, client=None, friendly_name=_MARKER, description=_MARKER, @@ -603,7 +799,8 @@

    Source code for gcloud.bigquery.table

             See
             https://cloud.google.com/bigquery/docs/reference/v2/tables/patch
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    @@ -663,13 +860,14 @@ 

    Source code for gcloud.bigquery.table

                 method='PATCH', path=self.path, data=partial)
             self._set_properties(api_response)
    -
    [docs] def update(self, client=None): +
    [docs] def update(self, client=None): """API call: update table properties via a PUT request See https://cloud.google.com/bigquery/docs/reference/v2/tables/update - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ @@ -678,20 +876,21 @@

    Source code for gcloud.bigquery.table

                 method='PUT', path=self.path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete the table via a DELETE request See: https://cloud.google.com/bigquery/docs/reference/v2/tables/delete - :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.bigquery.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current dataset. """ client = self._require_client(client) client.connection.api_request(method='DELETE', path=self.path)
    -
    [docs] def fetch_data(self, max_results=None, page_token=None, client=None): +
    [docs] def fetch_data(self, max_results=None, page_token=None, client=None): """API call: fetch the table data via a GET request See: @@ -711,7 +910,8 @@

    Source code for gcloud.bigquery.table

             :type page_token: str or ``NoneType``
             :param page_token: token representing a cursor into the table's rows.
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    @@ -743,7 +943,7 @@ 

    Source code for gcloud.bigquery.table

     
             return rows_data, total_rows, page_token
    -
    [docs] def insert_data(self, +
    [docs] def insert_data(self, rows, row_ids=None, skip_invalid_rows=None, @@ -777,7 +977,8 @@

    Source code for gcloud.bigquery.table

                                     schema of the template table. See:
                                     https://cloud.google.com/bigquery/streaming-data-into-bigquery#template-tables
     
    -        :type client: :class:`gcloud.bigquery.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.bigquery.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current dataset.
     
    @@ -830,7 +1031,7 @@ 

    Source code for gcloud.bigquery.table

             return errors
    # pylint: disable=too-many-arguments,too-many-locals -
    [docs] def upload_from_file(self, +
    [docs] def upload_from_file(self, file_obj, source_format, rewind=False, @@ -859,7 +1060,7 @@

    Source code for gcloud.bigquery.table

             :type source_format: str
             :param source_format: one of 'CSV' or 'NEWLINE_DELIMITED_JSON'.
                                   job configuration option; see
    -                              :meth:`gcloud.bigquery.job.LoadJob`
    +                              :meth:`google.cloud.bigquery.job.LoadJob`
     
             :type rewind: boolean
             :param rewind: If True, seek to the beginning of the file handle before
    @@ -876,51 +1077,52 @@ 

    Source code for gcloud.bigquery.table

     
             :type allow_jagged_rows: boolean
             :param allow_jagged_rows: job configuration option;  see
    -                                  :meth:`gcloud.bigquery.job.LoadJob`
    +                                  :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type allow_quoted_newlines: boolean
             :param allow_quoted_newlines: job configuration option; see
    -                                      :meth:`gcloud.bigquery.job.LoadJob`
    +                                      :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type create_disposition: str
             :param create_disposition: job configuration option; see
    -                                   :meth:`gcloud.bigquery.job.LoadJob`
    +                                   :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type encoding: str
             :param encoding: job configuration option; see
    -                         :meth:`gcloud.bigquery.job.LoadJob`
    +                         :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type field_delimiter: str
             :param field_delimiter: job configuration option; see
    -                                :meth:`gcloud.bigquery.job.LoadJob`
    +                                :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type ignore_unknown_values: boolean
             :param ignore_unknown_values: job configuration option; see
    -                                      :meth:`gcloud.bigquery.job.LoadJob`
    +                                      :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type max_bad_records: integer
             :param max_bad_records: job configuration option; see
    -                                :meth:`gcloud.bigquery.job.LoadJob`
    +                                :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type quote_character: str
             :param quote_character: job configuration option; see
    -                                :meth:`gcloud.bigquery.job.LoadJob`
    +                                :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type skip_leading_rows: integer
             :param skip_leading_rows: job configuration option; see
    -                                  :meth:`gcloud.bigquery.job.LoadJob`
    +                                  :meth:`google.cloud.bigquery.job.LoadJob`.
     
             :type write_disposition: str
             :param write_disposition: job configuration option; see
    -                                  :meth:`gcloud.bigquery.job.LoadJob`
    +                                  :meth:`google.cloud.bigquery.job.LoadJob`.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current dataset.
     
    -        :rtype: :class:`gcloud.bigquery.jobs.LoadTableFromStorageJob`
    +        :rtype: :class:`google.cloud.bigquery.jobs.LoadTableFromStorageJob`
             :returns: the job instance used to load the data (e.g., for
    -                  querying status)
    +                  querying status).
             :raises: :class:`ValueError` if ``size`` is not passed in and can not
                      be determined, or if the ``file_obj`` can be detected to be
                      a file opened in text mode.
    @@ -1122,123 +1324,62 @@ 

    Source code for gcloud.bigquery.table

             self._relative_path = ''
     
    -
    -
    + + + + + + + + + + + - - + + + + + + + + - - - - + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/bigtable/client.html b/latest/_modules/google/cloud/bigtable/client.html new file mode 100644 index 000000000000..028919c77aac --- /dev/null +++ b/latest/_modules/google/cloud/bigtable/client.html @@ -0,0 +1,651 @@ + + + + + + + + + + + google.cloud.bigtable.client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.client
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.client

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Parent client for calling the Google Cloud Bigtable API.
    +
    +This is the base from which all interactions with the API occur.
    +
    +In the hierarchy of API concepts
    +
    +* a :class:`Client` owns an :class:`.Instance`
    +* a :class:`.Instance` owns a :class:`~google.cloud.bigtable.table.Table`
    +* a :class:`~google.cloud.bigtable.table.Table` owns a
    +  :class:`~.column_family.ColumnFamily`
    +* a :class:`~google.cloud.bigtable.table.Table` owns a :class:`~.row.Row`
    +  (and all the cells in the row)
    +"""
    +
    +
    +from pkg_resources import get_distribution
    +
    +from google.cloud._helpers import make_secure_stub
    +from google.cloud.bigtable._generated import bigtable_instance_admin_pb2
    +from google.cloud.bigtable._generated import bigtable_pb2
    +from google.cloud.bigtable._generated import bigtable_table_admin_pb2
    +from google.cloud.bigtable._generated import operations_grpc_pb2
    +from google.cloud.bigtable.cluster import DEFAULT_SERVE_NODES
    +from google.cloud.bigtable.instance import Instance
    +from google.cloud.bigtable.instance import _EXISTING_INSTANCE_LOCATION_ID
    +from google.cloud.client import _ClientFactoryMixin
    +from google.cloud.client import _ClientProjectMixin
    +from google.cloud.credentials import get_credentials
    +
    +
    +TABLE_ADMIN_HOST = 'bigtableadmin.googleapis.com'
    +"""Table Admin API request host."""
    +
    +INSTANCE_ADMIN_HOST = 'bigtableadmin.googleapis.com'
    +"""Cluster Admin API request host."""
    +
    +DATA_API_HOST = 'bigtable.googleapis.com'
    +"""Data API request host."""
    +
    +OPERATIONS_API_HOST = INSTANCE_ADMIN_HOST
    +
    +ADMIN_SCOPE = 'https://www.googleapis.com/auth/bigtable.admin'
    +"""Scope for interacting with the Cluster Admin and Table Admin APIs."""
    +DATA_SCOPE = 'https://www.googleapis.com/auth/bigtable.data'
    +"""Scope for reading and writing table data."""
    +READ_ONLY_SCOPE = 'https://www.googleapis.com/auth/bigtable.data.readonly'
    +"""Scope for reading table data."""
    +
    +DEFAULT_USER_AGENT = 'google-cloud-python/{0}'.format(
    +    get_distribution('google-cloud').version)
    +"""The default user agent for API requests."""
    +
    +
    +def _make_data_stub(client):
    +    """Creates gRPC stub to make requests to the Data API.
    +
    +    :type client: :class:`Client`
    +    :param client: The client that will hold the stub.
    +
    +    :rtype: :class:`._generated.bigtable_pb2.BigtableStub`
    +    :returns: A gRPC stub object.
    +    """
    +    return make_secure_stub(client.credentials, client.user_agent,
    +                            bigtable_pb2.BigtableStub, DATA_API_HOST)
    +
    +
    +def _make_instance_stub(client):
    +    """Creates gRPC stub to make requests to the Instance Admin API.
    +
    +    :type client: :class:`Client`
    +    :param client: The client that will hold the stub.
    +
    +    :rtype: :class:`.bigtable_instance_admin_pb2.BigtableInstanceAdminStub`
    +    :returns: A gRPC stub object.
    +    """
    +    return make_secure_stub(
    +        client.credentials, client.user_agent,
    +        bigtable_instance_admin_pb2.BigtableInstanceAdminStub,
    +        INSTANCE_ADMIN_HOST)
    +
    +
    +def _make_operations_stub(client):
    +    """Creates gRPC stub to make requests to the Operations API.
    +
    +    These are for long-running operations of the Instance Admin API,
    +    hence the host and port matching.
    +
    +    :type client: :class:`Client`
    +    :param client: The client that will hold the stub.
    +
    +    :rtype: :class:`._generated.operations_grpc_pb2.OperationsStub`
    +    :returns: A gRPC stub object.
    +    """
    +    return make_secure_stub(client.credentials, client.user_agent,
    +                            operations_grpc_pb2.OperationsStub,
    +                            OPERATIONS_API_HOST)
    +
    +
    +def _make_table_stub(client):
    +    """Creates gRPC stub to make requests to the Table Admin API.
    +
    +    :type client: :class:`Client`
    +    :param client: The client that will hold the stub.
    +
    +    :rtype: :class:`.bigtable_instance_admin_pb2.BigtableTableAdminStub`
    +    :returns: A gRPC stub object.
    +    """
    +    return make_secure_stub(client.credentials, client.user_agent,
    +                            bigtable_table_admin_pb2.BigtableTableAdminStub,
    +                            TABLE_ADMIN_HOST)
    +
    +
    +
    [docs]class Client(_ClientFactoryMixin, _ClientProjectMixin): + """Client for interacting with Google Cloud Bigtable API. + + .. note:: + + Since the Cloud Bigtable API requires the gRPC transport, no + ``http`` argument is accepted by this class. + + :type project: :class:`str` or :func:`unicode <unicode>` + :param project: (Optional) The ID of the project which owns the + instances, tables and data. If not provided, will + attempt to determine from the environment. + + :type credentials: + :class:`OAuth2Credentials <oauth2client.client.OAuth2Credentials>` or + :data:`NoneType <types.NoneType>` + :param credentials: (Optional) The OAuth2 Credentials to use for this + client. If not provided, defaults to the Google + Application Default Credentials. + + :type read_only: bool + :param read_only: (Optional) Boolean indicating if the data scope should be + for reading only (or for writing as well). Defaults to + :data:`False`. + + :type admin: bool + :param admin: (Optional) Boolean indicating if the client will be used to + interact with the Instance Admin or Table Admin APIs. This + requires the :const:`ADMIN_SCOPE`. Defaults to :data:`False`. + + :type user_agent: str + :param user_agent: (Optional) The user agent to be used with API request. + Defaults to :const:`DEFAULT_USER_AGENT`. + + :raises: :class:`ValueError <exceptions.ValueError>` if both ``read_only`` + and ``admin`` are :data:`True` + """ + + _instance_stub_internal = None + _operations_stub_internal = None + _table_stub_internal = None + + def __init__(self, project=None, credentials=None, + read_only=False, admin=False, user_agent=DEFAULT_USER_AGENT): + _ClientProjectMixin.__init__(self, project=project) + if credentials is None: + credentials = get_credentials() + + if read_only and admin: + raise ValueError('A read-only client cannot also perform' + 'administrative actions.') + + scopes = [] + if read_only: + scopes.append(READ_ONLY_SCOPE) + else: + scopes.append(DATA_SCOPE) + + if admin: + scopes.append(ADMIN_SCOPE) + + self._admin = bool(admin) + try: + credentials = credentials.create_scoped(scopes) + except AttributeError: + pass + self._credentials = credentials + self.user_agent = user_agent + + # Create gRPC stubs for making requests. + self._data_stub = _make_data_stub(self) + if self._admin: + self._instance_stub_internal = _make_instance_stub(self) + self._operations_stub_internal = _make_operations_stub(self) + self._table_stub_internal = _make_table_stub(self) + +
    [docs] def copy(self): + """Make a copy of this client. + + Copies the local data stored as simple types but does not copy the + current state of any open connections with the Cloud Bigtable API. + + :rtype: :class:`.Client` + :returns: A copy of the current client. + """ + credentials = self._credentials + copied_creds = credentials.create_scoped(credentials.scopes) + return self.__class__( + self.project, + copied_creds, + READ_ONLY_SCOPE in copied_creds.scopes, + self._admin, + self.user_agent, + )
    + + @property + def credentials(self): + """Getter for client's credentials. + + :rtype: + :class:`OAuth2Credentials <oauth2client.client.OAuth2Credentials>` + :returns: The credentials stored on the client. + """ + return self._credentials + + @property + def project_name(self): + """Project name to be used with Instance Admin API. + + .. note:: + + This property will not change if ``project`` does not, but the + return value is not cached. + + The project name is of the form + + ``"projects/{project}"`` + + :rtype: str + :returns: The project name to be used with the Cloud Bigtable Admin + API RPC service. + """ + return 'projects/' + self.project + + @property + def _instance_stub(self): + """Getter for the gRPC stub used for the Instance Admin API. + + :rtype: :class:`.bigtable_instance_admin_pb2.BigtableInstanceAdminStub` + :returns: A gRPC stub object. + :raises: :class:`ValueError <exceptions.ValueError>` if the current + client is not an admin client or if it has not been + :meth:`start`-ed. + """ + if not self._admin: + raise ValueError('Client is not an admin client.') + return self._instance_stub_internal + + @property + def _operations_stub(self): + """Getter for the gRPC stub used for the Operations API. + + :rtype: :class:`._generated.operations_grpc_pb2.OperationsStub` + :returns: A gRPC stub object. + :raises: :class:`ValueError <exceptions.ValueError>` if the current + client is not an admin client or if it has not been + :meth:`start`-ed. + """ + if not self._admin: + raise ValueError('Client is not an admin client.') + return self._operations_stub_internal + + @property + def _table_stub(self): + """Getter for the gRPC stub used for the Table Admin API. + + :rtype: :class:`.bigtable_instance_admin_pb2.BigtableTableAdminStub` + :returns: A gRPC stub object. + :raises: :class:`ValueError <exceptions.ValueError>` if the current + client is not an admin client or if it has not been + :meth:`start`-ed. + """ + if not self._admin: + raise ValueError('Client is not an admin client.') + return self._table_stub_internal + +
    [docs] def instance(self, instance_id, location=_EXISTING_INSTANCE_LOCATION_ID, + display_name=None, serve_nodes=DEFAULT_SERVE_NODES): + """Factory to create a instance associated with this client. + + :type instance_id: str + :param instance_id: The ID of the instance. + + :type location: string + :param location: location name, in form + ``projects/<project>/locations/<location>``; used to + set up the instance's cluster. + + :type display_name: str + :param display_name: (Optional) The display name for the instance in + the Cloud Console UI. (Must be between 4 and 30 + characters.) If this value is not set in the + constructor, will fall back to the instance ID. + + :type serve_nodes: int + :param serve_nodes: (Optional) The number of nodes in the instance's + cluster; used to set up the instance's cluster. + + :rtype: :class:`.Instance` + :returns: an instance owned by this client. + """ + return Instance(instance_id, self, location, + display_name=display_name, serve_nodes=serve_nodes)
    + +
    [docs] def list_instances(self): + """List instances owned by the project. + + :rtype: tuple + :returns: A pair of results, the first is a list of + :class:`.Instance` objects returned and the second is a + list of strings (the failed locations in the request). + """ + request_pb = bigtable_instance_admin_pb2.ListInstancesRequest( + parent=self.project_name) + + response = self._instance_stub.ListInstances(request_pb) + + instances = [Instance.from_pb(instance_pb, self) + for instance_pb in response.instances] + return instances, response.failed_locations
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/cluster.html b/latest/_modules/google/cloud/bigtable/cluster.html similarity index 51% rename from latest/_modules/gcloud/bigtable/cluster.html rename to latest/_modules/google/cloud/bigtable/cluster.html index da46fb72ff64..01457e18d07d 100644 --- a/latest/_modules/gcloud/bigtable/cluster.html +++ b/latest/_modules/google/cloud/bigtable/cluster.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.cluster — google-cloud 92219b8 documentation + + + + + + + - - - - - gcloud.bigtable.cluster — gcloud 47bfd0a documentation - - - - + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.cluster
    • +
    • -

      Source code for gcloud.bigtable.cluster

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.cluster

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -116,29 +271,29 @@ 

    Source code for gcloud.bigtable.cluster

     
     import re
     
    -from google.longrunning import operations_pb2
    -
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         instance_pb2 as data_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         bigtable_instance_admin_pb2 as messages_v2_pb2)
    +from google.cloud.operation import Operation
    +from google.cloud.operation import _compute_type_url
    +from google.cloud.operation import _register_type_url
     
     
     _CLUSTER_NAME_RE = re.compile(r'^projects/(?P<project>[^/]+)/'
                                   r'instances/(?P<instance>[^/]+)/clusters/'
                                   r'(?P<cluster_id>[a-z][-a-z0-9]*)$')
    -_OPERATION_NAME_RE = re.compile(r'^operations/'
    -                                r'projects/([^/]+)/'
    -                                r'instances/([^/]+)/'
    -                                r'clusters/([a-z][-a-z0-9]*)/'
    -                                r'operations/(?P<operation_id>\d+)$')
    -_TYPE_URL_MAP = {
    -}
     
     DEFAULT_SERVE_NODES = 3
     """Default number of nodes to use when creating a cluster."""
     
     
    +_UPDATE_CLUSTER_METADATA_URL = _compute_type_url(
    +    messages_v2_pb2.UpdateClusterMetadata)
    +_register_type_url(
    +    _UPDATE_CLUSTER_METADATA_URL, messages_v2_pb2.UpdateClusterMetadata)
    +
    +
     def _prepare_create_request(cluster):
         """Creates a protobuf request for a CreateCluster request.
     
    @@ -157,111 +312,7 @@ 

    Source code for gcloud.bigtable.cluster

         )
     
     
    -def _parse_pb_any_to_native(any_val, expected_type=None):
    -    """Convert a serialized "google.protobuf.Any" value to actual type.
    -
    -    :type any_val: :class:`google.protobuf.any_pb2.Any`
    -    :param any_val: A serialized protobuf value container.
    -
    -    :type expected_type: str
    -    :param expected_type: (Optional) The type URL we expect ``any_val``
    -                          to have.
    -
    -    :rtype: object
    -    :returns: The de-serialized object.
    -    :raises: :class:`ValueError <exceptions.ValueError>` if the
    -             ``expected_type`` does not match the ``type_url`` on the input.
    -    """
    -    if expected_type is not None and expected_type != any_val.type_url:
    -        raise ValueError('Expected type: %s, Received: %s' % (
    -            expected_type, any_val.type_url))
    -    container_class = _TYPE_URL_MAP[any_val.type_url]
    -    return container_class.FromString(any_val.value)
    -
    -
    -def _process_operation(operation_pb):
    -    """Processes a create protobuf response.
    -
    -    :type operation_pb: :class:`google.longrunning.operations_pb2.Operation`
    -    :param operation_pb: The long-running operation response from a
    -                         Create/Update/Undelete cluster request.
    -
    -    :rtype: tuple
    -    :returns: integer ID of the operation (``operation_id``).
    -    :raises: :class:`ValueError <exceptions.ValueError>` if the operation name
    -             doesn't match the :data:`_OPERATION_NAME_RE` regex.
    -    """
    -    match = _OPERATION_NAME_RE.match(operation_pb.name)
    -    if match is None:
    -        raise ValueError('Operation name was not in the expected '
    -                         'format after a cluster modification.',
    -                         operation_pb.name)
    -    operation_id = int(match.group('operation_id'))
    -
    -    return operation_id
    -
    -
    -
    [docs]class Operation(object): - """Representation of a Google API Long-Running Operation. - - In particular, these will be the result of operations on - clusters using the Cloud Bigtable API. - - :type op_type: str - :param op_type: The type of operation being performed. Expect - ``create``, ``update`` or ``undelete``. - - :type op_id: int - :param op_id: The ID of the operation. - - :type cluster: :class:`Cluster` - :param cluster: The cluster that created the operation. - """ - - def __init__(self, op_type, op_id, cluster=None): - self.op_type = op_type - self.op_id = op_id - self._cluster = cluster - self._complete = False - - def __eq__(self, other): - if not isinstance(other, self.__class__): - return False - return (other.op_type == self.op_type and - other.op_id == self.op_id and - other._cluster == self._cluster and - other._complete == self._complete) - - def __ne__(self, other): - return not self.__eq__(other) - -
    [docs] def finished(self): - """Check if the operation has finished. - - :rtype: bool - :returns: A boolean indicating if the current operation has completed. - :raises: :class:`ValueError <exceptions.ValueError>` if the operation - has already completed. - """ - if self._complete: - raise ValueError('The operation has completed.') - - operation_name = ('operations/' + self._cluster.name + - '/operations/%d' % (self.op_id,)) - request_pb = operations_pb2.GetOperationRequest(name=operation_name) - # We expect a `google.longrunning.operations_pb2.Operation`. - client = self._cluster._instance._client - operation_pb = client._operations_stub.GetOperation( - request_pb, client.timeout_seconds) - - if operation_pb.done: - self._complete = True - return True - else: - return False
    - - -
    [docs]class Cluster(object): +
    [docs]class Cluster(object): """Representation of a Google Cloud Bigtable Cluster. We can use a :class:`Cluster` to: @@ -270,7 +321,6 @@

    Source code for gcloud.bigtable.cluster

         * :meth:`create` itself
         * :meth:`update` itself
         * :meth:`delete` itself
    -    * :meth:`undelete` itself
     
         .. note::
     
    @@ -306,7 +356,7 @@ 

    Source code for gcloud.bigtable.cluster

             self.location = cluster_pb.location
     
         @classmethod
    -
    [docs] def from_pb(cls, cluster_pb, instance): +
    [docs] def from_pb(cls, cluster_pb, instance): """Creates a cluster instance from a protobuf. :type cluster_pb: :class:`instance_pb2.Cluster` @@ -339,7 +389,7 @@

    Source code for gcloud.bigtable.cluster

             result._update_from_pb(cluster_pb)
             return result
    -
    [docs] def copy(self): +
    [docs] def copy(self): """Make a copy of this cluster. Copies the local data stored as simple types and copies the client @@ -384,18 +434,18 @@

    Source code for gcloud.bigtable.cluster

         def __ne__(self, other):
             return not self.__eq__(other)
     
    -
    [docs] def reload(self): +
    [docs] def reload(self): """Reload the metadata for this cluster.""" request_pb = messages_v2_pb2.GetClusterRequest(name=self.name) - # We expect a `._generated_v2.instance_pb2.Cluster`. + # We expect a `._generated.instance_pb2.Cluster`. cluster_pb = self._instance._client._instance_stub.GetCluster( - request_pb, self._instance._client.timeout_seconds) + request_pb) # NOTE: _update_from_pb does not check that the project, instance and # cluster ID on the response match the request. self._update_from_pb(cluster_pb)
    -
    [docs] def create(self): +
    [docs] def create(self): """Create this cluster. .. note:: @@ -417,13 +467,15 @@

    Source code for gcloud.bigtable.cluster

             """
             request_pb = _prepare_create_request(self)
             # We expect a `google.longrunning.operations_pb2.Operation`.
    -        operation_pb = self._instance._client._instance_stub.CreateCluster(
    -            request_pb, self._instance._client.timeout_seconds)
    +        client = self._instance._client
    +        operation_pb = client._instance_stub.CreateCluster(request_pb)
     
    -        op_id = _process_operation(operation_pb)
    -        return Operation('create', op_id, cluster=self)
    + operation = Operation.from_pb(operation_pb, client) + operation.target = self + operation.metadata['request_type'] = 'CreateCluster' + return operation
    -
    [docs] def update(self): +
    [docs] def update(self): """Update this cluster. .. note:: @@ -445,14 +497,16 @@

    Source code for gcloud.bigtable.cluster

                 name=self.name,
                 serve_nodes=self.serve_nodes,
             )
    -        # Ignore expected `._generated_v2.instance_pb2.Cluster`.
    -        operation_pb = self._instance._client._instance_stub.UpdateCluster(
    -            request_pb, self._instance._client.timeout_seconds)
    +        # We expect a `google.longrunning.operations_pb2.Operation`.
    +        client = self._instance._client
    +        operation_pb = client._instance_stub.UpdateCluster(request_pb)
     
    -        op_id = _process_operation(operation_pb)
    -        return Operation('update', op_id, cluster=self)
    + operation = Operation.from_pb(operation_pb, client) + operation.target = self + operation.metadata['request_type'] = 'UpdateCluster' + return operation
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Delete this cluster. Marks a cluster and all of its tables for permanent deletion in 7 days. @@ -466,11 +520,6 @@

    Source code for gcloud.bigtable.cluster

     
             * All tables within the cluster will become unavailable.
     
    -        Prior to the cluster's ``delete_time``:
    -
    -        * The cluster can be recovered with a call to ``UndeleteCluster``.
    -        * All other attempts to modify or delete the cluster will be rejected.
    -
             At the cluster's ``delete_time``:
     
             * The cluster and **all of its tables** will immediately and
    @@ -479,127 +528,65 @@ 

    Source code for gcloud.bigtable.cluster

             """
             request_pb = messages_v2_pb2.DeleteClusterRequest(name=self.name)
             # We expect a `google.protobuf.empty_pb2.Empty`
    -        self._instance._client._instance_stub.DeleteCluster(
    -            request_pb, self._instance._client.timeout_seconds)
    + self._instance._client._instance_stub.DeleteCluster(request_pb)
    -
    -
    +
    + + +
    + + + + + + + - - + + + + + + + + - - - - + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/column_family.html b/latest/_modules/google/cloud/bigtable/column_family.html similarity index 73% rename from latest/_modules/gcloud/bigtable/column_family.html rename to latest/_modules/google/cloud/bigtable/column_family.html index d9f159abd973..a1b69994ebec 100644 --- a/latest/_modules/gcloud/bigtable/column_family.html +++ b/latest/_modules/google/cloud/bigtable/column_family.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.column_family — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigtable.column_family — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.column_family
    • +
    • -

      Source code for gcloud.bigtable.column_family

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.column_family

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -118,10 +273,9 @@ 

    Source code for gcloud.bigtable.column_family

    from google.protobuf import duration_pb2 -from gcloud._helpers import _total_seconds -from gcloud.bigtable._generated_v2 import ( +from google.cloud.bigtable._generated import ( table_pb2 as table_v2_pb2) -from gcloud.bigtable._generated_v2 import ( +from google.cloud.bigtable._generated import ( bigtable_table_admin_pb2 as table_admin_v2_pb2) @@ -139,7 +293,7 @@

    Source code for gcloud.bigtable.column_family

    :rtype: :class:`google.protobuf.duration_pb2.Duration` :returns: A duration object equivalent to the time delta. """ - seconds_decimal = _total_seconds(timedelta_val) + seconds_decimal = timedelta_val.total_seconds() # Truncate the parts other than the integer. seconds = int(seconds_decimal) if seconds_decimal < 0: @@ -171,7 +325,7 @@

    Source code for gcloud.bigtable.column_family

    ) -
    [docs]class GarbageCollectionRule(object): +
    [docs]class GarbageCollectionRule(object): """Garbage collection rule for column families within a table. Cells in the column family (within a table) fitting the rule will be @@ -192,7 +346,7 @@

    Source code for gcloud.bigtable.column_family

    return not self.__eq__(other)
    -
    [docs]class MaxVersionsGCRule(GarbageCollectionRule): +
    [docs]class MaxVersionsGCRule(GarbageCollectionRule): """Garbage collection limiting the number of versions of a cell. :type max_num_versions: int @@ -207,7 +361,7 @@

    Source code for gcloud.bigtable.column_family

    return False return other.max_num_versions == self.max_num_versions -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the garbage collection rule to a protobuf. :rtype: :class:`.table_v2_pb2.GcRule` @@ -216,7 +370,7 @@

    Source code for gcloud.bigtable.column_family

    return table_v2_pb2.GcRule(max_num_versions=self.max_num_versions)
    -
    [docs]class MaxAgeGCRule(GarbageCollectionRule): +
    [docs]class MaxAgeGCRule(GarbageCollectionRule): """Garbage collection limiting the age of a cell. :type max_age: :class:`datetime.timedelta` @@ -231,7 +385,7 @@

    Source code for gcloud.bigtable.column_family

    return False return other.max_age == self.max_age -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the garbage collection rule to a protobuf. :rtype: :class:`.table_v2_pb2.GcRule` @@ -241,7 +395,7 @@

    Source code for gcloud.bigtable.column_family

    return table_v2_pb2.GcRule(max_age=max_age)
    -
    [docs]class GCRuleUnion(GarbageCollectionRule): +
    [docs]class GCRuleUnion(GarbageCollectionRule): """Union of garbage collection rules. :type rules: list @@ -256,7 +410,7 @@

    Source code for gcloud.bigtable.column_family

    return False return other.rules == self.rules -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the union into a single GC rule as a protobuf. :rtype: :class:`.table_v2_pb2.GcRule` @@ -267,7 +421,7 @@

    Source code for gcloud.bigtable.column_family

    return table_v2_pb2.GcRule(union=union)
    -
    [docs]class GCRuleIntersection(GarbageCollectionRule): +
    [docs]class GCRuleIntersection(GarbageCollectionRule): """Intersection of garbage collection rules. :type rules: list @@ -282,7 +436,7 @@

    Source code for gcloud.bigtable.column_family

    return False return other.rules == self.rules -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the intersection into a single GC rule as a protobuf. :rtype: :class:`.table_v2_pb2.GcRule` @@ -293,7 +447,7 @@

    Source code for gcloud.bigtable.column_family

    return table_v2_pb2.GcRule(intersection=intersection)
    -
    [docs]class ColumnFamily(object): +
    [docs]class ColumnFamily(object): """Representation of a Google Cloud Bigtable Column Family. We can use a :class:`ColumnFamily` to: @@ -306,7 +460,7 @@

    Source code for gcloud.bigtable.column_family

    :param column_family_id: The ID of the column family. Must be of the form ``[_a-zA-Z0-9][-_.a-zA-Z0-9]*``. - :type table: :class:`Table <gcloud.bigtable.table.Table>` + :type table: :class:`Table <google.cloud.bigtable.table.Table>` :param table: The table that owns the column family. :type gc_rule: :class:`GarbageCollectionRule` @@ -347,7 +501,7 @@

    Source code for gcloud.bigtable.column_family

    def __ne__(self, other): return not self.__eq__(other) -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the column family to a protobuf. :rtype: :class:`.table_v2_pb2.ColumnFamily` @@ -358,7 +512,7 @@

    Source code for gcloud.bigtable.column_family

    else: return table_v2_pb2.ColumnFamily(gc_rule=self.gc_rule.to_pb())
    -
    [docs] def create(self): +
    [docs] def create(self): """Create this column family.""" column_family = self.to_pb() request_pb = table_admin_v2_pb2.ModifyColumnFamiliesRequest( @@ -371,10 +525,9 @@

    Source code for gcloud.bigtable.column_family

    # We expect a `.table_v2_pb2.ColumnFamily`. We ignore it since the only # data it contains are the GC rule and the column family ID already # stored on this instance. - client._table_stub.ModifyColumnFamilies(request_pb, - client.timeout_seconds)
    + client._table_stub.ModifyColumnFamilies(request_pb)
    -
    [docs] def update(self): +
    [docs] def update(self): """Update this column family. .. note:: @@ -392,10 +545,9 @@

    Source code for gcloud.bigtable.column_family

    # We expect a `.table_v2_pb2.ColumnFamily`. We ignore it since the only # data it contains are the GC rule and the column family ID already # stored on this instance. - client._table_stub.ModifyColumnFamilies(request_pb, - client.timeout_seconds)
    + client._table_stub.ModifyColumnFamilies(request_pb)
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Delete this column family.""" request_pb = table_admin_v2_pb2.ModifyColumnFamiliesRequest( name=self._table.name) @@ -404,8 +556,7 @@

    Source code for gcloud.bigtable.column_family

    drop=True) client = self._table._instance._client # We expect a `google.protobuf.empty_pb2.Empty` - client._table_stub.ModifyColumnFamilies(request_pb, - client.timeout_seconds)
    + client._table_stub.ModifyColumnFamilies(request_pb)
    def _gc_rule_from_pb(gc_rule_pb): @@ -441,123 +592,62 @@

    Source code for gcloud.bigtable.column_family

    raise ValueError('Unexpected rule name', rule_name)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/instance.html b/latest/_modules/google/cloud/bigtable/instance.html similarity index 54% rename from latest/_modules/gcloud/bigtable/instance.html rename to latest/_modules/google/cloud/bigtable/instance.html index a6c7001cff79..48aba8864588 100644 --- a/latest/_modules/gcloud/bigtable/instance.html +++ b/latest/_modules/google/cloud/bigtable/instance.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.instance — google-cloud 92219b8 documentation + + + + + + + - - - - - gcloud.bigtable.instance — gcloud 47bfd0a documentation - - - - + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + -
    + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.instance
    • +
    • + + -

      Source code for gcloud.bigtable.instance

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.instance

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -116,33 +271,29 @@ 

    Source code for gcloud.bigtable.instance

     
     import re
     
    -from google.longrunning import operations_pb2
    -
    -from gcloud._helpers import _pb_timestamp_to_datetime
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         instance_pb2 as data_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         bigtable_instance_admin_pb2 as messages_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         bigtable_table_admin_pb2 as table_messages_v2_pb2)
    -from gcloud.bigtable.cluster import Cluster
    -from gcloud.bigtable.cluster import DEFAULT_SERVE_NODES
    -from gcloud.bigtable.table import Table
    +from google.cloud.bigtable.cluster import Cluster
    +from google.cloud.bigtable.cluster import DEFAULT_SERVE_NODES
    +from google.cloud.bigtable.table import Table
    +from google.cloud.operation import Operation
    +from google.cloud.operation import _compute_type_url
    +from google.cloud.operation import _register_type_url
     
     
     _EXISTING_INSTANCE_LOCATION_ID = 'see-existing-cluster'
     _INSTANCE_NAME_RE = re.compile(r'^projects/(?P<project>[^/]+)/'
                                    r'instances/(?P<instance_id>[a-z][-a-z0-9]*)$')
    -_OPERATION_NAME_RE = re.compile(r'^operations/projects/([^/]+)/'
    -                                r'instances/([a-z][-a-z0-9]*)/'
    -                                r'locations/(?P<location_id>[a-z][-a-z0-9]*)/'
    -                                r'operations/(?P<operation_id>\d+)$')
    -_TYPE_URL_BASE = 'type.googleapis.com/google.bigtable.'
    -_ADMIN_TYPE_URL_BASE = _TYPE_URL_BASE + 'admin.v2.'
    -_INSTANCE_CREATE_METADATA = _ADMIN_TYPE_URL_BASE + 'CreateInstanceMetadata'
    -_TYPE_URL_MAP = {
    -    _INSTANCE_CREATE_METADATA: messages_v2_pb2.CreateInstanceMetadata,
    -}
    +
    +
    +_CREATE_INSTANCE_METADATA_URL = _compute_type_url(
    +    messages_v2_pb2.CreateInstanceMetadata)
    +_register_type_url(
    +    _CREATE_INSTANCE_METADATA_URL, messages_v2_pb2.CreateInstanceMetadata)
     
     
     def _prepare_create_request(instance):
    @@ -170,126 +321,7 @@ 

    Source code for gcloud.bigtable.instance

         return message
     
     
    -def _parse_pb_any_to_native(any_val, expected_type=None):
    -    """Convert a serialized "google.protobuf.Any" value to actual type.
    -
    -    :type any_val: :class:`google.protobuf.any_pb2.Any`
    -    :param any_val: A serialized protobuf value container.
    -
    -    :type expected_type: str
    -    :param expected_type: (Optional) The type URL we expect ``any_val``
    -                          to have.
    -
    -    :rtype: object
    -    :returns: The de-serialized object.
    -    :raises: :class:`ValueError <exceptions.ValueError>` if the
    -             ``expected_type`` does not match the ``type_url`` on the input.
    -    """
    -    if expected_type is not None and expected_type != any_val.type_url:
    -        raise ValueError('Expected type: %s, Received: %s' % (
    -            expected_type, any_val.type_url))
    -    container_class = _TYPE_URL_MAP[any_val.type_url]
    -    return container_class.FromString(any_val.value)
    -
    -
    -def _process_operation(operation_pb):
    -    """Processes a create protobuf response.
    -
    -    :type operation_pb: :class:`google.longrunning.operations_pb2.Operation`
    -    :param operation_pb: The long-running operation response from a
    -                         Create/Update/Undelete instance request.
    -
    -    :rtype: (int, str, datetime)
    -    :returns: (operation_id, location_id, operation_begin).
    -    :raises: :class:`ValueError <exceptions.ValueError>` if the operation name
    -             doesn't match the :data:`_OPERATION_NAME_RE` regex.
    -    """
    -    match = _OPERATION_NAME_RE.match(operation_pb.name)
    -    if match is None:
    -        raise ValueError('Operation name was not in the expected '
    -                         'format after instance creation.',
    -                         operation_pb.name)
    -    location_id = match.group('location_id')
    -    operation_id = int(match.group('operation_id'))
    -
    -    request_metadata = _parse_pb_any_to_native(operation_pb.metadata)
    -    operation_begin = _pb_timestamp_to_datetime(
    -        request_metadata.request_time)
    -
    -    return operation_id, location_id, operation_begin
    -
    -
    -
    [docs]class Operation(object): - """Representation of a Google API Long-Running Operation. - - In particular, these will be the result of operations on - instances using the Cloud Bigtable API. - - :type op_type: str - :param op_type: The type of operation being performed. Expect - ``create``, ``update`` or ``undelete``. - - :type op_id: int - :param op_id: The ID of the operation. - - :type begin: :class:`datetime.datetime` - :param begin: The time when the operation was started. - - :type location_id: str - :param location_id: ID of the location in which the operation is running - - :type instance: :class:`Instance` - :param instance: The instance that created the operation. - """ - - def __init__(self, op_type, op_id, begin, location_id, instance=None): - self.op_type = op_type - self.op_id = op_id - self.begin = begin - self.location_id = location_id - self._instance = instance - self._complete = False - - def __eq__(self, other): - if not isinstance(other, self.__class__): - return False - return (other.op_type == self.op_type and - other.op_id == self.op_id and - other.begin == self.begin and - other.location_id == self.location_id and - other._instance == self._instance and - other._complete == self._complete) - - def __ne__(self, other): - return not self.__eq__(other) - -
    [docs] def finished(self): - """Check if the operation has finished. - - :rtype: bool - :returns: A boolean indicating if the current operation has completed. - :raises: :class:`ValueError <exceptions.ValueError>` if the operation - has already completed. - """ - if self._complete: - raise ValueError('The operation has completed.') - - operation_name = ( - 'operations/%s/locations/%s/operations/%d' % - (self._instance.name, self.location_id, self.op_id)) - request_pb = operations_pb2.GetOperationRequest(name=operation_name) - # We expect a `google.longrunning.operations_pb2.Operation`. - operation_pb = self._instance._client._operations_stub.GetOperation( - request_pb, self._instance._client.timeout_seconds) - - if operation_pb.done: - self._complete = True - return True - else: - return False
    - - -
    [docs]class Instance(object): +
    [docs]class Instance(object): """Representation of a Google Cloud Bigtable Instance. We can use a :class:`Instance` to: @@ -298,7 +330,6 @@

    Source code for gcloud.bigtable.instance

         * :meth:`create` itself
         * :meth:`update` itself
         * :meth:`delete` itself
    -    * :meth:`undelete` itself
     
         .. note::
     
    @@ -308,7 +339,7 @@ 

    Source code for gcloud.bigtable.instance

         :type instance_id: str
         :param instance_id: The ID of the instance.
     
    -    :type client: :class:`Client <gcloud.bigtable.client.Client>`
    +    :type client: :class:`Client <google.cloud.bigtable.client.Client>`
         :param client: The client that owns the instance. Provides
                        authorization and a project ID.
     
    @@ -348,13 +379,13 @@ 

    Source code for gcloud.bigtable.instance

             self.display_name = instance_pb.display_name
     
         @classmethod
    -
    [docs] def from_pb(cls, instance_pb, client): +
    [docs] def from_pb(cls, instance_pb, client): """Creates a instance instance from a protobuf. :type instance_pb: :class:`instance_pb2.Instance` :param instance_pb: A instance protobuf object. - :type client: :class:`Client <gcloud.bigtable.client.Client>` + :type client: :class:`Client <google.cloud.bigtable.client.Client>` :param client: The client that owns the instance. :rtype: :class:`Instance` @@ -378,7 +409,7 @@

    Source code for gcloud.bigtable.instance

             result._update_from_pb(instance_pb)
             return result
    -
    [docs] def copy(self): +
    [docs] def copy(self): """Make a copy of this instance. Copies the local data stored as simple types and copies the client @@ -424,18 +455,17 @@

    Source code for gcloud.bigtable.instance

         def __ne__(self, other):
             return not self.__eq__(other)
     
    -
    [docs] def reload(self): +
    [docs] def reload(self): """Reload the metadata for this instance.""" request_pb = messages_v2_pb2.GetInstanceRequest(name=self.name) # We expect `data_v2_pb2.Instance`. - instance_pb = self._client._instance_stub.GetInstance( - request_pb, self._client.timeout_seconds) + instance_pb = self._client._instance_stub.GetInstance(request_pb) # NOTE: _update_from_pb does not check that the project and # instance ID on the response match the request. self._update_from_pb(instance_pb)
    -
    [docs] def create(self): +
    [docs] def create(self): """Create this instance. .. note:: @@ -457,13 +487,14 @@

    Source code for gcloud.bigtable.instance

             """
             request_pb = _prepare_create_request(self)
             # We expect a `google.longrunning.operations_pb2.Operation`.
    -        operation_pb = self._client._instance_stub.CreateInstance(
    -            request_pb, self._client.timeout_seconds)
    +        operation_pb = self._client._instance_stub.CreateInstance(request_pb)
     
    -        op_id, loc_id, op_begin = _process_operation(operation_pb)
    -        return Operation('create', op_id, op_begin, loc_id, instance=self)
    + operation = Operation.from_pb(operation_pb, self._client) + operation.target = self + operation.metadata['request_type'] = 'CreateInstance' + return operation
    -
    [docs] def update(self): +
    [docs] def update(self): """Update this instance. .. note:: @@ -482,10 +513,9 @@

    Source code for gcloud.bigtable.instance

                 display_name=self.display_name,
             )
             # Ignore the expected `data_v2_pb2.Instance`.
    -        self._client._instance_stub.UpdateInstance(
    -            request_pb, self._client.timeout_seconds)
    + self._client._instance_stub.UpdateInstance(request_pb)
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Delete this instance. Marks a instance and all of its tables for permanent deletion @@ -501,11 +531,6 @@

    Source code for gcloud.bigtable.instance

     
             * All tables within the instance will become unavailable.
     
    -        Prior to the instance's ``delete_time``:
    -
    -        * The instance can be recovered with a call to ``UndeleteInstance``.
    -        * All other attempts to modify or delete the instance will be rejected.
    -
             At the instance's ``delete_time``:
     
             * The instance and **all of its tables** will immediately and
    @@ -514,10 +539,9 @@ 

    Source code for gcloud.bigtable.instance

             """
             request_pb = messages_v2_pb2.DeleteInstanceRequest(name=self.name)
             # We expect a `google.protobuf.empty_pb2.Empty`
    -        self._client._instance_stub.DeleteInstance(
    -            request_pb, self._client.timeout_seconds)
    + self._client._instance_stub.DeleteInstance(request_pb)
    -
    [docs] def cluster(self, cluster_id, serve_nodes=3): +
    [docs] def cluster(self, cluster_id, serve_nodes=3): """Factory to create a cluster associated with this client. :type cluster_id: str @@ -532,7 +556,7 @@

    Source code for gcloud.bigtable.instance

             """
             return Cluster(cluster_id, self, serve_nodes=serve_nodes)
    -
    [docs] def list_clusters(self): +
    [docs] def list_clusters(self): """Lists clusters in this instance. :rtype: tuple @@ -543,7 +567,7 @@

    Source code for gcloud.bigtable.instance

             request_pb = messages_v2_pb2.ListClustersRequest(parent=self.name)
             # We expect a `.cluster_messages_v1_pb2.ListClustersResponse`
             list_clusters_response = self._client._instance_stub.ListClusters(
    -            request_pb, self._client.timeout_seconds)
    +            request_pb)
     
             failed_locations = [
                 location for location in list_clusters_response.failed_locations]
    @@ -551,29 +575,28 @@ 

    Source code for gcloud.bigtable.instance

                         for cluster_pb in list_clusters_response.clusters]
             return clusters, failed_locations
    -
    [docs] def table(self, table_id): +
    [docs] def table(self, table_id): """Factory to create a table associated with this instance. :type table_id: str :param table_id: The ID of the table. - :rtype: :class:`Table <gcloud.bigtable.table.Table>` + :rtype: :class:`Table <google.cloud.bigtable.table.Table>` :returns: The table owned by this instance. """ return Table(table_id, self)
    -
    [docs] def list_tables(self): +
    [docs] def list_tables(self): """List the tables in this instance. - :rtype: list of :class:`Table <gcloud.bigtable.table.Table>` + :rtype: list of :class:`Table <google.cloud.bigtable.table.Table>` :returns: The list of tables owned by the instance. :raises: :class:`ValueError <exceptions.ValueError>` if one of the returned tables has a name that is not of the expected format. """ request_pb = table_messages_v2_pb2.ListTablesRequest(parent=self.name) # We expect a `table_messages_v2_pb2.ListTablesResponse` - table_list_pb = self._client._table_stub.ListTables( - request_pb, self._client.timeout_seconds) + table_list_pb = self._client._table_stub.ListTables(request_pb) result = [] for table_pb in table_list_pb.tables: @@ -587,123 +610,62 @@

    Source code for gcloud.bigtable.instance

             return result
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/row.html b/latest/_modules/google/cloud/bigtable/row.html similarity index 82% rename from latest/_modules/gcloud/bigtable/row.html rename to latest/_modules/google/cloud/bigtable/row.html index deeb528a3727..d84e7329c6f3 100644 --- a/latest/_modules/gcloud/bigtable/row.html +++ b/latest/_modules/google/cloud/bigtable/row.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.row — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigtable.row — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.row
    • +
    • -

      Source code for gcloud.bigtable.row

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.row

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -118,12 +273,12 @@ 

    Source code for gcloud.bigtable.row

     
     import six
     
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud._helpers import _microseconds_from_datetime
    -from gcloud._helpers import _to_bytes
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud._helpers import _datetime_from_microseconds
    +from google.cloud._helpers import _microseconds_from_datetime
    +from google.cloud._helpers import _to_bytes
    +from google.cloud.bigtable._generated import (
         data_pb2 as data_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         bigtable_pb2 as messages_v2_pb2)
     
     
    @@ -133,7 +288,7 @@ 

    Source code for gcloud.bigtable.row

     """The maximum number of mutations that a row can accumulate."""
     
     
    -
    [docs]class Row(object): +
    [docs]class Row(object): """Base representation of a Google Cloud Bigtable Row. This class has three subclasses corresponding to the three @@ -146,7 +301,7 @@

    Source code for gcloud.bigtable.row

         :type row_key: bytes
         :param row_key: The key for the current row.
     
    -    :type table: :class:`Table <gcloud.bigtable.table.Table>`
    +    :type table: :class:`Table <google.cloud.bigtable.table.Table>`
         :param table: The table that owns the row.
         """
     
    @@ -168,7 +323,7 @@ 

    Source code for gcloud.bigtable.row

         :type row_key: bytes
         :param row_key: The key for the current row.
     
    -    :type table: :class:`Table <gcloud.bigtable.table.Table>`
    +    :type table: :class:`Table <google.cloud.bigtable.table.Table>`
         :param table: The table that owns the row.
         """
     
    @@ -317,7 +472,7 @@ 

    Source code for gcloud.bigtable.row

                 mutations_list.extend(to_append)
     
     
    -
    [docs]class DirectRow(_SetDeleteRow): +
    [docs]class DirectRow(_SetDeleteRow): """Google Cloud Bigtable Row for sending "direct" mutations. These mutations directly set or delete cell contents: @@ -343,7 +498,7 @@

    Source code for gcloud.bigtable.row

         :type row_key: bytes
         :param row_key: The key for the current row.
     
    -    :type table: :class:`Table <gcloud.bigtable.table.Table>`
    +    :type table: :class:`Table <google.cloud.bigtable.table.Table>`
         :param table: The table that owns the row.
         """
     
    @@ -366,7 +521,7 @@ 

    Source code for gcloud.bigtable.row

             """
             return self._pb_mutations
     
    -
    [docs] def set_cell(self, column_family_id, column, value, timestamp=None): +
    [docs] def set_cell(self, column_family_id, column, value, timestamp=None): """Sets a value in this row. The cell is determined by the ``row_key`` of this :class:`DirectRow` @@ -400,7 +555,7 @@

    Source code for gcloud.bigtable.row

             self._set_cell(column_family_id, column, value, timestamp=timestamp,
                            state=None)
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Deletes this row from the table. .. note:: @@ -412,7 +567,7 @@

    Source code for gcloud.bigtable.row

             """
             self._delete(state=None)
    -
    [docs] def delete_cell(self, column_family_id, column, time_range=None): +
    [docs] def delete_cell(self, column_family_id, column, time_range=None): """Deletes cell in this row. .. note:: @@ -438,7 +593,7 @@

    Source code for gcloud.bigtable.row

             self._delete_cells(column_family_id, [column], time_range=time_range,
                                state=None)
    -
    [docs] def delete_cells(self, column_family_id, columns, time_range=None): +
    [docs] def delete_cells(self, column_family_id, columns, time_range=None): """Deletes cells in this row. .. note:: @@ -466,7 +621,7 @@

    Source code for gcloud.bigtable.row

             self._delete_cells(column_family_id, columns, time_range=time_range,
                                state=None)
    -
    [docs] def commit(self): +
    [docs] def commit(self): """Makes a ``MutateRow`` API request. If no mutations have been created in the row, no request is made. @@ -495,15 +650,15 @@

    Source code for gcloud.bigtable.row

             )
             # We expect a `google.protobuf.empty_pb2.Empty`
             client = self._table._instance._client
    -        client._data_stub.MutateRow(request_pb, client.timeout_seconds)
    +        client._data_stub.MutateRow(request_pb)
             self.clear()
    -
    [docs] def clear(self): +
    [docs] def clear(self): """Removes all currently accumulated mutations on the current row.""" del self._pb_mutations[:]
    -
    [docs]class ConditionalRow(_SetDeleteRow): +
    [docs]class ConditionalRow(_SetDeleteRow): """Google Cloud Bigtable Row for sending mutations conditionally. Each mutation has an associated state: :data:`True` or :data:`False`. @@ -533,7 +688,7 @@

    Source code for gcloud.bigtable.row

         :type row_key: bytes
         :param row_key: The key for the current row.
     
    -    :type table: :class:`Table <gcloud.bigtable.table.Table>`
    +    :type table: :class:`Table <google.cloud.bigtable.table.Table>`
         :param table: The table that owns the row.
     
         :type filter_: :class:`.RowFilter`
    @@ -567,7 +722,7 @@ 

    Source code for gcloud.bigtable.row

             else:
                 return self._false_pb_mutations
     
    -
    [docs] def commit(self): +
    [docs] def commit(self): """Makes a ``CheckAndMutateRow`` API request. If no mutations have been created in the row, no request is made. @@ -612,13 +767,12 @@

    Source code for gcloud.bigtable.row

             )
             # We expect a `.messages_v2_pb2.CheckAndMutateRowResponse`
             client = self._table._instance._client
    -        resp = client._data_stub.CheckAndMutateRow(
    -            request_pb, client.timeout_seconds)
    +        resp = client._data_stub.CheckAndMutateRow(request_pb)
             self.clear()
             return resp.predicate_matched
    # pylint: disable=arguments-differ -
    [docs] def set_cell(self, column_family_id, column, value, timestamp=None, +
    [docs] def set_cell(self, column_family_id, column, value, timestamp=None, state=True): """Sets a value in this row. @@ -658,7 +812,7 @@

    Source code for gcloud.bigtable.row

             self._set_cell(column_family_id, column, value, timestamp=timestamp,
                            state=state)
    -
    [docs] def delete(self, state=True): +
    [docs] def delete(self, state=True): """Deletes this row from the table. .. note:: @@ -674,7 +828,7 @@

    Source code for gcloud.bigtable.row

             """
             self._delete(state=state)
    -
    [docs] def delete_cell(self, column_family_id, column, time_range=None, +
    [docs] def delete_cell(self, column_family_id, column, time_range=None, state=True): """Deletes cell in this row. @@ -705,7 +859,7 @@

    Source code for gcloud.bigtable.row

             self._delete_cells(column_family_id, [column], time_range=time_range,
                                state=state)
    -
    [docs] def delete_cells(self, column_family_id, columns, time_range=None, +
    [docs] def delete_cells(self, column_family_id, columns, time_range=None, state=True): """Deletes cells in this row. @@ -739,13 +893,13 @@

    Source code for gcloud.bigtable.row

                                state=state)
    # pylint: enable=arguments-differ -
    [docs] def clear(self): +
    [docs] def clear(self): """Removes all currently accumulated mutations on the current row.""" del self._true_pb_mutations[:] del self._false_pb_mutations[:]
    -
    [docs]class AppendRow(Row): +
    [docs]class AppendRow(Row): """Google Cloud Bigtable Row for sending append mutations. These mutations are intended to augment the value of an existing cell @@ -762,7 +916,7 @@

    Source code for gcloud.bigtable.row

         :type row_key: bytes
         :param row_key: The key for the current row.
     
    -    :type table: :class:`Table <gcloud.bigtable.table.Table>`
    +    :type table: :class:`Table <google.cloud.bigtable.table.Table>`
         :param table: The table that owns the row.
         """
     
    @@ -770,11 +924,11 @@ 

    Source code for gcloud.bigtable.row

             super(AppendRow, self).__init__(row_key, table)
             self._rule_pb_list = []
     
    -
    [docs] def clear(self): +
    [docs] def clear(self): """Removes all currently accumulated modifications on current row.""" del self._rule_pb_list[:]
    -
    [docs] def append_cell_value(self, column_family_id, column, value): +
    [docs] def append_cell_value(self, column_family_id, column, value): """Appends a value to an existing cell. .. note:: @@ -806,7 +960,7 @@

    Source code for gcloud.bigtable.row

                 append_value=value)
             self._rule_pb_list.append(rule_pb)
    -
    [docs] def increment_cell_value(self, column_family_id, column, int_value): +
    [docs] def increment_cell_value(self, column_family_id, column, int_value): """Increments a value in an existing cell. Assumes the value in the cell is stored as a 64 bit integer @@ -843,7 +997,7 @@

    Source code for gcloud.bigtable.row

                 increment_amount=int_value)
             self._rule_pb_list.append(rule_pb)
    -
    [docs] def commit(self): +
    [docs] def commit(self): """Makes a ``ReadModifyWriteRow`` API request. This commits modifications made by :meth:`append_cell_value` and @@ -900,8 +1054,7 @@

    Source code for gcloud.bigtable.row

             )
             # We expect a `.data_v2_pb2.Row`
             client = self._table._instance._client
    -        row_response = client._data_stub.ReadModifyWriteRow(
    -            request_pb, client.timeout_seconds)
    +        row_response = client._data_stub.ReadModifyWriteRow(request_pb)
     
             # Reset modifications after commit-ing request.
             self.clear()
    @@ -953,7 +1106,7 @@ 

    Source code for gcloud.bigtable.row

     def _parse_family_pb(family_pb):
         """Parses a Family protobuf into a dictionary.
     
    -    :type family_pb: :class:`._generated_v2.data_pb2.Family`
    +    :type family_pb: :class:`._generated.data_pb2.Family`
         :param family_pb: A protobuf
     
         :rtype: tuple
    @@ -988,123 +1141,62 @@ 

    Source code for gcloud.bigtable.row

         return family_pb.name, result
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/row_data.html b/latest/_modules/google/cloud/bigtable/row_data.html similarity index 81% rename from latest/_modules/gcloud/bigtable/row_data.html rename to latest/_modules/google/cloud/bigtable/row_data.html index b597731f59e6..8c59e39db4bf 100644 --- a/latest/_modules/gcloud/bigtable/row_data.html +++ b/latest/_modules/google/cloud/bigtable/row_data.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.row_data — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigtable.row_data — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.row_data
    • +
    • -

      Source code for gcloud.bigtable.row_data

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.row_data

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -117,11 +272,11 @@ 

    Source code for gcloud.bigtable.row_data

     import copy
     import six
     
    -from gcloud._helpers import _datetime_from_microseconds
    -from gcloud._helpers import _to_bytes
    +from google.cloud._helpers import _datetime_from_microseconds
    +from google.cloud._helpers import _to_bytes
     
     
    -
    [docs]class Cell(object): +
    [docs]class Cell(object): """Representation of a Google Cloud Bigtable Cell. :type value: bytes @@ -140,10 +295,10 @@

    Source code for gcloud.bigtable.row_data

             self.labels = list(labels)
     
         @classmethod
    -
    [docs] def from_pb(cls, cell_pb): +
    [docs] def from_pb(cls, cell_pb): """Create a new cell from a Cell protobuf. - :type cell_pb: :class:`._generated_v2.data_pb2.Cell` + :type cell_pb: :class:`._generated.data_pb2.Cell` :param cell_pb: The protobuf to convert. :rtype: :class:`Cell` @@ -166,7 +321,7 @@

    Source code for gcloud.bigtable.row_data

             return not self.__eq__(other)
    -
    [docs]class PartialCellData(object): +
    [docs]class PartialCellData(object): """Representation of partial cell in a Google Cloud Bigtable Table. These are expected to be updated directly from a @@ -200,7 +355,7 @@

    Source code for gcloud.bigtable.row_data

             self.labels = labels
             self.value = value
     
    -
    [docs] def append_value(self, value): +
    [docs] def append_value(self, value): """Append bytes from a new chunk to value. :type value: bytes @@ -209,7 +364,7 @@

    Source code for gcloud.bigtable.row_data

             self.value += value
    -
    [docs]class PartialRowData(object): +
    [docs]class PartialRowData(object): """Representation of partial row in a Google Cloud Bigtable Table. These are expected to be updated directly from a @@ -232,7 +387,7 @@

    Source code for gcloud.bigtable.row_data

         def __ne__(self, other):
             return not self.__eq__(other)
     
    -
    [docs] def to_dict(self): +
    [docs] def to_dict(self): """Convert the cells to a dictionary. This is intended to be used with HappyBase, so the column family and @@ -271,19 +426,18 @@

    Source code for gcloud.bigtable.row_data

             return self._row_key
    -
    [docs]class InvalidReadRowsResponse(RuntimeError): +
    [docs]class InvalidReadRowsResponse(RuntimeError): """Exception raised to to invalid response data from back-end."""
    -
    [docs]class InvalidChunk(RuntimeError): +
    [docs]class InvalidChunk(RuntimeError): """Exception raised to to invalid chunk data from back-end."""
    -
    [docs]class PartialRowsData(object): +
    [docs]class PartialRowsData(object): """Convenience wrapper for consuming a ``ReadRows`` streaming response. - :type response_iterator: - :class:`grpc.framework.alpha._reexport._CancellableIterator` + :type response_iterator: :class:`grpc._channel._Rendezvous` :param response_iterator: A streaming iterator returned from a ``ReadRows`` request. """ @@ -348,11 +502,11 @@

    Source code for gcloud.bigtable.row_data

             #       mutable private data.
             return self._rows
     
    -
    [docs] def cancel(self): +
    [docs] def cancel(self): """Cancels the iterator, closing the stream.""" self._response_iterator.cancel()
    -
    [docs] def consume_next(self): +
    [docs] def consume_next(self): """Consume the next ``ReadRowsResponse`` from the stream. Parse the response and its chunks into a new/existing row in @@ -403,7 +557,7 @@

    Source code for gcloud.bigtable.row_data

                     self._save_current_cell()
                     cell = None
    -
    [docs] def consume_all(self, max_loops=None): +
    [docs] def consume_all(self, max_loops=None): """Consume the streamed responses until there are no more. This simply calls :meth:`consume_next` until there are no @@ -541,123 +695,62 @@

    Source code for gcloud.bigtable.row_data

             raise InvalidChunk(*args)
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/row_filters.html b/latest/_modules/google/cloud/bigtable/row_filters.html similarity index 77% rename from latest/_modules/gcloud/bigtable/row_filters.html rename to latest/_modules/google/cloud/bigtable/row_filters.html index 5d8f9cc402ae..7be2954bdd27 100644 --- a/latest/_modules/gcloud/bigtable/row_filters.html +++ b/latest/_modules/google/cloud/bigtable/row_filters.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.row_filters — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigtable.row_filters — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.row_filters
    • +
    • -

      Source code for gcloud.bigtable.row_filters

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.row_filters

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,13 +269,13 @@ 

    Source code for gcloud.bigtable.row_filters

     """Filters for Google Cloud Bigtable Row classes."""
     
     
    -from gcloud._helpers import _microseconds_from_datetime
    -from gcloud._helpers import _to_bytes
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud._helpers import _microseconds_from_datetime
    +from google.cloud._helpers import _to_bytes
    +from google.cloud.bigtable._generated import (
         data_pb2 as data_v2_pb2)
     
     
    -
    [docs]class RowFilter(object): +
    [docs]class RowFilter(object): """Basic filter to apply to cells in a row. These values can be combined via :class:`RowFilterChain`, @@ -151,7 +306,7 @@

    Source code for gcloud.bigtable.row_filters

             return other.flag == self.flag
     
     
    -
    [docs]class SinkFilter(_BoolFilter): +
    [docs]class SinkFilter(_BoolFilter): """Advanced row filter to skip parent filters. :type flag: bool @@ -162,7 +317,7 @@

    Source code for gcloud.bigtable.row_filters

                      of a :class:`ConditionalRowFilter`.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -171,7 +326,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(sink=self.flag)
    -
    [docs]class PassAllFilter(_BoolFilter): +
    [docs]class PassAllFilter(_BoolFilter): """Row filter equivalent to not filtering at all. :type flag: bool @@ -180,7 +335,7 @@

    Source code for gcloud.bigtable.row_filters

                      completeness.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -189,7 +344,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(pass_all_filter=self.flag)
    -
    [docs]class BlockAllFilter(_BoolFilter): +
    [docs]class BlockAllFilter(_BoolFilter): """Row filter that doesn't match any cells. :type flag: bool @@ -197,7 +352,7 @@

    Source code for gcloud.bigtable.row_filters

                      temporarily disabling just part of a filter.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -227,7 +382,7 @@

    Source code for gcloud.bigtable.row_filters

             return other.regex == self.regex
     
     
    -
    [docs]class RowKeyRegexFilter(_RegexFilter): +
    [docs]class RowKeyRegexFilter(_RegexFilter): """Row filter for a row key regular expression. The ``regex`` must be valid RE2 patterns. See Google's @@ -250,7 +405,7 @@

    Source code for gcloud.bigtable.row_filters

                       since the row key is already specified.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -259,7 +414,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(row_key_regex_filter=self.regex)
    -
    [docs]class RowSampleFilter(RowFilter): +
    [docs]class RowSampleFilter(RowFilter): """Matches all cells from a row with probability p. :type sample: float @@ -275,7 +430,7 @@

    Source code for gcloud.bigtable.row_filters

                 return False
             return other.sample == self.sample
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -284,7 +439,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(row_sample_filter=self.sample)
    -
    [docs]class FamilyNameRegexFilter(_RegexFilter): +
    [docs]class FamilyNameRegexFilter(_RegexFilter): """Row filter for a family name regular expression. The ``regex`` must be valid RE2 patterns. See Google's @@ -299,7 +454,7 @@

    Source code for gcloud.bigtable.row_filters

                       used as a literal.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -308,7 +463,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(family_name_regex_filter=self.regex)
    -
    [docs]class ColumnQualifierRegexFilter(_RegexFilter): +
    [docs]class ColumnQualifierRegexFilter(_RegexFilter): """Row filter for a column qualifier regular expression. The ``regex`` must be valid RE2 patterns. See Google's @@ -329,7 +484,7 @@

    Source code for gcloud.bigtable.row_filters

                       match this regex (irrespective of column family).
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -338,7 +493,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(column_qualifier_regex_filter=self.regex)
    -
    [docs]class TimestampRange(object): +
    [docs]class TimestampRange(object): """Range of time with inclusive lower and exclusive upper bounds. :type start: :class:`datetime.datetime` @@ -363,7 +518,7 @@

    Source code for gcloud.bigtable.row_filters

         def __ne__(self, other):
             return not self.__eq__(other)
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the :class:`TimestampRange` to a protobuf. :rtype: :class:`.data_v2_pb2.TimestampRange` @@ -379,7 +534,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.TimestampRange(**timestamp_range_kwargs)
    -
    [docs]class TimestampRangeFilter(RowFilter): +
    [docs]class TimestampRangeFilter(RowFilter): """Row filter that limits cells to a range of time. :type range_: :class:`TimestampRange` @@ -394,7 +549,7 @@

    Source code for gcloud.bigtable.row_filters

                 return False
             return other.range_ == self.range_
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. First converts the ``range_`` on the current object to a protobuf and @@ -407,7 +562,7 @@

    Source code for gcloud.bigtable.row_filters

                 timestamp_range_filter=self.range_.to_pb())
    -
    [docs]class ColumnRangeFilter(RowFilter): +
    [docs]class ColumnRangeFilter(RowFilter): """A row filter to restrict to a range of columns. Both the start and end column can be included or excluded in the range. @@ -473,7 +628,7 @@

    Source code for gcloud.bigtable.row_filters

                     other.inclusive_start == self.inclusive_start and
                     other.inclusive_end == self.inclusive_end)
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. First converts to a :class:`.data_v2_pb2.ColumnRange` and then uses it @@ -500,7 +655,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(column_range_filter=column_range)
    -
    [docs]class ValueRegexFilter(_RegexFilter): +
    [docs]class ValueRegexFilter(_RegexFilter): """Row filter for a value regular expression. The ``regex`` must be valid RE2 patterns. See Google's @@ -521,7 +676,7 @@

    Source code for gcloud.bigtable.row_filters

                       match this regex.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -530,7 +685,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(value_regex_filter=self.regex)
    -
    [docs]class ValueRangeFilter(RowFilter): +
    [docs]class ValueRangeFilter(RowFilter): """A range of values to restrict to in a row filter. Will only match cells that have values in this range. @@ -590,7 +745,7 @@

    Source code for gcloud.bigtable.row_filters

                     other.inclusive_start == self.inclusive_start and
                     other.inclusive_end == self.inclusive_end)
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. First converts to a :class:`.data_v2_pb2.ValueRange` and then uses @@ -636,14 +791,14 @@

    Source code for gcloud.bigtable.row_filters

             return other.num_cells == self.num_cells
     
     
    -
    [docs]class CellsRowOffsetFilter(_CellCountFilter): +
    [docs]class CellsRowOffsetFilter(_CellCountFilter): """Row filter to skip cells in a row. :type num_cells: int :param num_cells: Skips the first N cells of the row. """ -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -653,14 +808,14 @@

    Source code for gcloud.bigtable.row_filters

                 cells_per_row_offset_filter=self.num_cells)
    -
    [docs]class CellsRowLimitFilter(_CellCountFilter): +
    [docs]class CellsRowLimitFilter(_CellCountFilter): """Row filter to limit cells in a row. :type num_cells: int :param num_cells: Matches only the first N cells of the row. """ -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -669,7 +824,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(cells_per_row_limit_filter=self.num_cells)
    -
    [docs]class CellsColumnLimitFilter(_CellCountFilter): +
    [docs]class CellsColumnLimitFilter(_CellCountFilter): """Row filter to limit cells in a column. :type num_cells: int @@ -678,7 +833,7 @@

    Source code for gcloud.bigtable.row_filters

                           timestamps of each cell.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -688,7 +843,7 @@

    Source code for gcloud.bigtable.row_filters

                 cells_per_column_limit_filter=self.num_cells)
    -
    [docs]class StripValueTransformerFilter(_BoolFilter): +
    [docs]class StripValueTransformerFilter(_BoolFilter): """Row filter that transforms cells into empty string (0 bytes). :type flag: bool @@ -697,7 +852,7 @@

    Source code for gcloud.bigtable.row_filters

                      transformer than a generic query / filter.
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -706,7 +861,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(strip_value_transformer=self.flag)
    -
    [docs]class ApplyLabelFilter(RowFilter): +
    [docs]class ApplyLabelFilter(RowFilter): """Filter to apply labels to cells. Intended to be used as an intermediate filter on a pre-existing filtered @@ -733,7 +888,7 @@

    Source code for gcloud.bigtable.row_filters

                 return False
             return other.label == self.label
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -764,7 +919,7 @@

    Source code for gcloud.bigtable.row_filters

             return other.filters == self.filters
     
     
    -
    [docs]class RowFilterChain(_FilterCombination): +
    [docs]class RowFilterChain(_FilterCombination): """Chain of row filters. Sends rows through several filters in sequence. The filters are "chained" @@ -775,7 +930,7 @@

    Source code for gcloud.bigtable.row_filters

         :param filters: List of :class:`RowFilter`
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -786,7 +941,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(chain=chain)
    -
    [docs]class RowFilterUnion(_FilterCombination): +
    [docs]class RowFilterUnion(_FilterCombination): """Union of row filters. Sends rows through several filters simultaneously, then @@ -799,7 +954,7 @@

    Source code for gcloud.bigtable.row_filters

         :param filters: List of :class:`RowFilter`
         """
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -810,7 +965,7 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(interleave=interleave)
    -
    [docs]class ConditionalRowFilter(RowFilter): +
    [docs]class ConditionalRowFilter(RowFilter): """Conditional row filter which exhibits ternary behavior. Executes one of two filters based on another filter. If the ``base_filter`` @@ -852,7 +1007,7 @@

    Source code for gcloud.bigtable.row_filters

                     other.true_filter == self.true_filter and
                     other.false_filter == self.false_filter)
     
    -
    [docs] def to_pb(self): +
    [docs] def to_pb(self): """Converts the row filter to a protobuf. :rtype: :class:`.data_v2_pb2.RowFilter` @@ -867,123 +1022,62 @@

    Source code for gcloud.bigtable.row_filters

             return data_v2_pb2.RowFilter(condition=condition)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/bigtable/table.html b/latest/_modules/google/cloud/bigtable/table.html similarity index 73% rename from latest/_modules/gcloud/bigtable/table.html rename to latest/_modules/google/cloud/bigtable/table.html index d350159722c9..2abe079815b3 100644 --- a/latest/_modules/gcloud/bigtable/table.html +++ b/latest/_modules/google/cloud/bigtable/table.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.bigtable.table — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.bigtable.table — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.bigtable.table
    • +
    • -

      Source code for gcloud.bigtable.table

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.bigtable.table

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,22 +268,22 @@ 

    Source code for gcloud.bigtable.table

     
     """User friendly container for Google Cloud Bigtable Table."""
     
    -from gcloud._helpers import _to_bytes
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud._helpers import _to_bytes
    +from google.cloud.bigtable._generated import (
         bigtable_pb2 as data_messages_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         bigtable_table_admin_pb2 as table_admin_messages_v2_pb2)
    -from gcloud.bigtable._generated_v2 import (
    +from google.cloud.bigtable._generated import (
         table_pb2 as table_v2_pb2)
    -from gcloud.bigtable.column_family import _gc_rule_from_pb
    -from gcloud.bigtable.column_family import ColumnFamily
    -from gcloud.bigtable.row import AppendRow
    -from gcloud.bigtable.row import ConditionalRow
    -from gcloud.bigtable.row import DirectRow
    -from gcloud.bigtable.row_data import PartialRowsData
    +from google.cloud.bigtable.column_family import _gc_rule_from_pb
    +from google.cloud.bigtable.column_family import ColumnFamily
    +from google.cloud.bigtable.row import AppendRow
    +from google.cloud.bigtable.row import ConditionalRow
    +from google.cloud.bigtable.row import DirectRow
    +from google.cloud.bigtable.row_data import PartialRowsData
     
     
    -
    [docs]class Table(object): +
    [docs]class Table(object): """Representation of a Google Cloud Bigtable Table. .. note:: @@ -174,7 +329,7 @@

    Source code for gcloud.bigtable.table

             """
             return self._instance.name + '/tables/' + self.table_id
     
    -
    [docs] def column_family(self, column_family_id, gc_rule=None): +
    [docs] def column_family(self, column_family_id, gc_rule=None): """Factory to create a column family associated with this table. :type column_family_id: str @@ -190,7 +345,7 @@

    Source code for gcloud.bigtable.table

             """
             return ColumnFamily(column_family_id, self, gc_rule=gc_rule)
    -
    [docs] def row(self, row_key, filter_=None, append=False): +
    [docs] def row(self, row_key, filter_=None, append=False): """Factory to create a row associated with this table. .. warning:: @@ -232,13 +387,13 @@

    Source code for gcloud.bigtable.table

         def __ne__(self, other):
             return not self.__eq__(other)
     
    -
    [docs] def create(self, initial_split_keys=None, column_families=()): +
    [docs] def create(self, initial_split_keys=None, column_families=()): """Creates this table. .. note:: A create request returns a - :class:`._generated_v2.table_pb2.Table` but we don't use + :class:`._generated.table_pb2.Table` but we don't use this response. :type initial_split_keys: list @@ -273,18 +428,18 @@

    Source code for gcloud.bigtable.table

                 table=table_pb,
             )
             client = self._instance._client
    -        # We expect a `._generated_v2.table_pb2.Table`
    -        client._table_stub.CreateTable(request_pb, client.timeout_seconds)
    + # We expect a `._generated.table_pb2.Table` + client._table_stub.CreateTable(request_pb)
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Delete this table.""" request_pb = table_admin_messages_v2_pb2.DeleteTableRequest( name=self.name) client = self._instance._client # We expect a `google.protobuf.empty_pb2.Empty` - client._table_stub.DeleteTable(request_pb, client.timeout_seconds)
    + client._table_stub.DeleteTable(request_pb)
    -
    [docs] def list_column_families(self): +
    [docs] def list_column_families(self): """List the column families owned by this table. :rtype: dict @@ -298,9 +453,8 @@

    Source code for gcloud.bigtable.table

             request_pb = table_admin_messages_v2_pb2.GetTableRequest(
                 name=self.name)
             client = self._instance._client
    -        # We expect a `._generated_v2.table_pb2.Table`
    -        table_pb = client._table_stub.GetTable(request_pb,
    -                                               client.timeout_seconds)
    +        # We expect a `._generated.table_pb2.Table`
    +        table_pb = client._table_stub.GetTable(request_pb)
     
             result = {}
             for column_family_id, value_pb in table_pb.column_families.items():
    @@ -310,7 +464,7 @@ 

    Source code for gcloud.bigtable.table

                 result[column_family_id] = column_family
             return result
    -
    [docs] def read_row(self, row_key, filter_=None): +
    [docs] def read_row(self, row_key, filter_=None): """Read a single row from this table. :type row_key: bytes @@ -329,8 +483,7 @@

    Source code for gcloud.bigtable.table

             request_pb = _create_row_request(self.name, row_key=row_key,
                                              filter_=filter_)
             client = self._instance._client
    -        response_iterator = client._data_stub.ReadRows(request_pb,
    -                                                       client.timeout_seconds)
    +        response_iterator = client._data_stub.ReadRows(request_pb)
             rows_data = PartialRowsData(response_iterator)
             rows_data.consume_all()
             if rows_data.state not in (rows_data.NEW_ROW, rows_data.START):
    @@ -341,7 +494,7 @@ 

    Source code for gcloud.bigtable.table

     
             return rows_data.rows[row_key]
    -
    [docs] def read_rows(self, start_key=None, end_key=None, limit=None, +
    [docs] def read_rows(self, start_key=None, end_key=None, limit=None, filter_=None): """Read rows from this table. @@ -373,12 +526,11 @@

    Source code for gcloud.bigtable.table

                 self.name, start_key=start_key, end_key=end_key, filter_=filter_,
                 limit=limit)
             client = self._instance._client
    -        response_iterator = client._data_stub.ReadRows(request_pb,
    -                                                       client.timeout_seconds)
    +        response_iterator = client._data_stub.ReadRows(request_pb)
             # We expect an iterator of `data_messages_v2_pb2.ReadRowsResponse`
             return PartialRowsData(response_iterator)
    -
    [docs] def sample_row_keys(self): +
    [docs] def sample_row_keys(self): """Read a sample of row keys in the table. The returned row keys will delimit contiguous sections of the table of @@ -404,7 +556,7 @@

    Source code for gcloud.bigtable.table

             samples would require space roughly equal to the difference in their
             ``offset_bytes`` fields.
     
    -        :rtype: :class:`grpc.framework.alpha._reexport._CancellableIterator`
    +        :rtype: :class:`grpc._channel._Rendezvous`
             :returns: A cancel-able iterator. Can be consumed by calling ``next()``
                       or by casting to a :class:`list` and can be cancelled by
                       calling ``cancel()``.
    @@ -412,8 +564,7 @@ 

    Source code for gcloud.bigtable.table

             request_pb = data_messages_v2_pb2.SampleRowKeysRequest(
                 table_name=self.name)
             client = self._instance._client
    -        response_iterator = client._data_stub.SampleRowKeys(
    -            request_pb, client.timeout_seconds)
    +        response_iterator = client._data_stub.SampleRowKeys(request_pb)
             return response_iterator
    @@ -478,123 +629,62 @@

    Source code for gcloud.bigtable.table

         return message
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/client.html b/latest/_modules/google/cloud/client.html similarity index 68% rename from latest/_modules/gcloud/client.html rename to latest/_modules/google/cloud/client.html index 2949f474c00f..a6145e907b12 100644 --- a/latest/_modules/gcloud/client.html +++ b/latest/_modules/google/cloud/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.client
    • +
    • -

      Source code for gcloud.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -116,9 +271,9 @@ 

    Source code for gcloud.client

     from oauth2client.service_account import ServiceAccountCredentials
     import six
     
    -from gcloud._helpers import _determine_default_project
    -from gcloud.connection import Connection
    -from gcloud.credentials import get_credentials
    +from google.cloud._helpers import _determine_default_project
    +from google.cloud.connection import Connection
    +from google.cloud.credentials import get_credentials
     
     
     class _ClientFactoryMixin(object):
    @@ -147,7 +302,7 @@ 

    Source code for gcloud.client

             :type kwargs: dict
             :param kwargs: Remaining keyword arguments to pass to constructor.
     
    -        :rtype: :class:`gcloud.pubsub.client.Client`
    +        :rtype: :class:`google.cloud.pubsub.client.Client`
             :returns: The client created with the retrieved JSON credentials.
             :raises: :class:`TypeError` if there is a conflict with the kwargs
                      and the credentials created by the factory.
    @@ -182,7 +337,7 @@ 

    Source code for gcloud.client

             :type kwargs: dict
             :param kwargs: Remaining keyword arguments to pass to constructor.
     
    -        :rtype: :class:`gcloud.client.Client`
    +        :rtype: :class:`google.cloud.client.Client`
             :returns: The client created with the retrieved P12 credentials.
             :raises: :class:`TypeError` if there is a conflict with the kwargs
                      and the credentials created by the factory.
    @@ -195,7 +350,7 @@ 

    Source code for gcloud.client

             return cls(*args, **kwargs)
     
     
    -
    [docs]class Client(_ClientFactoryMixin): +
    [docs]class Client(_ClientFactoryMixin): """Client to bundle configuration needed for API requests. Assumes that the associated ``_connection_class`` only accepts @@ -253,7 +408,7 @@

    Source code for gcloud.client

             return _determine_default_project(project)
     
     
    -
    [docs]class JSONClient(Client, _ClientProjectMixin): +
    [docs]class JSONClient(Client, _ClientProjectMixin): """Client to for Google JSON-based API. Assumes such APIs use the ``project`` and the client needs to store this @@ -285,123 +440,62 @@

    Source code for gcloud.client

             Client.__init__(self, credentials=credentials, http=http)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/connection.html b/latest/_modules/google/cloud/connection.html similarity index 76% rename from latest/_modules/gcloud/connection.html rename to latest/_modules/google/cloud/connection.html index 8926c2a1d7e8..6fd54486d35b 100644 --- a/latest/_modules/gcloud/connection.html +++ b/latest/_modules/google/cloud/connection.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.connection — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.connection — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.connection
    • +
    • -

      Source code for gcloud.connection

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.connection

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -120,14 +275,14 @@ 

    Source code for gcloud.connection

     
     import httplib2
     
    -from gcloud.exceptions import make_exception
    +from google.cloud.exceptions import make_exception
     
     
     API_BASE_URL = 'https://www.googleapis.com'
     """The base of the API call URL."""
     
     
    -
    [docs]class Connection(object): +
    [docs]class Connection(object): """A generic connection to Google Cloud Platform. Subclasses should understand only the basic types in method arguments, @@ -162,8 +317,9 @@

    Source code for gcloud.connection

         :param http: An optional HTTP object to make requests.
         """
     
    -    USER_AGENT = "gcloud-python/{0}".format(get_distribution('gcloud').version)
    -    """The user agent for gcloud-python requests."""
    +    USER_AGENT = "google-cloud-python/{0}".format(
    +        get_distribution('google-cloud').version)
    +    """The user agent for google-cloud-python requests."""
     
         SCOPE = None
         """The scopes required for authenticating with a service.
    @@ -223,7 +379,7 @@ 

    Source code for gcloud.connection

             return credentials
    -
    [docs]class JSONConnection(Connection): +
    [docs]class JSONConnection(Connection): """A connection to a Google JSON-based API. These APIs are discovery based. For reference: @@ -252,7 +408,7 @@

    Source code for gcloud.connection

         """A template for the URL of a particular API call."""
     
         @classmethod
    -
    [docs] def build_api_url(cls, path, query_params=None, +
    [docs] def build_api_url(cls, path, query_params=None, api_base_url=None, api_version=None): """Construct an API url given a few components, some optional. @@ -368,7 +524,7 @@

    Source code for gcloud.connection

             return self.http.request(uri=url, method=method, headers=headers,
                                      body=data)
     
    -
    [docs] def api_request(self, method, path, query_params=None, +
    [docs] def api_request(self, method, path, query_params=None, data=None, content_type=None, api_base_url=None, api_version=None, expect_json=True, _target_object=None): @@ -409,7 +565,7 @@

    Source code for gcloud.connection

                                 you shouldn't provide this and instead use
                                 the default for the library.  Default is the
                                 latest API version supported by
    -                            gcloud-python.
    +                            google-cloud-python.
     
             :type expect_json: bool
             :param expect_json: If True, this method will try to parse the
    @@ -457,123 +613,62 @@ 

    Source code for gcloud.connection

             return content
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/credentials.html b/latest/_modules/google/cloud/credentials.html similarity index 69% rename from latest/_modules/gcloud/credentials.html rename to latest/_modules/google/cloud/credentials.html index 676012d63ee3..40b105951a6c 100644 --- a/latest/_modules/gcloud/credentials.html +++ b/latest/_modules/google/cloud/credentials.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.credentials — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.credentials — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.credentials
    • +
    • -

      Source code for gcloud.credentials

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.credentials

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -120,12 +275,12 @@ 

    Source code for gcloud.credentials

     
     from oauth2client import client
     
    -from gcloud._helpers import UTC
    -from gcloud._helpers import _NOW
    -from gcloud._helpers import _microseconds_from_datetime
    +from google.cloud._helpers import UTC
    +from google.cloud._helpers import _NOW
    +from google.cloud._helpers import _microseconds_from_datetime
     
     
    -
    [docs]def get_credentials(): +
    [docs]def get_credentials(): """Gets credentials implicitly from the current environment. .. note:: @@ -201,12 +356,12 @@

    Source code for gcloud.credentials

                   signed payload.
         """
         if not hasattr(credentials, 'sign_blob'):
    +        auth_uri = ('http://gcloud-python.readthedocs.io/en/latest/'
    +                    'gcloud-auth.html#setting-up-a-service-account')
             raise AttributeError('you need a private key to sign credentials.'
                                  'the credentials you are currently using %s '
    -                             'just contains a token. see https://googlecloud'
    -                             'platform.github.io/gcloud-python/stable/gcloud-'
    -                             'auth.html#setting-up-a-service-account for more '
    -                             'details.' % type(credentials))
    +                             'just contains a token. see %s for more '
    +                             'details.' % (type(credentials), auth_uri))
     
         _, signature_bytes = credentials.sign_blob(string_to_sign)
         signature = base64.b64encode(signature_bytes)
    @@ -245,7 +400,7 @@ 

    Source code for gcloud.credentials

         return expiration
     
     
    -
    [docs]def generate_signed_url(credentials, resource, expiration, +
    [docs]def generate_signed_url(credentials, resource, expiration, api_access_endpoint='', method='GET', content_md5=None, content_type=None, response_type=None, @@ -271,7 +426,7 @@

    Source code for gcloud.credentials

         See headers `reference`_ for more details on optional arguments.
     
         .. _Issue 922: https://github.com/GoogleCloudPlatform/\
    -                   gcloud-python/issues/922
    +                   google-cloud-python/issues/922
         .. _reference: https://cloud.google.com/storage/docs/reference-headers
     
         :type credentials: :class:`oauth2client.appengine.AppAssertionCredentials`
    @@ -345,123 +500,62 @@ 

    Source code for gcloud.credentials

             querystring=urlencode(query_params))
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/batch.html b/latest/_modules/google/cloud/datastore/batch.html similarity index 70% rename from latest/_modules/gcloud/datastore/batch.html rename to latest/_modules/google/cloud/datastore/batch.html index 0b9727891d96..fb979f2b9a9d 100644 --- a/latest/_modules/gcloud/datastore/batch.html +++ b/latest/_modules/google/cloud/datastore/batch.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.batch — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.batch — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.batch
    • +
    • -

      Source code for gcloud.datastore.batch

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.batch

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -120,20 +275,20 @@ 

    Source code for gcloud.datastore.batch

     https://cloud.google.com/datastore/docs/concepts/entities#Datastore_Batch_operations
     """
     
    -from gcloud.datastore import helpers
    -from gcloud.datastore._generated import datastore_pb2 as _datastore_pb2
    +from google.cloud.datastore import helpers
    +from google.cloud.datastore._generated import datastore_pb2 as _datastore_pb2
     
     
    -
    [docs]class Batch(object): +
    [docs]class Batch(object): """An abstraction representing a collected group of updates / deletes. - Used to build up a bulk mutuation. + Used to build up a bulk mutation. For example, the following snippet of code will put the two ``save`` operations and the ``delete`` operation into the same mutation, and send them to the server in a single API request:: - >>> from gcloud import datastore + >>> from google.cloud import datastore >>> client = datastore.Client() >>> batch = client.batch() >>> batch.put(entity1) @@ -156,7 +311,7 @@

    Source code for gcloud.datastore.batch

           ...     do_some_work(batch)
           ...     raise Exception()  # rolls back
     
    -    :type client: :class:`gcloud.datastore.client.Client`
    +    :type client: :class:`google.cloud.datastore.client.Client`
         :param client: The client used to connect to datastore.
         """
     
    @@ -180,7 +335,7 @@ 

    Source code for gcloud.datastore.batch

             self._partial_key_entities = []
             self._status = self._INITIAL
     
    -
    [docs] def current(self): +
    [docs] def current(self): """Return the topmost batch / transaction, or None.""" return self._client.current_batch
    @@ -206,7 +361,7 @@

    Source code for gcloud.datastore.batch

         def connection(self):
             """Getter for connection over which the batch will run.
     
    -        :rtype: :class:`gcloud.datastore.connection.Connection`
    +        :rtype: :class:`google.cloud.datastore.connection.Connection`
             :returns: The connection over which the batch will run.
             """
             return self._client.connection
    @@ -214,7 +369,7 @@ 

    Source code for gcloud.datastore.batch

         def _add_partial_key_entity_pb(self):
             """Adds a new mutation for an entity with a partial key.
     
    -        :rtype: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +        :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Entity`
             :returns: The newly created entity protobuf that will be
                       updated and sent with a commit.
             """
    @@ -224,7 +379,7 @@ 

    Source code for gcloud.datastore.batch

         def _add_complete_key_entity_pb(self):
             """Adds a new mutation for an entity with a completed key.
     
    -        :rtype: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +        :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Entity`
             :returns: The newly created entity protobuf that will be
                       updated and sent with a commit.
             """
    @@ -237,7 +392,7 @@ 

    Source code for gcloud.datastore.batch

         def _add_delete_key_pb(self):
             """Adds a new mutation for a key to be deleted.
     
    -        :rtype: :class:`gcloud.datastore._generated.entity_pb2.Key`
    +        :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Key`
             :returns: The newly created key protobuf that will be
                       deleted when sent with a commit.
             """
    @@ -260,7 +415,7 @@ 

    Source code for gcloud.datastore.batch

             """
             return self._commit_request.mutations
     
    -
    [docs] def put(self, entity): +
    [docs] def put(self, entity): """Remember an entity's state to be saved during :meth:`commit`. .. note:: @@ -279,7 +434,7 @@

    Source code for gcloud.datastore.batch

             the key for the ``entity`` passed in is updated to match the key ID
             assigned by the server.
     
    -        :type entity: :class:`gcloud.datastore.entity.Entity`
    +        :type entity: :class:`google.cloud.datastore.entity.Entity`
             :param entity: the entity to be saved.
     
             :raises: ValueError if entity has no key assigned, or if the key's
    @@ -299,10 +454,10 @@ 

    Source code for gcloud.datastore.batch

     
             _assign_entity_to_pb(entity_pb, entity)
    -
    [docs] def delete(self, key): +
    [docs] def delete(self, key): """Remember a key to be deleted during :meth:`commit`. - :type key: :class:`gcloud.datastore.key.Key` + :type key: :class:`google.cloud.datastore.key.Key` :param key: the key to be deleted. :raises: ValueError if key is not complete, or if the key's @@ -317,14 +472,14 @@

    Source code for gcloud.datastore.batch

             key_pb = key.to_protobuf()
             self._add_delete_key_pb().CopyFrom(key_pb)
    -
    [docs] def begin(self): +
    [docs] def begin(self): """Begins a batch. This method is called automatically when entering a with statement, however it can be called explicitly if you don't want to use a context manager. - Overridden by :class:`gcloud.datastore.transaction.Transaction`. + Overridden by :class:`google.cloud.datastore.transaction.Transaction`. :raises: :class:`ValueError` if the batch has already begun. """ @@ -348,7 +503,7 @@

    Source code for gcloud.datastore.batch

                 new_id = new_key_pb.path[-1].id
                 entity.key = entity.key.completed_key(new_id)
     
    -
    [docs] def commit(self): +
    [docs] def commit(self): """Commits the batch. This is called automatically upon exiting a with statement, @@ -360,12 +515,12 @@

    Source code for gcloud.datastore.batch

             finally:
                 self._status = self._FINISHED
    -
    [docs] def rollback(self): +
    [docs] def rollback(self): """Rolls back the current batch. Marks the batch as aborted (can't be used again). - Overridden by :class:`gcloud.datastore.transaction.Transaction`. + Overridden by :class:`google.cloud.datastore.transaction.Transaction`. """ self._status = self._ABORTED
    @@ -389,10 +544,10 @@

    Source code for gcloud.datastore.batch

     
         Helper method for ``Batch.put``.
     
    -    :type entity_pb: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +    :type entity_pb: :class:`._generated.entity_pb2.Entity`
         :param entity_pb: The entity owned by a mutation.
     
    -    :type entity: :class:`gcloud.datastore.entity.Entity`
    +    :type entity: :class:`google.cloud.datastore.entity.Entity`
         :param entity: The entity being updated within the batch / transaction.
         """
         bare_entity_pb = helpers.entity_to_protobuf(entity)
    @@ -400,123 +555,62 @@ 

    Source code for gcloud.datastore.batch

         entity_pb.CopyFrom(bare_entity_pb)
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/client.html b/latest/_modules/google/cloud/datastore/client.html similarity index 68% rename from latest/_modules/gcloud/datastore/client.html rename to latest/_modules/google/cloud/datastore/client.html index 604be941b33f..32d40c0cc3fb 100644 --- a/latest/_modules/gcloud/datastore/client.html +++ b/latest/_modules/google/cloud/datastore/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + -
    +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.client
    • +
    • -

      Source code for gcloud.datastore.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.client

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,18 +269,19 @@ 

    Source code for gcloud.datastore.client

     
     import os
     
    -from gcloud._helpers import _LocalStack
    -from gcloud._helpers import _determine_default_project as _base_default_project
    -from gcloud.client import _ClientProjectMixin
    -from gcloud.client import Client as _BaseClient
    -from gcloud.datastore import helpers
    -from gcloud.datastore.connection import Connection
    -from gcloud.datastore.batch import Batch
    -from gcloud.datastore.entity import Entity
    -from gcloud.datastore.key import Key
    -from gcloud.datastore.query import Query
    -from gcloud.datastore.transaction import Transaction
    -from gcloud.environment_vars import GCD_DATASET
    +from google.cloud._helpers import _LocalStack
    +from google.cloud._helpers import (
    +    _determine_default_project as _base_default_project)
    +from google.cloud.client import _ClientProjectMixin
    +from google.cloud.client import Client as _BaseClient
    +from google.cloud.datastore import helpers
    +from google.cloud.datastore.connection import Connection
    +from google.cloud.datastore.batch import Batch
    +from google.cloud.datastore.entity import Entity
    +from google.cloud.datastore.key import Key
    +from google.cloud.datastore.query import Query
    +from google.cloud.datastore.transaction import Transaction
    +from google.cloud.environment_vars import GCD_DATASET
     
     
     _MAX_LOOPS = 128
    @@ -144,7 +300,7 @@ 

    Source code for gcloud.datastore.client

         implicit environments are:
     
         * DATASTORE_DATASET environment variable (for ``gcd`` / emulator testing)
    -    * GCLOUD_PROJECT environment variable
    +    * GOOGLE_CLOUD_PROJECT environment variable
         * Google App Engine application ID
         * Google Compute Engine project ID (from metadata server)
     
    @@ -170,13 +326,13 @@ 

    Source code for gcloud.datastore.client

     
         Helper function for :meth:`Client.get_multi`.
     
    -    :type connection: :class:`gcloud.datastore.connection.Connection`
    +    :type connection: :class:`google.cloud.datastore.connection.Connection`
         :param connection: The connection used to connect to datastore.
     
         :type project: string
         :param project: The project to make the request for.
     
    -    :type key_pbs: list of :class:`gcloud.datastore._generated.entity_pb2.Key`
    +    :type key_pbs: list of :class:`._generated.entity_pb2.Key`
         :param key_pbs: The keys to retrieve from the datastore.
     
         :type missing: list
    @@ -198,7 +354,7 @@ 

    Source code for gcloud.datastore.client

                                the given transaction.  Incompatible with
                                ``eventual==True``.
     
    -    :rtype: list of :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +    :rtype: list of :class:`._generated.entity_pb2.Entity`
         :returns: The requested entities.
         :raises: :class:`ValueError` if missing / deferred are not null or
                  empty list.
    @@ -241,7 +397,7 @@ 

    Source code for gcloud.datastore.client

         return results
     
     
    -
    [docs]class Client(_BaseClient, _ClientProjectMixin): +
    [docs]class Client(_BaseClient, _ClientProjectMixin): """Convenience wrapper for invoking APIs/factories w/ a project. :type project: string @@ -281,7 +437,7 @@

    Source code for gcloud.datastore.client

     
             "Protected", intended for use by batch / transaction context mgrs.
     
    -        :type batch: :class:`gcloud.datastore.batch.Batch`, or an object
    +        :type batch: :class:`google.cloud.datastore.batch.Batch`, or an object
                          implementing its API.
             :param batch: newly-active batch/transaction.
             """
    @@ -293,7 +449,7 @@ 

    Source code for gcloud.datastore.client

             "Protected", intended for use by batch / transaction context mgrs.
     
             :raises: IndexError if the stack is empty.
    -        :rtype: :class:`gcloud.datastore.batch.Batch`, or an object
    +        :rtype: :class:`google.cloud.datastore.batch.Batch`, or an object
                      implementing its API.
             :returns: the top-most batch/transaction, after removing it.
             """
    @@ -303,7 +459,7 @@ 

    Source code for gcloud.datastore.client

         def current_batch(self):
             """Currently-active batch.
     
    -        :rtype: :class:`gcloud.datastore.batch.Batch`, or an object
    +        :rtype: :class:`google.cloud.datastore.batch.Batch`, or an object
                     implementing its API, or ``NoneType`` (if no batch is active).
             :returns: The batch/transaction at the top of the batch stack.
             """
    @@ -313,16 +469,16 @@ 

    Source code for gcloud.datastore.client

         def current_transaction(self):
             """Currently-active transaction.
     
    -        :rtype: :class:`gcloud.datastore.transaction.Transaction`, or an object
    -                implementing its API, or ``NoneType`` (if no transaction is
    -                active).
    +        :rtype: :class:`google.cloud.datastore.transaction.Transaction`, or an
    +                object implementing its API, or ``NoneType`` (if no transaction
    +                is active).
             :returns: The transaction at the top of the batch stack.
             """
             transaction = self.current_batch
             if isinstance(transaction, Transaction):
                 return transaction
     
    -
    [docs] def get(self, key, missing=None, deferred=None, transaction=None): +
    [docs] def get(self, key, missing=None, deferred=None, transaction=None): """Retrieve an entity from a single key (if it exists). .. note:: @@ -331,7 +487,7 @@

    Source code for gcloud.datastore.client

                The backend API does not make a distinction between a single key or
                multiple keys in a lookup request.
     
    -        :type key: :class:`gcloud.datastore.key.Key`
    +        :type key: :class:`google.cloud.datastore.key.Key`
             :param key: The key to be retrieved from the datastore.
     
             :type missing: list
    @@ -343,11 +499,11 @@ 

    Source code for gcloud.datastore.client

             :param deferred: (Optional) If a list is passed, the keys returned
                              by the backend as "deferred" will be copied into it.
     
    -        :type transaction: :class:`gcloud.datastore.transaction.Transaction`
    +        :type transaction: :class:`~.transaction.Transaction`
             :param transaction: (Optional) Transaction to use for read consistency.
                                 If not passed, uses current transaction, if set.
     
    -        :rtype: :class:`gcloud.datastore.entity.Entity` or ``NoneType``
    +        :rtype: :class:`google.cloud.datastore.entity.Entity` or ``NoneType``
             :returns: The requested entity if it exists.
             """
             entities = self.get_multi(keys=[key], missing=missing,
    @@ -355,10 +511,10 @@ 

    Source code for gcloud.datastore.client

             if entities:
                 return entities[0]
    -
    [docs] def get_multi(self, keys, missing=None, deferred=None, transaction=None): +
    [docs] def get_multi(self, keys, missing=None, deferred=None, transaction=None): """Retrieve entities, along with their attributes. - :type keys: list of :class:`gcloud.datastore.key.Key` + :type keys: list of :class:`google.cloud.datastore.key.Key` :param keys: The keys to be retrieved from the datastore. :type missing: list @@ -371,11 +527,11 @@

    Source code for gcloud.datastore.client

                              by the backend as "deferred" will be copied into it.
                              If the list is not empty, an error will occur.
     
    -        :type transaction: :class:`gcloud.datastore.transaction.Transaction`
    +        :type transaction: :class:`~.transaction.Transaction`
             :param transaction: (Optional) Transaction to use for read consistency.
                                 If not passed, uses current transaction, if set.
     
    -        :rtype: list of :class:`gcloud.datastore.entity.Entity`
    +        :rtype: list of :class:`google.cloud.datastore.entity.Entity`
             :returns: The requested entities.
             :raises: :class:`ValueError` if one or more of ``keys`` has a project
                      which does not match our project.
    @@ -413,7 +569,7 @@ 

    Source code for gcloud.datastore.client

             return [helpers.entity_from_protobuf(entity_pb)
                     for entity_pb in entity_pbs]
    -
    [docs] def put(self, entity): +
    [docs] def put(self, entity): """Save an entity in the Cloud Datastore. .. note:: @@ -422,15 +578,15 @@

    Source code for gcloud.datastore.client

                The backend API does not make a distinction between a single
                entity or multiple entities in a commit request.
     
    -        :type entity: :class:`gcloud.datastore.entity.Entity`
    +        :type entity: :class:`google.cloud.datastore.entity.Entity`
             :param entity: The entity to be saved to the datastore.
             """
             self.put_multi(entities=[entity])
    -
    [docs] def put_multi(self, entities): +
    [docs] def put_multi(self, entities): """Save entities in the Cloud Datastore. - :type entities: list of :class:`gcloud.datastore.entity.Entity` + :type entities: list of :class:`google.cloud.datastore.entity.Entity` :param entities: The entities to be saved to the datastore. :raises: :class:`ValueError` if ``entities`` is a single entity. @@ -453,7 +609,7 @@

    Source code for gcloud.datastore.client

             if not in_batch:
                 current.commit()
    -
    [docs] def delete(self, key): +
    [docs] def delete(self, key): """Delete the key in the Cloud Datastore. .. note:: @@ -462,16 +618,16 @@

    Source code for gcloud.datastore.client

                The backend API does not make a distinction between a single key or
                multiple keys in a commit request.
     
    -        :type key: :class:`gcloud.datastore.key.Key`
    +        :type key: :class:`google.cloud.datastore.key.Key`
             :param key: The key to be deleted from the datastore.
             """
             self.delete_multi(keys=[key])
    -
    [docs] def delete_multi(self, keys): +
    [docs] def delete_multi(self, keys): """Delete keys from the Cloud Datastore. - :type keys: list of :class:`gcloud.datastore.key.Key` - :param keys: The keys to be deleted from the datastore. + :type keys: list of :class:`google.cloud.datastore.key.Key` + :param keys: The keys to be deleted from the Datastore. """ if not keys: return @@ -489,16 +645,16 @@

    Source code for gcloud.datastore.client

             if not in_batch:
                 current.commit()
    -
    [docs] def allocate_ids(self, incomplete_key, num_ids): +
    [docs] def allocate_ids(self, incomplete_key, num_ids): """Allocate a list of IDs from a partial key. - :type incomplete_key: :class:`gcloud.datastore.key.Key` + :type incomplete_key: :class:`google.cloud.datastore.key.Key` :param incomplete_key: Partial key to use as base for allocated IDs. :type num_ids: int :param num_ids: The number of IDs to allocate. - :rtype: list of :class:`gcloud.datastore.key.Key` + :rtype: list of :class:`google.cloud.datastore.key.Key` :returns: The (complete) keys allocated with ``incomplete_key`` as root. :raises: :class:`ValueError` if ``incomplete_key`` is not a @@ -518,8 +674,8 @@

    Source code for gcloud.datastore.client

             return [incomplete_key.completed_key(allocated_id)
                     for allocated_id in allocated_ids]
    -
    [docs] def key(self, *path_args, **kwargs): - """Proxy to :class:`gcloud.datastore.key.Key`. +
    [docs] def key(self, *path_args, **kwargs): + """Proxy to :class:`google.cloud.datastore.key.Key`. Passes our ``project``. """ @@ -530,18 +686,49 @@

    Source code for gcloud.datastore.client

                 kwargs['namespace'] = self.namespace
             return Key(*path_args, **kwargs)
    -
    [docs] def batch(self): - """Proxy to :class:`gcloud.datastore.batch.Batch`.""" +
    [docs] def batch(self): + """Proxy to :class:`google.cloud.datastore.batch.Batch`.""" return Batch(self)
    -
    [docs] def transaction(self): - """Proxy to :class:`gcloud.datastore.transaction.Transaction`.""" +
    [docs] def transaction(self): + """Proxy to :class:`google.cloud.datastore.transaction.Transaction`.""" return Transaction(self)
    -
    [docs] def query(self, **kwargs): - """Proxy to :class:`gcloud.datastore.query.Query`. +
    [docs] def query(self, **kwargs): + """Proxy to :class:`google.cloud.datastore.query.Query`. Passes our ``project``. + + Using query to search a datastore:: + + >>> from google.cloud import datastore + >>> client = datastore.Client() + >>> query = client.query(kind='MyKind') + >>> query.add_filter('property', '=', 'val') + + Using the query iterator's + :meth:`~google.cloud.datastore.query.Iterator.next_page` method: + + >>> query_iter = query.fetch() + >>> entities, more_results, cursor = query_iter.next_page() + >>> entities + [<list of Entity unmarshalled from protobuf>] + >>> more_results + <boolean of more results> + >>> cursor + <string containing cursor where fetch stopped> + + Under the hood this is doing: + + >>> connection.run_query('project', query.to_protobuf()) + [<list of Entity Protobufs>], cursor, more_results, skipped_results + + :type kwargs: dict + :param kwargs: Parameters for initializing and instance of + :class:`google.cloud.datastore.query.Query`. + + :rtype: :class:`google.cloud.datastore.query.Query` + :returns: An instance of :class:`google.cloud.datastore.query.Query` """ if 'client' in kwargs: raise TypeError('Cannot pass client') @@ -553,123 +740,62 @@

    Source code for gcloud.datastore.client

             return Query(self, **kwargs)
    -
    -
    + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/datastore/connection.html b/latest/_modules/google/cloud/datastore/connection.html new file mode 100644 index 000000000000..003fd45814f2 --- /dev/null +++ b/latest/_modules/google/cloud/datastore/connection.html @@ -0,0 +1,988 @@ + + + + + + + + + + + google.cloud.datastore.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.connection

    +# Copyright 2014 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Connections to Google Cloud Datastore API servers."""
    +
    +import os
    +
    +from google.rpc import status_pb2
    +
    +from google.cloud._helpers import make_insecure_stub
    +from google.cloud._helpers import make_secure_stub
    +from google.cloud import connection as connection_module
    +from google.cloud.environment_vars import DISABLE_GRPC
    +from google.cloud.environment_vars import GCD_HOST
    +from google.cloud.exceptions import Conflict
    +from google.cloud.exceptions import make_exception
    +from google.cloud.datastore._generated import datastore_pb2 as _datastore_pb2
    +# pylint: disable=ungrouped-imports
    +try:
    +    from grpc import StatusCode
    +    from grpc._channel import _Rendezvous
    +    from google.cloud.datastore._generated import datastore_grpc_pb2
    +except ImportError:  # pragma: NO COVER
    +    _HAVE_GRPC = False
    +    datastore_grpc_pb2 = None
    +    StatusCode = None
    +    _Rendezvous = Exception
    +else:
    +    _HAVE_GRPC = True
    +# pylint: enable=ungrouped-imports
    +
    +
    +DATASTORE_API_HOST = 'datastore.googleapis.com'
    +"""Datastore API request host."""
    +
    +_DISABLE_GRPC = os.getenv(DISABLE_GRPC, False)
    +_USE_GRPC = _HAVE_GRPC and not _DISABLE_GRPC
    +
    +
    +class _DatastoreAPIOverHttp(object):
    +    """Helper mapping datastore API methods.
    +
    +    Makes requests to send / receive protobuf content over HTTP/1.1.
    +
    +    Methods make bare API requests without any helpers for constructing
    +    the requests or parsing the responses.
    +
    +    :type connection: :class:`google.cloud.datastore.connection.Connection`
    +    :param connection: A connection object that contains helpful
    +                       information for making requests.
    +    """
    +
    +    def __init__(self, connection):
    +        self.connection = connection
    +
    +    def _request(self, project, method, data):
    +        """Make a request over the Http transport to the Cloud Datastore API.
    +
    +        :type project: string
    +        :param project: The project to make the request for.
    +
    +        :type method: string
    +        :param method: The API call method name (ie, ``runQuery``,
    +                       ``lookup``, etc)
    +
    +        :type data: string
    +        :param data: The data to send with the API call.
    +                     Typically this is a serialized Protobuf string.
    +
    +        :rtype: string
    +        :returns: The string response content from the API call.
    +        :raises: :class:`google.cloud.exceptions.GoogleCloudError` if the
    +                 response code is not 200 OK.
    +        """
    +        headers = {
    +            'Content-Type': 'application/x-protobuf',
    +            'Content-Length': str(len(data)),
    +            'User-Agent': self.connection.USER_AGENT,
    +        }
    +        headers, content = self.connection.http.request(
    +            uri=self.connection.build_api_url(project=project, method=method),
    +            method='POST', headers=headers, body=data)
    +
    +        status = headers['status']
    +        if status != '200':
    +            error_status = status_pb2.Status.FromString(content)
    +            raise make_exception(headers, error_status.message, use_json=False)
    +
    +        return content
    +
    +    def _rpc(self, project, method, request_pb, response_pb_cls):
    +        """Make a protobuf RPC request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type method: string
    +        :param method: The name of the method to invoke.
    +
    +        :type request_pb: :class:`google.protobuf.message.Message` instance
    +        :param request_pb: the protobuf instance representing the request.
    +
    +        :type response_pb_cls: A :class:`google.protobuf.message.Message`
    +                               subclass.
    +        :param response_pb_cls: The class used to unmarshall the response
    +                                protobuf.
    +
    +        :rtype: :class:`google.protobuf.message.Message`
    +        :returns: The RPC message parsed from the response.
    +        """
    +        response = self._request(project=project, method=method,
    +                                 data=request_pb.SerializeToString())
    +        return response_pb_cls.FromString(response)
    +
    +    def lookup(self, project, request_pb):
    +        """Perform a ``lookup`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.LookupRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.LookupResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'lookup', request_pb,
    +                         _datastore_pb2.LookupResponse)
    +
    +    def run_query(self, project, request_pb):
    +        """Perform a ``runQuery`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.RunQueryRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.RunQueryResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'runQuery', request_pb,
    +                         _datastore_pb2.RunQueryResponse)
    +
    +    def begin_transaction(self, project, request_pb):
    +        """Perform a ``beginTransaction`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb:
    +            :class:`._generated.datastore_pb2.BeginTransactionRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.BeginTransactionResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'beginTransaction', request_pb,
    +                         _datastore_pb2.BeginTransactionResponse)
    +
    +    def commit(self, project, request_pb):
    +        """Perform a ``commit`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.CommitRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.CommitResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'commit', request_pb,
    +                         _datastore_pb2.CommitResponse)
    +
    +    def rollback(self, project, request_pb):
    +        """Perform a ``rollback`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.RollbackRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.RollbackResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'rollback', request_pb,
    +                         _datastore_pb2.RollbackResponse)
    +
    +    def allocate_ids(self, project, request_pb):
    +        """Perform an ``allocateIds`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.AllocateIdsRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.AllocateIdsResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        return self._rpc(project, 'allocateIds', request_pb,
    +                         _datastore_pb2.AllocateIdsResponse)
    +
    +
    +class _DatastoreAPIOverGRPC(object):
    +    """Helper mapping datastore API methods.
    +
    +    Makes requests to send / receive protobuf content over gRPC.
    +
    +    Methods make bare API requests without any helpers for constructing
    +    the requests or parsing the responses.
    +
    +    :type connection: :class:`google.cloud.datastore.connection.Connection`
    +    :param connection: A connection object that contains helpful
    +                       information for making requests.
    +
    +    :type secure: bool
    +    :param secure: Flag indicating if a secure stub connection is needed.
    +    """
    +
    +    def __init__(self, connection, secure):
    +        if secure:
    +            self._stub = make_secure_stub(connection.credentials,
    +                                          connection.USER_AGENT,
    +                                          datastore_grpc_pb2.DatastoreStub,
    +                                          connection.host)
    +        else:
    +            self._stub = make_insecure_stub(datastore_grpc_pb2.DatastoreStub,
    +                                            connection.host)
    +
    +    def lookup(self, project, request_pb):
    +        """Perform a ``lookup`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.LookupRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.LookupResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        return self._stub.Lookup(request_pb)
    +
    +    def run_query(self, project, request_pb):
    +        """Perform a ``runQuery`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.RunQueryRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.RunQueryResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        return self._stub.RunQuery(request_pb)
    +
    +    def begin_transaction(self, project, request_pb):
    +        """Perform a ``beginTransaction`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb:
    +            :class:`._generated.datastore_pb2.BeginTransactionRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.BeginTransactionResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        return self._stub.BeginTransaction(request_pb)
    +
    +    def commit(self, project, request_pb):
    +        """Perform a ``commit`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.CommitRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.CommitResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        try:
    +            return self._stub.Commit(request_pb)
    +        except _Rendezvous as exc:
    +            if exc.code() == StatusCode.ABORTED:
    +                raise Conflict(exc.details())
    +            raise
    +
    +    def rollback(self, project, request_pb):
    +        """Perform a ``rollback`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.RollbackRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.RollbackResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        return self._stub.Rollback(request_pb)
    +
    +    def allocate_ids(self, project, request_pb):
    +        """Perform an ``allocateIds`` request.
    +
    +        :type project: string
    +        :param project: The project to connect to. This is
    +                        usually your project name in the cloud console.
    +
    +        :type request_pb: :class:`._generated.datastore_pb2.AllocateIdsRequest`
    +        :param request_pb: The request protobuf object.
    +
    +        :rtype: :class:`._generated.datastore_pb2.AllocateIdsResponse`
    +        :returns: The returned protobuf response object.
    +        """
    +        request_pb.project_id = project
    +        return self._stub.AllocateIds(request_pb)
    +
    +
    +
    [docs]class Connection(connection_module.Connection): + """A connection to the Google Cloud Datastore via the Protobuf API. + + This class should understand only the basic types (and protobufs) + in method arguments, however it should be capable of returning advanced + types. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` + :param credentials: The OAuth2 Credentials to use for this connection. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: An optional HTTP object to make requests. + """ + + API_BASE_URL = 'https://' + DATASTORE_API_HOST + """The base of the API call URL.""" + + API_VERSION = 'v1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = ('{api_base}/{api_version}/projects' + '/{project}:{method}') + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/datastore',) + """The scopes required for authenticating as a Cloud Datastore consumer.""" + + def __init__(self, credentials=None, http=None): + super(Connection, self).__init__(credentials=credentials, http=http) + try: + self.host = os.environ[GCD_HOST] + self.api_base_url = 'http://' + self.host + secure = False + except KeyError: + self.host = DATASTORE_API_HOST + self.api_base_url = self.__class__.API_BASE_URL + secure = True + if _USE_GRPC: + self._datastore_api = _DatastoreAPIOverGRPC(self, secure=secure) + else: + self._datastore_api = _DatastoreAPIOverHttp(self) + +
    [docs] def build_api_url(self, project, method, base_url=None, + api_version=None): + """Construct the URL for a particular API call. + + This method is used internally to come up with the URL to use when + making RPCs to the Cloud Datastore API. + + :type project: string + :param project: The project to connect to. This is + usually your project name in the cloud console. + + :type method: string + :param method: The API method to call (e.g. 'runQuery', 'lookup'). + + :type base_url: string + :param base_url: The base URL where the API lives. + You shouldn't have to provide this. + + :type api_version: string + :param api_version: The version of the API to connect to. + You shouldn't have to provide this. + + :rtype: str + :returns: The API URL created. + """ + return self.API_URL_TEMPLATE.format( + api_base=(base_url or self.api_base_url), + api_version=(api_version or self.API_VERSION), + project=project, method=method)
    + +
    [docs] def lookup(self, project, key_pbs, + eventual=False, transaction_id=None): + """Lookup keys from a project in the Cloud Datastore. + + Maps the ``DatastoreService.Lookup`` protobuf RPC. + + This uses mostly protobufs + (:class:`google.cloud.datastore._generated.entity_pb2.Key` as input + and :class:`google.cloud.datastore._generated.entity_pb2.Entity` + as output). It is used under the hood in + :meth:`Client.get() <.datastore.client.Client.get>`: + + >>> from google.cloud import datastore + >>> client = datastore.Client(project='project') + >>> key = client.key('MyKind', 1234) + >>> client.get(key) + [<Entity object>] + + Using a :class:`Connection` directly: + + >>> connection.lookup('project', [key.to_protobuf()]) + [<Entity protobuf>] + + :type project: string + :param project: The project to look up the keys in. + + :type key_pbs: list of + :class:`google.cloud.datastore._generated.entity_pb2.Key` + :param key_pbs: The keys to retrieve from the datastore. + + :type eventual: bool + :param eventual: If False (the default), request ``STRONG`` read + consistency. If True, request ``EVENTUAL`` read + consistency. + + :type transaction_id: string + :param transaction_id: If passed, make the request in the scope of + the given transaction. Incompatible with + ``eventual==True``. + + :rtype: tuple + :returns: A triple of (``results``, ``missing``, ``deferred``) where + both ``results`` and ``missing`` are lists of + :class:`google.cloud.datastore._generated.entity_pb2.Entity` + and ``deferred`` is a list of + :class:`google.cloud.datastore._generated.entity_pb2.Key`. + """ + lookup_request = _datastore_pb2.LookupRequest() + _set_read_options(lookup_request, eventual, transaction_id) + _add_keys_to_request(lookup_request.keys, key_pbs) + + lookup_response = self._datastore_api.lookup(project, lookup_request) + + results = [result.entity for result in lookup_response.found] + missing = [result.entity for result in lookup_response.missing] + + return results, missing, list(lookup_response.deferred)
    + +
    [docs] def run_query(self, project, query_pb, namespace=None, + eventual=False, transaction_id=None): + """Run a query on the Cloud Datastore. + + Maps the ``DatastoreService.RunQuery`` protobuf RPC. + + Given a Query protobuf, sends a ``runQuery`` request to the + Cloud Datastore API and returns a list of entity protobufs + matching the query. + + You typically wouldn't use this method directly, in favor of the + :meth:`google.cloud.datastore.query.Query.fetch` method. + + Under the hood, the :class:`google.cloud.datastore.query.Query` class + uses this method to fetch data. + + :type project: string + :param project: The project over which to run the query. + + :type query_pb: :class:`.datastore._generated.query_pb2.Query` + :param query_pb: The Protobuf representing the query to run. + + :type namespace: string + :param namespace: The namespace over which to run the query. + + :type eventual: bool + :param eventual: If False (the default), request ``STRONG`` read + consistency. If True, request ``EVENTUAL`` read + consistency. + + :type transaction_id: string + :param transaction_id: If passed, make the request in the scope of + the given transaction. Incompatible with + ``eventual==True``. + + :rtype: tuple + :returns: Four-tuple containing the entities returned, + the end cursor of the query, a ``more_results`` + enum and a count of the number of skipped results. + """ + request = _datastore_pb2.RunQueryRequest() + _set_read_options(request, eventual, transaction_id) + + if namespace: + request.partition_id.namespace_id = namespace + + request.query.CopyFrom(query_pb) + response = self._datastore_api.run_query(project, request) + return ( + [e.entity for e in response.batch.entity_results], + response.batch.end_cursor, # Assume response always has cursor. + response.batch.more_results, + response.batch.skipped_results, + )
    + +
    [docs] def begin_transaction(self, project): + """Begin a transaction. + + Maps the ``DatastoreService.BeginTransaction`` protobuf RPC. + + :type project: string + :param project: The project to which the transaction applies. + + :rtype: bytes + :returns: The serialized transaction that was begun. + """ + request = _datastore_pb2.BeginTransactionRequest() + response = self._datastore_api.begin_transaction(project, request) + return response.transaction
    + +
    [docs] def commit(self, project, request, transaction_id): + """Commit mutations in context of current transaction (if any). + + Maps the ``DatastoreService.Commit`` protobuf RPC. + + :type project: string + :param project: The project to which the transaction applies. + + :type request: :class:`._generated.datastore_pb2.CommitRequest` + :param request: The protobuf with the mutations being committed. + + :type transaction_id: string or None + :param transaction_id: The transaction ID returned from + :meth:`begin_transaction`. Non-transactional + batches must pass ``None``. + + .. note:: + + This method will mutate ``request`` before using it. + + :rtype: tuple + :returns: The pair of the number of index updates and a list of + :class:`._generated.entity_pb2.Key` for each incomplete key + that was completed in the commit. + """ + if transaction_id: + request.mode = _datastore_pb2.CommitRequest.TRANSACTIONAL + request.transaction = transaction_id + else: + request.mode = _datastore_pb2.CommitRequest.NON_TRANSACTIONAL + + response = self._datastore_api.commit(project, request) + return _parse_commit_response(response)
    + +
    [docs] def rollback(self, project, transaction_id): + """Rollback the connection's existing transaction. + + Maps the ``DatastoreService.Rollback`` protobuf RPC. + + :type project: string + :param project: The project to which the transaction belongs. + + :type transaction_id: string + :param transaction_id: The transaction ID returned from + :meth:`begin_transaction`. + """ + request = _datastore_pb2.RollbackRequest() + request.transaction = transaction_id + # Nothing to do with this response, so just execute the method. + self._datastore_api.rollback(project, request)
    + +
    [docs] def allocate_ids(self, project, key_pbs): + """Obtain backend-generated IDs for a set of keys. + + Maps the ``DatastoreService.AllocateIds`` protobuf RPC. + + :type project: string + :param project: The project to which the transaction belongs. + + :type key_pbs: list of + :class:`google.cloud.datastore._generated.entity_pb2.Key` + :param key_pbs: The keys for which the backend should allocate IDs. + + :rtype: list of :class:`.datastore._generated.entity_pb2.Key` + :returns: An equal number of keys, with IDs filled in by the backend. + """ + request = _datastore_pb2.AllocateIdsRequest() + _add_keys_to_request(request.keys, key_pbs) + # Nothing to do with this response, so just execute the method. + response = self._datastore_api.allocate_ids(project, request) + return list(response.keys)
    + + +def _set_read_options(request, eventual, transaction_id): + """Validate rules for read options, and assign to the request. + + Helper method for ``lookup()`` and ``run_query``. + + :raises: :class:`ValueError` if ``eventual`` is ``True`` and the + ``transaction_id`` is not ``None``. + """ + if eventual and (transaction_id is not None): + raise ValueError('eventual must be False when in a transaction') + + opts = request.read_options + if eventual: + opts.read_consistency = _datastore_pb2.ReadOptions.EVENTUAL + elif transaction_id: + opts.transaction = transaction_id + + +def _add_keys_to_request(request_field_pb, key_pbs): + """Add protobuf keys to a request object. + + :type request_field_pb: `RepeatedCompositeFieldContainer` + :param request_field_pb: A repeated proto field that contains keys. + + :type key_pbs: list of :class:`.datastore._generated.entity_pb2.Key` + :param key_pbs: The keys to add to a request. + """ + for key_pb in key_pbs: + request_field_pb.add().CopyFrom(key_pb) + + +def _parse_commit_response(commit_response_pb): + """Extract response data from a commit response. + + :type commit_response_pb: :class:`._generated.datastore_pb2.CommitResponse` + :param commit_response_pb: The protobuf response from a commit request. + + :rtype: tuple + :returns: The pair of the number of index updates and a list of + :class:`._generated.entity_pb2.Key` for each incomplete key + that was completed in the commit. + """ + mut_results = commit_response_pb.mutation_results + index_updates = commit_response_pb.index_updates + completed_keys = [mut_result.key for mut_result in mut_results + if mut_result.HasField('key')] # Message field (Key) + return index_updates, completed_keys +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/entity.html b/latest/_modules/google/cloud/datastore/entity.html similarity index 62% rename from latest/_modules/gcloud/datastore/entity.html rename to latest/_modules/google/cloud/datastore/entity.html index 138c1afcc1f2..53bbfd3b4bca 100644 --- a/latest/_modules/gcloud/datastore/entity.html +++ b/latest/_modules/google/cloud/datastore/entity.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.entity — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.entity — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.entity
    • +
    • -

      Source code for gcloud.datastore.entity

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.entity

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,16 +269,16 @@ 

    Source code for gcloud.datastore.entity

     """Class for representing a single entity in the Cloud Datastore."""
     
     
    -from gcloud._helpers import _ensure_tuple_or_list
    +from google.cloud._helpers import _ensure_tuple_or_list
     
     
    -
    [docs]class Entity(dict): +
    [docs]class Entity(dict): """Entities are akin to rows in a relational database An entity storing the actual instance of data. Each entity is officially represented with a - :class:`gcloud.datastore.key.Key` class, however it is possible that + :class:`google.cloud.datastore.key.Key` class, however it is possible that you might create an Entity with only a partial Key (that is, a Key with a Kind, and possibly a parent, but without an ID). In such a case, the datastore service will automatically assign an ID to the @@ -136,9 +291,9 @@

    Source code for gcloud.datastore.entity

         This means you could take an existing entity and change the key
         to duplicate the object.
     
    -    Use :func:`gcloud.datastore.get` to retrieve an existing entity.
    +    Use :func:`google.cloud.datastore.get` to retrieve an existing entity.
     
    -      >>> from gcloud import datastore
    +      >>> from google.cloud import datastore
           >>> client = datastore.Client()
           >>> client.get(key)
           <Entity[{'kind': 'EntityKind', id: 1234}] {'property': 'value'}>
    @@ -167,7 +322,7 @@ 

    Source code for gcloud.datastore.entity

            Python3), will be saved using the 'blob_value' field, without
            any decoding / encoding step.
     
    -    :type key: :class:`gcloud.datastore.key.Key`
    +    :type key: :class:`google.cloud.datastore.key.Key`
         :param key: Optional key to be set on entity.
     
         :type exclude_from_indexes: tuple of string
    @@ -181,13 +336,13 @@ 

    Source code for gcloud.datastore.entity

             self._exclude_from_indexes = set(_ensure_tuple_or_list(
                 'exclude_from_indexes', exclude_from_indexes))
             # NOTE: This will be populated when parsing a protobuf in
    -        #       gcloud.datastore.helpers.entity_from_protobuf.
    +        #       google.cloud.datastore.helpers.entity_from_protobuf.
             self._meanings = {}
     
         def __eq__(self, other):
             """Compare two entities for equality.
     
    -        Entities compare equal if their keys compare equal, and their
    +        Entities compare equal if their keys compare equal and their
             properties compare equal.
     
             :rtype: boolean
    @@ -204,7 +359,7 @@ 

    Source code for gcloud.datastore.entity

         def __ne__(self, other):
             """Compare two entities for inequality.
     
    -        Entities compare equal if their keys compare equal, and their
    +        Entities compare equal if their keys compare equal and their
             properties compare equal.
     
             :rtype: boolean
    @@ -217,7 +372,7 @@ 

    Source code for gcloud.datastore.entity

             """Get the kind of the current entity.
     
             .. note::
    -          This relies entirely on the :class:`gcloud.datastore.key.Key`
    +          This relies entirely on the :class:`google.cloud.datastore.key.Key`
               set on the entity.  That means that we're not storing the kind
               of the entity at all, just the properties and a pointer to a
               Key which knows its Kind.
    @@ -242,123 +397,62 @@ 

    Source code for gcloud.datastore.entity

                 return '<Entity %s>' % (super(Entity, self).__repr__())
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/helpers.html b/latest/_modules/google/cloud/datastore/helpers.html similarity index 80% rename from latest/_modules/gcloud/datastore/helpers.html rename to latest/_modules/google/cloud/datastore/helpers.html index 03ea2a9ac18d..0510f9f7e83b 100644 --- a/latest/_modules/gcloud/datastore/helpers.html +++ b/latest/_modules/google/cloud/datastore/helpers.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.helpers — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.helpers — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.helpers
    • +
    • -

      Source code for gcloud.datastore.helpers

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.helpers

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -123,11 +278,13 @@ 

    Source code for gcloud.datastore.helpers

     from google.type import latlng_pb2
     import six
     
    -from gcloud._helpers import _datetime_to_pb_timestamp
    -from gcloud._helpers import _pb_timestamp_to_datetime
    -from gcloud.datastore._generated import entity_pb2 as _entity_pb2
    -from gcloud.datastore.entity import Entity
    -from gcloud.datastore.key import Key
    +# pylint: disable=ungrouped-imports
    +from google.cloud._helpers import _datetime_to_pb_timestamp
    +from google.cloud._helpers import _pb_timestamp_to_datetime
    +from google.cloud.datastore._generated import entity_pb2 as _entity_pb2
    +from google.cloud.datastore.entity import Entity
    +from google.cloud.datastore.key import Key
    +# pylint: enable=ungrouped-imports
     
     __all__ = ('entity_from_protobuf', 'key_from_protobuf')
     
    @@ -135,7 +292,7 @@ 

    Source code for gcloud.datastore.helpers

     def _get_meaning(value_pb, is_list=False):
         """Get the meaning from a protobuf value.
     
    -    :type value_pb: :class:`gcloud.datastore._generated.entity_pb2.Value`
    +    :type value_pb: :class:`google.cloud.datastore._generated.entity_pb2.Value`
         :param value_pb: The protobuf value to be checked for an
                          associated meaning.
     
    @@ -167,7 +324,7 @@ 

    Source code for gcloud.datastore.helpers

             else:  # We know len(value_pb.array_value.values) > 0.
                 # If the meaning is not unique, just return all of them.
                 meaning = all_meanings
    -    elif value_pb.meaning:  # Simple field (int32)
    +    elif value_pb.meaning:  # Simple field (int32).
             meaning = value_pb.meaning
     
         return meaning
    @@ -176,13 +333,13 @@ 

    Source code for gcloud.datastore.helpers

     def _new_value_pb(entity_pb, name):
         """Add (by name) a new ``Value`` protobuf to an entity protobuf.
     
    -    :type entity_pb: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +    :type entity_pb: :class:`.datastore._generated.entity_pb2.Entity`
         :param entity_pb: An entity protobuf to add a new property to.
     
         :type name: string
         :param name: The name of the new property.
     
    -    :rtype: :class:`gcloud.datastore._generated.entity_pb2.Value`
    +    :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Value`
         :returns: The new ``Value`` protobuf that was added to the entity.
         """
         return entity_pb.properties.get_or_create(name)
    @@ -191,7 +348,7 @@ 

    Source code for gcloud.datastore.helpers

     def _property_tuples(entity_pb):
         """Iterator of name, ``Value`` tuples from entity properties.
     
    -    :type entity_pb: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +    :type entity_pb: :class:`.datastore._generated.entity_pb2.Entity`
         :param entity_pb: An entity protobuf to add a new property to.
     
         :rtype: :class:`generator`
    @@ -201,16 +358,16 @@ 

    Source code for gcloud.datastore.helpers

         return six.iteritems(entity_pb.properties)
     
     
    -
    [docs]def entity_from_protobuf(pb): +
    [docs]def entity_from_protobuf(pb): """Factory method for creating an entity based on a protobuf. The protobuf should be one returned from the Cloud Datastore Protobuf API. - :type pb: :class:`gcloud.datastore._generated.entity_pb2.Entity` + :type pb: :class:`google.cloud.datastore._generated.entity_pb2.Entity` :param pb: The Protobuf representing the entity. - :rtype: :class:`gcloud.datastore.entity.Entity` + :rtype: :class:`google.cloud.datastore.entity.Entity` :returns: The entity derived from the protobuf. """ key = None @@ -258,7 +415,7 @@

    Source code for gcloud.datastore.helpers

                                     is_list=False):
         """Add meaning information (from an entity) to a protobuf.
     
    -    :type entity: :class:`gcloud.datastore.entity.Entity`
    +    :type entity: :class:`google.cloud.datastore.entity.Entity`
         :param entity: The entity to be turned into a protobuf.
     
         :type name: string
    @@ -267,7 +424,7 @@ 

    Source code for gcloud.datastore.helpers

         :type value: object
         :param value: The current value stored as property ``name``.
     
    -    :type value_pb: :class:`gcloud.datastore._generated.entity_pb2.Value`
    +    :type value_pb: :class:`google.cloud.datastore._generated.entity_pb2.Value`
         :param value_pb: The protobuf value to add meaning / meanings to.
     
         :type is_list: bool
    @@ -299,10 +456,10 @@ 

    Source code for gcloud.datastore.helpers

     def entity_to_protobuf(entity):
         """Converts an entity into a protobuf.
     
    -    :type entity: :class:`gcloud.datastore.entity.Entity`
    +    :type entity: :class:`google.cloud.datastore.entity.Entity`
         :param entity: The entity to be turned into a protobuf.
     
    -    :rtype: :class:`gcloud.datastore._generated.entity_pb2.Entity`
    +    :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Entity`
         :returns: The protobuf representing the entity.
         """
         entity_pb = _entity_pb2.Entity()
    @@ -334,16 +491,16 @@ 

    Source code for gcloud.datastore.helpers

         return entity_pb
     
     
    -
    [docs]def key_from_protobuf(pb): +
    [docs]def key_from_protobuf(pb): """Factory method for creating a key based on a protobuf. The protobuf should be one returned from the Cloud Datastore Protobuf API. - :type pb: :class:`gcloud.datastore._generated.entity_pb2.Key` + :type pb: :class:`google.cloud.datastore._generated.entity_pb2.Key` :param pb: The Protobuf representing the key. - :rtype: :class:`gcloud.datastore.key.Key` + :rtype: :class:`google.cloud.datastore.key.Key` :returns: a new `Key` instance """ path_args = [] @@ -376,7 +533,7 @@

    Source code for gcloud.datastore.helpers

     
         Certain value types need to be coerced into a different type (such
         as a `datetime.datetime` into an integer timestamp, or a
    -    `gcloud.datastore.key.Key` into a Protobuf representation.  This
    +    `google.cloud.datastore.key.Key` into a Protobuf representation.  This
         function handles that for you.
     
         .. note::
    @@ -391,7 +548,7 @@ 

    Source code for gcloud.datastore.helpers

         >>> _pb_attr_value('my_string')
         ('string_value', 'my_string')
     
    -    :type val: `datetime.datetime`, :class:`gcloud.datastore.key.Key`,
    +    :type val: `datetime.datetime`, :class:`google.cloud.datastore.key.Key`,
                    bool, float, integer, string
         :param val: The value to be scrutinized.
     
    @@ -438,7 +595,7 @@ 

    Source code for gcloud.datastore.helpers

         Some work is done to coerce the return value into a more useful type
         (particularly in the case of a timestamp value, or a key value).
     
    -    :type value_pb: :class:`gcloud.datastore._generated.entity_pb2.Value`
    +    :type value_pb: :class:`google.cloud.datastore._generated.entity_pb2.Value`
         :param value_pb: The Value Protobuf.
     
         :rtype: object
    @@ -498,12 +655,12 @@ 

    Source code for gcloud.datastore.helpers

         Some value types (entities, keys, lists) cannot be directly
         assigned; this function handles them correctly.
     
    -    :type value_pb: :class:`gcloud.datastore._generated.entity_pb2.Value`
    +    :type value_pb: :class:`google.cloud.datastore._generated.entity_pb2.Value`
         :param value_pb: The value protobuf to which the value is being assigned.
     
         :type val: :class:`datetime.datetime`, boolean, float, integer, string,
    -               :class:`gcloud.datastore.key.Key`,
    -               :class:`gcloud.datastore.entity.Entity`
    +               :class:`google.cloud.datastore.key.Key`,
    +               :class:`google.cloud.datastore.entity.Entity`
         :param val: The value to be assigned.
         """
         attr, val = _pb_attr_value(val)
    @@ -569,123 +726,62 @@ 

    Source code for gcloud.datastore.helpers

             return not self.__eq__(other)
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/key.html b/latest/_modules/google/cloud/datastore/key.html similarity index 79% rename from latest/_modules/gcloud/datastore/key.html rename to latest/_modules/google/cloud/datastore/key.html index cd4723754408..2142e83a7659 100644 --- a/latest/_modules/gcloud/datastore/key.html +++ b/latest/_modules/google/cloud/datastore/key.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.key — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.key — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.key
    • +
    • -

      Source code for gcloud.datastore.key

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.key

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,15 +266,15 @@ 

    Source code for gcloud.datastore.key

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Create / interact with gcloud datastore keys."""
    +"""Create / interact with Google Cloud Datastore keys."""
     
     import copy
     import six
     
    -from gcloud.datastore._generated import entity_pb2 as _entity_pb2
    +from google.cloud.datastore._generated import entity_pb2 as _entity_pb2
     
     
    -
    [docs]class Key(object): +
    [docs]class Key(object): """An immutable representation of a datastore Key. To create a basic key: @@ -152,7 +307,7 @@

    Source code for gcloud.datastore.key

     
         * namespace (string): A namespace identifier for the key.
         * project (string): The project associated with the key.
    -    * parent (:class:`gcloud.datastore.key.Key`): The parent of the key.
    +    * parent (:class:`google.cloud.datastore.key.Key`): The parent of the key.
     
         The project argument is required unless it has been set implicitly.
         """
    @@ -292,7 +447,7 @@ 

    Source code for gcloud.datastore.key

             Most attributes are simple types, so don't require copying. Other
             attributes like ``parent`` are long-lived and so we re-use them.
     
    -        :rtype: :class:`gcloud.datastore.key.Key`
    +        :rtype: :class:`google.cloud.datastore.key.Key`
             :returns: A new ``Key`` instance with the same data as the current one.
             """
             cloned_self = self.__class__(*self.flat_path,
    @@ -303,13 +458,13 @@ 

    Source code for gcloud.datastore.key

             cloned_self._parent = self._parent
             return cloned_self
     
    -
    [docs] def completed_key(self, id_or_name): +
    [docs] def completed_key(self, id_or_name): """Creates new key from existing partial key by adding final ID/name. :type id_or_name: string or integer :param id_or_name: ID or name to be added to the key. - :rtype: :class:`gcloud.datastore.key.Key` + :rtype: :class:`google.cloud.datastore.key.Key` :returns: A new ``Key`` instance with the same data as the current one and an extra ID or name added. :raises: :class:`ValueError` if the current key is not partial or if @@ -318,7 +473,6 @@

    Source code for gcloud.datastore.key

             if not self.is_partial:
                 raise ValueError('Only a partial key can be completed.')
     
    -        id_or_name_key = None
             if isinstance(id_or_name, six.string_types):
                 id_or_name_key = 'name'
             elif isinstance(id_or_name, six.integer_types):
    @@ -332,10 +486,10 @@ 

    Source code for gcloud.datastore.key

             new_key._flat_path += (id_or_name,)
             return new_key
    -
    [docs] def to_protobuf(self): +
    [docs] def to_protobuf(self): """Return a protobuf corresponding to the key. - :rtype: :class:`gcloud.datastore._generated.entity_pb2.Key` + :rtype: :class:`google.cloud.datastore._generated.entity_pb2.Key` :returns: The protobuf representing the key. """ key = _entity_pb2.Key() @@ -446,7 +600,7 @@

    Source code for gcloud.datastore.key

             Extracts all but the last element in the key path and creates a new
             key, while still matching the namespace and the project.
     
    -        :rtype: :class:`gcloud.datastore.key.Key` or :class:`NoneType`
    +        :rtype: :class:`google.cloud.datastore.key.Key` or :class:`NoneType`
             :returns: A new ``Key`` instance, whose path consists of all but the
                       last element of current path. If the current key has only
                       one path element, returns ``None``.
    @@ -463,7 +617,7 @@ 

    Source code for gcloud.datastore.key

         def parent(self):
             """The parent of the current key.
     
    -        :rtype: :class:`gcloud.datastore.key.Key` or :class:`NoneType`
    +        :rtype: :class:`google.cloud.datastore.key.Key` or :class:`NoneType`
             :returns: A new ``Key`` instance, whose path consists of all but the
                       last element of current path. If the current key has only
                       one path element, returns ``None``.
    @@ -488,7 +642,7 @@ 

    Source code for gcloud.datastore.key

         :type project: string
         :param project: A project.
     
    -    :type parent: :class:`gcloud.datastore.key.Key` or ``NoneType``
    +    :type parent: :class:`google.cloud.datastore.key.Key` or ``NoneType``
         :param parent: The parent of the key or ``None``.
     
         :rtype: string
    @@ -503,123 +657,62 @@ 

    Source code for gcloud.datastore.key

         return project
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/query.html b/latest/_modules/google/cloud/datastore/query.html similarity index 80% rename from latest/_modules/gcloud/datastore/query.html rename to latest/_modules/google/cloud/datastore/query.html index 3ffe4c452559..917697b24809 100644 --- a/latest/_modules/gcloud/datastore/query.html +++ b/latest/_modules/google/cloud/datastore/query.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.query — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.query — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.query
    • +
    • -

      Source code for gcloud.datastore.query

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.query

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,24 +266,24 @@ 

    Source code for gcloud.datastore.query

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Create / interact with gcloud datastore queries."""
    +"""Create / interact with Google Cloud Datastore queries."""
     
     import base64
     
    -from gcloud._helpers import _ensure_tuple_or_list
    -from gcloud.datastore._generated import query_pb2 as _query_pb2
    -from gcloud.datastore import helpers
    -from gcloud.datastore.key import Key
    +from google.cloud._helpers import _ensure_tuple_or_list
    +from google.cloud.datastore._generated import query_pb2 as _query_pb2
    +from google.cloud.datastore import helpers
    +from google.cloud.datastore.key import Key
     
     
    -
    [docs]class Query(object): +
    [docs]class Query(object): """A Query against the Cloud Datastore. This class serves as an abstraction for creating a query over data stored in the Cloud Datastore. - :type client: :class:`gcloud.datastore.client.Client` - :param client: The client used to connect to datastore. + :type client: :class:`google.cloud.datastore.client.Client` + :param client: The client used to connect to Datastore. :type kind: string :param kind: The kind to query. @@ -141,7 +296,7 @@

    Source code for gcloud.datastore.query

         :param namespace: The namespace to which to restrict results.  If not
                           passed, uses the client's value.
     
    -    :type ancestor: :class:`gcloud.datastore.key.Key` or None
    +    :type ancestor: :class:`google.cloud.datastore.key.Key` or None
         :param ancestor: key of the ancestor to which this query's results are
                          restricted.
     
    @@ -285,7 +440,7 @@ 

    Source code for gcloud.datastore.query

             """
             return self._filters[:]
     
    -
    [docs] def add_filter(self, property_name, operator, value): +
    [docs] def add_filter(self, property_name, operator, value): """Filter the query based on a property name, operator and a value. Expressions take the form of:: @@ -296,7 +451,7 @@

    Source code for gcloud.datastore.query

             and operator is one of ``OPERATORS``
             (ie, ``=``, ``<``, ``<=``, ``>``, ``>=``)::
     
    -          >>> from gcloud import datastore
    +          >>> from google.cloud import datastore
               >>> client = datastore.Client()
               >>> query = client.query(kind='Person')
               >>> query.add_filter('name', '=', 'James')
    @@ -311,7 +466,7 @@ 

    Source code for gcloud.datastore.query

             :type value: :class:`int`, :class:`str`, :class:`bool`,
                          :class:`float`, :class:`NoneType`,
                          :class:`datetime.datetime`,
    -                     :class:`gcloud.datastore.key.Key`
    +                     :class:`google.cloud.datastore.key.Key`
             :param value: The value to filter on.
     
             :raises: :class:`ValueError` if ``operation`` is not one of the
    @@ -349,14 +504,14 @@ 

    Source code for gcloud.datastore.query

                 projection = [projection]
             self._projection[:] = projection
     
    -
    [docs] def keys_only(self): +
    [docs] def keys_only(self): """Set the projection to include only keys.""" self._projection[:] = ['__key__']
    -
    [docs] def key_filter(self, key, operator='='): +
    [docs] def key_filter(self, key, operator='='): """Filter on a key. - :type key: :class:`gcloud.datastore.key.Key` + :type key: :class:`google.cloud.datastore.key.Key` :param key: The key to filter on. :type operator: string @@ -411,13 +566,13 @@

    Source code for gcloud.datastore.query

                 value = [value]
             self._distinct_on[:] = value
     
    -
    [docs] def fetch(self, limit=None, offset=0, start_cursor=None, end_cursor=None, +
    [docs] def fetch(self, limit=None, offset=0, start_cursor=None, end_cursor=None, client=None): """Execute the Query; return an iterator for the matching entities. For example:: - >>> from gcloud import datastore + >>> from google.cloud import datastore >>> client = datastore.Client() >>> query = client.query(kind='Person') >>> query.add_filter('name', '=', 'Sally') @@ -438,7 +593,7 @@

    Source code for gcloud.datastore.query

             :type end_cursor: bytes
             :param end_cursor: An optional cursor passed through to the iterator.
     
    -        :type client: :class:`gcloud.datastore.client.Client`
    +        :type client: :class:`google.cloud.datastore.client.Client`
             :param client: client used to connect to datastore.
                            If not supplied, uses the query's value.
     
    @@ -454,15 +609,15 @@ 

    Source code for gcloud.datastore.query

                 self, client, limit, offset, start_cursor, end_cursor)
    -
    [docs]class Iterator(object): +
    [docs]class Iterator(object): """Represent the state of a given execution of a Query. - :type query: :class:`gcloud.datastore.query.Query` + :type query: :class:`google.cloud.datastore.query.Query` :param query: Query object holding permanent configuration (i.e. things that don't change on with each page in a results set). - :type client: :class:`gcloud.datastore.client.Client` + :type client: :class:`google.cloud.datastore.client.Client` :param client: The client used to make a request. :type limit: integer @@ -499,7 +654,7 @@

    Source code for gcloud.datastore.query

             self._page = self._more_results = None
             self._skipped_results = None
     
    -
    [docs] def next_page(self): +
    [docs] def next_page(self): """Fetch a single "page" of query results. Low-level API for fine control: the more convenient API is @@ -556,7 +711,7 @@

    Source code for gcloud.datastore.query

         def __iter__(self):
             """Generator yielding all results matching our query.
     
    -        :rtype: sequence of :class:`gcloud.datastore.entity.Entity`
    +        :rtype: sequence of :class:`google.cloud.datastore.entity.Entity`
             """
             while True:
                 self.next_page()
    @@ -579,7 +734,7 @@ 

    Source code for gcloud.datastore.query

         :type query: :class:`Query`
         :param query: The source query.
     
    -    :rtype: :class:`gcloud.datastore._generated.query_pb2.Query`
    +    :rtype: :class:`google.cloud.datastore._generated.query_pb2.Query`
         :returns: A protobuf that can be sent to the protobuf API.  N.b. that
                   it does not contain "in-flight" fields for ongoing query
                   executions (cursors, offset, limit).
    @@ -638,123 +793,62 @@ 

    Source code for gcloud.datastore.query

         return pb
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/datastore/transaction.html b/latest/_modules/google/cloud/datastore/transaction.html similarity index 59% rename from latest/_modules/gcloud/datastore/transaction.html rename to latest/_modules/google/cloud/datastore/transaction.html index d2a99f72ee6d..a3cde66efcb2 100644 --- a/latest/_modules/gcloud/datastore/transaction.html +++ b/latest/_modules/google/cloud/datastore/transaction.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.datastore.transaction — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.datastore.transaction — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.datastore.transaction
    • +
    • -

      Source code for gcloud.datastore.transaction

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.datastore.transaction

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,12 +266,12 @@ 

    Source code for gcloud.datastore.transaction

    # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Create / interact with gcloud datastore transactions."""
    +"""Create / interact with Google Cloud Datastore transactions."""
     
    -from gcloud.datastore.batch import Batch
    +from google.cloud.datastore.batch import Batch
     
     
    -
    [docs]class Transaction(Batch): +
    [docs]class Transaction(Batch): """An abstraction representing datastore Transactions. Transactions can be used to build up a bulk mutation and ensure all @@ -126,7 +281,7 @@

    Source code for gcloud.datastore.transaction

        operations (either ``insert`` or ``upsert``) into the same
         mutation, and execute those within a transaction::
     
    -      >>> from gcloud import datastore
    +      >>> from google.cloud import datastore
           >>> client = datastore.Client()
           >>> with client.transaction():
           ...     client.put_multi([entity1, entity2])
    @@ -185,7 +340,7 @@ 

    Source code for gcloud.datastore.transaction

          ... else:
           ...     transaction.commit()
     
    -    :type client: :class:`gcloud.datastore.client.Client`
    +    :type client: :class:`google.cloud.datastore.client.Client`
         :param client: the client used to connect to datastore.
         """
     
    @@ -202,7 +357,7 @@ 

    Source code for gcloud.datastore.transaction

            """
             return self._id
     
    -
    [docs] def current(self): +
    [docs] def current(self): """Return the topmost transaction. .. note:: @@ -210,14 +365,14 @@

    Source code for gcloud.datastore.transaction

                If the topmost element on the stack is not a transaction,
                 returns None.
     
    -        :rtype: :class:`gcloud.datastore.transaction.Transaction` or None
    +        :rtype: :class:`google.cloud.datastore.transaction.Transaction` or None
             :returns: The current transaction (if any are active).
             """
             top = super(Transaction, self).current()
             if isinstance(top, Transaction):
                 return top
    -
    [docs] def begin(self): +
    [docs] def begin(self): """Begins a transaction. This method is called automatically when entering a with @@ -229,7 +384,7 @@

    Source code for gcloud.datastore.transaction

    super(Transaction, self).begin()
             self._id = self.connection.begin_transaction(self.project)
    -
    [docs] def rollback(self): +
    [docs] def rollback(self): """Rolls back the current transaction. This method has necessary side-effects: @@ -244,7 +399,7 @@

    Source code for gcloud.datastore.transaction

    # Clear our own ID in case this gets accidentally reused.
                 self._id = None
    -
    [docs] def commit(self): +
    [docs] def commit(self): """Commits the transaction. This is called automatically upon exiting a with statement, @@ -262,123 +417,62 @@

    Source code for gcloud.datastore.transaction

    self._id = None
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/dns/changes.html b/latest/_modules/google/cloud/dns/changes.html similarity index 68% rename from latest/_modules/gcloud/dns/changes.html rename to latest/_modules/google/cloud/dns/changes.html index d214b648ef04..f4b98e2b528c 100644 --- a/latest/_modules/gcloud/dns/changes.html +++ b/latest/_modules/google/cloud/dns/changes.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.dns.changes — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.dns.changes — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.dns.changes
    • +
    • -

      Source code for gcloud.dns.changes

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.dns.changes

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,20 +270,20 @@ 

    Source code for gcloud.dns.changes

     
     import six
     
    -from gcloud._helpers import _rfc3339_to_datetime
    -from gcloud.exceptions import NotFound
    -from gcloud.dns.resource_record_set import ResourceRecordSet
    +from google.cloud._helpers import _rfc3339_to_datetime
    +from google.cloud.exceptions import NotFound
    +from google.cloud.dns.resource_record_set import ResourceRecordSet
     
     
    -
    [docs]class Changes(object): +
    [docs]class Changes(object): """Changes are bundled additions / deletions of DNS resource records. - Changes are owned by a :class:`gcloud.dns.zone.ManagedZone` instance. + Changes are owned by a :class:`google.cloud.dns.zone.ManagedZone` instance. See: https://cloud.google.com/dns/api/v1/changes - :type zone: :class:`gcloud.dns.zone.ManagedZone` + :type zone: :class:`google.cloud.dns.zone.ManagedZone` :param zone: A zone which holds one or more record sets. """ @@ -138,16 +293,16 @@

    Source code for gcloud.dns.changes

             self._additions = self._deletions = ()
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, zone): +
    [docs] def from_api_repr(cls, resource, zone): """Factory: construct a change set given its API representation :type resource: dict - :param resource: change set representation returned from the API + :param resource: change set representation returned from the API. - :type zone: :class:`gcloud.dns.zone.ManagedZone` + :type zone: :class:`google.cloud.dns.zone.ManagedZone` :param zone: A zone which holds zero or more change sets. - :rtype: :class:`gcloud.dns.changes.Changes` + :rtype: :class:`google.cloud.dns.changes.Changes` :returns: RRS parsed from ``resource``. """ changes = cls(zone=zone) @@ -158,7 +313,7 @@

    Source code for gcloud.dns.changes

             """Helper method for :meth:`from_api_repr`, :meth:`create`, etc.
     
             :type resource: dict
    -        :param resource: change set representation returned from the API
    +        :param resource: change set representation returned from the API.
             """
             resource = resource.copy()
             self._additions = tuple([
    @@ -224,8 +379,8 @@ 

    Source code for gcloud.dns.changes

             """Resource record sets to be added to the zone.
     
             :rtype: sequence of
    -                :class:`gcloud.dns.resource_record_set.ResourceRecordSet`.
    -        :returns: record sets appended via :meth:`add_record_set`
    +                :class:`google.cloud.dns.resource_record_set.ResourceRecordSet`.
    +        :returns: record sets appended via :meth:`add_record_set`.
             """
             return self._additions
     
    @@ -234,17 +389,17 @@ 

    Source code for gcloud.dns.changes

             """Resource record sets to be deleted from the zone.
     
             :rtype: sequence of
    -                :class:`gcloud.dns.resource_record_set.ResourceRecordSet`.
    -        :returns: record sets appended via :meth:`delete_record_set`
    +                :class:`google.cloud.dns.resource_record_set.ResourceRecordSet`.
    +        :returns: record sets appended via :meth:`delete_record_set`.
             """
             return self._deletions
     
    -
    [docs] def add_record_set(self, record_set): +
    [docs] def add_record_set(self, record_set): """Append a record set to the 'additions' for the change set. :type record_set: - :class:`gcloud.dns.resource_record_set.ResourceRecordSet` - :param record_set: the record set to append + :class:`google.cloud.dns.resource_record_set.ResourceRecordSet` + :param record_set: the record set to append. :raises: ``ValueError`` if ``record_set`` is not of the required type. """ @@ -252,12 +407,12 @@

    Source code for gcloud.dns.changes

                 raise ValueError("Pass a ResourceRecordSet")
             self._additions += (record_set,)
    -
    [docs] def delete_record_set(self, record_set): +
    [docs] def delete_record_set(self, record_set): """Append a record set to the 'deletions' for the change set. :type record_set: - :class:`gcloud.dns.resource_record_set.ResourceRecordSet` - :param record_set: the record set to append + :class:`google.cloud.dns.resource_record_set.ResourceRecordSet` + :param record_set: the record set to append. :raises: ``ValueError`` if ``record_set`` is not of the required type. """ @@ -268,11 +423,11 @@

    Source code for gcloud.dns.changes

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.dns.client.Client` or ``NoneType``
    +        :type client: :class:`google.cloud.dns.client.Client` or ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current zone.
     
    -        :rtype: :class:`gcloud.dns.client.Client`
    +        :rtype: :class:`google.cloud.dns.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -300,13 +455,13 @@ 

    Source code for gcloud.dns.changes

                 'deletions': deletions,
             }
     
    -
    [docs] def create(self, client=None): - """API call: create the change set via a POST request +
    [docs] def create(self, client=None): + """API call: create the change set via a POST request. See: https://cloud.google.com/dns/api/v1/changes/create - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. """ @@ -319,13 +474,13 @@

    Source code for gcloud.dns.changes

                 method='POST', path=path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def exists(self, client=None): - """API call: test for the existence of the change set via a GET request +
    [docs] def exists(self, client=None): + """API call: test for the existence of the change set via a GET request. See https://cloud.google.com/dns/api/v1/changes/get - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. @@ -341,13 +496,13 @@

    Source code for gcloud.dns.changes

             else:
                 return True
    -
    [docs] def reload(self, client=None): - """API call: refresh zone properties via a GET request +
    [docs] def reload(self, client=None): + """API call: refresh zone properties via a GET request. See https://cloud.google.com/dns/api/v1/changes/get - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. """ @@ -358,123 +513,62 @@

    Source code for gcloud.dns.changes

             self._set_properties(api_response)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/dns/client.html b/latest/_modules/google/cloud/dns/client.html similarity index 57% rename from latest/_modules/gcloud/dns/client.html rename to latest/_modules/google/cloud/dns/client.html index 0a78f07baee0..7796cb163cfe 100644 --- a/latest/_modules/gcloud/dns/client.html +++ b/latest/_modules/google/cloud/dns/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.dns.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.dns.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.dns.client
    • +
    • -

      Source code for gcloud.dns.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.dns.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,12 +269,12 @@ 

    Source code for gcloud.dns.client

     """Client for interacting with the Google Cloud DNS API."""
     
     
    -from gcloud.client import JSONClient
    -from gcloud.dns.connection import Connection
    -from gcloud.dns.zone import ManagedZone
    +from google.cloud.client import JSONClient
    +from google.cloud.dns.connection import Connection
    +from google.cloud.dns.zone import ManagedZone
     
     
    -
    [docs]class Client(JSONClient): +
    [docs]class Client(JSONClient): """Client to bundle configuration needed for API requests. :type project: string @@ -142,8 +297,8 @@

    Source code for gcloud.dns.client

     
         _connection_class = Connection
     
    -
    [docs] def quotas(self): - """Return DNS quots for the project associated with this client. +
    [docs] def quotas(self): + """Return DNS quotas for the project associated with this client. See: https://cloud.google.com/dns/api/v1/projects/get @@ -158,7 +313,7 @@

    Source code for gcloud.dns.client

             return dict([(key, int(value))
                          for key, value in resp['quota'].items() if key != 'kind'])
    -
    [docs] def list_zones(self, max_results=None, page_token=None): +
    [docs] def list_zones(self, max_results=None, page_token=None): """List zones for the project associated with this client. See: @@ -174,7 +329,7 @@

    Source code for gcloud.dns.client

                                zones.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.dns.zone.ManagedZone`, plus a
    +        :returns: list of :class:`google.cloud.dns.zone.ManagedZone`, plus a
                       "next page token" string:  if the token is not None,
                       indicates that more zones can be retrieved with another
                       call (pass that value as ``page_token``).
    @@ -194,7 +349,7 @@ 

    Source code for gcloud.dns.client

                      for resource in resp['managedZones']]
             return zones, resp.get('nextPageToken')
    -
    [docs] def zone(self, name, dns_name=None, description=None): +
    [docs] def zone(self, name, dns_name=None, description=None): """Construct a zone bound to this client. :type name: string @@ -208,130 +363,69 @@

    Source code for gcloud.dns.client

             :param description: the description for the zone.  If not passed,
                                 defaults to the value of 'dns_name'.
     
    -        :rtype: :class:`gcloud.dns.zone.ManagedZone`
    -        :returns: a new ``ManagedZone`` instance
    +        :rtype: :class:`google.cloud.dns.zone.ManagedZone`
    +        :returns: a new ``ManagedZone`` instance.
             """
             return ManagedZone(name, dns_name, client=self,
                                description=description)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/dns/connection.html b/latest/_modules/google/cloud/dns/connection.html new file mode 100644 index 000000000000..872c0bc8185e --- /dev/null +++ b/latest/_modules/google/cloud/dns/connection.html @@ -0,0 +1,348 @@ + + + + + + + + + + + google.cloud.dns.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +

    Source code for google.cloud.dns.connection

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Google Cloud DNS connections."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud DNS via the JSON REST API.""" + + API_BASE_URL = 'https://www.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/dns/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/ndev.clouddns.readwrite',) + """The scopes required for authenticating as a Cloud DNS consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/dns/resource_record_set.html b/latest/_modules/google/cloud/dns/resource_record_set.html new file mode 100644 index 000000000000..e1bd5aed3c55 --- /dev/null +++ b/latest/_modules/google/cloud/dns/resource_record_set.html @@ -0,0 +1,381 @@ + + + + + + + + + + + google.cloud.dns.resource_record_set — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.dns.resource_record_set
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.dns.resource_record_set

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Define API ResourceRecordSets."""
    +
    +
    +
    [docs]class ResourceRecordSet(object): + """ResourceRecordSets are DNS resource records. + + RRS are owned by a :class:`google.cloud.dns.zone.ManagedZone` instance. + + See: + https://cloud.google.com/dns/api/v1/resourceRecordSets + + :type name: string + :param name: the name of the record set. + + :type record_type: string + :param record_type: the RR type of the zone. + + :type ttl: integer + :param ttl: TTL (in seconds) for caching the record sets. + + :type rrdatas: list of string + :param rrdatas: one or more lines containing the resource data. + + :type zone: :class:`google.cloud.dns.zone.ManagedZone` + :param zone: A zone which holds one or more record sets. + """ + + def __init__(self, name, record_type, ttl, rrdatas, zone): + self.name = name + self.record_type = record_type + self.ttl = ttl + self.rrdatas = rrdatas + self.zone = zone + + @classmethod +
    [docs] def from_api_repr(cls, resource, zone): + """Factory: construct a record set given its API representation + + :type resource: dict + :param resource: record sets representation returned from the API + + :type zone: :class:`google.cloud.dns.zone.ManagedZone` + :param zone: A zone which holds one or more record sets. + + :rtype: :class:`google.cloud.dns.zone.ResourceRecordSet` + :returns: RRS parsed from ``resource``. + """ + name = resource['name'] + record_type = resource['type'] + ttl = int(resource['ttl']) + rrdatas = resource['rrdatas'] + return cls(name, record_type, ttl, rrdatas, zone=zone)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/dns/zone.html b/latest/_modules/google/cloud/dns/zone.html similarity index 73% rename from latest/_modules/gcloud/dns/zone.html rename to latest/_modules/google/cloud/dns/zone.html index 3422ab708fb9..429aa5769d3a 100644 --- a/latest/_modules/gcloud/dns/zone.html +++ b/latest/_modules/google/cloud/dns/zone.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.dns.zone — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.dns.zone — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.dns.zone
    • +
    • -

      Source code for gcloud.dns.zone

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.dns.zone

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,13 +269,13 @@ 

    Source code for gcloud.dns.zone

     """Define API ManagedZones."""
     import six
     
    -from gcloud._helpers import _rfc3339_to_datetime
    -from gcloud.exceptions import NotFound
    -from gcloud.dns.changes import Changes
    -from gcloud.dns.resource_record_set import ResourceRecordSet
    +from google.cloud._helpers import _rfc3339_to_datetime
    +from google.cloud.exceptions import NotFound
    +from google.cloud.dns.changes import Changes
    +from google.cloud.dns.resource_record_set import ResourceRecordSet
     
     
    -
    [docs]class ManagedZone(object): +
    [docs]class ManagedZone(object): """ManagedZones are containers for DNS resource records. See: @@ -133,7 +288,7 @@

    Source code for gcloud.dns.zone

         :param dns_name: the DNS name of the zone.  If not passed, then calls
                          to :meth:`create` will fail.
     
    -    :type client: :class:`gcloud.dns.client.Client`
    +    :type client: :class:`google.cloud.dns.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the zone (which requires a project).
     
    @@ -152,17 +307,17 @@ 

    Source code for gcloud.dns.zone

             self.description = description
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a zone given its API representation :type resource: dict :param resource: zone resource representation returned from the API - :type client: :class:`gcloud.dns.client.Client` + :type client: :class:`google.cloud.dns.client.Client` :param client: Client which holds credentials and project configuration for the zone. - :rtype: :class:`gcloud.dns.zone.ManagedZone` + :rtype: :class:`google.cloud.dns.zone.ManagedZone` :returns: Zone parsed from ``resource``. """ name = resource.get('name') @@ -268,7 +423,7 @@

    Source code for gcloud.dns.zone

                 raise ValueError("Pass a string, or None")
             self._properties['nameServerSet'] = value
     
    -
    [docs] def resource_record_set(self, name, record_type, ttl, rrdatas): +
    [docs] def resource_record_set(self, name, record_type, ttl, rrdatas): """Construct a resource record set bound to this zone. :type name: string @@ -283,15 +438,15 @@

    Source code for gcloud.dns.zone

             :type rrdatas: list of string
             :param rrdatas: resource data for the RR
     
    -        :rtype: :class:`gcloud.dns.resource_record_set.ResourceRecordSet`
    +        :rtype: :class:`google.cloud.dns.resource_record_set.ResourceRecordSet`
             :returns: a new ``ResourceRecordSet`` instance
             """
             return ResourceRecordSet(name, record_type, ttl, rrdatas, zone=self)
    -
    [docs] def changes(self): +
    [docs] def changes(self): """Construct a change set bound to this zone. - :rtype: :class:`gcloud.dns.changes.Changes` + :rtype: :class:`google.cloud.dns.changes.Changes` :returns: a new ``Changes`` instance """ return Changes(zone=self)
    @@ -299,11 +454,11 @@

    Source code for gcloud.dns.zone

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.dns.client.Client` or ``NoneType``
    +        :type client: :class:`google.cloud.dns.client.Client` or ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current zone.
     
    -        :rtype: :class:`gcloud.dns.client.Client`
    +        :rtype: :class:`google.cloud.dns.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
    @@ -341,13 +496,13 @@ 

    Source code for gcloud.dns.zone

     
             return resource
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the zone via a PUT request See: https://cloud.google.com/dns/api/v1/managedZones/create - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. """ @@ -357,13 +512,13 @@

    Source code for gcloud.dns.zone

                 method='POST', path=path, data=self._build_resource())
             self._set_properties(api_response)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the zone via a GET request See https://cloud.google.com/dns/api/v1/managedZones/get - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. @@ -380,13 +535,13 @@

    Source code for gcloud.dns.zone

             else:
                 return True
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: refresh zone properties via a GET request See https://cloud.google.com/dns/api/v1/managedZones/get - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. """ @@ -396,20 +551,20 @@

    Source code for gcloud.dns.zone

                 method='GET', path=self.path)
             self._set_properties(api_response)
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete the zone via a DELETE request See: https://cloud.google.com/dns/api/v1/managedZones/delete - :type client: :class:`gcloud.dns.client.Client` or ``NoneType`` + :type client: :class:`google.cloud.dns.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current zone. """ client = self._require_client(client) client.connection.api_request(method='DELETE', path=self.path)
    -
    [docs] def list_resource_record_sets(self, max_results=None, page_token=None, +
    [docs] def list_resource_record_sets(self, max_results=None, page_token=None, client=None): """List resource record sets for this zone. @@ -425,13 +580,13 @@

    Source code for gcloud.dns.zone

                                not passed, the API will return the first page of
                                zones.
     
    -        :type client: :class:`gcloud.dns.client.Client` or ``NoneType``
    +        :type client: :class:`google.cloud.dns.client.Client` or ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current zone.
     
             :rtype: tuple, (list, str)
             :returns: list of
    -                  :class:`gcloud.dns.resource_record_set.ResourceRecordSet`,
    +                  :class:`google.cloud.dns.resource_record_set.ResourceRecordSet`,
                       plus a "next page token" string:  if the token is not None,
                       indicates that more zones can be retrieved with another
                       call (pass that value as ``page_token``).
    @@ -453,7 +608,7 @@ 

    Source code for gcloud.dns.zone

                      for resource in resp['rrsets']]
             return zones, resp.get('nextPageToken')
    -
    [docs] def list_changes(self, max_results=None, page_token=None, client=None): +
    [docs] def list_changes(self, max_results=None, page_token=None, client=None): """List change sets for this zone. See: @@ -468,13 +623,13 @@

    Source code for gcloud.dns.zone

                                not passed, the API will return the first page of
                                zones.
     
    -        :type client: :class:`gcloud.dns.client.Client` or ``NoneType``
    +        :type client: :class:`google.cloud.dns.client.Client` or ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current zone.
     
             :rtype: tuple, (list, str)
             :returns: list of
    -                  :class:`gcloud.dns.resource_record_set.ResourceRecordSet`,
    +                  :class:`google.cloud.dns.resource_record_set.ResourceRecordSet`,
                       plus a "next page token" string:  if the token is not None,
                       indicates that more zones can be retrieved with another
                       call (pass that value as ``page_token``).
    @@ -497,123 +652,62 @@ 

    Source code for gcloud.dns.zone

             return zones, resp.get('nextPageToken')
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/error_reporting/client.html b/latest/_modules/google/cloud/error_reporting/client.html new file mode 100644 index 000000000000..d89394d1cc39 --- /dev/null +++ b/latest/_modules/google/cloud/error_reporting/client.html @@ -0,0 +1,566 @@ + + + + + + + + + + + google.cloud.error_reporting.client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.error_reporting.client
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.error_reporting.client

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Client for interacting with the Stackdriver Logging API"""
    +
    +import traceback
    +
    +import google.cloud.logging.client
    +import six
    +
    +
    +
    [docs]class HTTPContext(object): + """HTTPContext defines an object that captures the parameter for the + httpRequest part of Error Reporting API + + :type method: string + :param method: The type of HTTP request, such as GET, POST, etc. + + :type url: string + :param url: The URL of the request + + :type user_agent: string + :param user_agent: The user agent information that is provided with the + request. + + :type referrer: string + :param referrer: The referrer information that is provided with the + request. + + :type response_status_code: int + :param response_status_code: The HTTP response status code for the request. + + :type remote_ip: string + :param remote_ip: The IP address from which the request originated. This + can be IPv4, IPv6, or a token which is derived from + the IP address, depending on the data that has been + provided in the error report. + """ + + def __init__(self, method=None, url=None, + user_agent=None, referrer=None, + response_status_code=None, remote_ip=None): + self.method = method + self.url = url + # intentionally camel case for mapping to JSON API expects + # pylint: disable=invalid-name + self.userAgent = user_agent + self.referrer = referrer + self.responseStatusCode = response_status_code + self.remoteIp = remote_ip
    + + +
    [docs]class Client(object): + """Error Reporting client. Currently Error Reporting is done by creating + a Logging client. + + :type project: string + :param project: the project which the client acts on behalf of. If not + passed falls back to the default inferred from the + environment. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` or + :class:`NoneType` + :param credentials: The OAuth2 Credentials to use for the connection + owned by this client. If not passed (and if no ``http`` + object is passed), falls back to the default inferred + from the environment. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: An optional HTTP object to make requests. If not passed, an + ``http`` object is created that is bound to the + ``credentials`` for the current object. + + :type service: str + :param service: An identifier of the service, such as the name of the + executable, job, or Google App Engine service name. This + field is expected to have a low number of values that are + relatively stable over time, as opposed to version, + which can be changed whenever new code is deployed. + + + :type version: str + :param version: Represents the source code version that the developer + provided, which could represent a version label or a Git + SHA-1 hash, for example. If the developer did not provide + a version, the value is set to default. + + :raises: :class:`ValueError` if the project is neither passed in nor + set in the environment. + """ + + def __init__(self, project=None, + credentials=None, + http=None, + service=None, + version=None): + self.logging_client = google.cloud.logging.client.Client( + project, credentials, http) + self.service = service if service else self.DEFAULT_SERVICE + self.version = version + + DEFAULT_SERVICE = 'python' + + def _send_error_report(self, message, + report_location=None, http_context=None, user=None): + """Makes the call to the Error Reporting API via the log stream. + + This is the lower-level interface to build the payload, generally + users will use either report() or report_exception() to automatically + gather the parameters for this method. + + Currently this method sends the Error Report by formatting a structured + log message according to + + https://cloud.google.com/error-reporting/docs/formatting-error-messages + + :type message: string + :param message: The stack trace that was reported or logged by the + service. + + :type report_location: dict + :param report_location: The location in the source code where the + decision was made to report the error, usually the place + where it was logged. For a logged exception this would be the + source line where the exception is logged, usually close to + the place where it was caught. + + This should be a Python dict that contains the keys 'filePath', + 'lineNumber', and 'functionName' + + :type http_context: :class`google.cloud.error_reporting.HTTPContext` + :param http_context: The HTTP request which was processed when the + error was triggered. + + :type user: string + :param user: The user who caused or was affected by the crash. This can + be a user ID, an email address, or an arbitrary token that + uniquely identifies the user. When sending an error + report, leave this field empty if the user was not + logged in. In this case the Error Reporting system will + use other data, such as remote IP address, + to distinguish affected users. + """ + payload = { + 'serviceContext': { + 'service': self.service, + }, + 'message': '{0}'.format(message) + } + + if self.version: + payload['serviceContext']['version'] = self.version + + if report_location or http_context or user: + payload['context'] = {} + + if report_location: + payload['context']['reportLocation'] = report_location + + if http_context: + http_context_dict = http_context.__dict__ + # strip out None values + payload['context']['httpContext'] = { + key: value for key, value in six.iteritems(http_context_dict) + if value is not None + } + + if user: + payload['context']['user'] = user + + logger = self.logging_client.logger('errors') + logger.log_struct(payload) + +
    [docs] def report(self, message, http_context=None, user=None): + """ Reports a message to Stackdriver Error Reporting + https://cloud.google.com/error-reporting/docs/formatting-error-messages + + :type message: str + :param message: A user-supplied message to report + + + :type http_context: :class`google.cloud.error_reporting.HTTPContext` + :param http_context: The HTTP request which was processed when the + error was triggered. + + :type user: string + :param user: The user who caused or was affected by the crash. This + can be a user ID, an email address, or an arbitrary + token that uniquely identifies the user. When sending + an error report, leave this field empty if the user + was not logged in. In this case the Error Reporting + system will use other data, such as remote IP address, + to distinguish affected users. + + Example:: + >>> client.report("Something went wrong!") + """ + stack = traceback.extract_stack() + last_call = stack[-2] + file_path = last_call[0] + line_number = last_call[1] + function_name = last_call[2] + report_location = { + 'filePath': file_path, + 'lineNumber': line_number, + 'functionName': function_name + } + + self._send_error_report(message, + http_context=http_context, + user=user, + report_location=report_location)
    + +
    [docs] def report_exception(self, http_context=None, user=None): + """ Reports the details of the latest exceptions to Stackdriver Error + Reporting. + + :type http_context: :class`google.cloud.error_reporting.HTTPContext` + :param http_context: The HTTP request which was processed when the + error was triggered. + + :type user: string + :param user: The user who caused or was affected by the crash. This + can be a user ID, an email address, or an arbitrary + token that uniquely identifies the user. When sending an + error report, leave this field empty if the user was + not logged in. In this case the Error Reporting system + will use other data, such as remote IP address, + to distinguish affected users. + + Example:: + + >>> try: + >>> raise NameError + >>> except Exception: + >>> client.report_exception() + """ + self._send_error_report(traceback.format_exc(), + http_context=http_context, + user=user)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/exceptions.html b/latest/_modules/google/cloud/exceptions.html similarity index 58% rename from latest/_modules/gcloud/exceptions.html rename to latest/_modules/google/cloud/exceptions.html index 37f7cd58681f..fc02162e70ad 100644 --- a/latest/_modules/gcloud/exceptions.html +++ b/latest/_modules/google/cloud/exceptions.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.exceptions — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.exceptions — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + -
    + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.exceptions
    • +
    • + + -

      Source code for gcloud.exceptions

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.exceptions

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,7 +266,7 @@ 

    Source code for gcloud.exceptions

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Custom exceptions for :mod:`gcloud` package.
    +"""Custom exceptions for :mod:`google.cloud` package.
     
     See: https://cloud.google.com/storage/docs/json_api/v1/status-codes
     """
    @@ -123,8 +278,8 @@ 

    Source code for gcloud.exceptions

     _HTTP_CODE_TO_EXCEPTION = {}  # populated at end of module
     
     
    -
    [docs]class GCloudError(Exception): - """Base error class for gcloud errors (abstract). +
    [docs]class GoogleCloudError(Exception): + """Base error class for Google Cloud errors (abstract). Each subclass represents a single type of HTTP error response. """ @@ -135,8 +290,7 @@

    Source code for gcloud.exceptions

         """
     
         def __init__(self, message, errors=()):
    -        super(GCloudError, self).__init__()
    -        # suppress deprecation warning under 2.6.x
    +        super(GoogleCloudError, self).__init__(message)
             self.message = message
             self._errors = errors
     
    @@ -153,110 +307,115 @@ 

    Source code for gcloud.exceptions

             return [copy.deepcopy(error) for error in self._errors]
    -
    [docs]class Redirection(GCloudError): +
    [docs]class Redirection(GoogleCloudError): """Base for 3xx responses This class is abstract. """
    -
    [docs]class MovedPermanently(Redirection): +
    [docs]class MovedPermanently(Redirection): """Exception mapping a '301 Moved Permanently' response.""" code = 301
    -
    [docs]class NotModified(Redirection): +
    [docs]class NotModified(Redirection): """Exception mapping a '304 Not Modified' response.""" code = 304
    -
    [docs]class TemporaryRedirect(Redirection): +
    [docs]class TemporaryRedirect(Redirection): """Exception mapping a '307 Temporary Redirect' response.""" code = 307
    -
    [docs]class ResumeIncomplete(Redirection): +
    [docs]class ResumeIncomplete(Redirection): """Exception mapping a '308 Resume Incomplete' response.""" code = 308
    -
    [docs]class ClientError(GCloudError): +
    [docs]class ClientError(GoogleCloudError): """Base for 4xx responses This class is abstract """
    -
    [docs]class BadRequest(ClientError): +
    [docs]class BadRequest(ClientError): """Exception mapping a '400 Bad Request' response.""" code = 400
    -
    [docs]class Unauthorized(ClientError): +
    [docs]class Unauthorized(ClientError): """Exception mapping a '401 Unauthorized' response.""" code = 401
    -
    [docs]class Forbidden(ClientError): +
    [docs]class Forbidden(ClientError): """Exception mapping a '403 Forbidden' response.""" code = 403
    -
    [docs]class NotFound(ClientError): +
    [docs]class NotFound(ClientError): """Exception mapping a '404 Not Found' response.""" code = 404
    -
    [docs]class MethodNotAllowed(ClientError): +
    [docs]class MethodNotAllowed(ClientError): """Exception mapping a '405 Method Not Allowed' response.""" code = 405
    -
    [docs]class Conflict(ClientError): +
    [docs]class Conflict(ClientError): """Exception mapping a '409 Conflict' response.""" code = 409
    -
    [docs]class LengthRequired(ClientError): +
    [docs]class LengthRequired(ClientError): """Exception mapping a '411 Length Required' response.""" code = 411
    -
    [docs]class PreconditionFailed(ClientError): +
    [docs]class PreconditionFailed(ClientError): """Exception mapping a '412 Precondition Failed' response.""" code = 412
    -
    [docs]class RequestRangeNotSatisfiable(ClientError): +
    [docs]class RequestRangeNotSatisfiable(ClientError): """Exception mapping a '416 Request Range Not Satisfiable' response.""" code = 416
    -
    [docs]class TooManyRequests(ClientError): +
    [docs]class TooManyRequests(ClientError): """Exception mapping a '429 Too Many Requests' response.""" code = 429
    -
    [docs]class ServerError(GCloudError): +
    [docs]class ServerError(GoogleCloudError): """Base for 5xx responses: (abstract)"""
    -
    [docs]class InternalServerError(ServerError): +
    [docs]class InternalServerError(ServerError): """Exception mapping a '500 Internal Server Error' response.""" code = 500
    -
    [docs]class MethodNotImplemented(ServerError): +
    [docs]class MethodNotImplemented(ServerError): """Exception mapping a '501 Not Implemented' response.""" code = 501
    -
    [docs]class ServiceUnavailable(ServerError): +
    [docs]class BadGateway(ServerError): + """Exception mapping a '502 Bad Gateway' response.""" + code = 502
    + + +
    [docs]class ServiceUnavailable(ServerError): """Exception mapping a '503 Service Unavailable' response.""" code = 503
    -
    [docs]def make_exception(response, content, error_info=None, use_json=True): +
    [docs]def make_exception(response, content, error_info=None, use_json=True): """Factory: create exception based on HTTP response code. :type response: :class:`httplib2.Response` or other HTTP response object @@ -273,7 +432,7 @@

    Source code for gcloud.exceptions

         :type use_json: bool
         :param use_json: Flag indicating if ``content`` is expected to be JSON.
     
    -    :rtype: instance of :class:`GCloudError`, or a concrete subclass.
    +    :rtype: instance of :class:`GoogleCloudError`, or a concrete subclass.
         :returns: Exception specific to the error response.
         """
         if isinstance(content, six.binary_type):
    @@ -301,7 +460,7 @@ 

    Source code for gcloud.exceptions

         try:
             klass = _HTTP_CODE_TO_EXCEPTION[response.status]
         except KeyError:
    -        error = GCloudError(message, errors)
    +        error = GoogleCloudError(message, errors)
             error.code = response.status
         else:
             error = klass(message, errors)
    @@ -317,129 +476,68 @@ 

    Source code for gcloud.exceptions

     
     
     # Build the code->exception class mapping.
    -for _eklass in _walk_subclasses(GCloudError):
    +for _eklass in _walk_subclasses(GoogleCloudError):
         code = getattr(_eklass, 'code', None)
         if code is not None:
             _HTTP_CODE_TO_EXCEPTION[code] = _eklass
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/client.html b/latest/_modules/google/cloud/language/client.html new file mode 100644 index 000000000000..0217040898cd --- /dev/null +++ b/latest/_modules/google/cloud/language/client.html @@ -0,0 +1,416 @@ + + + + + + + + + + + google.cloud.language.client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.client
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.client

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Basic client for Google Cloud Natural Language API."""
    +
    +
    +from google.cloud import client as client_module
    +from google.cloud.language.connection import Connection
    +from google.cloud.language.document import Document
    +
    +
    +
    [docs]class Client(client_module.Client): + """Client to bundle configuration needed for API requests. + + :type credentials: :class:`~oauth2client.client.OAuth2Credentials` + :param credentials: (Optional) The OAuth2 Credentials to use for the + connection owned by this client. If not passed (and + if no ``http`` object is passed), falls back to the + default inferred from the environment. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: An optional HTTP object to make requests. If not passed, an + ``http`` object is created that is bound to the + ``credentials`` for the current object. + """ + + _connection_class = Connection + +
    [docs] def document_from_text(self, content, **kwargs): + """Create a plain text document bound to this client. + + :type content: str + :param content: The document plain text content. + + :type kwargs: dict + :param kwargs: Remaining keyword arguments to be passed along to the + :class:`.Document` constructor. + + :rtype: :class:`.Document` + :returns: A plain-text document bound to this client. + :raises: :class:`~exceptions.TypeError` if ``doc_type`` is passed as a + keyword argument. + """ + if 'doc_type' in kwargs: + raise TypeError('Cannot pass doc_type') + return Document(self, content=content, + doc_type=Document.PLAIN_TEXT, **kwargs)
    + +
    [docs] def document_from_html(self, content, **kwargs): + """Create an HTML document bound to this client. + + :type content: str + :param content: The document HTML text content. + + :type kwargs: dict + :param kwargs: Remaining keyword arguments to be passed along to the + :class:`.Document` constructor. + + :rtype: :class:`.Document` + :returns: An HTML document bound to this client. + :raises: :class:`~exceptions.TypeError` if ``doc_type`` is passed as a + keyword argument. + """ + if 'doc_type' in kwargs: + raise TypeError('Cannot pass doc_type') + return Document(self, content=content, + doc_type=Document.HTML, **kwargs)
    + +
    [docs] def document_from_url(self, gcs_url, + doc_type=Document.PLAIN_TEXT, **kwargs): + """Create a Cloud Storage document bound to this client. + + :type gcs_url: str + :param gcs_url: The URL of the Google Cloud Storage object + holding the content. Of the form + ``gs://{bucket}/{blob-name}``. + + :type doc_type: str + :param doc_type: (Optional) The type of text in the document. + Defaults to plain text. Can also be specified + as HTML via :attr:`~.Document.HTML`. + + :type kwargs: dict + :param kwargs: Remaining keyword arguments to be passed along to the + :class:`.Document` constructor. + + :rtype: :class:`.Document` + :returns: A document bound to this client. + """ + return Document(self, gcs_url=gcs_url, doc_type=doc_type, **kwargs)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/connection.html b/latest/_modules/google/cloud/language/connection.html new file mode 100644 index 000000000000..e934a56efd8d --- /dev/null +++ b/latest/_modules/google/cloud/language/connection.html @@ -0,0 +1,348 @@ + + + + + + + + + + + google.cloud.language.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.connection

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Basic connection for Google Cloud Natural Language API."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Natural Language JSON REST API.""" + + API_BASE_URL = 'https://language.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v1beta1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/{api_version}/documents:{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/cloud-platform',) + """The scopes required for authenticating as an API consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/document.html b/latest/_modules/google/cloud/language/document.html new file mode 100644 index 000000000000..83639f27a8d5 --- /dev/null +++ b/latest/_modules/google/cloud/language/document.html @@ -0,0 +1,576 @@ + + + + + + + + + + + google.cloud.language.document — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.document
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.document

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Definition for Google Cloud Natural Language API documents.
    +
    +A document is used to hold text to be analyzed and annotated.
    +"""
    +
    +import collections
    +
    +from google.cloud.language.entity import Entity
    +from google.cloud.language.sentiment import Sentiment
    +from google.cloud.language.syntax import Sentence
    +from google.cloud.language.syntax import Token
    +
    +
    +DEFAULT_LANGUAGE = 'en-US'
    +"""Default document language, English."""
    +
    +
    +Annotations = collections.namedtuple(
    +    'Annotations',
    +    'sentences tokens sentiment entities')
    +"""Annotations for a document.
    +
    +:type sentences: list
    +:param sentences: List of :class:`.Sentence` in a document.
    +
    +:type tokens: list
    +:param tokens: List of :class:`.Token` from a document.
    +
    +:type sentiment: :class:`Sentiment`
    +:param sentiment: The sentiment of a document.
    +
    +:type entities: list
    +:param entities: List of :class:`~.language.entity.Entity`
    +                 found in a document.
    +"""
    +
    +
    +
    [docs]class Encoding(object): + """Document text encoding types.""" + + NONE = 'NONE' + """Unspecified encoding type.""" + + UTF8 = 'UTF8' + """UTF-8 encoding type.""" + + UTF16 = 'UTF16' + """UTF-16 encoding type.""" + + UTF32 = 'UTF32' + """UTF-32 encoding type."""
    + + +
    [docs]class Document(object): + """Document to send to Google Cloud Natural Language API. + + Represents either plain text or HTML, and the content is either + stored on the document or referred to in a Google Cloud Storage + object. + + :type client: :class:`~google.cloud.language.client.Client` + :param client: A client which holds credentials and other + configuration. + + :type content: str + :param content: (Optional) The document text content (either plain + text or HTML). + + :type gcs_url: str + :param gcs_url: (Optional) The URL of the Google Cloud Storage object + holding the content. Of the form + ``gs://{bucket}/{blob-name}``. + + :type doc_type: str + :param doc_type: (Optional) The type of text in the document. + Defaults to plain text. Can be one of + :attr:`~.Document.PLAIN_TEXT` or + or :attr:`~.Document.HTML`. + + :type language: str + :param language: (Optional) The language of the document text. + Defaults to :data:`DEFAULT_LANGUAGE`. + + :type encoding: str + :param encoding: (Optional) The encoding of the document text. + Defaults to UTF-8. Can be one of + :attr:`~.Encoding.UTF8`, :attr:`~.Encoding.UTF16` + or :attr:`~.Encoding.UTF32`. + + :raises: :class:`~exceptions.ValueError` both ``content`` and ``gcs_url`` + are specified or if neither are specified. + """ + + TYPE_UNSPECIFIED = 'TYPE_UNSPECIFIED' + """Unspecified document type.""" + + PLAIN_TEXT = 'PLAIN_TEXT' + """Plain text document type.""" + + HTML = 'HTML' + """HTML document type.""" + + def __init__(self, client, content=None, gcs_url=None, doc_type=PLAIN_TEXT, + language=DEFAULT_LANGUAGE, encoding=Encoding.UTF8): + if content is not None and gcs_url is not None: + raise ValueError('A Document cannot contain both local text and ' + 'a link to text in a Google Cloud Storage object') + if content is None and gcs_url is None: + raise ValueError('A Document must contain either local text or a ' + 'link to text in a Google Cloud Storage object') + self.client = client + self.content = content + self.gcs_url = gcs_url + self.doc_type = doc_type + self.language = language + self.encoding = encoding + + def _to_dict(self): + """Helper to convert the current document into a dictionary. + + To be used when constructing requests. + + :rtype: dict + :returns: The Document value as a JSON dictionary. + """ + info = { + 'type': self.doc_type, + 'language': self.language, + } + if self.content is not None: + info['content'] = self.content + elif self.gcs_url is not None: + info['gcsContentUri'] = self.gcs_url + return info + +
    [docs] def analyze_entities(self): + """Analyze the entities in the current document. + + Finds named entities (currently finds proper names as of August 2016) + in the text, entity types, salience, mentions for each entity, and + other properties. + + .. _analyzeEntities: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/documents/analyzeEntities + + See `analyzeEntities`_. + + :rtype: list + :returns: A list of :class:`~.language.entity.Entity` returned from + the API. + """ + data = { + 'document': self._to_dict(), + 'encodingType': self.encoding, + } + api_response = self.client.connection.api_request( + method='POST', path='analyzeEntities', data=data) + return [Entity.from_api_repr(entity) + for entity in api_response['entities']]
    + +
    [docs] def analyze_sentiment(self): + """Analyze the sentiment in the current document. + + .. _analyzeSentiment: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/documents/analyzeSentiment + + See `analyzeSentiment`_. + + :rtype: :class:`.Sentiment` + :returns: The sentiment of the current document. + """ + data = {'document': self._to_dict()} + api_response = self.client.connection.api_request( + method='POST', path='analyzeSentiment', data=data) + return Sentiment.from_api_repr(api_response['documentSentiment'])
    + +
    [docs] def annotate_text(self, include_syntax=True, include_entities=True, + include_sentiment=True): + """Advanced natural language API: document syntax and other features. + + Includes the full functionality of :meth:`analyze_entities` and + :meth:`analyze_sentiment`, enabled by the flags + ``include_entities`` and ``include_sentiment`` respectively. + + In addition ``include_syntax`` adds a new feature that analyzes + the document for semantic and syntacticinformation. + + .. note:: + + This API is intended for users who are familiar with machine + learning and need in-depth text features to build upon. + + .. _annotateText: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/documents/annotateText + + See `annotateText`_. + + :type include_syntax: bool + :param include_syntax: (Optional) Flag to enable syntax analysis + of the current document. + + :type include_entities: bool + :param include_entities: (Optional) Flag to enable entity extraction + from the current document. + + :type include_sentiment: bool + :param include_sentiment: (Optional) Flag to enable sentiment + analysis of the current document. + + :rtype: :class:`Annotations` + :returns: A tuple of each of the four values returned from the API: + sentences, tokens, sentiment and entities. + """ + features = {} + if include_syntax: + features['extractSyntax'] = True + if include_entities: + features['extractEntities'] = True + if include_sentiment: + features['extractDocumentSentiment'] = True + + data = { + 'document': self._to_dict(), + 'features': features, + 'encodingType': self.encoding, + } + api_response = self.client.connection.api_request( + method='POST', path='annotateText', data=data) + + sentences = [Sentence.from_api_repr(sentence) + for sentence in api_response['sentences']] + tokens = [Token.from_api_repr(token) + for token in api_response['tokens']] + sentiment_info = api_response.get('documentSentiment') + if sentiment_info is None: + sentiment = None + else: + sentiment = Sentiment.from_api_repr(sentiment_info) + entities = [Entity.from_api_repr(entity) + for entity in api_response['entities']] + annotations = Annotations( + sentences=sentences, + tokens=tokens, + sentiment=sentiment, + entities=entities, + ) + return annotations
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/entity.html b/latest/_modules/google/cloud/language/entity.html new file mode 100644 index 000000000000..6ba0a91d54e0 --- /dev/null +++ b/latest/_modules/google/cloud/language/entity.html @@ -0,0 +1,423 @@ + + + + + + + + + + + google.cloud.language.entity — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.entity
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.entity

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Definition for Google Cloud Natural Language API entities.
    +
    +An entity is used to describe a proper name extracted from text.
    +"""
    +
    +
    +
    [docs]class EntityType(object): + """List of possible entity types.""" + + UNKNOWN = 'UNKNOWN' + """Unknown entity type.""" + + PERSON = 'PERSON' + """Person entity type.""" + + LOCATION = 'LOCATION' + """Location entity type.""" + + ORGANIZATION = 'ORGANIZATION' + """Organization entity type.""" + + EVENT = 'EVENT' + """Event entity type.""" + + WORK_OF_ART = 'WORK_OF_ART' + """Work of art entity type.""" + + CONSUMER_GOOD = 'CONSUMER_GOOD' + """Consumer good entity type.""" + + OTHER = 'OTHER' + """Other entity type (i.e. known but not classified)."""
    + + +
    [docs]class Entity(object): + """A Google Cloud Natural Language API entity. + + Represents a phrase in text that is a known entity, such as a person, + an organization, or location. The API associates information, such as + salience and mentions, with entities. + + The only supported metadata (as of August 2016) is ``wikipedia_url``, + so this value will be removed from the passed in ``metadata`` + and put in its own property. + + .. _Entity message: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/Entity + .. _EntityType enum: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/Entity#Type + + See `Entity message`_. + + :type name: str + :param name: The name / phrase identified as the entity. + + :type entity_type: str + :param entity_type: The type of the entity. See `EntityType enum`_. + + :type metadata: dict + :param metadata: The metadata associated with the entity. + + :type salience: float + :param salience: The prominence of the entity / phrase within the text + containing it. + + :type mentions: list + :param mentions: List of strings that mention the entity. + """ + + def __init__(self, name, entity_type, metadata, salience, mentions): + self.name = name + self.entity_type = entity_type + self.wikipedia_url = metadata.pop('wikipedia_url', None) + self.metadata = metadata + self.salience = salience + self.mentions = mentions + + @classmethod +
    [docs] def from_api_repr(cls, payload): + """Convert an Entity from the JSON API into an :class:`Entity`. + + :param payload: dict + :type payload: The value from the backend. + + :rtype: :class:`Entity` + :returns: The entity parsed from the API representation. + """ + name = payload['name'] + entity_type = payload['type'] + metadata = payload['metadata'] + salience = payload['salience'] + mentions = [value['text']['content'] + for value in payload['mentions']] + return cls(name, entity_type, metadata, salience, mentions)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/sentiment.html b/latest/_modules/google/cloud/language/sentiment.html new file mode 100644 index 000000000000..3a476739c58e --- /dev/null +++ b/latest/_modules/google/cloud/language/sentiment.html @@ -0,0 +1,372 @@ + + + + + + + + + + + google.cloud.language.sentiment — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.sentiment
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.sentiment

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Definition for Google Cloud Natural Language API sentiment.
    +
    +Sentiment is the response to an ``analyzeSentiment`` request.
    +"""
    +
    +
    +
    [docs]class Sentiment(object): + """A Google Cloud Natural Language API sentiment object. + + .. _Sentiment message: https://cloud.google.com/natural-language/\ + reference/rest/v1beta1/Sentiment + .. _Sentiment basics: https://cloud.google.com/natural-language/\ + docs/basics#sentiment-analysis-values + + See `Sentiment message`_ and `Sentiment basics`_. + + :type polarity: float + :param polarity: Polarity of the sentiment in the ``[-1.0, 1.0]`` range. + Larger numbers represent more positive sentiments. + + :type magnitude: float + :param magnitude: A non-negative number in the ``[0, +inf)`` range, which + represents the absolute magnitude of sentiment + regardless of polarity (positive or negative). + """ + + def __init__(self, polarity, magnitude): + self.polarity = polarity + self.magnitude = magnitude + + @classmethod +
    [docs] def from_api_repr(cls, payload): + """Convert a Sentiment from the JSON API into a :class:`Sentiment`. + + :param payload: dict + :type payload: The value from the backend. + + :rtype: :class:`Sentiment` + :returns: The sentiment parsed from the API representation. + """ + polarity = payload['polarity'] + magnitude = payload['magnitude'] + return cls(polarity, magnitude)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/language/syntax.html b/latest/_modules/google/cloud/language/syntax.html new file mode 100644 index 000000000000..01e219a43313 --- /dev/null +++ b/latest/_modules/google/cloud/language/syntax.html @@ -0,0 +1,518 @@ + + + + + + + + + + + google.cloud.language.syntax — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.language.syntax
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.language.syntax

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Google Cloud Natural Language API helpers for tokenized text.
    +
    +The ``annotateText`` method, when used with the "syntax" feature,
    +breaks a document down into tokens and sentences.
    +"""
    +
    +
    +
    [docs]class PartOfSpeech(object): + """Part of speech of a :class:`Token`.""" + + UNKNOWN = 'UNKNOWN' + """Unknown part of speech.""" + + ADJECTIVE = 'ADJ' + """Part of speech: Adjective.""" + + ADPOSITION = 'ADP' + """Adposition (preposition and postposition).""" + + ADVERB = 'ADV' + """Adverb.""" + + CONJUNCTION = 'CONJ' + """Conjunction.""" + + DETERMINER = 'DET' + """Determiner.""" + + NOUN = 'NOUN' + """Noun (common and proper).""" + + CARDINAL_NUMBER = 'NUM' + """Cardinal number.""" + + PRONOUN = 'PRON' + """Pronoun.""" + + PARTICIPLE = 'PRT' + """Particle or other function word.""" + + PUNCTUATION = 'PUNCT' + """Punctuation.""" + + VERB = 'VERB' + """Verb (all tenses and modes).""" + + OTHER = 'X' + """Other: foreign words, typos, abbreviations.""" + + AFFIX = 'AFFIX' + """Affix.""" + + _REVERSE_MAP = { + 'UNKNOWN': 'UNKNOWN', + 'ADJ': 'ADJECTIVE', + 'ADP': 'ADPOSITION', + 'ADV': 'ADVERB', + 'CONJ': 'CONJUNCTION', + 'DET': 'DETERMINER', + 'NOUN': 'NOUN', + 'NUM': 'CARDINAL_NUMBER', + 'PRON': 'PRONOUN', + 'PRT': 'PARTICIPLE', + 'PUNCT': 'PUNCTUATION', + 'VERB': 'VERB', + 'X': 'OTHER', + 'AFFIX': 'AFFIX', + } + + @classmethod +
    [docs] def reverse(cls, tag): + """Reverses the API's enum name for the one on this class. + + For example:: + + >>> PartOfSpeech.OTHER + 'X' + >>> PartOfSpeech.reverse('X') + 'OTHER' + + :rtype: str + :returns: The attribute name corresponding to the API part of + speech enum. + """ + return cls._REVERSE_MAP[tag]
    + + +
    [docs]class Token(object): + """A Google Cloud Natural Language API token object. + + .. _Token message: https://cloud.google.com/natural-language/reference\ + /rest/v1beta1/documents/annotateText#Token + .. _Lemma: https://en.wikipedia.org/wiki/Lemma_(morphology) + .. _Label enum: https://cloud.google.com/natural-language/reference/\ + rest/v1beta1/documents/annotateText#Label + + See `Token message`_. + + :type text_content: str + :param text_content: The text that the token is composed of. + + :type text_begin: int + :param text_begin: The beginning offset of the content in the original + document according to the encoding type specified + in the API request. + + :type part_of_speech: str + :param part_of_speech: The part of speech of the token. See + :class:`PartOfSpeech` for possible values. + + :type edge_index: int + :param edge_index: The head of this token in the dependency tree. This is + the index of the token which has an arc going to this + token. The index is the position of the token in the + array of tokens returned by the API method. If this + token is a root token, then the ``edge_index`` is + its own index. + + :type edge_label: str + :param edge_label: See `Label enum`_. + + :type lemma: str + :param lemma: The `Lemma`_ of the token. + """ + + def __init__(self, text_content, text_begin, part_of_speech, + edge_index, edge_label, lemma): + self.text_content = text_content + self.text_begin = text_begin + self.part_of_speech = part_of_speech + self.edge_index = edge_index + self.edge_label = edge_label + self.lemma = lemma + + @classmethod +
    [docs] def from_api_repr(cls, payload): + """Convert a token from the JSON API into a :class:`Sentiment`. + + :param payload: dict + :type payload: The value from the backend. + + :rtype: :class:`Token` + :returns: The token parsed from the API representation. + """ + text_span = payload['text'] + text_content = text_span['content'] + text_begin = text_span['beginOffset'] + part_of_speech = payload['partOfSpeech']['tag'] + edge = payload['dependencyEdge'] + edge_index = edge['headTokenIndex'] + edge_label = edge['label'] + lemma = payload['lemma'] + return cls(text_content, text_begin, part_of_speech, + edge_index, edge_label, lemma)
    + + +
    [docs]class Sentence(object): + """A Google Cloud Natural Language API sentence object. + + .. _Sentence message: https://cloud.google.com/natural-language/reference\ + /rest/v1beta1/documents/annotateText#Sentence + + See `Sentence message`_. + + :type content: str + :param content: The text that the sentence is composed of. + + :type begin: int + :param begin: The beginning offset of the sentence in the original + document according to the encoding type specified + in the API request. + """ + + def __init__(self, content, begin): + self.content = content + self.begin = begin + + @classmethod +
    [docs] def from_api_repr(cls, payload): + """Convert a sentence from the JSON API into a :class:`Sentiment`. + + :param payload: dict + :type payload: The value from the backend. + + :rtype: :class:`Sentence` + :returns: The sentence parsed from the API representation. + """ + text_span = payload['text'] + return cls(text_span['content'], text_span['beginOffset'])
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/client.html b/latest/_modules/google/cloud/logging/client.html similarity index 63% rename from latest/_modules/gcloud/logging/client.html rename to latest/_modules/google/cloud/logging/client.html index 9a86900badc9..f512b5772f36 100644 --- a/latest/_modules/gcloud/logging/client.html +++ b/latest/_modules/google/cloud/logging/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + -
    + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.client
    • +
    • + + -

      Source code for gcloud.logging.client

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.client

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -116,15 +271,15 @@ 

    Source code for gcloud.logging.client

     import os
     
     try:
    -    from google.logging.v2.config_service_v2_api import (
    +    from google.cloud.logging.v2.config_service_v2_api import (
             ConfigServiceV2Api as GeneratedSinksAPI)
    -    from google.logging.v2.logging_service_v2_api import (
    +    from google.cloud.logging.v2.logging_service_v2_api import (
             LoggingServiceV2Api as GeneratedLoggingAPI)
    -    from google.logging.v2.metrics_service_v2_api import (
    +    from google.cloud.logging.v2.metrics_service_v2_api import (
             MetricsServiceV2Api as GeneratedMetricsAPI)
    -    from gcloud.logging._gax import _LoggingAPI as GAXLoggingAPI
    -    from gcloud.logging._gax import _MetricsAPI as GAXMetricsAPI
    -    from gcloud.logging._gax import _SinksAPI as GAXSinksAPI
    +    from google.cloud.logging._gax import _LoggingAPI as GAXLoggingAPI
    +    from google.cloud.logging._gax import _MetricsAPI as GAXMetricsAPI
    +    from google.cloud.logging._gax import _SinksAPI as GAXSinksAPI
     except ImportError:  # pragma: NO COVER
         _HAVE_GAX = False
         GeneratedLoggingAPI = GAXLoggingAPI = None
    @@ -133,23 +288,29 @@ 

    Source code for gcloud.logging.client

     else:
         _HAVE_GAX = True
     
    -from gcloud.client import JSONClient
    -from gcloud.logging.connection import Connection
    -from gcloud.logging.connection import _LoggingAPI as JSONLoggingAPI
    -from gcloud.logging.connection import _MetricsAPI as JSONMetricsAPI
    -from gcloud.logging.connection import _SinksAPI as JSONSinksAPI
    -from gcloud.logging.entries import ProtobufEntry
    -from gcloud.logging.entries import StructEntry
    -from gcloud.logging.entries import TextEntry
    -from gcloud.logging.logger import Logger
    -from gcloud.logging.metric import Metric
    -from gcloud.logging.sink import Sink
    -
    -
    -_USE_GAX = _HAVE_GAX and (os.environ.get('GCLOUD_ENABLE_GAX') is not None)
    -
    -
    -
    [docs]class Client(JSONClient): +from google.cloud.client import JSONClient +from google.cloud.environment_vars import DISABLE_GRPC +from google.cloud.logging.connection import Connection +from google.cloud.logging.connection import _LoggingAPI as JSONLoggingAPI +from google.cloud.logging.connection import _MetricsAPI as JSONMetricsAPI +from google.cloud.logging.connection import _SinksAPI as JSONSinksAPI +from google.cloud.logging.entries import ProtobufEntry +from google.cloud.logging.entries import StructEntry +from google.cloud.logging.entries import TextEntry +from google.cloud.logging.logger import Logger +from google.cloud.logging.metric import Metric +from google.cloud.logging.sink import Sink + + +_DISABLE_GAX = os.getenv(DISABLE_GRPC, False) +_USE_GAX = _HAVE_GAX and not _DISABLE_GAX +ASCENDING = 'timestamp asc' +"""Query string to order by ascending timestamps.""" +DESCENDING = 'timestamp desc' +"""Query string to order by decending timestamps.""" + + +
    [docs]class Client(JSONClient): """Client to bundle configuration needed for API requests. :type project: str @@ -219,13 +380,13 @@

    Source code for gcloud.logging.client

                     self._metrics_api = JSONMetricsAPI(self.connection)
             return self._metrics_api
     
    -
    [docs] def logger(self, name): +
    [docs] def logger(self, name): """Creates a logger bound to the current client. :type name: str :param name: the name of the logger to be constructed. - :rtype: :class:`gcloud.logging.logger.Logger` + :rtype: :class:`google.cloud.logging.logger.Logger` :returns: Logger created with the current client. """ return Logger(name, client=self)
    @@ -241,9 +402,9 @@

    Source code for gcloud.logging.client

                             passed, the entry will have a newly-created logger.
     
             :rtype: One of:
    -                :class:`gcloud.logging.entries.TextEntry`,
    -                :class:`gcloud.logging.entries.StructEntry`,
    -                :class:`gcloud.logging.entries.ProtobufEntry`
    +                :class:`google.cloud.logging.entries.TextEntry`,
    +                :class:`google.cloud.logging.entries.StructEntry`,
    +                :class:`google.cloud.logging.entries.ProtobufEntry`
             :returns: the entry instance, constructed via the resource
             """
             if 'textPayload' in resource:
    @@ -254,7 +415,7 @@ 

    Source code for gcloud.logging.client

                 return ProtobufEntry.from_api_repr(resource, self, loggers)
             raise ValueError('Cannot parse log entry resource')
     
    -
    [docs] def list_entries(self, projects=None, filter_=None, order_by=None, +
    [docs] def list_entries(self, projects=None, filter_=None, order_by=None, page_size=None, page_token=None): """Return a page of log entries. @@ -270,8 +431,8 @@

    Source code for gcloud.logging.client

                             https://cloud.google.com/logging/docs/view/advanced_filters
     
             :type order_by: str
    -        :param order_by: One of :data:`gcloud.logging.ASCENDING` or
    -                         :data:`gcloud.logging.DESCENDING`.
    +        :param order_by: One of :data:`~google.cloud.logging.client.ASCENDING`
    +                         or :data:`~google.cloud.logging.client.DESCENDING`.
     
             :type page_size: int
             :param page_size: maximum number of entries to return, If not passed,
    @@ -283,7 +444,7 @@ 

    Source code for gcloud.logging.client

                                entries.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.logging.entry.TextEntry`, plus a
    +        :returns: list of :class:`google.cloud.logging.entry.TextEntry`, plus a
                       "next page token" string:  if not None, indicates that
                       more entries can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -299,7 +460,7 @@ 

    Source code for gcloud.logging.client

                        for resource in resources]
             return entries, token
    -
    [docs] def sink(self, name, filter_=None, destination=None): +
    [docs] def sink(self, name, filter_=None, destination=None): """Creates a sink bound to the current client. :type name: str @@ -317,12 +478,12 @@

    Source code for gcloud.logging.client

                                 already exist, to be refreshed via
                                 :meth:`Sink.reload`.
     
    -        :rtype: :class:`gcloud.logging.sink.Sink`
    +        :rtype: :class:`google.cloud.logging.sink.Sink`
             :returns: Sink created with the current client.
             """
             return Sink(name, filter_, destination, client=self)
    -
    [docs] def list_sinks(self, page_size=None, page_token=None): +
    [docs] def list_sinks(self, page_size=None, page_token=None): """List sinks for the project associated with this client. See: @@ -338,7 +499,7 @@

    Source code for gcloud.logging.client

                                sinks.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.logging.sink.Sink`, plus a
    +        :returns: list of :class:`google.cloud.logging.sink.Sink`, plus a
                       "next page token" string:  if not None, indicates that
                       more sinks can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -349,7 +510,7 @@ 

    Source code for gcloud.logging.client

                      for resource in resources]
             return sinks, token
    -
    [docs] def metric(self, name, filter_=None, description=''): +
    [docs] def metric(self, name, filter_=None, description=''): """Creates a metric bound to the current client. :type name: str @@ -366,12 +527,12 @@

    Source code for gcloud.logging.client

                                 If not passed, the instance should already exist,
                                 to be refreshed via :meth:`Metric.reload`.
     
    -        :rtype: :class:`gcloud.logging.metric.Metric`
    +        :rtype: :class:`google.cloud.logging.metric.Metric`
             :returns: Metric created with the current client.
             """
             return Metric(name, filter_, client=self, description=description)
    -
    [docs] def list_metrics(self, page_size=None, page_token=None): +
    [docs] def list_metrics(self, page_size=None, page_token=None): """List metrics for the project associated with this client. See: @@ -387,7 +548,7 @@

    Source code for gcloud.logging.client

                                metrics.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.logging.metric.Metric`, plus a
    +        :returns: list of :class:`google.cloud.logging.metric.Metric`, plus a
                       "next page token" string:  if not None, indicates that
                       more metrics can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -399,123 +560,62 @@ 

    Source code for gcloud.logging.client

             return metrics, token
    -
    -
    +
    +
    + + +
    + +
    +

    + © Copyright 2014, Google. - -

    +

    +
    + Built with Sphinx using a theme provided by Read the Docs. - - - + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/connection.html b/latest/_modules/google/cloud/logging/connection.html similarity index 81% rename from latest/_modules/gcloud/logging/connection.html rename to latest/_modules/google/cloud/logging/connection.html index 0ab60a3db60c..1f3faa26ecb1 100644 --- a/latest/_modules/gcloud/logging/connection.html +++ b/latest/_modules/google/cloud/logging/connection.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.connection — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.connection — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.connection
    • +
    • -

      Source code for gcloud.logging.connection

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.connection

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,10 +268,10 @@ 

    Source code for gcloud.logging.connection

     
     """Create / interact with Stackdriver Logging connections."""
     
    -from gcloud import connection as base_connection
    +from google.cloud import connection as base_connection
     
     
    -
    [docs]class Connection(base_connection.JSONConnection): +
    [docs]class Connection(base_connection.JSONConnection): """A connection to Google Stackdriver Logging via the JSON REST API. :type credentials: :class:`oauth2client.client.OAuth2Credentials` @@ -154,7 +309,7 @@

    Source code for gcloud.logging.connection

         https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/entries
         https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.logs
     
    -    :type connection: :class:`gcloud.logging.connection.Connection`
    +    :type connection: :class:`google.cloud.logging.connection.Connection`
         :param connection: the connection used to make API requests.
         """
         def __init__(self, connection):
    @@ -176,8 +331,8 @@ 

    Source code for gcloud.logging.connection

                             https://cloud.google.com/logging/docs/view/advanced_filters
     
             :type order_by: str
    -        :param order_by: One of :data:`gcloud.logging.ASCENDING` or
    -                         :data:`gcloud.logging.DESCENDING`.
    +        :param order_by: One of :data:`~google.cloud.logging.client.ASCENDING`
    +                         or :data:`~google.cloud.logging.client.DESCENDING`.
     
             :type page_size: int
             :param page_size: maximum number of entries to return, If not passed,
    @@ -270,7 +425,7 @@ 

    Source code for gcloud.logging.connection

         See:
         https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks
     
    -    :type connection: :class:`gcloud.logging.connection.Connection`
    +    :type connection: :class:`google.cloud.logging.connection.Connection`
         :param connection: the connection used to make API requests.
         """
         def __init__(self, connection):
    @@ -409,7 +564,7 @@ 

    Source code for gcloud.logging.connection

         See:
         https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics
     
    -    :type connection: :class:`gcloud.logging.connection.Connection`
    +    :type connection: :class:`google.cloud.logging.connection.Connection`
         :param connection: the connection used to make API requests.
         """
         def __init__(self, connection):
    @@ -534,129 +689,68 @@ 

    Source code for gcloud.logging.connection

             :param project: ID of the project containing the metric.
     
             :type metric_name: string
    -        :param metric_name: the name of the metric
    +        :param metric_name: the name of the metric.
             """
             target = '/projects/%s/metrics/%s' % (project, metric_name)
             self._connection.api_request(method='DELETE', path=target)
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/entries.html b/latest/_modules/google/cloud/logging/entries.html similarity index 62% rename from latest/_modules/gcloud/logging/entries.html rename to latest/_modules/google/cloud/logging/entries.html index df83e237fd58..674da93894c1 100644 --- a/latest/_modules/gcloud/logging/entries.html +++ b/latest/_modules/google/cloud/logging/entries.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.entries — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.entries — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.entries
    • +
    • -

      Source code for gcloud.logging.entries

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.entries

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -118,8 +273,8 @@ 

    Source code for gcloud.logging.entries

     
     from google.protobuf.json_format import Parse
     
    -from gcloud._helpers import _name_from_project_path
    -from gcloud._helpers import _rfc3339_nanos_to_datetime
    +from google.cloud._helpers import _name_from_project_path
    +from google.cloud._helpers import _rfc3339_nanos_to_datetime
     
     
     _LOGGER_TEMPLATE = re.compile(r"""
    @@ -130,7 +285,7 @@ 

    Source code for gcloud.logging.entries

     """, re.VERBOSE)
     
     
    -
    [docs]def logger_name_from_path(path): +
    [docs]def logger_name_from_path(path): """Validate a logger URI path and get the logger name. :type path: str @@ -152,7 +307,7 @@

    Source code for gcloud.logging.entries

         :param payload: The payload passed as ``textPayload``, ``jsonPayload``,
                         or ``protoPayload``.
     
    -    :type logger: :class:`gcloud.logging.logger.Logger`
    +    :type logger: :class:`google.cloud.logging.logger.Logger`
         :param logger: the logger used to write the entry.
     
         :type insert_id: text, or :class:`NoneType`
    @@ -189,7 +344,7 @@ 

    Source code for gcloud.logging.entries

             :param resource: text entry resource representation returned from
                              the API
     
    -        :type client: :class:`gcloud.logging.client.Client`
    +        :type client: :class:`google.cloud.logging.client.Client`
             :param client: Client which holds credentials and project
                            configuration.
     
    @@ -197,7 +352,7 @@ 

    Source code for gcloud.logging.entries

             :param loggers: A mapping of logger fullnames -> loggers.  If not
                             passed, the entry will have a newly-created logger.
     
    -        :rtype: :class:`gcloud.logging.entries.TextEntry`
    +        :rtype: :class:`google.cloud.logging.entries.TextEntry`
             :returns: Text entry parsed from ``resource``.
             """
             if loggers is None:
    @@ -219,7 +374,7 @@ 

    Source code for gcloud.logging.entries

                        labels=labels, severity=severity, http_request=http_request)
     
     
    -
    [docs]class TextEntry(_BaseEntry): +
    [docs]class TextEntry(_BaseEntry): """Entry created with ``textPayload``. See: @@ -228,7 +383,7 @@

    Source code for gcloud.logging.entries

         _PAYLOAD_KEY = 'textPayload'
    -
    [docs]class StructEntry(_BaseEntry): +
    [docs]class StructEntry(_BaseEntry): """Entry created with ``jsonPayload``. See: @@ -237,7 +392,7 @@

    Source code for gcloud.logging.entries

         _PAYLOAD_KEY = 'jsonPayload'
    -
    [docs]class ProtobufEntry(_BaseEntry): +
    [docs]class ProtobufEntry(_BaseEntry): """Entry created with ``protoPayload``. See: @@ -245,7 +400,7 @@

    Source code for gcloud.logging.entries

         """
         _PAYLOAD_KEY = 'protoPayload'
     
    -
    [docs] def parse_message(self, message): +
    [docs] def parse_message(self, message): """Parse payload into a protobuf message. Mutates the passed-in ``message`` in place. @@ -256,123 +411,62 @@

    Source code for gcloud.logging.entries

             Parse(json.dumps(self.payload), message)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/logging/handlers/handlers.html b/latest/_modules/google/cloud/logging/handlers/handlers.html new file mode 100644 index 000000000000..b60fa5c3ef9a --- /dev/null +++ b/latest/_modules/google/cloud/logging/handlers/handlers.html @@ -0,0 +1,448 @@ + + + + + + + + + + + google.cloud.logging.handlers.handlers — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.handlers.handlers
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.handlers.handlers

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Python :mod:`logging` handlers for Google Cloud Logging."""
    +
    +import logging
    +
    +from google.cloud.logging.handlers.transports import BackgroundThreadTransport
    +
    +
    +EXCLUDE_LOGGER_DEFAULTS = (
    +    'google.cloud',
    +    'oauth2client'
    +)
    +
    +DEFAULT_LOGGER_NAME = 'python'
    +
    +
    +
    [docs]class CloudLoggingHandler(logging.StreamHandler): + """Python standard ``logging`` handler. + + This handler can be used to route Python standard logging messages + directly to the Google Cloud Logging API. + + Note that this handler currently only supports a synchronous API call, + which means each logging statement that uses this handler will require + an API call. + + :type client: :class:`google.cloud.logging.client` + :param client: the authenticated Google Cloud Logging client for this + handler to use + + :type name: str + :param name: the name of the custom log in Stackdriver Logging. Defaults + to 'python'. The name of the Python logger will be represented + in the ``python_logger`` field. + + :type transport: type + :param transport: Class for creating new transport objects. It should + extend from the base :class:`.Transport` type and + implement :meth`.Transport.send`. Defaults to + :class:`.BackgroundThreadTransport`. The other + option is :class:`.SyncTransport`. + + Example: + + .. doctest:: + + import google.cloud.logging + from google.cloud.logging.handlers import CloudLoggingHandler + + client = google.cloud.logging.Client() + handler = CloudLoggingHandler(client) + + cloud_logger = logging.getLogger('cloudLogger') + cloud_logger.setLevel(logging.INFO) + cloud_logger.addHandler(handler) + + cloud.logger.error('bad news') # API call + + """ + + def __init__(self, client, + name=DEFAULT_LOGGER_NAME, + transport=BackgroundThreadTransport): + super(CloudLoggingHandler, self).__init__() + self.name = name + self.client = client + self.transport = transport(client, name) + +
    [docs] def emit(self, record): + """Actually log the specified logging record. + + Overrides the default emit behavior of ``StreamHandler``. + + See: https://docs.python.org/2/library/logging.html#handler-objects + + :type record: :class:`logging.LogRecord` + :param record: The record to be logged. + """ + message = super(CloudLoggingHandler, self).format(record) + self.transport.send(record, message)
    + + +
    [docs]def setup_logging(handler, excluded_loggers=EXCLUDE_LOGGER_DEFAULTS): + """Attach the ``CloudLogging`` handler to the Python root logger + + Excludes loggers that this library itself uses to avoid + infinite recursion. + + :type handler: :class:`logging.handler` + :param handler: the handler to attach to the global handler + + :type excluded_loggers: tuple + :param excluded_loggers: The loggers to not attach the handler to. This + will always include the loggers in the path of + the logging client itself. + + Example: + + .. doctest:: + + import logging + import google.cloud.logging + from google.cloud.logging.handlers import CloudLoggingHandler + + client = google.cloud.logging.Client() + handler = CloudLoggingHandler(client) + google.cloud.logging.setup_logging(handler) + logging.getLogger().setLevel(logging.DEBUG) + + logging.error('bad news') # API call + + """ + all_excluded_loggers = set(excluded_loggers + EXCLUDE_LOGGER_DEFAULTS) + logger = logging.getLogger() + logger.addHandler(handler) + logger.addHandler(logging.StreamHandler()) + for logger_name in all_excluded_loggers: + logger = logging.getLogger(logger_name) + logger.propagate = False + logger.addHandler(logging.StreamHandler())
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/logging/handlers/transports/background_thread.html b/latest/_modules/google/cloud/logging/handlers/transports/background_thread.html new file mode 100644 index 000000000000..46f4ca86d564 --- /dev/null +++ b/latest/_modules/google/cloud/logging/handlers/transports/background_thread.html @@ -0,0 +1,486 @@ + + + + + + + + + + + google.cloud.logging.handlers.transports.background_thread — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.handlers.transports.background_thread
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.handlers.transports.background_thread

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Transport for Python logging handler
    +
    +Uses a background worker to log to Stackdriver Logging asynchronously.
    +"""
    +
    +import atexit
    +import copy
    +import threading
    +
    +from google.cloud.logging.client import Client
    +from google.cloud.logging.handlers.transports.base import Transport
    +
    +
    +class _Worker(object):
    +    """A threaded worker that writes batches of log entries
    +
    +    Writes entries to the logger API.
    +
    +    This class reuses a single :class:`Batch` method to write successive
    +    entries.
    +
    +    Currently, the only public methods are constructing it (which also starts
    +    it) and enqueuing :class:`Logger` (record, message) pairs.
    +    """
    +
    +    def __init__(self, logger):
    +        self.started = False
    +        self.stopping = False
    +        self.stopped = False
    +
    +        # _entries_condition is used to signal from the main thread whether
    +        # there are any waiting queued logger entries to be written
    +        self._entries_condition = threading.Condition()
    +
    +        # _stop_condition is used to signal from the worker thread to the
    +        # main thread that it's finished its last entries
    +        self._stop_condition = threading.Condition()
    +
    +        # This object continually reuses the same :class:`Batch` object to
    +        # write multiple entries at the same time.
    +        self.logger = logger
    +        self.batch = self.logger.batch()
    +
    +        self._thread = None
    +
    +        # Number in seconds of  how long to wait for worker to send remaining
    +        self._stop_timeout = 5
    +
    +        self._start()
    +
    +    def _run(self):
    +        """The entry point for the worker thread.
    +
    +        Loops until ``stopping`` is set to :data:`True`, and commits batch
    +        entries written during :meth:`enqueue`.
    +        """
    +        try:
    +            self._entries_condition.acquire()
    +            self.started = True
    +            while not self.stopping:
    +                if len(self.batch.entries) == 0:
    +                    # branch coverage of this code extremely flaky
    +                    self._entries_condition.wait()  # pragma: NO COVER
    +
    +                if len(self.batch.entries) > 0:
    +                    self.batch.commit()
    +        finally:
    +            self._entries_condition.release()
    +
    +        # main thread may be waiting for worker thread to finish writing its
    +        # final entries. here we signal that it's done.
    +        self._stop_condition.acquire()
    +        self._stop_condition.notify()
    +        self._stop_condition.release()
    +
    +    def _start(self):
    +        """Called by this class's constructor
    +
    +        This method is responsible for starting the thread and registering
    +        the exit handlers.
    +        """
    +        try:
    +            self._entries_condition.acquire()
    +            self._thread = threading.Thread(
    +                target=self._run,
    +                name='google.cloud.logging.handlers.transport.Worker')
    +            self._thread.setDaemon(True)
    +            self._thread.start()
    +        finally:
    +            self._entries_condition.release()
    +            atexit.register(self._stop)
    +
    +    def _stop(self):
    +        """Signals the worker thread to shut down
    +
    +        Also waits for ``stop_timeout`` seconds for the worker to finish.
    +
    +        This method is called by the ``atexit`` handler registered by
    +         :meth:`start`.
    +        """
    +        if not self.started or self.stopping:
    +            return
    +
    +        # lock the stop condition first so that the worker
    +        # thread can't notify it's finished before we wait
    +        self._stop_condition.acquire()
    +
    +        # now notify the worker thread to shutdown
    +        self._entries_condition.acquire()
    +        self.stopping = True
    +        self._entries_condition.notify()
    +        self._entries_condition.release()
    +
    +        # now wait for it to signal it's finished
    +        self._stop_condition.wait(self._stop_timeout)
    +        self._stop_condition.release()
    +        self.stopped = True
    +
    +    def enqueue(self, record, message):
    +        """Queues up a log entry to be written by the background thread."""
    +        try:
    +            self._entries_condition.acquire()
    +            if self.stopping:
    +                return
    +            info = {'message': message, 'python_logger': record.name}
    +            self.batch.log_struct(info, severity=record.levelname)
    +            self._entries_condition.notify()
    +        finally:
    +            self._entries_condition.release()
    +
    +
    +
    [docs]class BackgroundThreadTransport(Transport): + """Aysnchronous transport that uses a background thread. + + Writes logging entries as a batch process. + """ + + def __init__(self, client, name): + http = copy.deepcopy(client.connection.http) + http = client.connection.credentials.authorize(http) + self.client = Client(client.project, + client.connection.credentials, + http) + logger = self.client.logger(name) + self.worker = _Worker(logger) + +
    [docs] def send(self, record, message): + """Overrides Transport.send(). + + :type record: :class:`logging.LogRecord` + :param record: Python log record that the handler was called with. + + :type message: str + :param message: The message from the ``LogRecord`` after being + formatted by the associated log formatters. + """ + self.worker.enqueue(record, message)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/logging/handlers/transports/base.html b/latest/_modules/google/cloud/logging/handlers/transports/base.html new file mode 100644 index 000000000000..6e2458e373fe --- /dev/null +++ b/latest/_modules/google/cloud/logging/handlers/transports/base.html @@ -0,0 +1,350 @@ + + + + + + + + + + + google.cloud.logging.handlers.transports.base — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.handlers.transports.base
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.handlers.transports.base

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Module containing base class for logging transport."""
    +
    +
    +
    [docs]class Transport(object): + """Base class for Google Cloud Logging handler transports. + + Subclasses of :class:`Transport` must have constructors that accept a + client and name object, and must override :meth:`send`. + """ + +
    [docs] def send(self, record, message): + """Transport send to be implemented by subclasses. + + :type record: :class:`logging.LogRecord` + :param record: Python log record that the handler was called with. + + :type message: str + :param message: The message from the ``LogRecord`` after being + formatted by the associated log formatters. + """ + raise NotImplementedError
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/logging/handlers/transports/sync.html b/latest/_modules/google/cloud/logging/handlers/transports/sync.html new file mode 100644 index 000000000000..4fc8e8c1c246 --- /dev/null +++ b/latest/_modules/google/cloud/logging/handlers/transports/sync.html @@ -0,0 +1,358 @@ + + + + + + + + + + + google.cloud.logging.handlers.transports.sync — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.handlers.transports.sync
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.handlers.transports.sync

    +# Copyright 2016 Google Inc. All Rights Reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Transport for Python logging handler.
    +
    +Logs directly to the the Stackdriver Logging API with a synchronous call.
    +"""
    +
    +from google.cloud.logging.handlers.transports.base import Transport
    +
    +
    +
    [docs]class SyncTransport(Transport): + """Basic sychronous transport. + + Uses this library's Logging client to directly make the API call. + """ + + def __init__(self, client, name): + self.logger = client.logger(name) + +
    [docs] def send(self, record, message): + """Overrides transport.send(). + + :type record: :class:`logging.LogRecord` + :param record: Python log record that the handler was called with. + + :type message: str + :param message: The message from the ``LogRecord`` after being + formatted by the associated log formatters. + """ + info = {'message': message, 'python_logger': record.name} + self.logger.log_struct(info, severity=record.levelname)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/logger.html b/latest/_modules/google/cloud/logging/logger.html similarity index 73% rename from latest/_modules/gcloud/logging/logger.html rename to latest/_modules/google/cloud/logging/logger.html index 593ce295fe4e..92251d3258e3 100644 --- a/latest/_modules/gcloud/logging/logger.html +++ b/latest/_modules/google/cloud/logging/logger.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.logger — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.logger — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + -
    + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.logger
    • +
    • + + -

      Source code for gcloud.logging.logger

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.logger

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -118,7 +273,7 @@ 

    Source code for gcloud.logging.logger

     from google.protobuf.json_format import MessageToJson
     
     
    -
    [docs]class Logger(object): +
    [docs]class Logger(object): """Loggers represent named targets for log entries. See: @@ -127,7 +282,7 @@

    Source code for gcloud.logging.logger

         :type name: string
         :param name: the name of the logger
     
    -    :type client: :class:`gcloud.logging.client.Client`
    +    :type client: :class:`google.cloud.logging.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the logger (which requires a project).
     
    @@ -163,21 +318,23 @@ 

    Source code for gcloud.logging.logger

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current logger.
     
    -        :rtype: :class:`gcloud.logging.client.Client`
    +        :rtype: :class:`google.cloud.logging.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self._client
             return client
     
    -
    [docs] def batch(self, client=None): +
    [docs] def batch(self, client=None): """Return a batch to use as a context manager. - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current topic. @@ -254,7 +411,7 @@

    Source code for gcloud.logging.logger

     
             return resource
     
    -
    [docs] def log_text(self, text, client=None, labels=None, insert_id=None, +
    [docs] def log_text(self, text, client=None, labels=None, insert_id=None, severity=None, http_request=None): """API call: log a text message via a POST request @@ -264,7 +421,8 @@

    Source code for gcloud.logging.logger

             :type text: text
             :param text: the log message.
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current logger.
     
    @@ -287,7 +445,7 @@ 

    Source code for gcloud.logging.logger

                 http_request=http_request)
             client.logging_api.write_entries([entry_resource])
    -
    [docs] def log_struct(self, info, client=None, labels=None, insert_id=None, +
    [docs] def log_struct(self, info, client=None, labels=None, insert_id=None, severity=None, http_request=None): """API call: log a structured message via a POST request @@ -297,7 +455,8 @@

    Source code for gcloud.logging.logger

             :type info: dict
             :param info: the log entry information
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current logger.
     
    @@ -312,7 +471,7 @@ 

    Source code for gcloud.logging.logger

     
             :type http_request: dict or :class:`NoneType`
             :param http_request: (optional) info about HTTP request associated with
    -                             the entry
    +                             the entry.
             """
             client = self._require_client(client)
             entry_resource = self._make_entry_resource(
    @@ -320,7 +479,7 @@ 

    Source code for gcloud.logging.logger

                 http_request=http_request)
             client.logging_api.write_entries([entry_resource])
    -
    [docs] def log_proto(self, message, client=None, labels=None, insert_id=None, +
    [docs] def log_proto(self, message, client=None, labels=None, insert_id=None, severity=None, http_request=None): """API call: log a protobuf message via a POST request @@ -330,7 +489,8 @@

    Source code for gcloud.logging.logger

             :type message: Protobuf message
             :param message: the message to be logged
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current logger.
     
    @@ -345,7 +505,7 @@ 

    Source code for gcloud.logging.logger

     
             :type http_request: dict or :class:`NoneType`
             :param http_request: (optional) info about HTTP request associated with
    -                             the entry
    +                             the entry.
             """
             client = self._require_client(client)
             entry_resource = self._make_entry_resource(
    @@ -353,20 +513,21 @@ 

    Source code for gcloud.logging.logger

                 severity=severity, http_request=http_request)
             client.logging_api.write_entries([entry_resource])
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete all entries in a logger via a DELETE request See: https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.logs/delete - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current logger. """ client = self._require_client(client) client.logging_api.logger_delete(self.project, self.name)
    -
    [docs] def list_entries(self, projects=None, filter_=None, order_by=None, +
    [docs] def list_entries(self, projects=None, filter_=None, order_by=None, page_size=None, page_token=None): """Return a page of log entries. @@ -382,8 +543,8 @@

    Source code for gcloud.logging.logger

                             https://cloud.google.com/logging/docs/view/advanced_filters
     
             :type order_by: string
    -        :param order_by: One of :data:`gcloud.logging.ASCENDING` or
    -                         :data:`gcloud.logging.DESCENDING`.
    +        :param order_by: One of :data:`~google.cloud.logging.client.ASCENDING`
    +                         or :data:`~google.cloud.logging.client.DESCENDING`.
     
             :type page_size: int
             :param page_size: maximum number of entries to return, If not passed,
    @@ -395,7 +556,7 @@ 

    Source code for gcloud.logging.logger

                                entries.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.logging.entry.TextEntry`, plus a
    +        :returns: list of :class:`google.cloud.logging.entry.TextEntry`, plus a
                       "next page token" string:  if not None, indicates that
                       more entries can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -410,15 +571,15 @@ 

    Source code for gcloud.logging.logger

                 page_size=page_size, page_token=page_token)
    -
    [docs]class Batch(object): +
    [docs]class Batch(object): """Context manager: collect entries to log via a single API call. Helper returned by :meth:`Logger.batch` - :type logger: :class:`gcloud.logging.logger.Logger` + :type logger: :class:`google.cloud.logging.logger.Logger` :param logger: the logger to which entries will be logged. - :type client: :class:`gcloud.logging.client.Client` + :type client: :class:`google.cloud.logging.client.Client` :param client: The client to use. """ def __init__(self, logger, client): @@ -433,7 +594,7 @@

    Source code for gcloud.logging.logger

             if exc_type is None:
                 self.commit()
     
    -
    [docs] def log_text(self, text, labels=None, insert_id=None, severity=None, +
    [docs] def log_text(self, text, labels=None, insert_id=None, severity=None, http_request=None): """Add a text entry to be logged during :meth:`commit`. @@ -456,7 +617,7 @@

    Source code for gcloud.logging.logger

             self.entries.append(
                 ('text', text, labels, insert_id, severity, http_request))
    -
    [docs] def log_struct(self, info, labels=None, insert_id=None, severity=None, +
    [docs] def log_struct(self, info, labels=None, insert_id=None, severity=None, http_request=None): """Add a struct entry to be logged during :meth:`commit`. @@ -479,7 +640,7 @@

    Source code for gcloud.logging.logger

             self.entries.append(
                 ('struct', info, labels, insert_id, severity, http_request))
    -
    [docs] def log_proto(self, message, labels=None, insert_id=None, severity=None, +
    [docs] def log_proto(self, message, labels=None, insert_id=None, severity=None, http_request=None): """Add a protobuf entry to be logged during :meth:`commit`. @@ -502,10 +663,11 @@

    Source code for gcloud.logging.logger

             self.entries.append(
                 ('proto', message, labels, insert_id, severity, http_request))
    -
    [docs] def commit(self, client=None): +
    [docs] def commit(self, client=None): """Send saved log entries as a single API call. - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current batch. """ @@ -513,7 +675,7 @@

    Source code for gcloud.logging.logger

                 client = self.client
     
             kwargs = {
    -            'logger_name': self.logger.path,
    +            'logger_name': self.logger.full_name,
                 'resource': {'type': 'global'},
             }
             if self.logger.labels is not None:
    @@ -545,123 +707,62 @@ 

    Source code for gcloud.logging.logger

             del self.entries[:]
    -
    -
    +
    +
    + + +
    + +
    +

    + © Copyright 2014, Google. - -

    +

    +
    + Built with Sphinx using a theme provided by Read the Docs. - - - + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/metric.html b/latest/_modules/google/cloud/logging/metric.html similarity index 61% rename from latest/_modules/gcloud/logging/metric.html rename to latest/_modules/google/cloud/logging/metric.html index 262340ae93ff..0ae3d021185b 100644 --- a/latest/_modules/gcloud/logging/metric.html +++ b/latest/_modules/google/cloud/logging/metric.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.metric — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.metric — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.metric
    • +
    • -

      Source code for gcloud.logging.metric

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.metric

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,10 +268,10 @@ 

    Source code for gcloud.logging.metric

     
     """Define Stackdriver Logging API Metrics."""
     
    -from gcloud.exceptions import NotFound
    +from google.cloud.exceptions import NotFound
     
     
    -
    [docs]class Metric(object): +
    [docs]class Metric(object): """Metrics represent named filters for log entries. See: @@ -130,7 +285,7 @@

    Source code for gcloud.logging.metric

                        tracked by the metric.  If not passed, the instance should
                        already exist, to be refreshed via :meth:`reload`.
     
    -    :type client: :class:`gcloud.logging.client.Client`
    +    :type client: :class:`google.cloud.logging.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the metric (which requires a project).
     
    @@ -164,17 +319,17 @@ 

    Source code for gcloud.logging.metric

             return '/%s' % (self.full_name,)
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a metric given its API representation :type resource: dict :param resource: metric resource representation returned from the API - :type client: :class:`gcloud.logging.client.Client` + :type client: :class:`google.cloud.logging.client.Client` :param client: Client which holds credentials and project configuration for the metric. - :rtype: :class:`gcloud.logging.metric.Metric` + :rtype: :class:`google.cloud.logging.metric.Metric` :returns: Metric parsed from ``resource``. """ metric_name = resource['name'] @@ -186,24 +341,26 @@

    Source code for gcloud.logging.metric

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current metric.
     
    -        :rtype: :class:`gcloud.logging.client.Client`
    +        :rtype: :class:`google.cloud.logging.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self._client
             return client
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the metric via a PUT request See: https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/create - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current metric. """ @@ -211,13 +368,14 @@

    Source code for gcloud.logging.metric

             client.metrics_api.metric_create(
                 self.project, self.name, self.filter_, self.description)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the metric via a GET request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/get - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current metric. @@ -233,13 +391,14 @@

    Source code for gcloud.logging.metric

             else:
                 return True
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: sync local metric configuration via a GET request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/get - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current metric. """ @@ -248,13 +407,14 @@

    Source code for gcloud.logging.metric

             self.description = data.get('description', '')
             self.filter_ = data['filter']
    -
    [docs] def update(self, client=None): +
    [docs] def update(self, client=None): """API call: update metric configuration via a PUT request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/update - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current metric. """ @@ -262,13 +422,14 @@

    Source code for gcloud.logging.metric

             client.metrics_api.metric_update(
                 self.project, self.name, self.filter_, self.description)
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete a metric via a DELETE request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.metrics/delete - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current metric. """ @@ -276,123 +437,62 @@

    Source code for gcloud.logging.metric

             client.metrics_api.metric_delete(self.project, self.name)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/logging/sink.html b/latest/_modules/google/cloud/logging/sink.html similarity index 62% rename from latest/_modules/gcloud/logging/sink.html rename to latest/_modules/google/cloud/logging/sink.html index 33ac493a6ebc..bba4b01e445e 100644 --- a/latest/_modules/gcloud/logging/sink.html +++ b/latest/_modules/google/cloud/logging/sink.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.logging.sink — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.logging.sink — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.logging.sink
    • +
    • -

      Source code for gcloud.logging.sink

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.logging.sink

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,10 +268,10 @@ 

    Source code for gcloud.logging.sink

     
     """Define Stackdriver Logging API Sinks."""
     
    -from gcloud.exceptions import NotFound
    +from google.cloud.exceptions import NotFound
     
     
    -
    [docs]class Sink(object): +
    [docs]class Sink(object): """Sinks represent filtered exports for log entries. See: @@ -135,7 +290,7 @@

    Source code for gcloud.logging.sink

                             If not passed, the instance should already exist, to
                             be refreshed via :meth:`reload`.
     
    -    :type client: :class:`gcloud.logging.client.Client`
    +    :type client: :class:`google.cloud.logging.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the sink (which requires a project).
         """
    @@ -166,17 +321,17 @@ 

    Source code for gcloud.logging.sink

             return '/%s' % (self.full_name)
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a sink given its API representation :type resource: dict :param resource: sink resource representation returned from the API - :type client: :class:`gcloud.logging.client.Client` + :type client: :class:`google.cloud.logging.client.Client` :param client: Client which holds credentials and project configuration for the sink. - :rtype: :class:`gcloud.logging.sink.Sink` + :rtype: :class:`google.cloud.logging.sink.Sink` :returns: Sink parsed from ``resource``. :raises: :class:`ValueError` if ``client`` is not ``None`` and the project from the resource does not agree with the project @@ -190,24 +345,26 @@

    Source code for gcloud.logging.sink

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.logging.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.logging.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current sink.
     
    -        :rtype: :class:`gcloud.logging.client.Client`
    +        :rtype: :class:`google.cloud.logging.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self._client
             return client
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the sink via a PUT request See: https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks/create - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current sink. """ @@ -215,13 +372,14 @@

    Source code for gcloud.logging.sink

             client.sinks_api.sink_create(
                 self.project, self.name, self.filter_, self.destination)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the sink via a GET request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks/get - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current sink. @@ -237,13 +395,14 @@

    Source code for gcloud.logging.sink

             else:
                 return True
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: sync local sink configuration via a GET request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks/get - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current sink. """ @@ -252,13 +411,14 @@

    Source code for gcloud.logging.sink

             self.filter_ = data['filter']
             self.destination = data['destination']
    -
    [docs] def update(self, client=None): +
    [docs] def update(self, client=None): """API call: update sink configuration via a PUT request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks/update - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current sink. """ @@ -266,13 +426,14 @@

    Source code for gcloud.logging.sink

             client.sinks_api.sink_update(
                 self.project, self.name, self.filter_, self.destination)
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete a sink via a DELETE request See https://cloud.google.com/logging/docs/api/ref_v2beta1/rest/v2beta1/projects.sinks/delete - :type client: :class:`gcloud.logging.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.logging.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current sink. """ @@ -280,123 +441,62 @@

    Source code for gcloud.logging.sink

             client.sinks_api.sink_delete(self.project, self.name)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/monitoring/client.html b/latest/_modules/google/cloud/monitoring/client.html new file mode 100644 index 000000000000..3d06ae7210e6 --- /dev/null +++ b/latest/_modules/google/cloud/monitoring/client.html @@ -0,0 +1,812 @@ + + + + + + + + + + + google.cloud.monitoring.client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.client
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.client

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Client for interacting with the `Google Stackdriver Monitoring API (V3)`_.
    +
    +Example::
    +
    +    >>> from google.cloud import monitoring
    +    >>> client = monitoring.Client()
    +    >>> query = client.query(minutes=5)
    +    >>> print(query.as_dataframe())  # Requires pandas.
    +
    +At present, the client supports querying of time series, metric descriptors,
    +and monitored resource descriptors.
    +
    +.. _Google Stackdriver Monitoring API (V3):
    +    https://cloud.google.com/monitoring/api/v3/
    +"""
    +
    +import datetime
    +
    +from google.cloud.client import JSONClient
    +from google.cloud.monitoring.connection import Connection
    +from google.cloud.monitoring.group import Group
    +from google.cloud.monitoring.metric import Metric
    +from google.cloud.monitoring.metric import MetricDescriptor
    +from google.cloud.monitoring.metric import MetricKind
    +from google.cloud.monitoring.metric import ValueType
    +from google.cloud.monitoring.query import Query
    +from google.cloud.monitoring.resource import Resource
    +from google.cloud.monitoring.resource import ResourceDescriptor
    +from google.cloud.monitoring.timeseries import Point
    +from google.cloud.monitoring.timeseries import TimeSeries
    +
    +_UTCNOW = datetime.datetime.utcnow  # To be replaced by tests.
    +
    +
    +
    [docs]class Client(JSONClient): + """Client to bundle configuration needed for API requests. + + :type project: string + :param project: The target project. If not passed, falls back to the + default inferred from the environment. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` or + :class:`NoneType` + :param credentials: The OAuth2 Credentials to use for the connection + owned by this client. If not passed (and if no ``http`` + object is passed), falls back to the default inferred + from the environment. + + :type http: :class:`httplib2.Http` or class that defines ``request()`` + :param http: An optional HTTP object to make requests. If not passed, an + ``http`` object is created that is bound to the + ``credentials`` for the current object. + """ + + _connection_class = Connection + +
    [docs] def query(self, + metric_type=Query.DEFAULT_METRIC_TYPE, + end_time=None, + days=0, hours=0, minutes=0): + """Construct a query object for retrieving metric data. + + Example:: + + >>> query = client.query(minutes=5) + >>> print(query.as_dataframe()) # Requires pandas. + + :type metric_type: string + :param metric_type: The metric type name. The default value is + :data:`Query.DEFAULT_METRIC_TYPE + <google.cloud.monitoring.query.Query.DEFAULT_METRIC_TYPE>`, + but please note that this default value is provided only for + demonstration purposes and is subject to change. See the + `supported metrics`_. + + :type end_time: :class:`datetime.datetime` or None + :param end_time: The end time (inclusive) of the time interval + for which results should be returned, as a datetime object. + The default is the start of the current minute. + + The start time (exclusive) is determined by combining the + values of ``days``, ``hours``, and ``minutes``, and + subtracting the resulting duration from the end time. + + It is also allowed to omit the end time and duration here, + in which case + :meth:`~google.cloud.monitoring.query.Query.select_interval` + must be called before the query is executed. + + :type days: integer + :param days: The number of days in the time interval. + + :type hours: integer + :param hours: The number of hours in the time interval. + + :type minutes: integer + :param minutes: The number of minutes in the time interval. + + :rtype: :class:`~google.cloud.monitoring.query.Query` + :returns: The query object. + + :raises: :exc:`ValueError` if ``end_time`` is specified but + ``days``, ``hours``, and ``minutes`` are all zero. + If you really want to specify a point in time, use + :meth:`~google.cloud.monitoring.query.Query.select_interval`. + + .. _supported metrics: https://cloud.google.com/monitoring/api/metrics + """ + return Query(self, metric_type, + end_time=end_time, + days=days, hours=hours, minutes=minutes)
    + +
    [docs] def metric_descriptor(self, type_, + metric_kind=MetricKind.METRIC_KIND_UNSPECIFIED, + value_type=ValueType.VALUE_TYPE_UNSPECIFIED, + labels=(), unit='', description='', display_name=''): + """Construct a metric descriptor object. + + Metric descriptors specify the schema for a particular metric type. + + This factory method is used most often in conjunction with the metric + descriptor + :meth:`~google.cloud.monitoring.metric.MetricDescriptor.create` + method to define custom metrics:: + + >>> descriptor = client.metric_descriptor( + ... 'custom.googleapis.com/my_metric', + ... metric_kind=MetricKind.GAUGE, + ... value_type=ValueType.DOUBLE, + ... description='This is a simple example of a custom metric.') + >>> descriptor.create() + + Here is an example where the custom metric is parameterized by a + metric label:: + + >>> label = LabelDescriptor('response_code', LabelValueType.INT64, + ... description='HTTP status code') + >>> descriptor = client.metric_descriptor( + ... 'custom.googleapis.com/my_app/response_count', + ... metric_kind=MetricKind.CUMULATIVE, + ... value_type=ValueType.INT64, + ... labels=[label], + ... description='Cumulative count of HTTP responses.') + >>> descriptor.create() + + :type type_: string + :param type_: + The metric type including a DNS name prefix. For example: + ``"custom.googleapis.com/my_metric"`` + + :type metric_kind: string + :param metric_kind: + The kind of measurement. It must be one of + :data:`MetricKind.GAUGE`, :data:`MetricKind.DELTA`, + or :data:`MetricKind.CUMULATIVE`. + See :class:`~google.cloud.monitoring.metric.MetricKind`. + + :type value_type: string + :param value_type: + The value type of the metric. It must be one of + :data:`ValueType.BOOL`, :data:`ValueType.INT64`, + :data:`ValueType.DOUBLE`, :data:`ValueType.STRING`, + or :data:`ValueType.DISTRIBUTION`. + See :class:`ValueType`. + + :type labels: + list of :class:`~google.cloud.monitoring.label.LabelDescriptor` + :param labels: + A sequence of zero or more label descriptors specifying the labels + used to identify a specific instance of this metric. + + :type unit: string + :param unit: An optional unit in which the metric value is reported. + + :type description: string + :param description: An optional detailed description of the metric. + + :type display_name: string + :param display_name: An optional concise name for the metric. + + :rtype: :class:`MetricDescriptor` + :returns: The metric descriptor created with the passed-in arguments. + """ + return MetricDescriptor( + self, type_, + metric_kind=metric_kind, + value_type=value_type, + labels=labels, + unit=unit, + description=description, + display_name=display_name, + )
    + + @staticmethod +
    [docs] def metric(type_, labels): + """Factory for constructing metric objects. + + :class:`~google.cloud.monitoring.metric.Metric` objects are typically + created to write custom metric values. The type should match the + metric type specified in the + :class:`~google.cloud.monitoring.metric.MetricDescriptor` used to + create the custom metric:: + + >>> metric = client.metric('custom.googleapis.com/my_metric', + ... labels={ + ... 'status': 'successful', + ... }) + + :type type_: string + :param type_: The metric type name. + + :type labels: dict + :param labels: A mapping from label names to values for all labels + enumerated in the associated + :class:`~google.cloud.monitoring.metric.MetricDescriptor`. + + :rtype: :class:`~google.cloud.monitoring.metric.Metric` + :returns: The metric object. + """ + return Metric(type=type_, labels=labels)
    + + @staticmethod +
    [docs] def resource(type_, labels): + """Factory for constructing monitored resource objects. + + A monitored resource object ( + :class:`~google.cloud.monitoring.resource.Resource`) is + typically used to create a + :class:`~google.cloud.monitoring.timeseries.TimeSeries` object. + + For a list of possible monitored resource types and their associated + labels, see: + + https://cloud.google.com/monitoring/api/resources + + :type type_: string + :param type_: The monitored resource type name. + + :type labels: dict + :param labels: A mapping from label names to values for all labels + enumerated in the associated + :class:`~google.cloud.monitoring.resource.ResourceDescriptor`, + except that ``project_id`` can and should be omitted + when writing time series data. + + :rtype: :class:`~google.cloud.monitoring.resource.Resource` + :returns: A monitored resource object. + """ + return Resource(type_, labels)
    + + @staticmethod +
    [docs] def time_series(metric, resource, value, + end_time=None, start_time=None): + """Construct a time series object for a single data point. + + .. note:: + + While :class:`~google.cloud.monitoring.timeseries.TimeSeries` + objects returned by the API typically have multiple data points, + :class:`~google.cloud.monitoring.timeseries.TimeSeries` objects + sent to the API must have at most one point. + + For example:: + + >>> timeseries = client.time_series(metric, resource, 1.23, + ... end_time=end) + + For more information, see: + + https://cloud.google.com/monitoring/api/ref_v3/rest/v3/TimeSeries + + :type metric: :class:`~google.cloud.monitoring.metric.Metric` + :param metric: A :class:`~google.cloud.monitoring.metric.Metric`. + + :type resource: :class:`~google.cloud.monitoring.resource.Resource` + :param resource: A :class:`~google.cloud.monitoring.resource.Resource` + object. + + :type value: bool, int, string, or float + :param value: + The value of the data point to create for the + :class:`~google.cloud.monitoring.timeseries.TimeSeries`. + + .. note:: + + The Python type of the value will determine the + :class:`~ValueType` sent to the API, which must match the value + type specified in the metric descriptor. For example, a Python + float will be sent to the API as a :data:`ValueType.DOUBLE`. + + :type end_time: :class:`~datetime.datetime` + :param end_time: + The end time for the point to be included in the time series. + Assumed to be UTC if no time zone information is present. + Defaults to the current time, as obtained by calling + :meth:`datetime.datetime.utcnow`. + + :type start_time: :class:`~datetime.datetime` + :param start_time: + The start time for the point to be included in the time series. + Assumed to be UTC if no time zone information is present + Defaults to None. If the start time is unspecified, + the API interprets the start time to be the same as the end time. + + :rtype: :class:`~google.cloud.monitoring.timeseries.TimeSeries` + :returns: A time series object. + """ + if end_time is None: + end_time = _UTCNOW() + point = Point(value=value, start_time=start_time, end_time=end_time) + return TimeSeries(metric=metric, resource=resource, metric_kind=None, + value_type=None, points=[point])
    + +
    [docs] def fetch_metric_descriptor(self, metric_type): + """Look up a metric descriptor by type. + + Example:: + + >>> METRIC = 'compute.googleapis.com/instance/cpu/utilization' + >>> print(client.fetch_metric_descriptor(METRIC)) + + :type metric_type: string + :param metric_type: The metric type name. + + :rtype: :class:`~google.cloud.monitoring.metric.MetricDescriptor` + :returns: The metric descriptor instance. + + :raises: :class:`google.cloud.exceptions.NotFound` if the metric + descriptor is not found. + """ + return MetricDescriptor._fetch(self, metric_type)
    + +
    [docs] def list_metric_descriptors(self, filter_string=None, type_prefix=None): + """List all metric descriptors for the project. + + Examples:: + + >>> for descriptor in client.list_metric_descriptors(): + ... print(descriptor.type) + + >>> for descriptor in client.list_metric_descriptors( + ... type_prefix='custom.'): + ... print(descriptor.type) + + :type filter_string: string or None + :param filter_string: + An optional filter expression describing the metric descriptors + to be returned. See the `filter documentation`_. + + :type type_prefix: string or None + :param type_prefix: An optional prefix constraining the selected + metric types. This adds ``metric.type = starts_with("<prefix>")`` + to the filter. + + :rtype: + list of :class:`~google.cloud.monitoring.metric.MetricDescriptor` + :returns: A list of metric descriptor instances. + + .. _filter documentation: + https://cloud.google.com/monitoring/api/v3/filters + """ + return MetricDescriptor._list(self, filter_string, + type_prefix=type_prefix)
    + +
    [docs] def fetch_resource_descriptor(self, resource_type): + """Look up a monitored resource descriptor by type. + + Example:: + + >>> print(client.fetch_resource_descriptor('gce_instance')) + + :type resource_type: string + :param resource_type: The resource type name. + + :rtype: :class:`~google.cloud.monitoring.resource.ResourceDescriptor` + :returns: The resource descriptor instance. + + :raises: :class:`google.cloud.exceptions.NotFound` if the resource + descriptor is not found. + """ + return ResourceDescriptor._fetch(self, resource_type)
    + +
    [docs] def list_resource_descriptors(self, filter_string=None): + """List all monitored resource descriptors for the project. + + Example:: + + >>> for descriptor in client.list_resource_descriptors(): + ... print(descriptor.type) + + :type filter_string: string or None + :param filter_string: + An optional filter expression describing the resource descriptors + to be returned. See the `filter documentation`_. + + :rtype: list of + :class:`~google.cloud.monitoring.resource.ResourceDescriptor` + :returns: A list of resource descriptor instances. + + .. _filter documentation: + https://cloud.google.com/monitoring/api/v3/filters + """ + return ResourceDescriptor._list(self, filter_string)
    + +
    [docs] def group(self, group_id=None, display_name=None, parent_id=None, + filter_string=None, is_cluster=False): + """Factory constructor for group object. + + .. note:: + This will not make an HTTP request; it simply instantiates + a group object owned by this client. + + :type group_id: string or None + :param group_id: The ID of the group. + + :type display_name: string or None + :param display_name: + A user-assigned name for this group, used only for display + purposes. + + :type parent_id: string or None + :param parent_id: + The ID of the group's parent, if it has one. + + :type filter_string: string or None + :param filter_string: + The filter string used to determine which monitored resources + belong to this group. + + :type is_cluster: boolean + :param is_cluster: + If true, the members of this group are considered to be a cluster. + The system can perform additional analysis on groups that are + clusters. + + :rtype: :class:`Group` + :returns: The group created with the passed-in arguments. + + :raises: + :exc:`ValueError` if both ``group_id`` and ``name`` are specified. + """ + return Group( + self, + group_id=group_id, + display_name=display_name, + parent_id=parent_id, + filter_string=filter_string, + is_cluster=is_cluster, + )
    + +
    [docs] def fetch_group(self, group_id): + """Fetch a group from the API based on it's ID. + + Example:: + + >>> try: + >>> group = client.fetch_group('1234') + >>> except google.cloud.exceptions.NotFound: + >>> print('That group does not exist!') + + :type group_id: string + :param group_id: The ID of the group. + + :rtype: :class:`~google.cloud.monitoring.group.Group` + :returns: The group instance. + + :raises: :class:`google.cloud.exceptions.NotFound` if the group + is not found. + """ + return Group._fetch(self, group_id)
    + +
    [docs] def list_groups(self): + """List all groups for the project. + + Example:: + + >>> for group in client.list_groups(): + ... print((group.display_name, group.name)) + + :rtype: list of :class:`~google.cloud.monitoring.group.Group` + :returns: A list of group instances. + """ + return Group._list(self)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/monitoring/connection.html b/latest/_modules/google/cloud/monitoring/connection.html new file mode 100644 index 000000000000..18a392964e07 --- /dev/null +++ b/latest/_modules/google/cloud/monitoring/connection.html @@ -0,0 +1,362 @@ + + + + + + + + + + + google.cloud.monitoring.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.connection

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Stackdriver Monitoring connections."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Stackdriver Monitoring via the JSON REST API. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` + :param credentials: (Optional) The OAuth2 Credentials to use for this + connection. + + :type http: :class:`httplib2.Http` or class that defines ``request()`` + :param http: (Optional) HTTP object to make requests. + + :type api_base_url: string + :param api_base_url: The base of the API call URL. Defaults to the value + :attr:`Connection.API_BASE_URL`. + """ + + API_BASE_URL = 'https://monitoring.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v3' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/monitoring.read', + 'https://www.googleapis.com/auth/monitoring', + 'https://www.googleapis.com/auth/cloud-platform') + """The scopes required for authenticating as a Monitoring consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/monitoring/group.html b/latest/_modules/google/cloud/monitoring/group.html new file mode 100644 index 000000000000..84b902c46148 --- /dev/null +++ b/latest/_modules/google/cloud/monitoring/group.html @@ -0,0 +1,811 @@ + + + + + + + + + + + google.cloud.monitoring.group — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.group
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.group

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Groups for the `Google Stackdriver Monitoring API (V3)`_.
    +
    +.. _Google Stackdriver Monitoring API (V3):
    +    https://cloud.google.com/monitoring/api/ref_v3/rest/v3/\
    +    projects.groups
    +"""
    +
    +import re
    +
    +from google.cloud._helpers import _datetime_to_rfc3339
    +from google.cloud._helpers import _name_from_project_path
    +from google.cloud.exceptions import NotFound
    +from google.cloud.monitoring.resource import Resource
    +
    +
    +_GROUP_TEMPLATE = re.compile(r"""
    +    projects/            # static prefix
    +    (?P<project>[^/]+)   # initial letter, wordchars + hyphen
    +    /groups/             # static midfix
    +    (?P<name>[^/]+)      # initial letter, wordchars + allowed punc
    +""", re.VERBOSE)
    +
    +
    +def _group_id_from_name(path, project=None):
    +    """Validate a group URI path and get the group ID.
    +
    +    :type path: string
    +    :param path: URI path for a group API request.
    +
    +    :type project: string or None
    +    :param project: The project associated with the request. It is
    +                    included for validation purposes.
    +
    +    :rtype: string
    +    :returns: Group ID parsed from ``path``.
    +    :raises: :class:`ValueError` if the ``path`` is ill-formed or if
    +             the project from the ``path`` does not agree with the
    +             ``project`` passed in.
    +    """
    +    return _name_from_project_path(path, project, _GROUP_TEMPLATE)
    +
    +
    +def _group_name_from_id(project, group_id):
    +    """Build the group name given the project and group ID.
    +
    +    :type project: string
    +    :param project: The project associated with the group.
    +
    +    :type group_id: string
    +    :param group_id: The group ID.
    +
    +    :rtype: string
    +    :returns: The fully qualified name of the group.
    +    """
    +    return 'projects/{project}/groups/{group_id}'.format(
    +        project=project, group_id=group_id)
    +
    +
    +
    [docs]class Group(object): + """A dynamic collection of monitored resources. + + :type client: :class:`google.cloud.monitoring.client.Client` + :param client: A client for operating on the metric descriptor. + + :type group_id: string or None + :param group_id: The ID of the group. + + :type display_name: string or None + :param display_name: + A user-assigned name for this group, used only for display purposes. + + :type parent_id: string or None + :param parent_id: + The ID of the group's parent, if it has one. + + :type filter_string: string or None + :param filter_string: + The filter string used to determine which monitored resources belong to + this group. + + :type is_cluster: boolean + :param is_cluster: + If true, the members of this group are considered to be a cluster. The + system can perform additional analysis on groups that are clusters. + """ + def __init__(self, client, group_id=None, display_name=None, + parent_id=None, filter_string=None, is_cluster=False): + self.client = client + self._id = group_id + self.display_name = display_name + self.parent_id = parent_id + self.filter = filter_string + self.is_cluster = is_cluster + + if group_id: + self._name = _group_name_from_id(client.project, group_id) + else: + self._name = None + + @property + def id(self): + """Returns the group ID. + + :rtype: str or None + :returns: the ID of the group based on it's name. + """ + return self._id + + @property + def name(self): + """Returns the fully qualified name of the group. + + :rtype: str or None + :returns: + The fully qualified name of the group in the format + "projects/<project>/groups/<id>". + """ + return self._name + + @property + def parent_name(self): + """Returns the fully qualified name of the parent group. + + :rtype: str or None + :returns: + The fully qualified name of the parent group. + """ + if not self.parent_id: + return None + return _group_name_from_id(self.client.project, self.parent_id) + + @property + def path(self): + """URL path to this group. + + :rtype: str + :returns: the path based on project and group name. + + :raises: :exc:`ValueError` if :attr:`name` is not specified. + """ + if not self.id: + raise ValueError('Cannot determine path without group ID.') + return '/' + self.name + +
    [docs] def create(self): + """Create a new group based on this object via a ``POST`` request. + + Example:: + + >>> filter_string = 'resource.type = "gce_instance"' + >>> group = client.group( + ... display_name='My group', + ... filter_string=filter_string, + ... parent_id='5678', + ... is_cluster=True) + >>> group.create() + + The ``name`` attribute is ignored in preparing the creation request. + All attributes are overwritten by the values received in the response + (normally affecting only ``name``). + """ + path = '/projects/%s/groups/' % (self.client.project,) + info = self.client.connection.api_request( + method='POST', path=path, data=self._to_dict()) + self._set_properties_from_dict(info)
    + +
    [docs] def exists(self): + """Test for the existence of the group via a ``GET`` request. + + :rtype: bool + :returns: Boolean indicating existence of the group. + """ + try: + self.client.connection.api_request( + method='GET', path=self.path, query_params={'fields': 'name'}) + except NotFound: + return False + else: + return True
    + +
    [docs] def reload(self): + """Sync local group information via a ``GET`` request. + + .. warning:: + + This will overwrite any local changes you've made and not saved + via :meth:`update`. + """ + info = self.client.connection.api_request(method='GET', path=self.path) + self._set_properties_from_dict(info)
    + +
    [docs] def update(self): + """Update the group via a ``PUT`` request.""" + info = self.client.connection.api_request( + method='PUT', path=self.path, data=self._to_dict()) + self._set_properties_from_dict(info)
    + +
    [docs] def delete(self): + """Delete the group via a ``DELETE`` request. + + Example:: + + >>> group = client.group('1234') + >>> group.delete() + + Only the ``client`` and ``name`` attributes are used. + + .. warning:: + + This method will fail for groups that have one or more children + groups. + """ + self.client.connection.api_request(method='DELETE', path=self.path)
    + +
    [docs] def fetch_parent(self): + """Returns the parent group of this group via a ``GET`` request. + + :rtype: :class:`Group` or None + :returns: The parent of the group. + """ + if not self.parent_id: + return None + return self._fetch(self.client, self.parent_id)
    + +
    [docs] def list_children(self): + """Lists all children of this group via a ``GET`` request. + + Returns groups whose parent_name field contains the group name. If no + groups have this parent, the results are empty. + + :rtype: list of :class:`~google.cloud.monitoring.group.Group` + :returns: A list of group instances. + """ + return self._list(self.client, children_of_group=self.name)
    + +
    [docs] def list_ancestors(self): + """Lists all ancestors of this group via a ``GET`` request. + + The groups are returned in order, starting with the immediate parent + and ending with the most distant ancestor. If the specified group has + no immediate parent, the results are empty. + + :rtype: list of :class:`~google.cloud.monitoring.group.Group` + :returns: A list of group instances. + """ + return self._list(self.client, ancestors_of_group=self.name)
    + +
    [docs] def list_descendants(self): + """Lists all descendants of this group via a ``GET`` request. + + This returns a superset of the results returned by the :meth:`children` + method, and includes children-of-children, and so forth. + + :rtype: list of :class:`~google.cloud.monitoring.group.Group` + :returns: A list of group instances. + """ + return self._list(self.client, descendants_of_group=self.name)
    + +
    [docs] def list_members(self, filter_string=None, end_time=None, start_time=None): + """Lists all members of this group via a ``GET`` request. + + If no ``end_time`` is provided then the group membership over the last + minute is returned. + + Example:: + + >>> for member in group.list_members(): + ... print member + + List members that are Compute Engine VM instances:: + + >>> filter_string = 'resource.type = "gce_instance"' + >>> for member in group.list_members(filter_string=filter_string): + ... print member + + List historical members that existed between 4 and 5 hours ago:: + + >>> import datetime + >>> t1 = datetime.datetime.utcnow() - datetime.timedelta(hours=4) + >>> t0 = t1 - datetime.timedelta(hours=1) + >>> for member in group.list_members(end_time=t1, start_time=t0): + ... print member + + + :type filter_string: string or None + :param filter_string: + An optional list filter describing the members to be returned. The + filter may reference the type, labels, and metadata of monitored + resources that comprise the group. See the `filter documentation`_. + + :type end_time: :class:`datetime.datetime` or None + :param end_time: + The end time (inclusive) of the time interval for which results + should be returned, as a datetime object. If ``start_time`` is + specified, then this must also be specified. + + :type start_time: :class:`datetime.datetime` or None + :param start_time: + The start time (exclusive) of the time interval for which results + should be returned, as a datetime object. + + :rtype: list of :class:`~google.cloud.monitoring.resource.Resource` + :returns: A list of resource instances. + + :raises: + :exc:`ValueError` if the ``start_time`` is specified, but the + ``end_time`` is missing. + + .. _filter documentation: + https://cloud.google.com/monitoring/api/v3/filters#group-filter + """ + if start_time is not None and end_time is None: + raise ValueError('If "start_time" is specified, "end_time" must ' + 'also be specified') + + path = '%s/members' % (self.path,) + resources = [] + page_token = None + params = {} + + if filter_string is not None: + params['filter'] = filter_string + + if end_time is not None: + params['interval.endTime'] = _datetime_to_rfc3339( + end_time, ignore_zone=False) + + if start_time is not None: + params['interval.startTime'] = _datetime_to_rfc3339( + start_time, ignore_zone=False) + + while True: + if page_token is not None: + params['pageToken'] = page_token + + response = self.client.connection.api_request( + method='GET', path=path, query_params=params.copy()) + for info in response.get('members', ()): + resources.append(Resource._from_dict(info)) + + page_token = response.get('nextPageToken') + if not page_token: + break + + return resources
    + + @classmethod + def _fetch(cls, client, group_id): + """Fetch a group from the API based on it's ID. + + :type client: :class:`google.cloud.monitoring.client.Client` + :param client: The client to use. + + :type group_id: string + :param group_id: The group ID. + + :rtype: :class:`Group` + :returns: The group instance. + + :raises: :class:`google.cloud.exceptions.NotFound` if the group + is not found. + """ + new_group = cls(client, group_id) + new_group.reload() + return new_group + + @classmethod + def _list(cls, client, children_of_group=None, ancestors_of_group=None, + descendants_of_group=None): + """Lists all groups in the project. + + :type client: :class:`google.cloud.monitoring.client.Client` + :param client: The client to use. + + :type children_of_group: string or None + :param children_of_group: + Returns groups whose parent_name field contains the group name. If + no groups have this parent, the results are empty. + + :type ancestors_of_group: string or None + :param ancestors_of_group: + Returns groups that are ancestors of the specified group. If the + specified group has no immediate parent, the results are empty. + + :type descendants_of_group: string or None + :param descendants_of_group: + Returns the descendants of the specified group. This is a superset + of the results returned by the children_of_group filter, and + includes children-of-children, and so forth. + + :rtype: list of :class:`~google.cloud.monitoring.group.Group` + :returns: A list of group instances. + """ + path = '/projects/%s/groups/' % (client.project,) + groups = [] + page_token = None + params = {} + + if children_of_group is not None: + params['childrenOfGroup'] = children_of_group + + if ancestors_of_group is not None: + params['ancestorsOfGroup'] = ancestors_of_group + + if descendants_of_group is not None: + params['descendantsOfGroup'] = descendants_of_group + + while True: + if page_token is not None: + params['pageToken'] = page_token + + response = client.connection.api_request( + method='GET', path=path, query_params=params.copy()) + for info in response.get('group', ()): + groups.append(cls._from_dict(client, info)) + + page_token = response.get('nextPageToken') + if not page_token: + break + + return groups + + @classmethod + def _from_dict(cls, client, info): + """Constructs a Group instance from the parsed JSON representation. + + :type client: :class:`google.cloud.monitoring.client.Client` + :param client: A client to be included in the returned object. + + :type info: dict + :param info: + A ``dict`` parsed from the JSON wire-format representation. + + :rtype: :class:`Group` + :returns: A group. + """ + group = cls(client) + group._set_properties_from_dict(info) + return group + + def _set_properties_from_dict(self, info): + """Update the group properties from its API representation. + + :type info: dict + :param info: + A ``dict`` parsed from the JSON wire-format representation. + """ + self._name = info['name'] + self._id = _group_id_from_name(self._name) + self.display_name = info['displayName'] + self.filter = info['filter'] + self.is_cluster = info.get('isCluster', False) + + parent_name = info.get('parentName') + if parent_name is None: + self.parent_id = None + else: + self.parent_id = _group_id_from_name(parent_name) + + def _to_dict(self): + """Build a dictionary ready to be serialized to the JSON wire format. + + :rtype: dict + :returns: A dictionary. + """ + info = { + 'filter': self.filter, + 'displayName': self.display_name, + 'isCluster': self.is_cluster, + } + + if self.name is not None: + info['name'] = self.name + + parent_name = self.parent_name + if parent_name is not None: + info['parentName'] = parent_name + + return info + + def __repr__(self): + return '<Group: %s>' % (self.name,)
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/label.html b/latest/_modules/google/cloud/monitoring/label.html similarity index 58% rename from latest/_modules/gcloud/monitoring/label.html rename to latest/_modules/google/cloud/monitoring/label.html index ea8ba922dae1..0de8acab24dc 100644 --- a/latest/_modules/gcloud/monitoring/label.html +++ b/latest/_modules/google/cloud/monitoring/label.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.monitoring.label — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.monitoring.label — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + -
    + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.label
    • +
    • -

      Source code for gcloud.monitoring.label

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.label

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -118,7 +273,7 @@ 

    Source code for gcloud.monitoring.label

     """
     
     
    -
    [docs]class LabelValueType(object): +
    [docs]class LabelValueType(object): """Allowed values for the `type of a label`_. .. _type of a label: @@ -131,7 +286,7 @@

    Source code for gcloud.monitoring.label

         INT64 = 'INT64'
    -
    [docs]class LabelDescriptor(object): +
    [docs]class LabelDescriptor(object): """Schema specification and documentation for a single label. :type key: string @@ -198,123 +353,62 @@

    Source code for gcloud.monitoring.label

             ).format(**self.__dict__)
    -
    -
    + + - - - + + + + + + + + + + + + + + + + + + + + + - + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/metric.html b/latest/_modules/google/cloud/monitoring/metric.html similarity index 75% rename from latest/_modules/gcloud/monitoring/metric.html rename to latest/_modules/google/cloud/monitoring/metric.html index c6b1c523a4cd..66fc883266ab 100644 --- a/latest/_modules/gcloud/monitoring/metric.html +++ b/latest/_modules/google/cloud/monitoring/metric.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.monitoring.metric — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.monitoring.metric — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.metric
    • +
    • -

      Source code for gcloud.monitoring.metric

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.metric

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -120,10 +275,10 @@ 

    Source code for gcloud.monitoring.metric

     
     import collections
     
    -from gcloud.monitoring.label import LabelDescriptor
    +from google.cloud.monitoring.label import LabelDescriptor
     
     
    -
    [docs]class MetricKind(object): +
    [docs]class MetricKind(object): """Choices for the `kind of measurement`_. .. _kind of measurement: @@ -139,7 +294,7 @@

    Source code for gcloud.monitoring.metric

         CUMULATIVE = 'CUMULATIVE'
    -
    [docs]class ValueType(object): +
    [docs]class ValueType(object): """Choices for the `metric value type`_. .. _metric value type: @@ -157,14 +312,14 @@

    Source code for gcloud.monitoring.metric

         DISTRIBUTION = 'DISTRIBUTION'
    -
    [docs]class MetricDescriptor(object): +
    [docs]class MetricDescriptor(object): """Specification of a metric type and its schema. The preferred way to construct a metric descriptor object is using the - :meth:`~gcloud.monitoring.client.Client.metric_descriptor` factory method - of the :class:`~gcloud.monitoring.client.Client` class. + :meth:`~google.cloud.monitoring.client.Client.metric_descriptor` factory + method of the :class:`~google.cloud.monitoring.client.Client` class. - :type client: :class:`gcloud.monitoring.client.Client` + :type client: :class:`google.cloud.monitoring.client.Client` :param client: A client for operating on the metric descriptor. :type type_: string @@ -186,7 +341,8 @@

    Source code for gcloud.monitoring.metric

             or :data:`ValueType.DISTRIBUTION`.
             See :class:`ValueType`.
     
    -    :type labels: list of :class:`~gcloud.monitoring.label.LabelDescriptor`
    +    :type labels:
    +        list of :class:`~google.cloud.monitoring.label.LabelDescriptor`
         :param labels:
             A sequence of zero or more label descriptors specifying the labels
             used to identify a specific instance of this metric.
    @@ -225,7 +381,7 @@ 

    Source code for gcloud.monitoring.metric

             self.description = description
             self.display_name = display_name
     
    -
    [docs] def create(self): +
    [docs] def create(self): """Create a new metric descriptor based on this object. Example:: @@ -251,7 +407,7 @@

    Source code for gcloud.monitoring.metric

                                                           data=self._to_dict())
             self._init_from_dict(response)
    -
    [docs] def delete(self): +
    [docs] def delete(self): """Delete the metric descriptor identified by this object. Example:: @@ -271,7 +427,7 @@

    Source code for gcloud.monitoring.metric

         def _fetch(cls, client, metric_type):
             """Look up a metric descriptor by type.
     
    -        :type client: :class:`gcloud.monitoring.client.Client`
    +        :type client: :class:`google.cloud.monitoring.client.Client`
             :param client: The client to use.
     
             :type metric_type: string
    @@ -280,8 +436,8 @@ 

    Source code for gcloud.monitoring.metric

             :rtype: :class:`MetricDescriptor`
             :returns: The metric descriptor instance.
     
    -        :raises: :class:`gcloud.exceptions.NotFound` if the metric descriptor
    -            is not found.
    +        :raises: :class:`google.cloud.exceptions.NotFound` if the metric
    +                 descriptor is not found.
             """
             path = '/projects/{project}/metricDescriptors/{type}'.format(
                 project=client.project,
    @@ -293,7 +449,7 @@ 

    Source code for gcloud.monitoring.metric

         def _list(cls, client, filter_string=None, type_prefix=None):
             """List all metric descriptors for the project.
     
    -        :type client: :class:`gcloud.monitoring.client.Client`
    +        :type client: :class:`google.cloud.monitoring.client.Client`
             :param client: The client to use.
     
             :type filter_string: string or None
    @@ -349,7 +505,7 @@ 

    Source code for gcloud.monitoring.metric

         def _from_dict(cls, client, info):
             """Construct a metric descriptor from the parsed JSON representation.
     
    -        :type client: :class:`gcloud.monitoring.client.Client`
    +        :type client: :class:`google.cloud.monitoring.client.Client`
             :param client: A client to be included in the returned object.
     
             :type info: dict
    @@ -415,9 +571,13 @@ 

    Source code for gcloud.monitoring.metric

             ).format(**self.__dict__)
    -
    [docs]class Metric(collections.namedtuple('Metric', 'type labels')): +
    [docs]class Metric(collections.namedtuple('Metric', 'type labels')): """A specific metric identified by specifying values for all labels. + The preferred way to construct a metric object is using the + :meth:`~google.cloud.monitoring.client.Client.metric` factory method + of the :class:`~google.cloud.monitoring.client.Client` class. + :type type: string :param type: The metric type name. @@ -444,123 +604,62 @@

    Source code for gcloud.monitoring.metric

             )
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/query.html b/latest/_modules/google/cloud/monitoring/query.html similarity index 76% rename from latest/_modules/gcloud/monitoring/query.html rename to latest/_modules/google/cloud/monitoring/query.html index 2f359660d3f3..4bf521899b59 100644 --- a/latest/_modules/gcloud/monitoring/query.html +++ b/latest/_modules/google/cloud/monitoring/query.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.monitoring.query — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.monitoring.query — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + -
    +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.query
    • +
    • -

      Source code for gcloud.monitoring.query

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.query

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -124,13 +279,14 @@ 

    Source code for gcloud.monitoring.query

     
     import six
     
    -from gcloud.monitoring._dataframe import _build_dataframe
    -from gcloud.monitoring.timeseries import TimeSeries
    +from google.cloud._helpers import _datetime_to_rfc3339
    +from google.cloud.monitoring._dataframe import _build_dataframe
    +from google.cloud.monitoring.timeseries import TimeSeries
     
     _UTCNOW = datetime.datetime.utcnow  # To be replaced by tests.
     
     
    -
    [docs]class Aligner(object): +
    [docs]class Aligner(object): """Allowed values for the `supported aligners`_.""" ALIGN_NONE = 'ALIGN_NONE' @@ -148,7 +304,7 @@

    Source code for gcloud.monitoring.query

         ALIGN_FRACTION_TRUE = 'ALIGN_FRACTION_TRUE'
    -
    [docs]class Reducer(object): +
    [docs]class Reducer(object): """Allowed values for the `supported reducers`_.""" REDUCE_NONE = 'REDUCE_NONE' @@ -166,20 +322,20 @@

    Source code for gcloud.monitoring.query

         REDUCE_PERCENTILE_05 = 'REDUCE_PERCENTILE_05'
    -
    [docs]class Query(object): +
    [docs]class Query(object): """Query object for retrieving metric data. The preferred way to construct a query object is using the - :meth:`~gcloud.monitoring.client.Client.query` method - of the :class:`~gcloud.monitoring.client.Client` class. + :meth:`~google.cloud.monitoring.client.Client.query` method + of the :class:`~google.cloud.monitoring.client.Client` class. - :type client: :class:`gcloud.monitoring.client.Client` + :type client: :class:`google.cloud.monitoring.client.Client` :param client: The client to use. :type metric_type: string :param metric_type: The metric type name. The default value is :data:`Query.DEFAULT_METRIC_TYPE - <gcloud.monitoring.query.Query.DEFAULT_METRIC_TYPE>`, + <google.cloud.monitoring.query.Query.DEFAULT_METRIC_TYPE>`, but please note that this default value is provided only for demonstration purposes and is subject to change. See the `supported metrics`_. @@ -195,7 +351,7 @@

    Source code for gcloud.monitoring.query

     
             It is also allowed to omit the end time and duration here,
             in which case
    -        :meth:`~gcloud.monitoring.query.Query.select_interval`
    +        :meth:`~google.cloud.monitoring.query.Query.select_interval`
             must be called before the query is executed.
     
         :type days: integer
    @@ -210,7 +366,7 @@ 

    Source code for gcloud.monitoring.query

         :raises: :exc:`ValueError` if ``end_time`` is specified but
             ``days``, ``hours``, and ``minutes`` are all zero.
             If you really want to specify a point in time, use
    -        :meth:`~gcloud.monitoring.query.Query.select_interval`.
    +        :meth:`~google.cloud.monitoring.query.Query.select_interval`.
     
         .. _supported metrics: https://cloud.google.com/monitoring/api/metrics
         """
    @@ -258,7 +414,7 @@ 

    Source code for gcloud.monitoring.query

             """
             return str(self._filter)
     
    -
    [docs] def select_interval(self, end_time, start_time=None): +
    [docs] def select_interval(self, end_time, start_time=None): """Copy the query and set the query time interval. Example:: @@ -290,7 +446,7 @@

    Source code for gcloud.monitoring.query

             new_query._start_time = start_time
             return new_query
    -
    [docs] def select_group(self, group_id): +
    [docs] def select_group(self, group_id): """Copy the query and add filtering by group. Example:: @@ -307,7 +463,7 @@

    Source code for gcloud.monitoring.query

             new_query._filter.group_id = group_id
             return new_query
    -
    [docs] def select_projects(self, *args): +
    [docs] def select_projects(self, *args): """Copy the query and add filtering by monitored projects. This is only useful if the target project represents a Stackdriver @@ -329,7 +485,7 @@

    Source code for gcloud.monitoring.query

             new_query._filter.projects = args
             return new_query
    -
    [docs] def select_resources(self, *args, **kwargs): +
    [docs] def select_resources(self, *args, **kwargs): """Copy the query and add filtering by resource labels. Examples:: @@ -387,7 +543,7 @@

    Source code for gcloud.monitoring.query

             new_query._filter.select_resources(*args, **kwargs)
             return new_query
    -
    [docs] def select_metrics(self, *args, **kwargs): +
    [docs] def select_metrics(self, *args, **kwargs): """Copy the query and add filtering by metric labels. Examples:: @@ -411,6 +567,25 @@

    Source code for gcloud.monitoring.query

     
                 metric.label.<label> = ends_with("<value>")
     
    +        If the label's value type is ``INT64``, a similar notation can be
    +        used to express inequalities:
    +
    +        ``<label>_less=<value>`` generates::
    +
    +            metric.label.<label> < <value>
    +
    +        ``<label>_lessequal=<value>`` generates::
    +
    +            metric.label.<label> <= <value>
    +
    +        ``<label>_greater=<value>`` generates::
    +
    +            metric.label.<label> > <value>
    +
    +        ``<label>_greaterequal=<value>`` generates::
    +
    +            metric.label.<label> >= <value>
    +
             :type args: tuple
             :param args: Raw filter expression strings to include in the
                 conjunction. If just one is provided and no keyword arguments
    @@ -427,7 +602,7 @@ 

    Source code for gcloud.monitoring.query

             new_query._filter.select_metrics(*args, **kwargs)
             return new_query
    -
    [docs] def align(self, per_series_aligner, seconds=0, minutes=0, hours=0): +
    [docs] def align(self, per_series_aligner, seconds=0, minutes=0, hours=0): """Copy the query and add temporal alignment. If ``per_series_aligner`` is not :data:`Aligner.ALIGN_NONE`, each time @@ -469,7 +644,7 @@

    Source code for gcloud.monitoring.query

                                                                   60 * hours)
             return new_query
    -
    [docs] def reduce(self, cross_series_reducer, *group_by_fields): +
    [docs] def reduce(self, cross_series_reducer, *group_by_fields): """Copy the query and add cross-series reduction. Cross-series reduction combines time series by aggregating their @@ -505,11 +680,11 @@

    Source code for gcloud.monitoring.query

             new_query._group_by_fields = group_by_fields
             return new_query
    -
    [docs] def iter(self, headers_only=False, page_size=None): +
    [docs] def iter(self, headers_only=False, page_size=None): """Yield all time series objects selected by the query. The generator returned iterates over - :class:`~gcloud.monitoring.timeseries.TimeSeries` objects + :class:`~google.cloud.monitoring.timeseries.TimeSeries` objects containing points ordered from oldest to newest. Note that the :class:`Query` object itself is an iterable, such that @@ -587,7 +762,7 @@

    Source code for gcloud.monitoring.query

             :type headers_only: boolean
             :param headers_only:
                  Whether to omit the point data from the
    -             :class:`~gcloud.monitoring.timeseries.TimeSeries` objects.
    +             :class:`~google.cloud.monitoring.timeseries.TimeSeries` objects.
     
             :type page_size: integer or None
             :param page_size: A limit on the number of points to return per page.
    @@ -597,9 +772,12 @@ 

    Source code for gcloud.monitoring.query

             """
             yield 'filter', self.filter
     
    -        yield 'interval.endTime', _format_timestamp(self._end_time)
    +        yield 'interval.endTime', _datetime_to_rfc3339(
    +            self._end_time, ignore_zone=False)
    +
             if self._start_time is not None:
    -            yield 'interval.startTime', _format_timestamp(self._start_time)
    +            yield 'interval.startTime', _datetime_to_rfc3339(
    +                self._start_time, ignore_zone=False)
     
             if self._per_series_aligner is not None:
                 yield 'aggregation.perSeriesAligner', self._per_series_aligner
    @@ -625,7 +803,7 @@ 

    Source code for gcloud.monitoring.query

             if page_token is not None:
                 yield 'pageToken', page_token
     
    -
    [docs] def as_dataframe(self, label=None, labels=None): +
    [docs] def as_dataframe(self, label=None, labels=None): """Return all the selected time series as a :mod:`pandas` dataframe. .. note:: @@ -667,7 +845,7 @@

    Source code for gcloud.monitoring.query

             """
             return _build_dataframe(self, label, labels)  # pragma: NO COVER
    -
    [docs] def copy(self): +
    [docs] def copy(self): """Copy the query object. :rtype: :class:`Query` @@ -732,7 +910,8 @@

    Source code for gcloud.monitoring.query

                 continue
     
             suffix = None
    -        if key.endswith('_prefix') or key.endswith('_suffix'):
    +        if key.endswith(('_prefix', '_suffix', '_greater', '_greaterequal',
    +                         '_less', '_lessequal')):
                 key, suffix = key.rsplit('_', 1)
     
             if category == 'resource' and key == 'resource_type':
    @@ -744,148 +923,78 @@ 

    Source code for gcloud.monitoring.query

                 term = '{key} = starts_with("{value}")'
             elif suffix == 'suffix':
                 term = '{key} = ends_with("{value}")'
    +        elif suffix == 'greater':
    +            term = '{key} > {value}'
    +        elif suffix == 'greaterequal':
    +            term = '{key} >= {value}'
    +        elif suffix == 'less':
    +            term = '{key} < {value}'
    +        elif suffix == 'lessequal':
    +            term = '{key} <= {value}'
             else:
                 term = '{key} = "{value}"'
     
             terms.append(term.format(key=key, value=value))
     
         return ' AND '.join(sorted(terms))
    +
    +
    +
    +
    + -def _format_timestamp(timestamp): - """Convert a datetime object to a string as required by the API. +
    - :type timestamp: :class:`datetime.datetime` - :param timestamp: A datetime object. +
    +

    + © Copyright 2014, Google. - :rtype: string - :returns: The formatted timestamp. For example: - ``"2016-02-17T19:18:01.763000Z"`` - """ - if timestamp.tzinfo is not None: - # Convert to UTC and remove the time zone info. - timestamp = timestamp.replace(tzinfo=None) - timestamp.utcoffset() +

    +
    + Built with Sphinx using a theme provided by Read the Docs. - return timestamp.isoformat() + 'Z' -
    + -
    -
    + + + + + + + + + - - + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/resource.html b/latest/_modules/google/cloud/monitoring/resource.html similarity index 66% rename from latest/_modules/gcloud/monitoring/resource.html rename to latest/_modules/google/cloud/monitoring/resource.html index c5fef0ad85f9..494368cd6c55 100644 --- a/latest/_modules/gcloud/monitoring/resource.html +++ b/latest/_modules/google/cloud/monitoring/resource.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.monitoring.resource — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.monitoring.resource — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.resource
    • +
    • -

      Source code for gcloud.monitoring.resource

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.resource

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -121,10 +276,10 @@ 

    Source code for gcloud.monitoring.resource

     
     import collections
     
    -from gcloud.monitoring.label import LabelDescriptor
    +from google.cloud.monitoring.label import LabelDescriptor
     
     
    -
    [docs]class ResourceDescriptor(object): +
    [docs]class ResourceDescriptor(object): """Specification of a monitored resource type and its schema. :type name: string @@ -144,7 +299,8 @@

    Source code for gcloud.monitoring.resource

         :param description:
             A detailed description that might be used in documentation.
     
    -    :type labels: list of :class:`~gcloud.monitoring.label.LabelDescriptor`
    +    :type labels:
    +        list of :class:`~google.cloud.monitoring.label.LabelDescriptor`
         :param labels:
             A sequence of label descriptors specifying the labels used
             to identify a specific instance of this monitored resource.
    @@ -161,7 +317,7 @@ 

    Source code for gcloud.monitoring.resource

         def _fetch(cls, client, resource_type):
             """Look up a monitored resource descriptor by type.
     
    -        :type client: :class:`gcloud.monitoring.client.Client`
    +        :type client: :class:`google.cloud.monitoring.client.Client`
             :param client: The client to use.
     
             :type resource_type: string
    @@ -170,8 +326,8 @@ 

    Source code for gcloud.monitoring.resource

             :rtype: :class:`ResourceDescriptor`
             :returns: The resource descriptor instance.
     
    -        :raises: :class:`gcloud.exceptions.NotFound` if the resource descriptor
    -            is not found.
    +        :raises: :class:`google.cloud.exceptions.NotFound` if the resource
    +                 descriptor is not found.
             """
             path = ('/projects/{project}/monitoredResourceDescriptors/{type}'
                     .format(project=client.project,
    @@ -183,7 +339,7 @@ 

    Source code for gcloud.monitoring.resource

         def _list(cls, client, filter_string=None):
             """List all monitored resource descriptors for the project.
     
    -        :type client: :class:`gcloud.monitoring.client.Client`
    +        :type client: :class:`google.cloud.monitoring.client.Client`
             :param client: The client to use.
     
             :type filter_string: string or None
    @@ -254,9 +410,13 @@ 

    Source code for gcloud.monitoring.resource

             ).format(**self.__dict__)
    -
    [docs]class Resource(collections.namedtuple('Resource', 'type labels')): +
    [docs]class Resource(collections.namedtuple('Resource', 'type labels')): """A monitored resource identified by specifying values for all labels. + The preferred way to construct a resource object is using the + :meth:`~google.cloud.monitoring.client.Client.resource` factory method + of the :class:`~google.cloud.monitoring.client.Client` class. + :type type: string :param type: The resource type name. @@ -283,123 +443,62 @@

    Source code for gcloud.monitoring.resource

             )
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/monitoring/timeseries.html b/latest/_modules/google/cloud/monitoring/timeseries.html similarity index 62% rename from latest/_modules/gcloud/monitoring/timeseries.html rename to latest/_modules/google/cloud/monitoring/timeseries.html index ea1a88b188e2..e74f4b01928b 100644 --- a/latest/_modules/gcloud/monitoring/timeseries.html +++ b/latest/_modules/google/cloud/monitoring/timeseries.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.monitoring.timeseries — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.monitoring.timeseries — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.monitoring.timeseries
    • +
    • -

      Source code for gcloud.monitoring.timeseries

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.monitoring.timeseries

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -123,32 +278,38 @@ 

    Source code for gcloud.monitoring.timeseries

    import collections
     
    -from gcloud.monitoring.metric import Metric
    -from gcloud.monitoring.resource import Resource
    +from google.cloud.monitoring.metric import Metric
    +from google.cloud.monitoring.resource import Resource
     
     
    -
    [docs]class TimeSeries(collections.namedtuple( +
    [docs]class TimeSeries(collections.namedtuple( 'TimeSeries', 'metric resource metric_kind value_type points')): """A single time series of metric values. - :type metric: :class:`~gcloud.monitoring.metric.Metric` + The preferred way to construct a + :class:`~google.cloud.monitoring.timeseries.TimeSeries` object is + using the :meth:`~google.cloud.monitoring.client.Client.time_series` + factory method of the :class:`~google.cloud.monitoring.client.Client` + class. + + :type metric: :class:`~google.cloud.monitoring.metric.Metric` :param metric: A metric object. - :type resource: :class:`~gcloud.monitoring.resource.Resource` + :type resource: :class:`~google.cloud.monitoring.resource.Resource` :param resource: A resource object. :type metric_kind: string :param metric_kind: The kind of measurement: :data:`MetricKind.GAUGE`, :data:`MetricKind.DELTA`, or :data:`MetricKind.CUMULATIVE`. - See :class:`~gcloud.monitoring.metric.MetricKind`. + See :class:`~google.cloud.monitoring.metric.MetricKind`. :type value_type: string :param value_type: The value type of the metric: :data:`ValueType.BOOL`, :data:`ValueType.INT64`, :data:`ValueType.DOUBLE`, :data:`ValueType.STRING`, or :data:`ValueType.DISTRIBUTION`. - See :class:`~gcloud.monitoring.metric.ValueType`. + See :class:`~google.cloud.monitoring.metric.ValueType`. :type points: list of :class:`Point` :param points: A list of point objects. @@ -171,7 +332,7 @@

    Source code for gcloud.monitoring.timeseries

    return self._labels
     
    -
    [docs] def header(self, points=None): +
    [docs] def header(self, points=None): """Copy everything but the point data. :type points: list of :class:`Point`, or None @@ -217,7 +378,7 @@

    Source code for gcloud.monitoring.timeseries

    )
    -
    [docs]class Point(collections.namedtuple('Point', 'end_time start_time value')): +
    [docs]class Point(collections.namedtuple('Point', 'end_time start_time value')): """A single point in a time series. :type end_time: string @@ -251,123 +412,62 @@

    Source code for gcloud.monitoring.timeseries

    return cls(end_time, start_time, value)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/operation.html b/latest/_modules/google/cloud/operation.html new file mode 100644 index 000000000000..cd631904ca19 --- /dev/null +++ b/latest/_modules/google/cloud/operation.html @@ -0,0 +1,452 @@ + + + + + + + + + + + google.cloud.operation — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +

    Source code for google.cloud.operation

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Wrap long-running operations returned from Google Cloud APIs."""
    +
    +from google.longrunning import operations_pb2
    +
    +
    +_GOOGLE_APIS_PREFIX = 'types.googleapis.com'
    +
    +_TYPE_URL_MAP = {
    +}
    +
    +
    +def _compute_type_url(klass, prefix=_GOOGLE_APIS_PREFIX):
    +    """Compute a type URL for a klass.
    +
    +    :type klass: type
    +    :param klass: class to be used as a factory for the given type
    +
    +    :type prefix: str
    +    :param prefix: URL prefix for the type
    +
    +    :rtype: str
    +    :returns: the URL, prefixed as appropriate
    +    """
    +    name = klass.DESCRIPTOR.full_name
    +    return '%s/%s' % (prefix, name)
    +
    +
    +def _register_type_url(type_url, klass):
    +    """Register a klass as the factory for a given type URL.
    +
    +    :type type_url: str
    +    :param type_url: URL naming the type
    +
    +    :type klass: type
    +    :param klass: class to be used as a factory for the given type
    +
    +    :raises: ValueError if a registration already exists for the URL.
    +    """
    +    if type_url in _TYPE_URL_MAP:
    +        if _TYPE_URL_MAP[type_url] is not klass:
    +            raise ValueError("Conflict: %s" % (_TYPE_URL_MAP[type_url],))
    +
    +    _TYPE_URL_MAP[type_url] = klass
    +
    +
    +
    [docs]class Operation(object): + """Representation of a Google API Long-Running Operation. + + :type name: str + :param name: The fully-qualified path naming the operation. + + :type client: object: must provide ``_operations_stub`` accessor. + :param client: The client used to poll for the status of the operation. + + :type pb_metadata: object + :param pb_metadata: Instance of protobuf metadata class + + :type kw: dict + :param kw: caller-assigned metadata about the operation + """ + + target = None + """Instance assocated with the operations: callers may set.""" + + def __init__(self, name, client, pb_metadata=None, **kw): + self.name = name + self.client = client + self.pb_metadata = pb_metadata + self.metadata = kw.copy() + self._complete = False + + @classmethod +
    [docs] def from_pb(cls, op_pb, client, **kw): + """Factory: construct an instance from a protobuf. + + :type op_pb: :class:`google.longrunning.operations_pb2.Operation` + :param op_pb: Protobuf to be parsed. + + :type client: object: must provide ``_operations_stub`` accessor. + :param client: The client used to poll for the status of the operation. + + :type kw: dict + :param kw: caller-assigned metadata about the operation + + :rtype: :class:`Operation` + :returns: new instance, with attributes based on the protobuf. + """ + pb_metadata = None + if op_pb.metadata.type_url: + type_url = op_pb.metadata.type_url + md_klass = _TYPE_URL_MAP.get(type_url) + if md_klass: + pb_metadata = md_klass.FromString(op_pb.metadata.value) + return cls(op_pb.name, client, pb_metadata, **kw)
    + + @property + def complete(self): + """Has the operation already completed? + + :rtype: bool + :returns: True if already completed, else false. + """ + return self._complete + +
    [docs] def poll(self): + """Check if the operation has finished. + + :rtype: bool + :returns: A boolean indicating if the current operation has completed. + :raises: :class:`ValueError <exceptions.ValueError>` if the operation + has already completed. + """ + if self.complete: + raise ValueError('The operation has completed.') + + request_pb = operations_pb2.GetOperationRequest(name=self.name) + # We expect a `google.longrunning.operations_pb2.Operation`. + operation_pb = self.client._operations_stub.GetOperation(request_pb) + + if operation_pb.done: + self._complete = True + + return self.complete
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/client.html b/latest/_modules/google/cloud/pubsub/client.html similarity index 58% rename from latest/_modules/gcloud/pubsub/client.html rename to latest/_modules/google/cloud/pubsub/client.html index b0014a6af317..e4fbc0f125fe 100644 --- a/latest/_modules/gcloud/pubsub/client.html +++ b/latest/_modules/google/cloud/pubsub/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.client
    • +
    • -

      Source code for gcloud.pubsub.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,35 +270,37 @@ 

    Source code for gcloud.pubsub.client

     
     import os
     
    -from gcloud.client import JSONClient
    -from gcloud.pubsub.connection import Connection
    -from gcloud.pubsub.connection import _PublisherAPI as JSONPublisherAPI
    -from gcloud.pubsub.connection import _SubscriberAPI as JSONSubscriberAPI
    -from gcloud.pubsub.connection import _IAMPolicyAPI
    -from gcloud.pubsub.subscription import Subscription
    -from gcloud.pubsub.topic import Topic
    +from google.cloud.client import JSONClient
    +from google.cloud.environment_vars import DISABLE_GRPC
    +from google.cloud.pubsub.connection import Connection
    +from google.cloud.pubsub.connection import _PublisherAPI as JSONPublisherAPI
    +from google.cloud.pubsub.connection import _SubscriberAPI as JSONSubscriberAPI
    +from google.cloud.pubsub.connection import _IAMPolicyAPI
    +from google.cloud.pubsub.subscription import Subscription
    +from google.cloud.pubsub.topic import Topic
     
     # pylint: disable=ungrouped-imports
     try:
    -    from google.pubsub.v1.publisher_api import (
    -        PublisherApi as GeneratedPublisherAPI)
    -    from google.pubsub.v1.subscriber_api import (
    -        SubscriberApi as GeneratedSubscriberAPI)
    -    from gcloud.pubsub._gax import _PublisherAPI as GAXPublisherAPI
    -    from gcloud.pubsub._gax import _SubscriberAPI as GAXSubscriberAPI
    +    from google.cloud.pubsub._gax import _PublisherAPI as GAXPublisherAPI
    +    from google.cloud.pubsub._gax import _SubscriberAPI as GAXSubscriberAPI
    +    from google.cloud.pubsub._gax import make_gax_publisher_api
    +    from google.cloud.pubsub._gax import make_gax_subscriber_api
     except ImportError:  # pragma: NO COVER
         _HAVE_GAX = False
    -    GeneratedPublisherAPI = GAXPublisherAPI = None
    -    GeneratedSubscriberAPI = GAXSubscriberAPI = None
    +    GAXPublisherAPI = None
    +    GAXSubscriberAPI = None
    +    make_gax_publisher_api = None
    +    make_gax_subscriber_api = None
     else:
         _HAVE_GAX = True
     # pylint: enable=ungrouped-imports
     
     
    -_USE_GAX = _HAVE_GAX and (os.environ.get('GCLOUD_ENABLE_GAX') is not None)
    +_DISABLE_GAX = os.getenv(DISABLE_GRPC, False)
    +_USE_GAX = _HAVE_GAX and not _DISABLE_GAX
     
     
    -
    [docs]class Client(JSONClient): +
    [docs]class Client(JSONClient): """Client to bundle configuration needed for API requests. :type project: string @@ -172,7 +329,7 @@

    Source code for gcloud.pubsub.client

             """Helper for publisher-related API calls."""
             if self._publisher_api is None:
                 if _USE_GAX:
    -                generated = GeneratedPublisherAPI()
    +                generated = make_gax_publisher_api(self.connection)
                     self._publisher_api = GAXPublisherAPI(generated)
                 else:
                     self._publisher_api = JSONPublisherAPI(self.connection)
    @@ -183,7 +340,7 @@ 

    Source code for gcloud.pubsub.client

             """Helper for subscriber-related API calls."""
             if self._subscriber_api is None:
                 if _USE_GAX:
    -                generated = GeneratedSubscriberAPI()
    +                generated = make_gax_subscriber_api(self.connection)
                     self._subscriber_api = GAXSubscriberAPI(generated)
                 else:
                     self._subscriber_api = JSONSubscriberAPI(self.connection)
    @@ -196,7 +353,7 @@ 

    Source code for gcloud.pubsub.client

                 self._iam_policy_api = _IAMPolicyAPI(self.connection)
             return self._iam_policy_api
     
    -
    [docs] def list_topics(self, page_size=None, page_token=None): +
    [docs] def list_topics(self, page_size=None, page_token=None): """List topics for the project associated with this client. See: @@ -218,7 +375,7 @@

    Source code for gcloud.pubsub.client

                                topics.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.pubsub.topic.Topic`, plus a
    +        :returns: list of :class:`google.cloud.pubsub.topic.Topic`, plus a
                       "next page token" string:  if not None, indicates that
                       more topics can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -230,7 +387,7 @@ 

    Source code for gcloud.pubsub.client

                       for resource in resources]
             return topics, next_token
    -
    [docs] def list_subscriptions(self, page_size=None, page_token=None): +
    [docs] def list_subscriptions(self, page_size=None, page_token=None): """List subscriptions for the project associated with this client. See: @@ -252,7 +409,7 @@

    Source code for gcloud.pubsub.client

                                topics.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.pubsub.subscription.Subscription`,
    +        :returns: list of :class:`~.pubsub.subscription.Subscription`,
                       plus a "next page token" string:  if not None, indicates that
                       more topics can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -266,7 +423,7 @@ 

    Source code for gcloud.pubsub.client

                              for resource in resources]
             return subscriptions, next_token
    -
    [docs] def topic(self, name, timestamp_messages=False): +
    [docs] def topic(self, name, timestamp_messages=False): """Creates a topic bound to the current client. Example: @@ -281,129 +438,68 @@

    Source code for gcloud.pubsub.client

             :type timestamp_messages: boolean
             :param timestamp_messages: To be passed to ``Topic`` constructor.
     
    -        :rtype: :class:`gcloud.pubsub.topic.Topic`
    +        :rtype: :class:`google.cloud.pubsub.topic.Topic`
             :returns: Topic created with the current client.
             """
             return Topic(name, client=self, timestamp_messages=timestamp_messages)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/connection.html b/latest/_modules/google/cloud/pubsub/connection.html similarity index 82% rename from latest/_modules/gcloud/pubsub/connection.html rename to latest/_modules/google/cloud/pubsub/connection.html index fb596302d1f3..36a5c8f7ad06 100644 --- a/latest/_modules/gcloud/pubsub/connection.html +++ b/latest/_modules/google/cloud/pubsub/connection.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.connection — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.connection — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + -
    + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.connection
    • +
    • + + -

      Source code for gcloud.pubsub.connection

      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.connection

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,16 +266,20 @@ 

    Source code for gcloud.pubsub.connection

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Create / interact with gcloud pubsub connections."""
    +"""Create / interact with Google Cloud Pub/Sub connections."""
     
     import os
     
    -from gcloud import connection as base_connection
    -from gcloud.environment_vars import PUBSUB_EMULATOR
    +from google.cloud import connection as base_connection
    +from google.cloud.environment_vars import PUBSUB_EMULATOR
    +
     
    +PUBSUB_API_HOST = 'pubsub.googleapis.com'
    +"""Pub / Sub API request host."""
     
    -
    [docs]class Connection(base_connection.JSONConnection): - """A connection to Google Cloud Pubsub via the JSON REST API. + +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Pub/Sub via the JSON REST API. :type credentials: :class:`oauth2client.client.OAuth2Credentials` :param credentials: (Optional) The OAuth2 Credentials to use for this @@ -128,13 +287,9 @@

    Source code for gcloud.pubsub.connection

     
         :type http: :class:`httplib2.Http` or class that defines ``request()``.
         :param http: (Optional) HTTP object to make requests.
    -
    -    :type api_base_url: string
    -    :param api_base_url: The base of the API call URL. Defaults to the value
    -                         :attr:`Connection.API_BASE_URL`.
         """
     
    -    API_BASE_URL = 'https://pubsub.googleapis.com'
    +    API_BASE_URL = 'https://' + PUBSUB_API_HOST
         """The base of the API call URL."""
     
         API_VERSION = 'v1'
    @@ -147,17 +302,19 @@ 

    Source code for gcloud.pubsub.connection

                  'https://www.googleapis.com/auth/cloud-platform')
         """The scopes required for authenticating as a Cloud Pub/Sub consumer."""
     
    -    def __init__(self, credentials=None, http=None, api_base_url=None):
    +    def __init__(self, credentials=None, http=None):
             super(Connection, self).__init__(credentials=credentials, http=http)
    -        if api_base_url is None:
    -            emulator_host = os.getenv(PUBSUB_EMULATOR)
    -            if emulator_host is None:
    -                api_base_url = self.__class__.API_BASE_URL
    -            else:
    -                api_base_url = 'http://' + emulator_host
    -        self.api_base_url = api_base_url
    -
    -
    [docs] def build_api_url(self, path, query_params=None, + emulator_host = os.getenv(PUBSUB_EMULATOR) + if emulator_host is None: + self.host = self.__class__.API_BASE_URL + self.api_base_url = self.__class__.API_BASE_URL + self.in_emulator = False + else: + self.host = emulator_host + self.api_base_url = 'http://' + emulator_host + self.in_emulator = True + +
    [docs] def build_api_url(self, path, query_params=None, api_base_url=None, api_version=None): """Construct an API url given a few components, some optional. @@ -638,123 +795,62 @@

    Source code for gcloud.pubsub.connection

             return resp.get('permissions', [])
     
    -
    -
    +
    +
    + + +
    + +
    +

    + © Copyright 2014, Google. - -

    +

    +
    + Built with Sphinx using a theme provided by Read the Docs. - - - + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/iam.html b/latest/_modules/google/cloud/pubsub/iam.html similarity index 70% rename from latest/_modules/gcloud/pubsub/iam.html rename to latest/_modules/google/cloud/pubsub/iam.html index b5347978574b..441efbd4f903 100644 --- a/latest/_modules/gcloud/pubsub/iam.html +++ b/latest/_modules/google/cloud/pubsub/iam.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.iam — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.iam — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.iam
    • +
    • -

      Source code for gcloud.pubsub.iam

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.iam

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -193,7 +348,7 @@ 

    Source code for gcloud.pubsub.iam

     """Permission: update subscriptions."""
     
     
    -
    [docs]class Policy(object): +
    [docs]class Policy(object): """Combined IAM Policy / Bindings. See: @@ -216,7 +371,7 @@

    Source code for gcloud.pubsub.iam

             self.subscribers = set()
     
         @staticmethod
    -
    [docs] def user(email): +
    [docs] def user(email): """Factory method for a user member. :type email: string @@ -228,7 +383,7 @@

    Source code for gcloud.pubsub.iam

             return 'user:%s' % (email,)
    @staticmethod -
    [docs] def service_account(email): +
    [docs] def service_account(email): """Factory method for a service account member. :type email: string @@ -240,7 +395,7 @@

    Source code for gcloud.pubsub.iam

             return 'serviceAccount:%s' % (email,)
    @staticmethod -
    [docs] def group(email): +
    [docs] def group(email): """Factory method for a group member. :type email: string @@ -252,7 +407,7 @@

    Source code for gcloud.pubsub.iam

             return 'group:%s' % (email,)
    @staticmethod -
    [docs] def domain(domain): +
    [docs] def domain(domain): """Factory method for a domain member. :type domain: string @@ -264,7 +419,7 @@

    Source code for gcloud.pubsub.iam

             return 'domain:%s' % (domain,)
    @staticmethod -
    [docs] def all_users(): +
    [docs] def all_users(): """Factory method for a member representing all users. :rtype: string @@ -273,7 +428,7 @@

    Source code for gcloud.pubsub.iam

             return 'allUsers'
    @staticmethod -
    [docs] def authenticated_users(): +
    [docs] def authenticated_users(): """Factory method for a member representing all authenticated users. :rtype: string @@ -282,7 +437,7 @@

    Source code for gcloud.pubsub.iam

             return 'allAuthenticatedUsers'
    @classmethod -
    [docs] def from_api_repr(cls, resource): +
    [docs] def from_api_repr(cls, resource): """Create a policy from the resource returned from the API. :type resource: dict @@ -311,7 +466,7 @@

    Source code for gcloud.pubsub.iam

                     raise ValueError('Unknown role: %s' % (role,))
             return policy
    -
    [docs] def to_api_repr(self): +
    [docs] def to_api_repr(self): """Construct a Policy resource. :rtype: dict @@ -358,123 +513,62 @@

    Source code for gcloud.pubsub.iam

             return resource
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/message.html b/latest/_modules/google/cloud/pubsub/message.html similarity index 56% rename from latest/_modules/gcloud/pubsub/message.html rename to latest/_modules/google/cloud/pubsub/message.html index c47113e36d80..fe2b3e08e35a 100644 --- a/latest/_modules/gcloud/pubsub/message.html +++ b/latest/_modules/google/cloud/pubsub/message.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.message — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.message — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + -
    + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.message
    • +
    • -

      Source code for gcloud.pubsub.message

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.message

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,17 +270,17 @@ 

    Source code for gcloud.pubsub.message

     
     import base64
     
    -from gcloud._helpers import _rfc3339_to_datetime
    +from google.cloud._helpers import _rfc3339_to_datetime
     
     
    -
    [docs]class Message(object): +
    [docs]class Message(object): """Messages can be published to a topic and received by subscribers. See: https://cloud.google.com/pubsub/reference/rest/v1/PubsubMessage :type data: bytes - :param data: the payload of the message + :param data: the payload of the message. :type message_id: string :param message_id: An ID assigned to the message by the API. @@ -143,7 +298,7 @@

    Source code for gcloud.pubsub.message

     
         @property
         def attributes(self):
    -        """Lazily-constructed attribute dictionary"""
    +        """Lazily-constructed attribute dictionary."""
             if self._attributes is None:
                 self._attributes = {}
             return self._attributes
    @@ -175,7 +330,7 @@ 

    Source code for gcloud.pubsub.message

             return self._service_timestamp
     
         @classmethod
    -
    [docs] def from_api_repr(cls, api_repr): +
    [docs] def from_api_repr(cls, api_repr): """Factory: construct message from API representation. :type api_repr: dict or None @@ -192,123 +347,62 @@

    Source code for gcloud.pubsub.message

             return instance
    -
    -
    + + - - - + + + + + + + + + + + + + + + + + + + + + - + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/subscription.html b/latest/_modules/google/cloud/pubsub/subscription.html similarity index 70% rename from latest/_modules/gcloud/pubsub/subscription.html rename to latest/_modules/google/cloud/pubsub/subscription.html index c639990bfc37..8d9d4ffccb38 100644 --- a/latest/_modules/gcloud/pubsub/subscription.html +++ b/latest/_modules/google/cloud/pubsub/subscription.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.subscription — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.subscription — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.subscription
    • +
    • -

      Source code for gcloud.pubsub.subscription

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.subscription

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,22 +268,22 @@ 

    Source code for gcloud.pubsub.subscription

     
     """Define API Subscriptions."""
     
    -from gcloud.exceptions import NotFound
    -from gcloud.pubsub._helpers import topic_name_from_path
    -from gcloud.pubsub.iam import Policy
    -from gcloud.pubsub.message import Message
    +from google.cloud.exceptions import NotFound
    +from google.cloud.pubsub._helpers import topic_name_from_path
    +from google.cloud.pubsub.iam import Policy
    +from google.cloud.pubsub.message import Message
     
     
    -
    [docs]class Subscription(object): +
    [docs]class Subscription(object): """Subscriptions receive messages published to their topics. See: https://cloud.google.com/pubsub/reference/rest/v1/projects.subscriptions :type name: string - :param name: the name of the subscription + :param name: the name of the subscription. - :type topic: :class:`gcloud.pubsub.topic.Topic` or ``NoneType`` + :type topic: :class:`google.cloud.pubsub.topic.Topic` or ``NoneType`` :param topic: the topic to which the subscription belongs; if ``None``, the subscription's topic has been deleted. @@ -140,7 +295,8 @@

    Source code for gcloud.pubsub.subscription

         :param push_endpoint: URL to which messages will be pushed by the back-end.
                               If not set, the application must pull messages.
     
    -    :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +    :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                  ``NoneType``
         :param client: the client to use.  If not passed, falls back to the
                        ``client`` stored on the topic.
         """
    @@ -169,13 +325,13 @@ 

    Source code for gcloud.pubsub.subscription

             self.push_endpoint = push_endpoint
     
         @classmethod
    -
    [docs] def from_api_repr(cls, resource, client, topics=None): +
    [docs] def from_api_repr(cls, resource, client, topics=None): """Factory: construct a topic given its API representation :type resource: dict - :param resource: topic resource representation returned from the API + :param resource: topic resource representation returned from the API. - :type client: :class:`gcloud.pubsub.client.Client` + :type client: :class:`google.cloud.pubsub.client.Client` :param client: Client which holds credentials and project configuration for a topic. @@ -183,7 +339,7 @@

    Source code for gcloud.pubsub.subscription

             :param topics: A mapping of topic names -> topics.  If not passed,
                            the subscription will have a newly-created topic.
     
    -        :rtype: :class:`gcloud.pubsub.subscription.Subscription`
    +        :rtype: :class:`google.cloud.pubsub.subscription.Subscription`
             :returns: Subscription parsed from ``resource``.
             """
             if topics is None:
    @@ -222,7 +378,7 @@ 

    Source code for gcloud.pubsub.subscription

             """URL path for the subscription's APIs"""
             return '/%s' % (self.full_name,)
     
    -
    [docs] def auto_ack(self, return_immediately=False, max_messages=1, client=None): +
    [docs] def auto_ack(self, return_immediately=False, max_messages=1, client=None): """:class:`AutoAck` factory :type return_immediately: boolean @@ -231,7 +387,8 @@

    Source code for gcloud.pubsub.subscription

             :type max_messages: int
             :param max_messages: passed through to :meth:`Subscription.pull`
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: passed through to :meth:`Subscription.pull` and
                           :meth:`Subscription.acknowledge`.
     
    @@ -243,19 +400,20 @@ 

    Source code for gcloud.pubsub.subscription

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the topic of the
                            current subscription.
     
    -        :rtype: :class:`gcloud.pubsub.client.Client`
    +        :rtype: :class:`google.cloud.pubsub.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self._client
             return client
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the subscription via a PUT request See: @@ -267,7 +425,8 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_create]
                :end-before: [END subscription_create]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -277,7 +436,7 @@ 

    Source code for gcloud.pubsub.subscription

                 self.full_name, self.topic.full_name, self.ack_deadline,
                 self.push_endpoint)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test existence of the subscription via a GET request See @@ -289,7 +448,8 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_exists]
                :end-before: [END subscription_exists]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
     
    @@ -305,7 +465,7 @@ 

    Source code for gcloud.pubsub.subscription

             else:
                 return True
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: sync local subscription configuration via a GET request See @@ -317,7 +477,8 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_reload]
                :end-before: [END subscription_reload]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -328,7 +489,7 @@ 

    Source code for gcloud.pubsub.subscription

             push_config = data.get('pushConfig', {})
             self.push_endpoint = push_config.get('pushEndpoint')
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete the subscription via a DELETE request. See: @@ -340,7 +501,8 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_delete]
                :end-before: [END subscription_delete]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -348,7 +510,7 @@ 

    Source code for gcloud.pubsub.subscription

             api = client.subscriber_api
             api.subscription_delete(self.full_name)
    -
    [docs] def modify_push_configuration(self, push_endpoint, client=None): +
    [docs] def modify_push_configuration(self, push_endpoint, client=None): """API call: update the push endpoint for the subscription. See: @@ -369,7 +531,8 @@

    Source code for gcloud.pubsub.subscription

                                   back-end.  If None, the application must pull
                                   messages.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -378,7 +541,7 @@ 

    Source code for gcloud.pubsub.subscription

             api.subscription_modify_push_config(self.full_name, push_endpoint)
             self.push_endpoint = push_endpoint
    -
    [docs] def pull(self, return_immediately=False, max_messages=1, client=None): +
    [docs] def pull(self, return_immediately=False, max_messages=1, client=None): """API call: retrieve messages for the subscription. See: @@ -399,14 +562,16 @@

    Source code for gcloud.pubsub.subscription

             :type max_messages: int
             :param max_messages: the maximum number of messages to return.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
     
             :rtype: list of (ack_id, message) tuples
             :returns: sequence of tuples: ``ack_id`` is the ID to be used in a
                       subsequent call to :meth:`acknowledge`, and ``message``
    -                  is an instance of :class:`gcloud.pubsub.message.Message`.
    +                  is an instance of
    +                  :class:`~google.cloud.pubsub.message.Message`.
             """
             client = self._require_client(client)
             api = client.subscriber_api
    @@ -415,7 +580,7 @@ 

    Source code for gcloud.pubsub.subscription

             return [(info['ackId'], Message.from_api_repr(info['message']))
                     for info in response]
    -
    [docs] def acknowledge(self, ack_ids, client=None): +
    [docs] def acknowledge(self, ack_ids, client=None): """API call: acknowledge retrieved messages for the subscription. See: @@ -430,7 +595,8 @@

    Source code for gcloud.pubsub.subscription

             :type ack_ids: list of string
             :param ack_ids: ack IDs of messages being acknowledged
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -438,7 +604,7 @@ 

    Source code for gcloud.pubsub.subscription

             api = client.subscriber_api
             api.subscription_acknowledge(self.full_name, ack_ids)
    -
    [docs] def modify_ack_deadline(self, ack_ids, ack_deadline, client=None): +
    [docs] def modify_ack_deadline(self, ack_ids, ack_deadline, client=None): """API call: update acknowledgement deadline for a retrieved message. See: @@ -450,7 +616,8 @@

    Source code for gcloud.pubsub.subscription

             :type ack_deadline: int
             :param ack_deadline: new deadline for the message, in seconds
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
             """
    @@ -459,7 +626,7 @@ 

    Source code for gcloud.pubsub.subscription

             api.subscription_modify_ack_deadline(
                 self.full_name, ack_ids, ack_deadline)
    -
    [docs] def get_iam_policy(self, client=None): +
    [docs] def get_iam_policy(self, client=None): """Fetch the IAM policy for the subscription. See: @@ -471,11 +638,12 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_get_iam_policy]
                :end-before: [END subscription_get_iam_policy]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
     
    -        :rtype: :class:`gcloud.pubsub.iam.Policy`
    +        :rtype: :class:`google.cloud.pubsub.iam.Policy`
             :returns: policy created from the resource returned by the
                       ``getIamPolicy`` API request.
             """
    @@ -484,7 +652,7 @@ 

    Source code for gcloud.pubsub.subscription

             resp = api.get_iam_policy(self.full_name)
             return Policy.from_api_repr(resp)
    -
    [docs] def set_iam_policy(self, policy, client=None): +
    [docs] def set_iam_policy(self, policy, client=None): """Update the IAM policy for the subscription. See: @@ -496,15 +664,16 @@

    Source code for gcloud.pubsub.subscription

                :start-after: [START subscription_set_iam_policy]
                :end-before: [END subscription_set_iam_policy]
     
    -        :type policy: :class:`gcloud.pubsub.iam.Policy`
    +        :type policy: :class:`google.cloud.pubsub.iam.Policy`
             :param policy: the new policy, typically fetched via
                            :meth:`get_iam_policy` and updated in place.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
     
    -        :rtype: :class:`gcloud.pubsub.iam.Policy`
    +        :rtype: :class:`google.cloud.pubsub.iam.Policy`
             :returns: updated policy created from the resource returned by the
                       ``setIamPolicy`` API request.
             """
    @@ -514,7 +683,7 @@ 

    Source code for gcloud.pubsub.subscription

             resp = api.set_iam_policy(self.full_name, resource)
             return Policy.from_api_repr(resp)
    -
    [docs] def check_iam_permissions(self, permissions, client=None): +
    [docs] def check_iam_permissions(self, permissions, client=None): """Verify permissions allowed for the current user. See: @@ -529,7 +698,8 @@

    Source code for gcloud.pubsub.subscription

             :type permissions: list of string
             :param permissions: list of permissions to be tested
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current subscription's topic.
     
    @@ -542,13 +712,13 @@ 

    Source code for gcloud.pubsub.subscription

                 self.full_name, list(permissions))
    -
    [docs]class AutoAck(dict): +
    [docs]class AutoAck(dict): """Wrapper for :meth:`Subscription.pull` results. Mapping, tracks messages still-to-be-acknowledged. When used as a context manager, acknowledges all messages still in the - mapping on `__exit__`. When processing the pulled messsages, application + mapping on `__exit__`. When processing the pulled messages, application code MUST delete messages from the :class:`AutoAck` mapping which are not successfully processed, e.g.: @@ -562,7 +732,7 @@

    Source code for gcloud.pubsub.subscription

                        del ack[ack_id]
     
         :type subscription: :class:`Subscription`
    -    :param subscription: subcription to be pulled.
    +    :param subscription: subscription to be pulled.
     
         :type return_immediately: boolean
         :param return_immediately: passed through to :meth:`Subscription.pull`
    @@ -570,7 +740,8 @@ 

    Source code for gcloud.pubsub.subscription

         :type max_messages: int
         :param max_messages: passed through to :meth:`Subscription.pull`
     
    -    :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +    :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                  ``NoneType``
         :param client: passed through to :meth:`Subscription.pull` and
                        :meth:`Subscription.acknowledge`.
         """
    @@ -592,123 +763,62 @@ 

    Source code for gcloud.pubsub.subscription

             self._subscription.acknowledge(list(self), self._client)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/pubsub/topic.html b/latest/_modules/google/cloud/pubsub/topic.html similarity index 69% rename from latest/_modules/gcloud/pubsub/topic.html rename to latest/_modules/google/cloud/pubsub/topic.html index 3b1b8c7f7f4c..3bf3ebff8e22 100644 --- a/latest/_modules/gcloud/pubsub/topic.html +++ b/latest/_modules/google/cloud/pubsub/topic.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.pubsub.topic — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.pubsub.topic — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.pubsub.topic
    • +
    • -

      Source code for gcloud.pubsub.topic

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.pubsub.topic

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -115,16 +270,16 @@ 

    Source code for gcloud.pubsub.topic

     
     import base64
     
    -from gcloud._helpers import _datetime_to_rfc3339
    -from gcloud._helpers import _NOW
    -from gcloud.exceptions import NotFound
    -from gcloud.pubsub._helpers import subscription_name_from_path
    -from gcloud.pubsub._helpers import topic_name_from_path
    -from gcloud.pubsub.iam import Policy
    -from gcloud.pubsub.subscription import Subscription
    +from google.cloud._helpers import _datetime_to_rfc3339
    +from google.cloud._helpers import _NOW
    +from google.cloud.exceptions import NotFound
    +from google.cloud.pubsub._helpers import subscription_name_from_path
    +from google.cloud.pubsub._helpers import topic_name_from_path
    +from google.cloud.pubsub.iam import Policy
    +from google.cloud.pubsub.subscription import Subscription
     
     
    -
    [docs]class Topic(object): +
    [docs]class Topic(object): """Topics are targets to which messages can be published. Subscribers then receive those messages. @@ -135,7 +290,7 @@

    Source code for gcloud.pubsub.topic

         :type name: string
         :param name: the name of the topic
     
    -    :type client: :class:`gcloud.pubsub.client.Client`
    +    :type client: :class:`google.cloud.pubsub.client.Client`
         :param client: A client which holds credentials and project configuration
                        for the topic (which requires a project).
     
    @@ -149,7 +304,7 @@ 

    Source code for gcloud.pubsub.topic

             self._client = client
             self.timestamp_messages = timestamp_messages
     
    -
    [docs] def subscription(self, name, ack_deadline=None, push_endpoint=None): +
    [docs] def subscription(self, name, ack_deadline=None, push_endpoint=None): """Creates a subscription bound to the current topic. Example: pull-mode subcription, default paramter values @@ -189,17 +344,17 @@

    Source code for gcloud.pubsub.topic

                                 push_endpoint=push_endpoint)
    @classmethod -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a topic given its API representation :type resource: dict :param resource: topic resource representation returned from the API - :type client: :class:`gcloud.pubsub.client.Client` + :type client: :class:`google.cloud.pubsub.client.Client` :param client: Client which holds credentials and project configuration for the topic. - :rtype: :class:`gcloud.pubsub.topic.Topic` + :rtype: :class:`google.cloud.pubsub.topic.Topic` :returns: Topic parsed from ``resource``. :raises: :class:`ValueError` if ``client`` is not ``None`` and the project from the resource does not agree with the project @@ -221,18 +376,19 @@

    Source code for gcloud.pubsub.topic

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
     
    -        :rtype: :class:`gcloud.pubsub.client.Client`
    +        :rtype: :class:`google.cloud.pubsub.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self._client
             return client
     
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the topic via a PUT request See: @@ -244,7 +400,8 @@

    Source code for gcloud.pubsub.topic

                :start-after: [START topic_create]
                :end-before: [END topic_create]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
             """
    @@ -252,7 +409,7 @@ 

    Source code for gcloud.pubsub.topic

             api = client.publisher_api
             api.topic_create(topic_path=self.full_name)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test for the existence of the topic via a GET request See @@ -264,7 +421,8 @@

    Source code for gcloud.pubsub.topic

                :start-after: [START topic_exists]
                :end-before: [END topic_exists]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
     
    @@ -281,7 +439,7 @@ 

    Source code for gcloud.pubsub.topic

             else:
                 return True
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """API call: delete the topic via a DELETE request See: @@ -293,7 +451,8 @@

    Source code for gcloud.pubsub.topic

                :start-after: [START topic_delete]
                :end-before: [END topic_delete]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
             """
    @@ -311,7 +470,7 @@ 

    Source code for gcloud.pubsub.topic

             if self.timestamp_messages and 'timestamp' not in attrs:
                 attrs['timestamp'] = _datetime_to_rfc3339(_NOW())
     
    -
    [docs] def publish(self, message, client=None, **attrs): +
    [docs] def publish(self, message, client=None, **attrs): """API call: publish a message to a topic via a POST request See: @@ -332,7 +491,8 @@

    Source code for gcloud.pubsub.topic

             :type message: bytes
             :param message: the message payload
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
     
    @@ -351,7 +511,7 @@ 

    Source code for gcloud.pubsub.topic

             message_ids = api.topic_publish(self.full_name, [message_data])
             return message_ids[0]
    -
    [docs] def batch(self, client=None): +
    [docs] def batch(self, client=None): """Return a batch to use as a context manager. Example: @@ -366,7 +526,8 @@

    Source code for gcloud.pubsub.topic

                used as a context manager, and only if the block exits without
                raising an exception.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
     
    @@ -376,7 +537,7 @@ 

    Source code for gcloud.pubsub.topic

             client = self._require_client(client)
             return Batch(self, client)
    -
    [docs] def list_subscriptions(self, page_size=None, page_token=None, client=None): +
    [docs] def list_subscriptions(self, page_size=None, page_token=None, client=None): """List subscriptions for the project associated with this client. See: @@ -397,12 +558,13 @@

    Source code for gcloud.pubsub.topic

                                passed, the API will return the first page of
                                topics.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current topic.
     
             :rtype: tuple, (list, str)
    -        :returns: list of :class:`gcloud.pubsub.subscription.Subscription`,
    +        :returns: list of :class:`~.pubsub.subscription.Subscription`,
                       plus a "next page token" string:  if not None, indicates that
                       more topics can be retrieved with another call (pass that
                       value as ``page_token``).
    @@ -417,7 +579,7 @@ 

    Source code for gcloud.pubsub.topic

                 subscriptions.append(Subscription(sub_name, self))
             return subscriptions, next_token
    -
    [docs] def get_iam_policy(self, client=None): +
    [docs] def get_iam_policy(self, client=None): """Fetch the IAM policy for the topic. See: @@ -429,11 +591,12 @@

    Source code for gcloud.pubsub.topic

                :start-after: [START topic_get_iam_policy]
                :end-before: [END topic_get_iam_policy]
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current batch.
     
    -        :rtype: :class:`gcloud.pubsub.iam.Policy`
    +        :rtype: :class:`google.cloud.pubsub.iam.Policy`
             :returns: policy created from the resource returned by the
                       ``getIamPolicy`` API request.
             """
    @@ -442,7 +605,7 @@ 

    Source code for gcloud.pubsub.topic

             resp = api.get_iam_policy(self.full_name)
             return Policy.from_api_repr(resp)
    -
    [docs] def set_iam_policy(self, policy, client=None): +
    [docs] def set_iam_policy(self, policy, client=None): """Update the IAM policy for the topic. See: @@ -454,15 +617,16 @@

    Source code for gcloud.pubsub.topic

                :start-after: [START topic_set_iam_policy]
                :end-before: [END topic_set_iam_policy]
     
    -        :type policy: :class:`gcloud.pubsub.iam.Policy`
    +        :type policy: :class:`google.cloud.pubsub.iam.Policy`
             :param policy: the new policy, typically fetched via
                            :meth:`get_iam_policy` and updated in place.
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current batch.
     
    -        :rtype: :class:`gcloud.pubsub.iam.Policy`
    +        :rtype: :class:`google.cloud.pubsub.iam.Policy`
             :returns: updated policy created from the resource returned by the
                       ``setIamPolicy`` API request.
             """
    @@ -472,7 +636,7 @@ 

    Source code for gcloud.pubsub.topic

             resp = api.set_iam_policy(self.full_name, resource)
             return Policy.from_api_repr(resp)
    -
    [docs] def check_iam_permissions(self, permissions, client=None): +
    [docs] def check_iam_permissions(self, permissions, client=None): """Verify permissions allowed for the current user. See: @@ -487,7 +651,8 @@

    Source code for gcloud.pubsub.topic

             :type permissions: list of string
             :param permissions: list of permissions to be tested
     
    -        :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.pubsub.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current batch.
     
    @@ -500,15 +665,15 @@ 

    Source code for gcloud.pubsub.topic

                 self.full_name, list(permissions))
    -
    [docs]class Batch(object): +
    [docs]class Batch(object): """Context manager: collect messages to publish via a single API call. Helper returned by :meth:Topic.batch - :type topic: :class:`gcloud.pubsub.topic.Topic` + :type topic: :class:`google.cloud.pubsub.topic.Topic` :param topic: the topic being published - :type client: :class:`gcloud.pubsub.client.Client` + :type client: :class:`google.cloud.pubsub.client.Client` :param client: The client to use. """ def __init__(self, topic, client): @@ -527,7 +692,7 @@

    Source code for gcloud.pubsub.topic

         def __iter__(self):
             return iter(self.message_ids)
     
    -
    [docs] def publish(self, message, **attrs): +
    [docs] def publish(self, message, **attrs): """Emulate publishing a message, but save it. :type message: bytes @@ -541,10 +706,11 @@

    Source code for gcloud.pubsub.topic

                 {'data': base64.b64encode(message).decode('ascii'),
                  'attributes': attrs})
    -
    [docs] def commit(self, client=None): +
    [docs] def commit(self, client=None): """Send saved messages as a single API call. - :type client: :class:`gcloud.pubsub.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.pubsub.client.Client` or + ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current batch. """ @@ -559,123 +725,62 @@

    Source code for gcloud.pubsub.topic

             del self.messages[:]
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/resource_manager/client.html b/latest/_modules/google/cloud/resource_manager/client.html similarity index 56% rename from latest/_modules/gcloud/resource_manager/client.html rename to latest/_modules/google/cloud/resource_manager/client.html index d9c413fe2b09..a4c047c7c750 100644 --- a/latest/_modules/gcloud/resource_manager/client.html +++ b/latest/_modules/google/cloud/resource_manager/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.resource_manager.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.resource_manager.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.resource_manager.client
    • +
    • -

      Source code for gcloud.resource_manager.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.resource_manager.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,13 +269,13 @@ 

    Source code for gcloud.resource_manager.client

    """A Client for interacting with the Resource Manager API.""" -from gcloud.client import Client as BaseClient -from gcloud.iterator import Iterator -from gcloud.resource_manager.connection import Connection -from gcloud.resource_manager.project import Project +from google.cloud.client import Client as BaseClient +from google.cloud.iterator import Iterator +from google.cloud.resource_manager.connection import Connection +from google.cloud.resource_manager.project import Project -

    [docs]class Client(BaseClient): +
    [docs]class Client(BaseClient): """Client to bundle configuration needed for API requests. See @@ -129,7 +284,7 @@

    Source code for gcloud.resource_manager.client

    Automatically get credentials:: - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() :type credentials: :class:`oauth2client.client.OAuth2Credentials` or @@ -147,12 +302,13 @@

    Source code for gcloud.resource_manager.client

    _connection_class = Connection -

    [docs] def new_project(self, project_id, name=None, labels=None): - """Creates a :class:`.Project` bound to the current client. +
    [docs] def new_project(self, project_id, name=None, labels=None): + """Create a project bound to the current client. Use :meth:`Project.reload() \ - <gcloud.resource_manager.project.Project.reload>` to retrieve - project metadata after creating a :class:`.Project` instance. + <google.cloud.resource_manager.project.Project.reload>` to retrieve + project metadata after creating a + :class:`~gcloud.resource_manager.project.Project` instance. .. note: @@ -167,37 +323,39 @@

    Source code for gcloud.resource_manager.client

    :type labels: dict :param labels: A list of labels associated with the project. - :rtype: :class:`.Project` - :returns: A new instance of a :class:`.Project` **without** - any metadata loaded. + :rtype: :class:`~gcloud.resource_manager.project.Project` + :returns: A new instance of a + :class:`~gcloud.resource_manager.project.Project` + **without** any metadata loaded. """ return Project(project_id=project_id, client=self, name=name, labels=labels)

    -
    [docs] def fetch_project(self, project_id): +
    [docs] def fetch_project(self, project_id): """Fetch an existing project and it's relevant metadata by ID. .. note:: If the project does not exist, this will raise a - :class:`NotFound <gcloud.exceptions.NotFound>` error. + :class:`NotFound <google.cloud.exceptions.NotFound>` error. :type project_id: str :param project_id: The ID for this project. - :rtype: :class:`.Project` - :returns: A :class:`.Project` with metadata fetched from the API. + :rtype: :class:`~gcloud.resource_manager.project.Project` + :returns: A :class:`~gcloud.resource_manager.project.Project` with + metadata fetched from the API. """ project = self.new_project(project_id) project.reload() return project
    -
    [docs] def list_projects(self, filter_params=None, page_size=None): +
    [docs] def list_projects(self, filter_params=None, page_size=None): """List the projects visible to this client. Example:: - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() >>> for project in client.list_projects(): ... print project.project_id @@ -205,7 +363,7 @@

    Source code for gcloud.resource_manager.client

    List all projects with label ``'environment'`` set to ``'prod'`` (filtering by labels):: - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() >>> env_filter = {'labels.environment': 'prod'} >>> for project in client.list_projects(env_filter): @@ -241,7 +399,7 @@

    Source code for gcloud.resource_manager.client

    :returns: A project iterator. The iterator will make multiple API requests if you continue iterating and there are more pages of results. Each item returned will be a. - :class:`.Project`. + :class:`~gcloud.resource_manager.project.Project`. """ extra_params = {} @@ -258,10 +416,10 @@

    Source code for gcloud.resource_manager.client

    """An iterator over a list of Project resources. You shouldn't have to use this directly, but instead should use the - helper methods on :class:`gcloud.resource_manager.client.Client` + helper methods on :class:`google.cloud.resource_manager.client.Client` objects. - :type client: :class:`gcloud.resource_manager.client.Client` + :type client: :class:`google.cloud.resource_manager.client.Client` :param client: The client to use for making connections. :type extra_params: dict @@ -274,7 +432,7 @@

    Source code for gcloud.resource_manager.client

    extra_params=extra_params) def get_items_from_response(self, response): - """Yield :class:`.Project` items from response. + """Yield projects from response. :type response: dict :param response: The JSON API response for a page of projects. @@ -284,123 +442,62 @@

    Source code for gcloud.resource_manager.client

    yield item

    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/resource_manager/connection.html b/latest/_modules/google/cloud/resource_manager/connection.html new file mode 100644 index 000000000000..d36ac7179a0a --- /dev/null +++ b/latest/_modules/google/cloud/resource_manager/connection.html @@ -0,0 +1,357 @@ + + + + + + + + + + + google.cloud.resource_manager.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.resource_manager.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.resource_manager.connection

    +# Copyright 2015 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Google Cloud Resource Manager connections."""
    +
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Resource Manager via the JSON REST API. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` + :param credentials: (Optional) The OAuth2 Credentials to use for this + connection. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: (Optional) HTTP object to make requests. + """ + + API_BASE_URL = 'https://cloudresourcemanager.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v1beta1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/cloud-platform',) + """The scopes required for authenticating as a Resouce Manager consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/resource_manager/project.html b/latest/_modules/google/cloud/resource_manager/project.html similarity index 67% rename from latest/_modules/gcloud/resource_manager/project.html rename to latest/_modules/google/cloud/resource_manager/project.html index b19143c0be9c..0199c722da4d 100644 --- a/latest/_modules/gcloud/resource_manager/project.html +++ b/latest/_modules/google/cloud/resource_manager/project.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.resource_manager.project — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.resource_manager.project — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.resource_manager.project
    • +
    • -

      Source code for gcloud.resource_manager.project

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.resource_manager.project

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,21 +269,21 @@ 

    Source code for gcloud.resource_manager.project

    < """Utility for managing projects via the Cloud Resource Manager API.""" -from gcloud.exceptions import NotFound +from google.cloud.exceptions import NotFound -
    [docs]class Project(object): +
    [docs]class Project(object): """Projects are containers for your work on Google Cloud Platform. .. note:: A :class:`Project` can also be created via :meth:`Client.new_project() \ - <gcloud.resource_manager.client.Client.new_project>` + <google.cloud.resource_manager.client.Client.new_project>` To manage labels on a :class:`Project`:: - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() >>> project = client.new_project('purple-spaceship-123') >>> project.labels = {'color': 'purple'} @@ -141,7 +296,7 @@

    Source code for gcloud.resource_manager.project

    < :type project_id: string :param project_id: The globally unique ID of the project. - :type client: :class:`gcloud.resource_manager.client.Client` + :type client: :class:`google.cloud.resource_manager.client.Client` :param client: The Client used with this project. :type name: string @@ -162,23 +317,23 @@

    Source code for gcloud.resource_manager.project

    < return '<Project: %r (%r)>' % (self.name, self.project_id) @classmethod -
    [docs] def from_api_repr(cls, resource, client): +
    [docs] def from_api_repr(cls, resource, client): """Factory: construct a project given its API representation. :type resource: dict :param resource: project resource representation returned from the API - :type client: :class:`gcloud.resource_manager.client.Client` + :type client: :class:`google.cloud.resource_manager.client.Client` :param client: The Client used with this project. - :rtype: :class:`gcloud.resource_manager.project.Project` + :rtype: :class:`google.cloud.resource_manager.project.Project` :returns: The project created. """ project = cls(project_id=resource['projectId'], client=client) project.set_properties_from_api_repr(resource) return project
    -
    [docs] def set_properties_from_api_repr(self, resource): +
    [docs] def set_properties_from_api_repr(self, resource): """Update specific properties from its API representation.""" self.name = resource.get('name') self.number = resource['projectNumber'] @@ -200,25 +355,25 @@

    Source code for gcloud.resource_manager.project

    < def _require_client(self, client): """Check client or verify over-ride. - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or ``NoneType`` :param client: the client to use. If not passed, falls back to the ``client`` stored on the current project. - :rtype: :class:`gcloud.resource_manager.client.Client` + :rtype: :class:`google.cloud.resource_manager.client.Client` :returns: The client passed in or the currently bound client. """ if client is None: client = self._client return client -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """API call: create the project via a ``POST`` request. See https://cloud.google.com/resource-manager/reference/rest/v1beta1/projects/create - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -234,13 +389,13 @@

    Source code for gcloud.resource_manager.project

    < data=data) self.set_properties_from_api_repr(resource=resp)
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """API call: reload the project via a ``GET`` request. This method will reload the newest metadata for the project. If you've created a new :class:`Project` instance via :meth:`Client.new_project() \ - <gcloud.resource_manager.client.Client.new_project>`, + <google.cloud.resource_manager.client.Client.new_project>`, this method will retrieve project metadata. .. warning:: @@ -251,7 +406,7 @@

    Source code for gcloud.resource_manager.project

    < See https://cloud.google.com/resource-manager/reference/rest/v1beta1/projects/get - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -263,13 +418,13 @@

    Source code for gcloud.resource_manager.project

    < resp = client.connection.api_request(method='GET', path=self.path) self.set_properties_from_api_repr(resource=resp)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """API call: test the existence of a project via a ``GET`` request. See https://cloud.google.com/resource-manager/reference/rest/v1beta1/projects/get - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -288,13 +443,13 @@

    Source code for gcloud.resource_manager.project

    < else: return True
    -
    [docs] def update(self, client=None): +
    [docs] def update(self, client=None): """API call: update the project via a ``PUT`` request. See https://cloud.google.com/resource-manager/reference/rest/v1beta1/projects/update - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -306,7 +461,7 @@

    Source code for gcloud.resource_manager.project

    < data=data) self.set_properties_from_api_repr(resp)
    -
    [docs] def delete(self, client=None, reload_data=False): +
    [docs] def delete(self, client=None, reload_data=False): """API call: delete the project via a ``DELETE`` request. See: @@ -318,7 +473,7 @@

    Source code for gcloud.resource_manager.project

    < ``DELETE_IN_PROGRESS`` state, which means the deleting has actually begun. - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -337,7 +492,7 @@

    Source code for gcloud.resource_manager.project

    < if reload_data: self.reload()
    -
    [docs] def undelete(self, client=None, reload_data=False): +
    [docs] def undelete(self, client=None, reload_data=False): """API call: undelete the project via a ``POST`` request. See @@ -348,7 +503,7 @@

    Source code for gcloud.resource_manager.project

    < If the project has already reached a status of ``DELETE_IN_PROGRESS``, this request will fail and the project cannot be restored. - :type client: :class:`gcloud.resource_manager.client.Client` or + :type client: :class:`google.cloud.resource_manager.client.Client` or :data:`NoneType <types.NoneType>` :param client: the client to use. If not passed, falls back to the client stored on the current project. @@ -369,123 +524,62 @@

    Source code for gcloud.resource_manager.project

    < self.reload()
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/acl.html b/latest/_modules/google/cloud/storage/acl.html similarity index 76% rename from latest/_modules/gcloud/storage/acl.html rename to latest/_modules/google/cloud/storage/acl.html index 400f73e55573..b7a4c70a0ce9 100644 --- a/latest/_modules/gcloud/storage/acl.html +++ b/latest/_modules/google/cloud/storage/acl.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.storage.acl — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.storage.acl — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.acl
    • +
    • -

      Source code for gcloud.storage.acl

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.acl

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -113,11 +268,11 @@ 

    Source code for gcloud.storage.acl

     
     """Manipulate access control lists that Cloud Storage provides.
     
    -:class:`gcloud.storage.bucket.Bucket` has a getting method that creates
    +:class:`google.cloud.storage.bucket.Bucket` has a getting method that creates
     an ACL object under the hood, and you can interact with that using
    -:func:`gcloud.storage.bucket.Bucket.acl`::
    +:func:`google.cloud.storage.bucket.Bucket.acl`::
     
    -  >>> from gcloud import storage
    +  >>> from google.cloud import storage
       >>> client = storage.Client()
       >>> bucket = client.get_bucket(bucket_name)
       >>> acl = bucket.acl
    @@ -157,13 +312,13 @@ 

    Source code for gcloud.storage.acl

       >>> acl.all().grant_read().revoke_write()
     
     After that, you can save any changes you make with the
    -:func:`gcloud.storage.acl.ACL.save` method::
    +:func:`google.cloud.storage.acl.ACL.save` method::
     
       >>> acl.save()
     
    -You can alternatively save any existing :class:`gcloud.storage.acl.ACL`
    +You can alternatively save any existing :class:`google.cloud.storage.acl.ACL`
     object (whether it was created by a factory method or not) from a
    -:class:`gcloud.storage.bucket.Bucket`::
    +:class:`google.cloud.storage.bucket.Bucket`::
     
       >>> bucket.acl.save(acl=acl)
     
    @@ -261,7 +416,7 @@ 

    Source code for gcloud.storage.acl

             self.revoke(_ACLEntity.OWNER_ROLE)
     
     
    -
    [docs]class ACL(object): +
    [docs]class ACL(object): """Container class representing a list of access controls.""" _URL_PATH_ELEM = 'acl' @@ -305,7 +460,7 @@

    Source code for gcloud.storage.acl

             if not self.loaded:
                 self.reload()
     
    -
    [docs] def reset(self): +
    [docs] def reset(self): """Remove all entities from the ACL, and clear the ``loaded`` flag.""" self.entities.clear() self.loaded = False
    @@ -318,7 +473,7 @@

    Source code for gcloud.storage.acl

                     if role:
                         yield {'entity': str(entity), 'role': role}
     
    -
    [docs] def entity_from_dict(self, entity_dict): +
    [docs] def entity_from_dict(self, entity_dict): """Build an _ACLEntity object from a dictionary of data. An entity is a mutable object that represents a list of roles @@ -351,7 +506,7 @@

    Source code for gcloud.storage.acl

             entity.grant(role)
             return entity
    -
    [docs] def has_entity(self, entity): +
    [docs] def has_entity(self, entity): """Returns whether or not this ACL has any entries for an entity. :type entity: :class:`_ACLEntity` @@ -363,7 +518,7 @@

    Source code for gcloud.storage.acl

             self._ensure_loaded()
             return str(entity) in self.entities
    -
    [docs] def get_entity(self, entity, default=None): +
    [docs] def get_entity(self, entity, default=None): """Gets an entity object from the ACL. :type entity: :class:`_ACLEntity` or string @@ -380,7 +535,7 @@

    Source code for gcloud.storage.acl

             self._ensure_loaded()
             return self.entities.get(str(entity), default)
    -
    [docs] def add_entity(self, entity): +
    [docs] def add_entity(self, entity): """Add an entity to the ACL. :type entity: :class:`_ACLEntity` @@ -389,7 +544,7 @@

    Source code for gcloud.storage.acl

             self._ensure_loaded()
             self.entities[str(entity)] = entity
    -
    [docs] def entity(self, entity_type, identifier=None): +
    [docs] def entity(self, entity_type, identifier=None): """Factory method for creating an Entity. If an entity with the same type and identifier already exists, @@ -415,7 +570,7 @@

    Source code for gcloud.storage.acl

                 self.add_entity(entity)
             return entity
    -
    [docs] def user(self, identifier): +
    [docs] def user(self, identifier): """Factory method for a user Entity. :type identifier: string @@ -426,7 +581,7 @@

    Source code for gcloud.storage.acl

             """
             return self.entity('user', identifier=identifier)
    -
    [docs] def group(self, identifier): +
    [docs] def group(self, identifier): """Factory method for a group Entity. :type identifier: string @@ -437,7 +592,7 @@

    Source code for gcloud.storage.acl

             """
             return self.entity('group', identifier=identifier)
    -
    [docs] def domain(self, domain): +
    [docs] def domain(self, domain): """Factory method for a domain Entity. :type domain: string @@ -448,7 +603,7 @@

    Source code for gcloud.storage.acl

             """
             return self.entity('domain', identifier=domain)
    -
    [docs] def all(self): +
    [docs] def all(self): """Factory method for an Entity representing all users. :rtype: :class:`_ACLEntity` @@ -456,7 +611,7 @@

    Source code for gcloud.storage.acl

             """
             return self.entity('allUsers')
    -
    [docs] def all_authenticated(self): +
    [docs] def all_authenticated(self): """Factory method for an Entity representing all authenticated users. :rtype: :class:`_ACLEntity` @@ -464,7 +619,7 @@

    Source code for gcloud.storage.acl

             """
             return self.entity('allAuthenticatedUsers')
    -
    [docs] def get_entities(self): +
    [docs] def get_entities(self): """Get a list of all Entity objects. :rtype: list of :class:`_ACLEntity` objects @@ -481,21 +636,23 @@

    Source code for gcloud.storage.acl

         def _require_client(self, client):
             """Check client or verify over-ride.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: the client to use.  If not passed, falls back to the
                            ``client`` stored on the current ACL.
     
    -        :rtype: :class:`gcloud.storage.client.Client`
    +        :rtype: :class:`google.cloud.storage.client.Client`
             :returns: The client passed in or the currently bound client.
             """
             if client is None:
                 client = self.client
             return client
     
    -
    [docs] def reload(self, client=None): +
    [docs] def reload(self, client=None): """Reload the ACL data from Cloud Storage. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the ACL's parent. """ @@ -512,7 +669,7 @@

    Source code for gcloud.storage.acl

         def _save(self, acl, predefined, client):
             """Helper for :meth:`save` and :meth:`save_predefined`.
     
    -        :type acl: :class:`gcloud.storage.acl.ACL`, or a compatible list.
    +        :type acl: :class:`google.cloud.storage.acl.ACL`, or a compatible list.
             :param acl: The ACL object to save.  If left blank, this will save
                         current entries.
     
    @@ -521,7 +678,8 @@ 

    Source code for gcloud.storage.acl

                                of the keys in :attr:`PREDEFINED_JSON_ACLS`
                                If passed, `acl` must be None.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the ACL's parent.
             """
    @@ -542,14 +700,15 @@ 

    Source code for gcloud.storage.acl

                 self.add_entity(self.entity_from_dict(entry))
             self.loaded = True
     
    -
    [docs] def save(self, acl=None, client=None): +
    [docs] def save(self, acl=None, client=None): """Save this ACL for the current bucket. - :type acl: :class:`gcloud.storage.acl.ACL`, or a compatible list. + :type acl: :class:`google.cloud.storage.acl.ACL`, or a compatible list. :param acl: The ACL object to save. If left blank, this will save current entries. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the ACL's parent. """ @@ -562,7 +721,7 @@

    Source code for gcloud.storage.acl

             if save_to_backend:
                 self._save(acl, None, client)
    -
    [docs] def save_predefined(self, predefined, client=None): +
    [docs] def save_predefined(self, predefined, client=None): """Save this ACL for the current bucket using a predefined ACL. :type predefined: string @@ -572,7 +731,8 @@

    Source code for gcloud.storage.acl

                                aliased to the corresponding JSON name).
                                If passed, `acl` must be None.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the ACL's parent.
             """
    @@ -583,7 +743,7 @@ 

    Source code for gcloud.storage.acl

     
             self._save(None, predefined, client)
    -
    [docs] def clear(self, client=None): +
    [docs] def clear(self, client=None): """Remove all ACL entries. Note that this won't actually remove *ALL* the rules, but it @@ -591,17 +751,18 @@

    Source code for gcloud.storage.acl

             have access to a bucket that you created even after you clear
             ACL rules with this method.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the ACL's parent.
             """
             self.save([], client=client)
    -
    [docs]class BucketACL(ACL): +
    [docs]class BucketACL(ACL): """An ACL specifically for a bucket. - :type bucket: :class:`gcloud.storage.bucket.Bucket` + :type bucket: :class:`google.cloud.storage.bucket.Bucket` :param bucket: The bucket to which this ACL relates. """ @@ -625,17 +786,17 @@

    Source code for gcloud.storage.acl

             return self.bucket.path
    -
    [docs]class DefaultObjectACL(BucketACL): +
    [docs]class DefaultObjectACL(BucketACL): """A class representing the default object ACL for a bucket.""" _URL_PATH_ELEM = 'defaultObjectAcl' _PREDEFINED_QUERY_PARAM = 'predefinedDefaultObjectAcl'
    -
    [docs]class ObjectACL(ACL): +
    [docs]class ObjectACL(ACL): """An ACL specifically for a Cloud Storage object / blob. - :type blob: :class:`gcloud.storage.blob.Blob` + :type blob: :class:`google.cloud.storage.blob.Blob` :param blob: The blob that this ACL corresponds to. """ @@ -659,123 +820,62 @@

    Source code for gcloud.storage.acl

             return self.blob.path
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/batch.html b/latest/_modules/google/cloud/storage/batch.html similarity index 78% rename from latest/_modules/gcloud/storage/batch.html rename to latest/_modules/google/cloud/storage/batch.html index 6729d87cb7fa..d17d6b49f0c1 100644 --- a/latest/_modules/gcloud/storage/batch.html +++ b/latest/_modules/google/cloud/storage/batch.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.storage.batch — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.storage.batch — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.batch
    • +
    • -

      Source code for gcloud.storage.batch

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.batch

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -125,11 +280,11 @@ 

    Source code for gcloud.storage.batch

     import httplib2
     import six
     
    -from gcloud.exceptions import make_exception
    -from gcloud.storage.connection import Connection
    +from google.cloud.exceptions import make_exception
    +from google.cloud.storage.connection import Connection
     
     
    -
    [docs]class MIMEApplicationHTTP(MIMEApplication): +
    [docs]class MIMEApplicationHTTP(MIMEApplication): """MIME type for ``application/http``. Constructs payload from headers and body @@ -169,7 +324,7 @@

    Source code for gcloud.storage.batch

                 super_init(payload, 'http', encode_noop)
    -
    [docs]class NoContent(object): +
    [docs]class NoContent(object): """Emulate an HTTP '204 No Content' response.""" status = 204
    @@ -222,10 +377,10 @@

    Source code for gcloud.storage.batch

             raise KeyError('Cannot set %r -> %r on a future' % (key, value))
     
     
    -
    [docs]class Batch(Connection): +
    [docs]class Batch(Connection): """Proxy an underlying connection, batching up change operations. - :type client: :class:`gcloud.storage.client.Client` + :type client: :class:`google.cloud.storage.client.Client` :param client: The client to use for making connections. """ _MAX_BATCH_SIZE = 1000 @@ -330,8 +485,8 @@

    Source code for gcloud.storage.batch

             if exception_args is not None:
                 raise make_exception(*exception_args)
     
    -
    [docs] def finish(self): - """Submit a single `multipart/mixed` request w/ deferred requests. +
    [docs] def finish(self): + """Submit a single `multipart/mixed` request with deferred requests. :rtype: list of tuples :returns: one ``(headers, payload)`` tuple per deferred request. @@ -349,7 +504,7 @@

    Source code for gcloud.storage.batch

             self._finish_futures(responses)
             return responses
    -
    [docs] def current(self): +
    [docs] def current(self): """Return the topmost batch, or None.""" return self._client.current_batch
    @@ -370,7 +525,7 @@

    Source code for gcloud.storage.batch

     
         Helper for _unpack_batch_response.
         """
    -    # We coerce to bytes to get consitent concat across
    +    # We coerce to bytes to get consistent concat across
         # Py2 and Py3. Percent formatting is insufficient since
         # it includes the b in Py3.
         if not isinstance(content, six.binary_type):
    @@ -423,123 +578,62 @@ 

    Source code for gcloud.storage.batch

             yield headers, payload
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/blob.html b/latest/_modules/google/cloud/storage/blob.html similarity index 82% rename from latest/_modules/gcloud/storage/blob.html rename to latest/_modules/google/cloud/storage/blob.html index 8cdb0c995ebe..6ce92de93b09 100644 --- a/latest/_modules/gcloud/storage/blob.html +++ b/latest/_modules/google/cloud/storage/blob.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.storage.blob — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.storage.blob — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.blob
    • +
    • -

      Source code for gcloud.storage.blob

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.blob

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -127,33 +282,33 @@ 

    Source code for gcloud.storage.blob

     import six
     from six.moves.urllib.parse import quote
     
    -from gcloud._helpers import _rfc3339_to_datetime
    -from gcloud._helpers import _to_bytes
    -from gcloud._helpers import _bytes_to_unicode
    -from gcloud.credentials import generate_signed_url
    -from gcloud.exceptions import NotFound
    -from gcloud.exceptions import make_exception
    -from gcloud.storage._helpers import _PropertyMixin
    -from gcloud.storage._helpers import _scalar_property
    -from gcloud.storage.acl import ObjectACL
    -from gcloud.streaming.http_wrapper import Request
    -from gcloud.streaming.http_wrapper import make_api_request
    -from gcloud.streaming.transfer import Download
    -from gcloud.streaming.transfer import RESUMABLE_UPLOAD
    -from gcloud.streaming.transfer import Upload
    +from google.cloud._helpers import _rfc3339_to_datetime
    +from google.cloud._helpers import _to_bytes
    +from google.cloud._helpers import _bytes_to_unicode
    +from google.cloud.credentials import generate_signed_url
    +from google.cloud.exceptions import NotFound
    +from google.cloud.exceptions import make_exception
    +from google.cloud.storage._helpers import _PropertyMixin
    +from google.cloud.storage._helpers import _scalar_property
    +from google.cloud.storage.acl import ObjectACL
    +from google.cloud.streaming.http_wrapper import Request
    +from google.cloud.streaming.http_wrapper import make_api_request
    +from google.cloud.streaming.transfer import Download
    +from google.cloud.streaming.transfer import RESUMABLE_UPLOAD
    +from google.cloud.streaming.transfer import Upload
     
     
     _API_ACCESS_ENDPOINT = 'https://storage.googleapis.com'
     
     
    -
    [docs]class Blob(_PropertyMixin): +
    [docs]class Blob(_PropertyMixin): """A wrapper around Cloud Storage's concept of an ``Object``. :type name: string :param name: The name of the blob. This corresponds to the unique path of the object in the bucket. - :type bucket: :class:`gcloud.storage.bucket.Bucket` + :type bucket: :class:`google.cloud.storage.bucket.Bucket` :param bucket: The bucket to which this blob belongs. :type chunk_size: integer @@ -199,7 +354,7 @@

    Source code for gcloud.storage.blob

             self._chunk_size = value
     
         @staticmethod
    -
    [docs] def path_helper(bucket_path, blob_name): +
    [docs] def path_helper(bucket_path, blob_name): """Relative URL path for a blob. :type bucket_path: string @@ -255,7 +410,7 @@

    Source code for gcloud.storage.blob

                 bucket_name=self.bucket.name,
                 quoted_name=quote(self.name, safe=''))
     
    -
    [docs] def generate_signed_url(self, expiration, method='GET', +
    [docs] def generate_signed_url(self, expiration, method='GET', content_type=None, generation=None, response_disposition=None, response_type=None, client=None, credentials=None): @@ -269,7 +424,7 @@

    Source code for gcloud.storage.blob

                 service account from a JSON file rather than a GCE service account.
     
             .. _Issue 922: https://github.com/GoogleCloudPlatform/\
    -                       gcloud-python/issues/922
    +                       google-cloud-python/issues/922
     
             If you have a blob that you want to allow access to for a set
             amount of time, you can use this method to generate a URL that
    @@ -306,7 +461,8 @@ 

    Source code for gcloud.storage.blob

                                   for the signed URL. Used to over-ride the content
                                   type of the underlying blob/object.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: (Optional) The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
     
    @@ -338,10 +494,11 @@ 

    Source code for gcloud.storage.blob

                 response_disposition=response_disposition,
                 generation=generation)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """Determines whether or not this blob exists. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the blob's bucket. @@ -365,22 +522,23 @@

    Source code for gcloud.storage.blob

             except NotFound:
                 return False
    -
    [docs] def delete(self, client=None): +
    [docs] def delete(self, client=None): """Deletes a blob from Cloud Storage. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the blob's bucket. :rtype: :class:`Blob` :returns: The blob that was just deleted. - :raises: :class:`gcloud.exceptions.NotFound` + :raises: :class:`google.cloud.exceptions.NotFound` (propagated from - :meth:`gcloud.storage.bucket.Bucket.delete_blob`). + :meth:`google.cloud.storage.bucket.Bucket.delete_blob`). """ return self.bucket.delete_blob(self.name, client=client)
    -
    [docs] def download_to_file(self, file_obj, encryption_key=None, client=None): +
    [docs] def download_to_file(self, file_obj, encryption_key=None, client=None): """Download the contents of this blob into a file-like object. .. note:: @@ -391,8 +549,8 @@

    Source code for gcloud.storage.blob

              Downloading a file that has been encrypted with a `customer-supplied`_
              encryption key::
     
    -            >>> from gcloud import storage
    -            >>> from gcloud.storage import Blob
    +            >>> from google.cloud import storage
    +            >>> from google.cloud.storage import Blob
     
                 >>> client = storage.Client(project='my-project')
                 >>> bucket = client.get_bucket('my-bucket')
    @@ -415,11 +573,12 @@ 

    Source code for gcloud.storage.blob

             :param encryption_key: Optional 32 byte encryption key for
                                    customer-supplied encryption.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
     
    -        :raises: :class:`gcloud.exceptions.NotFound`
    +        :raises: :class:`google.cloud.exceptions.NotFound`
             """
             client = self._require_client(client)
             if self.media_link is None:  # not yet loaded
    @@ -447,7 +606,7 @@ 

    Source code for gcloud.storage.blob

             # it has all three (http, API_BASE_URL and build_api_url).
             download.initialize_download(request, client._connection.http)
    -
    [docs] def download_to_filename(self, filename, encryption_key=None, client=None): +
    [docs] def download_to_filename(self, filename, encryption_key=None, client=None): """Download the contents of this blob into a named file. :type filename: string @@ -457,11 +616,12 @@

    Source code for gcloud.storage.blob

             :param encryption_key: Optional 32 byte encryption key for
                                    customer-supplied encryption.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
     
    -        :raises: :class:`gcloud.exceptions.NotFound`
    +        :raises: :class:`google.cloud.exceptions.NotFound`
             """
             with open(filename, 'wb') as file_obj:
                 self.download_to_file(file_obj, encryption_key=encryption_key,
    @@ -470,20 +630,21 @@ 

    Source code for gcloud.storage.blob

             mtime = time.mktime(self.updated.timetuple())
             os.utime(file_obj.name, (mtime, mtime))
    -
    [docs] def download_as_string(self, encryption_key=None, client=None): +
    [docs] def download_as_string(self, encryption_key=None, client=None): """Download the contents of this blob as a string. :type encryption_key: str or bytes :param encryption_key: Optional 32 byte encryption key for customer-supplied encryption. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the blob's bucket. :rtype: bytes :returns: The data stored in this blob. - :raises: :class:`gcloud.exceptions.NotFound` + :raises: :class:`google.cloud.exceptions.NotFound` """ string_buffer = BytesIO() self.download_to_file(string_buffer, encryption_key=encryption_key, @@ -501,7 +662,7 @@

    Source code for gcloud.storage.blob

                                      error_info=request.url)
     
         # pylint: disable=too-many-locals
    -
    [docs] def upload_from_file(self, file_obj, rewind=False, size=None, +
    [docs] def upload_from_file(self, file_obj, rewind=False, size=None, encryption_key=None, content_type=None, num_retries=6, client=None): """Upload the contents of this blob from a file-like object. @@ -524,8 +685,8 @@

    Source code for gcloud.storage.blob

     
             Uploading a file with a `customer-supplied`_ encryption key::
     
    -            >>> from gcloud import storage
    -            >>> from gcloud.storage import Blob
    +            >>> from google.cloud import storage
    +            >>> from google.cloud.storage import Blob
     
                 >>> client = storage.Client(project='my-project')
                 >>> bucket = client.get_bucket('my-bucket')
    @@ -564,13 +725,14 @@ 

    Source code for gcloud.storage.blob

             :type num_retries: integer
             :param num_retries: Number of upload retries. Defaults to 6.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
     
             :raises: :class:`ValueError` if size is not passed in and can not be
    -                 determined; :class:`gcloud.exceptions.GCloudError` if the
    -                 upload response returns an error status.
    +                 determined; :class:`google.cloud.exceptions.GoogleCloudError`
    +                 if the upload response returns an error status.
             """
             client = self._require_client(client)
             # Use the private ``_connection`` rather than the public
    @@ -653,7 +815,7 @@ 

    Source code for gcloud.storage.blob

             self._set_properties(json.loads(response_content))
    # pylint: enable=too-many-locals -
    [docs] def upload_from_filename(self, filename, content_type=None, +
    [docs] def upload_from_filename(self, filename, content_type=None, encryption_key=None, client=None): """Upload this blob's contents from the content of a named file. @@ -683,7 +845,8 @@

    Source code for gcloud.storage.blob

             :param encryption_key: Optional 32 byte encryption key for
                                    customer-supplied encryption.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
             """
    @@ -695,7 +858,7 @@ 

    Source code for gcloud.storage.blob

                 self.upload_from_file(file_obj, content_type=content_type,
                                       encryption_key=encryption_key, client=client)
    -
    [docs] def upload_from_string(self, data, content_type='text/plain', +
    [docs] def upload_from_string(self, data, content_type='text/plain', encryption_key=None, client=None): """Upload contents of this blob from the provided string. @@ -722,7 +885,8 @@

    Source code for gcloud.storage.blob

             :param encryption_key: Optional 32 byte encryption key for
                                    customer-supplied encryption.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the blob's bucket.
             """
    @@ -734,10 +898,11 @@ 

    Source code for gcloud.storage.blob

                                   size=len(data), content_type=content_type,
                                   encryption_key=encryption_key, client=client)
    -
    [docs] def make_public(self, client=None): +
    [docs] def make_public(self, client=None): """Make this blob public giving all users read access. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the blob's bucket. """ @@ -1028,7 +1193,7 @@

    Source code for gcloud.storage.blob

     
     
     def _set_encryption_headers(key, headers):
    -    """Builds customer encyrption key headers
    +    """Builds customer encryption key headers
     
         :type key: str or bytes
         :param key: 32 byte key to build request key and hash.
    @@ -1045,123 +1210,62 @@ 

    Source code for gcloud.storage.blob

         headers['X-Goog-Encryption-Key-Sha256'] = _bytes_to_unicode(key_hash)
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/bucket.html b/latest/_modules/google/cloud/storage/bucket.html similarity index 79% rename from latest/_modules/gcloud/storage/bucket.html rename to latest/_modules/google/cloud/storage/bucket.html index b86db41938b3..6ed28e1e8fdc 100644 --- a/latest/_modules/gcloud/storage/bucket.html +++ b/latest/_modules/google/cloud/storage/bucket.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.storage.bucket — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.storage.bucket — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.bucket
    • +
    • -

      Source code for gcloud.storage.bucket

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.bucket

     # Copyright 2014 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -111,35 +266,35 @@ 

    Source code for gcloud.storage.bucket

     # See the License for the specific language governing permissions and
     # limitations under the License.
     
    -"""Create / interact with gcloud storage buckets."""
    +"""Create / interact with Google Cloud Storage buckets."""
     
     import copy
     
     import six
     
    -from gcloud._helpers import _rfc3339_to_datetime
    -from gcloud.exceptions import NotFound
    -from gcloud.iterator import Iterator
    -from gcloud.storage._helpers import _PropertyMixin
    -from gcloud.storage._helpers import _scalar_property
    -from gcloud.storage.acl import BucketACL
    -from gcloud.storage.acl import DefaultObjectACL
    -from gcloud.storage.blob import Blob
    +from google.cloud._helpers import _rfc3339_to_datetime
    +from google.cloud.exceptions import NotFound
    +from google.cloud.iterator import Iterator
    +from google.cloud.storage._helpers import _PropertyMixin
    +from google.cloud.storage._helpers import _scalar_property
    +from google.cloud.storage.acl import BucketACL
    +from google.cloud.storage.acl import DefaultObjectACL
    +from google.cloud.storage.blob import Blob
     
     
     class _BlobIterator(Iterator):
         """An iterator listing blobs in a bucket
     
         You shouldn't have to use this directly, but instead should use the
    -    :class:`gcloud.storage.blob.Bucket.list_blobs` method.
    +    :class:`google.cloud.storage.blob.Bucket.list_blobs` method.
     
    -    :type bucket: :class:`gcloud.storage.bucket.Bucket`
    +    :type bucket: :class:`google.cloud.storage.bucket.Bucket`
         :param bucket: The bucket from which to list blobs.
     
         :type extra_params: dict or None
         :param extra_params: Extra query string parameters for the API call.
     
    -    :type client: :class:`gcloud.storage.client.Client`
    +    :type client: :class:`google.cloud.storage.client.Client`
         :param client: Optional. The client to use for making connections.
                        Defaults to the bucket's client.
         """
    @@ -168,10 +323,10 @@ 

    Source code for gcloud.storage.bucket

                 yield blob
     
     
    -
    [docs]class Bucket(_PropertyMixin): +
    [docs]class Bucket(_PropertyMixin): """A class representing a Bucket on Cloud Storage. - :type client: :class:`gcloud.storage.client.Client` + :type client: :class:`google.cloud.storage.client.Client` :param client: A client which holds credentials and project configuration for the bucket (which requires a project). @@ -202,7 +357,7 @@

    Source code for gcloud.storage.bucket

             """The client bound to this bucket."""
             return self._client
     
    -
    [docs] def blob(self, blob_name, chunk_size=None): +
    [docs] def blob(self, blob_name, chunk_size=None): """Factory constructor for blob object. .. note:: @@ -217,15 +372,16 @@

    Source code for gcloud.storage.bucket

                                (1 MB). This must be a multiple of 256 KB per the
                                API specification.
     
    -        :rtype: :class:`gcloud.storage.blob.Blob`
    +        :rtype: :class:`google.cloud.storage.blob.Blob`
             :returns: The blob object created.
             """
             return Blob(name=blob_name, bucket=self, chunk_size=chunk_size)
    -
    [docs] def exists(self, client=None): +
    [docs] def exists(self, client=None): """Determines whether or not this bucket exists. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the current bucket. @@ -249,15 +405,16 @@

    Source code for gcloud.storage.bucket

             except NotFound:
                 return False
    -
    [docs] def create(self, client=None): +
    [docs] def create(self, client=None): """Creates current bucket. If the bucket already exists, will raise - :class:`gcloud.exceptions.Conflict`. + :class:`google.cloud.exceptions.Conflict`. This implements "storage.buckets.insert". - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the current bucket. """ @@ -282,7 +439,7 @@

    Source code for gcloud.storage.bucket

             return self._default_object_acl
     
         @staticmethod
    -
    [docs] def path_helper(bucket_name): +
    [docs] def path_helper(bucket_name): """Relative URL path for a bucket. :type bucket_name: string @@ -301,12 +458,12 @@

    Source code for gcloud.storage.bucket

     
             return self.path_helper(self.name)
     
    -
    [docs] def get_blob(self, blob_name, client=None): +
    [docs] def get_blob(self, blob_name, client=None): """Get a blob object by name. This will return None if the blob doesn't exist:: - >>> from gcloud import storage + >>> from google.cloud import storage >>> client = storage.Client() >>> bucket = client.get_bucket('my-bucket') >>> print bucket.get_blob('/path/to/blob.txt') @@ -317,11 +474,12 @@

    Source code for gcloud.storage.bucket

             :type blob_name: string
             :param blob_name: The name of the blob to retrieve.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
     
    -        :rtype: :class:`gcloud.storage.blob.Blob` or None
    +        :rtype: :class:`google.cloud.storage.blob.Blob` or None
             :returns: The blob object if it exists, otherwise None.
             """
             client = self._require_client(client)
    @@ -338,7 +496,7 @@ 

    Source code for gcloud.storage.bucket

             except NotFound:
                 return None
    -
    [docs] def list_blobs(self, max_results=None, page_token=None, prefix=None, +
    [docs] def list_blobs(self, max_results=None, page_token=None, prefix=None, delimiter=None, versions=None, projection='noAcl', fields=None, client=None): """Return an iterator used to find blobs in the bucket. @@ -372,7 +530,8 @@

    Source code for gcloud.storage.bucket

                            and the language of each blob returned:
                            'items/contentLanguage,nextPageToken'
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
     
    @@ -403,10 +562,12 @@ 

    Source code for gcloud.storage.bucket

             # Page token must be handled specially since the base `Iterator`
             # class has it as a reserved property.
             if page_token is not None:
    +            # pylint: disable=attribute-defined-outside-init
                 result.next_page_token = page_token
    +            # pylint: enable=attribute-defined-outside-init
             return result
    -
    [docs] def delete(self, force=False, client=None): +
    [docs] def delete(self, force=False, client=None): """Delete this bucket. The bucket **must** be empty in order to submit a delete request. If @@ -414,8 +575,9 @@

    Source code for gcloud.storage.bucket

             objects / blobs in the bucket (i.e. try to empty the bucket).
     
             If the bucket doesn't exist, this will raise
    -        :class:`gcloud.exceptions.NotFound`.  If the bucket is not empty
    -        (and ``force=False``), will raise :class:`gcloud.exceptions.Conflict`.
    +        :class:`google.cloud.exceptions.NotFound`.  If the bucket is not empty
    +        (and ``force=False``), will raise
    +        :class:`google.cloud.exceptions.Conflict`.
     
             If ``force=True`` and the bucket contains more than 256 objects / blobs
             this will cowardly refuse to delete the objects (or the bucket). This
    @@ -425,7 +587,8 @@ 

    Source code for gcloud.storage.bucket

             :type force: boolean
             :param force: If True, empties the bucket's objects then deletes it.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
     
    @@ -456,16 +619,16 @@ 

    Source code for gcloud.storage.bucket

             client.connection.api_request(method='DELETE', path=self.path,
                                           _target_object=None)
    -
    [docs] def delete_blob(self, blob_name, client=None): +
    [docs] def delete_blob(self, blob_name, client=None): """Deletes a blob from the current bucket. If the blob isn't found (backend 404), raises a - :class:`gcloud.exceptions.NotFound`. + :class:`google.cloud.exceptions.NotFound`. For example:: - >>> from gcloud.exceptions import NotFound - >>> from gcloud import storage + >>> from google.cloud.exceptions import NotFound + >>> from google.cloud import storage >>> client = storage.Client() >>> bucket = client.get_bucket('my-bucket') >>> print bucket.list_blobs() @@ -479,11 +642,12 @@

    Source code for gcloud.storage.bucket

             :type blob_name: string
             :param blob_name: A blob name to delete.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
     
    -        :raises: :class:`gcloud.exceptions.NotFound` (to suppress
    +        :raises: :class:`google.cloud.exceptions.NotFound` (to suppress
                      the exception, call ``delete_blobs``, passing a no-op
                      ``on_error`` callback, e.g.::
     
    @@ -497,24 +661,25 @@ 

    Source code for gcloud.storage.bucket

             client.connection.api_request(method='DELETE', path=blob_path,
                                           _target_object=None)
    -
    [docs] def delete_blobs(self, blobs, on_error=None, client=None): +
    [docs] def delete_blobs(self, blobs, on_error=None, client=None): """Deletes a list of blobs from the current bucket. Uses :func:`Bucket.delete_blob` to delete each individual blob. - :type blobs: list of string or :class:`gcloud.storage.blob.Blob` + :type blobs: list of string or :class:`google.cloud.storage.blob.Blob` :param blobs: A list of blob names or Blob objects to delete. :type on_error: a callable taking (blob) :param on_error: If not ``None``, called once for each blob raising - :class:`gcloud.exceptions.NotFound`; + :class:`google.cloud.exceptions.NotFound`; otherwise, the exception is propagated. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the current bucket. - :raises: :class:`gcloud.exceptions.NotFound` (if + :raises: :class:`google.cloud.exceptions.NotFound` (if `on_error` is not passed). """ for blob in blobs: @@ -529,25 +694,26 @@

    Source code for gcloud.storage.bucket

                     else:
                         raise
    -
    [docs] def copy_blob(self, blob, destination_bucket, new_name=None, +
    [docs] def copy_blob(self, blob, destination_bucket, new_name=None, client=None): """Copy the given blob to the given bucket, optionally with a new name. - :type blob: :class:`gcloud.storage.blob.Blob` + :type blob: :class:`google.cloud.storage.blob.Blob` :param blob: The blob to be copied. - :type destination_bucket: :class:`gcloud.storage.bucket.Bucket` + :type destination_bucket: :class:`google.cloud.storage.bucket.Bucket` :param destination_bucket: The bucket into which the blob should be copied. :type new_name: string :param new_name: (optional) the new name for the copied file. - :type client: :class:`gcloud.storage.client.Client` or ``NoneType`` + :type client: :class:`~google.cloud.storage.client.Client` or + ``NoneType`` :param client: Optional. The client to use. If not passed, falls back to the ``client`` stored on the current bucket. - :rtype: :class:`gcloud.storage.blob.Blob` + :rtype: :class:`google.cloud.storage.blob.Blob` :returns: The new Blob. """ client = self._require_client(client) @@ -560,7 +726,7 @@

    Source code for gcloud.storage.bucket

             new_blob._set_properties(copy_result)
             return new_blob
    -
    [docs] def rename_blob(self, blob, new_name, client=None): +
    [docs] def rename_blob(self, blob, new_name, client=None): """Rename the given blob using copy and delete operations. Effectively, copies blob to the same bucket with a new name, then @@ -572,13 +738,14 @@

    Source code for gcloud.storage.bucket

               old blob.  This means that with very large objects renaming
               could be a very (temporarily) costly or a very slow operation.
     
    -        :type blob: :class:`gcloud.storage.blob.Blob`
    +        :type blob: :class:`google.cloud.storage.blob.Blob`
             :param blob: The blob to be renamed.
     
             :type new_name: string
             :param new_name: The new name for this blob.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
     
    @@ -667,7 +834,7 @@ 

    Source code for gcloud.storage.bucket

         :rtype: string or ``NoneType``
         """
     
    -
    [docs] def get_logging(self): +
    [docs] def get_logging(self): """Return info about access logging for this bucket. See: https://cloud.google.com/storage/docs/accesslogs#status @@ -679,7 +846,7 @@

    Source code for gcloud.storage.bucket

             info = self._properties.get('logging')
             return copy.deepcopy(info)
    -
    [docs] def enable_logging(self, bucket_name, object_prefix=''): +
    [docs] def enable_logging(self, bucket_name, object_prefix=''): """Enable access logging for this bucket. See: https://cloud.google.com/storage/docs/accesslogs#delivery @@ -693,7 +860,7 @@

    Source code for gcloud.storage.bucket

             info = {'logBucket': bucket_name, 'logObjectPrefix': object_prefix}
             self._patch_property('logging', info)
    -
    [docs] def disable_logging(self): +
    [docs] def disable_logging(self): """Disable access logging for this bucket. See: https://cloud.google.com/storage/docs/accesslogs#disabling @@ -821,7 +988,7 @@

    Source code for gcloud.storage.bucket

             """
             self._patch_property('versioning', {'enabled': bool(value)})
     
    -
    [docs] def configure_website(self, main_page_suffix=None, not_found_page=None): +
    [docs] def configure_website(self, main_page_suffix=None, not_found_page=None): """Configure website-related properties. See: https://developers.google.com/storage/docs/website-configuration @@ -834,7 +1001,7 @@

    Source code for gcloud.storage.bucket

             If you want this bucket to host a website, just provide the name
             of an index page and a page to use when a blob isn't found::
     
    -          >>> from gcloud import storage
    +          >>> from google.cloud import storage
               >>> client = storage.Client()
               >>> bucket = client.get_bucket(bucket_name)
               >>> bucket.configure_website('index.html', '404.html')
    @@ -861,7 +1028,7 @@ 

    Source code for gcloud.storage.bucket

             }
             self._patch_property('website', data)
    -
    [docs] def disable_website(self): +
    [docs] def disable_website(self): """Disable the website configuration for this bucket. This is really just a shortcut for setting the website-related @@ -869,7 +1036,7 @@

    Source code for gcloud.storage.bucket

             """
             return self.configure_website(None, None)
    -
    [docs] def make_public(self, recursive=False, future=False, client=None): +
    [docs] def make_public(self, recursive=False, future=False, client=None): """Make a bucket public. If ``recursive=True`` and the bucket contains more than 256 @@ -884,7 +1051,8 @@

    Source code for gcloud.storage.bucket

             :param future: If True, this will make all objects created in the
                            future public as well.
     
    -        :type client: :class:`gcloud.storage.client.Client` or ``NoneType``
    +        :type client: :class:`~google.cloud.storage.client.Client` or
    +                      ``NoneType``
             :param client: Optional. The client to use.  If not passed, falls back
                            to the ``client`` stored on the current bucket.
             """
    @@ -917,123 +1085,62 @@ 

    Source code for gcloud.storage.bucket

                     blob.acl.save(client=client)
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/storage/client.html b/latest/_modules/google/cloud/storage/client.html similarity index 66% rename from latest/_modules/gcloud/storage/client.html rename to latest/_modules/google/cloud/storage/client.html index a551cefecb71..e1e30af04731 100644 --- a/latest/_modules/gcloud/storage/client.html +++ b/latest/_modules/google/cloud/storage/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.storage.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.storage.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.client
    • +
    • -

      Source code for gcloud.storage.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.client

     # Copyright 2015 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -114,16 +269,16 @@ 

    Source code for gcloud.storage.client

     """Client for interacting with the Google Cloud Storage API."""
     
     
    -from gcloud._helpers import _LocalStack
    -from gcloud.client import JSONClient
    -from gcloud.exceptions import NotFound
    -from gcloud.iterator import Iterator
    -from gcloud.storage.batch import Batch
    -from gcloud.storage.bucket import Bucket
    -from gcloud.storage.connection import Connection
    +from google.cloud._helpers import _LocalStack
    +from google.cloud.client import JSONClient
    +from google.cloud.exceptions import NotFound
    +from google.cloud.iterator import Iterator
    +from google.cloud.storage.batch import Batch
    +from google.cloud.storage.bucket import Bucket
    +from google.cloud.storage.connection import Connection
     
     
    -
    [docs]class Client(JSONClient): +
    [docs]class Client(JSONClient): """Client to bundle configuration needed for API requests. :type project: string @@ -156,7 +311,7 @@

    Source code for gcloud.storage.client

         def connection(self):
             """Get connection or batch on the client.
     
    -        :rtype: :class:`gcloud.storage.connection.Connection`
    +        :rtype: :class:`google.cloud.storage.connection.Connection`
             :returns: The connection set on the client, or the batch
                       if one is set.
             """
    @@ -173,7 +328,7 @@ 

    Source code for gcloud.storage.client

                 self.connection = connection
             Will raise if the connection is set more than once.
     
    -        :type value: :class:`gcloud.storage.connection.Connection`
    +        :type value: :class:`google.cloud.storage.connection.Connection`
             :param value: The connection set on the client.
     
             :raises: :class:`ValueError` if connection has already been set.
    @@ -187,7 +342,7 @@ 

    Source code for gcloud.storage.client

     
             "Protected", intended for use by batch context mgrs.
     
    -        :type batch: :class:`gcloud.storage.batch.Batch`
    +        :type batch: :class:`google.cloud.storage.batch.Batch`
             :param batch: newly-active batch
             """
             self._batch_stack.push(batch)
    @@ -198,7 +353,7 @@ 

    Source code for gcloud.storage.client

             "Protected", intended for use by batch context mgrs.
     
             :raises: IndexError if the stack is empty.
    -        :rtype: :class:`gcloud.storage.batch.Batch`
    +        :rtype: :class:`google.cloud.storage.batch.Batch`
             :returns: the top-most batch/transaction, after removing it.
             """
             return self._batch_stack.pop()
    @@ -207,13 +362,13 @@ 

    Source code for gcloud.storage.client

         def current_batch(self):
             """Currently-active batch.
     
    -        :rtype: :class:`gcloud.storage.batch.Batch` or ``NoneType`` (if
    +        :rtype: :class:`google.cloud.storage.batch.Batch` or ``NoneType`` (if
                     no batch is active).
             :returns: The batch at the top of the batch stack.
             """
             return self._batch_stack.top
     
    -
    [docs] def bucket(self, bucket_name): +
    [docs] def bucket(self, bucket_name): """Factory constructor for bucket object. .. note:: @@ -223,34 +378,34 @@

    Source code for gcloud.storage.client

             :type bucket_name: string
             :param bucket_name: The name of the bucket to be instantiated.
     
    -        :rtype: :class:`gcloud.storage.bucket.Bucket`
    +        :rtype: :class:`google.cloud.storage.bucket.Bucket`
             :returns: The bucket object created.
             """
             return Bucket(client=self, name=bucket_name)
    -
    [docs] def batch(self): +
    [docs] def batch(self): """Factory constructor for batch object. .. note:: This will not make an HTTP request; it simply instantiates a batch object owned by this client. - :rtype: :class:`gcloud.storage.batch.Batch` + :rtype: :class:`google.cloud.storage.batch.Batch` :returns: The batch object created. """ return Batch(client=self)
    -
    [docs] def get_bucket(self, bucket_name): +
    [docs] def get_bucket(self, bucket_name): """Get a bucket by name. If the bucket isn't found, this will raise a - :class:`gcloud.storage.exceptions.NotFound`. + :class:`google.cloud.storage.exceptions.NotFound`. For example:: >>> try: >>> bucket = client.get_bucket('my-bucket') - >>> except gcloud.exceptions.NotFound: + >>> except google.cloud.exceptions.NotFound: >>> print 'Sorry, that bucket does not exist!' This implements "storage.buckets.get". @@ -258,15 +413,15 @@

    Source code for gcloud.storage.client

             :type bucket_name: string
             :param bucket_name: The name of the bucket to get.
     
    -        :rtype: :class:`gcloud.storage.bucket.Bucket`
    +        :rtype: :class:`google.cloud.storage.bucket.Bucket`
             :returns: The bucket matching the name provided.
    -        :raises: :class:`gcloud.exceptions.NotFound`
    +        :raises: :class:`google.cloud.exceptions.NotFound`
             """
             bucket = Bucket(self, name=bucket_name)
             bucket.reload(client=self)
             return bucket
    -
    [docs] def lookup_bucket(self, bucket_name): +
    [docs] def lookup_bucket(self, bucket_name): """Get a bucket by name, returning None if not found. You can use this if you would rather check for a None value @@ -282,7 +437,7 @@

    Source code for gcloud.storage.client

             :type bucket_name: string
             :param bucket_name: The name of the bucket to get.
     
    -        :rtype: :class:`gcloud.storage.bucket.Bucket`
    +        :rtype: :class:`google.cloud.storage.bucket.Bucket`
             :returns: The bucket matching the name provided or None if not found.
             """
             try:
    @@ -290,7 +445,7 @@ 

    Source code for gcloud.storage.client

             except NotFound:
                 return None
    -
    [docs] def create_bucket(self, bucket_name): +
    [docs] def create_bucket(self, bucket_name): """Create a new bucket. For example:: @@ -302,19 +457,19 @@

    Source code for gcloud.storage.client

             This implements "storage.buckets.insert".
     
             If the bucket already exists, will raise
    -        :class:`gcloud.exceptions.Conflict`.
    +        :class:`google.cloud.exceptions.Conflict`.
     
             :type bucket_name: string
             :param bucket_name: The bucket name to create.
     
    -        :rtype: :class:`gcloud.storage.bucket.Bucket`
    +        :rtype: :class:`google.cloud.storage.bucket.Bucket`
             :returns: The newly created bucket.
             """
             bucket = Bucket(self, name=bucket_name)
             bucket.create(client=self)
             return bucket
    -
    [docs] def list_buckets(self, max_results=None, page_token=None, prefix=None, +
    [docs] def list_buckets(self, max_results=None, page_token=None, prefix=None, projection='noAcl', fields=None): """Get all buckets in the project associated to the client. @@ -349,7 +504,8 @@

    Source code for gcloud.storage.client

                            and the language of each bucket returned:
                            'items/id,nextPageToken'
     
    -        :rtype: iterable of :class:`gcloud.storage.bucket.Bucket` objects.
    +        :rtype: iterable of :class:`google.cloud.storage.bucket.Bucket`
    +                objects.
             :returns: All buckets belonging to this project.
             """
             extra_params = {'project': self.project}
    @@ -370,7 +526,9 @@ 

    Source code for gcloud.storage.client

             # Page token must be handled specially since the base `Iterator`
             # class has it as a reserved property.
             if page_token is not None:
    +            # pylint: disable=attribute-defined-outside-init
                 result.next_page_token = page_token
    +            # pylint: enable=attribute-defined-outside-init
             return result
    @@ -378,10 +536,10 @@

    Source code for gcloud.storage.client

         """An iterator listing all buckets.
     
         You shouldn't have to use this directly, but instead should use the
    -    helper methods on :class:`gcloud.storage.connection.Connection`
    +    helper methods on :class:`google.cloud.storage.connection.Connection`
         objects.
     
    -    :type client: :class:`gcloud.storage.client.Client`
    +    :type client: :class:`google.cloud.storage.client.Client`
         :param client: The client to use for making connections.
     
         :type extra_params: dict or ``NoneType``
    @@ -405,123 +563,62 @@ 

    Source code for gcloud.storage.client

                 yield bucket
     
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/storage/connection.html b/latest/_modules/google/cloud/storage/connection.html new file mode 100644 index 000000000000..24041750f4bb --- /dev/null +++ b/latest/_modules/google/cloud/storage/connection.html @@ -0,0 +1,358 @@ + + + + + + + + + + + google.cloud.storage.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.storage.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.storage.connection

    +# Copyright 2014 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Google Cloud Storage connections."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Storage via the JSON REST API. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` + :param credentials: (Optional) The OAuth2 Credentials to use for this + connection. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: (Optional) HTTP object to make requests. + """ + + API_BASE_URL = base_connection.API_BASE_URL + """The base of the API call URL.""" + + API_VERSION = 'v1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/storage/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/devstorage.full_control', + 'https://www.googleapis.com/auth/devstorage.read_only', + 'https://www.googleapis.com/auth/devstorage.read_write') + """The scopes required for authenticating as a Cloud Storage consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/gcloud/translate/client.html b/latest/_modules/google/cloud/translate/client.html similarity index 72% rename from latest/_modules/gcloud/translate/client.html rename to latest/_modules/google/cloud/translate/client.html index 9eb17a176efc..9e4376d80ce6 100644 --- a/latest/_modules/gcloud/translate/client.html +++ b/latest/_modules/google/cloud/translate/client.html @@ -1,102 +1,257 @@ + + + + + + + + + + google.cloud.translate.client — google-cloud 92219b8 documentation + + + + + - - - - - gcloud.translate.client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + -
    + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.translate.client
    • +
    • -

      Source code for gcloud.translate.client

      +          
      +        
      +      
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.translate.client

     # Copyright 2016 Google Inc. All rights reserved.
     #
     # Licensed under the Apache License, Version 2.0 (the "License");
    @@ -117,15 +272,15 @@ 

    Source code for gcloud.translate.client

     import httplib2
     import six
     
    -from gcloud._helpers import _to_bytes
    -from gcloud.translate.connection import Connection
    +from google.cloud._helpers import _to_bytes
    +from google.cloud.translate.connection import Connection
     
     
     ENGLISH_ISO_639 = 'en'
     """ISO 639-1 language code for English."""
     
     
    -
    [docs]class Client(object): +
    [docs]class Client(object): """Client to bundle configuration needed for API requests. :type api_key: str @@ -149,7 +304,7 @@

    Source code for gcloud.translate.client

             self.connection = Connection(http=http)
             self.target_language = target_language
     
    -
    [docs] def get_languages(self, target_language=None): +
    [docs] def get_languages(self, target_language=None): """Get list of supported languages for translation. Response @@ -178,7 +333,7 @@

    Source code for gcloud.translate.client

                 method='GET', path='/languages', query_params=query_params)
             return response.get('data', {}).get('languages', ())
    -
    [docs] def detect_language(self, values): +
    [docs] def detect_language(self, values): """Detect the language of a string or list of strings. See: https://cloud.google.com/translate/v2/\ @@ -244,7 +399,7 @@

    Source code for gcloud.translate.client

             else:
                 return detections
    -
    [docs] def translate(self, values, target_language=None, format_=None, +
    [docs] def translate(self, values, target_language=None, format_=None, source_language=None, customization_ids=()): """Translate a string or list of strings. @@ -323,123 +478,62 @@

    Source code for gcloud.translate.client

                 return translations
    -
    -
    +
    +
    + - - - +
    + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/translate/connection.html b/latest/_modules/google/cloud/translate/connection.html new file mode 100644 index 000000000000..5e1b93891455 --- /dev/null +++ b/latest/_modules/google/cloud/translate/connection.html @@ -0,0 +1,345 @@ + + + + + + + + + + + google.cloud.translate.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.translate.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.translate.connection

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Create / interact with Google Cloud Translate connections."""
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Translate via the JSON REST API.""" + + API_BASE_URL = 'https://www.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v2' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/language/translate/{api_version}{path}' + """A template for the URL of a particular API call."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/vision/client.html b/latest/_modules/google/cloud/vision/client.html new file mode 100644 index 000000000000..58434109ec0f --- /dev/null +++ b/latest/_modules/google/cloud/vision/client.html @@ -0,0 +1,424 @@ + + + + + + + + + + + google.cloud.vision.client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +

    Source code for google.cloud.vision.client

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Client for interacting with the Google Cloud Vision API."""
    +
    +
    +from google.cloud.client import JSONClient
    +from google.cloud.vision.connection import Connection
    +from google.cloud.vision.feature import Feature
    +from google.cloud.vision.image import Image
    +
    +
    +
    [docs]class VisionRequest(object): + """Request container with image and features information to annotate. + + :type features: list of :class:`gcoud.vision.feature.Feature`. + :param features: The features that dictate which annotations to run. + + :type image: bytes + :param image: Either Google Cloud Storage URI or raw byte stream of image. + """ + def __init__(self, image, features): + self._features = [] + self._image = image + + if isinstance(features, list): + self._features.extend(features) + elif isinstance(features, Feature): + self._features.append(features) + else: + raise TypeError('Feature or list of Feature classes are required.') + +
    [docs] def as_dict(self): + """Dictionary representation of Image.""" + return { + 'image': self.image.as_dict(), + 'features': [feature.as_dict() for feature in self.features] + }
    + + @property + def features(self): + """List of Feature objects.""" + return self._features + + @property + def image(self): + """Image object containing image content.""" + return self._image
    + + +
    [docs]class Client(JSONClient): + """Client to bundle configuration needed for API requests. + + :type project: str + :param project: the project which the client acts on behalf of. + If not passed, falls back to the default inferred + from the environment. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` or + :class:`NoneType` + :param credentials: The OAuth2 Credentials to use for the connection + owned by this client. If not passed (and if no ``http`` + object is passed), falls back to the default inferred + from the environment. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: An optional HTTP object to make requests. If not passed, an + ``http`` object is created that is bound to the + ``credentials`` for the current object. + """ + + _connection_class = Connection + +
    [docs] def annotate(self, image, features): + """Annotate an image to discover it's attributes. + + :type image: str + :param image: A string which can be a URL, a Google Cloud Storage path, + or a byte stream of the image. + + :type features: list of :class:`google.cloud.vision.feature.Feature` + :param features: The type of detection that the Vision API should + use to determine image attributes. Pricing is + based on the number of Feature Types. + + See: https://cloud.google.com/vision/docs/pricing + :rtype: dict + :returns: List of annotations. + """ + img = Image(image, self) + request = VisionRequest(img, features) + + data = {'requests': [request.as_dict()]} + response = self.connection.api_request(method='POST', + path='/images:annotate', + data=data) + + return response['responses'][0]
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/vision/connection.html b/latest/_modules/google/cloud/vision/connection.html new file mode 100644 index 000000000000..5d3f9787a9ab --- /dev/null +++ b/latest/_modules/google/cloud/vision/connection.html @@ -0,0 +1,362 @@ + + + + + + + + + + + google.cloud.vision.connection — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Module code »
    • + +
    • google.cloud.vision.connection
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    Source code for google.cloud.vision.connection

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +
    +"""Create / interact with Google Cloud Vision connections."""
    +
    +
    +from google.cloud import connection as base_connection
    +
    +
    +
    [docs]class Connection(base_connection.JSONConnection): + """A connection to Google Cloud Vision via the JSON REST API. + + :type credentials: :class:`oauth2client.client.OAuth2Credentials` + :param credentials: (Optional) The OAuth2 Credentials to use for this + connection. + + :type http: :class:`httplib2.Http` or class that defines ``request()``. + :param http: (Optional) HTTP object to make requests. + + :type api_base_url: string + :param api_base_url: The base of the API call URL. Defaults to the value + :attr:`Connection.API_BASE_URL`. + """ + + API_BASE_URL = 'https://vision.googleapis.com' + """The base of the API call URL.""" + + API_VERSION = 'v1' + """The version of the API, used in building the API call's URL.""" + + API_URL_TEMPLATE = '{api_base_url}/{api_version}{path}' + """A template for the URL of a particular API call.""" + + SCOPE = ('https://www.googleapis.com/auth/cloud-platform',) + """The scopes required for authenticating as a Cloud Vision consumer."""
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/vision/feature.html b/latest/_modules/google/cloud/vision/feature.html new file mode 100644 index 000000000000..73b458e78e05 --- /dev/null +++ b/latest/_modules/google/cloud/vision/feature.html @@ -0,0 +1,383 @@ + + + + + + + + + + + google.cloud.vision.feature — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +

    Source code for google.cloud.vision.feature

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Feature represenging various types of annotating."""
    +
    +
    +
    [docs]class FeatureTypes(object): + """Feature Types to indication which annotations to perform. + + See: + https://cloud.google.com/vision/reference/rest/v1/images/annotate#Type + """ + FACE_DETECTION = 'FACE_DETECTION' + LANDMARK_DETECTION = 'LANDMARK_DETECTION' + LOGO_DETECTION = 'LOGO_DETECTION' + LABEL_DETECTION = 'LABEL_DETECTION' + TEXT_DETECTION = 'TEXT_DETECTION' + SAFE_SEARCH_DETECTION = 'SAFE_SEARCH_DETECTION'
    + + +
    [docs]class Feature(object): + """Feature object specifying the annotation type and maximum results. + + :type feature_type: str + :param feature_type: String representation of + :class:`google.cloud.vision.feature.FeatureType`. + + :type max_results: int + :param max_results: Number of results to return for the specified + feature type. + + See: + https://cloud.google.com/vision/reference/rest/v1/images/annotate#Feature + """ + def __init__(self, feature_type, max_results=1): + try: + self._feature_type = getattr(FeatureTypes, feature_type) + except AttributeError: + raise AttributeError('Feature type passed in cannot be found.') + self._max_results = int(max_results) + +
    [docs] def as_dict(self): + """Generate dictionary for Feature request format.""" + return { + 'type': self.feature_type, + 'maxResults': self.max_results + }
    + + @property + def feature_type(self): + """"Feature type string.""" + return self._feature_type + + @property + def max_results(self): + """Maximum number of results for feature type.""" + return self._max_results
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/google/cloud/vision/image.html b/latest/_modules/google/cloud/vision/image.html new file mode 100644 index 000000000000..fbf73a4d1f6d --- /dev/null +++ b/latest/_modules/google/cloud/vision/image.html @@ -0,0 +1,381 @@ + + + + + + + + + + + google.cloud.vision.image — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +

    Source code for google.cloud.vision.image

    +# Copyright 2016 Google Inc. All rights reserved.
    +#
    +# Licensed under the Apache License, Version 2.0 (the "License");
    +# you may not use this file except in compliance with the License.
    +# You may obtain a copy of the License at
    +#
    +#     http://www.apache.org/licenses/LICENSE-2.0
    +#
    +# Unless required by applicable law or agreed to in writing, software
    +# distributed under the License is distributed on an "AS IS" BASIS,
    +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    +# See the License for the specific language governing permissions and
    +# limitations under the License.
    +
    +"""Image represented by either a URI or byte stream."""
    +
    +
    +from base64 import b64encode
    +
    +from google.cloud._helpers import _to_bytes
    +from google.cloud._helpers import _bytes_to_unicode
    +
    +
    +
    [docs]class Image(object): + """Image representation containing information to be annotate. + + :type image_source: str + :param image_source: A string which can a Google Cloud Storage URI, or + a byte stream of the image. + + :type client: :class:`Client` + :param client: Instance of Vision client. + """ + + def __init__(self, image_source, client): + self.client = client + self._content = None + self._source = None + + if _bytes_to_unicode(image_source).startswith('gs://'): + self._source = image_source + else: + self._content = b64encode(_to_bytes(image_source)) + +
    [docs] def as_dict(self): + """Generate dictionary structure for request""" + if self.content: + return { + 'content': self.content + } + else: + return { + 'source': { + 'gcs_image_uri': self.source + } + }
    + + @property + def content(self): + """Base64 encoded image content""" + return self._content + + @property + def source(self): + """Google Cloud Storage URI""" + return self._source
    +
    + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_modules/index.html b/latest/_modules/index.html index a35b847b80a1..3c31fb509e25 100644 --- a/latest/_modules/index.html +++ b/latest/_modules/index.html @@ -1,176 +1,88 @@ + + + + + + + + + + Overview: module code — google-cloud 92219b8 documentation + + + + + - - - - - Overview: module code — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + -
    + + +
    + + + +
    + + + + + + +
    +
    + + + - - - + + +
    +
      +
    • Docs »
    • + +
    • Overview: module code
    • +
    • + + + +
    • +
    +
    +
    +
    +
    + +

    All modules for which code is available

    + + +
    +
    + + +
    +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/_sources/bigquery-client.txt b/latest/_sources/bigquery-client.txt index 2dbb17c02ed9..a1c41f689ce4 100644 --- a/latest/_sources/bigquery-client.txt +++ b/latest/_sources/bigquery-client.txt @@ -1,13 +1,13 @@ BigQuery Client =============== -.. automodule:: gcloud.bigquery.client +.. automodule:: google.cloud.bigquery.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.bigquery.connection +.. automodule:: google.cloud.bigquery.connection :members: :show-inheritance: diff --git a/latest/_sources/bigquery-dataset.txt b/latest/_sources/bigquery-dataset.txt index 7ea68c97c4e8..dd1d05352918 100644 --- a/latest/_sources/bigquery-dataset.txt +++ b/latest/_sources/bigquery-dataset.txt @@ -1,6 +1,6 @@ Datasets ~~~~~~~~ -.. automodule:: gcloud.bigquery.dataset +.. automodule:: google.cloud.bigquery.dataset :members: :show-inheritance: diff --git a/latest/_sources/bigquery-job.txt b/latest/_sources/bigquery-job.txt index 3af44e9da0a3..7745a1ceb13a 100644 --- a/latest/_sources/bigquery-job.txt +++ b/latest/_sources/bigquery-job.txt @@ -1,6 +1,6 @@ Jobs ~~~~ -.. automodule:: gcloud.bigquery.job +.. automodule:: google.cloud.bigquery.job :members: :show-inheritance: diff --git a/latest/_sources/bigquery-query.txt b/latest/_sources/bigquery-query.txt index 735964725327..d8b9da09cde0 100644 --- a/latest/_sources/bigquery-query.txt +++ b/latest/_sources/bigquery-query.txt @@ -1,6 +1,6 @@ Query ~~~~~ -.. automodule:: gcloud.bigquery.query +.. automodule:: google.cloud.bigquery.query :members: :show-inheritance: diff --git a/latest/_sources/bigquery-schema.txt b/latest/_sources/bigquery-schema.txt new file mode 100644 index 000000000000..c8bf3edc18c3 --- /dev/null +++ b/latest/_sources/bigquery-schema.txt @@ -0,0 +1,7 @@ +Schemas +~~~~~~~ + +.. automodule:: google.cloud.bigquery.schema + :members: + :show-inheritance: + diff --git a/latest/_sources/bigquery-table.txt b/latest/_sources/bigquery-table.txt index 63297bb471fd..713f6116c932 100644 --- a/latest/_sources/bigquery-table.txt +++ b/latest/_sources/bigquery-table.txt @@ -1,6 +1,6 @@ Tables ~~~~~~ -.. automodule:: gcloud.bigquery.table +.. automodule:: google.cloud.bigquery.table :members: :show-inheritance: diff --git a/latest/_sources/bigquery-usage.txt b/latest/_sources/bigquery-usage.txt index 6ff904da5876..d8050affe145 100644 --- a/latest/_sources/bigquery-usage.txt +++ b/latest/_sources/bigquery-usage.txt @@ -4,25 +4,25 @@ Using the API Authentication / Configuration ------------------------------ -- Use :class:`Client ` objects to configure +- Use :class:`Client ` objects to configure your applications. -- :class:`Client ` objects hold both a ``project`` +- :class:`Client ` objects hold both a ``project`` and an authenticated connection to the BigQuery service. - The authentication credentials can be implicitly determined from the environment or directly via - :meth:`from_service_account_json ` + :meth:`from_service_account_json ` and - :meth:`from_service_account_p12 `. + :meth:`from_service_account_p12 `. - After setting :envvar:`GOOGLE_APPLICATION_CREDENTIALS` and - :envvar:`GCLOUD_PROJECT` environment variables, create an instance of - :class:`Client `. + :envvar:`GOOGLE_CLOUD_PROJECT` environment variables, create an instance of + :class:`Client `. .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() @@ -41,7 +41,7 @@ To override the project inferred from the environment, pass an explicit .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client(project='PROJECT_ID') @@ -103,7 +103,7 @@ Replace the ACL for a dataset, and update all writeable fields: .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() >>> dataset = client.dataset('dataset_name') >>> dataset.get() # API request @@ -232,7 +232,7 @@ Background a query, loading the results into a table: .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() >>> query = """\ SELECT firstname + ' ' + last_name AS full_name, @@ -242,7 +242,7 @@ Background a query, loading the results into a table: >>> dataset = client.dataset('dataset_name') >>> table = dataset.table(name='person_ages') >>> job = client.run_async_query('fullname-age-query-job', query) - >>> job.destination_table = table + >>> job.destination = table >>> job.write_disposition= 'truncate' >>> job.name 'fullname-age-query-job' @@ -255,7 +255,7 @@ Background a query, loading the results into a table: .. note:: - - ``gcloud.bigquery`` generates a UUID for each job. + - ``google.cloud.bigquery`` generates a UUID for each job. - The ``created`` and ``state`` fields are not set until the job is submitted to the BigQuery back-end. @@ -267,7 +267,7 @@ Then, begin executing the job on the server: >>> job.created datetime.datetime(2015, 7, 23, 9, 30, 20, 268260, tzinfo=) >>> job.state - 'running' + 'RUNNING' Poll until the job is complete: @@ -275,7 +275,7 @@ Poll until the job is complete: >>> import time >>> retry_count = 100 - >>> while retry_count > 0 and job.state == 'running': + >>> while retry_count > 0 and job.state != 'DONE': ... retry_count -= 1 ... time.sleep(10) ... job.reload() # API call @@ -294,8 +294,8 @@ the job locally: .. doctest:: - >>> from gcloud import bigquery - >>> from gcloud.bigquery import SchemaField + >>> from google.cloud import bigquery + >>> from google.cloud.bigquery import SchemaField >>> client = bigquery.Client() >>> table = dataset.table(name='person_ages') >>> table.schema = [ @@ -317,7 +317,7 @@ the job locally: .. note:: - - ``gcloud.bigquery`` generates a UUID for each job. + - ``google.cloud.bigquery`` generates a UUID for each job. - The ``created`` and ``state`` fields are not set until the job is submitted to the BigQuery back-end. @@ -329,7 +329,7 @@ Then, begin executing the job on the server: >>> job.created datetime.datetime(2015, 7, 23, 9, 30, 20, 268260, tzinfo=) >>> job.state - 'running' + 'RUNNING' Poll until the job is complete: @@ -337,7 +337,7 @@ Poll until the job is complete: >>> import time >>> retry_count = 100 - >>> while retry_count > 0 and job.state == 'running': + >>> while retry_count > 0 and job.state != 'DONE': ... retry_count -= 1 ... time.sleep(10) ... job.reload() # API call @@ -355,7 +355,7 @@ located on Google Cloud Storage. First, create the job locally: .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() >>> table = dataset.table(name='person_ages') >>> job = client.extract_table_to_storage( @@ -375,7 +375,7 @@ located on Google Cloud Storage. First, create the job locally: .. note:: - - ``gcloud.bigquery`` generates a UUID for each job. + - ``google.cloud.bigquery`` generates a UUID for each job. - The ``created`` and ``state`` fields are not set until the job is submitted to the BigQuery back-end. @@ -387,7 +387,7 @@ Then, begin executing the job on the server: >>> job.created datetime.datetime(2015, 7, 23, 9, 30, 20, 268260, tzinfo=) >>> job.state - 'running' + 'RUNNING' Poll until the job is complete: @@ -395,7 +395,7 @@ Poll until the job is complete: >>> import time >>> retry_count = 100 - >>> while retry_count > 0 and job.state == 'running': + >>> while retry_count > 0 and job.state != 'DONE': ... retry_count -= 1 ... time.sleep(10) ... job.reload() # API call @@ -412,7 +412,7 @@ First, create the job locally: .. doctest:: - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() >>> source_table = dataset.table(name='person_ages') >>> destination_table = dataset.table(name='person_ages_copy') @@ -429,7 +429,7 @@ First, create the job locally: .. note:: - - ``gcloud.bigquery`` generates a UUID for each job. + - ``google.cloud.bigquery`` generates a UUID for each job. - The ``created`` and ``state`` fields are not set until the job is submitted to the BigQuery back-end. @@ -441,7 +441,7 @@ Then, begin executing the job on the server: >>> job.created datetime.datetime(2015, 7, 23, 9, 30, 20, 268260, tzinfo=) >>> job.state - 'running' + 'RUNNING' Poll until the job is complete: @@ -449,7 +449,7 @@ Poll until the job is complete: >>> import time >>> retry_count = 100 - >>> while retry_count > 0 and job.state == 'running': + >>> while retry_count > 0 and job.state != 'DONE': ... retry_count -= 1 ... time.sleep(10) ... job.reload() # API call diff --git a/latest/_sources/bigtable-client-intro.txt b/latest/_sources/bigtable-client-intro.txt index db04ffa0e0c1..fa759481e8ba 100644 --- a/latest/_sources/bigtable-client-intro.txt +++ b/latest/_sources/bigtable-client-intro.txt @@ -1,59 +1,51 @@ Base for Everything =================== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -To use the API, the :class:`Client ` +To use the API, the :class:`Client ` class defines a high-level interface which handles authorization and creating other objects: .. code:: python - from gcloud.bigtable.client import Client + from google.cloud.bigtable.client import Client client = Client() Long-lived Defaults ------------------- -When creating a :class:`Client `, the -``user_agent`` and ``timeout_seconds`` arguments have sensible -defaults -(:data:`DEFAULT_USER_AGENT ` and -:data:`DEFAULT_TIMEOUT_SECONDS `). -However, you may over-ride them and these will be used throughout all API +When creating a :class:`Client `, the +``user_agent`` argument has sensible a default +(:data:`DEFAULT_USER_AGENT `). +However, you may over-ride it and the value will be used throughout all API requests made with the ``client`` you create. Configuration ------------- -- For an overview of authentication in ``gcloud-python``, +- For an overview of authentication in ``google-cloud-python``, see :doc:`gcloud-auth`. - In addition to any authentication configuration, you can also set the - :envvar:`GCLOUD_PROJECT` environment variable for the Google Cloud Console + :envvar:`GOOGLE_CLOUD_PROJECT` environment variable for the Google Cloud Console project you'd like to interact with. If your code is running in Google App Engine or Google Compute Engine the project will be detected automatically. (Setting this environment variable is not required, you may instead pass the ``project`` explicitly when constructing a - :class:`Client `). + :class:`Client `). - After configuring your environment, create a - :class:`Client ` + :class:`Client ` .. code:: - >>> from gcloud import bigtable + >>> from google.cloud import bigtable >>> client = bigtable.Client() or pass in ``credentials`` and ``project`` explicitly .. code:: - >>> from gcloud import bigtable + >>> from google.cloud import bigtable >>> client = bigtable.Client(project='my-project', credentials=creds) .. tip:: @@ -81,15 +73,15 @@ you can pass the ``read_only`` argument: client = bigtable.Client(read_only=True) This will ensure that the -:data:`READ_ONLY_SCOPE ` is used +:data:`READ_ONLY_SCOPE ` is used for API requests (so any accidental requests that would modify data will fail). Next Step --------- -After a :class:`Client `, the next highest-level -object is a :class:`Instance `. You'll need +After a :class:`Client `, the next highest-level +object is a :class:`Instance `. You'll need one before you can interact with tables or data. Head next to learn about the :doc:`bigtable-instance-api`. diff --git a/latest/_sources/bigtable-client.txt b/latest/_sources/bigtable-client.txt index 97dc99f1d177..c48595c8ac0b 100644 --- a/latest/_sources/bigtable-client.txt +++ b/latest/_sources/bigtable-client.txt @@ -1,12 +1,6 @@ Client ~~~~~~ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.client +.. automodule:: google.cloud.bigtable.client :members: :show-inheritance: diff --git a/latest/_sources/bigtable-cluster.txt b/latest/_sources/bigtable-cluster.txt index f2986b820253..ad33aae5e0b8 100644 --- a/latest/_sources/bigtable-cluster.txt +++ b/latest/_sources/bigtable-cluster.txt @@ -1,12 +1,6 @@ Cluster ~~~~~~~ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.cluster +.. automodule:: google.cloud.bigtable.cluster :members: :show-inheritance: diff --git a/latest/_sources/bigtable-column-family.txt b/latest/_sources/bigtable-column-family.txt index 10eb6307dc56..de6c1eb1f5df 100644 --- a/latest/_sources/bigtable-column-family.txt +++ b/latest/_sources/bigtable-column-family.txt @@ -1,14 +1,8 @@ Column Families =============== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - When creating a -:class:`ColumnFamily `, it is +:class:`ColumnFamily `, it is possible to set garbage collection rules for expired data. By setting a rule, cells in the table matching the rule will be deleted @@ -16,19 +10,19 @@ during periodic garbage collection (which executes opportunistically in the background). The types -:class:`MaxAgeGCRule `, -:class:`MaxVersionsGCRule `, -:class:`GarbageCollectionRuleUnion ` and -:class:`GarbageCollectionRuleIntersection ` +:class:`MaxAgeGCRule `, +:class:`MaxVersionsGCRule `, +:class:`GarbageCollectionRuleUnion ` and +:class:`GarbageCollectionRuleIntersection ` can all be used as the optional ``gc_rule`` argument in the -:class:`ColumnFamily ` +:class:`ColumnFamily ` constructor. This value is then used in the -:meth:`create() ` and -:meth:`update() ` methods. +:meth:`create() ` and +:meth:`update() ` methods. These rules can be nested arbitrarily, with a -:class:`MaxAgeGCRule ` or -:class:`MaxVersionsGCRule ` +:class:`MaxAgeGCRule ` or +:class:`MaxVersionsGCRule ` at the lowest level of the nesting: .. code:: python @@ -50,6 +44,6 @@ at the lowest level of the nesting: ---- -.. automodule:: gcloud.bigtable.column_family +.. automodule:: google.cloud.bigtable.column_family :members: :show-inheritance: diff --git a/latest/_sources/bigtable-data-api.txt b/latest/_sources/bigtable-data-api.txt index 13ffd706b373..78cc10b0f485 100644 --- a/latest/_sources/bigtable-data-api.txt +++ b/latest/_sources/bigtable-data-api.txt @@ -1,13 +1,7 @@ Data API ======== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -After creating a :class:`Table ` and some +After creating a :class:`Table ` and some column families, you are ready to store and retrieve data. Cells vs. Columns vs. Column Families @@ -33,7 +27,7 @@ Modifying Data Since data is stored in cells, which are stored in rows, we use the metaphor of a **row** in classes that are used to modify (write, update, delete) data in a -:class:`Table `. +:class:`Table `. Direct vs. Conditional vs. Append --------------------------------- @@ -44,26 +38,26 @@ methods. * The **direct** way is via `MutateRow`_ which involves simply adding, overwriting or deleting cells. The - :class:`DirectRow ` class + :class:`DirectRow ` class handles direct mutations. * The **conditional** way is via `CheckAndMutateRow`_. This method first checks if some filter is matched in a a given row, then applies one of two sets of mutations, depending on if a match occurred or not. (These mutation sets are called the "true mutations" and "false mutations".) The - :class:`ConditionalRow ` class + :class:`ConditionalRow ` class handles conditional mutations. * The **append** way is via `ReadModifyWriteRow`_. This simply appends (as bytes) or increments (as an integer) data in a presumed existing cell in a row. The - :class:`AppendRow ` class + :class:`AppendRow ` class handles append mutations. Row Factory ----------- A single factory can be used to create any of the three row types. -To create a :class:`DirectRow `: +To create a :class:`DirectRow `: .. code:: python @@ -72,15 +66,15 @@ To create a :class:`DirectRow `: Unlike the previous string values we've used before, the row key must be ``bytes``. -To create a :class:`ConditionalRow `, -first create a :class:`RowFilter ` and +To create a :class:`ConditionalRow `, +first create a :class:`RowFilter ` and then .. code:: python cond_row = table.row(row_key, filter_=filter_) -To create an :class:`AppendRow ` +To create an :class:`AppendRow ` .. code:: python @@ -101,7 +95,7 @@ Direct Mutations Direct mutations can be added via one of four methods -* :meth:`set_cell() ` allows a +* :meth:`set_cell() ` allows a single value to be written to a column .. code:: python @@ -115,7 +109,7 @@ Direct mutations can be added via one of four methods The value can either by bytes or an integer (which will be converted to bytes as a signed 64-bit integer). -* :meth:`delete_cell() ` deletes +* :meth:`delete_cell() ` deletes all cells (i.e. for all timestamps) in a given column .. code:: python @@ -125,7 +119,7 @@ Direct mutations can be added via one of four methods Remember, this only happens in the ``row`` we are using. If we only want to delete cells from a limited range of time, a - :class:`TimestampRange ` can + :class:`TimestampRange ` can be used .. code:: python @@ -133,9 +127,9 @@ Direct mutations can be added via one of four methods row.delete_cell(column_family_id, column, time_range=time_range) -* :meth:`delete_cells() ` does +* :meth:`delete_cells() ` does the same thing as - :meth:`delete_cell() ` + :meth:`delete_cell() ` but accepts a list of columns in a column family rather than a single one. .. code:: python @@ -144,7 +138,7 @@ Direct mutations can be added via one of four methods time_range=time_range) In addition, if we want to delete cells from every column in a column family, - the special :attr:`ALL_COLUMNS ` + the special :attr:`ALL_COLUMNS ` value can be used .. code:: python @@ -152,7 +146,7 @@ Direct mutations can be added via one of four methods row.delete_cells(column_family_id, row.ALL_COLUMNS, time_range=time_range) -* :meth:`delete() ` will delete the +* :meth:`delete() ` will delete the entire row .. code:: python @@ -183,14 +177,14 @@ Append Mutations Append mutations can be added via one of two methods -* :meth:`append_cell_value() ` +* :meth:`append_cell_value() ` appends a bytes value to an existing cell: .. code:: python append_row.append_cell_value(column_family_id, column, bytes_value) -* :meth:`increment_cell_value() ` +* :meth:`increment_cell_value() ` increments an integer value in an existing cell: .. code:: python @@ -223,7 +217,7 @@ Read Single Row from a Table ---------------------------- To make a `ReadRows`_ API request for a single row key, use -:meth:`Table.read_row() `: +:meth:`Table.read_row() `: .. code:: python @@ -232,34 +226,34 @@ To make a `ReadRows`_ API request for a single row key, use { u'fam1': { b'col1': [ - , - , + , + , ], b'col2': [ - , + , ], }, u'fam2': { b'col3': [ - , - , - , + , + , + , ], }, } >>> cell = row_data.cells[u'fam1'][b'col1'][0] >>> cell - + >>> cell.value b'val1' >>> cell.timestamp datetime.datetime(2016, 2, 27, 3, 41, 18, 122823, tzinfo=) -Rather than returning a :class:`DirectRow ` +Rather than returning a :class:`DirectRow ` or similar class, this method returns a -:class:`PartialRowData ` +:class:`PartialRowData ` instance. This class is used for reading and parsing data rather than for -modifying data (as :class:`DirectRow ` is). +modifying data (as :class:`DirectRow ` is). A filter can also be applied to the results: @@ -268,15 +262,15 @@ A filter can also be applied to the results: row_data = table.read_row(row_key, filter_=filter_val) The allowable ``filter_`` values are the same as those used for a -:class:`ConditionalRow `. For +:class:`ConditionalRow `. For more information, see the -:meth:`Table.read_row() ` documentation. +:meth:`Table.read_row() ` documentation. Stream Many Rows from a Table ----------------------------- To make a `ReadRows`_ API request for a stream of rows, use -:meth:`Table.read_rows() `: +:meth:`Table.read_rows() `: .. code:: python @@ -285,32 +279,32 @@ To make a `ReadRows`_ API request for a stream of rows, use Using gRPC over HTTP/2, a continual stream of responses will be delivered. In particular -* :meth:`consume_next() ` +* :meth:`consume_next() ` pulls the next result from the stream, parses it and stores it on the - :class:`PartialRowsData ` instance -* :meth:`consume_all() ` + :class:`PartialRowsData ` instance +* :meth:`consume_all() ` pulls results from the stream until there are no more -* :meth:`cancel() ` closes +* :meth:`cancel() ` closes the stream -See the :class:`PartialRowsData ` +See the :class:`PartialRowsData ` documentation for more information. As with -:meth:`Table.read_row() `, an optional +:meth:`Table.read_row() `, an optional ``filter_`` can be applied. In addition a ``start_key`` and / or ``end_key`` can be supplied for the stream, a ``limit`` can be set and a boolean ``allow_row_interleaving`` can be specified to allow faster streamed results at the potential cost of non-sequential reads. -See the :meth:`Table.read_rows() ` +See the :meth:`Table.read_rows() ` documentation for more information on the optional arguments. Sample Keys in a Table ---------------------- Make a `SampleRowKeys`_ API request with -:meth:`Table.sample_row_keys() `: +:meth:`Table.sample_row_keys() `: .. code:: python @@ -321,7 +315,7 @@ approximately equal size, which can be used to break up the data for distributed tasks like mapreduces. As with -:meth:`Table.read_rows() `, the +:meth:`Table.read_rows() `, the returned ``keys_iterator`` is connected to a cancellable HTTP/2 stream. The next key in the result can be accessed via diff --git a/latest/_sources/bigtable-instance-api.txt b/latest/_sources/bigtable-instance-api.txt index 4d03fa7b1b97..18a772a59b09 100644 --- a/latest/_sources/bigtable-instance-api.txt +++ b/latest/_sources/bigtable-instance-api.txt @@ -1,13 +1,7 @@ Instance Admin API ================== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -After creating a :class:`Client `, you can +After creating a :class:`Client `, you can interact with individual instances for a project. List Instances @@ -15,7 +9,7 @@ List Instances If you want a comprehensive list of all existing instances, make a `ListInstances`_ API request with -:meth:`Client.list_instances() `: +:meth:`Client.list_instances() `: .. code:: python @@ -24,7 +18,7 @@ If you want a comprehensive list of all existing instances, make a Instance Factory ---------------- -To create a :class:`Instance ` object: +To create a :class:`Instance ` object: .. code:: python @@ -51,7 +45,7 @@ Create a new Instance --------------------- After creating the instance object, make a `CreateInstance`_ API request -with :meth:`create() `: +with :meth:`create() `: .. code:: python @@ -65,14 +59,14 @@ Check on Current Operation When modifying a instance (via a `CreateInstance`_ request), the Bigtable API will return a `long-running operation`_ and a corresponding - :class:`Operation ` object + :class:`Operation ` object will be returned by - :meth:`create() `. + :meth:`create() `. You can check if a long-running operation (for a -:meth:`create() ` has finished +:meth:`create() ` has finished by making a `GetOperation`_ request with -:meth:`Operation.finished() `: +:meth:`Operation.finished() `: .. code:: python @@ -82,18 +76,18 @@ by making a `GetOperation`_ request with .. note:: - Once an :class:`Operation ` object + Once an :class:`Operation ` object has returned :data:`True` from - :meth:`finished() `, the + :meth:`finished() `, the object should not be re-used. Subsequent calls to - :meth:`finished() ` + :meth:`finished() ` will result in a :class:`ValueError `. Get metadata for an existing Instance ------------------------------------- After creating the instance object, make a `GetInstance`_ API request -with :meth:`reload() `: +with :meth:`reload() `: .. code:: python @@ -105,7 +99,7 @@ Update an existing Instance --------------------------- After creating the instance object, make an `UpdateInstance`_ API request -with :meth:`update() `: +with :meth:`update() `: .. code:: python @@ -116,7 +110,7 @@ Delete an existing Instance --------------------------- Make a `DeleteInstance`_ API request with -:meth:`delete() `: +:meth:`delete() `: .. code:: python @@ -126,8 +120,8 @@ Next Step --------- Now we go down the hierarchy from -:class:`Instance ` to a -:class:`Table `. +:class:`Instance ` to a +:class:`Table `. Head next to learn about the :doc:`bigtable-table-api`. diff --git a/latest/_sources/bigtable-instance.txt b/latest/_sources/bigtable-instance.txt index 7ba1c15d8df3..f9be9672fc64 100644 --- a/latest/_sources/bigtable-instance.txt +++ b/latest/_sources/bigtable-instance.txt @@ -1,12 +1,6 @@ Instance ~~~~~~~~ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.instance +.. automodule:: google.cloud.bigtable.instance :members: :show-inheritance: diff --git a/latest/_sources/bigtable-row-data.txt b/latest/_sources/bigtable-row-data.txt index 1d45bb5f2962..503f9b1cbdfd 100644 --- a/latest/_sources/bigtable-row-data.txt +++ b/latest/_sources/bigtable-row-data.txt @@ -1,12 +1,6 @@ Row Data ~~~~~~~~ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.row_data +.. automodule:: google.cloud.bigtable.row_data :members: :show-inheritance: diff --git a/latest/_sources/bigtable-row-filters.txt b/latest/_sources/bigtable-row-filters.txt index 1b03ef7ef59a..4a0112f2f519 100644 --- a/latest/_sources/bigtable-row-filters.txt +++ b/latest/_sources/bigtable-row-filters.txt @@ -1,18 +1,12 @@ Bigtable Row Filters ==================== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - It is possible to use a -:class:`RowFilter ` +:class:`RowFilter ` when adding mutations to a -:class:`ConditionalRow ` and when -reading row data with :meth:`read_row() ` -:meth:`read_rows() `. +:class:`ConditionalRow ` and when +reading row data with :meth:`read_row() ` +:meth:`read_rows() `. As laid out in the `RowFilter definition`_, the following basic filters are provided: @@ -66,7 +60,7 @@ level. For example: ---- -.. automodule:: gcloud.bigtable.row_filters +.. automodule:: google.cloud.bigtable.row_filters :members: :show-inheritance: diff --git a/latest/_sources/bigtable-row.txt b/latest/_sources/bigtable-row.txt index e5c95728fb42..33686608b363 100644 --- a/latest/_sources/bigtable-row.txt +++ b/latest/_sources/bigtable-row.txt @@ -1,13 +1,7 @@ Bigtable Row ============ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.row +.. automodule:: google.cloud.bigtable.row :members: :show-inheritance: :inherited-members: diff --git a/latest/_sources/bigtable-table-api.txt b/latest/_sources/bigtable-table-api.txt index 554b157031f9..0d5edcd64bf2 100644 --- a/latest/_sources/bigtable-table-api.txt +++ b/latest/_sources/bigtable-table-api.txt @@ -1,13 +1,7 @@ Table Admin API =============== -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -After creating a :class:`Instance `, you can +After creating a :class:`Instance `, you can interact with individual tables, groups of tables or column families within a table. @@ -16,33 +10,33 @@ List Tables If you want a comprehensive list of all existing tables in a instance, make a `ListTables`_ API request with -:meth:`Instance.list_tables() `: +:meth:`Instance.list_tables() `: .. code:: python >>> instance.list_tables() - [, - ] + [, + ] Table Factory ------------- -To create a :class:`Table ` object: +To create a :class:`Table ` object: .. code:: python table = instance.table(table_id) -Even if this :class:`Table ` already +Even if this :class:`Table ` already has been created with the API, you'll want this object to use as a -parent of a :class:`ColumnFamily ` -or :class:`Row `. +parent of a :class:`ColumnFamily ` +or :class:`Row `. Create a new Table ------------------ After creating the table object, make a `CreateTable`_ API request -with :meth:`create() `: +with :meth:`create() `: .. code:: python @@ -59,7 +53,7 @@ Delete an existing Table ------------------------ Make a `DeleteTable`_ API request with -:meth:`delete() `: +:meth:`delete() `: .. code:: python @@ -73,7 +67,7 @@ associated with a table, the `GetTable`_ API method returns a table object with the names of the column families. To retrieve the list of column families use -:meth:`list_column_families() `: +:meth:`list_column_families() `: .. code:: python @@ -83,7 +77,7 @@ Column Family Factory --------------------- To create a -:class:`ColumnFamily ` object: +:class:`ColumnFamily ` object: .. code:: python @@ -93,7 +87,7 @@ There is no real reason to use this factory unless you intend to create or delete a column family. In addition, you can specify an optional ``gc_rule`` (a -:class:`GarbageCollectionRule ` +:class:`GarbageCollectionRule ` or similar): .. code:: python @@ -105,7 +99,7 @@ This rule helps the backend determine when and how to clean up old cells in the column family. See :doc:`bigtable-column-family` for more information about -:class:`GarbageCollectionRule ` +:class:`GarbageCollectionRule ` and related classes. Create a new Column Family @@ -113,7 +107,7 @@ Create a new Column Family After creating the column family object, make a `CreateColumnFamily`_ API request with -:meth:`ColumnFamily.create() ` +:meth:`ColumnFamily.create() ` .. code:: python @@ -123,7 +117,7 @@ Delete an existing Column Family -------------------------------- Make a `DeleteColumnFamily`_ API request with -:meth:`ColumnFamily.delete() ` +:meth:`ColumnFamily.delete() ` .. code:: python @@ -133,7 +127,7 @@ Update an existing Column Family -------------------------------- Make an `UpdateColumnFamily`_ API request with -:meth:`ColumnFamily.delete() ` +:meth:`ColumnFamily.delete() ` .. code:: python @@ -143,9 +137,9 @@ Next Step --------- Now we go down the final step of the hierarchy from -:class:`Table ` to -:class:`Row ` as well as streaming -data directly via a :class:`Table `. +:class:`Table ` to +:class:`Row ` as well as streaming +data directly via a :class:`Table `. Head next to learn about the :doc:`bigtable-data-api`. diff --git a/latest/_sources/bigtable-table.txt b/latest/_sources/bigtable-table.txt index 414d567bfd03..c230725d1351 100644 --- a/latest/_sources/bigtable-table.txt +++ b/latest/_sources/bigtable-table.txt @@ -1,12 +1,6 @@ Table ~~~~~ -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.table +.. automodule:: google.cloud.bigtable.table :members: :show-inheritance: diff --git a/latest/_sources/bigtable-usage.txt b/latest/_sources/bigtable-usage.txt index 14cadd084f72..157c339d166b 100644 --- a/latest/_sources/bigtable-usage.txt +++ b/latest/_sources/bigtable-usage.txt @@ -1,30 +1,24 @@ Using the API ============= -.. warning:: - - `gRPC`_ is required for using the Cloud Bigtable API. As of May 2016, - `grpcio`_ is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - API requests are sent to the `Google Cloud Bigtable`_ API via RPC over HTTP/2. In order to support this, we'll rely on `gRPC`_. We are working with the gRPC team to rapidly make the install story more user-friendly. Get started by learning about the -:class:`Client ` on the +:class:`Client ` on the :doc:`bigtable-client-intro` page. In the hierarchy of API concepts -* a :class:`Client ` owns a - :class:`Cluster ` -* a :class:`Table ` owns a - :class:`ColumnFamily ` -* a :class:`Table ` owns a - :class:`Row ` +* a :class:`Client ` owns a + :class:`Cluster ` +* a :class:`Table ` owns a + :class:`ColumnFamily ` +* a :class:`Table ` owns a + :class:`Row ` (and all the cells in the row) .. _Google Cloud Bigtable: https://cloud.google.com/bigtable/docs/ diff --git a/latest/_sources/datastore-batches.txt b/latest/_sources/datastore-batches.txt index bf7d5c4ffbcc..4a2b0eb7d761 100644 --- a/latest/_sources/datastore-batches.txt +++ b/latest/_sources/datastore-batches.txt @@ -1,6 +1,6 @@ Batches ~~~~~~~ -.. automodule:: gcloud.datastore.batch +.. automodule:: google.cloud.datastore.batch :members: :show-inheritance: diff --git a/latest/_sources/datastore-client.txt b/latest/_sources/datastore-client.txt index 23c489dd11c6..924fa5d789a5 100644 --- a/latest/_sources/datastore-client.txt +++ b/latest/_sources/datastore-client.txt @@ -1,13 +1,13 @@ Datastore Client ================ -.. automodule:: gcloud.datastore.client +.. automodule:: google.cloud.datastore.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.datastore.connection +.. automodule:: google.cloud.datastore.connection :members: :show-inheritance: diff --git a/latest/_sources/datastore-entities.txt b/latest/_sources/datastore-entities.txt index 6e263ceeda0e..dc8217ddf3ba 100644 --- a/latest/_sources/datastore-entities.txt +++ b/latest/_sources/datastore-entities.txt @@ -1,6 +1,6 @@ Entities ~~~~~~~~ -.. automodule:: gcloud.datastore.entity +.. automodule:: google.cloud.datastore.entity :members: :show-inheritance: diff --git a/latest/_sources/datastore-helpers.txt b/latest/_sources/datastore-helpers.txt index a70e4d2cf534..99f9b9bf28bc 100644 --- a/latest/_sources/datastore-helpers.txt +++ b/latest/_sources/datastore-helpers.txt @@ -1,6 +1,6 @@ Helpers ~~~~~~~ -.. automodule:: gcloud.datastore.helpers +.. automodule:: google.cloud.datastore.helpers :members: :show-inheritance: diff --git a/latest/_sources/datastore-keys.txt b/latest/_sources/datastore-keys.txt index c202471d252d..79f7a7eb4e38 100644 --- a/latest/_sources/datastore-keys.txt +++ b/latest/_sources/datastore-keys.txt @@ -1,6 +1,6 @@ Keys ~~~~ -.. automodule:: gcloud.datastore.key +.. automodule:: google.cloud.datastore.key :members: :show-inheritance: diff --git a/latest/_sources/datastore-queries.txt b/latest/_sources/datastore-queries.txt index 4ffed79925fa..aa9e7dfb7193 100644 --- a/latest/_sources/datastore-queries.txt +++ b/latest/_sources/datastore-queries.txt @@ -1,6 +1,6 @@ Queries ~~~~~~~ -.. automodule:: gcloud.datastore.query +.. automodule:: google.cloud.datastore.query :members: :show-inheritance: diff --git a/latest/_sources/datastore-transactions.txt b/latest/_sources/datastore-transactions.txt index d86d7fd74c71..1737a7bf5994 100644 --- a/latest/_sources/datastore-transactions.txt +++ b/latest/_sources/datastore-transactions.txt @@ -1,7 +1,7 @@ Transactions ~~~~~~~~~~~~ -.. automodule:: gcloud.datastore.transaction +.. automodule:: google.cloud.datastore.transaction :members: :show-inheritance: :inherited-members: diff --git a/latest/_sources/dns-changes.txt b/latest/_sources/dns-changes.txt index 40dc0dddc257..9510ebbcc013 100644 --- a/latest/_sources/dns-changes.txt +++ b/latest/_sources/dns-changes.txt @@ -1,6 +1,6 @@ Change Sets ~~~~~~~~~~~ -.. automodule:: gcloud.dns.changes +.. automodule:: google.cloud.dns.changes :members: :show-inheritance: diff --git a/latest/_sources/dns-client.txt b/latest/_sources/dns-client.txt index e499c2d0eeff..337ac6558859 100644 --- a/latest/_sources/dns-client.txt +++ b/latest/_sources/dns-client.txt @@ -1,13 +1,13 @@ DNS Client ========== -.. automodule:: gcloud.dns.client +.. automodule:: google.cloud.dns.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.dns.connection +.. automodule:: google.cloud.dns.connection :members: :show-inheritance: diff --git a/latest/_sources/dns-resource-record-set.txt b/latest/_sources/dns-resource-record-set.txt index ff46e6c7f1ee..1112d16aaa4f 100644 --- a/latest/_sources/dns-resource-record-set.txt +++ b/latest/_sources/dns-resource-record-set.txt @@ -1,6 +1,6 @@ Resource Record Sets ~~~~~~~~~~~~~~~~~~~~ -.. automodule:: gcloud.dns.resource_record_set +.. automodule:: google.cloud.dns.resource_record_set :members: :show-inheritance: diff --git a/latest/_sources/dns-usage.txt b/latest/_sources/dns-usage.txt index 42bd1d5d8548..d0f5415282fa 100644 --- a/latest/_sources/dns-usage.txt +++ b/latest/_sources/dns-usage.txt @@ -4,18 +4,18 @@ Using the API Client ------ -:class:`Client ` objects provide a means to -configure your DNS applications. Eash instance holds both a ``project`` +:class:`Client ` objects provide a means to +configure your DNS applications. Each instance holds both a ``project`` and an authenticated connection to the DNS service. -For an overview of authentication in ``gcloud-python``, see :doc:`gcloud-auth`. +For an overview of authentication in ``google-cloud-python``, see :doc:`gcloud-auth`. Assuming your environment is set up as described in that document, -create an instance of :class:`Client `. +create an instance of :class:`Client `. .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client() Projects @@ -33,7 +33,7 @@ To override the project inferred from the environment, pass an explicit .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') Project Quotas @@ -43,7 +43,7 @@ Query the quotas for a given project: .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> quotas = client.quotas() # API request >>> for key, value in sorted(quotas.items()): @@ -72,7 +72,7 @@ suffix and has a set of name servers that accept and responds to queries: .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> zone = client.zone('acme-co', 'example.com', ... description='Acme Company zone') @@ -87,7 +87,7 @@ List the zones for a given project: .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> zones = client.list_zones() # API request >>> [zone.name for zone in zones] @@ -101,7 +101,7 @@ Each managed zone exposes a read-only set of resource records: .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> zone = client.zone('acme-co', 'example.com') >>> records, page_token = zone.list_resource_record_sets() # API request @@ -135,7 +135,7 @@ bundling additions to or deletions from the set. .. doctest:: >>> import time - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> zone = client.zone('acme-co', 'example.com') >>> TWO_HOURS = 2 * 60 * 60 # seconds @@ -154,7 +154,7 @@ List changes made to the resource record set for a given zone: .. doctest:: - >>> from gcloud import dns + >>> from google.cloud import dns >>> client = dns.Client(project='PROJECT_ID') >>> zone = client.zone('acme-co', 'example.com') >>> changes = [] diff --git a/latest/_sources/dns-zone.txt b/latest/_sources/dns-zone.txt index 22cb456b56f6..b65081f00a92 100644 --- a/latest/_sources/dns-zone.txt +++ b/latest/_sources/dns-zone.txt @@ -1,6 +1,6 @@ Managed Zones ~~~~~~~~~~~~~ -.. automodule:: gcloud.dns.zone +.. automodule:: google.cloud.dns.zone :members: :show-inheritance: diff --git a/latest/_sources/error-reporting-client.txt b/latest/_sources/error-reporting-client.txt new file mode 100644 index 000000000000..4f4d08a16872 --- /dev/null +++ b/latest/_sources/error-reporting-client.txt @@ -0,0 +1,7 @@ +Error Reporting Client +======================= + +.. automodule:: google.cloud.error_reporting.client + :members: + :show-inheritance: + diff --git a/latest/_sources/error-reporting-usage.txt b/latest/_sources/error-reporting-usage.txt new file mode 100644 index 000000000000..c07c35a9070b --- /dev/null +++ b/latest/_sources/error-reporting-usage.txt @@ -0,0 +1,102 @@ +Using the API +============= + + +Authentication and Configuration +-------------------------------- + +- For an overview of authentication in ``google-cloud-python``, + see :doc:`gcloud-auth`. + +- In addition to any authentication configuration, you should also set the + :envvar:`GOOGLE_CLOUD_PROJECT` environment variable for the project you'd like + to interact with. If you are Google App Engine or Google Compute Engine + this will be detected automatically. + +- After configuring your environment, create a + :class:`Client ` + + .. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client() + + or pass in ``credentials`` and ``project`` explicitly + + .. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client(project='my-project', credentials=creds) + + Error Reporting associates errors with a service, which is an identifier for an executable, + App Engine service, or job. The default service is "python", but a default can be specified + for the client on construction time. You can also optionally specify a version for that service, + which defaults to "default." + + + .. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client(project='my-project', + ... service="login_service", + ... version="0.1.0") + +Reporting an exception +----------------------- + +Report a stacktrace to Stackdriver Error Reporting after an exception + +.. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client() + >>> try: + >>> raise NameError + >>> except Exception: + >>> client.report_exception() + + +By default, the client will report the error using the service specified in the client's +constructor, or the default service of "python". + +The user and HTTP context can also be included in the exception. The HTTP context +can be constructed using :class:`google.cloud.error_reporting.HTTPContext`. This will +be used by Stackdriver Error Reporting to help group exceptions. + +.. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client() + >>> user = 'example@gmail.com' + >>> http_context = HTTPContext(method='GET', url='/', userAgent='test agent', + ... referrer='example.com', responseStatusCode=500, + ... remote_ip='1.2.3.4') + >>> try: + >>> raise NameError + >>> except Exception: + >>> client.report_exception(http_context=http_context, user=user)) + +Reporting an error without an exception +----------------------------------------- + +Errors can also be reported to Stackdriver Error Reporting outside the context of an exception. +The library will include the file path, function name, and line number of the location where the +error was reported. + +.. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client() + >>> error_reporting.report("Found an error!") + +Similarly to reporting an exception, the user and HTTP context can be provided: + +.. doctest:: + + >>> from google.cloud import error_reporting + >>> client = error_reporting.Client() + >>> user = 'example@gmail.com' + >>> http_context = HTTPContext(method='GET', url='/', userAgent='test agent', + ... referrer='example.com', responseStatusCode=500, + ... remote_ip='1.2.3.4') + >>> error_reporting.report("Found an error!", http_context=http_context, user=user)) diff --git a/latest/_sources/gcloud-api.txt b/latest/_sources/gcloud-api.txt index 7226dd59c3bf..0fb79d966cfb 100644 --- a/latest/_sources/gcloud-api.txt +++ b/latest/_sources/gcloud-api.txt @@ -4,7 +4,7 @@ Shared Core Modules Base Client ~~~~~~~~~~~ -.. automodule:: gcloud.client +.. automodule:: google.cloud.client :members: :show-inheritance: :inherited-members: @@ -12,27 +12,27 @@ Base Client Credentials Helpers ~~~~~~~~~~~~~~~~~~~ -.. automodule:: gcloud.credentials +.. automodule:: google.cloud.credentials :members: :show-inheritance: Base Connections ~~~~~~~~~~~~~~~~ -.. automodule:: gcloud.connection +.. automodule:: google.cloud.connection :members: :show-inheritance: Exceptions ~~~~~~~~~~ -.. automodule:: gcloud.exceptions +.. automodule:: google.cloud.exceptions :members: :show-inheritance: Environment Variables ~~~~~~~~~~~~~~~~~~~~~ -.. automodule:: gcloud.environment_vars +.. automodule:: google.cloud.environment_vars :members: :show-inheritance: diff --git a/latest/_sources/gcloud-auth.txt b/latest/_sources/gcloud-auth.txt index c5b10b8a6763..2b65a58c785f 100644 --- a/latest/_sources/gcloud-auth.txt +++ b/latest/_sources/gcloud-auth.txt @@ -22,7 +22,9 @@ Overview $ gcloud auth login - Previously, `gcloud auth login` was used for both use cases. If your gcloud installation does not support the new command, please update it: + Previously, ``gcloud auth login`` was used for both use cases. If + your ``gcloud`` installation does not support the new command, + please update it: .. code-block:: bash @@ -44,13 +46,13 @@ Overview Client-Provided Authentication ============================== -Every package uses a :class:`Client ` +Every package uses a :class:`Client ` as a base for interacting with an API. For example: .. code-block:: python - from gcloud import datastore + from google.cloud import datastore client = datastore.Client() Passing no arguments at all will "just work" if you've followed the @@ -94,7 +96,7 @@ In these situations, you can create an explicit :class:`Credentials ` object suited to your environment. After creation, -you can pass it directly to a :class:`Client `: +you can pass it directly to a :class:`Client `: .. code:: python @@ -133,10 +135,10 @@ a PKCS12/P12 keyfile. Directly creating ``credentials`` in `oauth2client`_ for a service account is a rather complex process, so as a convenience, the -:meth:`from_service_account_json() ` +:meth:`from_service_account_json() ` and -:meth:`from_service_account_p12() ` -factories are provided to create a :class:`Client ` with +:meth:`from_service_account_p12() ` +factories are provided to create a :class:`Client ` with service account credentials. .. _oauth2client: http://oauth2client.readthedocs.org/en/latest/ @@ -167,7 +169,7 @@ possible to call Google Cloud APIs with a user account via A production application should **use a service account**, but you may wish to use your own personal user account when first - getting started with the ``gcloud-python`` library. + getting started with the ``google-cloud-python`` library. The simplest way to use credentials from a user account is via Application Default Credentials using ``gcloud auth login`` @@ -305,11 +307,11 @@ you add the correct scopes for the APIs you want to access: Advanced Customization ====================== -Though the ``gcloud-python`` library defaults to using `oauth2client`_ +Though the ``google-cloud-python`` library defaults to using `oauth2client`_ to sign requests and ``httplib2`` for sending requests, it is not a strict requirement. -The :class:`Client ` constructor accepts an optional +The :class:`Client ` constructor accepts an optional ``http`` argument in place of a ``credentials`` object. If passed, all HTTP requests made by the client will use your custom HTTP object. @@ -329,10 +331,10 @@ we only use it as http.request(uri, method=method_name, body=body, headers=headers) For an example of such an implementation, -a ``gcloud-python`` user created a `custom HTTP class`_ +a ``google-cloud-python`` user created a `custom HTTP class`_ using the `requests`_ library. -.. _custom HTTP class: https://github.com/GoogleCloudPlatform/gcloud-python/issues/908#issuecomment-110811556 +.. _custom HTTP class: https://github.com/GoogleCloudPlatform/google-cloud-python/issues/908#issuecomment-110811556 .. _requests: http://www.python-requests.org/en/latest/ As for handling authentication on your own, diff --git a/latest/_sources/gcloud-config.txt b/latest/_sources/gcloud-config.txt index 8d30d7573cdb..53132629cfcd 100644 --- a/latest/_sources/gcloud-config.txt +++ b/latest/_sources/gcloud-config.txt @@ -10,13 +10,13 @@ For example: .. code-block:: python - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client() When creating a client in this way, the project ID will be determined by searching these locations in the following order. -* GCLOUD_PROJECT environment variable +* GOOGLE_CLOUD_PROJECT environment variable * GOOGLE_APPLICATION_CREDENTIALS JSON file * Default service configuration path from ``$ gcloud beta auth application-default login``. @@ -28,7 +28,7 @@ You can override the detection of your default project by setting the .. code-block:: python - >>> from gcloud import bigquery + >>> from google.cloud import bigquery >>> client = bigquery.Client(project='my-project') You can see what project ID a client is referencing by accessing the ``project`` @@ -49,7 +49,7 @@ Logging in via ``gcloud beta auth application-default login`` will automatically configure a JSON key file with your default project ID and credentials. -Setting the ``GOOGLE_APPLICATION_CREDENTIALS`` and ``GCLOUD_PROJECT`` +Setting the ``GOOGLE_APPLICATION_CREDENTIALS`` and ``GOOGLE_CLOUD_PROJECT`` environment variables will override the automatically configured credentials. You can change your default project ID to ``my-new-default-project`` by diff --git a/latest/_sources/happybase-batch.txt b/latest/_sources/happybase-batch.txt deleted file mode 100644 index ebeab35082f5..000000000000 --- a/latest/_sources/happybase-batch.txt +++ /dev/null @@ -1,12 +0,0 @@ -HappyBase Batch -~~~~~~~~~~~~~~~ - -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.happybase.batch - :members: - :show-inheritance: diff --git a/latest/_sources/happybase-connection.txt b/latest/_sources/happybase-connection.txt deleted file mode 100644 index ccdd762d9f44..000000000000 --- a/latest/_sources/happybase-connection.txt +++ /dev/null @@ -1,12 +0,0 @@ -HappyBase Connection -~~~~~~~~~~~~~~~~~~~~ - -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.happybase.connection - :members: - :show-inheritance: diff --git a/latest/_sources/happybase-package.txt b/latest/_sources/happybase-package.txt deleted file mode 100644 index 19d15c4788e2..000000000000 --- a/latest/_sources/happybase-package.txt +++ /dev/null @@ -1,12 +0,0 @@ -HappyBase Package -~~~~~~~~~~~~~~~~~ - -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.happybase.__init__ - :members: - :show-inheritance: diff --git a/latest/_sources/happybase-pool.txt b/latest/_sources/happybase-pool.txt deleted file mode 100644 index 566008445cc5..000000000000 --- a/latest/_sources/happybase-pool.txt +++ /dev/null @@ -1,12 +0,0 @@ -HappyBase Connection Pool -~~~~~~~~~~~~~~~~~~~~~~~~~ - -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.happybase.pool - :members: - :show-inheritance: diff --git a/latest/_sources/happybase-table.txt b/latest/_sources/happybase-table.txt deleted file mode 100644 index 44cd8f6bb86c..000000000000 --- a/latest/_sources/happybase-table.txt +++ /dev/null @@ -1,12 +0,0 @@ -HappyBase Table -~~~~~~~~~~~~~~~ - -.. warning:: - - gRPC is required for using the Cloud Bigtable API. As of May 2016, - ``grpcio`` is only supported in Python 2.7, so importing - :mod:`gcloud.bigtable` in other versions of Python will fail. - -.. automodule:: gcloud.bigtable.happybase.table - :members: - :show-inheritance: diff --git a/latest/_sources/index.txt b/latest/_sources/index.txt index 0c2b6ffbedb9..edcf978c47f7 100644 --- a/latest/_sources/index.txt +++ b/latest/_sources/index.txt @@ -1,11 +1,12 @@ .. toctree:: :maxdepth: 0 :hidden: - :caption: gcloud + :caption: google-cloud gcloud-api gcloud-config gcloud-auth + operation-api .. toctree:: :maxdepth: 0 @@ -54,6 +55,7 @@ bigquery-job bigquery-table bigquery-query + bigquery-schema .. toctree:: :maxdepth: 0 @@ -61,7 +63,6 @@ :caption: Cloud Bigtable bigtable-usage - HappyBase bigtable-client-intro bigtable-instance-api bigtable-table-api @@ -74,10 +75,6 @@ bigtable-row bigtable-row-filters bigtable-row-data - happybase-connection - happybase-pool - happybase-table - happybase-batch .. toctree:: :maxdepth: 0 @@ -110,6 +107,18 @@ logging-entries logging-metric logging-sink + logging-handlers + logging-transports-sync + logging-transports-thread + logging-transports-base + +.. toctree:: + :maxdepth: 0 + :hidden: + :caption: Stackdriver Error Reporting + + error-reporting-usage + Client .. toctree:: :maxdepth: 0 @@ -120,6 +129,7 @@ Client monitoring-metric monitoring-resource + monitoring-group monitoring-query monitoring-timeseries monitoring-label @@ -132,32 +142,52 @@ translate-usage Client +.. toctree:: + :maxdepth: 0 + :hidden: + :caption: Vision + + vision-usage + vision-client + vision-image + vision-feature + +.. toctree:: + :maxdepth: 0 + :hidden: + :caption: Natural Language + + language-usage + Client + language-document + language-responses + .. toctree:: :maxdepth: 0 :hidden: :caption: External Links - GitHub - Issues - Stack Overflow - PyPI + GitHub + Issues + Stack Overflow + PyPI Getting started --------------- -The ``gcloud`` library is ``pip`` install-able: +The ``google-cloud`` library is ``pip`` install-able: .. code-block:: console - $ pip install gcloud + $ pip install google-cloud -If you want to install ``gcloud-python`` from source, +If you want to install ``google-cloud-python`` from source, you can clone the repository from GitHub: .. code-block:: console - $ git clone git://github.com/GoogleCloudPlatform/gcloud-python.git - $ cd gcloud-python + $ git clone git://github.com/GoogleCloudPlatform/google-cloud-python.git + $ cd google-cloud-python $ python setup.py install ---- @@ -171,7 +201,7 @@ Cloud Datastore .. code-block:: python - from gcloud import datastore + from google.cloud import datastore client = datastore.Client() key = client.key('Person') @@ -190,7 +220,7 @@ Cloud Storage .. code-block:: python - from gcloud import storage + from google.cloud import storage client = storage.Client() bucket = client.get_bucket('') diff --git a/latest/_sources/language-client.txt b/latest/_sources/language-client.txt new file mode 100644 index 000000000000..c0bc0b329ee0 --- /dev/null +++ b/latest/_sources/language-client.txt @@ -0,0 +1,13 @@ +Natural Language Client +======================= + +.. automodule:: google.cloud.language.client + :members: + :show-inheritance: + +Connection +~~~~~~~~~~ + +.. automodule:: google.cloud.language.connection + :members: + :show-inheritance: diff --git a/latest/_sources/language-document.txt b/latest/_sources/language-document.txt new file mode 100644 index 000000000000..e879b11e590a --- /dev/null +++ b/latest/_sources/language-document.txt @@ -0,0 +1,6 @@ +Document +~~~~~~~~ + +.. automodule:: google.cloud.language.document + :members: + :show-inheritance: diff --git a/latest/_sources/language-responses.txt b/latest/_sources/language-responses.txt new file mode 100644 index 000000000000..0ad22fa9bb4f --- /dev/null +++ b/latest/_sources/language-responses.txt @@ -0,0 +1,23 @@ +Natural Language Response Classes +================================= + +Entity +~~~~~~ + +.. automodule:: google.cloud.language.entity + :members: + :show-inheritance: + +Sentiment +~~~~~~~~~ + +.. automodule:: google.cloud.language.sentiment + :members: + :show-inheritance: + +Syntax +~~~~~~ + +.. automodule:: google.cloud.language.syntax + :members: + :show-inheritance: diff --git a/latest/_sources/language-usage.txt b/latest/_sources/language-usage.txt new file mode 100644 index 000000000000..9feea9c88de5 --- /dev/null +++ b/latest/_sources/language-usage.txt @@ -0,0 +1,278 @@ +Using the API +============= + +The `Google Natural Language`_ API can be used to reveal the +structure and meaning of text via powerful machine +learning models. You can use it to extract information about +people, places, events and much more, mentioned in text documents, +news articles or blog posts. You can use it to understand +sentiment about your product on social media or parse intent from +customer conversations happening in a call center or a messaging +app. You can analyze text uploaded in your request or integrate +with your document storage on Google Cloud Storage. + +.. warning:: + + This is a Beta release of Google Cloud Natural Language API. This + API is not intended for real-time usage in critical applications. + +.. _Google Natural Language: https://cloud.google.com/natural-language/docs/getting-started + +Client +------ + +:class:`~google.cloud.language.client.Client` objects provide a +means to configure your application. Each instance holds +an authenticated connection to the Natural Language service. + +For an overview of authentication in ``google-cloud-python``, see +:doc:`gcloud-auth`. + +Assuming your environment is set up as described in that document, +create an instance of :class:`~google.cloud.language.client.Client`. + + .. code-block:: python + + >>> from google.cloud import language + >>> client = language.Client() + +By default the ``language`` is ``'en-US'`` and the ``encoding`` is +UTF-8. To over-ride these values: + + .. code-block:: python + + >>> client = language.Client(language='es', + ... encoding=language.Encoding.UTF16) + +The encoding can be one of +:attr:`Encoding.UTF8 `, +:attr:`Encoding.UTF16 `, or +:attr:`Encoding.UTF32 `. + +Methods +------- + +The Google Natural Language API has three supported methods + +- `analyzeEntities`_ +- `analyzeSentiment`_ +- `annotateText`_ + +and each method uses a `Document`_ for representing text. To +create a :class:`~google.cloud.language.document.Document`, + + .. code-block:: python + + >>> text_content = ( + ... 'Google, headquartered in Mountain View, unveiled the ' + ... 'new Android phone at the Consumer Electronic Show. ' + ... 'Sundar Pichai said in his keynote that users love ' + ... 'their new Android phones.') + >>> document = client.document_from_text(text_content) + +By using :meth:`~google.cloud.language.client.Client.document_from_text`, +the document's type is plain text: + + .. code-block:: python + + >>> document.doc_type == language.Document.PLAIN_TEXT + True + +In addition, the document's language defaults to the language on +the client + + .. code-block:: python + + >>> document.language + 'en-US' + >>> document.language == client.language + True + +In addition, the +:meth:`~google.cloud.language.client.Client.document_from_html`, +factory can be used to created an HTML document. In this +method and the from text method, the language can be +over-ridden: + + .. code-block:: python + + >>> html_content = """\ + ... + ... + ... El Tiempo de las Historias</time> + ... </head> + ... <body> + ... <p>La vaca saltó sobre la luna.</p> + ... </body> + ... </html> + ... """ + >>> document = client.document_from_html(html_content, + ... language='es') + +The ``language`` argument can be either ISO-639-1 or BCP-47 language +codes; at the time, only English, Spanish, and Japanese `are supported`_. +However, the ``analyzeSentiment`` method `only supports`_ English text. + +.. _are supported: https://cloud.google.com/natural-language/docs/ +.. _only supports: https://cloud.google.com/natural-language/reference/rest/v1beta1/documents/analyzeSentiment#body.request_body.FIELDS.document + +The document type (``doc_type``) value can be one of +:attr:`Document.PLAIN_TEXT <google.cloud.language.document.Document.PLAIN_TEXT>` or +:attr:`Document.HTML <google.cloud.language.document.Document.HTML>`. + +In addition to supplying the text / HTML content, a document can refer +to content stored in `Google Cloud Storage`_. We can use the +:meth:`~google.cloud.language.client.Client.document_from_url` method: + + .. code-block:: python + + >>> gcs_url = 'gs://my-text-bucket/sentiment-me.txt' + >>> document = client.document_from_url( + ... gcs_url, doc_type=language.Document.HTML) + >>> document.gcs_url == gcs_url + True + >>> document.doc_type == language.Document.PLAIN_TEXT + True + +The document type can be specified with the ``doc_type`` argument: + + .. code-block:: python + + >>> document = client.document_from_url( + ... gcs_url, doc_type=language.Document.HTML) + +.. _analyzeEntities: https://cloud.google.com/natural-language/reference/rest/v1beta1/documents/analyzeEntities +.. _analyzeSentiment: https://cloud.google.com/natural-language/reference/rest/v1beta1/documents/analyzeSentiment +.. _annotateText: https://cloud.google.com/natural-language/reference/rest/v1beta1/documents/annotateText +.. _Document: https://cloud.google.com/natural-language/reference/rest/v1beta1/Document +.. _Google Cloud Storage: https://cloud.google.com/storage/ + +Analyze Entities +---------------- + +The :meth:`~google.cloud.language.document.Document.analyze_entities` method +finds named entities (i.e. proper names) in the text and returns them +as a :class:`list` of :class:`~google.cloud.language.entity.Entity` objects. +Each entity has a corresponding type, salience (prominence), associated +metadata and other properties. + + .. code-block:: python + + >>> text_content = ("Michelangelo Caravaggio, Italian painter, is " + ... "known for 'The Calling of Saint Matthew'.") + >>> document = client.document(text_content) + >>> entities = document.analyze_entities() + >>> for entity in entities: + ... print('=' * 20) + ... print(' name: %s' % (entity.name,)) + ... print(' type: %s' % (entity.entity_type,)) + ... print('wikipedia_url: %s' % (entity.wikipedia_url,)) + ... print(' metadata: %s' % (entity.metadata,)) + ... print(' salience: %s' % (entity.salience,)) + ==================== + name: Michelangelo Caravaggio + type: PERSON + wikipedia_url: http://en.wikipedia.org/wiki/Caravaggio + metadata: {} + salience: 0.7615959 + ==================== + name: Italian + type: LOCATION + wikipedia_url: http://en.wikipedia.org/wiki/Italy + metadata: {} + salience: 0.19960518 + ==================== + name: The Calling of Saint Matthew + type: EVENT + wikipedia_url: http://en.wikipedia.org/wiki/The_Calling_of_St_Matthew_(Caravaggio) + metadata: {} + salience: 0.038798928 + +Analyze Sentiment +----------------- + +The :meth:`~google.cloud.language.document.Document.analyze_sentiment` method +analyzes the sentiment of the provided text and returns a +:class:`~google.cloud.language.sentiment.Sentiment`. Currently, this method +only supports English text. + + .. code-block:: python + + >>> text_content = "Jogging isn't very fun." + >>> document = client.document(text_content) + >>> sentiment = document.analyze_sentiment() + >>> print(sentiment.polarity) + -1 + >>> print(sentiment.magnitude) + 0.8 + +Annotate Text +------------- + +The :meth:`~google.cloud.language.document.Document.annotate_text` method +analyzes a document and is intended for users who are familiar with +machine learning and need in-depth text features to build upon. + +The method returns a named tuple with four entries: + +* ``sentences``: A :class:`list` of sentences in the text +* ``tokens``: A :class:`list` of :class:`~google.cloud.language.syntax.Token` + object (e.g. words, punctuation) +* ``sentiment``: The :class:`~google.cloud.language.sentiment.Sentiment` of + the text (as returned by + :meth:`~google.cloud.language.document.Document.analyze_sentiment`) +* ``entities``: :class:`list` of :class:`~google.cloud.language.entity.Entity` + objects extracted from the text (as returned by + :meth:`~google.cloud.language.document.Document.analyze_entities`) + +By default :meth:`~google.cloud.language.document.Document.annotate_text` has +three arguments ``include_syntax``, ``include_entities`` and +``include_sentiment`` which are all :data:`True`. However, each of these +`Features`_ can be selectively turned off by setting the corresponding +arguments to :data:`False`. + +When ``include_syntax=False``, ``sentences`` and ``tokens`` in the +response is :data:`None`. When ``include_sentiment``, ``sentiment`` in +the response is :data:`None`. When ``include_entities``, ``entities`` in +the response is :data:`None`. + + .. code-block:: python + + >>> text_content = 'The cow jumped over the Moon.' + >>> document = client.document(text_content) + >>> annotations = document.annotate_text() + >>> # Sentences present if include_syntax=True + >>> print(annotations.sentences) + ['The cow jumped over the Moon.'] + >>> # Tokens present if include_syntax=True + >>> for token in annotations.tokens: + ... msg = '%11s: %s' % (token.part_of_speech, token.text_content) + ... print(msg) + DETERMINER: The + NOUN: cow + VERB: jumped + ADPOSITION: over + DETERMINER: the + NOUN: Moon + PUNCTUATION: . + >>> # Sentiment present if include_sentiment=True + >>> print(annotations.sentiment.polarity) + 1 + >>> print(annotations.sentiment.magnitude) + 0.1 + >>> # Entities present if include_entities=True + >>> for entity in annotations.entities: + ... print('=' * 20) + ... print(' name: %s' % (entity.name,)) + ... print(' type: %s' % (entity.entity_type,)) + ... print('wikipedia_url: %s' % (entity.wikipedia_url,)) + ... print(' metadata: %s' % (entity.metadata,)) + ... print(' salience: %s' % (entity.salience,)) + ==================== + name: Moon + type: LOCATION + wikipedia_url: http://en.wikipedia.org/wiki/Natural_satellite + metadata: {} + salience: 0.11793101 + +.. _Features: https://cloud.google.com/natural-language/reference/rest/v1beta1/documents/annotateText#Features diff --git a/latest/_sources/logging-client.txt b/latest/_sources/logging-client.txt index fb5f009947cd..cc834d1c21af 100644 --- a/latest/_sources/logging-client.txt +++ b/latest/_sources/logging-client.txt @@ -1,13 +1,13 @@ Stackdriver Logging Client ========================== -.. automodule:: gcloud.logging.client +.. automodule:: google.cloud.logging.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.logging.connection +.. automodule:: google.cloud.logging.connection :members: :show-inheritance: diff --git a/latest/_sources/logging-entries.txt b/latest/_sources/logging-entries.txt index a22f6094d927..762b7776ee2c 100644 --- a/latest/_sources/logging-entries.txt +++ b/latest/_sources/logging-entries.txt @@ -1,7 +1,7 @@ Entries ======= -.. automodule:: gcloud.logging.entries +.. automodule:: google.cloud.logging.entries :members: :show-inheritance: diff --git a/latest/_sources/logging-handlers.txt b/latest/_sources/logging-handlers.txt new file mode 100644 index 000000000000..1a258a88a541 --- /dev/null +++ b/latest/_sources/logging-handlers.txt @@ -0,0 +1,6 @@ +Python Logging Module Handler +============================== + +.. automodule:: google.cloud.logging.handlers.handlers + :members: + :show-inheritance: diff --git a/latest/_sources/logging-logger.txt b/latest/_sources/logging-logger.txt index 4a95d01662a7..5e167671b7bd 100644 --- a/latest/_sources/logging-logger.txt +++ b/latest/_sources/logging-logger.txt @@ -1,7 +1,7 @@ Logger ====== -.. automodule:: gcloud.logging.logger +.. automodule:: google.cloud.logging.logger :members: :show-inheritance: diff --git a/latest/_sources/logging-metric.txt b/latest/_sources/logging-metric.txt index 2c49a94049ce..ca30e3c89eca 100644 --- a/latest/_sources/logging-metric.txt +++ b/latest/_sources/logging-metric.txt @@ -1,6 +1,6 @@ Metrics ======= -.. automodule:: gcloud.logging.metric +.. automodule:: google.cloud.logging.metric :members: :show-inheritance: diff --git a/latest/_sources/logging-sink.txt b/latest/_sources/logging-sink.txt index 4e2dd40d44dc..35e88562bbee 100644 --- a/latest/_sources/logging-sink.txt +++ b/latest/_sources/logging-sink.txt @@ -1,6 +1,6 @@ Sinks ===== -.. automodule:: gcloud.logging.sink +.. automodule:: google.cloud.logging.sink :members: :show-inheritance: diff --git a/latest/_sources/logging-transports-base.txt b/latest/_sources/logging-transports-base.txt new file mode 100644 index 000000000000..5b52c46cadcb --- /dev/null +++ b/latest/_sources/logging-transports-base.txt @@ -0,0 +1,6 @@ +Python Logging Handler Sync Transport +====================================== + +.. automodule:: google.cloud.logging.handlers.transports.base + :members: + :show-inheritance: diff --git a/latest/_sources/logging-transports-sync.txt b/latest/_sources/logging-transports-sync.txt new file mode 100644 index 000000000000..edb2b72f578d --- /dev/null +++ b/latest/_sources/logging-transports-sync.txt @@ -0,0 +1,6 @@ +Python Logging Handler Sync Transport +====================================== + +.. automodule:: google.cloud.logging.handlers.transports.sync + :members: + :show-inheritance: diff --git a/latest/_sources/logging-transports-thread.txt b/latest/_sources/logging-transports-thread.txt new file mode 100644 index 000000000000..45780b27fe42 --- /dev/null +++ b/latest/_sources/logging-transports-thread.txt @@ -0,0 +1,7 @@ +Python Logging Handler Threaded Transport +========================================= + + +.. automodule:: google.cloud.logging.handlers.transports.background_thread + :members: + :show-inheritance: diff --git a/latest/_sources/logging-usage.txt b/latest/_sources/logging-usage.txt index 3dd2a6efab19..4736924eae04 100644 --- a/latest/_sources/logging-usage.txt +++ b/latest/_sources/logging-usage.txt @@ -5,27 +5,33 @@ Using the API Authentication and Configuration -------------------------------- -- For an overview of authentication in ``gcloud-python``, +- For an overview of authentication in ``google-cloud-python``, see :doc:`gcloud-auth`. - In addition to any authentication configuration, you should also set the - :envvar:`GCLOUD_PROJECT` environment variable for the project you'd like + :envvar:`GOOGLE_CLOUD_PROJECT` environment variable for the project you'd like to interact with. If you are Google App Engine or Google Compute Engine this will be detected automatically. +- The library now enables the ``gRPC`` transport for the logging API by + default, assuming that the required dependencies are installed and + importable. To *disable* this transport, set the + :envvar:`GOOGLE_CLOUD_DISABLE_GRPC` environment variable to a + non-empty string, e.g.: ``$ export GOOGLE_CLOUD_DISABLE_GRPC=true``. + - After configuring your environment, create a - :class:`Client <gcloud.logging.client.Client>` + :class:`Client <google.cloud.logging.client.Client>` .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() or pass in ``credentials`` and ``project`` explicitly .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client(project='my-project', credentials=creds) @@ -36,7 +42,7 @@ Write a simple text entry to a logger. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> logger = client.logger('log_name') >>> logger.log_text("A simple entry") # API call @@ -45,7 +51,7 @@ Write a dictionary entry to a logger. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> logger = client.logger('log_name') >>> logger.log_struct( @@ -60,7 +66,7 @@ Fetch entries for the default project. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> entries, token = client.list_entries() # API call >>> for entry in entries: @@ -74,7 +80,7 @@ Fetch entries across multiple projects. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> entries, token = client.list_entries( ... project_ids=['one-project', 'another-project']) # API call @@ -85,7 +91,7 @@ Filter entries retrieved using the `Advanced Logs Filters`_ syntax .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> FILTER = "log:log_name AND textPayload:simple" >>> entries, token = client.list_entries(filter=FILTER) # API call @@ -94,7 +100,7 @@ Sort entries in descending timestamp order. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> entries, token = client.list_entries(order_by=logging.DESCENDING) # API call @@ -102,7 +108,7 @@ Retrieve entries in batches of 10, iterating until done. .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> retrieved = [] >>> token = None @@ -116,7 +122,7 @@ Retrieve entries for a single logger, sorting in descending timestamp order: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> logger = client.logger('log_name') >>> entries, token = logger.list_entries(order_by=logging.DESCENDING) # API call @@ -126,7 +132,7 @@ Delete all entries for a logger .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> logger = client.logger('log_name') >>> logger.delete() # API call @@ -142,7 +148,7 @@ Create a metric: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> metric = client.metric( ... "robots", "Robots all up in your server", @@ -157,7 +163,7 @@ List all metrics for a project: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> metrics, token = client.list_metrics() >>> len(metrics) @@ -170,7 +176,7 @@ Refresh local information about a metric: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> metric = client.metric("robots") >>> metric.reload() # API call @@ -183,7 +189,7 @@ Update a metric: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> metric = client.metric("robots") >>> metric.exists() # API call @@ -196,7 +202,7 @@ Delete a metric: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> metric = client.metric("robots") >>> metric.exists() # API call @@ -221,7 +227,7 @@ Add ``cloud-logs@google.com`` as the owner of ``my-bucket-name``: .. doctest:: - >>> from gcloud import storage + >>> from google.cloud import storage >>> client = storage.Client() >>> bucket = client.get_bucket('my-bucket-name') >>> bucket.acl.reload() @@ -242,8 +248,8 @@ See: `Setting permissions for BigQuery`_ .. doctest:: - >>> from gcloud import bigquery - >>> from gcloud.bigquery.dataset import AccessGrant + >>> from google.cloud import bigquery + >>> from google.cloud.bigquery.dataset import AccessGrant >>> bigquery_client = bigquery.Client() >>> dataset = bigquery_client.dataset('my-dataset-name') >>> dataset.create() @@ -266,7 +272,7 @@ See: `Setting permissions for Pub/Sub`_ .. doctest:: - >>> from gcloud import pubsub + >>> from google.cloud import pubsub >>> client = pubsub.Client() >>> topic = client.topic('your-topic-name') >>> policy = top.get_iam_policy() @@ -279,7 +285,7 @@ Create a Cloud Storage sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink( ... "robots-storage", @@ -295,7 +301,7 @@ Create a BigQuery sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink( ... "robots-bq", @@ -311,7 +317,7 @@ Create a Cloud Pub/Sub sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink( @@ -328,7 +334,7 @@ List all sinks for a project: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sinks, token = client.list_sinks() >>> for sink in sinks: @@ -341,7 +347,7 @@ Refresh local information about a sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink('robots-storage') >>> sink.filter is None @@ -356,7 +362,7 @@ Update a sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink("robots") >>> sink.reload() # API call @@ -367,7 +373,7 @@ Delete a sink: .. doctest:: - >>> from gcloud import logging + >>> from google.cloud import logging >>> client = logging.Client() >>> sink = client.sink( ... "robots", @@ -377,3 +383,74 @@ Delete a sink: >>> sink.delete() # API call >>> sink.exists() # API call False + +Integration with Python logging module +--------------------------------------------- + + +It's possible to tie the Python :mod:`logging` module directly into Google Cloud Logging. To use it, +create a :class:`CloudLoggingHandler <google.cloud.logging.CloudLoggingHandler>` instance from your +Logging client. + +.. doctest:: + + >>> import logging + >>> import google.cloud.logging # Don't conflict with standard logging + >>> from google.cloud.logging.handlers import CloudLoggingHandler + >>> client = google.cloud.logging.Client() + >>> handler = CloudLoggingHandler(client) + >>> cloud_logger = logging.getLogger('cloudLogger') + >>> cloud_logger.setLevel(logging.INFO) # defaults to WARN + >>> cloud_logger.addHandler(handler) + >>> cloud_logger.error('bad news') + +.. note:: + + This handler by default uses an asynchronous transport that sends log entries on a background + thread. However, the API call will still be made in the same process. For other transport + options, see the transports section. + +All logs will go to a single custom log, which defaults to "python". The name of the Python +logger will be included in the structured log entry under the "python_logger" field. You can +change it by providing a name to the handler: + +.. doctest:: + + >>> handler = CloudLoggingHandler(client, name="mycustomlog") + +It is also possible to attach the handler to the root Python logger, so that for example a plain +`logging.warn` call would be sent to Cloud Logging, as well as any other loggers created. However, +you must avoid infinite recursion from the logging calls the client itself makes. A helper +method :meth:`setup_logging <google.cloud.logging.handlers.setup_logging>` is provided to configure +this automatically: + +.. doctest:: + + >>> import logging + >>> import google.cloud.logging # Don't conflict with standard logging + >>> from google.cloud.logging.handlers import CloudLoggingHandler, setup_logging + >>> client = google.cloud.logging.Client() + >>> handler = CloudLoggingHandler(client) + >>> logging.getLogger().setLevel(logging.INFO) # defaults to WARN + >>> setup_logging(handler) + >>> logging.error('bad news') + +You can also exclude certain loggers: + +.. doctest:: + + >>> setup_logging(handler, excluded_loggers=('werkzeug',))) + + + +Python logging handler transports +================================== + +The Python logging handler can use different transports. The default is +:class:`google.cloud.logging.handlers.BackgroundThreadTransport`. + + 1. :class:`google.cloud.logging.handlers.BackgroundThreadTransport` this is the default. It writes + entries on a background :class:`python.threading.Thread`. + + 1. :class:`google.cloud.logging.handlers.SyncTransport` this handler does a direct API call on each + logging statement to write the entry. diff --git a/latest/_sources/monitoring-client.txt b/latest/_sources/monitoring-client.txt index baea7d2fd592..1aec72367379 100644 --- a/latest/_sources/monitoring-client.txt +++ b/latest/_sources/monitoring-client.txt @@ -1,13 +1,13 @@ Stackdriver Monitoring Client ============================= -.. automodule:: gcloud.monitoring.client +.. automodule:: google.cloud.monitoring.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.monitoring.connection +.. automodule:: google.cloud.monitoring.connection :members: :show-inheritance: diff --git a/latest/_sources/monitoring-group.txt b/latest/_sources/monitoring-group.txt new file mode 100644 index 000000000000..db7d3acb02ed --- /dev/null +++ b/latest/_sources/monitoring-group.txt @@ -0,0 +1,7 @@ +Groups +====== + +.. automodule:: google.cloud.monitoring.group + :members: + :show-inheritance: + diff --git a/latest/_sources/monitoring-label.txt b/latest/_sources/monitoring-label.txt index a20d5a741af0..67b7c16b7689 100644 --- a/latest/_sources/monitoring-label.txt +++ b/latest/_sources/monitoring-label.txt @@ -1,6 +1,6 @@ Label Descriptors ================= -.. automodule:: gcloud.monitoring.label +.. automodule:: google.cloud.monitoring.label :members: :show-inheritance: diff --git a/latest/_sources/monitoring-metric.txt b/latest/_sources/monitoring-metric.txt index e1fb979e3d22..abb6395f864c 100644 --- a/latest/_sources/monitoring-metric.txt +++ b/latest/_sources/monitoring-metric.txt @@ -1,6 +1,6 @@ Metric Descriptors ================== -.. automodule:: gcloud.monitoring.metric +.. automodule:: google.cloud.monitoring.metric :members: :show-inheritance: diff --git a/latest/_sources/monitoring-query.txt b/latest/_sources/monitoring-query.txt index 1da7f7e61fcc..28cc2def2522 100644 --- a/latest/_sources/monitoring-query.txt +++ b/latest/_sources/monitoring-query.txt @@ -1,6 +1,6 @@ Time Series Query ================= -.. automodule:: gcloud.monitoring.query +.. automodule:: google.cloud.monitoring.query :members: :show-inheritance: diff --git a/latest/_sources/monitoring-resource.txt b/latest/_sources/monitoring-resource.txt index d9750decd1c6..b7faf93e68df 100644 --- a/latest/_sources/monitoring-resource.txt +++ b/latest/_sources/monitoring-resource.txt @@ -1,6 +1,6 @@ Monitored Resource Descriptors ============================== -.. automodule:: gcloud.monitoring.resource +.. automodule:: google.cloud.monitoring.resource :members: :show-inheritance: diff --git a/latest/_sources/monitoring-timeseries.txt b/latest/_sources/monitoring-timeseries.txt index 2d3133e7823a..e580f8067d69 100644 --- a/latest/_sources/monitoring-timeseries.txt +++ b/latest/_sources/monitoring-timeseries.txt @@ -1,6 +1,6 @@ Time Series =========== -.. automodule:: gcloud.monitoring.timeseries +.. automodule:: google.cloud.monitoring.timeseries :members: :show-inheritance: diff --git a/latest/_sources/monitoring-usage.txt b/latest/_sources/monitoring-usage.txt index adfd93cefe67..af217c6271f2 100644 --- a/latest/_sources/monitoring-usage.txt +++ b/latest/_sources/monitoring-usage.txt @@ -40,8 +40,8 @@ The Stackdriver Monitoring Client Object The Stackdriver Monitoring client library generally makes its functionality available as methods of the monitoring -:class:`~gcloud.monitoring.client.Client` class. -A :class:`~gcloud.monitoring.client.Client` instance holds +:class:`~google.cloud.monitoring.client.Client` class. +A :class:`~google.cloud.monitoring.client.Client` instance holds authentication credentials and the ID of the target project with which the metric data of interest is associated. This project ID will often refer to a `Stackdriver account`_ binding multiple @@ -54,12 +54,12 @@ more information. It is thus typical to create a client object as follows:: - >>> from gcloud import monitoring + >>> from google.cloud import monitoring >>> client = monitoring.Client(project='target-project') If you are running in Google Compute Engine or Google App Engine, the current project is the default target project. This default -can be further overridden with the :envvar:`GCLOUD_PROJECT` +can be further overridden with the :envvar:`GOOGLE_CLOUD_PROJECT` environment variable. Using the default target project is even easier:: @@ -77,14 +77,14 @@ Monitored Resource Descriptors The available monitored resource types are defined by *monitored resource descriptors*. You can fetch a list of these with the -:meth:`~gcloud.monitoring.client.Client.list_resource_descriptors` method:: +:meth:`~google.cloud.monitoring.client.Client.list_resource_descriptors` method:: >>> for descriptor in client.list_resource_descriptors(): ... print(descriptor.type) -Each :class:`~gcloud.monitoring.resource.ResourceDescriptor` +Each :class:`~google.cloud.monitoring.resource.ResourceDescriptor` has a type, a display name, a description, and a list of -:class:`~gcloud.monitoring.label.LabelDescriptor` instances. +:class:`~google.cloud.monitoring.label.LabelDescriptor` instances. See the documentation about `Monitored Resources`_ for more information. @@ -98,22 +98,22 @@ Metric Descriptors The available metric types are defined by *metric descriptors*. They include `platform metrics`_, `agent metrics`_, and `custom metrics`_. You can list all of these with the -:meth:`~gcloud.monitoring.client.Client.list_metric_descriptors` method:: +:meth:`~google.cloud.monitoring.client.Client.list_metric_descriptors` method:: >>> for descriptor in client.list_metric_descriptors(): ... print(descriptor.type) -See :class:`~gcloud.monitoring.metric.MetricDescriptor` and the +See :class:`~google.cloud.monitoring.metric.MetricDescriptor` and the `Metric Descriptors`_ API documentation for more information. You can create new metric descriptors to define custom metrics in the ``custom.googleapis.com`` namespace. You do this by creating a -:class:`~gcloud.monitoring.metric.MetricDescriptor` object using the -client's :meth:`~gcloud.monitoring.client.Client.metric_descriptor` +:class:`~google.cloud.monitoring.metric.MetricDescriptor` object using the +client's :meth:`~google.cloud.monitoring.client.Client.metric_descriptor` factory and then calling the object's -:meth:`~gcloud.monitoring.metric.MetricDescriptor.create` method:: +:meth:`~google.cloud.monitoring.metric.MetricDescriptor.create` method:: - >>> from gcloud.monitoring import MetricKind, ValueType + >>> from google.cloud.monitoring import MetricKind, ValueType >>> descriptor = client.metric_descriptor( ... 'custom.googleapis.com/my_metric', ... metric_kind=MetricKind.GAUGE, @@ -129,13 +129,13 @@ You can delete such a metric descriptor as follows:: To define a custom metric parameterized by one or more labels, you must build the appropriate -:class:`~gcloud.monitoring.label.LabelDescriptor` objects +:class:`~google.cloud.monitoring.label.LabelDescriptor` objects and include them in the -:class:`~gcloud.monitoring.metric.MetricDescriptor` object +:class:`~google.cloud.monitoring.metric.MetricDescriptor` object before you call -:meth:`~gcloud.monitoring.metric.MetricDescriptor.create`:: +:meth:`~google.cloud.monitoring.metric.MetricDescriptor.create`:: - >>> from gcloud.monitoring import LabelDescriptor, LabelValueType + >>> from google.cloud.monitoring import LabelDescriptor, LabelValueType >>> label = LabelDescriptor('response_code', LabelValueType.INT64, ... description='HTTP status code') >>> descriptor = client.metric_descriptor( @@ -154,20 +154,100 @@ before you call projects.metricDescriptors +Groups +------ + +A group is a dynamic collection of *monitored resources* whose membership is +defined by a `filter`_. These groups are usually created via the +`Stackdriver dashboard`_. You can list all the groups in a project with the +:meth:`~google.cloud.monitoring.client.Client.list_groups` method:: + + >>> for group in client.list_groups(): + ... print(group.id, group.display_name, group.parent_id) + ('a001', 'Production', None) + ('a002', 'Front-end', 'a001') + ('1003', 'Back-end', 'a001') + +See :class:`~google.cloud.monitoring.group.Group` and the API documentation for +`Groups`_ and `Group members`_ for more information. + +You can get a specific group based on it's ID as follows:: + + >>> group = client.fetch_group('a001') + +You can get the current members of this group using the +:meth:`~google.cloud.monitoring.group.Group.list_members` method:: + + >>> for member in group.list_members(): + ... print(member) + +Passing in ``end_time`` and ``start_time`` to the above method will return +historical members based on the current filter of the group. The group +membership changes over time, as *monitored resources* come and go, and as they +change properties. + +You can create new groups to define new collections of *monitored resources*. +You do this by creating a :class:`~google.cloud.monitoring.group.Group` object using +the client's :meth:`~google.cloud.monitoring.client.Client.group` factory and then +calling the object's :meth:`~google.cloud.monitoring.group.Group.create` method:: + + >>> filter_string = 'resource.zone = "us-central1-a"' + >>> group = client.group( + ... display_name='My group', + ... filter_string=filter_string, + ... parent_id='a001', + ... is_cluster=True) + >>> group.create() + >>> group.id + '1234' + +You can further manipulate an existing group by first initializing a Group +object with it's ID or name, and then calling various methods on it. + +Delete a group:: + + >>> group = client.group('1234') + >>> group.exists() + True + >>> group.delete() + + +Update a group:: + + >>> group = client.group('1234') + >>> group.exists() + True + >>> group.reload() + >>> group.display_name = 'New Display Name' + >>> group.update() + +.. _Stackdriver dashboard: + https://support.stackdriver.com/customer/portal/articles/\ + 1535145-creating-groups +.. _filter: + https://cloud.google.com/monitoring/api/v3/filters#group-filter +.. _Groups: + https://cloud.google.com/monitoring/api/ref_v3/rest/v3/\ + projects.groups +.. _Group members: + https://cloud.google.com/monitoring/api/ref_v3/rest/v3/\ + projects.groups.members + + Time Series Queries ------------------- A time series includes a collection of data points and a set of resource and metric label values. -See :class:`~gcloud.monitoring.timeseries.TimeSeries` and the +See :class:`~google.cloud.monitoring.timeseries.TimeSeries` and the `Time Series`_ API documentation for more information. While you can obtain time series objects by iterating over a -:class:`~gcloud.monitoring.query.Query` object, usually it is +:class:`~google.cloud.monitoring.query.Query` object, usually it is more useful to retrieve time series data in the form of a :class:`pandas.DataFrame`, where each column corresponds to a single time series. For this, you must have :mod:`pandas` installed; -it is not a required dependency of ``gcloud-python``. +it is not a required dependency of ``google-cloud-python``. You can display CPU utilization across your GCE instances during the last five minutes as follows:: @@ -176,11 +256,11 @@ the last five minutes as follows:: >>> query = client.query(METRIC, minutes=5) >>> print(query.as_dataframe()) -:class:`~gcloud.monitoring.query.Query` objects provide a variety of +:class:`~google.cloud.monitoring.query.Query` objects provide a variety of methods for refining the query. You can request temporal alignment and cross-series reduction, and you can filter by label values. -See the client :meth:`~gcloud.monitoring.client.Client.query` method -and the :class:`~gcloud.monitoring.query.Query` class for more +See the client :meth:`~google.cloud.monitoring.client.Client.query` method +and the :class:`~google.cloud.monitoring.query.Query` class for more information. For example, you can display CPU utilization during the last hour @@ -188,7 +268,7 @@ across GCE instances with names beginning with ``"mycluster-"``, averaged over five-minute intervals and aggregated per zone, as follows:: - >>> from gcloud.monitoring import Aligner, Reducer + >>> from google.cloud.monitoring import Aligner, Reducer >>> METRIC = 'compute.googleapis.com/instance/cpu/utilization' >>> query = (client.query(METRIC, hours=1) ... .select_metrics(instance_name_prefix='mycluster-') diff --git a/latest/_sources/operation-api.txt b/latest/_sources/operation-api.txt new file mode 100644 index 000000000000..489a2683920c --- /dev/null +++ b/latest/_sources/operation-api.txt @@ -0,0 +1,7 @@ +Long-Running Operations +~~~~~~~~~~~~~~~~~~~~~~~ + +.. automodule:: google.cloud.operation + :members: + :show-inheritance: + diff --git a/latest/_sources/pubsub-client.txt b/latest/_sources/pubsub-client.txt index 858d2b7332b7..c5e70e6ae683 100644 --- a/latest/_sources/pubsub-client.txt +++ b/latest/_sources/pubsub-client.txt @@ -1,13 +1,13 @@ Pub/Sub Client ============== -.. automodule:: gcloud.pubsub.client +.. automodule:: google.cloud.pubsub.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.pubsub.connection +.. automodule:: google.cloud.pubsub.connection :members: :show-inheritance: diff --git a/latest/_sources/pubsub-iam.txt b/latest/_sources/pubsub-iam.txt index 6cdfaf266cf5..a939f4d3a8c8 100644 --- a/latest/_sources/pubsub-iam.txt +++ b/latest/_sources/pubsub-iam.txt @@ -1,7 +1,7 @@ IAM Policy ~~~~~~~~~~ -.. automodule:: gcloud.pubsub.iam +.. automodule:: google.cloud.pubsub.iam :members: :member-order: bysource :show-inheritance: diff --git a/latest/_sources/pubsub-message.txt b/latest/_sources/pubsub-message.txt index 3b2561f87b9f..654c607d46b3 100644 --- a/latest/_sources/pubsub-message.txt +++ b/latest/_sources/pubsub-message.txt @@ -1,6 +1,6 @@ Message ~~~~~~~ -.. automodule:: gcloud.pubsub.message +.. automodule:: google.cloud.pubsub.message :members: :show-inheritance: diff --git a/latest/_sources/pubsub-subscription.txt b/latest/_sources/pubsub-subscription.txt index d92d43e57ad4..f242cb644e83 100644 --- a/latest/_sources/pubsub-subscription.txt +++ b/latest/_sources/pubsub-subscription.txt @@ -1,7 +1,7 @@ Subscriptions ~~~~~~~~~~~~~ -.. automodule:: gcloud.pubsub.subscription +.. automodule:: google.cloud.pubsub.subscription :members: :member-order: bysource :show-inheritance: diff --git a/latest/_sources/pubsub-topic.txt b/latest/_sources/pubsub-topic.txt index e2ddc3c04570..323d467a08ce 100644 --- a/latest/_sources/pubsub-topic.txt +++ b/latest/_sources/pubsub-topic.txt @@ -1,7 +1,7 @@ Topics ~~~~~~ -.. automodule:: gcloud.pubsub.topic +.. automodule:: google.cloud.pubsub.topic :members: :member-order: bysource :show-inheritance: diff --git a/latest/_sources/pubsub-usage.txt b/latest/_sources/pubsub-usage.txt index 9a7f7e7acf27..431f2784d050 100644 --- a/latest/_sources/pubsub-usage.txt +++ b/latest/_sources/pubsub-usage.txt @@ -4,24 +4,35 @@ Using the API Authentication / Configuration ------------------------------ -- Use :class:`Client <gcloud.pubsub.client.Client>` objects to configure +- Use :class:`Client <google.cloud.pubsub.client.Client>` objects to configure your applications. -- :class:`Client <gcloud.pubsub.client.Client>` objects hold both a ``project`` +- In addition to any authentication configuration, you should also set the + :envvar:`GOOGLE_CLOUD_PROJECT` environment variable for the project you'd like + to interact with. If you are Google App Engine or Google Compute Engine + this will be detected automatically. + +- The library now enables the ``gRPC`` transport for the pubsub API by + default, assuming that the required dependencies are installed and + importable. To *disable* this transport, set the + :envvar:`GOOGLE_CLOUD_DISABLE_GRPC` environment variable to a + non-empty string, e.g.: ``$ export GOOGLE_CLOUD_DISABLE_GRPC=true``. + +- :class:`Client <google.cloud.pubsub.client.Client>` objects hold both a ``project`` and an authenticated connection to the PubSub service. - The authentication credentials can be implicitly determined from the environment or directly via - :meth:`from_service_account_json <gcloud.pubsub.client.Client.from_service_account_json>` + :meth:`from_service_account_json <google.cloud.pubsub.client.Client.from_service_account_json>` and - :meth:`from_service_account_p12 <gcloud.pubsub.client.Client.from_service_account_p12>`. + :meth:`from_service_account_p12 <google.cloud.pubsub.client.Client.from_service_account_p12>`. -- After setting ``GOOGLE_APPLICATION_CREDENTIALS`` and ``GCLOUD_PROJECT`` - environment variables, create a :class:`Client <gcloud.pubsub.client.Client>` +- After setting ``GOOGLE_APPLICATION_CREDENTIALS`` and ``GOOGLE_CLOUD_PROJECT`` + environment variables, create a :class:`Client <google.cloud.pubsub.client.Client>` .. doctest:: - >>> from gcloud import pubsub + >>> from google.cloud import pubsub >>> client = pubsub.Client() diff --git a/latest/_sources/resource-manager-api.txt b/latest/_sources/resource-manager-api.txt index 6caf53e93b1d..87fab63c27f2 100644 --- a/latest/_sources/resource-manager-api.txt +++ b/latest/_sources/resource-manager-api.txt @@ -20,7 +20,7 @@ Here's a quick example of the full life-cycle: .. code-block:: python - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() >>> # List all projects you have access to @@ -69,7 +69,7 @@ provided by the `Google Cloud SDK`_, which you can get by running .. _Google Cloud SDK: http://cloud.google.com/sdk -Once you run that command, ``gcloud-python`` will automatically pick up the +Once you run that command, ``google-cloud-python`` will automatically pick up the credentials, and you can use the "automatic discovery" feature of the library. Start by authenticating: @@ -82,5 +82,5 @@ And then simply create a client: .. code-block:: python - >>> from gcloud import resource_manager + >>> from google.cloud import resource_manager >>> client = resource_manager.Client() diff --git a/latest/_sources/resource-manager-client.txt b/latest/_sources/resource-manager-client.txt index 4c354b25bec5..0eb5837f2623 100644 --- a/latest/_sources/resource-manager-client.txt +++ b/latest/_sources/resource-manager-client.txt @@ -5,13 +5,13 @@ Client ------ -.. automodule:: gcloud.resource_manager.client +.. automodule:: google.cloud.resource_manager.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.resource_manager.connection +.. automodule:: google.cloud.resource_manager.connection :members: :show-inheritance: diff --git a/latest/_sources/resource-manager-project.txt b/latest/_sources/resource-manager-project.txt index eee478c2533f..e6f8a90be298 100644 --- a/latest/_sources/resource-manager-project.txt +++ b/latest/_sources/resource-manager-project.txt @@ -1,6 +1,6 @@ Projects ~~~~~~~~ -.. automodule:: gcloud.resource_manager.project +.. automodule:: google.cloud.resource_manager.project :members: :show-inheritance: diff --git a/latest/_sources/storage-acl.txt b/latest/_sources/storage-acl.txt index 6c2e60b55042..f1f7d028907d 100644 --- a/latest/_sources/storage-acl.txt +++ b/latest/_sources/storage-acl.txt @@ -1,6 +1,6 @@ ACL ~~~ -.. automodule:: gcloud.storage.acl +.. automodule:: google.cloud.storage.acl :members: :show-inheritance: diff --git a/latest/_sources/storage-batch.txt b/latest/_sources/storage-batch.txt index 15d96186975c..992dd9349157 100644 --- a/latest/_sources/storage-batch.txt +++ b/latest/_sources/storage-batch.txt @@ -1,6 +1,6 @@ Batches ~~~~~~~ -.. automodule:: gcloud.storage.batch +.. automodule:: google.cloud.storage.batch :members: :show-inheritance: diff --git a/latest/_sources/storage-blobs.txt b/latest/_sources/storage-blobs.txt index e6a157771a1d..18fb773629d6 100644 --- a/latest/_sources/storage-blobs.txt +++ b/latest/_sources/storage-blobs.txt @@ -1,6 +1,6 @@ Blobs / Objects ~~~~~~~~~~~~~~~ -.. automodule:: gcloud.storage.blob +.. automodule:: google.cloud.storage.blob :members: :show-inheritance: diff --git a/latest/_sources/storage-buckets.txt b/latest/_sources/storage-buckets.txt index 44ed1118040d..e03b1f8b9b56 100644 --- a/latest/_sources/storage-buckets.txt +++ b/latest/_sources/storage-buckets.txt @@ -1,6 +1,6 @@ Buckets ~~~~~~~ -.. automodule:: gcloud.storage.bucket +.. automodule:: google.cloud.storage.bucket :members: :show-inheritance: diff --git a/latest/_sources/storage-client.txt b/latest/_sources/storage-client.txt index 9fb00e91f92f..9c73e60c0e3e 100644 --- a/latest/_sources/storage-client.txt +++ b/latest/_sources/storage-client.txt @@ -1,13 +1,13 @@ Storage Client ============== -.. automodule:: gcloud.storage.client +.. automodule:: google.cloud.storage.client :members: :show-inheritance: Connection ~~~~~~~~~~ -.. automodule:: gcloud.storage.connection +.. automodule:: google.cloud.storage.connection :members: :show-inheritance: diff --git a/latest/_sources/translate-client.txt b/latest/_sources/translate-client.txt index 14c76ba9d6c0..c724c9f2fe03 100644 --- a/latest/_sources/translate-client.txt +++ b/latest/_sources/translate-client.txt @@ -1,7 +1,7 @@ Translate Client ================ -.. automodule:: gcloud.translate.client +.. automodule:: google.cloud.translate.client :members: :undoc-members: :show-inheritance: @@ -9,7 +9,7 @@ Translate Client Connection ~~~~~~~~~~ -.. automodule:: gcloud.translate.connection +.. automodule:: google.cloud.translate.connection :members: :undoc-members: :show-inheritance: diff --git a/latest/_sources/translate-usage.txt b/latest/_sources/translate-usage.txt index f79f7e07d1c5..501a402f9cef 100644 --- a/latest/_sources/translate-usage.txt +++ b/latest/_sources/translate-usage.txt @@ -10,15 +10,15 @@ paid service. See the `Pricing`_ and `FAQ`_ pages for details. Authentication / Configuration ------------------------------ -- Use :class:`~gcloud.translate.client.Client` objects to configure +- Use :class:`~google.cloud.translate.client.Client` objects to configure your applications. -- :class:`~gcloud.translate.client.Client` objects hold both a ``key`` +- :class:`~google.cloud.translate.client.Client` objects hold both a ``key`` and a connection to the Translate service. - **An API key is required for Translate.** See `Identifying your application to Google`_ for details. This is - significantly different than the other clients in ``gcloud-python``. + significantly different than the other clients in ``google-cloud-python``. Methods ------- @@ -27,7 +27,7 @@ To create a client: .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key') By default, the client targets English when doing detections @@ -36,20 +36,20 @@ well: .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key', target_language='es') The Google Translate API has three supported methods, and they map to three methods on a client: -:meth:`~gcloud.translate.client.Client.get_languages`, -:meth:`~gcloud.translate.client.Client.detect_language` and -:meth:`~gcloud.translate.client.Client.translate`. +:meth:`~google.cloud.translate.client.Client.get_languages`, +:meth:`~google.cloud.translate.client.Client.detect_language` and +:meth:`~google.cloud.translate.client.Client.translate`. To get a list of languages supported by Google Translate .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key') >>> client.get_languages() [ @@ -64,7 +64,7 @@ To detect the language that some given text is written in: .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key') >>> client.detect_language(['Me llamo', 'I am']) [ @@ -87,7 +87,7 @@ To translate text: .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key') >>> client.translate('koszula') { @@ -100,7 +100,7 @@ or to use a non-default target language: .. code:: - >>> from gcloud import translate + >>> from google.cloud import translate >>> client = translate.Client('my-api-key') >>> client.translate(['Me llamo Jeff', 'My name is Jeff'], ... target_language='de') diff --git a/latest/_sources/vision-client.txt b/latest/_sources/vision-client.txt new file mode 100644 index 000000000000..f7f9fd259ce4 --- /dev/null +++ b/latest/_sources/vision-client.txt @@ -0,0 +1,18 @@ +Vision Client +============= + +Client +~~~~~~ + +.. automodule:: google.cloud.vision.client + :members: + :undoc-members: + :show-inheritance: + +Connection +~~~~~~~~~~ + +.. automodule:: google.cloud.vision.connection + :members: + :undoc-members: + :show-inheritance: diff --git a/latest/_sources/vision-feature.txt b/latest/_sources/vision-feature.txt new file mode 100644 index 000000000000..325b0caad717 --- /dev/null +++ b/latest/_sources/vision-feature.txt @@ -0,0 +1,10 @@ +Vision Feature +============== + +Feature +~~~~~~~ + +.. automodule:: google.cloud.vision.feature + :members: + :undoc-members: + :show-inheritance: diff --git a/latest/_sources/vision-image.txt b/latest/_sources/vision-image.txt new file mode 100644 index 000000000000..e22be7161d22 --- /dev/null +++ b/latest/_sources/vision-image.txt @@ -0,0 +1,10 @@ +Vision Image +============ + +Image +~~~~~ + +.. automodule:: google.cloud.vision.image + :members: + :undoc-members: + :show-inheritance: diff --git a/latest/_sources/vision-usage.txt b/latest/_sources/vision-usage.txt new file mode 100644 index 000000000000..461ee9e19e27 --- /dev/null +++ b/latest/_sources/vision-usage.txt @@ -0,0 +1,233 @@ +Using the Vision API +==================== + +Authentication and Configuration +-------------------------------- + +- For an overview of authentication in ``google-cloud-python``, + see :doc:`gcloud-auth`. + +- In addition to any authentication configuration, you should also set the + :envvar:`GOOGLE_CLOUD_PROJECT` environment variable for the project you'd like + to interact with. If the GOOGLE_CLOUD_PROJECT environment variable is not present, + the project ID from JSON file credentials is used. + + If you are using Google App Engine or Google Compute Engine + this will be detected automatically. + +- After configuring your environment, create a + :class:`Client <google.cloud.vision.client.Client>` + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + +or pass in ``credentials`` and ``project`` explicitly + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client(project='my-project', credentials=creds) + +Annotating an Image +------------------- + +Annotate a single image +~~~~~~~~~~~~~~~~~~~~~~~ + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.png') + >>> faces = image.detect_faces(limit=10) + +Annotate multiple images +~~~~~~~~~~~~~~~~~~~~~~~~ + +.. code-block:: python + + >>> first_image = client.image('./image.jpg') + >>> second_image = client.image('gs://my-storage-bucket/image2.jpg') + >>> with client.batch(): + ... labels = first_image.detect_labels() + ... faces = second_image.detect_faces(limit=10) + +or + +.. code-block:: python + + >>> images = [] + >>> images.append(client.image('./image.jpg')) + >>> images.append(client.image('gs://my-storage-bucket/image2.jpg')) + >>> faces = client.detect_faces_multi(images, limit=10) + +No results returned +~~~~~~~~~~~~~~~~~~~ + +Failing annotations return no results for the feature type requested. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> logos = image.detect_logos(limit=10) + >>> logos + [] + + +Manual Detection +~~~~~~~~~~~~~~~~ + +You can call the detection method manually. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('gs://my-test-bucket/image.jpg') + >>> faces = image.detect(type=vision.FACE_DETECTION, limit=10) + +Face Detection +~~~~~~~~~~~~~~ + +Detecting a face or faces in an image. +For a list of the possible facial landmarks +see: https://cloud.google.com/vision/reference/rest/v1/images/annotate#type_1 + + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> faces = image.detect_faces(limit=10) + >>> faces[0].landmarks[0].type + 'LEFT_EYE' + >>> faces[0].landmarks[0].position.x + 1301.2404 + >>> faces[0].detection_confidence + 0.9863683 + >>> faces[0].joy_likelihood + 0.54453093 + >>> faces[0].anger_likelihood + 0.02545464 + + + +Label Detection +~~~~~~~~~~~~~~~ + +Image labels are a way to help categorize the contents of an image. +If you have an image with a car, person and a dog it, label detection will +attempt to identify those objects. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> labels = image.detect_labels(limit=3) + >>> labels[0].description + 'automobile' + >>> labels[0].score + 0.9863683 + + +Landmark Detection +~~~~~~~~~~~~~~~~~~ + +The API will attemtp to detect landmarks such as Mount Rushmore and +the Sydney Opera House. The API will also provide their known geographical +locations if available. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> landmarks = image.detect_landmarks() + >>> landmarks[0].description + 'Sydney Opera House' + >>> landmarks[0].locations[0].latitude + -33.857123 + >>> landmarks[0].locations[0].longitude + 151.213921 + >>> landmarks[0].bounding_poly.vertices[0].x + 78 + >>> landmarks[0].bounding_poly.vertices[0].y + 162 + +Logo Detection +~~~~~~~~~~~~~~ + +Google Vision can also attempt to detect company and brand logos in images. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> logos = image.detect_logos(limit=1) + >>> results.logos[0].description + 'Google' + >>> logos[0].score + 0.9795432 + >>> logos[0].bounding_poly.vertices[0].x + 78 + >>> logos[0].bounding_poly.vertices[0].y + 62 + +Safe Search Detection +~~~~~~~~~~~~~~~~~~~~~ + +Detecting safe search properties of an image. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> safe_search = image.detect_safe_search() + >>> safe_search.adult + 'VERY_UNLIKELY' + >>> safe_search.medical + 'UNLIKELY' + +Text Detection +~~~~~~~~~~~~~~ + +Detecting text with ORC from an image. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> text = image.detect_text() + >>> text.locale + 'en' + >>> text.description + 'the full text of the image.' + +Image Properties +~~~~~~~~~~~~~~~~ + +Detecting image color properties. + +.. code-block:: python + + >>> from google.cloud import vision + >>> client = vision.Client() + >>> image = client.image('./image.jpg') + >>> colors = image.detect_properties() + >>> colors[0].red + 244 + >>> colors[0].blue + 134 + >>> colors[0].score + 0.65519291 + >>> colors[0].pixel_fraction + 0.758658 diff --git a/latest/_static/alabaster.css b/latest/_static/alabaster.css deleted file mode 100644 index 517cb43e58b2..000000000000 --- a/latest/_static/alabaster.css +++ /dev/null @@ -1,607 +0,0 @@ - - - - - - - - - - - - - - - - - -@import url("basic.css"); - -/* -- page layout ----------------------------------------------------------- */ - -body { - font-family: 'goudy old style', 'minion pro', 'bell mt', Georgia, 'Hiragino Mincho Pro', serif; - font-size: 17px; - background-color: white; - color: #000; - margin: 0; - padding: 0; -} - - -div.document { - width: 940px; - margin: 30px auto 0 auto; -} - -div.documentwrapper { - float: left; - width: 100%; -} - -div.bodywrapper { - margin: 0 0 0 220px; -} - -div.sphinxsidebar { - width: 220px; - font-size: 14px; - line-height: 1.5; -} - -hr { - border: 1px solid #B1B4B6; -} - -div.body { - background-color: #ffffff; - color: #3E4349; - padding: 0 30px 0 30px; -} - -div.body > .section { - text-align: left; -} - -div.footer { - width: 940px; - margin: 20px auto 30px auto; - font-size: 14px; - color: #888; - text-align: right; -} - -div.footer a { - color: #888; -} - -p.caption { - font-family: ; - font-size: inherit; -} - - -div.relations { - display: none; -} - - -div.sphinxsidebar a { - color: #444; - text-decoration: none; - border-bottom: 1px dotted #999; -} - -div.sphinxsidebar a:hover { - border-bottom: 1px solid #999; -} - -div.sphinxsidebarwrapper { - padding: 18px 10px; -} - -div.sphinxsidebarwrapper p.logo { - padding: 0; - margin: -10px 0 0 0px; - text-align: center; -} - -div.sphinxsidebarwrapper h1.logo { - margin-top: -10px; - text-align: center; - margin-bottom: 5px; - text-align: left; -} - -div.sphinxsidebarwrapper h1.logo-name { - margin-top: 0px; -} - -div.sphinxsidebarwrapper p.blurb { - margin-top: 0; - font-style: normal; -} - -div.sphinxsidebar h3, -div.sphinxsidebar h4 { - font-family: 'Garamond', 'Georgia', serif; - color: #444; - font-size: 24px; - font-weight: normal; - margin: 0 0 5px 0; - padding: 0; -} - -div.sphinxsidebar h4 { - font-size: 20px; -} - -div.sphinxsidebar h3 a { - color: #444; -} - -div.sphinxsidebar p.logo a, -div.sphinxsidebar h3 a, -div.sphinxsidebar p.logo a:hover, -div.sphinxsidebar h3 a:hover { - border: none; -} - -div.sphinxsidebar p { - color: #555; - margin: 10px 0; -} - -div.sphinxsidebar ul { - margin: 10px 0; - padding: 0; - color: #000; -} - -div.sphinxsidebar ul li.toctree-l1 > a { - font-size: 120%; -} - -div.sphinxsidebar ul li.toctree-l2 > a { - font-size: 110%; -} - -div.sphinxsidebar input { - border: 1px solid #CCC; - font-family: 'goudy old style', 'minion pro', 'bell mt', Georgia, 'Hiragino Mincho Pro', serif; - font-size: 1em; -} - -div.sphinxsidebar hr { - border: none; - height: 1px; - color: #AAA; - background: #AAA; - - text-align: left; - margin-left: 0; - width: 50%; -} - -/* -- body styles ----------------------------------------------------------- */ - -a { - color: #004B6B; - text-decoration: underline; -} - -a:hover { - color: #6D4100; - text-decoration: underline; -} - -div.body h1, -div.body h2, -div.body h3, -div.body h4, -div.body h5, -div.body h6 { - font-family: 'Garamond', 'Georgia', serif; - font-weight: normal; - margin: 30px 0px 10px 0px; - padding: 0; -} - -div.body h1 { margin-top: 0; padding-top: 0; font-size: 240%; } -div.body h2 { font-size: 180%; } -div.body h3 { font-size: 150%; } -div.body h4 { font-size: 130%; } -div.body h5 { font-size: 100%; } -div.body h6 { font-size: 100%; } - -a.headerlink { - color: #DDD; - padding: 0 4px; - text-decoration: none; -} - -a.headerlink:hover { - color: #444; - background: #EAEAEA; -} - -div.body p, div.body dd, div.body li { - line-height: 1.4em; -} - -div.admonition { - margin: 20px 0px; - padding: 10px 30px; - background-color: #FCC; - border: 1px solid #FAA; -} - -div.admonition tt.xref, div.admonition a tt { - border-bottom: 1px solid #fafafa; -} - -dd div.admonition { - margin-left: -60px; - padding-left: 60px; -} - -div.admonition p.admonition-title { - font-family: 'Garamond', 'Georgia', serif; - font-weight: normal; - font-size: 24px; - margin: 0 0 10px 0; - padding: 0; - line-height: 1; -} - -div.admonition p.last { - margin-bottom: 0; -} - -div.highlight { - background-color: white; -} - -dt:target, .highlight { - background: #FAF3E8; -} - -div.note { - background-color: #EEE; - border: 1px solid #CCC; -} - -div.seealso { - background-color: #EEE; - border: 1px solid #CCC; -} - -div.topic { - background-color: #eee; -} - -p.admonition-title { - display: inline; -} - -p.admonition-title:after { - content: ":"; -} - -pre, tt, code { - font-family: 'Consolas', 'Menlo', 'Deja Vu Sans Mono', 'Bitstream Vera Sans Mono', monospace; - font-size: 0.9em; -} - -.hll { - background-color: #FFC; - margin: 0 -12px; - padding: 0 12px; - display: block; -} - -img.screenshot { -} - -tt.descname, tt.descclassname, code.descname, code.descclassname { - font-size: 0.95em; -} - -tt.descname, code.descname { - padding-right: 0.08em; -} - -img.screenshot { - -moz-box-shadow: 2px 2px 4px #eee; - -webkit-box-shadow: 2px 2px 4px #eee; - box-shadow: 2px 2px 4px #eee; -} - -table.docutils { - border: 1px solid #888; - -moz-box-shadow: 2px 2px 4px #eee; - -webkit-box-shadow: 2px 2px 4px #eee; - box-shadow: 2px 2px 4px #eee; -} - -table.docutils td, table.docutils th { - border: 1px solid #888; - padding: 0.25em 0.7em; -} - -table.field-list, table.footnote { - border: none; - -moz-box-shadow: none; - -webkit-box-shadow: none; - box-shadow: none; -} - -table.footnote { - margin: 15px 0; - width: 100%; - border: 1px solid #EEE; - background: #FDFDFD; - font-size: 0.9em; -} - -table.footnote + table.footnote { - margin-top: -15px; - border-top: none; -} - -table.field-list th { - padding: 0 0.8em 0 0; -} - -table.field-list td { - padding: 0; -} - -table.field-list p { - margin-bottom: 0.8em; -} - -table.footnote td.label { - width: .1px; - padding: 0.3em 0 0.3em 0.5em; -} - -table.footnote td { - padding: 0.3em 0.5em; -} - -dl { - margin: 0; - padding: 0; -} - -dl dd { - margin-left: 30px; -} - -blockquote { - margin: 0 0 0 30px; - padding: 0; -} - -ul, ol { - /* Matches the 30px from the narrow-screen "li > ul" selector below */ - margin: 10px 0 10px 30px; - padding: 0; -} - -pre { - background: #EEE; - padding: 7px 30px; - margin: 15px 0px; - line-height: 1.3em; -} - -dl pre, blockquote pre, li pre { - margin-left: 0; - padding-left: 30px; -} - -dl dl pre { - margin-left: -90px; - padding-left: 90px; -} - -tt, code { - background-color: #ecf0f3; - color: #222; - /* padding: 1px 2px; */ -} - -tt.xref, code.xref, a tt { - background-color: #FBFBFB; - border-bottom: 1px solid white; -} - -a.reference { - text-decoration: none; - border-bottom: 1px dotted #004B6B; -} - -/* Don't put an underline on images */ -a.image-reference, a.image-reference:hover { - border-bottom: none; -} - -a.reference:hover { - border-bottom: 1px solid #6D4100; -} - -a.footnote-reference { - text-decoration: none; - font-size: 0.7em; - vertical-align: top; - border-bottom: 1px dotted #004B6B; -} - -a.footnote-reference:hover { - border-bottom: 1px solid #6D4100; -} - -a:hover tt, a:hover code { - background: #EEE; -} - - -@media screen and (max-width: 870px) { - - div.sphinxsidebar { - display: none; - } - - div.document { - width: 100%; - - } - - div.documentwrapper { - margin-left: 0; - margin-top: 0; - margin-right: 0; - margin-bottom: 0; - } - - div.bodywrapper { - margin-top: 0; - margin-right: 0; - margin-bottom: 0; - margin-left: 0; - } - - ul { - margin-left: 0; - } - - li > ul { - /* Matches the 30px from the "ul, ol" selector above */ - margin-left: 30px; - } - - .document { - width: auto; - } - - .footer { - width: auto; - } - - .bodywrapper { - margin: 0; - } - - .footer { - width: auto; - } - - .github { - display: none; - } - - - -} - - - -@media screen and (max-width: 875px) { - - body { - margin: 0; - padding: 20px 30px; - } - - div.documentwrapper { - float: none; - background: white; - } - - div.sphinxsidebar { - display: block; - float: none; - width: 102.5%; - margin: 50px -30px -20px -30px; - padding: 10px 20px; - background: #333; - color: #FFF; - } - - div.sphinxsidebar h3, div.sphinxsidebar h4, div.sphinxsidebar p, - div.sphinxsidebar h3 a { - color: white; - } - - div.sphinxsidebar a { - color: #AAA; - } - - div.sphinxsidebar p.logo { - display: none; - } - - div.document { - width: 100%; - margin: 0; - } - - div.footer { - display: none; - } - - div.bodywrapper { - margin: 0; - } - - div.body { - min-height: 0; - padding: 0; - } - - .rtd_doc_footer { - display: none; - } - - .document { - width: auto; - } - - .footer { - width: auto; - } - - .footer { - width: auto; - } - - .github { - display: none; - } -} - - -/* misc. */ - -.revsys-inline { - display: none!important; -} - -/* Make nested-list/multi-paragraph items look better in Releases changelog - * pages. Without this, docutils' magical list fuckery causes inconsistent - * formatting between different release sub-lists. - */ -div#changelog > div.section > ul > li > p:only-child { - margin-bottom: 0; -} - -/* Hide fugly table cell borders in ..bibliography:: directive output */ -table.docutils.citation, table.docutils.citation td, table.docutils.citation th { - border: none; - /* Below needed in some edge cases; if not applied, bottom shadows appear */ - -moz-box-shadow: none; - -webkit-box-shadow: none; - box-shadow: none; -} \ No newline at end of file diff --git a/latest/_static/css/badge_only.css b/latest/_static/css/badge_only.css new file mode 100644 index 000000000000..7e17fb148c63 --- /dev/null +++ b/latest/_static/css/badge_only.css @@ -0,0 +1,2 @@ +.fa:before{-webkit-font-smoothing:antialiased}.clearfix{*zoom:1}.clearfix:before,.clearfix:after{display:table;content:""}.clearfix:after{clear:both}@font-face{font-family:FontAwesome;font-weight:normal;font-style:normal;src:url("../font/fontawesome_webfont.eot");src:url("../font/fontawesome_webfont.eot?#iefix") format("embedded-opentype"),url("../font/fontawesome_webfont.woff") format("woff"),url("../font/fontawesome_webfont.ttf") format("truetype"),url("../font/fontawesome_webfont.svg#FontAwesome") format("svg")}.fa:before{display:inline-block;font-family:FontAwesome;font-style:normal;font-weight:normal;line-height:1;text-decoration:inherit}a .fa{display:inline-block;text-decoration:inherit}li .fa{display:inline-block}li .fa-large:before,li .fa-large:before{width:1.875em}ul.fas{list-style-type:none;margin-left:2em;text-indent:-0.8em}ul.fas li .fa{width:0.8em}ul.fas li .fa-large:before,ul.fas li .fa-large:before{vertical-align:baseline}.fa-book:before{content:""}.icon-book:before{content:""}.fa-caret-down:before{content:""}.icon-caret-down:before{content:""}.fa-caret-up:before{content:""}.icon-caret-up:before{content:""}.fa-caret-left:before{content:""}.icon-caret-left:before{content:""}.fa-caret-right:before{content:""}.icon-caret-right:before{content:""}.rst-versions{position:fixed;bottom:0;left:0;width:300px;color:#fcfcfc;background:#1f1d1d;border-top:solid 10px #343131;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;z-index:400}.rst-versions a{color:#2980B9;text-decoration:none}.rst-versions .rst-badge-small{display:none}.rst-versions .rst-current-version{padding:12px;background-color:#272525;display:block;text-align:right;font-size:90%;cursor:pointer;color:#27AE60;*zoom:1}.rst-versions .rst-current-version:before,.rst-versions .rst-current-version:after{display:table;content:""}.rst-versions .rst-current-version:after{clear:both}.rst-versions .rst-current-version .fa{color:#fcfcfc}.rst-versions .rst-current-version .fa-book{float:left}.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version.rst-out-of-date{background-color:#E74C3C;color:#fff}.rst-versions .rst-current-version.rst-active-old-version{background-color:#F1C40F;color:#000}.rst-versions.shift-up .rst-other-versions{display:block}.rst-versions .rst-other-versions{font-size:90%;padding:12px;color:gray;display:none}.rst-versions .rst-other-versions hr{display:block;height:1px;border:0;margin:20px 0;padding:0;border-top:solid 1px #413d3d}.rst-versions .rst-other-versions dd{display:inline-block;margin:0}.rst-versions .rst-other-versions dd a{display:inline-block;padding:6px;color:#fcfcfc}.rst-versions.rst-badge{width:auto;bottom:20px;right:20px;left:auto;border:none;max-width:300px}.rst-versions.rst-badge .icon-book{float:none}.rst-versions.rst-badge .fa-book{float:none}.rst-versions.rst-badge.shift-up .rst-current-version{text-align:right}.rst-versions.rst-badge.shift-up .rst-current-version .fa-book{float:left}.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge .rst-current-version{width:auto;height:30px;line-height:30px;padding:0 6px;display:block;text-align:center}@media screen and (max-width: 768px){.rst-versions{width:85%;display:none}.rst-versions.shift{display:block}img{width:100%;height:auto}} +/*# sourceMappingURL=badge_only.css.map */ diff --git a/latest/_static/css/main.css b/latest/_static/css/main.css deleted file mode 100644 index 6b2e6d0e1903..000000000000 --- a/latest/_static/css/main.css +++ /dev/null @@ -1,1432 +0,0 @@ -/*! HTML5 Boilerplate v4.3.0 | MIT License | http://h5bp.com/ */ - -/* - * What follows is the result of much research on cross-browser styling. - * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal, - * Kroc Camen, and the H5BP dev community and team. - */ - -/* ========================================================================== - Base styles: opinionated defaults - ========================================================================== */ - -html, -button, -input, -select, -textarea { - color: #222; -} - -html { - font-size: 1em; - line-height: 1.4; -} - -*[id]:before { - display: block; - content: " "; - margin-top: -70px; - height: 70px; - visibility: hidden; -} - -/* - * Remove text-shadow in selection highlight: h5bp.com/i - * These selection rule sets have to be separate. - * Customize the background color to match your design. - */ - -::-moz-selection { - background: #b3d4fc; - text-shadow: none; -} - -::selection { - background: #b3d4fc; - text-shadow: none; -} - -/* - * A better looking default horizontal rule - */ - -hr { - display: block; - height: 1px; - border: 0; - border-top: 1px solid #ccc; - margin: 1em 0; - padding: 0; -} - -/* - * Remove the gap between images, videos, audio and canvas and the bottom of - * their containers: h5bp.com/i/440 - */ - -audio, -canvas, -img, -video { - vertical-align: middle; -} - -/* - * Remove default fieldset styles. - */ - -fieldset { - border: 0; - margin: 0; - padding: 0; -} - -/* - * Allow only vertical resizing of textareas. - */ - -textarea { - resize: vertical; -} - -/* ========================================================================== - Browse Happy prompt - ========================================================================== */ - -.browsehappy { - margin: 0.2em 0; - background: #ccc; - color: #000; - padding: 0.2em 0; -} - -/* ========================================================================== - Author's custom styles - ========================================================================== */ - -html { - height: 100%; - background: #fff; -} - -body { - min-height: 100%; - font-family: 'Roboto', sans-serif; - color: #5d6061; -} - - -/* Global Elements - ========================================================================== */ - -pre { - border: 1px solid rgba(0,0,0,0.2); - /* Border Radius */ - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - background: #fff; - font-size: 0.9em; - line-height: 1.6em; -} - -pre, -code { - font-family: Monaco, 'Droid Sans Mono', monospace !important; -} - -img { - max-width: 100%; -} - -h1, h2, h3, h4, h5, h6 { - font-weight: normal; - font-weight: 300; -} - -h2, h3 { - color: #4285f4; -} - -/* Header - ========================================================================== */ - -.page-header, -.hero-banner { - background: #4285f4; - color: #fff; -} - -.page-header { - position: relative; - padding: 1em; -} - -.page-header.fixed { - position: fixed; - z-index: 2; - top: 0; - width: 100%; - padding: 0; -} - -/* - Logo -*/ - -.logo { - margin: 0; - width: 13em; - font-size: 1em; - line-height: normal; -} - -.page-header.fixed .logo { - width: auto; -} - -.page-header.fixed a { - color: #fff; - text-decoration: none; -} - -.page-header.fixed a:hover { - opacity: 0.4; -} - -.page-header.fixed .logo img { - position: relative; - top: -0.2em; - width: 2em; - margin: 0 0.5em; -} - -.page-header.fixed .gcloud { - display: inline-block; - padding: 0.4em 0 0.6em 0.6em; - border-left: 1px solid rgba(255,255,255,0.2); - font-family: 'Open Sans', sans-serif; - font-weight: 300; - font-size: 1.4em; -} - -/* - Menu -*/ - -.nav-current { - display: block; - position: absolute; - top: 1.2em; - right: 1em; - width: 24px; - height: 20px; - background: url(../images/icon-menu.svg) no-repeat; - text-indent: -90000px; - cursor: pointer; -} - -.page-header.fixed .nav-current { - top: 1em; -} - -.menu { - display: none; - position: absolute; - top: 3.6em; - right: 0; - width: 100%; - margin: 0; - padding: 0; - background: #2570ec; - /* Box Shadow */ - -webkit-box-shadow: 5px 5px 8px rgba(0,16,41,0.3); - -moz-box-shadow: 5px 5px 8px rgba(0,16,41,0.3); - box-shadow: 5px 5px 8px rgba(0,16,41,0.3); - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.page-header.fixed .menu { - top: 3.3em; -} - -.menu a { - display: block; - padding: 1em; - border-top: 1px solid rgba(255,255,255,0.2); - color: #fff; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.menu a:hover { - background: #1a65e0; -} - -.menu-icon { - margin-right: 0.5em; -} - -/* - Open Menu - */ - -.main-nav.open .nav-current { - opacity: 0.4; -} - -.main-nav.open .menu { - display: block; -} - - - -/* Home Content - ========================================================================== */ - -/* - Main Content -*/ - -.main { - font-size: 0.9em; - line-height: 1.8em; -} - -.container { - padding: 2.8em 2em; -} - -.block-title { - margin-top: 0; - font-size: 1.6em; -} - -/* - Hero Banner -*/ - -.hero-banner h1 { - margin: 0 0 0.6em; - font-family: 'Open Sans', sans-serif; - font-size: 3.5em; - font-weight: 300; -} - -.hero-banner p { - margin-bottom: 2.2em; - font-size: 0.9em; - line-height: 1.6em; -} - -.hero-banner h2 { - margin-bottom: 0.2em; - font-size: 1.3em; -} - -.hero-banner pre { - margin: 0; - padding: 1em; - border: none; - background: #2a74ed; -} - -/* - What is it? - */ -.about pre { - font-size: 110%; -} - -/* - Featuring -*/ - -.featuring .block-title { - text-align: center; -} - -.featuring p { - font-size: 0.9em; - line-height: 1.6em; -} - -.featuring-links { - list-style: none; - margin: 0; - margin-bottom: -1em; - padding: 0; -} - -.btn, -.ext-link { - display: block; -} - -.btn { - padding: 1em; - border: none; - /* Border Radius */ - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - background: #db4437; - color: #fff; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.btn:hover { - background: #f24f41; -} - -.btn img { - margin-right: 0.5em; -} - -.featuring-links .btn { - margin-bottom: 1em; - padding: 1.5em; - font-size: 1.1em; - text-align: center; -} - -.featuring-links .btn img { - width: 2em; -} - -.btn-docs img { - background-color: #fff; - border: 1px solid transparent; - -webkit-border-radius: 80px; - -moz-border-radius: 80px; - border-radius: 80px; - padding: 4px; - width: 40px; - /* Transitions */ - -webkit-transition: all 0.5s ease; - -moz-transition: all 0.5s ease; - -ms-transition: all 0.5s ease; - -o-transition: all 0.5s ease; - transition: all 0.5s ease; -} - -.btn-docs:hover img { - border: 1px solid #ccc; - transform: rotate(135deg); - -webkit-box-shadow: 4px 4px 4px rgba(0, 0, 0, .3); - -moz-box-shadow: 4px 4px 4px rgba(0, 0, 0, .3); - box-shadow: 4px 4px 4px rgba(0, 0, 0, .3); -} - -.btn-docs:active img { - -webkit-box-shadow: 4px 4px 4px rgba(0, 0, 0, .5); - -moz-box-shadow: 4px 4px 4px rgba(0, 0, 0, .5); - box-shadow: 4px 4px 4px rgba(0, 0, 0, .5); -} - -.ext-link { - display: block; - padding: 1em; - border-bottom: 1px solid rgba(0,0,0,0.1); - color: #5d6061; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.featuring-links li:last-child .ext-link { - border-bottom: none; -} - -.ext-link:hover { - background: #f6f6f6; -} - -.ext-link img { - opacity: 0.5; - margin-right: 0.5em; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.ext-link:hover img { - opacity: 0.7; -} - -.pagination { - margin: 2em 0 0; - padding: 0; - list-style: none; - text-decoration: none; - text-align: center; -} - -.pagination li { - display: inline-block; - width: 1em; - height: 1em; - margin: 0 0.2em; -} - -.pagination a { - display: block; - width: 100%; - height: 100%; - border: 1px solid rgba(0,0,0,0.2); - /* Border Radius */ - -webkit-border-radius: 50%; - -moz-border-radius: 50%; - border-radius: 50%; - background: #fff; - text-indent: -90000px; -} - -.pagination a:hover { - background: rgba(0,0,0,0.1); -} - -.pagination .current, -.pagination .current:hover { - background: #db4437; - border-color: #db4437; -} - -/* - About -*/ - -.about { - background: #eee; -} - -.about h4 { - margin-bottom: 0; - font-size: 1.2em; - font-weight: bold; - color: #4285f4; -} - -/* - FAQ -*/ - -.faq-btn, -.faq-questions { - max-width: 20em; - margin: 0; - padding: 0; - list-style: none; -} - -.faq-btn { - position: relative; - margin-bottom: 2em; -} - -.faq-btn .current { - background: #e6eefc url(../images/icon-dropdown-faq.svg) 95% 50% no-repeat; -} - -.faq-btn .current, -.faq-questions a { - display: block; - padding: 1em; - border: 1px solid #a7bfe8; - color: #2b70e2; - cursor: pointer; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.faq-questions { - display: none; - position: absolute; - width: 100%; -} - -.faq-questions a { - border-top: none; - background: #e6eefc; -} - -.faq-questions a:hover { - background: #fcfdff; -} - -/* - Open FAQ button - */ - -.faq-btn.open .current { - background-color: #c6d7f6; - /* Box Shadow */ - -webkit-box-shadow: inset 0 0 10px rgba(16,71,163,0.3); - -moz-box-shadow: inset 0 0 10px rgba(16,71,163,0.3); - box-shadow: inset 0 0 10px rgba(16,71,163,0.3); - color: #1555bf; -} - -.faq-btn.open .faq-questions { - display: block; -} - - -/* Docs Content - ========================================================================== */ - -.admonition { - background-color: #f8f8f8; -} - -.admonition p.admonition-title { - background-color: #e5ecf9; - font-weight: bold; - padding: 8px; -} - -.admonition pre { - background-color: #eeeeee !important; -} - -.admonition p { - padding: 0 8px; -} - -.admonition .last { - padding-bottom: 8px; -} - -.docs-header { - position: relative; - padding: 7em 2em 4em; - background: #f8f8f8; - border-bottom: 1px solid rgba(0,0,0,0.05); -} - -.headerlink { - display: none; - padding: 0 7px; - left: -24px; - text-decoration: none; -} - -.headerlink:hover { - color: #505050; - display: block; -} - -h2 .headerlink { - color: #2b70e2; -} - -h2 .headerlink:hover { - color: #4285f4; - display: block; -} - -.highlight pre { - background: #f8f8f8; -} - -.method-heading { - position: relative; -} - -.param-optional .param-types { - font-style: italic; -} - -.param-optional .param-description:before { - content: "optional. "; - color: #aaa; - font-style: italic; -} - -.sub-heading { - color: #5d6061; - margin: 0 !important; -} - -.toggler { - float: left; - min-width: 15px; - margin: auto; -} - -.toggle { - cursor: pointer; -} - -.viewcode-link { - float: right; -} - -/* - Page Title -*/ - -.page-title { - margin: 0; - font-family: 'Open Sans', sans-serif; - font-weight: 300; - color: #4285f4; - font-size: 2.4em; - line-height: 1em; -} - -/* - Versions -*/ - -.versions { - display: inline-block; - margin-top: 2em; -} - -.versions span, -.versions a { - display: block; -} - -.v-current { - font-size: 1.2em; - color: #2b70e2; -} - -.v-current i { - font-size: 0.7em; -} - -.v-btn { - padding: 0.5em; - border: 1px solid rgba(0,0,0,0.2); - background: rgba(0,0,0,0.07); - font-size: 0.8em; - color: rgba(0,0,0,0.6); - text-align: center; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.v-btn:hover { - background: rgba(0,0,0,0.02); -} - -.v-btn img { - position: relative; - top: -0.1em; - opacity: 0.3; -} - -#file-issue { - position: absolute; - right: 20px; - top: 20px; - display: none; -} - -#file-issue-secondary { - margin-top: 1em; - display: inline-block; -} - -.v-list { - color: rgba(0,0,0,0.2); -} - -.v-list a { - color: #4285f4; - text-decoration: none; -} - -.v-list a:hover { - text-decoration: underline; -} - -/* - Content - */ - - -.content { - padding: 1em 2em; -} - -.content pre, -.field-list { - border: 0; - margin-bottom: 2em; -} - -.content h2, .content h3, .content h4, .content h5, .content h6 { - margin: 2em 0 0.5em; -} - -.content>h2:first-child { - margin-top: 1em; -} - -/* - Tables - */ - -.field-list { - text-align: left; -} - -.field-list th, -.field-list td { - padding: 0.3em 1em; - border: 1px solid #cfcfcf; -} - -.field-list th[scope="col"] { - border-color: #2264d0; - background: #4285f4; - color: #fff; -} - -.field-name { - background: #f6f6f6; - font-weight: 'bold'; -} - -/* - Side Nav - */ - - .side-nav { - padding-bottom: 3em; - background: #efefef; - } - -.side-nav a { - display: block; - padding: 0.3em 2em; - color: #5d6061; - text-decoration: none; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.side-nav a:hover { - background: rgba(255,255,255,0.7); -} - -.side-nav .current .current, -.side-nav .current .current:hover { - background: #e2e2e2; -} - -.side-nav ul { - margin: 0; - padding: 0; -} - -.side-nav ul ul a { - padding-left: 4em; -} - -.side-nav .external-links { - margin-top: 2em; -} - -.side-nav > ul > li.toctree-l1 { - padding-left: 2em; -} - -p.caption { - padding-left: 2em; -} - -span.caption-text { - font-weight: bold; -} - -.external-links img { - margin-right: 0.3em; - opacity: 0.3; - /* Transitions */ - -webkit-transition: all 0.3s ease; - -moz-transition: all 0.3s ease; - -ms-transition: all 0.3s ease; - -o-transition: all 0.3s ease; - transition: all 0.3s ease; -} - -.external-links a:hover img { - opacity: 0.6; -} - - - -/* ========================================================================== - Helper classes - ========================================================================== */ - -/* - * Image replacement - */ - -.ir { - background-color: transparent; - border: 0; - overflow: hidden; - /* IE 6/7 fallback */ - *text-indent: -9999px; -} - -.ir:before { - content: ""; - display: block; - width: 0; - height: 150%; -} - -/* - * Hide from both screenreaders and browsers: h5bp.com/u - */ - -.hidden { - display: none !important; - visibility: hidden; -} - -/* - * Hide only visually, but have it available for screenreaders: h5bp.com/v - */ - -.visuallyhidden { - border: 0; - clip: rect(0 0 0 0); - height: 1px; - margin: -1px; - overflow: hidden; - padding: 0; - position: absolute; - width: 1px; -} - -/* - * Extends the .visuallyhidden class to allow the element to be focusable - * when navigated to via the keyboard: h5bp.com/p - */ - -.visuallyhidden.focusable:active, -.visuallyhidden.focusable:focus { - clip: auto; - height: auto; - margin: 0; - overflow: visible; - position: static; - width: auto; -} - -/* - * Hide visually and from screenreaders, but maintain layout - */ - -.invisible { - visibility: hidden; -} - -/* - * Clearfix: contain floats - * - * For modern browsers - * 1. The space content is one way to avoid an Opera bug when the - * `contenteditable` attribute is included anywhere else in the document. - * Otherwise it causes space to appear at the top and bottom of elements - * that receive the `clearfix` class. - * 2. The use of `table` rather than `block` is only necessary if using - * `:before` to contain the top-margins of child elements. - */ - -.clearfix:before, -.clearfix:after { - content: " "; /* 1 */ - display: table; /* 2 */ -} - -.clearfix:after { - clear: both; -} - -/* - * For IE 6/7 only - * Include this rule to trigger hasLayout and contain floats. - */ - -.clearfix { - *zoom: 1; -} - -/* ========================================================================== - EXAMPLE Media Queries for Responsive Design. - These examples override the primary ('mobile first') styles. - Modify as content requires. - ========================================================================== */ - -@media only screen and (min-width: 37em) { - - /* - Main - */ - - .main { - font-size: 1em; - } - - /* - Featuring - */ - - .featuring-links li:first-child { - display: block; - } - - .featuring-links { - text-align: center; - } - - .featuring-links li { - display: inline-block; - } - - .featuring-links .btn { - display: inline-block; - padding: 1em 2.4em; - } - - .ext-link { - display: inline-block; - padding: 0.8em 1.2em; - border: none; - /* Border Radius */ - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - } - - .pagination li { - width: 0.6em; - height: 0.6em; - } - -} - -@media only screen and (min-width: 50em) { - - /* - Header - */ - - .page-header { - padding: 1.6em; - } - - .page-header.fixed .logo img { - margin: 0 0.8em; - } - - .page-header.fixed .gcloud { - padding: 0 0 0 1em; - height: 70px; - line-height: 70px; - } - - #file-issue { - display: inline; - } - - #file-issue-secondary { - display: none; - } - - /* - Logo - */ - - .logo { - width: 280px; - } - - /* - Menu - */ - - .main-nav { - position: absolute; - top: 1.2em; - left: 21.5em; - } - - .page-header.fixed .main-nav { - top: 0; - left: 11.5em; - } - - .nav-current { - position: relative; - top: 0; - left: 0; - padding: 0.8em 1.6em; - width: 150px; - height: auto; - border: 1px solid rgba(255,255,255,0.4); - background: url(../images/icon-dropdown.svg) 90% 50% no-repeat; - text-indent: 0; - } - - .page-header.fixed .nav-current { - top: 0; - padding: 0 1.6em; - height: 70px; - border: 1px solid rgba(255,255,255,0.2); - border-top: none; - border-bottom: none; - line-height: 70px; - } - - .nav-current:hover { - background-color: rgba(255,255,255,0.1); - } - - .menu { - top: 3em; - left: 0; - } - - .menu a { - padding: 1.2em 1.5em; - } - - .page-header.fixed .menu { - top: 70px; - } - - /* - Docs Header - */ - - .docs-header { - padding-top: 7.7em; - } - - .versions { - position: absolute; - top: 6em; - right: 2em; - margin: 0; - } - - .v-btn { - font-size: 0.7em; - line-height: normal; - } - - /* - Content - */ - - .container, - .content { - width: 80%; - margin: 0 auto; - padding: 2em 0; - } - - /* - Hero Banner - */ - - .hero-banner { - padding: 2em 0; - } - - .hero-banner h1 { - font-size: 5em; - margin-bottom: 0.8em; - } - - .hero-banner p { - font-size: 1em; - line-height: 2em; - } - - /* - Featuring - */ - - .featuring .block-title { - margin-bottom: 1.4em; - } - -} - -@media only screen and (min-width: 60em) { - - /* - Content - */ - - .container { - width: 90%; - max-width: 1020px; - font-size: 0.9em; - } - - .col { - width: 46%; - } - - .col-left { - float: left; - } - - .col-right { - float: right; - } - - .block-title { - font-size: 2em; - } - - /* - Hero Banner - */ - - .hero-banner { - padding-bottom: 0; - } - - .hero-banner .col-right { - padding-top: 3.6em; - } - - .hero-banner h1 { - font-size: 5.6em; - } - - .hero-banner p { - font-size: 1.1em; - } - - .hero-banner h2 { - font-size: 1.3em; - margin-bottom: 0.4em; - } - - .hero-banner pre { - font-size: 1.1em; - padding: 1em 1.5em; - } - - /* - Featuring - */ - - .featuring { - text-align: center; - } - - .featuring-links li { - font-size: 1em; - } - - .featuring-links li:first-child { - display: inline-block; - } - - .featuring-links .btn { - margin-right: 0.5em; - } - - .ext-link { - padding: 0.5em 1.2em; - } - - .featuring p { - max-width: 80%; - margin: 0 auto; - font-size: 1em; - } - - /* - About - */ - - .about .col-right { - padding-top: 2.4em; - } - - /* - FAQ - */ - - .faq .answer { - -moz-column-count: 2; - -moz-column-gap: 50px; - -webkit-column-count: 2; - -webkit-column-gap: 50px; - column-count: 2; - column-gap: 50px; - } - - /* - Docs Page - */ - - .lang-page { - background: url(../images/lang-bg.png) repeat-y; - } - - .docs-header { - margin-left: 240px; - } - - .content { - width: 100%; - max-width: 1070px; - padding-left: 290px; - padding-right: 2em; - /* Box Sizing */ - -webkit-box-sizing: border-box; - -moz-box-sizing: border-box; - box-sizing: border-box; - margin: 0; - font-size: 0.9em; - } - - .side-nav { - position: absolute; - top: 0; - left: 0; - width: 240px; - padding-top: 7.7em; - font-size: 0.9em; - } - - .side-nav a { - padding-left: 2.5em; - } - -} - -@media print, - (-o-min-device-pixel-ratio: 5/4), - (-webkit-min-device-pixel-ratio: 1.25), - (min-resolution: 120dpi) { - /* Style adjustments for high resolution devices */ -} - -/* ========================================================================== - Print styles. - Inlined to avoid required HTTP connection: h5bp.com/r - ========================================================================== */ - -@media print { - * { - background: transparent !important; - color: #000 !important; /* Black prints faster: h5bp.com/s */ - box-shadow: none !important; - text-shadow: none !important; - } - - a, - a:visited { - text-decoration: underline; - } - - a[href]:after { - content: " (" attr(href) ")"; - } - - abbr[title]:after { - content: " (" attr(title) ")"; - } - - /* - * Don't show links for images, or javascript/internal links - */ - - .ir a:after, - a[href^="javascript:"]:after, - a[href^="#"]:after { - content: ""; - } - - pre, - blockquote { - border: 1px solid #999; - page-break-inside: avoid; - } - - thead { - display: table-header-group; /* h5bp.com/t */ - } - - tr, - img { - page-break-inside: avoid; - } - - img { - max-width: 100% !important; - } - - @page { - margin: 0.5cm; - } - - p, - h2, - h3 { - orphans: 3; - widows: 3; - } - - h2, - h3 { - page-break-after: avoid; - } -} diff --git a/latest/_static/css/normalize.css b/latest/_static/css/normalize.css deleted file mode 100644 index 42e24d6880b5..000000000000 --- a/latest/_static/css/normalize.css +++ /dev/null @@ -1,527 +0,0 @@ -/*! normalize.css v1.1.3 | MIT License | git.io/normalize */ - -/* ========================================================================== - HTML5 display definitions - ========================================================================== */ - -/** - * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. - */ - -article, -aside, -details, -figcaption, -figure, -footer, -header, -hgroup, -main, -nav, -section, -summary { - display: block; -} - -/** - * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. - */ - -audio, -canvas, -video { - display: inline-block; - *display: inline; - *zoom: 1; -} - -/** - * Prevent modern browsers from displaying `audio` without controls. - * Remove excess height in iOS 5 devices. - */ - -audio:not([controls]) { - display: none; - height: 0; -} - -/** - * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4. - * Known issue: no IE 6 support. - */ - -[hidden] { - display: none; -} - -/* ========================================================================== - Base - ========================================================================== */ - -/** - * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using - * `em` units. - * 2. Prevent iOS text size adjust after orientation change, without disabling - * user zoom. - */ - -html { - font-size: 100%; /* 1 */ - -ms-text-size-adjust: 100%; /* 2 */ - -webkit-text-size-adjust: 100%; /* 2 */ -} - -/** - * Address `font-family` inconsistency between `textarea` and other form - * elements. - */ - -html, -button, -input, -select, -textarea { - font-family: sans-serif; -} - -/** - * Address margins handled incorrectly in IE 6/7. - */ - -body { - margin: 0; -} - -/* ========================================================================== - Links - ========================================================================== */ - -/** - * Address `outline` inconsistency between Chrome and other browsers. - */ - -a:focus { - outline: thin dotted; -} - -/** - * Improve readability when focused and also mouse hovered in all browsers. - */ - -a:active, -a:hover { - outline: 0; -} - -/* ========================================================================== - Typography - ========================================================================== */ - -/** - * Address font sizes and margins set differently in IE 6/7. - * Address font sizes within `section` and `article` in Firefox 4+, Safari 5, - * and Chrome. - */ - -h1 { - font-size: 2em; - margin: 0.67em 0; -} - -h2 { - font-size: 1.5em; - margin: 0.83em 0; -} - -h3 { - font-size: 1.17em; - margin: 1em 0; -} - -h4 { - font-size: 1em; - margin: 1.33em 0; -} - -h5 { - font-size: 0.83em; - margin: 1.67em 0; -} - -h6 { - font-size: 0.67em; - margin: 2.33em 0; -} - -/** - * Address styling not present in IE 7/8/9, Safari 5, and Chrome. - */ - -abbr[title] { - border-bottom: 1px dotted; -} - -/** - * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. - */ - -b, -strong { - font-weight: bold; -} - -blockquote { - margin: 1em 40px; -} - -/** - * Address styling not present in Safari 5 and Chrome. - */ - -dfn { - font-style: italic; -} - -/** - * Address differences between Firefox and other browsers. - * Known issue: no IE 6/7 normalization. - */ - -hr { - -moz-box-sizing: content-box; - box-sizing: content-box; - height: 0; -} - -/** - * Address styling not present in IE 6/7/8/9. - */ - -mark { - background: #ff0; - color: #000; -} - -/** - * Address margins set differently in IE 6/7. - */ - -p, -pre { - margin: 1em 0; -} - -/** - * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. - */ - -code, -kbd, -pre, -samp { - font-family: monospace, serif; - _font-family: 'courier new', monospace; - font-size: 1em; -} - -/** - * Improve readability of pre-formatted text in all browsers. - */ - -pre { - white-space: pre; - white-space: pre-wrap; - word-wrap: break-word; -} - -/** - * Address CSS quotes not supported in IE 6/7. - */ - -q { - quotes: none; -} - -/** - * Address `quotes` property not supported in Safari 4. - */ - -q:before, -q:after { - content: ''; - content: none; -} - -/** - * Address inconsistent and variable font size in all browsers. - */ - -small { - font-size: 80%; -} - -/** - * Prevent `sub` and `sup` affecting `line-height` in all browsers. - */ - -sub, -sup { - font-size: 75%; - line-height: 0; - position: relative; - vertical-align: baseline; -} - -sup { - top: -0.5em; -} - -sub { - bottom: -0.25em; -} - -/* ========================================================================== - Lists - ========================================================================== */ - -/** - * Address margins set differently in IE 6/7. - */ - -dl, -menu, -ol, -ul { - margin: 1em 0; -} - -dd { - margin: 0 0 0 40px; -} - -/** - * Address paddings set differently in IE 6/7. - */ - -menu, -ol, -ul { - padding: 0 0 0 40px; -} - -/** - * Correct list images handled incorrectly in IE 7. - */ - -nav ul, -nav ol { - list-style: none; - list-style-image: none; -} - -/* ========================================================================== - Embedded content - ========================================================================== */ - -/** - * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3. - * 2. Improve image quality when scaled in IE 7. - */ - -img { - border: 0; /* 1 */ - -ms-interpolation-mode: bicubic; /* 2 */ -} - -/** - * Correct overflow displayed oddly in IE 9. - */ - -svg:not(:root) { - overflow: hidden; -} - -/* ========================================================================== - Figures - ========================================================================== */ - -/** - * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. - */ - -figure { - margin: 0; -} - -/* ========================================================================== - Forms - ========================================================================== */ - -/** - * Correct margin displayed oddly in IE 6/7. - */ - -form { - margin: 0; -} - -/** - * Define consistent border, margin, and padding. - */ - -fieldset { - border: 1px solid #c0c0c0; - margin: 0 2px; - padding: 0.35em 0.625em 0.75em; -} - -/** - * 1. Correct color not being inherited in IE 6/7/8/9. - * 2. Correct text not wrapping in Firefox 3. - * 3. Correct alignment displayed oddly in IE 6/7. - */ - -legend { - border: 0; /* 1 */ - padding: 0; - white-space: normal; /* 2 */ - *margin-left: -7px; /* 3 */ -} - -/** - * 1. Correct font size not being inherited in all browsers. - * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5, - * and Chrome. - * 3. Improve appearance and consistency in all browsers. - */ - -button, -input, -select, -textarea { - font-size: 100%; /* 1 */ - margin: 0; /* 2 */ - vertical-align: baseline; /* 3 */ - *vertical-align: middle; /* 3 */ -} - -/** - * Address Firefox 3+ setting `line-height` on `input` using `!important` in - * the UA stylesheet. - */ - -button, -input { - line-height: normal; -} - -/** - * Address inconsistent `text-transform` inheritance for `button` and `select`. - * All other form control elements do not inherit `text-transform` values. - * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+. - * Correct `select` style inheritance in Firefox 4+ and Opera. - */ - -button, -select { - text-transform: none; -} - -/** - * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` - * and `video` controls. - * 2. Correct inability to style clickable `input` types in iOS. - * 3. Improve usability and consistency of cursor style between image-type - * `input` and others. - * 4. Remove inner spacing in IE 7 without affecting normal text inputs. - * Known issue: inner spacing remains in IE 6. - */ - -button, -html input[type="button"], /* 1 */ -input[type="reset"], -input[type="submit"] { - -webkit-appearance: button; /* 2 */ - cursor: pointer; /* 3 */ - *overflow: visible; /* 4 */ -} - -/** - * Re-set default cursor for disabled elements. - */ - -button[disabled], -html input[disabled] { - cursor: default; -} - -/** - * 1. Address box sizing set to content-box in IE 8/9. - * 2. Remove excess padding in IE 8/9. - * 3. Remove excess padding in IE 7. - * Known issue: excess padding remains in IE 6. - */ - -input[type="checkbox"], -input[type="radio"] { - box-sizing: border-box; /* 1 */ - padding: 0; /* 2 */ - *height: 13px; /* 3 */ - *width: 13px; /* 3 */ -} - -/** - * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. - * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome - * (include `-moz` to future-proof). - */ - -input[type="search"] { - -webkit-appearance: textfield; /* 1 */ - -moz-box-sizing: content-box; - -webkit-box-sizing: content-box; /* 2 */ - box-sizing: content-box; -} - -/** - * Remove inner padding and search cancel button in Safari 5 and Chrome - * on OS X. - */ - -input[type="search"]::-webkit-search-cancel-button, -input[type="search"]::-webkit-search-decoration { - -webkit-appearance: none; -} - -/** - * Remove inner padding and border in Firefox 3+. - */ - -button::-moz-focus-inner, -input::-moz-focus-inner { - border: 0; - padding: 0; -} - -/** - * 1. Remove default vertical scrollbar in IE 6/7/8/9. - * 2. Improve readability and alignment in all browsers. - */ - -textarea { - overflow: auto; /* 1 */ - vertical-align: top; /* 2 */ -} - -/* ========================================================================== - Tables - ========================================================================== */ - -/** - * Remove most spacing between table cells. - */ - -table { - border-collapse: collapse; - border-spacing: 0; -} diff --git a/latest/_static/css/theme.css b/latest/_static/css/theme.css new file mode 100644 index 000000000000..7be93399a4f5 --- /dev/null +++ b/latest/_static/css/theme.css @@ -0,0 +1,5 @@ +*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}audio:not([controls]){display:none}[hidden]{display:none}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}a:hover,a:active{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:bold}blockquote{margin:0}dfn{font-style:italic}ins{background:#ff9;color:#000;text-decoration:none}mark{background:#ff0;color:#000;font-style:italic;font-weight:bold}pre,code,.rst-content tt,.rst-content code,kbd,samp{font-family:monospace,serif;_font-family:"courier new",monospace;font-size:1em}pre{white-space:pre}q{quotes:none}q:before,q:after{content:"";content:none}small{font-size:85%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}ul,ol,dl{margin:0;padding:0;list-style:none;list-style-image:none}li{list-style:none}dd{margin:0}img{border:0;-ms-interpolation-mode:bicubic;vertical-align:middle;max-width:100%}svg:not(:root){overflow:hidden}figure{margin:0}form{margin:0}fieldset{border:0;margin:0;padding:0}label{cursor:pointer}legend{border:0;*margin-left:-7px;padding:0;white-space:normal}button,input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}button,input{line-height:normal}button,input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button;*overflow:visible}button[disabled],input[disabled]{cursor:default}input[type="checkbox"],input[type="radio"]{box-sizing:border-box;padding:0;*width:13px;*height:13px}input[type="search"]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}input[type="search"]::-webkit-search-decoration,input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top;resize:vertical}table{border-collapse:collapse;border-spacing:0}td{vertical-align:top}.chromeframe{margin:0.2em 0;background:#ccc;color:#000;padding:0.2em 0}.ir{display:block;border:0;text-indent:-999em;overflow:hidden;background-color:transparent;background-repeat:no-repeat;text-align:left;direction:ltr;*line-height:0}.ir br{display:none}.hidden{display:none !important;visibility:hidden}.visuallyhidden{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.visuallyhidden.focusable:active,.visuallyhidden.focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}.invisible{visibility:hidden}.relative{position:relative}big,small{font-size:100%}@media print{html,body,section{background:none !important}*{box-shadow:none !important;text-shadow:none !important;filter:none !important;-ms-filter:none !important}a,a:visited{text-decoration:underline}.ir a:after,a[href^="javascript:"]:after,a[href^="#"]:after{content:""}pre,blockquote{page-break-inside:avoid}thead{display:table-header-group}tr,img{page-break-inside:avoid}img{max-width:100% !important}@page{margin:0.5cm}p,h2,.rst-content .toctree-wrapper p.caption,h3{orphans:3;widows:3}h2,.rst-content .toctree-wrapper p.caption,h3{page-break-after:avoid}}.fa:before,.wy-menu-vertical li span.toctree-expand:before,.wy-menu-vertical li.on a span.toctree-expand:before,.wy-menu-vertical li.current>a span.toctree-expand:before,.rst-content .admonition-title:before,.rst-content h1 .headerlink:before,.rst-content h2 .headerlink:before,.rst-content h3 .headerlink:before,.rst-content h4 .headerlink:before,.rst-content h5 .headerlink:before,.rst-content h6 .headerlink:before,.rst-content dl dt .headerlink:before,.rst-content p.caption .headerlink:before,.rst-content tt.download span:first-child:before,.rst-content code.download span:first-child:before,.icon:before,.wy-dropdown .caret:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before,.wy-alert,.rst-content .note,.rst-content .attention,.rst-content .caution,.rst-content .danger,.rst-content .error,.rst-content .hint,.rst-content .important,.rst-content .tip,.rst-content .warning,.rst-content .seealso,.rst-content .admonition-todo,.btn,input[type="text"],input[type="password"],input[type="email"],input[type="url"],input[type="date"],input[type="month"],input[type="time"],input[type="datetime"],input[type="datetime-local"],input[type="week"],input[type="number"],input[type="search"],input[type="tel"],input[type="color"],select,textarea,.wy-menu-vertical li.on a,.wy-menu-vertical li.current>a,.wy-side-nav-search>a,.wy-side-nav-search .wy-dropdown>a,.wy-nav-top a{-webkit-font-smoothing:antialiased}.clearfix{*zoom:1}.clearfix:before,.clearfix:after{display:table;content:""}.clearfix:after{clear:both}/*! + * Font Awesome 4.2.0 by @davegandy - http://fontawesome.io - @fontawesome + * License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) + */@font-face{font-family:'FontAwesome';src:url("../fonts/fontawesome-webfont.eot?v=4.2.0");src:url("../fonts/fontawesome-webfont.eot?#iefix&v=4.2.0") format("embedded-opentype"),url("../fonts/fontawesome-webfont.woff?v=4.2.0") format("woff"),url("../fonts/fontawesome-webfont.ttf?v=4.2.0") format("truetype"),url("../fonts/fontawesome-webfont.svg?v=4.2.0#fontawesomeregular") format("svg");font-weight:normal;font-style:normal}.fa,.wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.current>a span.toctree-expand,.rst-content .admonition-title,.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content dl dt .headerlink,.rst-content p.caption .headerlink,.rst-content tt.download span:first-child,.rst-content code.download span:first-child,.icon{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333em;line-height:0.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14286em;width:2.14286em;top:0.14286em;text-align:center}.fa-li.fa-lg{left:-1.85714em}.fa-border{padding:.2em .25em .15em;border:solid 0.08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left,.wy-menu-vertical li span.pull-left.toctree-expand,.wy-menu-vertical li.on a span.pull-left.toctree-expand,.wy-menu-vertical li.current>a span.pull-left.toctree-expand,.rst-content .pull-left.admonition-title,.rst-content h1 .pull-left.headerlink,.rst-content h2 .pull-left.headerlink,.rst-content h3 .pull-left.headerlink,.rst-content h4 .pull-left.headerlink,.rst-content h5 .pull-left.headerlink,.rst-content h6 .pull-left.headerlink,.rst-content dl dt .pull-left.headerlink,.rst-content p.caption .pull-left.headerlink,.rst-content tt.download span.pull-left:first-child,.rst-content code.download span.pull-left:first-child,.pull-left.icon{margin-right:.3em}.fa.pull-right,.wy-menu-vertical li span.pull-right.toctree-expand,.wy-menu-vertical li.on a span.pull-right.toctree-expand,.wy-menu-vertical li.current>a span.pull-right.toctree-expand,.rst-content .pull-right.admonition-title,.rst-content h1 .pull-right.headerlink,.rst-content h2 .pull-right.headerlink,.rst-content h3 .pull-right.headerlink,.rst-content h4 .pull-right.headerlink,.rst-content h5 .pull-right.headerlink,.rst-content h6 .pull-right.headerlink,.rst-content dl dt .pull-right.headerlink,.rst-content p.caption .pull-right.headerlink,.rst-content tt.download span.pull-right:first-child,.rst-content code.download span.pull-right:first-child,.pull-right.icon{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0);-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:""}.fa-music:before{content:""}.fa-search:before,.icon-search:before{content:""}.fa-envelope-o:before{content:""}.fa-heart:before{content:""}.fa-star:before{content:""}.fa-star-o:before{content:""}.fa-user:before{content:""}.fa-film:before{content:""}.fa-th-large:before{content:""}.fa-th:before{content:""}.fa-th-list:before{content:""}.fa-check:before{content:""}.fa-remove:before,.fa-close:before,.fa-times:before{content:""}.fa-search-plus:before{content:""}.fa-search-minus:before{content:""}.fa-power-off:before{content:""}.fa-signal:before{content:""}.fa-gear:before,.fa-cog:before{content:""}.fa-trash-o:before{content:""}.fa-home:before,.icon-home:before{content:""}.fa-file-o:before{content:""}.fa-clock-o:before{content:""}.fa-road:before{content:""}.fa-download:before,.rst-content tt.download span:first-child:before,.rst-content code.download span:first-child:before{content:""}.fa-arrow-circle-o-down:before{content:""}.fa-arrow-circle-o-up:before{content:""}.fa-inbox:before{content:""}.fa-play-circle-o:before{content:""}.fa-rotate-right:before,.fa-repeat:before{content:""}.fa-refresh:before{content:""}.fa-list-alt:before{content:""}.fa-lock:before{content:""}.fa-flag:before{content:""}.fa-headphones:before{content:""}.fa-volume-off:before{content:""}.fa-volume-down:before{content:""}.fa-volume-up:before{content:""}.fa-qrcode:before{content:""}.fa-barcode:before{content:""}.fa-tag:before{content:""}.fa-tags:before{content:""}.fa-book:before,.icon-book:before{content:""}.fa-bookmark:before{content:""}.fa-print:before{content:""}.fa-camera:before{content:""}.fa-font:before{content:""}.fa-bold:before{content:""}.fa-italic:before{content:""}.fa-text-height:before{content:""}.fa-text-width:before{content:""}.fa-align-left:before{content:""}.fa-align-center:before{content:""}.fa-align-right:before{content:""}.fa-align-justify:before{content:""}.fa-list:before{content:""}.fa-dedent:before,.fa-outdent:before{content:""}.fa-indent:before{content:""}.fa-video-camera:before{content:""}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:""}.fa-pencil:before{content:""}.fa-map-marker:before{content:""}.fa-adjust:before{content:""}.fa-tint:before{content:""}.fa-edit:before,.fa-pencil-square-o:before{content:""}.fa-share-square-o:before{content:""}.fa-check-square-o:before{content:""}.fa-arrows:before{content:""}.fa-step-backward:before{content:""}.fa-fast-backward:before{content:""}.fa-backward:before{content:""}.fa-play:before{content:""}.fa-pause:before{content:""}.fa-stop:before{content:""}.fa-forward:before{content:""}.fa-fast-forward:before{content:""}.fa-step-forward:before{content:""}.fa-eject:before{content:""}.fa-chevron-left:before{content:""}.fa-chevron-right:before{content:""}.fa-plus-circle:before{content:""}.fa-minus-circle:before{content:""}.fa-times-circle:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before{content:""}.fa-check-circle:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before{content:""}.fa-question-circle:before{content:""}.fa-info-circle:before{content:""}.fa-crosshairs:before{content:""}.fa-times-circle-o:before{content:""}.fa-check-circle-o:before{content:""}.fa-ban:before{content:""}.fa-arrow-left:before{content:""}.fa-arrow-right:before{content:""}.fa-arrow-up:before{content:""}.fa-arrow-down:before{content:""}.fa-mail-forward:before,.fa-share:before{content:""}.fa-expand:before{content:""}.fa-compress:before{content:""}.fa-plus:before{content:""}.fa-minus:before{content:""}.fa-asterisk:before{content:""}.fa-exclamation-circle:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before,.rst-content .admonition-title:before{content:""}.fa-gift:before{content:""}.fa-leaf:before{content:""}.fa-fire:before,.icon-fire:before{content:""}.fa-eye:before{content:""}.fa-eye-slash:before{content:""}.fa-warning:before,.fa-exclamation-triangle:before{content:""}.fa-plane:before{content:""}.fa-calendar:before{content:""}.fa-random:before{content:""}.fa-comment:before{content:""}.fa-magnet:before{content:""}.fa-chevron-up:before{content:""}.fa-chevron-down:before{content:""}.fa-retweet:before{content:""}.fa-shopping-cart:before{content:""}.fa-folder:before{content:""}.fa-folder-open:before{content:""}.fa-arrows-v:before{content:""}.fa-arrows-h:before{content:""}.fa-bar-chart-o:before,.fa-bar-chart:before{content:""}.fa-twitter-square:before{content:""}.fa-facebook-square:before{content:""}.fa-camera-retro:before{content:""}.fa-key:before{content:""}.fa-gears:before,.fa-cogs:before{content:""}.fa-comments:before{content:""}.fa-thumbs-o-up:before{content:""}.fa-thumbs-o-down:before{content:""}.fa-star-half:before{content:""}.fa-heart-o:before{content:""}.fa-sign-out:before{content:""}.fa-linkedin-square:before{content:""}.fa-thumb-tack:before{content:""}.fa-external-link:before{content:""}.fa-sign-in:before{content:""}.fa-trophy:before{content:""}.fa-github-square:before{content:""}.fa-upload:before{content:""}.fa-lemon-o:before{content:""}.fa-phone:before{content:""}.fa-square-o:before{content:""}.fa-bookmark-o:before{content:""}.fa-phone-square:before{content:""}.fa-twitter:before{content:""}.fa-facebook:before{content:""}.fa-github:before,.icon-github:before{content:""}.fa-unlock:before{content:""}.fa-credit-card:before{content:""}.fa-rss:before{content:""}.fa-hdd-o:before{content:""}.fa-bullhorn:before{content:""}.fa-bell:before{content:""}.fa-certificate:before{content:""}.fa-hand-o-right:before{content:""}.fa-hand-o-left:before{content:""}.fa-hand-o-up:before{content:""}.fa-hand-o-down:before{content:""}.fa-arrow-circle-left:before,.icon-circle-arrow-left:before{content:""}.fa-arrow-circle-right:before,.icon-circle-arrow-right:before{content:""}.fa-arrow-circle-up:before{content:""}.fa-arrow-circle-down:before{content:""}.fa-globe:before{content:""}.fa-wrench:before{content:""}.fa-tasks:before{content:""}.fa-filter:before{content:""}.fa-briefcase:before{content:""}.fa-arrows-alt:before{content:""}.fa-group:before,.fa-users:before{content:""}.fa-chain:before,.fa-link:before,.icon-link:before{content:""}.fa-cloud:before{content:""}.fa-flask:before{content:""}.fa-cut:before,.fa-scissors:before{content:""}.fa-copy:before,.fa-files-o:before{content:""}.fa-paperclip:before{content:""}.fa-save:before,.fa-floppy-o:before{content:""}.fa-square:before{content:""}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:""}.fa-list-ul:before{content:""}.fa-list-ol:before{content:""}.fa-strikethrough:before{content:""}.fa-underline:before{content:""}.fa-table:before{content:""}.fa-magic:before{content:""}.fa-truck:before{content:""}.fa-pinterest:before{content:""}.fa-pinterest-square:before{content:""}.fa-google-plus-square:before{content:""}.fa-google-plus:before{content:""}.fa-money:before{content:""}.fa-caret-down:before,.wy-dropdown .caret:before,.icon-caret-down:before{content:""}.fa-caret-up:before{content:""}.fa-caret-left:before{content:""}.fa-caret-right:before{content:""}.fa-columns:before{content:""}.fa-unsorted:before,.fa-sort:before{content:""}.fa-sort-down:before,.fa-sort-desc:before{content:""}.fa-sort-up:before,.fa-sort-asc:before{content:""}.fa-envelope:before{content:""}.fa-linkedin:before{content:""}.fa-rotate-left:before,.fa-undo:before{content:""}.fa-legal:before,.fa-gavel:before{content:""}.fa-dashboard:before,.fa-tachometer:before{content:""}.fa-comment-o:before{content:""}.fa-comments-o:before{content:""}.fa-flash:before,.fa-bolt:before{content:""}.fa-sitemap:before{content:""}.fa-umbrella:before{content:""}.fa-paste:before,.fa-clipboard:before{content:""}.fa-lightbulb-o:before{content:""}.fa-exchange:before{content:""}.fa-cloud-download:before{content:""}.fa-cloud-upload:before{content:""}.fa-user-md:before{content:""}.fa-stethoscope:before{content:""}.fa-suitcase:before{content:""}.fa-bell-o:before{content:""}.fa-coffee:before{content:""}.fa-cutlery:before{content:""}.fa-file-text-o:before{content:""}.fa-building-o:before{content:""}.fa-hospital-o:before{content:""}.fa-ambulance:before{content:""}.fa-medkit:before{content:""}.fa-fighter-jet:before{content:""}.fa-beer:before{content:""}.fa-h-square:before{content:""}.fa-plus-square:before{content:""}.fa-angle-double-left:before{content:""}.fa-angle-double-right:before{content:""}.fa-angle-double-up:before{content:""}.fa-angle-double-down:before{content:""}.fa-angle-left:before{content:""}.fa-angle-right:before{content:""}.fa-angle-up:before{content:""}.fa-angle-down:before{content:""}.fa-desktop:before{content:""}.fa-laptop:before{content:""}.fa-tablet:before{content:""}.fa-mobile-phone:before,.fa-mobile:before{content:""}.fa-circle-o:before{content:""}.fa-quote-left:before{content:""}.fa-quote-right:before{content:""}.fa-spinner:before{content:""}.fa-circle:before{content:""}.fa-mail-reply:before,.fa-reply:before{content:""}.fa-github-alt:before{content:""}.fa-folder-o:before{content:""}.fa-folder-open-o:before{content:""}.fa-smile-o:before{content:""}.fa-frown-o:before{content:""}.fa-meh-o:before{content:""}.fa-gamepad:before{content:""}.fa-keyboard-o:before{content:""}.fa-flag-o:before{content:""}.fa-flag-checkered:before{content:""}.fa-terminal:before{content:""}.fa-code:before{content:""}.fa-mail-reply-all:before,.fa-reply-all:before{content:""}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:""}.fa-location-arrow:before{content:""}.fa-crop:before{content:""}.fa-code-fork:before{content:""}.fa-unlink:before,.fa-chain-broken:before{content:""}.fa-question:before{content:""}.fa-info:before{content:""}.fa-exclamation:before{content:""}.fa-superscript:before{content:""}.fa-subscript:before{content:""}.fa-eraser:before{content:""}.fa-puzzle-piece:before{content:""}.fa-microphone:before{content:""}.fa-microphone-slash:before{content:""}.fa-shield:before{content:""}.fa-calendar-o:before{content:""}.fa-fire-extinguisher:before{content:""}.fa-rocket:before{content:""}.fa-maxcdn:before{content:""}.fa-chevron-circle-left:before{content:""}.fa-chevron-circle-right:before{content:""}.fa-chevron-circle-up:before{content:""}.fa-chevron-circle-down:before{content:""}.fa-html5:before{content:""}.fa-css3:before{content:""}.fa-anchor:before{content:""}.fa-unlock-alt:before{content:""}.fa-bullseye:before{content:""}.fa-ellipsis-h:before{content:""}.fa-ellipsis-v:before{content:""}.fa-rss-square:before{content:""}.fa-play-circle:before{content:""}.fa-ticket:before{content:""}.fa-minus-square:before{content:""}.fa-minus-square-o:before,.wy-menu-vertical li.on a span.toctree-expand:before,.wy-menu-vertical li.current>a span.toctree-expand:before{content:""}.fa-level-up:before{content:""}.fa-level-down:before{content:""}.fa-check-square:before{content:""}.fa-pencil-square:before{content:""}.fa-external-link-square:before{content:""}.fa-share-square:before{content:""}.fa-compass:before{content:""}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:""}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:""}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:""}.fa-euro:before,.fa-eur:before{content:""}.fa-gbp:before{content:""}.fa-dollar:before,.fa-usd:before{content:""}.fa-rupee:before,.fa-inr:before{content:""}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:""}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:""}.fa-won:before,.fa-krw:before{content:""}.fa-bitcoin:before,.fa-btc:before{content:""}.fa-file:before{content:""}.fa-file-text:before{content:""}.fa-sort-alpha-asc:before{content:""}.fa-sort-alpha-desc:before{content:""}.fa-sort-amount-asc:before{content:""}.fa-sort-amount-desc:before{content:""}.fa-sort-numeric-asc:before{content:""}.fa-sort-numeric-desc:before{content:""}.fa-thumbs-up:before{content:""}.fa-thumbs-down:before{content:""}.fa-youtube-square:before{content:""}.fa-youtube:before{content:""}.fa-xing:before{content:""}.fa-xing-square:before{content:""}.fa-youtube-play:before{content:""}.fa-dropbox:before{content:""}.fa-stack-overflow:before{content:""}.fa-instagram:before{content:""}.fa-flickr:before{content:""}.fa-adn:before{content:""}.fa-bitbucket:before,.icon-bitbucket:before{content:""}.fa-bitbucket-square:before{content:""}.fa-tumblr:before{content:""}.fa-tumblr-square:before{content:""}.fa-long-arrow-down:before{content:""}.fa-long-arrow-up:before{content:""}.fa-long-arrow-left:before{content:""}.fa-long-arrow-right:before{content:""}.fa-apple:before{content:""}.fa-windows:before{content:""}.fa-android:before{content:""}.fa-linux:before{content:""}.fa-dribbble:before{content:""}.fa-skype:before{content:""}.fa-foursquare:before{content:""}.fa-trello:before{content:""}.fa-female:before{content:""}.fa-male:before{content:""}.fa-gittip:before{content:""}.fa-sun-o:before{content:""}.fa-moon-o:before{content:""}.fa-archive:before{content:""}.fa-bug:before{content:""}.fa-vk:before{content:""}.fa-weibo:before{content:""}.fa-renren:before{content:""}.fa-pagelines:before{content:""}.fa-stack-exchange:before{content:""}.fa-arrow-circle-o-right:before{content:""}.fa-arrow-circle-o-left:before{content:""}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:""}.fa-dot-circle-o:before{content:""}.fa-wheelchair:before{content:""}.fa-vimeo-square:before{content:""}.fa-turkish-lira:before,.fa-try:before{content:""}.fa-plus-square-o:before,.wy-menu-vertical li span.toctree-expand:before{content:""}.fa-space-shuttle:before{content:""}.fa-slack:before{content:""}.fa-envelope-square:before{content:""}.fa-wordpress:before{content:""}.fa-openid:before{content:""}.fa-institution:before,.fa-bank:before,.fa-university:before{content:""}.fa-mortar-board:before,.fa-graduation-cap:before{content:""}.fa-yahoo:before{content:""}.fa-google:before{content:""}.fa-reddit:before{content:""}.fa-reddit-square:before{content:""}.fa-stumbleupon-circle:before{content:""}.fa-stumbleupon:before{content:""}.fa-delicious:before{content:""}.fa-digg:before{content:""}.fa-pied-piper:before{content:""}.fa-pied-piper-alt:before{content:""}.fa-drupal:before{content:""}.fa-joomla:before{content:""}.fa-language:before{content:""}.fa-fax:before{content:""}.fa-building:before{content:""}.fa-child:before{content:""}.fa-paw:before{content:""}.fa-spoon:before{content:""}.fa-cube:before{content:""}.fa-cubes:before{content:""}.fa-behance:before{content:""}.fa-behance-square:before{content:""}.fa-steam:before{content:""}.fa-steam-square:before{content:""}.fa-recycle:before{content:""}.fa-automobile:before,.fa-car:before{content:""}.fa-cab:before,.fa-taxi:before{content:""}.fa-tree:before{content:""}.fa-spotify:before{content:""}.fa-deviantart:before{content:""}.fa-soundcloud:before{content:""}.fa-database:before{content:""}.fa-file-pdf-o:before{content:""}.fa-file-word-o:before{content:""}.fa-file-excel-o:before{content:""}.fa-file-powerpoint-o:before{content:""}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:""}.fa-file-zip-o:before,.fa-file-archive-o:before{content:""}.fa-file-sound-o:before,.fa-file-audio-o:before{content:""}.fa-file-movie-o:before,.fa-file-video-o:before{content:""}.fa-file-code-o:before{content:""}.fa-vine:before{content:""}.fa-codepen:before{content:""}.fa-jsfiddle:before{content:""}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:""}.fa-circle-o-notch:before{content:""}.fa-ra:before,.fa-rebel:before{content:""}.fa-ge:before,.fa-empire:before{content:""}.fa-git-square:before{content:""}.fa-git:before{content:""}.fa-hacker-news:before{content:""}.fa-tencent-weibo:before{content:""}.fa-qq:before{content:""}.fa-wechat:before,.fa-weixin:before{content:""}.fa-send:before,.fa-paper-plane:before{content:""}.fa-send-o:before,.fa-paper-plane-o:before{content:""}.fa-history:before{content:""}.fa-circle-thin:before{content:""}.fa-header:before{content:""}.fa-paragraph:before{content:""}.fa-sliders:before{content:""}.fa-share-alt:before{content:""}.fa-share-alt-square:before{content:""}.fa-bomb:before{content:""}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:""}.fa-tty:before{content:""}.fa-binoculars:before{content:""}.fa-plug:before{content:""}.fa-slideshare:before{content:""}.fa-twitch:before{content:""}.fa-yelp:before{content:""}.fa-newspaper-o:before{content:""}.fa-wifi:before{content:""}.fa-calculator:before{content:""}.fa-paypal:before{content:""}.fa-google-wallet:before{content:""}.fa-cc-visa:before{content:""}.fa-cc-mastercard:before{content:""}.fa-cc-discover:before{content:""}.fa-cc-amex:before{content:""}.fa-cc-paypal:before{content:""}.fa-cc-stripe:before{content:""}.fa-bell-slash:before{content:""}.fa-bell-slash-o:before{content:""}.fa-trash:before{content:""}.fa-copyright:before{content:""}.fa-at:before{content:""}.fa-eyedropper:before{content:""}.fa-paint-brush:before{content:""}.fa-birthday-cake:before{content:""}.fa-area-chart:before{content:""}.fa-pie-chart:before{content:""}.fa-line-chart:before{content:""}.fa-lastfm:before{content:""}.fa-lastfm-square:before{content:""}.fa-toggle-off:before{content:""}.fa-toggle-on:before{content:""}.fa-bicycle:before{content:""}.fa-bus:before{content:""}.fa-ioxhost:before{content:""}.fa-angellist:before{content:""}.fa-cc:before{content:""}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:""}.fa-meanpath:before{content:""}.fa,.wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.current>a span.toctree-expand,.rst-content .admonition-title,.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content dl dt .headerlink,.rst-content p.caption .headerlink,.rst-content tt.download span:first-child,.rst-content code.download span:first-child,.icon,.wy-dropdown .caret,.wy-inline-validate.wy-inline-validate-success .wy-input-context,.wy-inline-validate.wy-inline-validate-danger .wy-input-context,.wy-inline-validate.wy-inline-validate-warning .wy-input-context,.wy-inline-validate.wy-inline-validate-info .wy-input-context{font-family:inherit}.fa:before,.wy-menu-vertical li span.toctree-expand:before,.wy-menu-vertical li.on a span.toctree-expand:before,.wy-menu-vertical li.current>a span.toctree-expand:before,.rst-content .admonition-title:before,.rst-content h1 .headerlink:before,.rst-content h2 .headerlink:before,.rst-content h3 .headerlink:before,.rst-content h4 .headerlink:before,.rst-content h5 .headerlink:before,.rst-content h6 .headerlink:before,.rst-content dl dt .headerlink:before,.rst-content p.caption .headerlink:before,.rst-content tt.download span:first-child:before,.rst-content code.download span:first-child:before,.icon:before,.wy-dropdown .caret:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before{font-family:"FontAwesome";display:inline-block;font-style:normal;font-weight:normal;line-height:1;text-decoration:inherit}a .fa,a .wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li a span.toctree-expand,.wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.current>a span.toctree-expand,a .rst-content .admonition-title,.rst-content a .admonition-title,a .rst-content h1 .headerlink,.rst-content h1 a .headerlink,a .rst-content h2 .headerlink,.rst-content h2 a .headerlink,a .rst-content h3 .headerlink,.rst-content h3 a .headerlink,a .rst-content h4 .headerlink,.rst-content h4 a .headerlink,a .rst-content h5 .headerlink,.rst-content h5 a .headerlink,a .rst-content h6 .headerlink,.rst-content h6 a .headerlink,a .rst-content dl dt .headerlink,.rst-content dl dt a .headerlink,a .rst-content p.caption .headerlink,.rst-content p.caption a .headerlink,a .rst-content tt.download span:first-child,.rst-content tt.download a span:first-child,a .rst-content code.download span:first-child,.rst-content code.download a span:first-child,a .icon{display:inline-block;text-decoration:inherit}.btn .fa,.btn .wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li .btn span.toctree-expand,.btn .wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.on a .btn span.toctree-expand,.btn .wy-menu-vertical li.current>a span.toctree-expand,.wy-menu-vertical li.current>a .btn span.toctree-expand,.btn .rst-content .admonition-title,.rst-content .btn .admonition-title,.btn .rst-content h1 .headerlink,.rst-content h1 .btn .headerlink,.btn .rst-content h2 .headerlink,.rst-content h2 .btn .headerlink,.btn .rst-content h3 .headerlink,.rst-content h3 .btn .headerlink,.btn .rst-content h4 .headerlink,.rst-content h4 .btn .headerlink,.btn .rst-content h5 .headerlink,.rst-content h5 .btn .headerlink,.btn .rst-content h6 .headerlink,.rst-content h6 .btn .headerlink,.btn .rst-content dl dt .headerlink,.rst-content dl dt .btn .headerlink,.btn .rst-content p.caption .headerlink,.rst-content p.caption .btn .headerlink,.btn .rst-content tt.download span:first-child,.rst-content tt.download .btn span:first-child,.btn .rst-content code.download span:first-child,.rst-content code.download .btn span:first-child,.btn .icon,.nav .fa,.nav .wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li .nav span.toctree-expand,.nav .wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.on a .nav span.toctree-expand,.nav .wy-menu-vertical li.current>a span.toctree-expand,.wy-menu-vertical li.current>a .nav span.toctree-expand,.nav .rst-content .admonition-title,.rst-content .nav .admonition-title,.nav .rst-content h1 .headerlink,.rst-content h1 .nav .headerlink,.nav .rst-content h2 .headerlink,.rst-content h2 .nav .headerlink,.nav .rst-content h3 .headerlink,.rst-content h3 .nav .headerlink,.nav .rst-content h4 .headerlink,.rst-content h4 .nav .headerlink,.nav .rst-content h5 .headerlink,.rst-content h5 .nav .headerlink,.nav .rst-content h6 .headerlink,.rst-content h6 .nav .headerlink,.nav .rst-content dl dt .headerlink,.rst-content dl dt .nav .headerlink,.nav .rst-content p.caption .headerlink,.rst-content p.caption .nav .headerlink,.nav .rst-content tt.download span:first-child,.rst-content tt.download .nav span:first-child,.nav .rst-content code.download span:first-child,.rst-content code.download .nav span:first-child,.nav .icon{display:inline}.btn .fa.fa-large,.btn .wy-menu-vertical li span.fa-large.toctree-expand,.wy-menu-vertical li .btn span.fa-large.toctree-expand,.btn .rst-content .fa-large.admonition-title,.rst-content .btn .fa-large.admonition-title,.btn .rst-content h1 .fa-large.headerlink,.rst-content h1 .btn .fa-large.headerlink,.btn .rst-content h2 .fa-large.headerlink,.rst-content h2 .btn .fa-large.headerlink,.btn .rst-content h3 .fa-large.headerlink,.rst-content h3 .btn .fa-large.headerlink,.btn .rst-content h4 .fa-large.headerlink,.rst-content h4 .btn .fa-large.headerlink,.btn .rst-content h5 .fa-large.headerlink,.rst-content h5 .btn .fa-large.headerlink,.btn .rst-content h6 .fa-large.headerlink,.rst-content h6 .btn .fa-large.headerlink,.btn .rst-content dl dt .fa-large.headerlink,.rst-content dl dt .btn .fa-large.headerlink,.btn .rst-content p.caption .fa-large.headerlink,.rst-content p.caption .btn .fa-large.headerlink,.btn .rst-content tt.download span.fa-large:first-child,.rst-content tt.download .btn span.fa-large:first-child,.btn .rst-content code.download span.fa-large:first-child,.rst-content code.download .btn span.fa-large:first-child,.btn .fa-large.icon,.nav .fa.fa-large,.nav .wy-menu-vertical li span.fa-large.toctree-expand,.wy-menu-vertical li .nav span.fa-large.toctree-expand,.nav .rst-content .fa-large.admonition-title,.rst-content .nav .fa-large.admonition-title,.nav .rst-content h1 .fa-large.headerlink,.rst-content h1 .nav .fa-large.headerlink,.nav .rst-content h2 .fa-large.headerlink,.rst-content h2 .nav .fa-large.headerlink,.nav .rst-content h3 .fa-large.headerlink,.rst-content h3 .nav .fa-large.headerlink,.nav .rst-content h4 .fa-large.headerlink,.rst-content h4 .nav .fa-large.headerlink,.nav .rst-content h5 .fa-large.headerlink,.rst-content h5 .nav .fa-large.headerlink,.nav .rst-content h6 .fa-large.headerlink,.rst-content h6 .nav .fa-large.headerlink,.nav .rst-content dl dt .fa-large.headerlink,.rst-content dl dt .nav .fa-large.headerlink,.nav .rst-content p.caption .fa-large.headerlink,.rst-content p.caption .nav .fa-large.headerlink,.nav .rst-content tt.download span.fa-large:first-child,.rst-content tt.download .nav span.fa-large:first-child,.nav .rst-content code.download span.fa-large:first-child,.rst-content code.download .nav span.fa-large:first-child,.nav .fa-large.icon{line-height:0.9em}.btn .fa.fa-spin,.btn .wy-menu-vertical li span.fa-spin.toctree-expand,.wy-menu-vertical li .btn span.fa-spin.toctree-expand,.btn .rst-content .fa-spin.admonition-title,.rst-content .btn .fa-spin.admonition-title,.btn .rst-content h1 .fa-spin.headerlink,.rst-content h1 .btn .fa-spin.headerlink,.btn .rst-content h2 .fa-spin.headerlink,.rst-content h2 .btn .fa-spin.headerlink,.btn .rst-content h3 .fa-spin.headerlink,.rst-content h3 .btn .fa-spin.headerlink,.btn .rst-content h4 .fa-spin.headerlink,.rst-content h4 .btn .fa-spin.headerlink,.btn .rst-content h5 .fa-spin.headerlink,.rst-content h5 .btn .fa-spin.headerlink,.btn .rst-content h6 .fa-spin.headerlink,.rst-content h6 .btn .fa-spin.headerlink,.btn .rst-content dl dt .fa-spin.headerlink,.rst-content dl dt .btn .fa-spin.headerlink,.btn .rst-content p.caption .fa-spin.headerlink,.rst-content p.caption .btn .fa-spin.headerlink,.btn .rst-content tt.download span.fa-spin:first-child,.rst-content tt.download .btn span.fa-spin:first-child,.btn .rst-content code.download span.fa-spin:first-child,.rst-content code.download .btn span.fa-spin:first-child,.btn .fa-spin.icon,.nav .fa.fa-spin,.nav .wy-menu-vertical li span.fa-spin.toctree-expand,.wy-menu-vertical li .nav span.fa-spin.toctree-expand,.nav .rst-content .fa-spin.admonition-title,.rst-content .nav .fa-spin.admonition-title,.nav .rst-content h1 .fa-spin.headerlink,.rst-content h1 .nav .fa-spin.headerlink,.nav .rst-content h2 .fa-spin.headerlink,.rst-content h2 .nav .fa-spin.headerlink,.nav .rst-content h3 .fa-spin.headerlink,.rst-content h3 .nav .fa-spin.headerlink,.nav .rst-content h4 .fa-spin.headerlink,.rst-content h4 .nav .fa-spin.headerlink,.nav .rst-content h5 .fa-spin.headerlink,.rst-content h5 .nav .fa-spin.headerlink,.nav .rst-content h6 .fa-spin.headerlink,.rst-content h6 .nav .fa-spin.headerlink,.nav .rst-content dl dt .fa-spin.headerlink,.rst-content dl dt .nav .fa-spin.headerlink,.nav .rst-content p.caption .fa-spin.headerlink,.rst-content p.caption .nav .fa-spin.headerlink,.nav .rst-content tt.download span.fa-spin:first-child,.rst-content tt.download .nav span.fa-spin:first-child,.nav .rst-content code.download span.fa-spin:first-child,.rst-content code.download .nav span.fa-spin:first-child,.nav .fa-spin.icon{display:inline-block}.btn.fa:before,.wy-menu-vertical li span.btn.toctree-expand:before,.rst-content .btn.admonition-title:before,.rst-content h1 .btn.headerlink:before,.rst-content h2 .btn.headerlink:before,.rst-content h3 .btn.headerlink:before,.rst-content h4 .btn.headerlink:before,.rst-content h5 .btn.headerlink:before,.rst-content h6 .btn.headerlink:before,.rst-content dl dt .btn.headerlink:before,.rst-content p.caption .btn.headerlink:before,.rst-content tt.download span.btn:first-child:before,.rst-content code.download span.btn:first-child:before,.btn.icon:before{opacity:0.5;-webkit-transition:opacity 0.05s ease-in;-moz-transition:opacity 0.05s ease-in;transition:opacity 0.05s ease-in}.btn.fa:hover:before,.wy-menu-vertical li span.btn.toctree-expand:hover:before,.rst-content .btn.admonition-title:hover:before,.rst-content h1 .btn.headerlink:hover:before,.rst-content h2 .btn.headerlink:hover:before,.rst-content h3 .btn.headerlink:hover:before,.rst-content h4 .btn.headerlink:hover:before,.rst-content h5 .btn.headerlink:hover:before,.rst-content h6 .btn.headerlink:hover:before,.rst-content dl dt .btn.headerlink:hover:before,.rst-content p.caption .btn.headerlink:hover:before,.rst-content tt.download span.btn:first-child:hover:before,.rst-content code.download span.btn:first-child:hover:before,.btn.icon:hover:before{opacity:1}.btn-mini .fa:before,.btn-mini .wy-menu-vertical li span.toctree-expand:before,.wy-menu-vertical li .btn-mini span.toctree-expand:before,.btn-mini .rst-content .admonition-title:before,.rst-content .btn-mini .admonition-title:before,.btn-mini .rst-content h1 .headerlink:before,.rst-content h1 .btn-mini .headerlink:before,.btn-mini .rst-content h2 .headerlink:before,.rst-content h2 .btn-mini .headerlink:before,.btn-mini .rst-content h3 .headerlink:before,.rst-content h3 .btn-mini .headerlink:before,.btn-mini .rst-content h4 .headerlink:before,.rst-content h4 .btn-mini .headerlink:before,.btn-mini .rst-content h5 .headerlink:before,.rst-content h5 .btn-mini .headerlink:before,.btn-mini .rst-content h6 .headerlink:before,.rst-content h6 .btn-mini .headerlink:before,.btn-mini .rst-content dl dt .headerlink:before,.rst-content dl dt .btn-mini .headerlink:before,.btn-mini .rst-content p.caption .headerlink:before,.rst-content p.caption .btn-mini .headerlink:before,.btn-mini .rst-content tt.download span:first-child:before,.rst-content tt.download .btn-mini span:first-child:before,.btn-mini .rst-content code.download span:first-child:before,.rst-content code.download .btn-mini span:first-child:before,.btn-mini .icon:before{font-size:14px;vertical-align:-15%}.wy-alert,.rst-content .note,.rst-content .attention,.rst-content .caution,.rst-content .danger,.rst-content .error,.rst-content .hint,.rst-content .important,.rst-content .tip,.rst-content .warning,.rst-content .seealso,.rst-content .admonition-todo{padding:12px;line-height:24px;margin-bottom:24px;background:#e7f2fa}.wy-alert-title,.rst-content .admonition-title{color:#fff;font-weight:bold;display:block;color:#fff;background:#6ab0de;margin:-12px;padding:6px 12px;margin-bottom:12px}.wy-alert.wy-alert-danger,.rst-content .wy-alert-danger.note,.rst-content .wy-alert-danger.attention,.rst-content .wy-alert-danger.caution,.rst-content .danger,.rst-content .error,.rst-content .wy-alert-danger.hint,.rst-content .wy-alert-danger.important,.rst-content .wy-alert-danger.tip,.rst-content .wy-alert-danger.warning,.rst-content .wy-alert-danger.seealso,.rst-content .wy-alert-danger.admonition-todo{background:#fdf3f2}.wy-alert.wy-alert-danger .wy-alert-title,.rst-content .wy-alert-danger.note .wy-alert-title,.rst-content .wy-alert-danger.attention .wy-alert-title,.rst-content .wy-alert-danger.caution .wy-alert-title,.rst-content .danger .wy-alert-title,.rst-content .error .wy-alert-title,.rst-content .wy-alert-danger.hint .wy-alert-title,.rst-content .wy-alert-danger.important .wy-alert-title,.rst-content .wy-alert-danger.tip .wy-alert-title,.rst-content .wy-alert-danger.warning .wy-alert-title,.rst-content .wy-alert-danger.seealso .wy-alert-title,.rst-content .wy-alert-danger.admonition-todo .wy-alert-title,.wy-alert.wy-alert-danger .rst-content .admonition-title,.rst-content .wy-alert.wy-alert-danger .admonition-title,.rst-content .wy-alert-danger.note .admonition-title,.rst-content .wy-alert-danger.attention .admonition-title,.rst-content .wy-alert-danger.caution .admonition-title,.rst-content .danger .admonition-title,.rst-content .error .admonition-title,.rst-content .wy-alert-danger.hint .admonition-title,.rst-content .wy-alert-danger.important .admonition-title,.rst-content .wy-alert-danger.tip .admonition-title,.rst-content .wy-alert-danger.warning .admonition-title,.rst-content .wy-alert-danger.seealso .admonition-title,.rst-content .wy-alert-danger.admonition-todo .admonition-title{background:#f29f97}.wy-alert.wy-alert-warning,.rst-content .wy-alert-warning.note,.rst-content .attention,.rst-content .caution,.rst-content .wy-alert-warning.danger,.rst-content .wy-alert-warning.error,.rst-content .wy-alert-warning.hint,.rst-content .wy-alert-warning.important,.rst-content .wy-alert-warning.tip,.rst-content .warning,.rst-content .wy-alert-warning.seealso,.rst-content .admonition-todo{background:#ffedcc}.wy-alert.wy-alert-warning .wy-alert-title,.rst-content .wy-alert-warning.note .wy-alert-title,.rst-content .attention .wy-alert-title,.rst-content .caution .wy-alert-title,.rst-content .wy-alert-warning.danger .wy-alert-title,.rst-content .wy-alert-warning.error .wy-alert-title,.rst-content .wy-alert-warning.hint .wy-alert-title,.rst-content .wy-alert-warning.important .wy-alert-title,.rst-content .wy-alert-warning.tip .wy-alert-title,.rst-content .warning .wy-alert-title,.rst-content .wy-alert-warning.seealso .wy-alert-title,.rst-content .admonition-todo .wy-alert-title,.wy-alert.wy-alert-warning .rst-content .admonition-title,.rst-content .wy-alert.wy-alert-warning .admonition-title,.rst-content .wy-alert-warning.note .admonition-title,.rst-content .attention .admonition-title,.rst-content .caution .admonition-title,.rst-content .wy-alert-warning.danger .admonition-title,.rst-content .wy-alert-warning.error .admonition-title,.rst-content .wy-alert-warning.hint .admonition-title,.rst-content .wy-alert-warning.important .admonition-title,.rst-content .wy-alert-warning.tip .admonition-title,.rst-content .warning .admonition-title,.rst-content .wy-alert-warning.seealso .admonition-title,.rst-content .admonition-todo .admonition-title{background:#f0b37e}.wy-alert.wy-alert-info,.rst-content .note,.rst-content .wy-alert-info.attention,.rst-content .wy-alert-info.caution,.rst-content .wy-alert-info.danger,.rst-content .wy-alert-info.error,.rst-content .wy-alert-info.hint,.rst-content .wy-alert-info.important,.rst-content .wy-alert-info.tip,.rst-content .wy-alert-info.warning,.rst-content .seealso,.rst-content .wy-alert-info.admonition-todo{background:#e7f2fa}.wy-alert.wy-alert-info .wy-alert-title,.rst-content .note .wy-alert-title,.rst-content .wy-alert-info.attention .wy-alert-title,.rst-content .wy-alert-info.caution .wy-alert-title,.rst-content .wy-alert-info.danger .wy-alert-title,.rst-content .wy-alert-info.error .wy-alert-title,.rst-content .wy-alert-info.hint .wy-alert-title,.rst-content .wy-alert-info.important .wy-alert-title,.rst-content .wy-alert-info.tip .wy-alert-title,.rst-content .wy-alert-info.warning .wy-alert-title,.rst-content .seealso .wy-alert-title,.rst-content .wy-alert-info.admonition-todo .wy-alert-title,.wy-alert.wy-alert-info .rst-content .admonition-title,.rst-content .wy-alert.wy-alert-info .admonition-title,.rst-content .note .admonition-title,.rst-content .wy-alert-info.attention .admonition-title,.rst-content .wy-alert-info.caution .admonition-title,.rst-content .wy-alert-info.danger .admonition-title,.rst-content .wy-alert-info.error .admonition-title,.rst-content .wy-alert-info.hint .admonition-title,.rst-content .wy-alert-info.important .admonition-title,.rst-content .wy-alert-info.tip .admonition-title,.rst-content .wy-alert-info.warning .admonition-title,.rst-content .seealso .admonition-title,.rst-content .wy-alert-info.admonition-todo .admonition-title{background:#6ab0de}.wy-alert.wy-alert-success,.rst-content .wy-alert-success.note,.rst-content .wy-alert-success.attention,.rst-content .wy-alert-success.caution,.rst-content .wy-alert-success.danger,.rst-content .wy-alert-success.error,.rst-content .hint,.rst-content .important,.rst-content .tip,.rst-content .wy-alert-success.warning,.rst-content .wy-alert-success.seealso,.rst-content .wy-alert-success.admonition-todo{background:#dbfaf4}.wy-alert.wy-alert-success .wy-alert-title,.rst-content .wy-alert-success.note .wy-alert-title,.rst-content .wy-alert-success.attention .wy-alert-title,.rst-content .wy-alert-success.caution .wy-alert-title,.rst-content .wy-alert-success.danger .wy-alert-title,.rst-content .wy-alert-success.error .wy-alert-title,.rst-content .hint .wy-alert-title,.rst-content .important .wy-alert-title,.rst-content .tip .wy-alert-title,.rst-content .wy-alert-success.warning .wy-alert-title,.rst-content .wy-alert-success.seealso .wy-alert-title,.rst-content .wy-alert-success.admonition-todo .wy-alert-title,.wy-alert.wy-alert-success .rst-content .admonition-title,.rst-content .wy-alert.wy-alert-success .admonition-title,.rst-content .wy-alert-success.note .admonition-title,.rst-content .wy-alert-success.attention .admonition-title,.rst-content .wy-alert-success.caution .admonition-title,.rst-content .wy-alert-success.danger .admonition-title,.rst-content .wy-alert-success.error .admonition-title,.rst-content .hint .admonition-title,.rst-content .important .admonition-title,.rst-content .tip .admonition-title,.rst-content .wy-alert-success.warning .admonition-title,.rst-content .wy-alert-success.seealso .admonition-title,.rst-content .wy-alert-success.admonition-todo .admonition-title{background:#1abc9c}.wy-alert.wy-alert-neutral,.rst-content .wy-alert-neutral.note,.rst-content .wy-alert-neutral.attention,.rst-content .wy-alert-neutral.caution,.rst-content .wy-alert-neutral.danger,.rst-content .wy-alert-neutral.error,.rst-content .wy-alert-neutral.hint,.rst-content .wy-alert-neutral.important,.rst-content .wy-alert-neutral.tip,.rst-content .wy-alert-neutral.warning,.rst-content .wy-alert-neutral.seealso,.rst-content .wy-alert-neutral.admonition-todo{background:#f3f6f6}.wy-alert.wy-alert-neutral .wy-alert-title,.rst-content .wy-alert-neutral.note .wy-alert-title,.rst-content .wy-alert-neutral.attention .wy-alert-title,.rst-content .wy-alert-neutral.caution .wy-alert-title,.rst-content .wy-alert-neutral.danger .wy-alert-title,.rst-content .wy-alert-neutral.error .wy-alert-title,.rst-content .wy-alert-neutral.hint .wy-alert-title,.rst-content .wy-alert-neutral.important .wy-alert-title,.rst-content .wy-alert-neutral.tip .wy-alert-title,.rst-content .wy-alert-neutral.warning .wy-alert-title,.rst-content .wy-alert-neutral.seealso .wy-alert-title,.rst-content .wy-alert-neutral.admonition-todo .wy-alert-title,.wy-alert.wy-alert-neutral .rst-content .admonition-title,.rst-content .wy-alert.wy-alert-neutral .admonition-title,.rst-content .wy-alert-neutral.note .admonition-title,.rst-content .wy-alert-neutral.attention .admonition-title,.rst-content .wy-alert-neutral.caution .admonition-title,.rst-content .wy-alert-neutral.danger .admonition-title,.rst-content .wy-alert-neutral.error .admonition-title,.rst-content .wy-alert-neutral.hint .admonition-title,.rst-content .wy-alert-neutral.important .admonition-title,.rst-content .wy-alert-neutral.tip .admonition-title,.rst-content .wy-alert-neutral.warning .admonition-title,.rst-content .wy-alert-neutral.seealso .admonition-title,.rst-content .wy-alert-neutral.admonition-todo .admonition-title{color:#404040;background:#e1e4e5}.wy-alert.wy-alert-neutral a,.rst-content .wy-alert-neutral.note a,.rst-content .wy-alert-neutral.attention a,.rst-content .wy-alert-neutral.caution a,.rst-content .wy-alert-neutral.danger a,.rst-content .wy-alert-neutral.error a,.rst-content .wy-alert-neutral.hint a,.rst-content .wy-alert-neutral.important a,.rst-content .wy-alert-neutral.tip a,.rst-content .wy-alert-neutral.warning a,.rst-content .wy-alert-neutral.seealso a,.rst-content .wy-alert-neutral.admonition-todo a{color:#2980B9}.wy-alert p:last-child,.rst-content .note p:last-child,.rst-content .attention p:last-child,.rst-content .caution p:last-child,.rst-content .danger p:last-child,.rst-content .error p:last-child,.rst-content .hint p:last-child,.rst-content .important p:last-child,.rst-content .tip p:last-child,.rst-content .warning p:last-child,.rst-content .seealso p:last-child,.rst-content .admonition-todo p:last-child{margin-bottom:0}.wy-tray-container{position:fixed;bottom:0px;left:0;z-index:600}.wy-tray-container li{display:block;width:300px;background:transparent;color:#fff;text-align:center;box-shadow:0 5px 5px 0 rgba(0,0,0,0.1);padding:0 24px;min-width:20%;opacity:0;height:0;line-height:56px;overflow:hidden;-webkit-transition:all 0.3s ease-in;-moz-transition:all 0.3s ease-in;transition:all 0.3s ease-in}.wy-tray-container li.wy-tray-item-success{background:#27AE60}.wy-tray-container li.wy-tray-item-info{background:#2980B9}.wy-tray-container li.wy-tray-item-warning{background:#E67E22}.wy-tray-container li.wy-tray-item-danger{background:#E74C3C}.wy-tray-container li.on{opacity:1;height:56px}@media screen and (max-width: 768px){.wy-tray-container{bottom:auto;top:0;width:100%}.wy-tray-container li{width:100%}}button{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle;cursor:pointer;line-height:normal;-webkit-appearance:button;*overflow:visible}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}button[disabled]{cursor:default}.btn{display:inline-block;border-radius:2px;line-height:normal;white-space:nowrap;text-align:center;cursor:pointer;font-size:100%;padding:6px 12px 8px 12px;color:#fff;border:1px solid rgba(0,0,0,0.1);background-color:#27AE60;text-decoration:none;font-weight:normal;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;box-shadow:0px 1px 2px -1px rgba(255,255,255,0.5) inset,0px -2px 0px 0px rgba(0,0,0,0.1) inset;outline-none:false;vertical-align:middle;*display:inline;zoom:1;-webkit-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-transition:all 0.1s linear;-moz-transition:all 0.1s linear;transition:all 0.1s linear}.btn-hover{background:#2e8ece;color:#fff}.btn:hover{background:#2cc36b;color:#fff}.btn:focus{background:#2cc36b;outline:0}.btn:active{box-shadow:0px -1px 0px 0px rgba(0,0,0,0.05) inset,0px 2px 0px 0px rgba(0,0,0,0.1) inset;padding:8px 12px 6px 12px}.btn:visited{color:#fff}.btn:disabled{background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled = false);filter:alpha(opacity=40);opacity:0.4;cursor:not-allowed;box-shadow:none}.btn-disabled{background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled = false);filter:alpha(opacity=40);opacity:0.4;cursor:not-allowed;box-shadow:none}.btn-disabled:hover,.btn-disabled:focus,.btn-disabled:active{background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled = false);filter:alpha(opacity=40);opacity:0.4;cursor:not-allowed;box-shadow:none}.btn::-moz-focus-inner{padding:0;border:0}.btn-small{font-size:80%}.btn-info{background-color:#2980B9 !important}.btn-info:hover{background-color:#2e8ece !important}.btn-neutral{background-color:#f3f6f6 !important;color:#404040 !important}.btn-neutral:hover{background-color:#e5ebeb !important;color:#404040}.btn-neutral:visited{color:#404040 !important}.btn-success{background-color:#27AE60 !important}.btn-success:hover{background-color:#295 !important}.btn-danger{background-color:#E74C3C !important}.btn-danger:hover{background-color:#ea6153 !important}.btn-warning{background-color:#E67E22 !important}.btn-warning:hover{background-color:#e98b39 !important}.btn-invert{background-color:#222}.btn-invert:hover{background-color:#2f2f2f !important}.btn-link{background-color:transparent !important;color:#2980B9;box-shadow:none;border-color:transparent !important}.btn-link:hover{background-color:transparent !important;color:#409ad5 !important;box-shadow:none}.btn-link:active{background-color:transparent !important;color:#409ad5 !important;box-shadow:none}.btn-link:visited{color:#9B59B6}.wy-btn-group .btn,.wy-control .btn{vertical-align:middle}.wy-btn-group{margin-bottom:24px;*zoom:1}.wy-btn-group:before,.wy-btn-group:after{display:table;content:""}.wy-btn-group:after{clear:both}.wy-dropdown{position:relative;display:inline-block}.wy-dropdown-active .wy-dropdown-menu{display:block}.wy-dropdown-menu{position:absolute;left:0;display:none;float:left;top:100%;min-width:100%;background:#fcfcfc;z-index:100;border:solid 1px #cfd7dd;box-shadow:0 2px 2px 0 rgba(0,0,0,0.1);padding:12px}.wy-dropdown-menu>dd>a{display:block;clear:both;color:#404040;white-space:nowrap;font-size:90%;padding:0 12px;cursor:pointer}.wy-dropdown-menu>dd>a:hover{background:#2980B9;color:#fff}.wy-dropdown-menu>dd.divider{border-top:solid 1px #cfd7dd;margin:6px 0}.wy-dropdown-menu>dd.search{padding-bottom:12px}.wy-dropdown-menu>dd.search input[type="search"]{width:100%}.wy-dropdown-menu>dd.call-to-action{background:#e3e3e3;text-transform:uppercase;font-weight:500;font-size:80%}.wy-dropdown-menu>dd.call-to-action:hover{background:#e3e3e3}.wy-dropdown-menu>dd.call-to-action .btn{color:#fff}.wy-dropdown.wy-dropdown-up .wy-dropdown-menu{bottom:100%;top:auto;left:auto;right:0}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu{background:#fcfcfc;margin-top:2px}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu a{padding:6px 12px}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu a:hover{background:#2980B9;color:#fff}.wy-dropdown.wy-dropdown-left .wy-dropdown-menu{right:0;left:auto;text-align:right}.wy-dropdown-arrow:before{content:" ";border-bottom:5px solid #f5f5f5;border-left:5px solid transparent;border-right:5px solid transparent;position:absolute;display:block;top:-4px;left:50%;margin-left:-3px}.wy-dropdown-arrow.wy-dropdown-arrow-left:before{left:11px}.wy-form-stacked select{display:block}.wy-form-aligned input,.wy-form-aligned textarea,.wy-form-aligned select,.wy-form-aligned .wy-help-inline,.wy-form-aligned label{display:inline-block;*display:inline;*zoom:1;vertical-align:middle}.wy-form-aligned .wy-control-group>label{display:inline-block;vertical-align:middle;width:10em;margin:6px 12px 0 0;float:left}.wy-form-aligned .wy-control{float:left}.wy-form-aligned .wy-control label{display:block}.wy-form-aligned .wy-control select{margin-top:6px}fieldset{border:0;margin:0;padding:0}legend{display:block;width:100%;border:0;padding:0;white-space:normal;margin-bottom:24px;font-size:150%;*margin-left:-7px}label{display:block;margin:0 0 0.3125em 0;color:#333;font-size:90%}input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}.wy-control-group{margin-bottom:24px;*zoom:1;max-width:68em;margin-left:auto;margin-right:auto;*zoom:1}.wy-control-group:before,.wy-control-group:after{display:table;content:""}.wy-control-group:after{clear:both}.wy-control-group:before,.wy-control-group:after{display:table;content:""}.wy-control-group:after{clear:both}.wy-control-group.wy-control-group-required>label:after{content:" *";color:#E74C3C}.wy-control-group .wy-form-full,.wy-control-group .wy-form-halves,.wy-control-group .wy-form-thirds{padding-bottom:12px}.wy-control-group .wy-form-full select,.wy-control-group .wy-form-halves select,.wy-control-group .wy-form-thirds select{width:100%}.wy-control-group .wy-form-full input[type="text"],.wy-control-group .wy-form-full input[type="password"],.wy-control-group .wy-form-full input[type="email"],.wy-control-group .wy-form-full input[type="url"],.wy-control-group .wy-form-full input[type="date"],.wy-control-group .wy-form-full input[type="month"],.wy-control-group .wy-form-full input[type="time"],.wy-control-group .wy-form-full input[type="datetime"],.wy-control-group .wy-form-full input[type="datetime-local"],.wy-control-group .wy-form-full input[type="week"],.wy-control-group .wy-form-full input[type="number"],.wy-control-group .wy-form-full input[type="search"],.wy-control-group .wy-form-full input[type="tel"],.wy-control-group .wy-form-full input[type="color"],.wy-control-group .wy-form-halves input[type="text"],.wy-control-group .wy-form-halves input[type="password"],.wy-control-group .wy-form-halves input[type="email"],.wy-control-group .wy-form-halves input[type="url"],.wy-control-group .wy-form-halves input[type="date"],.wy-control-group .wy-form-halves input[type="month"],.wy-control-group .wy-form-halves input[type="time"],.wy-control-group .wy-form-halves input[type="datetime"],.wy-control-group .wy-form-halves input[type="datetime-local"],.wy-control-group .wy-form-halves input[type="week"],.wy-control-group .wy-form-halves input[type="number"],.wy-control-group .wy-form-halves input[type="search"],.wy-control-group .wy-form-halves input[type="tel"],.wy-control-group .wy-form-halves input[type="color"],.wy-control-group .wy-form-thirds input[type="text"],.wy-control-group .wy-form-thirds input[type="password"],.wy-control-group .wy-form-thirds input[type="email"],.wy-control-group .wy-form-thirds input[type="url"],.wy-control-group .wy-form-thirds input[type="date"],.wy-control-group .wy-form-thirds input[type="month"],.wy-control-group .wy-form-thirds input[type="time"],.wy-control-group .wy-form-thirds input[type="datetime"],.wy-control-group .wy-form-thirds input[type="datetime-local"],.wy-control-group .wy-form-thirds input[type="week"],.wy-control-group .wy-form-thirds input[type="number"],.wy-control-group .wy-form-thirds input[type="search"],.wy-control-group .wy-form-thirds input[type="tel"],.wy-control-group .wy-form-thirds input[type="color"]{width:100%}.wy-control-group .wy-form-full{float:left;display:block;margin-right:2.35765%;width:100%;margin-right:0}.wy-control-group .wy-form-full:last-child{margin-right:0}.wy-control-group .wy-form-halves{float:left;display:block;margin-right:2.35765%;width:48.82117%}.wy-control-group .wy-form-halves:last-child{margin-right:0}.wy-control-group .wy-form-halves:nth-of-type(2n){margin-right:0}.wy-control-group .wy-form-halves:nth-of-type(2n+1){clear:left}.wy-control-group .wy-form-thirds{float:left;display:block;margin-right:2.35765%;width:31.76157%}.wy-control-group .wy-form-thirds:last-child{margin-right:0}.wy-control-group .wy-form-thirds:nth-of-type(3n){margin-right:0}.wy-control-group .wy-form-thirds:nth-of-type(3n+1){clear:left}.wy-control-group.wy-control-group-no-input .wy-control{margin:6px 0 0 0;font-size:90%}.wy-control-no-input{display:inline-block;margin:6px 0 0 0;font-size:90%}.wy-control-group.fluid-input input[type="text"],.wy-control-group.fluid-input input[type="password"],.wy-control-group.fluid-input input[type="email"],.wy-control-group.fluid-input input[type="url"],.wy-control-group.fluid-input input[type="date"],.wy-control-group.fluid-input input[type="month"],.wy-control-group.fluid-input input[type="time"],.wy-control-group.fluid-input input[type="datetime"],.wy-control-group.fluid-input input[type="datetime-local"],.wy-control-group.fluid-input input[type="week"],.wy-control-group.fluid-input input[type="number"],.wy-control-group.fluid-input input[type="search"],.wy-control-group.fluid-input input[type="tel"],.wy-control-group.fluid-input input[type="color"]{width:100%}.wy-form-message-inline{display:inline-block;padding-left:0.3em;color:#666;vertical-align:middle;font-size:90%}.wy-form-message{display:block;color:#999;font-size:70%;margin-top:0.3125em;font-style:italic}.wy-form-message p{font-size:inherit;font-style:italic;margin-bottom:6px}.wy-form-message p:last-child{margin-bottom:0}input{line-height:normal}input[type="button"],input[type="reset"],input[type="submit"]{-webkit-appearance:button;cursor:pointer;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;*overflow:visible}input[type="text"],input[type="password"],input[type="email"],input[type="url"],input[type="date"],input[type="month"],input[type="time"],input[type="datetime"],input[type="datetime-local"],input[type="week"],input[type="number"],input[type="search"],input[type="tel"],input[type="color"]{-webkit-appearance:none;padding:6px;display:inline-block;border:1px solid #ccc;font-size:80%;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;box-shadow:inset 0 1px 3px #ddd;border-radius:0;-webkit-transition:border 0.3s linear;-moz-transition:border 0.3s linear;transition:border 0.3s linear}input[type="datetime-local"]{padding:0.34375em 0.625em}input[disabled]{cursor:default}input[type="checkbox"],input[type="radio"]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0;margin-right:0.3125em;*height:13px;*width:13px}input[type="search"]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}input[type="text"]:focus,input[type="password"]:focus,input[type="email"]:focus,input[type="url"]:focus,input[type="date"]:focus,input[type="month"]:focus,input[type="time"]:focus,input[type="datetime"]:focus,input[type="datetime-local"]:focus,input[type="week"]:focus,input[type="number"]:focus,input[type="search"]:focus,input[type="tel"]:focus,input[type="color"]:focus{outline:0;outline:thin dotted \9;border-color:#333}input.no-focus:focus{border-color:#ccc !important}input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus{outline:thin dotted #333;outline:1px auto #129FEA}input[type="text"][disabled],input[type="password"][disabled],input[type="email"][disabled],input[type="url"][disabled],input[type="date"][disabled],input[type="month"][disabled],input[type="time"][disabled],input[type="datetime"][disabled],input[type="datetime-local"][disabled],input[type="week"][disabled],input[type="number"][disabled],input[type="search"][disabled],input[type="tel"][disabled],input[type="color"][disabled]{cursor:not-allowed;background-color:#fafafa}input:focus:invalid,textarea:focus:invalid,select:focus:invalid{color:#E74C3C;border:1px solid #E74C3C}input:focus:invalid:focus,textarea:focus:invalid:focus,select:focus:invalid:focus{border-color:#E74C3C}input[type="file"]:focus:invalid:focus,input[type="radio"]:focus:invalid:focus,input[type="checkbox"]:focus:invalid:focus{outline-color:#E74C3C}input.wy-input-large{padding:12px;font-size:100%}textarea{overflow:auto;vertical-align:top;width:100%;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif}select,textarea{padding:0.5em 0.625em;display:inline-block;border:1px solid #ccc;font-size:80%;box-shadow:inset 0 1px 3px #ddd;-webkit-transition:border 0.3s linear;-moz-transition:border 0.3s linear;transition:border 0.3s linear}select{border:1px solid #ccc;background-color:#fff}select[multiple]{height:auto}select:focus,textarea:focus{outline:0}select[disabled],textarea[disabled],input[readonly],select[readonly],textarea[readonly]{cursor:not-allowed;background-color:#fafafa}input[type="radio"][disabled],input[type="checkbox"][disabled]{cursor:not-allowed}.wy-checkbox,.wy-radio{margin:6px 0;color:#404040;display:block}.wy-checkbox input,.wy-radio input{vertical-align:baseline}.wy-form-message-inline{display:inline-block;*display:inline;*zoom:1;vertical-align:middle}.wy-input-prefix,.wy-input-suffix{white-space:nowrap;padding:6px}.wy-input-prefix .wy-input-context,.wy-input-suffix .wy-input-context{line-height:27px;padding:0 8px;display:inline-block;font-size:80%;background-color:#f3f6f6;border:solid 1px #ccc;color:#999}.wy-input-suffix .wy-input-context{border-left:0}.wy-input-prefix .wy-input-context{border-right:0}.wy-switch{width:36px;height:12px;margin:12px 0;position:relative;border-radius:4px;background:#ccc;cursor:pointer;-webkit-transition:all 0.2s ease-in-out;-moz-transition:all 0.2s ease-in-out;transition:all 0.2s ease-in-out}.wy-switch:before{position:absolute;content:"";display:block;width:18px;height:18px;border-radius:4px;background:#999;left:-3px;top:-3px;-webkit-transition:all 0.2s ease-in-out;-moz-transition:all 0.2s ease-in-out;transition:all 0.2s ease-in-out}.wy-switch:after{content:"false";position:absolute;left:48px;display:block;font-size:12px;color:#ccc}.wy-switch.active{background:#1e8449}.wy-switch.active:before{left:24px;background:#27AE60}.wy-switch.active:after{content:"true"}.wy-switch.disabled,.wy-switch.active.disabled{cursor:not-allowed}.wy-control-group.wy-control-group-error .wy-form-message,.wy-control-group.wy-control-group-error>label{color:#E74C3C}.wy-control-group.wy-control-group-error input[type="text"],.wy-control-group.wy-control-group-error input[type="password"],.wy-control-group.wy-control-group-error input[type="email"],.wy-control-group.wy-control-group-error input[type="url"],.wy-control-group.wy-control-group-error input[type="date"],.wy-control-group.wy-control-group-error input[type="month"],.wy-control-group.wy-control-group-error input[type="time"],.wy-control-group.wy-control-group-error input[type="datetime"],.wy-control-group.wy-control-group-error input[type="datetime-local"],.wy-control-group.wy-control-group-error input[type="week"],.wy-control-group.wy-control-group-error input[type="number"],.wy-control-group.wy-control-group-error input[type="search"],.wy-control-group.wy-control-group-error input[type="tel"],.wy-control-group.wy-control-group-error input[type="color"]{border:solid 1px #E74C3C}.wy-control-group.wy-control-group-error textarea{border:solid 1px #E74C3C}.wy-inline-validate{white-space:nowrap}.wy-inline-validate .wy-input-context{padding:0.5em 0.625em;display:inline-block;font-size:80%}.wy-inline-validate.wy-inline-validate-success .wy-input-context{color:#27AE60}.wy-inline-validate.wy-inline-validate-danger .wy-input-context{color:#E74C3C}.wy-inline-validate.wy-inline-validate-warning .wy-input-context{color:#E67E22}.wy-inline-validate.wy-inline-validate-info .wy-input-context{color:#2980B9}.rotate-90{-webkit-transform:rotate(90deg);-moz-transform:rotate(90deg);-ms-transform:rotate(90deg);-o-transform:rotate(90deg);transform:rotate(90deg)}.rotate-180{-webkit-transform:rotate(180deg);-moz-transform:rotate(180deg);-ms-transform:rotate(180deg);-o-transform:rotate(180deg);transform:rotate(180deg)}.rotate-270{-webkit-transform:rotate(270deg);-moz-transform:rotate(270deg);-ms-transform:rotate(270deg);-o-transform:rotate(270deg);transform:rotate(270deg)}.mirror{-webkit-transform:scaleX(-1);-moz-transform:scaleX(-1);-ms-transform:scaleX(-1);-o-transform:scaleX(-1);transform:scaleX(-1)}.mirror.rotate-90{-webkit-transform:scaleX(-1) rotate(90deg);-moz-transform:scaleX(-1) rotate(90deg);-ms-transform:scaleX(-1) rotate(90deg);-o-transform:scaleX(-1) rotate(90deg);transform:scaleX(-1) rotate(90deg)}.mirror.rotate-180{-webkit-transform:scaleX(-1) rotate(180deg);-moz-transform:scaleX(-1) rotate(180deg);-ms-transform:scaleX(-1) rotate(180deg);-o-transform:scaleX(-1) rotate(180deg);transform:scaleX(-1) rotate(180deg)}.mirror.rotate-270{-webkit-transform:scaleX(-1) rotate(270deg);-moz-transform:scaleX(-1) rotate(270deg);-ms-transform:scaleX(-1) rotate(270deg);-o-transform:scaleX(-1) rotate(270deg);transform:scaleX(-1) rotate(270deg)}@media only screen and (max-width: 480px){.wy-form button[type="submit"]{margin:0.7em 0 0}.wy-form input[type="text"],.wy-form input[type="password"],.wy-form input[type="email"],.wy-form input[type="url"],.wy-form input[type="date"],.wy-form input[type="month"],.wy-form input[type="time"],.wy-form input[type="datetime"],.wy-form input[type="datetime-local"],.wy-form input[type="week"],.wy-form input[type="number"],.wy-form input[type="search"],.wy-form input[type="tel"],.wy-form input[type="color"]{margin-bottom:0.3em;display:block}.wy-form label{margin-bottom:0.3em;display:block}.wy-form input[type="password"],.wy-form input[type="email"],.wy-form input[type="url"],.wy-form input[type="date"],.wy-form input[type="month"],.wy-form input[type="time"],.wy-form input[type="datetime"],.wy-form input[type="datetime-local"],.wy-form input[type="week"],.wy-form input[type="number"],.wy-form input[type="search"],.wy-form input[type="tel"],.wy-form input[type="color"]{margin-bottom:0}.wy-form-aligned .wy-control-group label{margin-bottom:0.3em;text-align:left;display:block;width:100%}.wy-form-aligned .wy-control{margin:1.5em 0 0 0}.wy-form .wy-help-inline,.wy-form-message-inline,.wy-form-message{display:block;font-size:80%;padding:6px 0}}@media screen and (max-width: 768px){.tablet-hide{display:none}}@media screen and (max-width: 480px){.mobile-hide{display:none}}.float-left{float:left}.float-right{float:right}.full-width{width:100%}.wy-table,.rst-content table.docutils,.rst-content table.field-list{border-collapse:collapse;border-spacing:0;empty-cells:show;margin-bottom:24px}.wy-table caption,.rst-content table.docutils caption,.rst-content table.field-list caption{color:#000;font:italic 85%/1 arial,sans-serif;padding:1em 0;text-align:center}.wy-table td,.rst-content table.docutils td,.rst-content table.field-list td,.wy-table th,.rst-content table.docutils th,.rst-content table.field-list th{font-size:90%;margin:0;overflow:visible;padding:8px 16px}.wy-table td:first-child,.rst-content table.docutils td:first-child,.rst-content table.field-list td:first-child,.wy-table th:first-child,.rst-content table.docutils th:first-child,.rst-content table.field-list th:first-child{border-left-width:0}.wy-table thead,.rst-content table.docutils thead,.rst-content table.field-list thead{color:#000;text-align:left;vertical-align:bottom;white-space:nowrap}.wy-table thead th,.rst-content table.docutils thead th,.rst-content table.field-list thead th{font-weight:bold;border-bottom:solid 2px #e1e4e5}.wy-table td,.rst-content table.docutils td,.rst-content table.field-list td{background-color:transparent;vertical-align:middle}.wy-table td p,.rst-content table.docutils td p,.rst-content table.field-list td p{line-height:18px}.wy-table td p:last-child,.rst-content table.docutils td p:last-child,.rst-content table.field-list td p:last-child{margin-bottom:0}.wy-table .wy-table-cell-min,.rst-content table.docutils .wy-table-cell-min,.rst-content table.field-list .wy-table-cell-min{width:1%;padding-right:0}.wy-table .wy-table-cell-min input[type=checkbox],.rst-content table.docutils .wy-table-cell-min input[type=checkbox],.rst-content table.field-list .wy-table-cell-min input[type=checkbox],.wy-table .wy-table-cell-min input[type=checkbox],.rst-content table.docutils .wy-table-cell-min input[type=checkbox],.rst-content table.field-list .wy-table-cell-min input[type=checkbox]{margin:0}.wy-table-secondary{color:gray;font-size:90%}.wy-table-tertiary{color:gray;font-size:80%}.wy-table-odd td,.wy-table-striped tr:nth-child(2n-1) td,.rst-content table.docutils:not(.field-list) tr:nth-child(2n-1) td{background-color:#f3f6f6}.wy-table-backed{background-color:#f3f6f6}.wy-table-bordered-all,.rst-content table.docutils{border:1px solid #e1e4e5}.wy-table-bordered-all td,.rst-content table.docutils td{border-bottom:1px solid #e1e4e5;border-left:1px solid #e1e4e5}.wy-table-bordered-all tbody>tr:last-child td,.rst-content table.docutils tbody>tr:last-child td{border-bottom-width:0}.wy-table-bordered{border:1px solid #e1e4e5}.wy-table-bordered-rows td{border-bottom:1px solid #e1e4e5}.wy-table-bordered-rows tbody>tr:last-child td{border-bottom-width:0}.wy-table-horizontal tbody>tr:last-child td{border-bottom-width:0}.wy-table-horizontal td,.wy-table-horizontal th{border-width:0 0 1px 0;border-bottom:1px solid #e1e4e5}.wy-table-horizontal tbody>tr:last-child td{border-bottom-width:0}.wy-table-responsive{margin-bottom:24px;max-width:100%;overflow:auto}.wy-table-responsive table{margin-bottom:0 !important}.wy-table-responsive table td,.wy-table-responsive table th{white-space:nowrap}a{color:#2980B9;text-decoration:none;cursor:pointer}a:hover{color:#3091d1}a:visited{color:#9B59B6}html{height:100%;overflow-x:hidden}body{font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;font-weight:normal;color:#404040;min-height:100%;overflow-x:hidden;background:#edf0f2}.wy-text-left{text-align:left}.wy-text-center{text-align:center}.wy-text-right{text-align:right}.wy-text-large{font-size:120%}.wy-text-normal{font-size:100%}.wy-text-small,small{font-size:80%}.wy-text-strike{text-decoration:line-through}.wy-text-warning{color:#E67E22 !important}a.wy-text-warning:hover{color:#eb9950 !important}.wy-text-info{color:#2980B9 !important}a.wy-text-info:hover{color:#409ad5 !important}.wy-text-success{color:#27AE60 !important}a.wy-text-success:hover{color:#36d278 !important}.wy-text-danger{color:#E74C3C !important}a.wy-text-danger:hover{color:#ed7669 !important}.wy-text-neutral{color:#404040 !important}a.wy-text-neutral:hover{color:#595959 !important}h1,h2,.rst-content .toctree-wrapper p.caption,h3,h4,h5,h6,legend{margin-top:0;font-weight:700;font-family:"Roboto Slab","ff-tisa-web-pro","Georgia",Arial,sans-serif}p{line-height:24px;margin:0;font-size:16px;margin-bottom:24px}h1{font-size:175%}h2,.rst-content .toctree-wrapper p.caption{font-size:150%}h3{font-size:125%}h4{font-size:115%}h5{font-size:110%}h6{font-size:100%}hr{display:block;height:1px;border:0;border-top:1px solid #e1e4e5;margin:24px 0;padding:0}code,.rst-content tt,.rst-content code{white-space:nowrap;max-width:100%;background:#fff;border:solid 1px #e1e4e5;font-size:75%;padding:0 5px;font-family:Consolas,"Andale Mono WT","Andale Mono","Lucida Console","Lucida Sans Typewriter","DejaVu Sans Mono","Bitstream Vera Sans Mono","Liberation Mono","Nimbus Mono L",Monaco,"Courier New",Courier,monospace;color:#E74C3C;overflow-x:auto}code.code-large,.rst-content tt.code-large{font-size:90%}.wy-plain-list-disc,.rst-content .section ul,.rst-content .toctree-wrapper ul,article ul{list-style:disc;line-height:24px;margin-bottom:24px}.wy-plain-list-disc li,.rst-content .section ul li,.rst-content .toctree-wrapper ul li,article ul li{list-style:disc;margin-left:24px}.wy-plain-list-disc li p:last-child,.rst-content .section ul li p:last-child,.rst-content .toctree-wrapper ul li p:last-child,article ul li p:last-child{margin-bottom:0}.wy-plain-list-disc li ul,.rst-content .section ul li ul,.rst-content .toctree-wrapper ul li ul,article ul li ul{margin-bottom:0}.wy-plain-list-disc li li,.rst-content .section ul li li,.rst-content .toctree-wrapper ul li li,article ul li li{list-style:circle}.wy-plain-list-disc li li li,.rst-content .section ul li li li,.rst-content .toctree-wrapper ul li li li,article ul li li li{list-style:square}.wy-plain-list-disc li ol li,.rst-content .section ul li ol li,.rst-content .toctree-wrapper ul li ol li,article ul li ol li{list-style:decimal}.wy-plain-list-decimal,.rst-content .section ol,.rst-content ol.arabic,article ol{list-style:decimal;line-height:24px;margin-bottom:24px}.wy-plain-list-decimal li,.rst-content .section ol li,.rst-content ol.arabic li,article ol li{list-style:decimal;margin-left:24px}.wy-plain-list-decimal li p:last-child,.rst-content .section ol li p:last-child,.rst-content ol.arabic li p:last-child,article ol li p:last-child{margin-bottom:0}.wy-plain-list-decimal li ul,.rst-content .section ol li ul,.rst-content ol.arabic li ul,article ol li ul{margin-bottom:0}.wy-plain-list-decimal li ul li,.rst-content .section ol li ul li,.rst-content ol.arabic li ul li,article ol li ul li{list-style:disc}.codeblock-example{border:1px solid #e1e4e5;border-bottom:none;padding:24px;padding-top:48px;font-weight:500;background:#fff;position:relative}.codeblock-example:after{content:"Example";position:absolute;top:0px;left:0px;background:#9B59B6;color:#fff;padding:6px 12px}.codeblock-example.prettyprint-example-only{border:1px solid #e1e4e5;margin-bottom:24px}.codeblock,pre.literal-block,.rst-content .literal-block,.rst-content pre.literal-block,div[class^='highlight']{border:1px solid #e1e4e5;padding:0px;overflow-x:auto;background:#fff;margin:1px 0 24px 0}.codeblock div[class^='highlight'],pre.literal-block div[class^='highlight'],.rst-content .literal-block div[class^='highlight'],div[class^='highlight'] div[class^='highlight']{border:none;background:none;margin:0}div[class^='highlight'] td.code{width:100%}.linenodiv pre{border-right:solid 1px #e6e9ea;margin:0;padding:12px 12px;font-family:Consolas,"Andale Mono WT","Andale Mono","Lucida Console","Lucida Sans Typewriter","DejaVu Sans Mono","Bitstream Vera Sans Mono","Liberation Mono","Nimbus Mono L",Monaco,"Courier New",Courier,monospace;font-size:12px;line-height:1.5;color:#d9d9d9}div[class^='highlight'] pre{white-space:pre;margin:0;padding:12px 12px;font-family:Consolas,"Andale Mono WT","Andale Mono","Lucida Console","Lucida Sans Typewriter","DejaVu Sans Mono","Bitstream Vera Sans Mono","Liberation Mono","Nimbus Mono L",Monaco,"Courier New",Courier,monospace;font-size:12px;line-height:1.5;display:block;overflow:auto;color:#404040}@media print{.codeblock,pre.literal-block,.rst-content .literal-block,.rst-content pre.literal-block,div[class^='highlight'],div[class^='highlight'] pre{white-space:pre-wrap}}.hll{background-color:#ffc;margin:0 -12px;padding:0 12px;display:block}.c{color:#998;font-style:italic}.err{color:#a61717;background-color:#e3d2d2}.k{font-weight:bold}.o{font-weight:bold}.cm{color:#998;font-style:italic}.cp{color:#999;font-weight:bold}.c1{color:#998;font-style:italic}.cs{color:#999;font-weight:bold;font-style:italic}.gd{color:#000;background-color:#fdd}.gd .x{color:#000;background-color:#faa}.ge{font-style:italic}.gr{color:#a00}.gh{color:#999}.gi{color:#000;background-color:#dfd}.gi .x{color:#000;background-color:#afa}.go{color:#888}.gp{color:#555}.gs{font-weight:bold}.gu{color:purple;font-weight:bold}.gt{color:#a00}.kc{font-weight:bold}.kd{font-weight:bold}.kn{font-weight:bold}.kp{font-weight:bold}.kr{font-weight:bold}.kt{color:#458;font-weight:bold}.m{color:#099}.s{color:#d14}.n{color:#333}.na{color:teal}.nb{color:#0086b3}.nc{color:#458;font-weight:bold}.no{color:teal}.ni{color:purple}.ne{color:#900;font-weight:bold}.nf{color:#900;font-weight:bold}.nn{color:#555}.nt{color:navy}.nv{color:teal}.ow{font-weight:bold}.w{color:#bbb}.mf{color:#099}.mh{color:#099}.mi{color:#099}.mo{color:#099}.sb{color:#d14}.sc{color:#d14}.sd{color:#d14}.s2{color:#d14}.se{color:#d14}.sh{color:#d14}.si{color:#d14}.sx{color:#d14}.sr{color:#009926}.s1{color:#d14}.ss{color:#990073}.bp{color:#999}.vc{color:teal}.vg{color:teal}.vi{color:teal}.il{color:#099}.gc{color:#999;background-color:#EAF2F5}.wy-breadcrumbs li{display:inline-block}.wy-breadcrumbs li.wy-breadcrumbs-aside{float:right}.wy-breadcrumbs li a{display:inline-block;padding:5px}.wy-breadcrumbs li a:first-child{padding-left:0}.wy-breadcrumbs li code,.wy-breadcrumbs li .rst-content tt,.rst-content .wy-breadcrumbs li tt{padding:5px;border:none;background:none}.wy-breadcrumbs li code.literal,.wy-breadcrumbs li .rst-content tt.literal,.rst-content .wy-breadcrumbs li tt.literal{color:#404040}.wy-breadcrumbs-extra{margin-bottom:0;color:#b3b3b3;font-size:80%;display:inline-block}@media screen and (max-width: 480px){.wy-breadcrumbs-extra{display:none}.wy-breadcrumbs li.wy-breadcrumbs-aside{display:none}}@media print{.wy-breadcrumbs li.wy-breadcrumbs-aside{display:none}}.wy-affix{position:fixed;top:1.618em}.wy-menu a:hover{text-decoration:none}.wy-menu-horiz{*zoom:1}.wy-menu-horiz:before,.wy-menu-horiz:after{display:table;content:""}.wy-menu-horiz:after{clear:both}.wy-menu-horiz ul,.wy-menu-horiz li{display:inline-block}.wy-menu-horiz li:hover{background:rgba(255,255,255,0.1)}.wy-menu-horiz li.divide-left{border-left:solid 1px #404040}.wy-menu-horiz li.divide-right{border-right:solid 1px #404040}.wy-menu-horiz a{height:32px;display:inline-block;line-height:32px;padding:0 16px}.wy-menu-vertical{width:300px}.wy-menu-vertical header,.wy-menu-vertical p.caption{height:32px;display:inline-block;line-height:32px;padding:0 1.618em;margin-bottom:0;display:block;font-weight:bold;text-transform:uppercase;font-size:80%;color:#555;white-space:nowrap}.wy-menu-vertical ul{margin-bottom:0}.wy-menu-vertical li.divide-top{border-top:solid 1px #404040}.wy-menu-vertical li.divide-bottom{border-bottom:solid 1px #404040}.wy-menu-vertical li.current{background:#e3e3e3}.wy-menu-vertical li.current a{color:gray;border-right:solid 1px #c9c9c9;padding:0.4045em 2.427em}.wy-menu-vertical li.current a:hover{background:#d6d6d6}.wy-menu-vertical li code,.wy-menu-vertical li .rst-content tt,.rst-content .wy-menu-vertical li tt{border:none;background:inherit;color:inherit;padding-left:0;padding-right:0}.wy-menu-vertical li span.toctree-expand{display:block;float:left;margin-left:-1.2em;font-size:0.8em;line-height:1.6em;color:#4d4d4d}.wy-menu-vertical li.on a,.wy-menu-vertical li.current>a{color:#404040;padding:0.4045em 1.618em;font-weight:bold;position:relative;background:#fcfcfc;border:none;border-bottom:solid 1px #c9c9c9;border-top:solid 1px #c9c9c9;padding-left:1.618em -4px}.wy-menu-vertical li.on a:hover,.wy-menu-vertical li.current>a:hover{background:#fcfcfc}.wy-menu-vertical li.on a:hover span.toctree-expand,.wy-menu-vertical li.current>a:hover span.toctree-expand{color:gray}.wy-menu-vertical li.on a span.toctree-expand,.wy-menu-vertical li.current>a span.toctree-expand{display:block;font-size:0.8em;line-height:1.6em;color:#333}.wy-menu-vertical li.toctree-l1.current li.toctree-l2>ul,.wy-menu-vertical li.toctree-l2.current li.toctree-l3>ul{display:none}.wy-menu-vertical li.toctree-l1.current li.toctree-l2.current>ul,.wy-menu-vertical li.toctree-l2.current li.toctree-l3.current>ul{display:block}.wy-menu-vertical li.toctree-l2.current>a{background:#c9c9c9;padding:0.4045em 2.427em}.wy-menu-vertical li.toctree-l2.current li.toctree-l3>a{display:block;background:#c9c9c9;padding:0.4045em 4.045em}.wy-menu-vertical li.toctree-l2 a:hover span.toctree-expand{color:gray}.wy-menu-vertical li.toctree-l2 span.toctree-expand{color:#a3a3a3}.wy-menu-vertical li.toctree-l3{font-size:0.9em}.wy-menu-vertical li.toctree-l3.current>a{background:#bdbdbd;padding:0.4045em 4.045em}.wy-menu-vertical li.toctree-l3.current li.toctree-l4>a{display:block;background:#bdbdbd;padding:0.4045em 5.663em;border-top:none;border-bottom:none}.wy-menu-vertical li.toctree-l3 a:hover span.toctree-expand{color:gray}.wy-menu-vertical li.toctree-l3 span.toctree-expand{color:#969696}.wy-menu-vertical li.toctree-l4{font-size:0.9em}.wy-menu-vertical li.current ul{display:block}.wy-menu-vertical li ul{margin-bottom:0;display:none}.wy-menu-vertical .local-toc li ul{display:block}.wy-menu-vertical li ul li a{margin-bottom:0;color:#b3b3b3;font-weight:normal}.wy-menu-vertical a{display:inline-block;line-height:18px;padding:0.4045em 1.618em;display:block;position:relative;font-size:90%;color:#b3b3b3}.wy-menu-vertical a:hover{background-color:#4e4a4a;cursor:pointer}.wy-menu-vertical a:hover span.toctree-expand{color:#b3b3b3}.wy-menu-vertical a:active{background-color:#2980B9;cursor:pointer;color:#fff}.wy-menu-vertical a:active span.toctree-expand{color:#fff}.wy-side-nav-search{display:block;width:300px;padding:0.809em;margin-bottom:0.809em;z-index:200;background-color:#2980B9;text-align:center;padding:0.809em;display:block;color:#fcfcfc;margin-bottom:0.809em}.wy-side-nav-search input[type=text]{width:100%;border-radius:50px;padding:6px 12px;border-color:#2472a4}.wy-side-nav-search img{display:block;margin:auto auto 0.809em auto;height:45px;width:45px;background-color:#2980B9;padding:5px;border-radius:100%}.wy-side-nav-search>a,.wy-side-nav-search .wy-dropdown>a{color:#fcfcfc;font-size:100%;font-weight:bold;display:inline-block;padding:4px 6px;margin-bottom:0.809em}.wy-side-nav-search>a:hover,.wy-side-nav-search .wy-dropdown>a:hover{background:rgba(255,255,255,0.1)}.wy-side-nav-search>a img.logo,.wy-side-nav-search .wy-dropdown>a img.logo{display:block;margin:0 auto;height:auto;width:auto;border-radius:0;max-width:100%;background:transparent}.wy-side-nav-search>a.icon img.logo,.wy-side-nav-search .wy-dropdown>a.icon img.logo{margin-top:0.85em}.wy-side-nav-search>div.version{margin-top:-0.4045em;margin-bottom:0.809em;font-weight:normal;color:rgba(255,255,255,0.3)}.wy-nav .wy-menu-vertical header{color:#2980B9}.wy-nav .wy-menu-vertical a{color:#b3b3b3}.wy-nav .wy-menu-vertical a:hover{background-color:#2980B9;color:#fff}[data-menu-wrap]{-webkit-transition:all 0.2s ease-in;-moz-transition:all 0.2s ease-in;transition:all 0.2s ease-in;position:absolute;opacity:1;width:100%;opacity:0}[data-menu-wrap].move-center{left:0;right:auto;opacity:1}[data-menu-wrap].move-left{right:auto;left:-100%;opacity:0}[data-menu-wrap].move-right{right:-100%;left:auto;opacity:0}.wy-body-for-nav{background:left repeat-y #fcfcfc;background-image:url();background-size:300px 1px}.wy-grid-for-nav{position:absolute;width:100%;height:100%}.wy-nav-side{position:fixed;top:0;bottom:0;left:0;padding-bottom:2em;width:300px;overflow-x:hidden;overflow-y:hidden;min-height:100%;background:#343131;z-index:200}.wy-side-scroll{width:320px;position:relative;overflow-x:hidden;overflow-y:scroll;height:100%}.wy-nav-top{display:none;background:#2980B9;color:#fff;padding:0.4045em 0.809em;position:relative;line-height:50px;text-align:center;font-size:100%;*zoom:1}.wy-nav-top:before,.wy-nav-top:after{display:table;content:""}.wy-nav-top:after{clear:both}.wy-nav-top a{color:#fff;font-weight:bold}.wy-nav-top img{margin-right:12px;height:45px;width:45px;background-color:#2980B9;padding:5px;border-radius:100%}.wy-nav-top i{font-size:30px;float:left;cursor:pointer}.wy-nav-content-wrap{margin-left:300px;background:#fcfcfc;min-height:100%}.wy-nav-content{padding:1.618em 3.236em;height:100%;max-width:800px;margin:auto}.wy-body-mask{position:fixed;width:100%;height:100%;background:rgba(0,0,0,0.2);display:none;z-index:499}.wy-body-mask.on{display:block}footer{color:#999}footer p{margin-bottom:12px}footer span.commit code,footer span.commit .rst-content tt,.rst-content footer span.commit tt{padding:0px;font-family:Consolas,"Andale Mono WT","Andale Mono","Lucida Console","Lucida Sans Typewriter","DejaVu Sans Mono","Bitstream Vera Sans Mono","Liberation Mono","Nimbus Mono L",Monaco,"Courier New",Courier,monospace;font-size:1em;background:none;border:none;color:#999}.rst-footer-buttons{*zoom:1}.rst-footer-buttons:before,.rst-footer-buttons:after{display:table;content:""}.rst-footer-buttons:after{clear:both}#search-results .search li{margin-bottom:24px;border-bottom:solid 1px #e1e4e5;padding-bottom:24px}#search-results .search li:first-child{border-top:solid 1px #e1e4e5;padding-top:24px}#search-results .search li a{font-size:120%;margin-bottom:12px;display:inline-block}#search-results .context{color:gray;font-size:90%}@media screen and (max-width: 768px){.wy-body-for-nav{background:#fcfcfc}.wy-nav-top{display:block}.wy-nav-side{left:-300px}.wy-nav-side.shift{width:85%;left:0}.wy-side-scroll{width:auto}.wy-side-nav-search{width:auto}.wy-menu.wy-menu-vertical{width:auto}.wy-nav-content-wrap{margin-left:0}.wy-nav-content-wrap .wy-nav-content{padding:1.618em}.wy-nav-content-wrap.shift{position:fixed;min-width:100%;left:85%;top:0;height:100%;overflow:hidden}}@media screen and (min-width: 1400px){.wy-nav-content-wrap{background:rgba(0,0,0,0.05)}.wy-nav-content{margin:0;background:#fcfcfc}}@media print{.rst-versions,footer,.wy-nav-side{display:none}.wy-nav-content-wrap{margin-left:0}}.rst-versions{position:fixed;bottom:0;left:0;width:300px;color:#fcfcfc;background:#1f1d1d;border-top:solid 10px #343131;font-family:"Lato","proxima-nova","Helvetica Neue",Arial,sans-serif;z-index:400}.rst-versions a{color:#2980B9;text-decoration:none}.rst-versions .rst-badge-small{display:none}.rst-versions .rst-current-version{padding:12px;background-color:#272525;display:block;text-align:right;font-size:90%;cursor:pointer;color:#27AE60;*zoom:1}.rst-versions .rst-current-version:before,.rst-versions .rst-current-version:after{display:table;content:""}.rst-versions .rst-current-version:after{clear:both}.rst-versions .rst-current-version .fa,.rst-versions .rst-current-version .wy-menu-vertical li span.toctree-expand,.wy-menu-vertical li .rst-versions .rst-current-version span.toctree-expand,.rst-versions .rst-current-version .rst-content .admonition-title,.rst-content .rst-versions .rst-current-version .admonition-title,.rst-versions .rst-current-version .rst-content h1 .headerlink,.rst-content h1 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content h2 .headerlink,.rst-content h2 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content h3 .headerlink,.rst-content h3 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content h4 .headerlink,.rst-content h4 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content h5 .headerlink,.rst-content h5 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content h6 .headerlink,.rst-content h6 .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content dl dt .headerlink,.rst-content dl dt .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content p.caption .headerlink,.rst-content p.caption .rst-versions .rst-current-version .headerlink,.rst-versions .rst-current-version .rst-content tt.download span:first-child,.rst-content tt.download .rst-versions .rst-current-version span:first-child,.rst-versions .rst-current-version .rst-content code.download span:first-child,.rst-content code.download .rst-versions .rst-current-version span:first-child,.rst-versions .rst-current-version .icon{color:#fcfcfc}.rst-versions .rst-current-version .fa-book,.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version.rst-out-of-date{background-color:#E74C3C;color:#fff}.rst-versions .rst-current-version.rst-active-old-version{background-color:#F1C40F;color:#000}.rst-versions.shift-up .rst-other-versions{display:block}.rst-versions .rst-other-versions{font-size:90%;padding:12px;color:gray;display:none}.rst-versions .rst-other-versions hr{display:block;height:1px;border:0;margin:20px 0;padding:0;border-top:solid 1px #413d3d}.rst-versions .rst-other-versions dd{display:inline-block;margin:0}.rst-versions .rst-other-versions dd a{display:inline-block;padding:6px;color:#fcfcfc}.rst-versions.rst-badge{width:auto;bottom:20px;right:20px;left:auto;border:none;max-width:300px}.rst-versions.rst-badge .icon-book{float:none}.rst-versions.rst-badge .fa-book,.rst-versions.rst-badge .icon-book{float:none}.rst-versions.rst-badge.shift-up .rst-current-version{text-align:right}.rst-versions.rst-badge.shift-up .rst-current-version .fa-book,.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge .rst-current-version{width:auto;height:30px;line-height:30px;padding:0 6px;display:block;text-align:center}@media screen and (max-width: 768px){.rst-versions{width:85%;display:none}.rst-versions.shift{display:block}img{width:100%;height:auto}}.rst-content img{max-width:100%;height:auto !important}.rst-content div.figure{margin-bottom:24px}.rst-content div.figure p.caption{font-style:italic}.rst-content div.figure.align-center{text-align:center}.rst-content .section>img,.rst-content .section>a>img{margin-bottom:24px}.rst-content blockquote{margin-left:24px;line-height:24px;margin-bottom:24px}.rst-content .note .last,.rst-content .attention .last,.rst-content .caution .last,.rst-content .danger .last,.rst-content .error .last,.rst-content .hint .last,.rst-content .important .last,.rst-content .tip .last,.rst-content .warning .last,.rst-content .seealso .last,.rst-content .admonition-todo .last{margin-bottom:0}.rst-content .admonition-title:before{margin-right:4px}.rst-content .admonition table{border-color:rgba(0,0,0,0.1)}.rst-content .admonition table td,.rst-content .admonition table th{background:transparent !important;border-color:rgba(0,0,0,0.1) !important}.rst-content .section ol.loweralpha,.rst-content .section ol.loweralpha li{list-style:lower-alpha}.rst-content .section ol.upperalpha,.rst-content .section ol.upperalpha li{list-style:upper-alpha}.rst-content .section ol p,.rst-content .section ul p{margin-bottom:12px}.rst-content .line-block{margin-left:24px}.rst-content .topic-title{font-weight:bold;margin-bottom:12px}.rst-content .toc-backref{color:#404040}.rst-content .align-right{float:right;margin:0px 0px 24px 24px}.rst-content .align-left{float:left;margin:0px 24px 24px 0px}.rst-content .align-center{margin:auto;display:block}.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content .toctree-wrapper p.caption .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content dl dt .headerlink,.rst-content p.caption .headerlink{display:none;visibility:hidden;font-size:14px}.rst-content h1 .headerlink:after,.rst-content h2 .headerlink:after,.rst-content .toctree-wrapper p.caption .headerlink:after,.rst-content h3 .headerlink:after,.rst-content h4 .headerlink:after,.rst-content h5 .headerlink:after,.rst-content h6 .headerlink:after,.rst-content dl dt .headerlink:after,.rst-content p.caption .headerlink:after{visibility:visible;content:"";font-family:FontAwesome;display:inline-block}.rst-content h1:hover .headerlink,.rst-content h2:hover .headerlink,.rst-content .toctree-wrapper p.caption:hover .headerlink,.rst-content h3:hover .headerlink,.rst-content h4:hover .headerlink,.rst-content h5:hover .headerlink,.rst-content h6:hover .headerlink,.rst-content dl dt:hover .headerlink,.rst-content p.caption:hover .headerlink{display:inline-block}.rst-content .sidebar{float:right;width:40%;display:block;margin:0 0 24px 24px;padding:24px;background:#f3f6f6;border:solid 1px #e1e4e5}.rst-content .sidebar p,.rst-content .sidebar ul,.rst-content .sidebar dl{font-size:90%}.rst-content .sidebar .last{margin-bottom:0}.rst-content .sidebar .sidebar-title{display:block;font-family:"Roboto Slab","ff-tisa-web-pro","Georgia",Arial,sans-serif;font-weight:bold;background:#e1e4e5;padding:6px 12px;margin:-24px;margin-bottom:24px;font-size:100%}.rst-content .highlighted{background:#F1C40F;display:inline-block;font-weight:bold;padding:0 6px}.rst-content .footnote-reference,.rst-content .citation-reference{vertical-align:super;font-size:90%}.rst-content table.docutils.citation,.rst-content table.docutils.footnote{background:none;border:none;color:#999}.rst-content table.docutils.citation td,.rst-content table.docutils.citation tr,.rst-content table.docutils.footnote td,.rst-content table.docutils.footnote tr{border:none;background-color:transparent !important;white-space:normal}.rst-content table.docutils.citation td.label,.rst-content table.docutils.footnote td.label{padding-left:0;padding-right:0;vertical-align:top}.rst-content table.docutils.citation tt,.rst-content table.docutils.citation code,.rst-content table.docutils.footnote tt,.rst-content table.docutils.footnote code{color:#555}.rst-content table.field-list{border:none}.rst-content table.field-list td{border:none;padding-top:5px}.rst-content table.field-list td>strong{display:inline-block;margin-top:3px}.rst-content table.field-list .field-name{padding-right:10px;text-align:left;white-space:nowrap}.rst-content table.field-list .field-body{text-align:left;padding-left:0}.rst-content tt,.rst-content tt,.rst-content code{color:#000;padding:2px 5px}.rst-content tt big,.rst-content tt em,.rst-content tt big,.rst-content code big,.rst-content tt em,.rst-content code em{font-size:100% !important;line-height:normal}.rst-content tt.literal,.rst-content tt.literal,.rst-content code.literal{color:#E74C3C}.rst-content tt.xref,a .rst-content tt,.rst-content tt.xref,.rst-content code.xref,a .rst-content tt,a .rst-content code{font-weight:bold;color:#404040}.rst-content a tt,.rst-content a tt,.rst-content a code{color:#2980B9}.rst-content dl{margin-bottom:24px}.rst-content dl dt{font-weight:bold}.rst-content dl p,.rst-content dl table,.rst-content dl ul,.rst-content dl ol{margin-bottom:12px !important}.rst-content dl dd{margin:0 0 12px 24px}.rst-content dl:not(.docutils){margin-bottom:24px}.rst-content dl:not(.docutils) dt{display:inline-block;margin:6px 0;font-size:90%;line-height:normal;background:#e7f2fa;color:#2980B9;border-top:solid 3px #6ab0de;padding:6px;position:relative}.rst-content dl:not(.docutils) dt:before{color:#6ab0de}.rst-content dl:not(.docutils) dt .headerlink{color:#404040;font-size:100% !important}.rst-content dl:not(.docutils) dl dt{margin-bottom:6px;border:none;border-left:solid 3px #ccc;background:#f0f0f0;color:#555}.rst-content dl:not(.docutils) dl dt .headerlink{color:#404040;font-size:100% !important}.rst-content dl:not(.docutils) dt:first-child{margin-top:0}.rst-content dl:not(.docutils) tt,.rst-content dl:not(.docutils) tt,.rst-content dl:not(.docutils) code{font-weight:bold}.rst-content dl:not(.docutils) tt.descname,.rst-content dl:not(.docutils) tt.descclassname,.rst-content dl:not(.docutils) tt.descname,.rst-content dl:not(.docutils) code.descname,.rst-content dl:not(.docutils) tt.descclassname,.rst-content dl:not(.docutils) code.descclassname{background-color:transparent;border:none;padding:0;font-size:100% !important}.rst-content dl:not(.docutils) tt.descname,.rst-content dl:not(.docutils) tt.descname,.rst-content dl:not(.docutils) code.descname{font-weight:bold}.rst-content dl:not(.docutils) .optional{display:inline-block;padding:0 4px;color:#000;font-weight:bold}.rst-content dl:not(.docutils) .property{display:inline-block;padding-right:8px}.rst-content .viewcode-link,.rst-content .viewcode-back{display:inline-block;color:#27AE60;font-size:80%;padding-left:24px}.rst-content .viewcode-back{display:block;float:right}.rst-content p.rubric{margin-bottom:12px;font-weight:bold}.rst-content tt.download,.rst-content code.download{background:inherit;padding:inherit;font-family:inherit;font-size:inherit;color:inherit;border:inherit;white-space:inherit}.rst-content tt.download span:first-child:before,.rst-content code.download span:first-child:before{margin-right:4px}@media screen and (max-width: 480px){.rst-content .sidebar{width:100%}}span[id*='MathJax-Span']{color:#404040}.math{text-align:center}@font-face{font-family:"Inconsolata";font-style:normal;font-weight:400;src:local("Inconsolata"),local("Inconsolata-Regular"),url(../fonts/Inconsolata-Regular.ttf) format("truetype")}@font-face{font-family:"Inconsolata";font-style:normal;font-weight:700;src:local("Inconsolata Bold"),local("Inconsolata-Bold"),url(../fonts/Inconsolata-Bold.ttf) format("truetype")}@font-face{font-family:"Lato";font-style:normal;font-weight:400;src:local("Lato Regular"),local("Lato-Regular"),url(../fonts/Lato-Regular.ttf) format("truetype")}@font-face{font-family:"Lato";font-style:normal;font-weight:700;src:local("Lato Bold"),local("Lato-Bold"),url(../fonts/Lato-Bold.ttf) format("truetype")}@font-face{font-family:"Roboto Slab";font-style:normal;font-weight:400;src:local("Roboto Slab Regular"),local("RobotoSlab-Regular"),url(../fonts/RobotoSlab-Regular.ttf) format("truetype")}@font-face{font-family:"Roboto Slab";font-style:normal;font-weight:700;src:local("Roboto Slab Bold"),local("RobotoSlab-Bold"),url(../fonts/RobotoSlab-Bold.ttf) format("truetype")} +/*# sourceMappingURL=theme.css.map */ diff --git a/latest/_static/custom.css b/latest/_static/custom.css deleted file mode 100644 index 2a924f1d6a8b..000000000000 --- a/latest/_static/custom.css +++ /dev/null @@ -1 +0,0 @@ -/* This file intentionally left blank. */ diff --git a/latest/_static/fonts/Inconsolata-Bold.ttf b/latest/_static/fonts/Inconsolata-Bold.ttf new file mode 100644 index 0000000000000000000000000000000000000000..58c9fef3a01c899867e280f49283fbb8e57d631d GIT binary patch literal 66352 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 X9Qeq-SAUJIQg_^iJwbxyCGCF$zf$1i literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/Inconsolata-Regular.ttf b/latest/_static/fonts/Inconsolata-Regular.ttf new file mode 100644 index 0000000000000000000000000000000000000000..a87ffba6bef48195c8cf4e3ccb42ea77034f7cbc GIT binary patch literal 84548 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%0Am60^i>^d(hPdT;qb{g1P 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 OG|;OYVSulL^Zx)kukT&} literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/Lato-Bold.ttf b/latest/_static/fonts/Lato-Bold.ttf new file mode 100644 index 0000000000000000000000000000000000000000..74343694e2b2114272f38b1124813b972cb592e5 GIT binary patch literal 121788 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 literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/Lato-Regular.ttf b/latest/_static/fonts/Lato-Regular.ttf new file mode 100644 index 0000000000000000000000000000000000000000..04ea8efb1367727b081dea87e63818be0a4d02f0 GIT binary patch literal 120196 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�r(aJ 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 literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/RobotoSlab-Bold.ttf b/latest/_static/fonts/RobotoSlab-Bold.ttf new file mode 100644 index 0000000000000000000000000000000000000000..df5d1df2730433013f41bf2698cbe249b075aa02 GIT binary patch literal 170616 zcmb4s2Vhi1wD!#0vgyfYv+0E0Y#PZXfpj3il1dFBv=mAbNC+iJ@4X2~7X_t?fCva1 zKm<gpA|N6n0@9m^pa`gllHB~?+}$9y_ue0zom*z_oH=v)Id>(L5TeD0NIbGLGP9hU zJGUS#)dN>8*|{A$`4rqEIL{@daA$U>E@_Qh1~(&YsYr-0yhEqhxP2^g8X<HU#uxXl zEEzoI+W6gscvcYN(7*S{;fBbaY!)FQPjNq`d~n~&SDeSTB*gzLA&!gsmJAz=>mGQ% z1A2$P1ILs*ZBk+hi5^Jk?T;(UO8PvltXhKS2jYHG1ukf>I9K7kGtNUQDu<80n0zA- z=Xk!ypn)&-F6p=L!9+qr8{%<IDoaKWmYz7>#r@G3Zx~ckS$4l^n2|6~+?VDLeree7 zfTB1z!h8<maan_hmJN2GbKl~R#`yV!;|6WVZ->QR?y0{LXAUMIA3xN_@c#1yT?STn zt9jEY+o2TW90}uB@rUm?l-7KWH9o0bQ+vYkg8C%eJ@r!z;8(;zvXpp}Vxqw}b4d>} z2si(5T!g)#L=Z2seMADBZ%XlaWPMvNd`Zgdrm;QnI$^cB#88AY1HUqO%+O){sJ6xi zgF`8cG7!4D1D~;pWW^8zVe|<fi|3-}O>iS~#jPY<>_if!*GMB#A<^^@d4;`43fM8y zOjt~U#Wti7{f#scV#ze-M5eGGYQGm3lM-PzX)X>V(PBPH5T}w5F$3qLNfDmaNGu}h z;t0}$eoBhyCnQk#g)|X+lX0SkR0!XY`WiP9CmkRSq&6f)iX{osH1vTaMSO(5HHnp5 zk`#8FB#RqKkhB}utt3S=o21AwxWAF4OVQ}xML!w$E|L<dgha^BBwX4@f;BryJ!us& zN+SW&3DSn8kynJS#Dz5`&cblOn?<^_LBt}Kkv8JW+IwO$VBLq7PSV*Qq$$?cQSv4R zwuFSUZnf9M8#tav44NT$t`{+g<4Ftg0%?FXrwctvmKa1zST!*NcSdmmsW0~jKHtH( zeZ*gkA^B`R38!1gboL5ymZC@>=0c_dSGnRFq_MP&<Vj;l14hYA@e=6*{4A7%NE@Ly z=_%|XB5*%cJ%30Rv+qfN(SxK3$)uOilH{@J_-;CI)R!c&24oTag>+)Rq#S!zDSS>W z(hM>}sv_lbZ_-+*BGH;!k|vr-GifwwCHVt)4M@2Bl(ZHPkyNn~czlzz6R(nBxjqSF zTd}SuBog>f!P@=gh9pB`Bu8_S^wo3%{vHvtP_On!=?uxnxE%Qb36^@0XjWPKqu7gd z7sir8p+CtK`eD6hG8;G;O1~lz!Y(pU_>2_N10;rdkR0YndI;}VcVm6XB;g!Mryl}e zj7$+dfiJ8{{FJnmb`lrBY>_@Bq2d+NLQW$s0c)0YizLgRkYvdMxDSw0aT}Q^769kd zNd{=Jn@CAp@oKFit|3F&A)*KUX+#U@EBS#Imyr=-Ea@nILvn;mc<wIZDZ7yZzHjmb zQcqq*%A|5qi9HRKe<R&6XDs$!>oAVQI2<J{<x?bq!y)ApiyTfO9m=uipO8d3lVoyw zm7b7>(j?Gi3282uV!W1^9nwgqLno3cA16tgCAgmpn)`*sYCa@7&~KW!gcL{={9_@h zQU+<HX+k2zFp?(CCS9aBQY0mj*79xiFXJ57KrhMCS<*%t0AA{a@wl#e9W?P83D+3$ zoI7YqBuzd~vLz$wF8S0x0$%boPNbP;0G{DpTZ`v()pREl<*j5Ao|mr~4IUeaIll%^ z-y}&6fkdmx2fw~TngB1^j!#I0!!_a~_9qF#T@uM@2{_A<regi;fFtmvIEAEZV#p9V z0`Tx>ufwyik#eyC_M{#06wZ=4q7#`)za)L>X;P^<Oae9INTB#7F-tkbQ~bU57x81z zWDC+*#YGhMdpT(=Ye2K>NoUPiVv^^PYzG$-EjK374x>p+O&Q4p?hC*VJ+bycc^mPS zJ@LF=z<n_GC6q)-X|+FtmNLZ8LHDuPyE4)l@MnrMNHcLZX)3vrQQ{C%Dzzg?^5>Xu z4{0TLC%)2_+K1vY;BGb%AzNbPBP7ism}F?0;`<s>40+NG_-cUtjF)86i9&iqPLjHw zY=yv`iq;L+>Z6~F#x+d>8vdm2WWC&!Y!JJW?({k-rsqjhsz4SwlaAo?GNBdtw<+-2 z8gg|o$z%t}XyHDYExk`>Yo?IKtO+qQ3&|FS61}j5G!k|Izg47-{0s0FPMS!slE%VS z&}}tw6wiZK=8_I_8R;!QB)v3{NAgU_m3<^hx=Ugqe`CSFiy+$?fnM|3(b_f84<p1J zGES(0%yI%xgp&~Z2r{xUczzxU=WB3SL?&t$5m(S$h*(G>=>6K?SUoaL7)SaFlOXfQ zqb(raMbM#`ReMovNecKmldz5$$mFj`lsJv_#{5wtr=ge8&XV5JN#NlWj(d^_pw$d{ zm@a<^I@p72UywfH*N`*U!1FKR{5okQr9no!Lk5G+Ky&r5E+5Fp4&e6z>>y;FJ82IX zS}{xQZLuk6w+-;S1H6|<^2B(O$^s#K6G)NJmUMvpY9f?EmQ|2Sb`i2{G$|H(k$hn- z<m*S|W%f335>JK#*Ofv&;B5?a%2eQdBH)~X^GecFe1-G_3|%>npeI_0gP?OD`>~b+ zDH-zSBJf^;<GOP{@X@;@AK%LoZ(-jcKUF;q-7CFCV$_yE93d|vpmUh2L%AOPx5o7< zbn1(Z9j|@N^(y*1Xvd!GQ?65AXk3@R*i>E0_2qvxu0x?eUu@7J8ni67we}g>mFK#X z>(3V(*PAakt~b&6n)rPG=&>%Yv$@^yuRXUV@^GKq6M*S|?O|`II{!a<Zi}e)!13C% zSjYFk+a>f5(f^F~IjH#LwgT`98zEV|k3EFl0$sS1>jG{+aQlVZ5HI$E$##xCHmLgm z+v4xN<W;+s?+eG*KYG|c-2UJ;(2G5{hqz7hzx8$+GQZdhA;ir0o$ts0wdeL0w|P_= z;rnK{ySVMc?XMSm4Qvo@bEtZQ+Z&IdpLyfF3pwy#O_dE?F1*kn7u>jPKx6Dw?d|6> zfy;##nko~xT(CDT6JDH0eKwapb*)YYy)c(LFXR!INp;O8n?MJrAnQ&McRMV9kyTt? z)in-ZU3(EeRc3Oz$s3nrFE-%ixm<f;4Rvc#<s6rBb#ji&Iy8r?n2XDV$+h|N`q~~s zbZvKOU+rD#Vr^HcbL}VWQ0*S|KDWO)pJ1OjopT!IH2V)*8}f$lE4Qn;+)($J+g#kv zf{mrxSFoW}n~~Ehw@YCQW1b`2wo>_>+gRML;`70-<Me5lMaSywd~P$<!KK=M7|U%c z6&}uq;04w0;`Tq6ZyYYbq{=1E>)bBlvW45{HoM-R+jOd2f?cKB>YP_0kGO5m?J6#7 z>S*}yeH~46pNRWP!V@wIeElld(Hth#C#aKC8*5uR#FM5DQ(#Nj;a24jVB&Tvw=3;- zl9yu&Y2nlddkvdWwejj?8Rs3?upBSkrsOuDx+isW*!$;v#Bs^j&FvW2-MrO(ukP8Z zP0C^5wki7Oa-`07v-jK<<@O@q16BV1t>-qZYG=a6(7?V_@ow{T(p7sG_9@@Hf0fzl z_1cC1^ZkF3^?!d}-FpACuRSZK*ADtGnXl3t*GXIlf)1YJ;-4}$LL3ix|9Raei|u|- zo&WP+{Xb-=-A}6Xm;S4-qr1QN;F)yZIFEALRdo~h2fzoaKfrl``!M#ss_RvL1O3<0 zhFoV4!_S4?8pRvN7$MU%;;*$&>u9C!`6~Z$--G)#e4p)f`kV&19C!q~3wA8I0Xz2@ z8O3cL{0a6JNGLy*i*bb?1rkxtK!1}=CNe3-5hJd|NG6gsWD9wZ93V%@7vv84i73>a zYH279rwwT*+Kcw36X_(nn7&1=^dYTf0W6snuzl=PcAQ;dKMPb41V_PLFbQ*nxx!-M zEx{`65e^8)g;T;A;hY#M#)_F@2eDLqNgN~26i<og#T(+U5|un8T@Vdw5i}#{QP9sp zzt?YXa5m@-L55&Mn4zH|-q6I5YRE7QH%v0DGrVKiVw8+Jqqi~G7-ozy_6%mha<F@_ zXRv>8P;gXmtKj0`vd|Mxjyw~U+S;1hTCC8vMgs}P8sEYiw~~Y8Q*xSoM;?+|>Onne z7>%HfXlGhXE7Ucvq1&*=KbWt5jYqM@3s@t0zQ*ZT<9y*&;ccNx*ee_qP6%IOjYJF+ z8;V(CuGm`~ERGdtiC>5p#GB$1iAmZZ64X3sa?qNf$3eefjl`fc_!ta^P^>Y|(D?Zp z-^Lm@|7DFu_BCo>SYsb`jTCFF#u};UQ~N8TP&aA&+Jm%Z?E%mN{2Yqt9*sh4fCi6& z`$5!LtE;8TFUohcgri0&Q7q*3nzJ?QYd)^oR`Yhv+M1O$%W7ueX~SxV@)0!>8m-N% z{-gRgLaIMN+lICdZ56)H+j1PYBIMgH-|BB4z5Vod;q524oo*BmawGRfha2s0WZVk8 zk$TJPM*I!&`X7W`KZ`c{`he^GuJ^pQ;CiR);n${LedpTfYoo3WzE*jy<XYynm}^m& zK6Uy6TlYGB(?-Jp<uZrI{)cCft5^@hgf#et)~9X&?`b*ZQO|$<qdoa$jDVMjIqZLQ z1<r0`UKcb(9$9m=V`vx9eyAH&*R$(&M=$p5G{&O+U;fw@`zS&5r@zo&=@a@JeM)~P zljuVxGKtAd!yFK?nT!~q6LV%R%$2#pvz^A=nFrG{Po`sDWICC_>N5i~vS4OnA!H^z zrBD{e!dV1sKxWaOgok7{{Kq*gA6#3=idc8n0};obtQRY0C9IV7W_?&0yySVTob_cD ztRL&o2C#u-K3Tvj*&y~38_b5Vp=2Rh#HO&RYzCXjUS_lCWBM~VMbFl-x7b?tHk-sI zvuTKuy-PN+XJj+0W;IOVvPF;tS<sNJf`i~lwh2yxGqDOTq)Kol+XXklo$L@i$WHRU zpcOm?o!}+t1#iJe@FfQXe<6Sz6#Rrj!AMRC!Q=}_nGhjV2m=>?NzMr2LXi+bz7iUc zvqGd0MZOly<QzFqE(p=&8*)*I5n_dgLL(tgh!+ybC30Cv6q3OIcggqU9wK}9$q(d5 zA%#4E+<QnK3605Pp$WYIpM_NNi_lEyE;J{#LJI_nEka8nO-QGdG6=j3p@)!3MJiEQ zl!cx`FX~10)SLPU#X^bDTPTJ63=^G1XHkM2ji3!^B#ja^)J&sk45S4W`UqvhW8r5S zOB;#~q9deGobZeAD~+cKG?6CJWSSzB3w?zr!f!%_&`<Ofb;48OciNaX5&jUK(WW$& zHWNkKoVE~|C<y(90m49Pp)ExZQA^Wky67Uh3e`f5=q9?;3}KWoQW!0a5ylGRgz+?! zW(kT=D=ZQg(`?!b@@$FdCF*Hw;Wg1)cwJaZ%V@diEBer}!XrAKzDkz}`9cAad87q= zqW<?6DyPsVw!gamFSlPfQS}lc@BWCuOVC9c;y@gU6LBUk&`55?9k~iE@gzFpMf8Z= z`w(B^NBl_ubXYwSMCua*^j0u2kq{C}!VnROAPq<)i6UkaO=3taX-FE8I1-PDPa;Vo z$s~m|CQV3Fl1iG9=A;F&kd`Ekq>~JiNwP>bLBxl&A#F)J(w^jy4#*O8BzdG0=}fvH zme7sllLAsmib!{44|<Ybq!`Nwr_yJ%2At{$zVrZ3YQc}5%!_$Ld-yOv=FbA5E9<c! z@TU<R8q7k#p<&=o@FsnUyaX-W8!@>dWCWQ;DoH;&nG7QpbUv9xrqEZ&V7h=VBxPhc zok?fWm&qYIm-HuN$ot^=m!Y>y$Ur)Wyh`Umvkf3)=`bQdj{L?PIH&UcqXTIr^jbeM zlP+SB><u~!J2`@m<hu#!IFk0KgXnO`9R<>-mR2*$7!w%bk_U23Qe}=4nM2+rYset7 zf~+K~U}wBVRujm5D=}LQ#pTgfYBuySSP$k}#jrxFm|2u>G#LZt<QuHHx%oz`r69my zP2oo=1qBAHb7n~&YXm=a&NNsX@`Hwa#KGKrL%CtjoDzf8DL20uR}B1~6F*AgM@hv2 z#RUZg0ag-KP++o>-2AeFf@mu<8}J-4v;-hX>ACq<$&_Z5O=$r}V}X?xM_UE63Gf*D zR7s_227YI|Gi8xR9HtxQ80O${RSl)kIUVzha|2593i3?_xM%5<j~f9Tdizw-R?%$L zq(^NBnWq=0MO!7Dn$k=LD>0>&SSOcaGOHLFZI#Ui4iU@jZKau|#ThCP8rww@WvX%z zLyHZWb4(>1Y3dqD0LO#X5P;e0rn3s6rjiWXmmSPil9XwsB^l9HM>C#hFjyVa+i(=% zz?4>Cb>e4vICH{TwAIOM*e#M${?Qu~S)J314ReZtd%zoQbvC!{oL{A(83iF$*D}-S zXse64ZO8n!oop8ajJU2-ue+M7h)a5x{3;ihbWERSb&4vml5{HzO{;R`A5QqNQg0wZ z2+hr}qQDHcB5e-vifJ7qjV64p?l{19pMQmgs&@;pjBEg(T@3vFi85p!btWu5-AbBo zhrCtM?FLw+%+C45>S9VW6yv$?ySh@yjI^{l#Z|6Sl(jM{AQ+2x$3VBJXsd_0it=7- zu426RG*=0{*O{wC-g^P7yw{tnWZrw5t2Dg#F;_Y8-q&2^$a_Dt)gkKtIJZCM_QQ7q zFgNc5F*on)VQ$_BVQ${n$K1R(U~b+UF*omnF*ol`n49+@W<#n<KcQwU*|pe^4ulr- z4Jbix4T&^HTf@xO&?svtC@&mDmJQmdBRx||ipemiOa9+4Vuz!x5zp~Sy{+MqR;q8P zqOZY=%l+%ENV6ePg(k`j{cWRfa7o>K{E&F>R0VxTb5lxHB-H~dGu8kI>P8iVfJ#!L zt<mNfpVVk;%)i{l&iBTMSRjvhhZ<rG*__9)=+<-QWSg?VIr*hngO!4pV<^>oVU~tw z%njPZf9epcoEcR%C&pwjq|U*!8vS|O5Mz6WRpf#qGs<8s=6q!7n7@M=1Vg|M7AE)? zq;bx6fP}z&n9-C4!cGU3f{RF$O-!-$;yxy;kY3UU%*)bC0&rYh08YTL5=;znXv!){ z2{7R~S%4m$`Yb%c_9)B%fq)a>B+4pbPbL0ce6IvULe;0^6T&aRWGwjeiP*h3z8<&` zRw>NB9#blo8LwWpI)FnAhAb2C76l@RwkD{{2V~5S9nv{J#*hjz&Ec|N#KT@dUntI6 z;}!@lv$x5HahpUl*|7?kqOFPc8Pn^~TFi9<R#AufB(up7!<U~0`IK4^Qx!(NK-tO9 zF9Z31UQT&_Ssh*X)xV5sY_>Lxs=M=-hc+==8%52*mh-)x1LFV3#6Wh8H4O7NRWZWp zr4E5s(1Ho18UxC;!I%negfx3jSanPM-zg{i|BqNWb~vx5no<IcFKnE#zz#_>zT`U8 zHRr1|a{O{Y?9e`6SPLvnZ{wKlgfoXO#%czGSpMUBOUME0rL#t3Oq$smi!PnxCKK2* zWI>GAVIu>A0UVPK<Yk(-6OxL9EF4gNkZs;h)hn%Vpk8Us$27yOHhc^}Xv@d&gLZrj zKWNX#G{!*=AHxqi@G<-#myh8G9r>81ILPB;_(3N=h97k1WB5TAKBhSiy7Dpnpc@~< z5AyjKeo(;2G{He3AHxrd_!xfBosZ!MJ<Qg)=V<Q9PpnC}+)F)5#!<0KHMpFDlM=Hv z{`u%qexi=<tse2webgg9w9ITxcs{h8pQuCosz-cig?hw?_A^@(pAYTNPt>6U)FVE0 zpnAlIR+^)%4rNv$BzH6y-_ek~ZLP=hpoi)Ff;|qfs(TwCBr~jnX|UBN(_m<8b?eyH zDt9W(w<ZKwBMORPaCL#~vNL(9m6<YN9m$c~U1WTC;iF)?7~z<im$BW&K@(Xe(~PPR zI;&&8)iNtzJqzP!urq9@u+Iv1)7lwUabA@K>-rym)I_fH#_MBbU$F@y2*td9M*5`o zz8o#))ZSOx+UjYZe>Du2?j72bUZziB!**x$*<M6s9>bRmg0D4Gcp&D93&qD$p)_B5 zAa|CB%S+^~@>%(T#-h3G5ack~;jCkzV;{#gj!&I3oCZ4WcXo5maDLtSf=i%Fxyx=> zf7j8jR@WzP4c$h&9d;Mp)7;D5C%Uh7KjwbZz1pL~W1rST+h2RwQ}*odxy$peE=)IE zx6F%qwegzebz7gRAFDs-?d_fKz0muDkHM$E&sv{5KGnV!-^sq~{6xP}zmxtk{+<1w z1b7Fm2qb|aft>@d20p20u2))bLy${QSkR!LO+g<AJ*n?mzfJv-^>@~PXvi`wGdwj0 z8P^#f2WJJ}G_^8~HQfzq6|z0#Txeiu&(Ou8_rlV`wuhU;i^F$DxJ2}f*xA6TL282~ z4R$rS80i!l9N9H;X5{|J+flwzSyA1irbg|Gx*YYy>|t(V?rffE-fC8&6QU<Z?~bmH z=^t}A)-!fw?A3<34KFszXtc1=#kh#L!np16Uh#$TTM`@++9k|NIFlHWI56>8Qb^Lo zq_fEh$xD(Sr{t#WZS2*!u<@qGPnt|^@}Q}u>58VeQxj76H)G8@H(S%}Y4e=s`&xLk z7}VmNCBw3@rQ9;5<;*me)*muNPH&a|diwPY|BSqho0$zWr)D0_^33X!buv3Bdvf;G zR_0dAT2;3$Y<;kef1A=aTiQHn+p6t}b{XyFwmaS4(td4@OV0QXti#k?r`*N4k2|*N zIIH8SyqLUMokBY8?;O&3PUk0Ga=Og#va`#bE=pJLZW-MU=bQ7V=ie&`Ea+3PsgM-r z7Va%F6wNBS+dZxOvhGiMbnbDYXIjrCJ+Jr5?{%g)q<DVulakz$wWXxAd+FZZUcLMG z-qgpfPhp>ZWhrGx%TvlX_Vw;Nyzl9X)QU9~Py4m$x2E4O{fqze-}wH^`tRz0rvJkM zE(5{_qz&jfVD5n31D*`@9hfk%>%i(tLuISV!pen}CkLet+W%76OEX_OHaKK(=fU#_ z|1o6M&?ZAS4!tvs4T~7oWLW+%>#*y?lZJO6K79Dx;k$;P8WA#L?1-@=2aeo3vU*g+ zsCJ`zj#@VA%&0#`n@4vaJ#qA!(I-Y<9pf~n&6tT}wv0J5=E+#|*q&p@j$J$U+}J1M z%;O5j%^!DS+=KBk<8#JO9=~z?g$XVbQYPe2m@{GRgtHU9CnilCI&s&;bCW_Ql}{Qy zX~U#Dlbt48CQqKcV)ET75mUNOshF~A%Hb(br+QA!m^y1}^|at=h11qdyFBgk^uXzT zroTS@^bD67IWuO?I5?wvX3)%mGp#eP&wM!Z>C2uk_ka2DtiV})X6>AHbGFCqjM<ZC zZ=Zc<PTHIebFRMP{YvLo7QV9UmCJMGxiNG5&z(Pa``pX(+~y_BE1kD+-r;$V=Nsm) zn16YJVZopU)&)-%wpqAq;e$nCi~1~DwdnAoJBvLQrz{@6_|3%!7yt08;nl2HhrYV% z)zhykOCpzaT{3;i;U#~(miF4{*Y>^k;Pr^ti(g;$`st-kOD#($F5R{C&a$9oU6(Ce zcJU3*H`=^0>y4*xCcQcQ&8=_#u-v?S(DHT5FR$=i(Qd`m6}wm5TN$)6V`cx9Z>~JH z^2w@*RXMActU9*Zdv(U@(W|$vzPg63iCfck&Ga=J)|^{Y{Z`~#`ESj9Yv)^c*7~n) zwRYgzg=-J4efYNb+o^94e|zoQ7uPwg%UU;j-KKR{*L$zeSwDaMsSRX9+=hw`t2Uh4 zpuCg%&Z>9LZWK3KHjdr6apT!{UEWQ5cjUVp-@UL&-qd8%z)dSQo!#uPIc0Oj=2e?d zZ;`j8Y#F*`<CeScrMx%wy}j?9e(%nEe{A*G8n!icYu?t1t&_Jd+qz}z!L4Vv-rZWg z&0|~0wv=r-+e){M-Zp>Rx@~*6o!)kP+f%EH)nHAqwy_plM_T7tS6R1Pk6JHUA5^g_ z@2beE=2dxB<yB*==2xw)+EsO;>T1>F?ecd2?J?Waws+m$fBVGki??sszIXen?YFmA z@9^9av7`BpydC8`#_pKEW9^PzJ5KDly5sRqhn+z?<9254EZjM0=hU6A@7%O=|IQ!Y z&wYRT`<vcB^}ezzVpsmIiMzJ$y8MB|2Ms@H_rb^yR(){zgR8q8cE{}QynE#CRl85^ zVSCc{4BfMA&xt*c_qy#(*xPyU#J!vLp4$8L!-x<2e7Nw#2m74%#qAroZ`HmF`;?Dj zKFa%O@<;nVy1n0Jf5iTF`$z6yv;XM+y9WXfv^g;Sz?uUm4;l`p9qe;()xnbopB(Z% zWI5F5(6U1(4?R5`dARH0S%-HW{^5xKk*p)dN5&snbL7;K+aG&>-0tJ4A0PYp=_e_l zjQwQ$C%2CV9&LAY(9y+54<3E+Y0#&+pYHthmt*aY?LT(=c*EoEjxRfY{do0>gcIXW zY(4Stv#`$wezx_qhbLoBc0c+0$%~)+f8O)+wV$6oC7wz-)&JDOQ@c*x{=(&ptS`oX zvFnRJPDh^Ze0t{T?Wb>l>G@^Wmy^FdcE;mO)|v5VHk`ThRq$82U(NsO=vlY3?asb= z_QKa8U-$od|2c<q#phO?`{BI#{OI$$FUS}2E^NI}{Y}?zmVI;YV(`Vniz_Z(y%ch( z|D~;$9$!wnJofU5EB;poUD<zCzM6A&;?*rzPhWj{E%2HJvH3OEPG4u&<F5C)zUKPX z8$ma^-&lC#;~Nie8g90`IsWGMoA+*o+$z2`_txH9cW!&$ZgYF`?d`Yke(V2j?zeNl zJ$c9F&Y(N1?wt9Kd}scy&v(ndJ9{_m?)<wa?keBMec$K%*S|mZ{U7(j?&aN^esAx+ zAMOX=&%HnK{=xgo50)P$|FH2#`Nuv#Zg?O*=<{I9gU3Hb{M7TO#XlYW>B+<3hl3wh zKkEEw>!aI`y&uQnU)RT_up1a^Y~9%!*%$FeM^ew?FX0lUX^clLI|_&>xRDI4r&cTK zqNv8CjkkRiwx4o}X0@OEx#aLWb5tJUgFg$|6LA{sl>o#Y(=8S^XC}CyWReP`z=6uL zOS-!g6Gf?`qlQV6d%7zg?@BZ32h|G<@b~le@rDJCsce599==i3B$#xjM5Ef`g?JsB z-lR5s>P&3v!B)Fl-J&G^J1VvLp!LDlyW3p;BmQP>s}G6}#vi0_D&_RecWLlux<)DH zZL@OqU8S6*(_pNflEm6bQ7bP)Bs9yC?&1hg-4U`5qmpPcFhLU22t~}2iWNkZn24fF zEE2KXA|eTb)PYEn(2*cupBbzV4A%S0`Y4(Z79JLsn2?m57_ayC)@Y0gVWwbN@8#{| zjn&B-y(uv)EIHZe<sBcF#D45C<m$QeyH;;I&IILlX{WAT3PxQycm9LbAO3=A1IPC) zDxs4)mYX|%`u@iAy7L$PA03iLPVSwTQxe<l==S%%)E)gqck8k=b9f0LLwvYV?GI9K z=@UeT0}$m+Mie*0(y|HA-;^?;F_kqbRFbhOYzdxUggw{DqNWH5I|OhE@k%GMEOo-V z^ioEs?JwBDCrX!)6d&iU2mGesu*7&3_QXWn%IN=aPYS0#jox`}>4pujy}t3VCAEpA zWz(iD=#!1Fz5Wg^y?Zz_rDckxX=)3_XFmIMzPN14md#V!Pua9-N|O#9nzV1yv160! z&nIu$Jf;2AO`E4Q?%1|P`^FtRHh$Vx9NHG(3M9JrzT|@S8WGKIOfoHL4Lt;bN};}5 zL8O7$J0T5=saqSiwv&Lct!uhWMbUoDGEBiKNx^25*`)W6(CGMLlhrNcOU90AXi^f^ zENgr;#&8)J2$ABFlBq`KyDDH~lW||gMfB7e8R-|^U;SxmmmbtBB;sO5)@i2fYu{yO z-;0Vu?<e+eq@2~ohYoU$it3sY-nwbaEIMoC<{sUbb$IWKPv(}cZI-6&Po0}H=WgLI zQbBU^w^Bd=?e5yJD5hYTFeR!eIVGfBbX-n1zSk5r9}j7s%D282J<h?j{CY<maF*3F zZ4?za!{%j8`BZXNzGV^W_X?EeY&vRlw8YQi?IMAm`4=go<rJCh3_l&dsPiDn@jf!s z>ODMtG^Q}3Euak#%8ApqZ=aSZA5>1WTsn)HIxa3%+9_N8mG_kPWeYm8U^?3dTQkft z>V-K};4o2t+}0A?9MpqoOyNnM+C&c)o*eH@v}}~}@nJb>%FbPrlH|iQl{HbO)O?k@ zpp@>So&0Go-P3!1Zp|5Gs=AI~mM)BdtZ^fO7C$#v7iT9&2aPOXJ+8=F5adTPyr@SM z4NaDi&kFUCbQ(bjr@6|R#<YRwJ}+uYQBECOy6wGX!qI}NakNNTJ$h$>^4lO9tbE4- z1x^}~#i9>tgq%sJB^dn0r1m03=755M3P4$`Bai%NsshV{v%gVq)Z$+v8ne>A${Wgk z<#nVE^n$rsDW$8bk%Yi=n<z`@BJwjNuDiuW6qpKdi7&tn1)+t5pc0LA;jm5%!y~C2 zUVgiEPS$JPFWO+5Miuq}y9Vm_v3TKGgtiBIk%Yl<rWUzQK#^!<AJm*=2~@eEu44*r zuES7)cv{@;qk*Ojb+{40(sjxeYT^&8{l0b@I}g0t#^Rv^@C6rY8|!1D@rN!j?+X*; zXh@Ng+WUBa!zOQnECHx>qn$7sa>OoC^n}ZiV6Hqoh$)z8wH_osj%Y(|!b58lC1Mlh zx0|<>C)DxQP3o*%sVMDT-nUO_IZIZqDPL18h_<8#8m)Y#Tn~Ehtu<Sf8P+vx;1=^W zBl9fe0$xXAu+-DY6!}6>v?MZO;kP+iL&xYnftciEttl~7>!UZeeDXUBd{X^rTaa+^ zoziFZf{?4nV1xz4D6A)t46-;uJK?*Mz|z|CG>gTA0eB6jm>_|OnqR1bPFS$IRw+-W zlH@971Xx0BqqxfW?_mWNS9~8XuGYuo8Lsh)ibodHE=Bal@G#&=<g$nQ7?b0*t?Bvl zuDy%O`YE@WL|t#+pls1brH0Y5E>{oG-$%Ta*?q+9q4FnGd+*5f>pPWirG?5ubv+5# zp9ricl4M&lT#$^_Qw<5CvIM!v8J`ssNh50{xdOvA5`ik9ROp1=Q&j;f=tNO3W`qRm zB2Atl2B-oGwPlz5fHTAnC)aHvBx9Xo<0DLT!n%q+eR|~$hUk&0=Vv#m>*#)CCMj2L zeWqN2+zA-ny==s=!Rv(1l_mN8i*w}7S1%mvwYg!`_L0ZFJ^!)XxpHvvumK#;$Xyb# zoyzMv5@U(-)G{JEI!F-Wl%+|3a-=A_q+?H98B7+PPOGvc3<f=RJTW=Z7!E=*YQr_c zJL}gkui3DoW~&?PLBne1(+;vP3p%_YXxp}+1q*~vst4g2k(e5r*&H}@$J|EJ(UJq@ zf`T7#Y?>oVDkyO%CP1bn3l&5VB|$95H3_u9UwzVaBpMCi;i?8e=^2ml7>QBq34Df_ zv`)ZgxKT(-N>1|BdodM#p*Dt4xkD4GGirr2e`R!o217H?+^KnROt}fX`3@>5FRkd? zsX(VForNs1PpM)J3a5fnefNxV@6tiZt)z1C@QKTsCu)T#1vv&rim-+p(1AZJw6>O3 z5MbaEMx9}eu^?DG+$7LYZsTwQAf3QP+!%m;!)ZY;WCR9Kf(UqcV7OlA?&=^Df9mhx z9!2B4eKcX*!qNC7!A8J3>bP8oYfz9ja$#@hy^<B*qJQSpl~ic7w8xRF%7bt2C|7Cr z{*FWIPpBxY93*{GKj>?3pZ$BJ_$JEz^Ou#I$lmKgqlvUzO>9DR$$NX(j~Mg1ZBH73 z9+Fgg;BpyOWXn2o2KmAy6M%N23OKEo7Z*NA)oP5%o}S4@*sw-1>E7m0H|4Th@bx1# zwa(W?N&G^2poA$^OP0`<%<slR<e9m&Ob6afz?%;-AyXb}F}n*4EC{25z&wN<h?;_b z2)q#dMMiLK01mF>3~mzItqKuFqRl1*a)cL-MK-)__)O)&m8;5+GlrKBRZgF#L{Wwn z6%8KTqi9HQj}Ey7g&jK-i7}NMV;k)napIeAPK<oNQS8Rb!(V@0y}fkg$kIN;hO?Xb z1Ns#f4H$rZZvpu0+4sGTB|8XPEK(}^0<Au<3dJ;RI+s^41)<Dr;*9V8ziqpl%kymy zg$zjKrVvX^P{lc<IxNHRWN&XBY$LmT@bad=j#$`eR?f-0RDbpw^;SOnx!qeC#`K93 zTUQze7w5m!`?DQ8yj!%S&iAj-DCKkIp7OEst#Y(}&{uvw^h|QhiZvVF8#^7PMg-Mc zU@1CL#CsiL01m^5$3+5R=23eQbtpF7qwc(WI;UW0L)-SlaS4i2zaI#lJHht-KmtDS zsQreU#Ki3;;eL;!17mp2lrS!FR4d9IhKg1z)Wg@g9B6{KES8Fpkwo4h3p65%>Lo3x zQ%k!sOZD4A4;ChWraYuC-J*k(hx|K?jHB&@XTo(*l7<*9L3j#`2h>M^iiGwcQ*J*9 zs{P=>sZ_Na5{<&M>dC@n-q^EmYX*L6o4<mj3SS7-FU${B1`g4(s+tdkzSVEA0QnSk zRTke;7Qq5k=SL-*@TI!{K_u1E*bSHg@j_k_S}apRg7c#KG<HQMNn%Hkv@6~MA>1c} zyzn=9Mrb^vpq-wZxiEvd;8%@f7{NL~O|xjnG1*;83fuIhP*SLJJbk_PwZYB8m~s(i zgRACF?a^drr|uQ`UF3r&ZylL*p>=GpPD<$?97l0VQ~4`t4k}R6NoPyP=FOVOqUaQk zor!>v4MioOpi6M7z)&ZVIdMwGn`#aYF6oZ2;_*rokgDg73*P<HX#6x8X_l0vkkF72 zlP)AA*cncw4A~l{n(ko`wSe456EDbIG$nfyqX82TBaVGQ(FUSZFHzg=grr2BD&FKH zjt_p!8R~1EmOpQ)&hNpy!{>Gpq<Bqa$go!&Jd`h#L&|Aosk<lYgW|fp-!d%yi{8p` zrIXf^UZgYVG`ixM;?&rZQWQeXKC!+p4QKSC@^OBLyu1e=D>N=4Nvt{2GyCE@w3NQ0 zbXDF|Rx0HYL9a%}qHe5;Ze~;osChPNT4EMz+~`A%!yzD}0UW-ikb&-~{fV>0y1GCi z5*bpROD7ZyaSH@eQDlW61($Tld~OG6wK|>76T&GunHs687sHJj^wcPr8dT5^VQuZM zP&~>kN`$3M@n9Y_XPvywU3~n^&3)T8&tu0tx3OZ_4)_yLD@5QbS^+^Is*74#xc$k2 z5JY!3sAg;)%D4o$VSLwYYDHDhs?Y>9US5=hn(Ei{3iJx_(Yrbm9rfgD#h_Y0HrWZy ztqo6%r&{b0mn@++m0~in16Yz_K>4(3$`3U)3Cou+ry<mJ_}GfU%9S%CCQh1oOtK#P zv}|=m;O;SBp5GQE>VvG+XO-?{y$1|AQQW<(n6H5nZX?|QkJKlPElKrZ@Oc7fEDg87 zs$8$5gpEP3Q`IqsR%EQsE($g2LQSfXVS?8WaR?U~^p%thqfJH#fxx!`X~BiK@l8<F zw1WMgpWNGZL3q$N`N~i4DwmWwC@2blmwFTkpB#>gQ+~J_e^t2`7j;;<UOtAtPMbHP z&FHdmWgJeX;@Yh0JYSMxNpwMMg*Z9#G9*|)+}wuUi+u)ob=Y-xr^MaY-N(}dlG}~C z${e!<J{>XIkt%69GC5Y+r_`AiDjSqvYlf(pJhXEA_LY)V*{uBf2z9XU+3<IxT6=c$ z&+ncE-mv%LZouQkV+^n)WLRY2d|*zJHL_F;kl`osH_2gJK<3G^DqH{|baWnspQ`|B z)P|yYaKjQ_2+(E+%&0Ym<AQKo(b03RSD#G=Ov0_}u1XC3kxf>Lw<<$z04YPZDvQ;9 z<nSB-JX($&2w22&+@RXv2teXN%F<#GEVt1LfFe~v02I||*Kz;NOXUerntf_Ga^Q-T z<;%sFF>NSS6t<#f{hyP*bVC^ouYr<S(9chxA0ugDNp%I$Ae;qT5O;X=0cL{0@D`mU zBAir?RoB@I5M7-CHyk8ACnLm&qC)>dGr+)KXetq)i9cm44^J!KDDzRQ7PgrN^t{j@ zVp^92XHS2eUs?Y&{dH~D5c&#Dje{I|v$BVB=}2$`<<9MdtIBUdUcY&K&gmU^k{y7j zdK^#n+*}<rqCgxd2@LS{@zQy?I|wSq06i58IitIzbNa$=>2&&dofd%V5{-Hd{9Lf5 zF&;;%7{R%%PhmwXSl)^i)U;v+PzEa-pUWj;wFW8O>AE2F&+c<en=a%i<S6BEC4){D z11@J$-x3ICUIxlIT##ofUEAC^9@el;Z<{O`lkrK^$J-vuABX1!VPEFqd3pkGOXmqm zNCiiTNAAwKz@762gM(L!ahaQopb7ha1X%p|Es%1>KkgM+oYhV93f6^6P>WdnUmYJ# zK;pa=%8zH@&%#&_9Mq%ZkQEe!X$`9W>Z{+bUXX|Nn@}l42U%@<A-w?@14$E0vYWFL zk6&mg@c^v;e%^XdN;CqeB2G*H+zoG??oX-(B=HoJ>owFS)~U%(z^v1fNz}J1Yq?5! zlP+FdbD&VU`}UF=J4a(v#?hrNR%?I~Tyw~8+cp=vUa7SE!<?rk0X}z<U}@y!D1tPg zQfypqXK(x72zeY=AQGU*ow#dti9k=hO?0a?!kHV~1Q`v=SnhVs#z`Or<pZUkoh~&6 zm@9}RTM~S{-CUta1XeH5&)3D-LE`{9%uN9>6v4JI#;KC2MxGu*#G9)$6c3xIMrZT( zRN_Q|FsD?NR1&54Wo7Kg%6K`D(<306K!?e6B=hG4v|LQ2&rXPOv}Ve;Hku5wKKnv! zR7b1a2>X+Fd`Pq<62WR7c0$mJQ5T>k4Q?TaiyI_}t>6njD9O_6>~vzJb&SH<hH|B5 zlpR(mS88_3c7Q@yJK0Vv&w_-rwEB-aP^!(a)<7~4s_;pq0gyL5#{0j=T#R-lgf27z zc92~~c_vB&l*P&gh?3V3p5j&4FDX~{?cV+V2OsR&%RW~QDn031YVk(N^g5-xa+uwu z{>t6kzIX6Ogx?(w2WUg$azqO&5!4HXFA{Eqs6IKjFhM5VK_Z>tpxYD^{BlbCeZ4$E z=@Ne8#e-|4IKpEGDzVx%{c{EX;~&(hT>Ilm9eSROoiJhS6DXzH(_bpeM|H@lX*r{B zKSUlmZak%xz>N;lxPc{%D{xyV2$uc7ho&O9-R;FRk|tC&|5T0rFUXobjwYQ_-VW~& z{$D8DuN>`tX!U&ur~d=q@`1Nt)L^GsS{Ul9784VL>iPS*fu_OkHoNUbo5^myQ4-Z4 z)C5WGt#v2C)TrV3tFx7OlEFvMBlJ+{;s1)zqfe>-$e~k)gqcH@E*L(f?@x7@Ju!Cd zn2}#d)?3F0t&Iz-n%1Uaq9j@09NVe?7(to*9MKaiN=rw84|v>fwe&G;P}ocjU>bSx zJP8DKoy`Pcz+)lLZKgkCAdx1-k~}!K+VtD=+z5{!g=^!HC$a5+ct}WMLP#>Vp5|N% z3tOBwdfM!bkA7D!Jbq94zQ@h_=A}JGPZ;%@QiHgm`PN42)l;~3%r~Sgw@t6a^vgRw zyfCPQHvA$awluGEd34)TJF0F7<y`<fqTmw$%^7zRZ)vEi8A!4;9yElqE9QunI`U|q zsuMu5bpj1m0s?hZHB9UZ53vNP$#oaymlZYZRw%!^Tmxy2fBTuD;)}gar*oMR4u1U+ z^9693;p^iLG0%AHNR=0etnx?&>kRs|1&9KOU#R}MZc%Z;B?VVB1k9YM$~881#qyVD zuUHP{r+lRRp*&L#aLLM*OpU|B1@jlNr(Dg}IQ$CaIQ`1cFbf6E5ox)~vk{h1cc>eR zR|)_L?qTt)g0H@A-B2z%&Kw9r#wXh~i;?#%=_SfMWi1s3F|V;oC*`b?H=21##H)H~ zZjLa(%WCy_<{>`xu+3Qyk+9b>rw=h(8tA<sBDjNqIT3&WgI2&m;|iEt8jzZLJ@Bjw za}6~@oU1eHH98-N@?;%m*StO&9Qa82RaSmQcYYM}o$-!Lwdbi$-Y|ptNW}e_yKtzw zh4{$bYW1nUNrgMr{!|F^;otxVM&Mw)x*t)N2sP>G>47~#@&L-sgVO>R;M`$S1Bs|t z(gO`}muxuDaUh;6SwR3P7{}2m%IvW$cGQiVBUq!c%4|A&O3jhs_wJ9VIkk<y-{9zH zwYn<HX_>3l>R0ny%{^7m4ptVr*y7G1fT;su(vwD(7##we>b___+>zCgq4WNAgAi=N zdoI`@UA!G8y8)(dQrl5C<(nf}_;_VFn0$pYZX64T%vFNvRjt+PRpX_6&dHRfu`6D{ z48=Pg1UzlUCN#4&fr&0TK)+&USRR5{i~$6%f+6i$#~h&AJW#ETLtKd~PZE1_4$)KS zdcl|o@nq78qiT}rGvBM;&knJpN+X|Z-ja3kv%^+p@G>#kiX@1-C$A`0mMSlYufU@u z0;WR77&OV$+y;-5&_AOj$Z7E`3rn3hPw7Cbq$9t7azS%neU3}*G+{2*V9#?9IsliE z2vYMLI{3IQ)WC`rl+^wH6<@QnVx=EFpBEl2BY1Cz!Eb5L6$Wx?jPmRbkIo<%YfOyS znw;r&C1=3`dHGZQ1-w$K&Ku3X5xQYsN1lt~R1NqmI7RmZcOiEI)TjX-WKXC`2sde{ z*LO7PERFhZy@RY_->~yF4d}{XuqP$mYqNxVc<O)WcO*nygnQLPh538;+UB>2`&g=U z6pDlAckmRR1;n~N)pU@FCIeePC=VG;68BM2#t25*K!&%(Z>N|@4C!EL=K~3jpo=CL zIIu-sxB{;LK#&s13)sD0A4FYb{E&=;#8l@c6r>v&5fT#`g9n+AtPcrw@`^Hs+2bt; zd&bAx;(;2C2_YmNH$v72iV8u*<V0H>ls$CuloDPmM%w#_*9!CFa(s1{Y3>(ek3XYA zLCyBGfkChJD9#ROTraiFd#^3q&_AcEkH_$bNo_varL^=jd%0{o(l}~;w`R%wCB)i$ zSXUS1MY#<Cy96$>z+4fs5AbJ_2!Y45`i!~pxV#$X^x<BhJ&eS&RVE!m*F1O&Ybh)o zA|Cv%RfF4FTQXmxwW%nv%Y~D@<~Gz<FQ@xsr*%1XLAlana7NF7fL@tH3Tf?Q<!Xnv zGo&^_)|zcCvy|gX&8j_(6P4t+gw=3ZDYxT<C%}IYNw-)$k!OOL#Jy*{1PA`-i02Gv z55fB&WsSwz)dVGe+*NaP<gOcD3WgcLL$XF6Z^UE?)IWl<-afiI1q;J~HO=Ws;n^u4 zJy!mpuD?$^ohkm<(A&~re0k5$irUHRuF$xLK|j%ioNVRVyE?y}^Me*uaoSStO>q_Q z>5VK5Vu)&B#}#Ripn9l?@X~=!)${?!s3fW0EilT>KCl6IZ@G7CcW>2*aiWJBf>ZSv z7g$tH5+rNYIGdi;#=lZ<?8?>S9j7*eqYyGz8Kva)8ffVm6x5@|fYRx0b7;szo)&15 z-I7iZvi|XY&^B5-|LufE^s|J<``>sDv+z{x0GR6&*jPHabBHu?55g9>FF@Q|tb>)u zPB?Y}tFI6DgMI4z*4IMxB5LAIy%CR+Y)JJ%enW3WNS}vz5G@pV+QSIyW|{YtyVUX8 zrN=d6nZu;YlF98lq<_7#V^3#+mUq)r^LG)CXbM%H-dHUUm=hkkGqII0b$prR-{U0? zFDkUb?k>ov29QKcoC~1!Lx>)H3V;zL=FwSixI3J$5x%Dgam%u+oT1Yq`~;cnZA)x| z&p3P86Eb=|5?>s@9p=6D)|vgG?PL6Wql2<rpFcmZ=J2*4w&wHEyFPJt`bLy<T95v` zrWhU{q9RILF&H#i54I_&QbrIqG=xdA4-y9+JgNtofS>o^0)Q(?m33^vFrM*M0rg{Q z<%mfa47hZ*y@u<@y<{~(paz_5xdU4fOx@0Rymq{3P9wdd{Cq!ecTQ5)+?)aZ8&2)~ z=`|WsJTSdSU|^4y1A6mqq)j@uo%QU_x!UOP&x1@;hi5ml(9oaezuhR7o@<l@5}?EY zUG^JjwjTE-;gvz1!sI}Wk*C%TFG4{i2vDg6Bx?`I_@r~661q$usyBH_UL2!!d=G&I zG{QGgQ#Gm+7dsDbTKtm2O^4>zoS9gV->j(q#F{g3X(xc&m$mJ51EtxjcKu*tKXXLQ zF4dg|eo-IAh5;@|Xj%9t+}-D(!REjgtLY1X1P7YO$ZWw{p1rce!g&RfKM8XmoLh5* zRw<Wh2zGKc!kVuJZIhZ^!dF@CHKi^60dr_U&<!oo?rs`bGJFn|nA8{?CSlB$DB&>= zKVB}P4-Lk$CAGwdCvx~caTGw28|e=xb~H#2ar2G|Xxb99%Y5dD{a-jZUX$fcU4<n< zRw{jC$NOH)?ayOj{+NUyjDzW&5zz4S)q80@ToKTK0JaA-Y<s|Ac^+c&hW%#?F=^wI zRZ~l_#WMtZ8dqze2U>3I#k?jTq1u-em(&dtfctq;g|&M0kFc-mAzE4Hvu&Fbb$O~9 z;uA274K`M(;$F@6aM5YQyh;ZuzIFEKl6}7o^dNYJKbcDzzPtQ6+@8$?kKh-%EREwG zx%eY-jbftBp&>>?AYY>!kD&1qBmCweY$$A}MgqklIHC{r4b>y{%WJA2u2pqt`}`}7 zdHoB`fdK2#%`OQm`&KLoi(4~r&7OHRUrx;J(7Y&sjjVYzGB>wrK|PKMVUBe{PM7XI zx|LqJsWex~@W{C0<VLyxH$}Fcj_w`Zpk_BeW~=SE5xFj^$0-Ix36c0Bv#69~V|n*~ zXOw?i1jl0R+~st$YtpLHb-TeS6Y>k1bgw_M=Aw;imv`!Z>ax;61?gO6QEXJrK9x~y zdCOG5Qy1f~SCc^A*xh(Nt*a~1sToKF-U(NIHjz?So7RH5|MZZ$D~}#LQXbKeis3{0 z^&dL4f`vb(iOR{J^}i^e)A(PO?AZCLe&McN3pt%2uc8!-uVHQ<WHg#vn)<*?5lQ_Z z7!MwlNeIem5$6F3^X=tA5PXE(sj8W|IME6jp<xK=+KE_2jHg!3?}vrk3CorMuCpT= z(2Z^lXBHg4diB#T(_`n=9GS<ql=n;P5fIQLqknJg=ESUa%F$Y)f2dq;(M<W2dv;=T zW#b$Blj4-Hn1&nXt8k|S?iGMr4?_%;2^W^s3xtYxhun5^MevRZfV$4qQFXM?82}@9 z#_&2e$EVHm`BP}y#NNLN>-4L~^Jg{ksp0(5a7x~>D>MX3x_iBPMNrZ<A)V7|>L0&w zSZPvfGbrr^>tkc+jfM#a-sE_uBnvt(ONAE|9h~MEa&P$AU&PB<nhPZsE<WloY~vo2 z=}&QJXC5ION|>Xyi%Mx>qdWM-YwM4;boQQG^RbQ0R(0;Fk(4JwTujYldt4Lo3*jPu z@A3Z@zff_dDmS?3{~5o4aT69E{zCksu87b_*#2?-prYjVg<Yo{Km6?T314;;PDc0_ zHY(`RbK-#`*T0x}!@`cf>}$wOXw=d#V)?Aads=7wJkMKiNp6@G5dOyWS)XJi+HhvB zz0XeJ_p5w(JeJ!D6d8P($o;ulfL}edkt0-zy0L07)`$40W`foMHZ43Slda}T&2}PG zgo3DeEq$<me}XwEI?%6Camv!SSFe`RmES(E`KCpZB!A`ZzF{Ye_?$Xo&y29GPvA|Y z0Pf49R@VW74T2puAoh$055NrAwaz>h1#=4KiK<n2XpPUs1E2QkpPPR|Lc$xRn-7l~ zMMFB|WR@8wPo^Q$lnJxj<z4!Y9)LO>GO}-UB+IrbIlzFNwm1YZXvu%aFjO$0&7a3G zbckWton%`K!>N3MPS($>p!a(scl*6^uqVAQ%+V=<<>mAiA{g$~GlX&OJVp<lEoWjr zAChE=|7-k$2jwdu=(&U_S7p3=T^s{i3<XG9PoCM*2qyKPs?Ff6^M5#&Gb?ZYa$G+C z^Q}sHZ&<l};^UKY*>HMKnB!JGolUP9FN}AyTD=u5d%vbNeOMR2Fkt<2)IIp0;ur4! z6~FMYDOG!tAe^Uu4P`V;xm`xT>%H!+GWva~a*u|VE85;0H+MrQ%Y*izUA5MCT~42N zdDp5{HYqDSwrzB|c*%LA%E$h&8CL_IdfcK3@P~keUS&LS!%5<Ac80HaXowoKfD`$r zL5Sdr4L3eM95LeRGG%D&%2lB)&B1O#&aHFwM&;cy<~e4GyS#ZU^AzT|Kf5(zm5cM& zOw3Nq6UKQUprPdEP+H4F8Q8OY$d*fh$(7rG$jPB3ixFtCf5b8%4?!ys`}R-<b_}jM z?2k}eGLpwIv_?HWOk-TGRZl>b_HWMDh0^ONu-n46ETBW)QRfR+ma#E%Gx&1hmJs+5 z2&s9vGm2OSFYN>~&<?o9>yRnQ)_U_AO-Kjs7bmLuSJj>1_0_yyh{thR%OmT%6%}<` ze<Y=AW+DDEyDH0)A8!7v_n_mIWuI;SDS2i6)gwQvcq=;gt@6)Ct_D-^XHQoi)A;A{ z4_vXw0c>TVycjrs+cxE~ydPto0dsd1W^RcBI+_OGj&PW13w)L0w>{9Iyou0kUYpO{ zqabtvwOYx<W6UrUIkfS5ILsV)=gwK(d-m*})j8$xhOR|LT{j#)p+dPPI{K}C9Lkl+ zKW+Z3tn&Dv-k)uLh=d=9xepyH?ne!eACHgvA-}_1T@Z!iHV0g`4!|G<M0GXl0?9^g zhgwi-GgWPFW4O)ru{-Abt6uK1Fek2^Iic0@_hxrm+O|=<sQ5PQ$y=9NWSJw%v;Ehe zPfv>uuV{^pCsUDze+RU}Yjpm#jtB+I_7D)yQ6m^&r0*z~XsFue2z#CYRe&+K))_h8 zFnGy`rugbTk@)2vy)){H2)vCy-FjR_B3R7`7r_F>?GES&k8%-~2?2*hfR~PE+eiov zdBL|=UmjrC08iW71%LJMTfxJ36oeD2j_v#O*oVgkY)So#hrjSEpYQI6P}Aw4&!{Ql z+e=Puo4x4i<4t17l^)2QgzySMKdNznQ=)N@95lsvSpW+xcBB$77({fU0OdDwC%A!L zkTQQV54JOegqVVZbx<-qrS5{_8z0bxjhEs<JmF9`w!PBSy&B<T)Wb4KO`+GoVF6CD zvEtjy9Uh%H|D(v1Tivs=bDd}()~-v=!p2~_>n`gHN^hJy^YGdSa&ghf0q1UDQbzJ> zzm+n?N3eWiiN(^)-`CRvtZoc&=T=WJ{CH$kgfu@bSkk1iu_SaSs#1V_{^A34Rg5_z z%-btiL<zP{G-<+Z1$)Wi$#z>K*+(ts<8K1kf)=*GmKfK5PoJ{gZKuq8xlw#d;=+0J z+gMAAx3^t1e@T2weC#Xpt4IH|dDBlnZQA_PfM#hen@wLhyWNh`vOOJMUAQPYwOPuN zMN4x&=u=YFcHSa3Zg;J+=L1CnJ@NV;o)0yV97|iH0f|r|J2~?70RmSn4YeP{(TP+* z(1LlvB!!T1@S?Eb0%z*zh%mld$z=+z9~9t^-Qem->&dr7LlHn#|EUIEB50cbv&&#r zH%SE>lplUk_R$Pw-`tw_mn-klPH4``4;z?o#v%Do2J@AOcTM&B3F|s>1HRL`3G12Y z&BNSC9J;Epc1C7G9=)Q<BMmWG44^RZ3he^4+p08qb_KN}P@qK6N*+-<6cO<H`I%Hw zo}oP!0;<0ij<F}$<1R|PxCHbWPcq3ci#7})2}?36EvU!~n+1DT-(+Jn&@7OFvK@Q; zOfB0{w;IkaFVcR_j{iLjxqfqGM0g13IYLIR|AlJK<mBgtx+v19tL@~~(9g*lLfqRs zRE>jjf$r_iWoJT|xTJH3j7;UbAMYwBU_1FQ8aQCon0J4@*Eu&clLq|w3-y$ka%arI zp+jD>{&uhC!-$OfVWESnf-_CwQRC^QqFGV#^Gd3YeR@%*{kwNcPwyCK`EX1AoanfD zrCYwddQ8qA)-Anl`-YYeJ)FFqz1uYGn3v$>#SgLzfy0I3ZDE0ZKfEnE1RtOx)TGY~ zGA_}m2ACHpzhb{#_@{XL<jIpzsXS&ZokQLax}GGGZkEn&JV=b406p3(U7R2v)KV87 zZ{sWm*&&Ol-qdK+vOTr1+_5upbksXy_Y>kc;{_Y=$a<kDsxUbtgP_JSxqjsFEX0k~ zz>BJBpe;jfZxHZ`Q-YsDGa^~5eu}M`XkEGHqmS0CtP<Ih!or??`t&R;sBx#=e*J}Z zQ{MgMiLz-dU4>M4I9;t2D;JUeE@hqNr7O>F8};6~)vw7tyUZCfdf4nv#WR$r%2L{o zI)GRBOB}!B7sRYeuJQ>ARC6eP909oO$#$}5php8@Wto;VZ!h@zA$YwC5)tL~4pid# zBndx=1!8|*QE!Vm${E2%l%R$hqk^OGeM1<c=8nkZ{7ckaA08gYv7iRcUksVIac~lh zFXfDy`tI7<O&h1RT2JLob7!t}aZ_H7AE=$xrc)DkSRd;j+iYzAmqy1oZ<!G5Dwj^3 zKT|mxpC36j)zsG#6BW(tYDF?!C>37ib+zJf5=KW{xPn!WpuKCaaBBu(P=uq^EFpFp z^wOTw3+V{jp(Io1i5wI!u%-BaD2x=|7ecY*X14bwym6J{2f+T8P6@E6<vu7+{%e}0 zU?(gu0el973t^}CkJZc&(((IS;%1;5P}b3&Gc55qL`<P&gQ2AwP*I~sTQm#^N1+u# z9i(FsK^|TsI{f9`wm)MBzP?QxC&v56`8KL&M3pGYM0u=|Jf|fb^S4w~8bihxrH5*@ ztKB%$o9xD0xGhs{GPU_TS&e;>=;*$s)Nkq5CMiu4HBQSN#q@ToW@VS=luTvc{FSa~ z>fh+@J!PAaH)~>(ZuNsI+oUvTsrS%#j7-YTn3<Z=stItuSaK06r7CddU-LdTdyk{B zvL=*Wl3dnv95T{hSjT39W;qVItz(a?fG4pRJj{$AzvJlO=`NM|VAa7)Pp+%uN4lo} zn!$rst$b<7>Q`GQBxGgBC$tuK3|_l-@X(d3h9qWZB_*{%B9YI9AfIqf3c_6OB+?QN zmk@*lJ%#tCP!K4w0!Re8qb-sR&BXs~b$~p%XScJk0=9r=D|>2*vV*n<$wgN07t(|s zca<r0(p@^>k6X7n?e${I**DUsh&v*d0GR~)o7a1_1dSoCTg+vUh@YoJR#W9fn!#VY z@j$#20o71dF7reb@+B&(LC_<v&%UWygwTa4wo!7*aVA$SS-5h*_)10#+4AMpap?`h z6H{a5{;y9RnKz+t51vv39C>U3yN^6vB+0XMz)z>)hYmHQ-rwK1;l+_KNn|nqIYj9| z29j#vFCR??bbq+X2(|6!j<^jfWg=;$Bd_$Rd-LW6KtYnWElRe(mI+yDN~DXLH%&>2 zPdUb9>&&H9+0C-s?s#L-KA9bBk(!c`l{Q!$)+i<{-dtZU8#iiDa*>~JuZ+RtCk&Az zV;h>|l4huDK~6FEc}|hDJeJ6FnYLHVe2|>?qlrxU;huC<R;tzYCo9ELC~WCKURwdk zoE#C&@%Q8Q7fco&Vu!cIi4Ha}FWRR3jYFLtc|%+Mqv{i4_x~CwPzwu%Y33mr@m)>I z6{Lks1%>VU1R@4MPwA6kj@ElCZ6p`O3YNS!AUTo6*<%F^zh_9q1n4_A{6Zoq18hO4 zi!*}HsyB#Lc7iGOXUT)RySt~mr!FKIC0n6*R}29~L>JZRsa}&v{~u@H0oY`<zW<$X zCEZQaG+ne!({uu*bg@YXd+#ow454gLK=u?B*$zNkQ4|$t@hT3Gp|}8XFBC*^feNmB zMW8wTKkxaH4g~J~{kc~tG)>NT#(UoJJkNW)X2@CYVai!{bG7FYxx5<n^NvjU;60`h zg^b`A?}~ZYB)4O`p^AC!8ZLzrY&Yf6@ltG01cyAAeU5z*LU|3G6hI_^qQMSUWP_B0 zcZTzV-+`|Sw?xnw4S&>`B6dbfKI<3Y9{%D^Q+6kJ|9HK9z~F&XmTgZ<PjhILBE)A* zfUe<-IRBbNoKgJ46gv0_JY*vH`OGgka_q$qm$E_fz4F`#>^RHQ<mZ$`{2b+DV}P8* zG|Fs5gZV(p6D7VzqhV~xD~Q6=UfH&7-z)b&u&=gc*x-`VAwx%~bMM}}_wG6Oy!`S# z!zNA~HfKmx6*=R$libo4<#FW&$%(F1_!_s;+=~)!rMYYaUVuCd&IMA2;#LBpmx2)1 zPkhmEGnvhdnS;&2SZ)(Dh3hdHc;7kjsR_4)yAEHbu(zcQc`N?B8EU6=*B_N{#rqF* z_w&QF-~z$<l}yo5z#N)UK{mm)(F@_RDkcEK%}hb+N8pKlb4aIH8w8&dOh5~{+khro z{G7NR@!1pb*-sgtjW6jlk3)5c#t<uS#YY{MKf`DDbN41Qi5nNE3x<-JG*~T@Rv3hr z6ky>@5?K#eQ%#3c)%25vON}A}**5xYGn@;2E`nUW47L%^j4$!I>^bqdN0kE1nu#5$ zza&>nE8I&JX7Y2WGPH{T70+gBKrr)H!>yoQ;E2#CF?3x4+R<dLlmdcOHJ}nYq^kcw zoMoS7H<|o~z_Y`B5)`Bl2}Y8~UKEHzh%dcjkLcRDJ@`RcnJ#BSe2bU}x7}?_R7gSw zc2z4rSNRI|BN~|$!B@e@qLP9@8dapmlDH^h8F?GZyCZr1555ZMAcCMxrCQX*srpE6 zI&8gy&_{kr9&~fhVPndBO+Z;tmbvHM)BNsPol<0E!oHAe)~&4QaNFRrs^P=*14mCE zTKsvRR-=cpZI_LEO)@<Sn-T?=6?~OgOpF~!91tnV3&y#X85YRjtm&0F|EfO$&iy5` z=5KBeJU0#YV<uCOshFe>XtU6-Fz{7~nL#KsD+X#cLg)Mjjz&u1?ee3_#Zv)%b13_h zM_Ab6z^^WUcc;z=4;kt?j-AxjuGNOC=lF(oL<Oo^$2Zo-Zh0iQR_-pRlh4)}y1;*` z>u@jY&-oFL$;zOg3qBb30{8~G{OFU=GH>%FKgx2S1gqtJb`y+T#~u6#%i94D_>CPb zj~~HS#nbhy->%Kn&SNfIQkFEv9U5T;A37e#!cUixZSw|YG5A<OaZn}^{CjK<DxTmS z5O>G8<Bjhsia-zuH>BAsN?%NGX-zRe8Sv2rC?h`^c@X>s<?j4!Q$&~zgyNJGM){vG zDgxQ<aHa|Es?8*r>!_VQMsHj*bq+yYhiok_+&Fo`t^8!0);f<%n^f@f9#4FtQ)kCh zDso=hZGc}}wS4&3@htUO0f2QmXYIa$AKoL+e5DJkd&8Lo2<-UBVfkCy2^33nAxlUj zs+X`YY{uR-n@}ZUC}~isQ>LAPiVTt`6}StL?|@CmZAzCRPAo8HaS<(u6q*D8l~L{m zuHGitwZO&_q8Yh+<Nhzg{dcgY<|Jpa{5#x+o*nGq$%XjkLsYx}e*5s>L*r_dS9!tG z(W6&jdI^K5>n=oX$lKddYf&R)WTh}FFAO5WxRxm(1PCwPmF^<%$RVoUUal7^Y=&L; zRfltMJNi5l_5&}dX7Z`s=O(j^ACC9C$CZ~frBmPG{Nw2Zy7wIgn)R~Ne;wF0^-ys; z{{7m0uf#>4ig5HT=)r>4m%ZJm$B5ftj<KJ5LD_64YC^4%jVhF8xu?hC>_@=#c7{o8 zo8eN-rk1D^nSnvTqym<P&>v>nESt(hz=u&Z068?xUKH#no6RU51<7KMb?ne4lSy5> zbSUgtn46v1zD@hIlq6?DTr^73VWB|*aIspm)}aLS_$O}3<}%zu#P39KZ3+Ns5|1$- z7DT<c{BTjHqiYU+!2jGmxc8t6Vn5e^JYi?Y&JU0K_z%xqSzWZKVp0EoT|TX=?y$u5 z+}LSDl*G}aOfs81%r>ZRap~^+A9$+cfbu@=!t{-=<mcq%^S@7T(`T+qO?#<LuXj7A z?<(oqv77w-!bw`}D1jf5rB0~JEYi+N31G0}c7&fJGY1?8xiEpUKS<t&Oa9D_odCB2 zThHtF<M<JtI4N00LK=q%%pkANL+1+7sK|lQdfW5uijiqGLIGv-^m+V^pU?A;S>TU- zZf~oG_s{*Y|9)pLSH-ZJ;`jUgnz+1V{;JhC&RMO=bNCzk`U0%^G>dxwG_$l!QTwdO zT{dfyH9qJITlcKlvpm_UIop=cxbHJ0(}`2IL+u331<J<;NT_k(D{_K>2gD6Z>`CyI zwSKTBbPZ@~Q}u;hhYKMC1rKVc%XO;CH<5=WysXaOK7ID``LlFZ6{&CiO=>UofY)vT zs{nHau#XkwUOK5HRH5onN&#^P+iZ#eyx<1~-lee+7)e%%P%dy1y@rVL;h00roRhML zWR;x4D&-kg$zT)O`l2x1YG_)~Lt}54hU#=~Wk&CZrj8mbe-Uog`K7Q{(X%G;-a)~d zCp6LGtyc#HtUlcH_svwZ4h`9Ivgg@Nwk}hWJZJs<p1&)<A|B^M)ltHhr9{+$*8}H3 z^=srM;J(rQtb&%*yo8N2B#;k{K&b1KvAqDe>y@z+*@4Uz!>&=q28P1(th?KlWo$jR z?ntvTHpZWfRR+c%qfevzHPJ!9ctT8@h@B+3Ah=_Z|HRVxE2U8FA(njrl4<b$%(!+? zk*7#Q08`UaQ<Cvc!1NLC5x)f?|4EkBz(xU6;bSc!F-;6Be9wVDLD0Y^(*CMhxRB7Z z28C(C0s>qc)TX*M@?g(1<ngcF>Io4L1}~dQ{(b9ODtoWR@1FI`Fv+6UE#C>hMkp*1 z(zp?O0ypMr*pu!8<3m^u!uI%Z8tJ%W_TYUY>6C+O0csfovrlCawopnt;l{<M!5=o5 zTaB<93t%;kT%l&j8YZrn%yoCN-J>6>l&woYWkECeEBpt7)fg3YUh$&<)|}^4?6vF- zz-sU*K5meW#)8UyXh<+Jf7ooOOQV7#A}qu&61*WVAK&K%f>j+Mih!1Uz}meYj>RO{ z9}fAhniD68AawcV>O1bhglke9-|9Z(=4l`bA>i7aawvtpLV$L_AaU_d!CtpW&;bbX zioh772qxDN{|P`9?zAXTb)ydyNpIiBvEz5%Ng#%$OL40ztFsPeag$ihd(#i4%MLGY zzL@vX!?7owga~ocmIOnM^45VWD65JZ2DcAN4U}@gE~I-Mxp%r!1ug`TxJU#@7Tl;n z{RrkyHZ~d-q_G5=o7+GSDrN`eK05IH2da-epH}D!wr9n(cYAj0h&hSpRtH@lop#uz zzX*bLQa6<iPE|f-bq3tYhI#3ank->h1cHUI6)KF913N@h!*QcpG2AN=EXHst2ZZ6; zFkENjei2t6r68LQxCtC?B(N7x1m|uW^YBXmiWLJW);6|7mqCNvV-p%s7+VLGfBdbd zfJXeaW*R<N-amUxX1ZrD_L3}3tpC}x5%DFdRv~kez|2}a0DCy)CNqvpC0+tIyAtO| zg3uW18)ma{)rS`aQgosKaUeXY7O_c*v1u*RsNxakN`yxpN+%vy0x*aU6n2m;rgSmP zwU_6KtcnkT2xx--ia|K78(y)zi2uQB*#H*YZT$dcr@=j~^Y3s|yN)-tzx&ahUK*-@ z0PD;A;4%BLzJY#%j_R4>=coK>4%oMwzx%>|x^F7r*Zc?Tk%(>!?MZ74kZQ?>OD#46 z<Y*jPG-_7-<WhflGROnb9wNjq1Z0pY5fUtIv+{DY+P7`*awP#!i-aYqa*1o_pKb~5 zDym^gSHPhfe3S}YKR4|yaz8s2h}HQ(tWF=Ztk1y0Pgl;_S5&xnb~CV)vJ)^?nN1ua zP*eT7_vqUc#@e@M&%R9|RIIxf*2<)oSgSL@v|8zGA{a+Hl@c$ssQ3$c|8P3Jn9C&O zec|>t!>`ggZMjw;S0iK7Vte$h_Uwiq`8}alKhyL<z3O7f4%MIIeH0TuN1&dfk!u6V z6X80xI001!X*)ucDb+!Q`h~sq=7FP-dIC-h|B1Y#Q)#}v=|X5WAX~P4<UMxe`P8DM z5L?@r_FW%*@WTVHK5e4xnJs$sdQX{FH>Ke`D)%&n*Wy`asRw-U$Mr;UFC!O4OyO{N zwwMlqM)v|yn?*jZGy|0h?IZ^_t~cO83`=rk$oyTw=$p}$(YNB%@XXXh!%NzAx+br$ zWMIsSs=MB5Q}NZpE9re0FZ6}gUFvq<cnRi$F%!$n@Q;iL4la=w_zP^53j-z;X~WL+ z4fLw$y#CmQH@;kyl2AKnXuRX9AicibTFe}=?CEs(T?4NI)?-p4&eeD5GwdXsha(}< z9%ex&USaqpWJ@sZNTF2d*mXo}^40<&XJd2aI&o#ecVkqR1855%vT&MY1EfTxX2a1% zD$=3#)0Yj{Co3<V!nNolTe+&M?;{EpJE-2r<a>5#-=8;o{%Yh~HDzL9AWUf0%}}?Z zMBdTeF42(?VMF|{DyZk;y2h-MQ$9*3peVK|oU)-9G=YHe!%33U>2gNc1iMBI80$~x z!w|Lj2e3*Vq8Fq;x#B+HsH|6_tJDsQSipqIk3DDe?1-zq3d{;)r8C7Y!OyTrNp43o z1hL5A;{1AX!`PoVy8lECvrC7c2Vz*96F2g-sR!Qm-c$q@riFn`{6)2>1AQ2M+)KDh zg=dGdnJQ~gN$~>n?L`f6ec(Q?fzfB+kz$*rK$9ld0pA-5eG*c$!n~(AhyfAu6N}^* zzB>6kIx+#HKXzGfSiEfmM+Pdqdbm1}fAnMOpU8PI6F~Zt*QBOBpWCZ$@xlpO^r-1# z{mM`~?Sx#1SpvsLS431&h?$U)M8ye~i^Iauk_q0W6V89GD_iMwy!yV6S@h%TW&53X zM*l{8pc~$!i}vrv_rOsS=V=N>-jMC{zDItxO>;7cUc7e8-~7zm{Kt!0)mlqEnBf=- z-e<gehY|^YB!t$-1ZS7FJUm|+T}?$oTWlNTi2=nR`ms?^g)D_Pdb7yd-fa({9`I&y zuO7wPE`90t?Mw9zefxljK<~d=J<9fIuizQ4QCDJn_<Jl%J^DMnUPhnc!N3E2ig?W~ zT{S=aUy4dME-WjVKfk1W!A<Sb({ggs(%WfaLuSnyGIZ+Hp|}__TDAi^1>;KPCG0pl z6IrQx<&Vi{g;qa|(oNqbAtsa)TrR+?aMcqq$>3?=KBU|qo1EL$krSI?cP5o|p0=i9 zY;NzYn2bR4eb%U1H}qSRhxebVzN?gK7xDhUL8E?!<N`8!h1i#FKO_*y2_X*&MjFSJ zN=e{YA>?d?BT*U2z_(DgMk&3yy!*2`Nm<o5m$f^P<IL9Hsl07OL96spYeu*;F>kb| zp242d5Y3<-k2I>0zlKkbtpE@Uioy<5T2d5;U2)2fFcUB_U&wdEVElFx3hulPnNdI` zXboCJ;q<=x$HW>C3k@SgiiaRBzM1hZg8dqmz1EZa_pPex+kf(`)cDxs<k<LB-ec6L z9^ETOc59K6(jp-RNJz|4fAwkhiuMD|dY@f>5K;)BfA-2w#u%mFP`s|0E@4cwSCy7N z=S8F`+3b~P_x*^s!~!#Er1~#*MEk|N?`Sgc-k1yVYKXr&zx(09Gukf*BkSu%sPEPn zW35mls4rIEg+uk=<)86#tQ;IdP!4G2z)N;x4X?R!PAXnA^ngbfIeit*6EJAOutefG z;cNqUMrMeRa0<9LIQ8A|B?%maTX3+furLGy$~Wr6rn^FVx%(EHUVdXlSEl~9T8VSG z5>{1}yL<W-;Kz_7#Ckv4xZZT=8$@=)06i2@5z+OSQvqkMuly7LR%Uj&_s`(&g{f!Z z4C-L?0>llBBj3uF*WZr0x}FXsn5mz!G`<z)2S2l1{fm98kM;fx`C<L&-?4ZSc#c%q zvpN*#F&6RRMtv;58{bo;TQKHF^u73s@-fg@L;@26Lt1I$=!s!TzX&+V;5TXbkKRam z<otQhvGeEWvZ!5m2@nYoC3{hm@YTntzJsq7U7Cx}y4rJC<XDtXXzZ9lbrWn}5LNP! z+LEOJtSn+(85Y#Yy5rwOk&=88q*akrZ^VoHc-sX~bQuWFb~)mDBV)=pY$VDytxq6w z4}0+$^sELGm9nHHjtKVw2Wc>-Oz?6HI;Vr-@H3}8gk{K`FAZY1$~*Y;y0+`mz^@fN z5KahuzAD5u3U1PPs_Wr7j2xDid<aWIS#i9#aG&6giaDg*L!-|J*RQ#!r!3~TpgY;m zP5nK<TAC_2-0=0h|El4@5Fbj~4snlQY)uuUWDHbB#f2W6tP&oYbfd688+D^l0EP?V zTFjn?X4KP*Jr~CEpLKqAoaaJqsQUZmkkHy%tMW|UU@N8;GXPAf`UF19gyUnCpczEf zGhj<9v5!!0lPYm5`blO#(p5DLLROcw6LFHgQbA@j<rvH%<`99=wS*F6BU|WWA~%k5 z34pp(G3k0LK;9g9>he8m(bs{VCj!3y4(yma*vySU4}zY*VI#EtJll_BNXDMhEf|wf zl{6txMqwBcBQh(HcEq(xzPWcxHOvCkDtwfzhGc?BB4KA~?^i=tvRb5zeCc?vD2;6F zF_8;WXX7(Nr6RW*yBFIS(KzN9n$onB;jC6-Ta(0S!-r!(H%N?P;Gt3|Rn5ZT4?;MU zA>)bXH+a{U?zoz}tJYJ2z~N1TxW|FOQ(NV3a;GhLbd-yD&<3Fms*v7}h6EOBZBE2$ zh)ILcwgic@wA6%nRY%nmymtu172?5B8b!cb0p_o-?npW(SSQpuGt$GYHb@0H!$bWM zX(vOpLCU908Wk`iNZZ3?2(kb&X$PqeAsLdQ@Lu!s<gtH)fRl59G9A@u=E#rzhh~re zxnaJh&EKGOTsKeCZeEXU$EBn1<M+b2#~+U?H1YcPj@Id&<96<hlg*Roqb~WOEH9fr zV=3x*ts#nvb;YykRHI9!{IM&^Nw9PfvqDIE0qQz1?=T?ZP>ZddniiEJOfQWp*CO<4 zpiXRzI~VH5K0pFJ0CI!s#<luQ^H>rH=->QBL%zgMu3gKV%Vz8NV;3@3o;57wg@@Ql zsO$XB>-drAe^F8i)uen(W=PyF?%eibm@Los=9l{7Z2Sp3;Uo-wFs(Z-ARHP4H%8e^ z26BgCdm@r8_GCh+=Y<IbxxikBQBup{EsDWjAW>_=VURzYFniOAWgF&9=Gf7z9$~%l z@n+WVk(B^fn*Ni>g8s}r{NYD$Xa0x(+wq@o%USCuTd`;XdHbQ&Q~cwKZ|R)K(pbcT zn~}eWMSTI$OAOPM6c87Kp+<)tf-qYd0`L{Y5WwTZxdQDC-IT}&%}8^^<ELUNYhi{n z(~Nu~q8F;;2|{qbfvL?;&dK$1fmMeyNe@t?;@c;eFH2~%y5jAxzB)2=d1eG3H+o8^ zVX-WBXotyT)%Ko*KAmLwgOGqhLk14@(S!T-Sn7Fm!y`FaW@|9pnbQumBUxI)r>XNW z&*4DmpwbS0s}c{$9z@>-WDi+cbYC?@Yaqj9NT3Su$w!ik0QH!_IkC~U^oVqriU28` zg$r<wPlm<FA|S7vlZ4>IfC$^XlyL#hk%xWAl*(a?Zu|AUUUzmzal-Q2sFIPx28>Uc zT6Dv_nG-6tH$HoQ%=WB|JuBb)-j&SrwFh6l;MqKB+<@sfSJqvQi=RJg>QVz|63s`e zJ=Jc=n=Nq%M@0rn*eV)!53&k|BZkT=U5yIr7|1Y56KE@m!Z|?g@YP5M>uN7SR4?Jm zLUHzL-}SvgY3U2$;jSbr;iyauPi&NkDD0woh>vrl_AKY0@e@A<W~BN>EB2`Jq)9{L zxBKfsOQsR$Cb;fSK8PKczetT!*hzDsyV7&Mb7ywiMqwh>tQc`(FWo6QfbCxH4$yH` z#G6oB^*ti|5u{R7JR-hBX(eQQ8&eYAhy2HjM8VT{@y3u-bDcNAgGRK>5L6}u7U$zw z6R;O$Gb;HI?H<B^$;nnD#=^pbnr1tA`t9DE2er&wQP^i#LHW<;_%G*v<G<`$sg{m? zY}U+avlfk=ev|s`<|i^zU$!~&TDf{U2J`RU4?mBxd)nFX9sf=YXnC7w?Z&-(H-=9? zXnXk%niD3Cz?`J0{jiINxCget4knyRfRXdMLVXYC9`bwTIHQ87jg_TzDP{<1kZS?W zFmB@^4CDk%x}bdITmf*-&bG+~l@qH*j+(?EuE5V6JjuVGG`?gk^E>e>oK%_rIAK6( zX~l@W?1;Nt{(#>3`a@6EZYf*lNSfbs^CQn~((~NC+va!OC!VPfU!*{>5$lYY7E6hc z791LK8{nXlL4lWvuN{&jAzlF*&IWV|A*%tc2E0dzrsn|zKyd7^e8l{@%G-SFv<ff> zYHnwnO73pmnq_zCy?e(kYmUjDI&If>K5Y4cC8fh6B3qB0Iq*=&X;~!+&NiXe%x5>> z%OaonL;D(^hFl2eW7HwAeQ|_ogT<2=CR`#ko6piwsup)4Z9A|(@k8igjvTGaN%yli zP3}Dt;$+y!IEVy=<xxQ2BBSDx7j&+?*^;+y%#IiNiNOO4#wI8Mt&%kT&G6VkLk5+- z|0ATya%Ydr%&0quw^yVaVUPR3js=PA3Hg-<sDOMYVXxp<QuYKdMvWJ$9EQMPa}9P# zqZzA=QkNKxP3_ZMhn-I&6?Q(2-9?J*S5sr>7lx7&J8RXSWZ7xHBpW!2wT-zWWJ(}u zhfPSnl&~CZDApFYgONM(T742<H7J4(_DRdk7Kw>*nM3pMe+*R_R#4E^6!2kq$dk2l zic$A5)t^@@v`g3wV0$1BfVRS@ghA36W*o{12=`zH8Obi9LZ%SghKwHu5RB5GfH+u_ za+7k%*LHyS(2y-6vn9&4ZN2=+6a`u>1^i96q(^u`%dqGWJ#I`|)sjT^ur1RS5Mq`i z@)8%UO?g@mR1>zfYR%;L{Q`y!xqK!&kDXN1NjI@?I?<d=<Z}W2cmvsgXh^rgorxKc zQsB9uXcR@d!{lwtBWP{Kl}~gO2Vl5J-859)QL+^0k~X{z@Fwi26yJt#IGz!9rF!`A z+-cLM&)%}({)bo27;_K$BA49LrWKR3yChvWUvt-_SxotI)NQ@hJ+{z+g*}I!S+R8d ztf&a*<QoUQ)@gd%VM)oYg8j1&eYp13%;eig?K&1osRRtL1A2?7YDe5PP@DC~*aHw{ z19?r!RTN%L@Tai61a=1tg{%ujgp^<p^@CsdPvR+RG9aJAYf;lzuWqv9{8xTri`)iz z)efI}zG__hxVjo;{HItw+zE4drCN+L8G@(^{s<vNfR+>LE^tS{KY#!yt~^7LLR9UI zvp~iVDI$_>Z7T9Y=MlA(Ft5Oi&6Mqvcqu;d*07ara7PDx_x)vlV(g^RBN>aSD4sHg z)q{@Rxr2u*-~5b@5pVJO`wqOchSf_3AsbV|?@&0#m?-sjLk9#CRtOFq>uTJ(Vc4QF z12`T8B!Vy6Wn8uv{3CEuP5!Oa4JI@oz^atU5>>(gH};ev;|FAh*Y@GM5vX)YE`IwD zP^T`G44E<J=2bgy(bko0&1{vEbM`B^@BL35(1%TbVQt)s+fy<}&mMHB(~RsPNhz&@ zI$roJ?mWxI+*013_@$vRV~F<Yyoh@ei|egX5c%HeN;dG*0u%4O|A3V>j<e4(Rqx<@ z;CTM`4^&bL`Bm;xccyCgq_N{B&zhu^6z(2pJIPO>d}RBHrFlLVJp9|9c=A?bzq!EC zeiY*nxi|_CY0t?BN8l^N85Wfs%&Iqb#?M$KD{VI&ZYCh)&9Z+e|0$31qfK|&=S=Nz z%JW0x{)#wdd~O(?zZ`d~gM9HAcm;69@u5uUP6~!ICd4bmgEFZoczB;WSx#}l9|)C& zDKkvGVfbzAtK#<K=PS9bSwyz`^5w(dIFqbVk#WfjJKwmNZJ%|+i49Acyt0aW?uD4! zo-e*))4le8_FSw<DNoeCRC^#+11f@aL$F0+B7@1@gI#UdG<X2)Bc~%e%4)$CsU-oS z6-JiKBw{b*{Spw6Nt(qW${vPkk%5Hce=VHww!284e~13U3OsT&|C65}*o=P1VtLlM zL|dSf^*LY7{0D9Aws+K~R{@!9zvyXx;P@&2dIE1FACM!TUvWpRvjyx#0@jE2k6i+L z1R9y4!3d{`3q!2VLaZaq1j1gzXM{(DH)^YCtO+xjd3ni6{D&J@A`9Kp$V>i~pV(&b zk}Fx6Wf$YOye)XiPx9)}T6WvVf|iVNwBU()9?oAH<@B6bzQjnI2}~sgGlu&BJ~AZ5 z5#3`BF(kRzm12*ykt-|a3K2a*K|r7!gs`V6vmg#M?n$qMYhynxoT_7v)~}S?XR(m> zJz=^&<tIG+7iUsfXri&Wa-aJl0jCVA+bKuAe%G8oR*w5?)1UmgINpYRoQR}N@arvI zs`;((SS&PtG3f@>w1#2+Qpw){l#)V0j2>IC3hPeQAp~8LI@DVj#?PcmsY#HnvAT%j zk9PFNt&R~JUo_p7M#yEsu8=KVdMLey^eAE3BYF<*t@h}`B8r9_J2U;!%&bSIo;^0W zSnaTa^JUwPt=>$+(3@8u+qR4;%f%M`lfO1);>0PeD+|1rf(x?A(~#>5z#T_eP$&z> zDFA?qqXW-cg%-J?w-hcSMBk}plG6dgcxZs16vd*T21<xJq!5h4tIZ&G<w7GmJOXYt zqHn`bkzZSSm--s7|LmzJ-{$-IMgAAx&2p;Gm-W}vQZlkX*;Nz#%hMBIK6!kf$Ajba zI_r56h+j|ltq0`ahunyubwEL3ksEW3{FnNN_BP^f=<Y>9$5pZf8yGN<2bpFFA{xrt z@TiPE>q-h2a#oPUCwIYQI1d#57<YBk@JGq*yk$i~TU(Uk40N>%<EL?|&RE+e1tux> z@V1VXn>*bTrd!qL?p<UK_=>4H8J<e+WWUIpGICV*Re*W!R=%{1^xHANBd{+{VqZic zTLYCScs)9%7u^UXlU@Zshs+{oIi!d>tu=(;*cIUxTars$!cOdEVVr#1ATJ*`FovCi zdWm=200Jepjec@jWb9j~XFr{l{q&9Bz7-R7vwkbTQ)v-ZcOW`eF6!TZ3~M`jK)-Iv ztX}sIgSmKZ`sB&eX+sRZzvp33UB7Ju2W;#Az&ooqA3L^r^*fmB%=+I&t}RLG<?aq| zNREqLU_IvBYwBFvE;Ll)4e{*}XLWPXDHCP$))lBI-(fKvhS9IGuUEF5kHrJIoV z63{dR-;yhZco4>NctJi+V()AINcVo*ZGOAISt58u=QXzR2DWT&(aoKfc@9<|3OJ>H zsdnAS*M)|iJ%MXnk&msIICDv00PjsX8&yWakj|wAG1q?ZVVsn^bfQief%{Z0#J4bP z*b+itk?1}w3yciVicB;lz`g-8kI2$C9oHtP(N-_s!0UE`|LoHg14gBp1h~3i$i_c@ zI8>1>o?n%aw;sE?eEge`kN;}7ep-L&>#NAeqc$W-=B|jXVo*wk9$Hi+^##zdeUN!I zp$QySiL^oBEJF1ZX;~aqTzi!CjYX>r^x=g>KYlja;j|<<A@2tS9ni>hl{m?ZL#7%D z|F(IQCIf$$DqlFK+WzWGmsl$Q{F3K1UxGB)&l#zkr`4zvE-hHKY5^hV_y_#L`ycYZ z(R`&hFXwB&zJUATFi>-eJowJZ6E+(Az5rt<U2xLN?d$G^#IKOaHY-v>Jhi1k13Rn& zq`l3WVy?hKY2ayih0DRmKrI{(gq9Xgr!&Kuo@fQiI@=nK<~snKV7z#gMj><GL-}xl z4WMh}b_x17h*Vaqt1n%~bA5Kn)1%r`i!y?ib7|o%w>03d`9yXv!L#@Q&X2vz>wsCS z<~PLE$_IJU9TUc_#t?ImpL`O}<fPRAgIUO2+X>z1M+gh#o_uEk<y;ji0m#7)5<M@- zw?=6Lo;4|z8NRjm5TI#-H)Cmd9!<}H`a2TBe|4PK23~tIWh|GiYqPK&0m}AZ|L>#y zzt1n=r$7Fpf&aB`dVn8KY_j`l{}=GB;`|EiA;};G!8J9j3h)cE3SbXzDS-TGeB#7{ z3x{h8z&ki)hPu81aKmgH8vi28N>lI9Ey$X`$iMV#6QH+hOtXOfQRW;)uBwJiI#*?i z|76LH+;sxxFATd9Gl)0@zJ&y_BN_!IyecKIb&O;l-SOB-B3~_1AlM72WyDyc6O*u8 z!*OXEJ3&;4ypa1wxV_t3FB*Nx18&IYmpw)7(4~c|Zdue&JmPO&c=v;P`FY-Q^`!Aj zgso2J_i5+F_@d|*r-fCKTQ9_v0OU@)l1w$u8o@n8?UbrY;noN$qIsJkSR6`rUYJ*I z7RnvC*fDk5NBlzFO8#fW%>J|eW7exbRX<gCzu$=Na(liC^6nG(eRB6A=3tTR_E;?C zWiBr|$&XG}e#N*Da^fr%Y5S!v(lGbnl(-gAks(kG$TZ1*O6N}P+ku#au-RYoQwp(; z=rDoWx?dStVtEK`9TmQTP!p?)x9cKx>DVDZFM^Dk)s-xuwIqj|o6oLD1ZLAJ6Q(BH z+U(M7P<HcfRr&W5?L1#>Vr4I9bx)6Qgl9O*bEn?Y^Yj)VNNQ@feAVriX*p%dz!-&R zbkE$w25<3v)ZueFfi?0_J|UpC)`n7CdXF5F_N6^`^n89ZTO|(SLbiJT=ve!gnklCT z|IqWSt+qA*y+P*-pyzFvmt6S#OX0g@(7Xg9L3U-IGzs<{%qKKT!##DKPHBw9P!nO8 zqDfO2yn+mt(UiJr!iAJaX*5tN1bGj{q~=}Ia^=c7GjCZnd?nh13}c~>{>>8RO`5li zAG!D?KZw<dT{CUr#wClNRfbL-Gi-Wx`fg?&zv%O~$3L2x@${m@-+g*aA2xeV`At*4 zr1eIzTBrUj4)PeNqYrdkAlpPpS;#KnoRFL%>DJTvpd1^vAy(EQ#Yfrz!4QVt&IBHs zmQO6MC50Jg28){QkRPnk<vuvKz(c{DRO_DIv>r9!Xp)KdjFROcgJ=<qGMId)?0L#9 zEDO4^h&@R<@(*H9CK0wal!|bgB1J-AR3N{R*96CoYzvWR%0yO+42yA3iK9##Fx(Kq zH0*hHbJxtf%UF|s2rHRo#H};3OI%qA_VCvI^S@(v-Rn6pg#Y$r^S%hH7mUKTF=^N~ zZ+i|1(dK(;+tA#$!MG1%ZiPLxgyMv&f(QnOojS7MZ-Q4zDF-9Ohb_bdM@o^lWQ&uc zRG2Mrbs>u)4te7Q%M(@Y+{K<Lw^yjzz3O~SCT3Jzk|lh@*8xAXBDy7gQ;Nt+%wsD2 z@5vZX3&LZ2b(j<xfwMxc6{Zl&ErUfzF(Zs2MnxDdqz5Tsonz$i4ds&*A*0hM%48^l zOkU5&xSx73s%xkmkQY2)KuiQ5RV~|lePq`UkC4MO$y%4P;XXw^CClA=<SP}nUAuyL zem~i2p><Z!NAC%}6O=<y2M1Sdp*u9pf;nTj`cTEEgsM@oNCdb*(niDo2=Mb)&;n7f zK=~0_2#vDX0%#TEcHl+Yl<U2w)E$|Y=154(N^8?HJ;jxf>PV%FKPfQ~l{4rL1L>C| zISBGETA0|3$k-vU@RS<DoB%NF^JQd9jR_6no?s)G#YB6%rba;`sf0hqe^anJ_uRK@ z*L@~z`FnTmy0>p!Z<g}!zgbrQxQ8B!>(4*<```St-f<79t6qG3$20Q3JpG@2`0?Fh z%?kK-y%1|A^xUXINstCJj4p`=88>Qg<3<%}7_Uf`)tZYMIAJYdQ5D~PYP4eUU8wJb z@Lw(`ihdh#U3?d+$MYH+edTqEy$r0b22pJISin)nwSbif3HJA+=0dnt6XLNzAaEDr z;w9#E1^I^Jj>qw{<pPn6%>%kLp{o(P8K&L{B8+mWcV{cBs*85Gq0afGFz3tGcX_Ok z{3)@&;UtX@wVe6$0&VOI>!$)N{Jw9GW2y{WW{$xa<7j`ALXtrSQ9xaWW-sj_oI6}n zWE*IN+F+wVjh;2|`7m3?El-0Hlhn-dgJtW6bv=mj)YQmj)oiP=$~AwdH=i!LQppQ3 zPM;VTf5=Sz1QI29BE+^L-w1an>J<varyJH0T6qfjMz~1f!Zb>!CrSypKe3`#KfqDx zlDx{23ci5hr<!AG_J;G{FSaHl3uhDqu3`JVBPN@BnPZhfxubqpO@?bYPl6M#(^^x{ zE@B%aV=Dy*8Bs6LG$7SUC=u%#Lm?D31c0W!&XWk*DQkmE!)Vw=q>n&<sJmF1m2Nqj zTb~0(E;KH?1`k>}R8!+~p}N=b<pHOZb;6Glk-&50LSe{Idzk4_y`GdxHr6x|V+|3J zODa{nQj&>n3#@_!kz_hBsJ-B%Adt~DNw4rXDd<3Apc5Ea0pdz?xhRftrMgm$SSBVK zp-YGqoa6`q@vZ5QVGfMWEO-*^iN?_r{r|Vd@z>O-Zfq3Md#LU^@f@RSv|XO>z0ZNE zzf|vA0l2X~?@+EYBm!U$QDPN7YzVG|SYm3$L<fORA`?b|a#WCY0!>J*0FfALg!2YZ zkt!#+qNAchLm>tb8x<QG8EUs$jA!w?%Cq<kn1b=kO4ISPq^pkFH~GGSQr!NF`W}2E z5%+?{3KX~)9~=lcM2L5(D-d!(z=VNdMt#0Su3c21jM_P{LlpI*21UBJaDND(fS|ES zzYnU{`B1wiXJ#o2eS#$seuaPa1plq{cwF*^l85()$XsC_Ib{FN@|Edv$JHNhSiq<7 zgIQ2;oH}m;OL#S-?a7z4)7r~lwas{y;sk5`Po@>x>)1VM5-LS8G@-f#Dv*MhG1`X0 zQ~@jtdeo_9V%&yj0sp+AhylMAJQAx{v6uFDnB?$|KS5G_T~=7L-a1xnj5Rhk9#t+v zWl^7<i~OOaO>~cIyL?@CK;=P@*b~n=mpbf32)x!H7R+xk{39-3(Q`+U3hOUudBO&! zz*oiTg@x8tP`9=8v=F2puty595U7JeW`!!gkS(B=xO9&FOgQKikfo*~Wtfqgk(}go zz?#M)XKwSSq`BDg7N=r(0bqS1lBbF`+OQajeRMxa)LCx6P0OpU<^>0D&wF4>_6TQk zc#H6i9w|3&+00@uvx^?<qIsWuGJhd!g@-llr0nFc-?TW|e!`?>75(1+^(~*B;kh#x zv(M&Vexf!GZOO1!rSQRr>o%N)bmIP7aq|e}1<~La*&p0M;{K<6im!wi*8({_XN&Z> z^e_ul-hc=Z9dQH_+({+*Fe%@M??;9UDP246cH?fM8ihRbJ0|nrfBg;R2^M~8%*fM< zy65YetE_7NU3s&rs&0Z{u)_I|r))p)uUYaBYp|v(T88F!(qCKRwBE5$%j)t?&BBmd zAKkvnwy=ioDFsf7q`o5R7XNckL{T>rX9b7*T0IdPB!~boF(T+}28OuEwWN@?9-@Ay zy!Z3pZy337>Gz*{%IIEj{@AZ~kAXiv+pp)~A=}jsTQ~Qe8y~r<^xhhS*ymaOefxIp zI_+mU*&Xw75>TvEe#6)W#u5u48y%gHu5XB|@oyAPi)xU8u_RO=$#(h>mbv+#RV&ZG z7|7qHM1wLFXs4Cco;kFsX`Qq9E2>A#Pc+r;AQ7Xg;B26tj?GN5vG@Jaqz>1(Lfw4v zIg$jG1UuDusH&Lk2bw%ul2XM$Tsm}RB49@56G5_b!}#v1e6O;nrsn=|{+nk7|20Z( zV=ivT#+*1^b$Aa1(-E1>_M9MfJ2{#Cy#3D-c_!WEI2k6Z+DB?nnI^=?(NUpDxo0Bg zRrB+*pwfu{D}_iX5iVSn$_OI}=o3Zp_M!mzOJtoXj?Qk2pahwZWTCi64kvWfp+IY7 zC%s?*yN_|2jb~|+OGdXFo5PShm)9>|`aYj}_xDR83*&5IF<B`Cv&Y}wapR4P<+vqt zHg>rEhPDG!vtq--;|uLezP*P}eQ(7Q&*|E@xA~OX2)6WfS4+)wBr<mNsNdeDhkp0B zQKMrckC?QUuGjhUh+1~f+r*)QUHL`%+=nN*o^H`UqF)qOVP}ToOrlTtweTdyCdJ8f zG%74nS>-ChZ&>f{MSXjWAkzHbd*1)Oq<`6H?)l(legQeKn2Mo;1`ZrjBj4JkeNInz zp1$e19b0<McP1>Y*!s*<59#fC_ix|5U=N;W81B{%*ke&tZzuLU$f?xg2O$u8LV6=! zDx~-#-Y7(64PBS)Ol&G&v}+tThrE5Q&ML{{0ugPk&L8CP0H{h0BMy0jJF%t4h=jr$ z%rnh6UN|R=>;a_U`oKSgRZ9%Q6@>WKhWM5=9qrmxquUUXg{A1$LeVV|mB1V&-tskf z3jD2dxp>w1hdSRnzU{!2thkWyxT46lm+#^;ewn$-^GXe<#0?w3thRQ(!`DO_8^B-} z(^w%8qtf}0BouwPH6$2DmmqHxGr}VQ1|Fx;YpuM#mCfaFh8Y2XgNh5zlzc3=Hwqvh zO1`It*S&GBwVE)#Q;qT?tP%mQ<uyO!zWeA0w&QfYIF6V*e1I`u`n?!~=-q&h4MFfT zBu2d{4eqx@BN2f~6+t3Hijck#l^K@};tZh_7NP5(H|8KtvEo!3QWuE!l-W9qVAE+C zKbo#ze*HiC49|yTD<^?+^+UrdzQ{Za<@t;cqcx=-3p6&`SM9{u{>R>#jSTE&y)(TW z^M*lUZH?VFOzymdjbFUjh>8v^<~2(^hm55=bH+DMwQ-+)W{k==Cfe)&6~jzrSFzvG z$Maek=3#JbzsJlRTEg$eCmT=hn-h5rS#kPI;A>S}C-6Iw-Mmf@HL+C?GGJjvQ%D$Z z;;`YS@HtLYp;5Pg9r!XOk9MOKdk4PZPS1_v@z&qTP<f#{wKsIds=@P4M&`UwDtDJ8 zIb}&pg!3bH>e#xKYSL}!H!K7K07uaZ{ZYvX_I4_w$k~pfn8{>RHGEJ`Npg4Tkl(gV zMjGCh3i*ciWOJnhZ$h0sq6VNU<-M9K_&Y?!%ts?uR<!7rvj4*m_N8=-ryDS?IBEa; z9~^KM#32%oDjO9R7Ze;HHhM(eg&|`?;zEL3gj5dKBYAXCh)*6NIPf!C>rVrNd}!9- zKo)_9ly&zWR29z@MR|1nhDVU+-l8b`t8u5c<p;EQtVaY80;0Y{(J}0u1i=(s*f=q; zdcDzVN&~PQCk9jEi$LvmOi#2u8b52JDAa<h6=BacV$fW5(ZdKn>+*ziv1%2Yfd39w zs~zed@qEn+8urU<S!f`<i_gu%nF+(#5+w8$i)$eavCN<*AHiS;k@FznurMyDoK=AN zComS`L}Tp}q<EZbmjHE`8j}iCwh<>rw4pb$4)V0cqh`8#B`=Y?z{c#TarI05m3sg# zS3A_k-8N+~6v46^kI)@v(>ovDCX9|a*Cx_<k0NXnn#2SJ0&#=8j;u~&Ucop(4S5A8 z91#c14J<PqWZ{AM65Za@OlfPVjV7@ak@Bdy7;2nl&upcv?onfoj9bI#!!ej2Fb%{w zVyJ>{gt!052YGeoo23zOu0&2qsLfwx@n~#tl}v>-Phj;fxy0%<3{5Uq?jV2YRMQ3Y z4G?P}`qpUoVO&&iLG>183zdN`ghD444iN~IZ7F9U>!{npJtsC8&c2s$OKzeS_#Bj6 zBEs<=VJPBSNbeM9UtDU!wG~cnL%_|#ptC-s=IDuwm%jAOL89YmS;>fUrDQ#uxhrnN z8#{KsLw5-O7yo2XVKEY!q%bR){4vH5tYRXL^dNVCS5g$n9B89N>v)Y!ff!~(roicp zj+P{6vNJh4G1>uvGURfM=-QhpfG^SDerxb~jfHL)wurN1e4|E|@GV2fqwZBP{>&QK zw}-u>CpWY~-Ggs4o<weABnXT+Vy}3f|0O?w$M_%f15Kacn&bA)_m$)Iyx(+`<Tn~U z%o0hd1q~tLv71;Na`rgTxR#L^s6rY83xoXutvMM{DTy>;V~|BgabhUEN7Tg`)pDb4 zl+r_S*Fd`=p+snqW{Ck&KJrF)$@%%PyNpj5t1J8*3zPjOPHH(I-0_Rj^~<Ff5Jq46 zV_!W6<X3TY^(?Jco4hJIY%}CQ2J?4*jr)zidvb@~7Xc;l^7T!?2}Pkgh8zK&09Z__ z?o(t9+^7zv40u3r`pYOd0k=U!Kg4;U)GROw@X$zWA{?jBTS?5O8jp9JNhyYYm$)N* zz_{Vm#Oa<mrhoXG=udN;Ux>OBO`Vjnz9uz>Ddi*I{N3BB=JNYzkw*$^(ya!mSZw?g z*dx^E44K<7@Op6$C8+ixP$6ADECcRql|+*anpuMrfK+!okwo?dCnC_#YiQ`LhzvO5 zeR<QmT_5pRZ&@*J^5u`&N#Xt;A2IO2p220canJBowc%%4-ZysJVZ%$1kG31aVjyf< z|2s5DsNYg6+8b%9GE};tk3w?fEg(Y@ip^ql69WPPgT<_up}-C7KA{g_J_KsBnJ7uC zmeB7J$|MH#!{!B38-xoZU6JbpRvYIM)fMtYq1^DuA++my{8dAq#7^oBr6rvz;ud>8 zT6^pm?ubL``jfrUx63o!tKm>OM1E??q>L2L^W=*tudeA9S5r^E&tT*!G=b|ZaSx-u zePF|=3D_~1Z$_#r8aA*FHi8MSt|WL4(@ix00@`crdmnxfR0dS#nl$rEWQoSUzg9Cp z2-6C<h}`=c4gIE9p-AZDr({#*)f)S)r=u`sDfWG596!=pYyn%@!wrfpsxg`z8-s%? z3p|Ahx|8LE2@!=X3Q4GvMZN=)NO6ee<C5cCp!YzzJIRSCKmbET1VC8{UmXB(t<PjO zSR1+R$G^5#<I75_m3OMEkA89K(ifgNC?Os#8!@6xDft;H+wXmQ@Q4TuYTkHg#~Z@d zZ{ff8@7k#+-AC}lO`S0I|2rlGcJhD0gfu$nNU``H!0^%=o&vsd6L0;UFE8RL?lL@f zwZ}X3C_Z=SqmRh%xc_zWB)|NEj)lMao`r!8YxJrUYF*SzTn@%wf?N+V@BseRVNBt; zW8SgBAmUDq79lh0GoqpspumEF5*P-kHB69q+f%n6-yt#1LnAOGbKSmu@JUXdyh;~4 z<$>xVByE1Je&y<&?3gqh_=b*{|7fbk08<8hgGonp9f^1ra6jxH9F!>(H5&KQU@v(M zwHTL|;d&(sq|xw{0goDwy2b&7K@*lN5up%|CvbyrK0RLdl3XYFCrnxb{UGW^o<RDB zxNsEoMbarQq%QGDeh$UXrBbJGC=&>;kmMBokc_s3<lZNN_vZynHhy6;^WVRm@m%|k zyQhD_|75O-<&{%d@|2OIs<d5omec<p*uVe4|9qqTT4!0bVE*F9KWR)$aj#Tjj{Y$w zBPP7gm@pcj3}NF?8V09V{`vN}`*ZTPk9+HPmejZB;1cE<FtB$&wS#B=iC?<o*DojJ z+dT8<-gx6&`t#;l^e3Ji=LUUo)R*)qabF-#AaPe6wI9lcV{;**$Kl5o1D47pn~5_d z_L?wUaN_KCd%Qgk$#5%xGoe6GF+%k>o{xro=c_u%QT6pW-ItH!bk~qn%F)u2l2Y~D z^ZfYdwa<P5vpV(pQ4nj6;!lt6({l`s5xQdaznHRsv&)voxJPBDyKsYNBw<|WIjT70 zfbmI;kHDp@(H_HH+=#pbJ{%?sxwtZ1AAUm`nqcV2f(tJrE3;M0H01NWAUtY?;cb!X zv#KKD?FHdA<o3NKVv+erH*!;!0OdV-I9OpnajR@T{7fS#?+jlbx}MVfaIR4#-W0{A zvarWlXsJRFy>DL9_iAtc+XvB`3u1mD-7ZF@j*kbkXxzdZFbD9fbn4BUDUEfHZi&P_ z7}l}^;;IZ_ik9wbfx>uNvTWA%LSnW6zX3lB3ZJG*m<jZ0fk-fUS`3pQZc<%05A}y= zmd#w8*$OQ!oX#*&kx2}tNyyF<LQ=kdu_il~72p)I;vj%wH%f*JL&+3^e8?MZ%<sE~ z7P6D8O!9@lWo^s^-<5QV^Y9JuX4YXAlH_?GFwNUm_SVVT^V;-VjfS(@#}|w&hJon< zCQfkgt*C~>ssP$%MnMlt+yHVV*<%?vC<4UdU?Z7F=~je3_&<7)k@v-bY$pT~77za; zG!jE5HD@L}z*@3bW^%oJc-emj46oq2oX;Xx>$M^3AD4qeYHKab#M`sC_(e-C0G|)w ztdMs2(>T8&FdXQ%7DQZE8VhvW0k|bE&?iF-xa}a{Xu^y>D~6(!7z0LQjEZHap!2ih z-(`Q^6n=Op8;l_h8p@CG>V57QJ(hLhuhD<C!OG&gmBF>_r@c4ch;dke*>b?Pkscyq znnVZOr~n3kImSqdfjtg;OL7+hQWf&j6dxjzE`u;4mFdmG4vHL1qZp!?F`pPB*Z}{S zHRP&&DJfcVnnZbO4Lb#L@D=kob0nYS+wi!iFsD@X@zg5uSI%o~2s2;wZTGsbG0FHP z!*i8P7R+-T5I{ZM-O#2vK=cX?)sT8`d@>RCvO&PJAhN_`N;1SA$;9K)oIqT~#fk<u z*bHJ%Lphmtf_EQa4f2~kk5~#k&hoFli!jZ*Dp{O*s~Q`3i?J?0$pgiDG_21GBRz%q z&9lo`qYik6NmwK3>k>NH7ABjObTmOrNv3t8yd}vZ!X3v3CTCYhv}!hsY-%7i2NfGR z%<8fsHD^o2B`(zGQK=G}8TB`p(VPd|w1$5}wMUewtq%FUB{P=aM6Ey3YaD7Y&u9y4 zdEK9N>(HBa_OfA1Jl`<u5ssWRn>}IW8d`xhe;k+D>-Jr{?7XA-i=T{tTRDNRg=%n5 zc8ge-9`FylVqK`xh)yp6#+zg-I2?MiE75^kOaxdRx_Br_Hvxk#RjEXdL@8$i{1dOw z=sOln%1BR3CC%NK=+F=ZcquG}5Cc?=!{XTN$$9w-dFmzwbk6)-dTy#`c_$!0+v=3J zk1ye47wX!Z2OoG=eQ4K%FCJ9&g?vou*g!ntl1=&|4_jZk@VVN!F!{(kVJu8M-Z|T` zHxx@;?Q;t&U!^C1^%q1#;`vbP@%tQW)(*WyfcguD2Lna<0I5BYM|ruKtuxXw+<59* z3&{Y=(qng{hH7Xy2Ly-?C@@3*W*r@Ek*e?5p<R9sET>pSEA_rIf<a0RU32wdQi;{) zTW4sMd)G8opbM1IyzZZ?>09jxJHG`-Pfrtz>%ByZ*`cehYtz;5KD!OantPWTXAn6+ z^H!{N4rXJxdq^Pqhy_p-3<-FZwasdY#iMEkpo3`88A=^|K|g@jD)1s|h2)!zkRmYE zfN_DV&@LbK$ZRwyvpS=pJlZfBsL@?}mBmb8H{{Z85XY5a-IFO)mXB<^%9`7}JHi^l zDR|ZvU=MiX=5!Wv_4OA!#KbbHTEB&GdI9YQS<2yVHQBUKqP{ZlI@;%DBXMfrKy{p2 zB!AVekiJ(;W~B=8Dt^KQu|^mn!km=D-4HGk3hjt&8){*+AxP>zBejJO4ceBq4ImO9 z6>F(+DH325#5O^L(j0*40#*shNO{Y<&RlDQBG`plQzuRBIVU0V)4u2KJj*QermtGh zfBB(($GoAP20yTqz4Cb1$&1$BcH28X<uIkZs$}p)Ek0^H(}#~bynpUvt<s-dbmZIY zR-JlBKbdr3-Nw7744*#pta7(cVN90Nd4J`A<`MHT&Ru!k`S`~)z~z@^6D+mK1o!d( zJR`YASntKh>dyZ<BQIB!mXB&v9u@U&;nBrk)sGrJZI0*TtfJ0+atE(`ls$c4y9sk{ zzHxH3Z$9K{eY@rrvKY%<fA{Ej-#tSYyBza|Zhc%#$NlMh7q47Z+`g#zSw;0t2kH+! zfvubg42;3IhUeS@e0Me6g6c1BD8Md&S#9hoAC6ENS$8k{I?^5zZ1j}3h6P82L;wW? zpbp?KK#`E5BmN)_QV7^YL;!gRR}`5TL$;nDhky$t>j_2TnY{DGK-rTm`|p1AvF8G0 z`IsEI$Iz;04>7mUsV5kT=jWea)3n!qR;_0bXxjdtVCxjY>Ffi4(ilIyEBqTu0a|Ip zK(Ex;yULiGcUp$&HioMB22Xm9MmCGso_y>?cuWt<ev?L5PV|%c7}<Pf<7HNU+f+@P zdYfm|%ITUmeI<qp-!}z*V1;%FUKg}mfC3>mkFw0<)DUA2JzL-d2zZf5EIYgc6hdwS zd&h3VjxoWdfuWIe#@B`EmXC6uSeFVRsm>vM7ypEpES7@^uDWedfBDC!cCugG?Jhs0 z{wi>)3_iD{F2`I&39Wowa8!}_=KzqOGDN1VJ_QWl02)bQiZO`x({Hlqp%ra*E(aAX zQcVm>?i_dqJ!ijJ00HYeY&@={gw1{EVROJqrgY5ksLFy+R2wl2si=OQHbqavYC$d* z2&@inRNi#RWmSUTU{atE1eoz?*dH7;uhuCh1_=(Y5kgrDsdj@>fJhB6tnB7H?+RV1 z_OHJ#A37wrxwf#BI*z@0aR7Utt@^L>Qeyn8RJZzk!}x*sK#ojhqu?*0i3*+qX;eG~ za!jK|UIy7efhf?1!f@C$i1{^p0JwA6t{g-w4G15j^yW*e${V(9(Km1Q>}j?Y8ykOL zW-nj*fW3L*k8Ae-R-{>oy?!=jfivZnx=U5=8@d;vjeTK31jYt8o0MV@h#<uW>|3DZ z9~|gk9>RhUZAw9CI~E)qjLbH*w*X-i?g6++P-MUkBE^Hu%x=Y*?#!-Th-;DEwhcK8 zVIb#OLJ@`K=c!Ow1|-6W{gIEzNwV9iwdz0867Y<yPy<L37p7B?CDm+}lAi+ENLBxs z1@S+QPkpvS$6b>tYZ3T~US3s2nTv?YW6G+k%BI_w^EcA6@>b2C*`4Lg;LbrE*bCZD zS*`n#t7q!^^zPlK?hLE@u}+nbuUNs=mCNTZ28?af;`z&0vbq&3*iX04%gzpSO`AH8 z56Pc;*K+JtMH&Vh`3E#0jd`2qo?Kjjc`GVxI&T0K`v?0~`R1?5y!rbF4v_)_!<$SV znWScu*S*_yCXbZ&n<P#!DaPdaz+OJF3vw&}Ie8j79i(KdN&4aXUtcZ1E356DWv`v* zNA!VZy$ibyV7C6<3;L7~IA&kQUr%e3FD5Q`27h(i;EwDCwNO#ceR1r|^F4d?=z0Fj zV_%$8l;g8!ADc7#ra6y4KIf*{bB@iP&HmFcXFt7=KW!DAZ|D(G-U>wp6Oczh966X- zB~!zs$pJ8X=m;UweW-~jK4zYID3UW2$D_Z6WKK1wy1>mtrVw>hXc6I^aNL7H+(6{+ zusL%zL$h1twrF<57b>MWD89!YlXYb-<C}NOw^ofBIfZ{QrLue?8rueaF@1N(_Rr1u zl7;A7X3ku?^v62O;`s{}QHsm==QsbM^w+;n3vQ8Y<h!(IulFpPJlS{_1K;w0d=_@K zXQ3>GFZIuURNCph_IWwBU+;kf_?IPvd-mlget&D+_Pm_?$G!chRzOd}FH&x7*3C_G zWQ}<<S{Eiw;CHGo;J%NN7Q6k?V+4zVYXA%d(z|Sdy9j|NsGgKzf$<d-Pk~x9RF(Yk zqUeSf!NH{7bH3Lq(0RE2J3ws+h*NKSItw(tK(GX4*5qrLOXeV38Ol$7^f$}l*d?)$ zd-!ht$`xzZu6Tvt$;LWZ@p;^T0c<e$oYU9c{^3r3^6`)8xkm6!sw(cb(&o=aLQt{B zkYSXK$ATe-9V4)xP=fl$pqqXF$}v;pwB}kB7_%QgdGI}EI``(E81Y|a17=oM&f3Q} zv2h73`J=dVEbqHL`jDAWr`YhEu?}IFyLMU^U|XOiK>B|{fdu2CNDXlaroIplg;OF* z5>esQS6ef=6qwa~P5hUw;O~e^9X<KU-L>EFQ$3jL2>+@VbH4o4cg)onsLofPTJ{8g zm92kr*^{j5$rVqs?tIFVOP>(?;12a6WhDGyljL$I!pJGq&QgfTV2-HB9jFxJg~qWH ze5sUtM~dCXIzG$fME0zfu!NnT%1+SSuh8tuBH&vsQo1|EH^-z$L#`sSuh2(89W*pJ z2-yNq1c00eAKuy)g+!P(82Mypq6)gu)>*7muUU(4@6aZL?^_Y6-9K;YG*?)5_Pks1 z856ZAHcFoakJRF(ZVcFYT`|5f7KYxsx!Gu3JaIqkFi1PG?ty8=c>OfIetg60X_FhT zx6<pyeR2R6Zl4xaJneyXAg09f*G;>%TI9sy;U{&4F6wA$hO|^V>;A!njVO;8WVfLH zHE~ReL-q5&c~*Xw8Wh~4K(>Twg$ZQQ;7h4hE=2bxP1DV~X0A$(iAoI6{QLv`{Q|3! ztazzq3UtvyuEteX9?8tn3@h$m9?Jsb7<g;J<yd&^gfIdF3m-eMC?&pyGeir*ui}~5 zQv(OO-EG<=BoIh`=F*u<7cZPYZ_Z7XGb(3Hn=+~DhH(Q&4;($RytHK45cdH0fPQ^? z_3T#ErfZw7ojcOCoRFE2*(xIqhBY)k6g|q20kGnMNlG~thSfkYB66bz(QQ}$9S~0h zbd61Gul)Z1_3u}{pAsr-GsjfULS;RxZQD%tgRIS}th`Z`C$-6L+j@}r8+{Xh%j6$6 z`>SU}vmf;g!*?6si5u_a``OOT-dFuoA24y^06n8ahYW~(_OHU%E!*R3zs9dU7aPCk z-{}J<Oc;pQv~Q_JH~HCXydGB>_SQI41@itXR6v7q;-ioebmCs@?e3B2h=7()sxvOi z4kJM9MSn=qrzE$C1=&t;RTYtM3dCtbrN?Wsppq+Tej3aL-ct?JLo;v!omM3ULc%Ox z1KiW(%7yBP%MP-ONlS4lDN4ST*{vo;jSpB**}X#`ev{*ZSU>*g<=H{#Kw75M$gH5) z#p~<-l=;DKEIGq+cfp%VrRAQ&H#!BQ#nBk`p<vkE2e~D1(bygx={NRF=)J}EXY1Bm z?(O!r{GH6YcjKSbeJk_5J($q8m5G0)J^_&cs^j0}4s2SNF<5a)s3S}IsH+ueh^zo} zf><cV?ZnIU$=82XsXO%lUdZwP=9_oCg`7QmP?~#(3OQQwZobl6$a!ryDjAngH5787 z9FAu?jr<xwURcR)?m}yr3^*x5W|izXSUW^Y#CjFrCAeZCwM=fau!NLBKwei<<6<L0 zMGNp#q09nv2y{ulLc#;EgkI<kf$@B467|y?c<&oZFEIx{b?Gmp#svTEuLX-2FZfFi ztzch|WCwWt`yX(=&zFbx6s(#!X*EoH{lB3pRf)S%5o{5}_%TrDS0!g6u6o4!7?CC_ zvPfxO**nE3=Tkrk{Wn)Kkc2ki!dw_E`C*jL2qQ&Ka_xP9Az?jCKAEY)NqpHvPY&A| z+~(HOYqU^`tzd7IvnO^f>E73e6YScVzeSa0wF}?bq>Ylm@vG}h35fSm4;6$W6jKl? zQe__xI2qIKO+FhFZ9~?a1W<|cC{oUZ7E@}!^2{J0U5(Pil;Ei)0b8S1CGJKDb}MHz zJI?BGH@a+MH4PvrKEsf>LQ)YI<|y%5C<+_6VXSJ5JECzAO}~ML>v-p2DG22Wx=g8M zOT%!oWghb$4>d{+YKN1&z@QWu&|LV^KJEh5kH92GC0$d9Dkk{2KxH6dQ;Bqk(4wOz z#G04^l1mZZ13pt!l1M1ULCR!;v`(A`Y8GX)L(@86-pmWOZuOEIKK>XK7?i2sx{n12 zio=EbF3|+hU0=YTQ#tm&*!S4-vcXU^>0!`3rd>}SWhGVu#eL)tL7mc6Y7{O^7t)BL zFQgSRCqkg00ak>;Scp7DS|_>id$EbcF~BekP3wmNs_cdq6+i2nC$a~(K8)EiR*b}d z=kSmCx0f(7`Q3N7zO;u=H?X|z`8(=tQGWqG6V(@{QO+BZD{>)L6?spLmLXI}`UOZ$ zN_L7Cr^xb&w71KefnqSBuEkVAgd#!~VvIC6Bd;y0hRV4Y0{Jm`I4n;-_`-tm6E-a` zHWpKfl=oGCcKPR3{EtriTCW_l<d*ko9*u=%QW329=h}W$A^N-f*r=@{40{V$g0xf+ zQ{hD@A~TOJfXq~eWi=owm_)N#Tnbbz5+I3;^ps?Do}z?;HA(c@q+KrPBe~f?CWySF zPtQk?#?czfnJZ>kG+kV`ZpdSfW8H3_o>P{TWpjkL?3VQeD_DYw{k{ETL)LjvdhjOU z7uMA^NDgH8<X?Fnw${o+PoDH~#{pQ>ZU84hD4P7&XF@w0T}Jm%-?RPqC$eSJ6J4Dv zfG4758A=F?xpSv3NL-wA$As)bE@BKMbdH++-ZDP>k=6^Q&h;EM7NI8Y^ixm$HnK7% z@~Bx&O?#6s4+n2x>(&!-)wI{0@PDJRJ}DHz5`SNX_=GM~l?VhHRHd=s5j+WuDDvg9 zUJ7<IfxJ*pL4A^9e8@=S;HO9_Rx8mR92UYB5I9sU&UM)QD4!tpa!Toc_ubc}^jE9z z3g9S*62vtq{a8B~0z41Zy?SG9T;zE)J`WXxqT#e&?`cAsJdI0o8RU&-PjjtBF^n$D z!m~uIT6G-~hXH`~@_7D1<5+|7x59e71lto&<ByHOj58gIZU7U7S%QPiLL)_B1}gEm zsKg0T1x5mnv>aZs9DEDFE-;v=wC?343kY!|$*ZYtcF4C=UpzGeN=x_9sWuwsVT&aR zdT#~W0Ta1#gK>p0Z>KyuEchT}%(@C2^#3#F2CmFi#w=i5L`?H~3k^IAfn%6VR0}2R zR3OIdqgoJdgD5@3w!nZrv&j_s=oT0*+4g76xtQN1@@bMN#?s*=7;QFj$p*o;lZA&# zXDS%fl(-%tffP$#X~T9WN;-*H5h0eUo>w*N*xkPSuK>#O<C`1z@x(1K=GkD9R+4?c z$p7WD?=!`9Ep+F}Fwr~@=4VWV#dk?XZnr=ZC>m9$2_KDYy<7-iL8ge2A!a7}w>F5R zZHY191LV7?nW8m=v~3v?k{S%YxQ)C9-#2WUW-Y%uouT=td~o-|aT8h1n)C*G2~aZ1 zGc?=pUi#%$vi_}B!TO&Q)?aW<e76AQ%D@lRJmB)CgPn)_9bG!)lqgv>A<wE}!r`<l zCY8E!L-kX`aH$GI4y70Rl^h<Kl8a<3-S6HuueeE3fN7d06m5lbAV*IA8VR&ylNunA zD@FVbEfvqKcgy-dJ&GUWOIeF=^f5Ev`xln6YR0+!?|90GrjN|_+*3MCclR7Rs8|0m zrxS(y+gS43xUDKQ`SeGR9C`b)tc+pG*26!u4*W%4_u{(0D<QNHFz+pQ=Y6w2ezN-h z8a(T$`ZFqNho<6LySs}*f`RL8pC;>?%Z@%J^u%yMVM=8P(jb`%r1As>k8EUQd{3O0 z+ZtG(_!f9(6M8gx^U9=C9foHHA_}QdLGKj_WRkHqo*0j6awdy!i$_=a_@{eyy1l1| zA3C>JZ(nf7Of9SJzWW|{vwMNFe>y*$o2IAdWVX^<Wk*IwM@F%Zzl}V`0#*4N(~60s z*X{CC@*W&{&-3T_r8hT>-&G76&g@NPH>>K@A@}x}m*Je-1N$<TZ#Q+qnTjR^h|z~Y zfx`@$%SK%|IB>m5ibxp*RRt1KpgpM%#?cDW>H3J4q6HF&3Ld!K4U&<tS>hJ)5?Tb` zXyn%c^Pq`Aat~gejQ0ahp*h6H^>txhaR;AL2E)C9H^&$w`2oE>&W@c{1Vdm7;MUh0 zp>b-OjL<IG#R$pMY%)S|{F@9<x%g_pN(SOUHBoIYe^Px5B)UM0+TgieDFd|TCNI-w z%?36Ld&Q^Sp#aA_*BzVah>by^F$f2N`ccB;Rg;|X{dGz8Dy$^nH0d%tI*1M6Vy+;B zB-|yz*btLR`YPfj*j(3oO{v?Dq(4x)peAZmTlyaaKw3TaSjlxXK$uhhciq;w>k5I$ zQUPwQM681X3%s13m-LK~NkZ3AII7WzD-HiuJTK)noyZZOY*<ORohBSv4Hc&fub8Ic z#m2ak=v6pGRo8o2sXG|?(<IdiPEs<;Y6$Z1=pcRk7iLo3V~;Jp207_hL?p%kjh~c@ zL7m0<@N%e-M1#$PjTVAVf>DKA2W}QH8xo|`VD}o@w%{MZp#nhI%b_B`!8MfPs9?IW zy6_P<iNw(@zI+`?v=Ew+LFuSAj@JZR&;DUZw5*$E4d!h`^l3vNAxjzcXHoxoUEs;l z!_yG}q!Xe$9lH<^d10}DrGWJ+6_|2wA1$%#$V?MW1PI-Dut%JbPK{5FMC=w4gyc;N z)&fu=jjT1a2++dJ9wyoGH=DPlLjt!-qHebnWC%T<5Aw&WAA7S)7siIvL8K?C?txv0 zX8x;JR`zGdH`XAm$y;e>rL0B!$P>>DnGu1jsf6*n_@T{7yFN*d{U$a~J@fwkTKv6x zB)R@iVEwnk4il3fECvJ;5XV*YC_GZM@kr3#hf)fR@D-2dHO1biBAtRnM+;XRQlId` zAihOf1@u(FR(c;wqzRg}7so@P#EyrOzyFS(HO*Q0A}*B6ub^k=0_tElW?A0>MW5V{ z_M8fvFv7;-P9-1O*s&yb?>9|5bSf*n9XZK{74v7c@z_TW2}~D<ADkDYTLQpECMN(D z%`nI;;AWw)%IH*&OLYYH6dV`B&cbVngbnlYkx@>D^`h3{KKV^VeZI@TST3)gz;0s8 z9^>zysuxiy+g$bF7Jiwwl;N{1mIv*M=0g(r@ymac=W+~@>0WMlF7Q}r%qjdc^#Pps z1meVD<`Dl;&trwrq#{gJ3UN~)Oa)Q^+pU5|>x)gTnHFm}xXC^s7J@ts7YH+NjN0I` zqyTL-<nEI5Z0ubxJoJKm;DrU_Cb0X~P8abr1)^|KSk10Tezx`3wYTuUJML?_Y}Dcf zM4lI8EI@x?>LcW$yMdS#6s97v;7r62btKtUJ+kT4`s68LZYhiw3A`v`$+-~zBsFN6 z8MH!jqTnGmr@4qprt||ChN2_&ff{rsMeAMSwz!)$AmYONZq_bXUPW_kjD0BYqvZ*o z@c%G&%<z97yWxG)LtHWThWHcRa>lJ?&sL++u^2lV9e3sT!?86SKf?{*6<0U4ft17E z0reRJm!)p?KWRy*(NWG6{FQKq{*jO|qFawrEZ_%2kEXGSWH@3oiaK%6p%Q<sCX!@U zLM0d38b^K}W%wzVVHFS;*m!vYP`gw4{n*U!@x99Pit_p=H^0&^EC1AQ8y@wOJvVOG z-aya!4<3Tf?`p=Tur8bRJ!ey5zKPAhY=39F7JuK%V!w2TUFnVe5-0U>_XM{?kHo+= z5?;W_QMXYwB!^&R0HwtJ&EyH#Bs!FsbR7o~X(BJQ2=9ef6Ub(uTu5{V>RoU(RRt!x zW2qU8-@We`KYs2#{wbou*g0cnpk{a*8>sLN<o~?LC&vGDKxhaKziCeSh7~WciMmj~ zrE}Pk&q1#l!s#OJfnAg1%&_nl$nImzP{xpO!-5G4R}`TS{y%|Mi6ro_SG?pWWJhVJ zaDT{Y5Q9Q@!>f;3{y^qy!2x}l@vVE0HV%4jB@Oy^kniCByu_;#e%}Aq_n#frhu$=& zbi>Ns_)suvZsz0FpD@3PYRt_N{Gz8y@jLtQw+J}mud$T+Pb6@+a1}t59EnTSti~`C zHjZv0<43I{Dk&$2Xs)y|DMxj8kut=QHJOB>uSF*%(L`&aD@o)IZT^Xr&{w3fe5G1| zxe7wH&q1Gs>GEo+nAK=}R@C)A3pmQFepXmmm?O-A&!VtAjB+Hnu^R(&1_>p2%{rx- zy(RHnmfA#$g<bFz$@^NqxC0%GgKceNQ(Gz1ps;#NwGrjAR@I)%wL4!h`<>GDE}iI3 z2L@gX!#rBxU3YbN3J&rEKtZOqEU1S2EG{0+$Qu~RdyvDz!k82m9TsJ?qTG*KBt-K< zG91w3K~cCt3)F6N3G6GX*>cHcew?LTz6^7QlszxFyl~~ph0Ofn`?zr1lJzC^$gkP2 z>n2RTlg>VJ&-!B+mzTTd9T%#>(1^tG2l);n8+3!w(2zVs9(pKU#e%rTyu>wogoWs) zluV?nxXJj0y+zaq3qbnspb|M7$6D?iD-E_=`8bs&z(a8)$tpi{gm3xh(CgWxQGFgA zFm7{?V<(zCL(lrN`W)~hU6^GkIT6NGbHEm4Cj(<0&M?K8VUP{rU68{h5MJIEKJ+N^ zP>T4_HBgeWGSgG>Hc4o*WpfJpz8=wJ^s?mC4NOrp2?KAFEwASaCj>HB1^HvA;(6j& zi$o`$=k!OnypWlF*Vwnd`s#3>1#N0-;)dr>89RDvr?NOWa*>xSdRMR~w~RSDap}wD z&|v>g9x-~vNS|aur*>>6xILb<R{QU@t$(<6ON$G6f5cJsXY_dO6=01Qy92^t-qH-p zp;72+i3$<ci##fV%ESI)3zCS6EQ^PS{nIqlP@F)U36+HZ_HsZo8ea~~gUg<Q3)VqG zWF+B$EdRBzxHe-Bfz!ny!yYhZQGRvCsP{InTQc>=Uh^E0pZ5Fp?u*R4cGZR@tW`?c zc+KoLiIpWLGMc)_UN*BO<K}-`HEq-+B{>1;+mYkH{9yK@S<Xin6}Rcap4gf*B`<i_ zt<ROw)F}@?3(o9s^{2J}N8NjXS5;+w<7c0CZ*F?;y^;jd2%&S6(0d^C0HHT&h9=VO z1rQVvLRAD&5G;tIqoY`{gN%xx(j0pmaYp5ye808#xi{zD1oeIA`~J`KpBYDHJa_N4 z_F8-G)z>)ao2}_Zi^l^{oB^*4THDdP0RILx=d)3{7G~L?6&sBw_0&_7kIC%l2_(ZZ zQZq9NOJZN07=Sz&so5TUeR}bDp{vEGft`Oi^weQTyHcY;-aKYh*KQTVjmxt3<KypL ztgf0`!;-Tqda0^5hmDZWPhQ{SgMTX5uIf|V_O$`sJN9JV+v%H*J+!%cNp|eQAw?~V z*sY6`%2R{k?UPX#e6M<!_9WcBMfCaw!J?057?}rNS1R)JNR@*Q2mXg82IsIYY1Ra5 zG#jGU$;h_{-xp$$tVANH9Ye?efR?ZsB2&TQbOsD=4!r4@68+iX)l0nydBf6$)6#N` z6FJcfX30O-4ZbTo7l&LeNSGYQ6R1CaZ_WdSEe<TduH((gQ7QLyn}5w>*9Vg?_Uhk# zL(OTDO{%d-9ijHZt5ZlGSTahZfL|iVFE7`FUu_fgU^7_JD=feonTbS7LeC@}R1#m( zHILob@{#`ix^*ib0kY{oJ@L-x<451RAT+`_8Rj=;gnW;Q9lPbVfzFQoy0_Ig9y_>Y z*ov&!yJq)G9UT@FTHC5m-zwwAM$~W>TQz)PtApIlAzhr>WFVlMNDn3@K||vr>sd4j z67CsRO+~{f(#nj^M1?T-6(Cw9Tl&S5df4n$Q_dMTU|d>hi|c3AtF_Q{A)IEYc01iL zA)KB+;ZWZ+S{v6IYc9B03Oi3P#g+A3D3#183p!+qCFMElLs9{`a~<B~M%XoiT_V^O z^z0{o6R-=%O>?lP^A1O4)(%HLu)`OOyQb)GzWPNkwZ+JO^~xi#o_lraJ6N^ZX0Q=- zv5YIvzjE544Ed+=qVeue?9dwq0dCj<_=X!>)fNREx_<xAUyNS`++A_z7jWjSNG7xj z4x&gd`mRe*R~YIUbD-^#Z~%rXqlXXfLEUX%Kseyt<C(OuEuu4F{|JwBqh)c`^Y=8j z=t_Pvxj%Wv@fUw0gq#ypc<zM5^;n}tXBrzO8MugRB*T{;(+=H-L62WRk6fwJ>CEL$ zKZWo@=1m500$G~D3A&^=PKdQPHfQ7p2Y<W;Rou@vr-{e+UoCgNiOr_IH6~#goDK;d z!uT8O&@QW<x63+n#zL7<FO2ihrQK&DM2YjRg)aX&><|pwaTbT*wuhphe;TYkq6(b< zG?|dH)?s+?q;-#whW9L!+Aa$P111LzQt%{?^Q>Q}AmRa1_h%s~%6RWH<11q~t6@=d zAM4t=a@~;4Pdu@C?qZ}|O<*IGust*SeEJO=jSHuv5^PM%{C85*Kih5mXYXfh@yx6N zxq%eFz#I`Z25(H7ggO8>yeY|))7S)HNF-97a53PTq1Fo~!0;ZY^NEMNa1_NVB$Y^$ z0KioEuebt()X$&(-8jo)ej2^DRjYzU-L9RtbZNITWdIv4$9A0B>fuLO`wO|}S^M<l zGYLu0EX`eUly&G7?T<GCZR8rh&}imEGI{!`O$4i;vN<@uVHd$jk|$F^xeXI5_>^Gi z24=!LAWfE%F?KAPTFk)6;ISW{J1U;?Q0@x8@|pj)reyJ(!bWg4?)*temT&ygB-dEG z`pSb`o^VE9{I?qZRzLT)GJG|hulN^}O5m#}K29bL8J_w-1Qz`JSAnH-glQxmZvpJJ zpZUMadUh$t_>>uJPDrTs?<XKgmYeQjBLR>O>Kh<jP%+&0g=3i-h<l9QOjIT&<5 z13t~AYPaTQM%uuqz=y^@BbF}7mZ_0oTs+g1X7rb*Mxqt8dun8AF=SsVo?b8s<*r7` zo7b(|y>{Ui7LRhp$1b8J^x<1q)vaW0FlLRl*O+l>{fyOjt-Adc`MMc(qvp>WqQCWz zi?1&^kXNv0;%gtCJFE|yHoJP<H6L?Z?*Vy)dS2-y(JXQNnRREkeJKqtaiXo2GXnT{ z&7lu9=ZV8c+#`?B&YHi&pXqncOOq%6>F;Wca)qjDU|XX7O14xkNyhI?r@u=H&RB~0 zfkA2h3lI4rcb5G9V$OW6@*~@;w?&3qurmPmr-a?4aWRx_iNk^)6Pcd1)B4|))8ZHP zu?c5-K&cr00&wV{oM0<qEBH}fC;g6MbU{*A`lUyoDPb$8_l3%GSsO9&Z1(}(HjH_m z__NaZ8@rt)H||Nl<$GqjHK7uA8~^1ml@rc(Cq?Eg&Zi1{Zo-~)uJq>~Xpnb8lK##B zGtVydKoQI0$?U~%CMiG4F5pMM!JnlpHWl4yZEPwViVwn_Xv2t5gyh88NaJE-#cX%{ zu9tE`zF_W!KjU}Pg6MbC*m(Rd(g_bg{jLlB4rrUdlnFQaV~!gdgF2BrOBq}It8tid z6PnkEA=1Z$*5|>M4fMhJj2n4uiE}GL)<O_ukiV4XOoqxy0}@C<pl}JUu~~Z#((>dN z-u(+tCjPAk8N1;B*~3P%3^rC7bmb9c&==_Od%IY-8}iK3ux_}7-g!{?V4%V=rNO&H zfmT1PE=o(`W?*<rx+3Gz{1>&oN%d?bHjAVU)3D*k#$Gmp{$iPItg#D!)v}$R$&1d@ z&gWgXa-0^iujOjh0XsO%8B82Xj-+6yXK6SrG1}HFqbOap@|syISI(TdQpuXQV)>+z zla?%*#A!^)ayQ{5h{pIcbkq<#Xoa!b=kULxoZ*z$VWQySeb5-+YD0a0hx@~SN55Ad z!|&sq(Rll50p7|T2D?CBPsxLesU3Pl^oI<iUQMOQ45~t6J^b?3%wHYC9GDG^{!H+! z3<{SKE3J?m&`KTJD6B?JhG@)@zdyGksmw&zWu%~R6M8_up54p4(DMcp8Y2P_Jw)*( zo?@O7WS$70nUz&4{)zjP5FRFritGvqH_hvRdH=KUY!<Bq9a!7DE<1Bx@4F7{U)yJX zX4br(>khc`cHg#c|NgbNKcH;v*0#K@vqQ%&>{a)lejn=W*xp&*p=0MC*2u4}VUw00 zXj@d&_Q3LfEB2Qa7nki{p{!W`$bl98mha!c{K{MHs`_;4*RHCn9sbMwll*!60R!6i zYhP8>{`XUT)NA|Tn8Dxq(k9lRJc(0Hb|xSapnxCXaqyOx;h~gMAD+%i(Nr_|hi8m0 zSj;nWmNA#z9L{d$>-3N|$#Hz0EN40;b<#RSK?q)|dm<^wCy`($JzRmnf&&(5xX_eh zj4z(~{(I#~V{y2#m|;*UeHkguRHkdWfJc8E?@>-(8BXqg!hNO*yet*Tg-SK}zyWE1 zPNh_&XU9%*1+rb>IA!=9dG5HWh_rftfBzu=Ai75(l(s<me3*Nd%}Nw>2bDjcHS3I# zr?U6YozX8SH$L>xLrdh@uIE{<Y`hP6ZkJap?X;ufzS7bm_%CRuaOe$&i<x30oa4>^ z!C;u;+i)s<rmlr151|zV=MfwJz)Dgw=JsBG>nUfKqRP;JXpda)?6Gm1p|fWv4bRPT zeW0Y$IrN77nF}2ArP0ojiOkOd>i9Wq4!>Hsh44YGKSPPKj<GZ&&>97b2Yg@fS2`T_ z!AO0J08p?-8^;XfOH{?3lMN?8auUVJBj_(GJfpaOD&<<zD3a1r_(ZblFMb0&?>4oa z!e4SsMh1H_;L|Jdj>1-Zcd9!!D?c9p;9Hb)T&U^ZW1z|=8M{<g%Z|%E>ssDr-1S-D zt>~k*VE>F0KYV&buN}2u#ti%~oRA`wqt5PG$U*Wg7E_%aq2Qk#h-r};S`AbLGJjYA z{#0fI@#0Po2B~r2@QCOd!f_-q;R=$gsSz`!mLkv?UmRatREYZh78%rQEFmr?B8-pX zK@mg{6<_nYWzD4zXHvr?QEX?9|1ITtpz=(EB^VctF<V_5sj*A(n0a+|^TsG|J@;Je z{G^r%u|>6QH{HKu2lT~;H{VBW;3b}U6P0w()%)ggqgUQ&{QE7}M_t-z`pMwnJx|Cv zZ=qO_-<|g8pZ6JPoF@%%_Dw?9on)q?O(n@IxTPzACU8UmX@oxo1BmV;KwI}*Iq;!5 z{Zvqvmr7y;s%U^=I`*Jca8(^7CDMwz95c%i(MI~Wvel@*Wl{UtC6VnGcfM?#SdV|P zmOpo_!*q|iZ5Q0a_8Zk~Kf7eVaZPCGh2RhtbkV+f<L1EcSYk-<rI7ILw+C<D2z*qM z&)Ov5lL(C3p~G09)6uCzX{+oMhoa`-E>JTW^1^tPNC-eny~Sk-|Hdt5NqEXDWp(o% ztG8{v^Uf`*{B)b5;?g!Hg{3Tg-^LAl_HNwp;EP>4c5s$ewC(oM8dtkDYK}f*(?cu! zt=xa_HF}FKRS<v!I_F&ZVdcXQt?IY(;r%PPknGZ@s-5y`pWoMzP{f?PhHsT)fIl8y z0{h|2<X~CO$-@mpgHaqKrQC+P;gWgGUoj;=pB5^+v<AafG_j=3q?WHA-1z**&)3d# zwn)m%(Yy5ul9lh?SM2s@{QTIa_r7~(Tkc)PYZF>uf1Og5U(|6}H42g1?S_&>)en;W zIqmP@`cT*uWpsw=De)13x-8Kd!pZOb1R)@9d4iCO5Sl6`t(on5#5@c84X&edch}9& zZr}d5XSeP6+ri;O1`QuExO&*9TaB}>Cv-$Qd9u9RS4Uegw)P&m|2@w<bI<$@Pd~k3 z$doBV<`14abujA!PkfT{KD)v*ohg6sN<LaHAumpr`YLy;18|>%ks)J092JHUHUKwU zq3+9+AA)~}rXy1X|AvA1wmz-bEPdsUh5Di`D~*5^cP(RU)C17`SuQg^kQ0rKY`W_L zd&20?9-GE#GXQfadc$s|Y6AP=xG27Urr>U~Bsf*%)0Z)X?VyQeWhrkBdv@$;<84;? z`a3MeC6%r2H}>c-<F4MT+sg@U?if?nf%W?0JR4vf|7U^mRB5}8ot513cE;B%sdXpP zXD2jV)@N#uk*+^MlCs%rQmlM4{=SffK?2*@JIXM?cEA~pwluN>=?-zo)WQXZR7RSB zW+vQZ(S!+dZJ_B3B`kA?rfg1!LhgdQd_$zo|CO&{g~dDn%7>^58G*F=4E!s%B?P`- zdLH35w&5}gu>MYXjU~K}OCj<-9IrP_yuQcZ<DDt3VD=RRz<uE!h}H!S2m)I&e@8yE z``b(eox)>VOEc1RtrlV{fT@8xT7v{i4*x)h$AJqwl3Hk@2Rm9aLmA^wRiM3Vyg>cG zTL(q4@y`El34ns*N|V``n&CqS4eZ;yd)M}DtrOksI?I#ug5ykkXCltAR69uLIFZir zP022=p>srnE$0t48GjFSCZ|KDXF#Uw@F$~Zq}n<M$C!p=M9Ht`7(1i!pROVZiL@)U z%|Kl|>H}nb6dHO3AiGIZtmny%OGHDO9O8eo3O~aCW&v@4@kqU?>er`7xAHC>+7+~9 zDJ%tXUv&Kq3r^+yHy!tCi#WIGbZ&1;nd02o0C8^0jks5jITJ|Nf<FyeCb(C@xK~L0 zz`cT6$;w5*=r7&^lf(YX*Z<4Q6%k373o%ppS*9Qs6CtHSPQ^!}{V?R9$`cFdC8qRJ zj50=pmvFKigzpTEY~N$;*l6SBum1_#@!Y^Q1xm`<$KRcCclr$@>lQ56^)jQ_*gYTf zYoB4U?_OXbEpxQJZ|42}<XiWS%PZTqYR+aH9A@>{wMQX?{h>Q!j1cxE*^3x4RXS*o z*8kJB>Yw%6Dnwg;%hKNXtyDWr8QA!p@h|la{4NB)3wF@&(z8=>=Y?9xP{pL~`!v9H zg?(lu$t?mt`F*0?&h@Ig7;{5in^IkC*BI+I$#2TXHes!G@(AT5{3;&(oyVn5UU^Qb zkVjkuS@8|o*27FV5#hvs(IsWDFwzyg4RTPfp2m_tG{$`Sw@=tIhS_Rr)NcdjDEhG? z4M)xV&v*xf4d^&hl$)LqEGt+eLZZ;OsqgUmW3GHlk;3<6i=>+OHl?Zj!7MXR-uAO` z;k(V}diOoI={vkW@!xDd*SGiiE#I(2<IIBDD;@|6+`Dwn!rvaAckPk~gF<&NpFLkj z+rRe@-G0YGmj6|oFIlVoH{ZP9IPvA}`@bBNH00-ft5@&)c}UXWFZK(2zhS4*M?R{z zL=Kt$cnHx1t_VwrUMLi9g)EdEc>Rf-%FN*C;@Ec16VGM#DU6NFP3+M(=lQqoerI*t z$U*AqCtvn=e4y!7y?)OEzs;AvQY&G<VbUo0tt2Zp0Q?pX%e75ZG)LIfWszrQ!@Fp^ z>OWatu%x{E=%Kx9DxFIT9feDrl{LMGj_zK*q#)v||3sPDwLeSA%}Vaq?NqmZ$yvE6 ztbf;!n)&|(-LIF%E5ECIU?1s^huMklB`5`^j<(q}iMkBRO<A<k`%&YaIc%5fvsH6z zUS~b$7(L~-v*s$FT{?d0tFC+S->-DV8#YkNP##m4k?b9qAx(i+5G8%)l-g}!Hg;RX zr>-|}8vcGLrEURXjqhjT`}fs5==+)UeF~fdm#_9c&NTx(O7rG4Xf*c2ftWW;_c)c| zKWJiwMt;=qh24#$o4Lka=;m^l{PN*&J>u~v@n4t(mhEaGf52Yp+SO=pbm-bu;9u1c z0No)3I-dTxT><`$4l1^ANICp|r|zBhanJreR*$}k?nxSaCSl;6RLZ#_n*hz0Fptkn z*cW+DBD4@yi2@E32vw2UXDx|Hl~R$T0;_=B;fRq6<=f3~a36`%6ZhZKcKv$3|Gg7) zdoAoYX%ezQT~Dkw?m=nOR%PZ}z27{WocMWEOwEYiSMKKVkDabs@pr&VeS1a&)^w@d z*_qxus{i3L`jBUX{CsK#g|rQtgdN3mx6w2aVw?)_L?az)Nr~Q~)cy`5$$3P9>@fi! zH(jU}KDxyGf0X@Y*L0bC?GHZ?bhqBh^zVi~ID7wU*NdyQ{D7c2GYj5w1NT<JM_(r= z{&t32Wzct`q-Dmn_E7B+s3$aSssnttJ*0kchK-iSNt2{$;FY<!SIeYT(#_KC(i&;K zv{Ax@_zicjTf6#>+itn(hLy{gEU3G7_N*Dxr%awOe(ac$)l~yfMqbgWWBbyq<k%oT zISR}oyh5gZqlrudnArHgA&|KgFl`~KZY9eo-G)#FzJsC+TNHN#^eRF63|e_aX2Ri@ z4mS*?OX<j5fKbLi7k^p*9F9ZcU!Y=<n|x%$W?KHN)U2F5dBuvUlUA^lnrUqcbMj|T zdUi+eE)~6dJDq)$qh&e8ZK`E`+Ni4OHNU<z_a!ao)!F}<$x2_+zF}=<UpcK6l#~`P zWBpl_YZQxg)vyStzMelnJGxW5j_pTZ`Ef4)mo05J|Cijg_WJ8<=ZwGZy73<l=-aY; zU~uQ`K7Cvtf7q>m|88@-4j9n2KEF-NR(ijxngML_?*mwe<8$X8H(u70S>n8X`{o%J z_FZ{WZk3gjw@>LkkN@k}wqgr)R7!SE&c-Xte!CL+>oV~-+}c3bDch~~@pv(kaF4P; zXZYM(WM{(vf#L*7%gOUoG<e+wK`4J1?hkQx&|)K_(<4h1@E`x{b>;ah<yX3@!Ere~ z$LzcN*1d}IBI}UXrb9{YfDXrxAMb<OT4d-Ax>9tdNO|YS(oS*NH}qezY1Jydq;;3l z;(iHbBZrTA$kkVMtX9d+B-wIUT@Cw=?98l`04`fN-B5JG+X0%{3YHQ|PnolP^9K!6 zC(al<%J_Ru)X+hX*SikfbI(02<DnrnV+KE@u72+R+B@@-*G}ycdN6!yan-=;Q~Z+t zgnpHm2X-qbS3F?I0SpCzAsCv9{cw0lkWTWAd}I8^k$()PCJHEQ%B_3%@}jO&VR9#y z?mEuG^&s~13zKQt$@TKHifam+B!|<wtl{6rSoSCa6eQ!}{D=QeaBO2%8bX?`Q6tvQ z>M|-lEvg`?G_$a{OY1xOOqv@Pw#6Qh7hlk$1oGqtV-wpe-DlM!VA<|9&aez)lkCrN zn4-R-#OUXNLppFsj}<anxEadIOv^Z&-z}0S!ly+SObKQB(e2xxvB^*Nsv6Me_OadC z-jSV{b=~M5c^h)$v$aF|#1$(h>O~zp6|#`tGrAUMr1qLwS(Jfuo2tH{B-;?d!3$zP z92?@`wDY>Z+1Z)MFv%`O0%@5bs!gu#*MCr-BeLz;T|1BJ%;*==qm!m}udwYoRNa|r zhYCA(EYv3~Su#OSoQVWwJw9g2!0yFu^)?*Osp{)Wynd~RR?Xs>O|8$A2&O-?eaAC4 z_GF)`0e$DZEI)KFu$i!I*#y0)OP8V-wWokXjrz5cr@u~J7l1=T7@Bv0_O|qF{3o-d zthocrlV9Dw<5ii(ZhyRQhk_f@ViG3x?vS}UEh<_4Q3s=+{h;%h^4!FP&b7`~e9jx~ z@vZ(M_K3wEVSWPUbPca2{*&!<K#_9X0pol5)g9Ykm4^j(E>+de?QE+z_A1p*UDWTq zQ@?(m5)-Q@#m^qrudI`;40%MS)r-nE`ZBB^i1h>fym8Rdm9i4$8~L40o8CqO&i%%1 zdq0ssQ@<imFOFpnji2iX^=oy8ev@Yn0b_|KPJ)%7Uj&<VKYUMo8KvNy{OMi-2#c_L zG~*Y#M>Xp0O1l2UpU?(lu~L-;S$pBW-GA5Rm-_VU+dJgqafJnfILmkKTCSIN?OK|5 zQU_Sz{oB-mtX@ZUKJE}&T0oye&x*+O+pgW2@txX$M1Y?j;P9i?6M3q1hr{WNF{}=B zZ0v%J3|rh~xVh6?R<XsbBfD;}(YbrBu`suX(S?2GTB08eRNlK%7<BNykVT6^?qfet zXExk8XiVxRtV=UuGbP87^u)*re~EN#kBkD3pj9W8c6%D)yEBy1<xL;{IJI`^Doi09 zz&m08RMn$L)lUZoRaXr;psv1u$KX|IF?Wr>e=pL!Nh*yuzVA}rv)9os9lK#F0q~#D z@V(kj-3C7*>=@FMnA?ph)Os6|xwwKLRC%>j)_?!tlJO;rzVy-Wx@>$NFmm{`Idi9u ztqNeP_1E5IQC~msEsKBm6}@)!j@$O!ylt59DG{Fc0?!~!JhLAT2^O}R*<H>=PvhOp z>Cu+gonu+X>2t0v9I3sNmMxp4t~P!?apI)$i$LX5SK-<@Cugq(4$yYg609BJmV+gx zLyl+c;@u7<>k5VCTb1h1{EegR4WpFx@c&dSWNf{uL3-Nw@+M=OxmHiC6^gY&$X+t% zjKE5RZopfmVj)%gG{ATOHd>0PTfos`n3nO)NqFmUtme5c!nvkk9aOME|Fl?3Xl?F& ztne47s*5TwAN$@o#nLZcM13$EbOBSwPrLrcx?$s!PBUXypD8T%+|kci+_5M0L4CI` zd1mR3n8?E~2$;1EfSG6*%6S;d3c2N|o`JHC%xA_d8LgB@ZDl9nUFY+lcW*UX(vzc{ zrOc?W86Rcr3Ze(c<r1$M;e#`lw_^{ocTpRNd&2h+DkE0JBr|gj@mu*PaSk~R-@=!; z8oosHjbea@OFceRhO1z(nAP6(zaBgJALLmkjOkS|l&1ZyMgiX6k9_>nQ~IE)af4*1 zu%D@a%So)qZM;S}_~7(N#4b2Miu*0kmrLdi-(M+*&i{o)Pj`LOanJO5uD48F|IHHo z51}UJkTE#=;6Voq<6Sp6;DV>3u}`oYZZ}Wyd@hrnc$!vTz$b!{0B`bo1CcfJy!4g$ zJ<){I|4&Bc)gYqEmViZFZ!F-W^3W83cz+QaqO`@zoFE81xmwA`nBnhMGu(S=Yp_=| z_Cf>)clau<X>H9`xIEgE3!2tWXRqi;t)`Q{QZBzE8<KljS8JJF;lAdHpx<)vaUeYP z_QTO37_*J_$^NJER^A^n(@XhQmm6ok{1T1rGQRu*clgY*Yi3`+WcD>n*$<bD^DOz| z{tGP0IDdgHzi-!y11om#UI7#!+ebF!sSjbFaPG@Vj0)EHJ}AqwS#ORM>9gDXu|vQ5 zoAGU8yM)F)&n~}a_TnY8u35%@SpIgm`_{dQkwQKjue_gc%%nKuG39QhlKW#&SOLCH zMShs2?MG@H#w>aD`Y_HbmEHy5bU$!TsenHlG)Um~Hgqp&mfo>F<d2eyW=`YeJ_Fep zyY$lAzn(nviw0>rc+7~Zk*hyAVf=FDE8{0zhd6oego$HWMVp=p`8#&q{o*SR>OK2c zl(g@fn15gW*1x^7U$5?7j{V8c^MJ{(XbcV-HP+&bl%@wh3wREfwEieY|E;Fcf61KM z=V<gFlM)-g)pGHBx>w<D9un~m@@Ns)bFfRfP?1M$T{vgXJY3Ud%Z!WPd~0051d()p zWj~oRecDtxjk5V%pS*eT(i`+=qA@1$07e(~AlVwg&j|BZOE9aIL<x+2{9TT#eGS9& z-l%22*BSR=I?b+Y+3(8PaM!G?RC!bQp+g~8N|d*F(^eEdz{qWb^@#6HADohkC<vSe zv?9ep@NfKCZ!_|9<KkicQRBj;k?glcqxHi-KBkXZ$bM7K23{$YA9M{@-VH>LcGth< zcU`5j8qIxmiGcSg){mz%(Qu|^W$0-|OGnc<T!@=+E^e~v?N7Y@r|<4$zZI{#v5;N4 z^Sd8!H}sNQZZ0uYOozRNEsj2PzvKP)9rvRT{LRL7Q3vmHoIUHfPn-+d_o%zD56Q?t zooGj}^BtIJBJi_`?0&m`M-OJKF+QY@1jZ+8n4z2vGLAE3w;zghz4s<j^aD8~k`A1q zXPl%4VBJ8h%Xzz`l%-O$58-YcAa^uSjji0{dV$phe6m<+4OW<c<rPzg$<hqy25p<( zed1nfnM&QX&D&`9O;y_(KYw(__?bD*oJMQZGt)+noHngy#8g)Q(idO6#D*RF;)`Rf zX7=nF<H51BXTv|h=b*|@Vh`@85oZi5I+LEPn)*lB2~nZ;`sb-v3h}fu_zooHFuo@~ zMP5x#9&mEomDX%+>X=*-I)?2luk2LbXAn)f{psyjK3aYMeVASu`}8MlUe_6g9R`i= zsqgvlxrdh?UA0MHX6zR9=-KeS@-g<v#U8PNL=WyzAT=meG@YYBzU3l|djc_-UMh$8 z>Cv}aw`$t(@>B2qR9js;#rXZbBgSt?*oYh3uh+;ygWr^&=vGnMze^ka-Y56(9C%Y! z+U*l|9XYg5Z_{UR`>O88a4roOjkWOAZ{_a~m+6`0X=t?UO4-|%>Y}aIVj@m^!r^E2 zG^DBic(NboDXOyJ{))7Wva(DM%<xoZhU2gl_FQb%<jzmN^UrUN8$S}XlLikPUQ^X= zP^j@+4>>pd(|qONPmu{sKK{gGC-&Z_hji#ZZt%ddEfNCd4gHK$bat{d2|N>wvx|ct zz<xL-KHRjoO*fd0`-z1J!~+r{Q6FyMEJpF|vVO}u6_iZwJmUsM$z9d|spH1)@4jXH zhqX9TF+NtFKD76+f$Fx{m{Sqqt2b%c1uyS=^ej_9xd)EHRM++Snah@p?lAy^cZjbl zz$Xj9`$51zko&!LnFb)V4lCnVKw0qcUB;P@ml)5Z@~yS<$j8R{D^EZDE4y(K$wLLR z$G%sCfJZd!-2&+4`B^D(5q9qTZX~@s?~<GurVEN6t0G=R@#n9nj+(y2xctU@#@8!m z)n3!^(%=4VG)(PNHD_*BpDF3p9V=@_S9Tn%)C{>XJ7?|a`;HvBuja0t>>Gz{e(*up z<StcJUAhbyAm^8smzS1x@6OM-BWQbqpK&(MI5i%#BA{P_M=5j;-xgg>$=%@?K7nvV z(@Coa|04SF&7irt)7!m#j_Gf|z?kvV>wWh0F6^{mN?CQ><bFMd414R^q21Eb-#fJD zT!ZwQ@xsw><6_<m4`a7xB=;J-Y<iEXDg1nqGsEhYd~P>!-$N=zn=@JciRG+HUa%t? zG{Brl`4qm10}aqZGzTelrJ0_~ih)3GClD^He9E<swdt5%P*m3Tby<J(p1ZcqSTa*) zBkQjeSGLG5?O32s-?(bQprunr!*YXcYq%_bfwh~tqn3r;{t%Ccg5OcLrgMk3ZA;p| zChLc8-t=gXPCfcOzIolVy8K#~j%~Ykub9I=Dr%KglAo+kx_;rTvQe=yW4q2-vUIMV zTTqx^+y?$)S;8C=B^K#J{?Hukhf&?8lD<Md9jNl~=b%*{{5kRylO~-sCI_;;CymkX z>X0Sd?zm%_93>mjp=HXMt!cQd=vXJ2_*B@RFf$N3aNpIeF0%EiUf)_yH#UaG_i1_4 zrU&=meN1Ps_v%z$UeUT;mms7;zPjbU5X@7&<ND?I)XmlW^ICOm)2>GXukV(nnb<3u z)5GK&@4FdkPB7zghTNreH%*sn>n!#~*@WV>?5e`v<1#09yyed4Hr@T=KbGfLMpU)y z=qy+A!$LL%g$(P{A~EIWdDm}#^v-A39yBUrB0_tN>R4Qgj&Z=X8xF1>xCQ`Me{m-% z4VT|ZJpJ{{r=8e3%$O?=m2bND?~g2Bet`M+--^3f3%H{I_f_wr;QBU*^a*{->;AbJ zAEt)v>g((?@`bxMzg{z-TmPeLZ+rader-Ap8q~S0Ph6+`;>xbYd7b2e?MKBYOz1La z>C!o!Cnm(zw4YX2XO!l(ZJU=@Qo@#H=H+H(6|^EA7!Dr1Y&}okd&v2_QEq$R!}Xo2 zQ>t>;-1p?#yI+3e-qLGJGIFc?x9l9!w{4p)<#+Y#)G9IYo~75;KYqu_Rl7q&?+p!N z0SPfl-ADH<Zi9oQ{fVAM*xyGt=cgeK0)9At?M*5wMK5jNaqPt%+h0D}ud<?F->#K? zS;_kS`_~^`_sApbSfAm;`#jTs$dLY^)h+S{rK?hi(>HSid2F#Om9@$n(2b0I7uT!R z^3(cLkO84mB4lJ-L=a*(BqK}E#4p<>5_p8MXW?P?v>_Y6J|f>Te`s}GUG>oUb4#)_ zi;6O{OZ2DoSGCXkPoLg@;N&R-vWtqcvr9?@uGgxw<>T51*o$IBL4GKX#XjLBkxF`| zC!w3&I{W13HO5yX`wh-bKcL>qIz<{Uj2eDtc6G{VC*_aOnSHHRA@9ih%tFYXp{fuF z&QKqnrpoyF(&uRI?*I8Ej5<9tebS_9(<e`yCYKqX!dRy`RXIyxEnyLSmh{NZotV>k zXy;C@KNeua2E?_jx(y^C={674!v$B$l^f;U+pT|3bo&jQ(AhczKC8_1Qg8qwA7a9y zQ`OE_lGq26hfWwZX&OpGH5PdB9AoSD8ZKF$_&ob{{;qB{^KZLWf0>1Tb?nAZ4;z;> zoB^YJK(#&gAlVrgM7jZ);eu13;Bdw6Y6=d!eK!Iz;|I+l1&4*bagl{wH+}I6<MgFB zjI&T0;uqCSK?~sBO7+Zf!>8Bw*B}1m!`H?>T$uORg4Zs6@RD9Vb53pD45Fzb<r}?u zo>2kv*ZP5fx|g>r&W$GiNr&L(W)cONiFtXnfGeJ6sRO_4{H2SEPW4V`3+JI}kKjsI zd*7It3{4`neZ0SaMW;KSdc!#N(*?trSQQh~p}2NBQ{HbmB%951wVF^}HGaaN!Q+R- z<b}s3UNiZ+RTX`dow?)ML~T2v>Vb)&xhY%ky5;=Nc|(?FMR(3|j?F0AH7@G@H~syL zwdJEml}A+$A5r0IiMFd9v)c9<(z;b!;3@Mt7em1Z4#B(Vv1+~*l*67)QBHFGKel_f zamIBpNUmYouGMUS9xW%GH(p{L4=OKTnI(tG2qQ4`tNL0kz*^q#g+lKIT7$??&3$yc zCDlqx*Rh<OYrCEJ-1XgS#(5AacIJpF<EBoo9uY3zq~v{N97@V&igD$O6UJ8`|6L0j zH*?+mW%qV2CD^B7zZ%Yu&Au7YT%V(+B<2P3dNbrl2i?)Vb@|k;H|^4uqK#vYePVp~ z(dWh|toJij*CsEWI&$VL?d9a8e?-N+dPpm2Z+!j18Tbg=Asr$CM)x3BLF<;|4jg@8 z{&gGqISvIZ(~*x5#^V7Ak=z%-y#t<dYq)+fj*JT%ciMq6pmf*lcP?Fe@0x9;F^pYP zXEYe0V`og5=x3WWe){;`BgeYysB1^=ah-QvWDRQ{*t4?J?N2<vh4_?7U64C^8vFhw z+n%H^TwB7ne}2re=Z}5;@;jGd+g}<~)qT*=m9M|}`&%EvbBc!MGlo?SWx0jj<Fhy4 zc;~Sf@6pQ#b!%Nz9-C8t>-wk9+@TNa@8o#*2Hpd)e;PUt+7D-^$B=IX4n*7yuI^!a zk$HPFO`Qt%STw5sN$(R{pZr5WnAUnj?T%+If4yPwz@7t)f66xF?PEVNWvc7`iffWK zj2YWAzFlI+-j8nBad2q=q1`$${kB(Me$pt9&5H;;c&uIC<299SpjG2M1_B-h@Q`mS z$OidAx~Dn6P&kFqmD{XB!Znn8_8-ms6t&^mf1!Lw`|-8Q)RVrZYTnqfUUPHNlD>NO z6Kj&zp+1{>(5Wwj?}*RiBS=Q2E5Z|PrVYcoL$d&PEuR{#zI?Va>)O5>5ANB}dudw5 zhr^BU_Zhz$Pq9AC?_m};Qn`ycQd^vQz&QKh`<Y2D<N3+gp~Hv+x6hANV-%#h=UMDY zHk0YIweH}a+GtJ*;pKPg*-GQP6UJrZ5$t2z$09~X|6Y|ct=qcC9$q{7`qX#X<pX^e zu)f%%kl9(kSrd%6{~4e1&i%&Q54@Wm`+4YFv@hi`?ZCcX{FQ;KE|SEall1l-aTZq= zFWg|bj9*yMH$SqL<UhJ)@%)vyJ^16V#)m(BYiuWZykpIxrEE#{<d%Kje*EzZ4bSM4 zmQJneJ+`#+%;V2|c=@cp>bmiC&#C8M3}Enm7gNm>#^1c(MJ>j7#Q4$p$vDIYpbRpY zVNAk98}E5w&xVZ;%0rBQ8TYd>@M7!eaD^fnR7O8^`t(D_e-4~JeZYOzC$XP3?jSX8 z=5dgl)K=e-1C7rOgHzPWBphf`IA$>ftXzA;miunMd2s;yUjH7$kUS(ce!Q&Tvw`Tn z_te@AoNtMzh`tt|yobIijXrsEOLBWz$lD#82C|4q+4weM)r~jr=JY+vKJ}un@u9xx z1~+w?6e@bqAYVhd1ex8a_o8$Wg#cl&MUkL;>D1PgVB<_s%A1e6Mk&v!?-<`1nZ{#? zGndP;=gt9iyp_nsQfmSGRdrzN<4AmSHG5R;a^18=cNiBw|EF>O_UmRWWPTrg#QY6o z*~E$0FP<`SN!pYVBPLE7IbxF9YUaLH#fRq~|LCLR^Pem#cyQ*6r%qjYZ2W=+<0sb5 zlg|&IF>U0i88g5;-2of*2Z{p+H?>D);U*^S%Jg4&>%mv*))n2-|BWwM#HmkNl=1qH zeRp+BD__36=QXKwYKPCB^v1(GdUkd)zw@WjZ2T=$<vwWq+juuQ>11p)`>IXLn|JQn zy<iD)@_4Tj^$2W!s&lX(jtLX-Vp5mT#M}&iP!!G7cGBfHKY^F(U!T11_J_Yedd4+1 z@2jiN9X#~ePLD7A?~{A>nofC56A^!m0UfCxi~g*`KLZye#SL5J;h&rTlF^}z=Rw`T z4Ec!sDgPdS#`nSa<PT~kfddQ+jrtW)MtV1A1scHU616}?;Xe|cq4lC>YXlN|B#heS z&BADIkHkyl_=xlPD2xt7+kSt$PTgQ=@*}P;IxWHW=Hsft*3?9hyai+ohnC2fa79NN zdyLDjx%J16)yo_H@xr#p9^3Z9KTu`yuyOfE6pbFhOv5+p*(1n8|I+C3{=@&;_r3v< z`Tsk3QSO2BjpV&xaJpzr`2Woe@P4b`dk@L}ufN{h4Dh?_2OxZSq5ja-W`INS)7pb4 zqAA}iDA3`DK4z=}^hcVSREzE{D3nC~JI3N+ZYFAV{QQuuY<BLzkD`%{PJN6#tuWEr z+?wqbN)9otJsJxC{LVYnh5q<)<8lCX>0ENZaYwzuLr?6ddN%)lb|cAdx#4U1ZLJa< zTIqC#Ajg_j_%ny(n2y8%^iLsBP+5a=G(WH?%7##LX$~0!%b;jHDG>ni5}Hsd03>L5 z=XasD@%S@JSKN72?7Qcld+$9<`OoXGqX4K9l|Gy6|K%z5`MG|xsP(};Y=QIIWXq-e z!xoa91rHuF#H9+>mQ9p8I@{3+B0C(1N4+%AmKj;#Hk8bvybJ$JMo)o}fYZ~~k&4+U zug{)FcU-KU=CgJk`-s(CZEdWK?DD_7cA3xGTUZ$DMcwY=V<HvZ?txyeK(lf?&K$*l z(>;hZhd>xmAPgvLn&g<kVT8{<JEiYfEzO_B$Z0#OqipC8iIL^zS*aB{%<lATW5;RP zQRNBKR`Sy^Pon9$Wo4ibiP+d7Y9YkFfj;|Am7Zgx-JI=17Zj7C#N%p|Nr)$==BUvQ z7Th-Y?6I9~V9!%m4-Y;T+5-c-j)8K(36n>g#RU~^$f@`2<T=Any!T-z*=Cj{-RtzX z>>~;;T7v~ZCd?oMt^8C!Vmdp#hj#zQ4gLJ2!8GI3!+P-;;@9lY9M+#X94Pj{Z&Cf( z_|p;2P|QPZk(r+1=HGyH;@{RriFyuiHSR`hx*M7NZY*SH8Vu<{XHW`e4ums5ISupC z6x5thS64Xis2_xa@<5pyLSSmWpF9RtHa68>i>F5$jLuIH=>6~KCz?Zey0*pYs1re+ ziSN(RXle3a{5|kUO-(IKEsO|_MFSE@4S$XYENk^CamU*d9?-Gqj!U27j-$d4&E|BK zx)(EC6Afpm)#9;&&$SjTYghfy<KKqo%Z4gHvk?$PCMs|Sq45GLdE#P;u`=nuOx_jy z@q2IC4=p!w@Ber|yX2?Z{r-3Raamy5Z;SLaWWh-1u!Pts#qMatQb7r}-7y{A>{L4# z%nRW^LNqBcK8_fKql%N|cSzvM@2O?)snR6eQ*^Xw+|~DNF`Cf<2>$GJ6BFX&Vq@rV z`L<w8es>#?G9s_HwIJTapRy=7ifG#K7@HuqaAsj38R)3Oj*@VDkw6B19Km@WltbsE zu!zVoYW~1+D8mZ(*-~jOq_DZys*?txkyn$ouo9ZbUu~_1&#~5Pwl+R+ZE3iZ^`y=M z;UR(OJ!63m$ATo)>EJy{M$ru}r3oN9e}`$wRF~868rFQ(7T~ky)P}a;r<TrK%WABG zo_DO}jV(?O_)@XHn`RKmT&8oH74oy&i53O5M6+1bJEfyvUmBBDMBiwz6Q(sOGSXqy zihQO!A;+owbri0JD%;dicBGP{qaR*zn1o#!%gxEoOaZsB7#59Cq+g=BZzb%;8G>e& zbk4{_;BRef&@9K9Ne>1T1S%1?^yM*|YGMpKy08KT$R)83r<Y}&I(7>5qIK|01N^_b z4yTo6oh>W~v})}vN>52dKRvJys=qM3NoDHv=0OXKAlPiFjj#<TT3OcIDSgGpN?o1h zn2@4p1Gp@-6jUk-eGZf1Fq_>XH4}Z~u!qnq1pb^KEPG6qj)EUBS%})R0otpbB$$Dp zrC2K)H2GG@#%!Vq?gFRD6v)PQ&Ni_zR4ah4x!_8!0nxHF=MO_Ez)W&Az(u!1#!^9W zc;ezRBeQI7dW*HW9JH)mC))vMleJBv{m<6sGS9O17WmhD(K!p+S)j)~Ya}C>xd{U3 zFo6<$69s!B(Ne(AWt(M>snWNQZRjdwS)IY)avwTwLzBfb($i8?pv#)e(~ZFT$T!yp z*!cM%g*giq4|Mi*Xfj_TVJ2^cAD<E;F)?8gmBv7V>+v#mfag4}Kz9Zuc$s||>TJWq z>6T+{@&lG@pA#SUrnNyWqN`LdrAVio!7;eoIndkEk#n!p<4q$pi|NtEGf4f)Y{)T# znq&8?g1Uej5wp=_bfrIv{GobivV<HIDiNi*nuz_FzjVKt?iH@~yZ_B*C<2Ym%4Do{ zNl_uxm4d7Sv~tNnM~95807yzM+XUWR*RtSU$2uaH6dfCU@b-Z12G`HeUIncAk(zBi zy%GLv`~S=9+;wTod`+6>oQ%qNyu@BGP&)y;Lv`4p<GIh!4UEHKJ$U%XaPa=-!4n)b z$iBG9=OhC8n<40rxt3P?>(b7u1nGL`qC%9owr6&~c4)He1&v-&$sEomfcW`22BU=q zpt0Ni2cx*vdOm1t2Dkz&aFt_}GJ)m;S&%o4UiX1*YHF-B!CC7C4^$POLxIi!o`mv1 zcB_ZEn!-?qAXN!EPW&MZdX*OpHfg)`AL)9c)YYJHKtXdr|96wftn-cfLs+_Zb#`vw z_D{}3ulI(9os_OLT##;d-T+wqEq4_bh{NvZz?kbmv_GnqWPimUs;a`M;k*Yh3?d#J z#A#9~1qO2R;lRvBJJFRW+6B?X2U1sJCaS9DU^cy6Aw)QOca0L|7m6*IZ(BDmQx>vH z*aJtLLE#v}twY~J@wDu=2Rfl<nv8xDDQFlw872#?4;TdKC1S62cc3Pz0y}{}Cf)`? z=VpGdNn{cHr3FSflTuP-mV)7-ty)r>l{gGh3k`OlStCo9lLJsOPIw_^^B?V>9=v)0 zFI}p*E>#-n>=ywuCX(je)ANUR;M}8TtKyY&e(v7oq9Y%7vq31L$rYpLBrzc-B{n4t zV--;b5iLhMs6gGb-=|*tk=&0%O-A!O+H7D|YD)D#-_f(*&tCgMCJol58s~`Yj8u3E z+*m4j$aFhHLH$$@x^{aI3^ub%yNM}zYfMaA<YZ;0r}^UQ?}h7epS`ET>pIjq*u87x z*}{U?ZSVzA13`3G5uM@9J;~fP_XH&~=}q<B6$AyoWW=o3zMwsA^!B0Tm+1Lw8fo(w zTMOb7pHj0Rr3ywIFM)J74-11&lq>_RgA6M9i1rz+)4g$>x+!tK>nQF)r+9;!uG8>4 z);X(PrgiWqH#}Q**+|O_4T5?FnPNgESHKj&91&DB!58KYSy*H^Hwge+!&$6!Mtj3+ zO`9~ep&v3(VH0@PV-+w5fF|`vg8*oRk8FbQMw=i7Hu5jxy+|P#2lBhUQ(A%SNpwn2 zMi-nGP;qi_jWK`|-Oyl{(TEor4gf`~C}uX81v>A61E4jH_mIGb_>xaP65U(T3<#<$ zswUyZgNF%cjCiTqQP2t<hO@{qVd^Pq5=~@Q(Sr@kVNF^I@Pipl`v3z2JXQg}S7I$r zFUwl=_Q&zH(7l1W6q``}m9;p{JZsTAZj;KKt=*OZR4_QyRFF#7uLhyVIKX~xeD!Fe zn`PadRY^2ssnI&1;aS`|z-&9J&Bf}f%1`$y&|55o#(e~TSoWEk8ZWhS=D|ELTiab_ zHE$as6*M|7Xp~AcLUs(N(X&z-bsUb22nY8f2Q-!`pbg|Cs^B@yq@ChE$g)&TWBhP= z!^oNIww1)XoL-i7>!4l7HM=f#m%`%0<@KlQa@twe-GXXi8+oCLdK!||tWYZz7_DN% zykW>as)=p}@-Q$PK!@2xbQG}j`{&t1m!?+4lV{g^ZHmUwk&tX_4t5;2I2E_gHO}aR z81H+;BN$kpMY)kU?>g2OK0tJ{O^C+;Rq{zg2s3`%CR;;t&{zl9;nW*8mQFh+Dl^k# z_ltEwHOsnyxhR0FF`refEYf6Mf|yn|&w~4E^<QXRiw}L4^bYHGH9z+s_|W-rczozW zpXa@PJo>yY%_?SpMVmLx7cjX;Q*5fuH=`wzH31q6AM_|6ytX3c<Y9WJ6QX3h&Eve4 zE8s%3p$*s=i{o2|+r6eahj(OTWJV-)UlERC;iu%d3fW-6b?c%j(p=}PvLe~x=cSga zO_bvxf4EyAD(rT*!so%;TSG1^B$cmmy1I{+9Bkrm4A*UlC3(|zhl;o(O%=@%xFe90 z1a3@*X9GijaO2B82hhaRU+I1$LT#AHEN~Zoh~CC<^^njlJ-FMX9r6d*Yl?HC8}Z7* zbaWim+cCS;9-#+xlk~9<nx`}!iQizTo}qqR*(LkL2WOM!ts(2q2_Kck=UvC%gpUfc zBZd3C(FBt$aW6+VA`ft-QiEC3$L)qBQl)2#yQ9tfLi*+}8n;ownOT(U%I|k4*r-*` z{%$=Qdo(J~5^6v_S|EfVZ%-ACE)CEFOec&CTR1hvTf_AuHH>&!;MJLEX~Am?26GIg zITu0;bYrJ@!bKY55I%@Diy&S(jv*Iew4cC{+rb_j@qRAQ=-y_fr$Fa)<0*7b#jYc2 z;Egb8o{hMY&e@17e2h@By|E<)+k<O6A6&Pw9c<|z(-2aL8aFmeLlV*WPpB6SzoR`o z_}Qdw=ps`5hcqPhR&?FC3Ju9q<c*aN4F~z)RWJPt-oSk%8rpOV4dDUD{iRNgGOh{c zl^`2l(GkY@GZMP#r`x>n)1~_9;nFDQaH5}0Z=@f*MT%|%`IriBv6yvGTEx2-1k2^G zP>=H}VhUQmtq<+Z{nJ_ee$-1l*)WQqq$I{EnCKcHD-sP+hpmanN`rG&leFp7wnU7r z<5J(9?+}6>Kjhy_h!2Ski3tydK^80r(a8#2wFQXtb6QGSr1zu1a=p@^*(6M4%MA&} z3)liZ<XCbN#=%6wYyo1}RhBt_@=c(ZLNcLut?-Kxv$*vf9wQO&qa{W%OIm>U@sHy{ zZg1Kjg=H+!5i|ZI?AgaXv=jF1tPuGs)}_gle`sAcXKlIdSrG%`@1zC4t<tl2Cnq|` zB}U`rY77J^G{D@?;qb#l=@ol&AlT-x*Zg6yEh;K16T_%MNxYmQBoxT)2#&LxhLEWO z=dDAh5(GJEc&XjSCWM=5$OquTrv5j&Zdxl>u{cvx$)cygVypbz7Fij-R%f7T>xy$I z_V8^s=i6;;FkA5dkj~$G(HSyG`W8K>n)f4kq|YDt5w1dM+>^G(c$H>YyYHpIZwFh3 zY-LCVPU03(NI6lU4cL_wJkZclyoqds6lgw@YJH<K(x4o8#Z)Ve^~!(L0Y13yz*_C4 z=baHm+}5d)s3^c}7zss@I?Yujr*;cBwVOrRs*sqz>@4>Wc$$Z8ShK&A5Ul>|E5mV( zAg0U;TIOW=GLQLY3EpXxdE#vAr2~+8W(?QQZoNcsg!&<Ti}Zm1I)*Fmj@|2QA?tfY zxcx&m-Ew&l8PL%?-aMs|WYzo^{-FZsTi=U#X#wd%(7B-tZIP}Z1~=F_ution<*`83 zLihv&_+Z=6C`>b%g+V)k_W`pf0gj4CVKTe~?${xuu{k0G6WVAXNoG1}C*b2M*jH)7 zAA@$ESyC_T3EgA{Mk_dnmlU>CY<M1YDJv6$oMZ5`gd(PjksOMSJSw!9@q?d51VzY) zN>NY9e)tv!1GGr;Q^?f+H&*V7VkL?UV(WBI&WXTxB%QSd->p&udx$in+zhfQe9-k6 z7CyMzF^!Ati{@}nPfssSFNT33Fz4ZV5AJ#_?Qg+->#S+ydvD!JMx?iS)bZ4Eb<Aet ziZou=Kf%6b%a$Emc5L4^Jj*--ckCYh5Q*kRK4-9vZDjMMUe4~`=tErlpbaez_nT%& zHYIgvsKA%BG_FesTL0jMFX?F-rg`D*Z5CNr6*e1>1M$b<4{6L}sYGFuw+dWa)bB;k zOe1~SdiJ=nM#9`FU)-{@WF7t)ZyttEX-2cy#R}vQX>P<#-{g%O+s$&NdnC;IEo=#1 zY8F8q2qL4%hRl{fA)<$Y-M$IPDdZ0Dm^pvzbH#ndwBDYigJz~B<Gv<|c}SFfk(fYp zpD~n~53;c&q2VH9mZmupiM*3YrNKQ7563vzFzkkVngXBXzil%JzZANsy-nG0GxT`O zD5Jf|87U(egBxRYNJ2!|G~0Cebf6M~5kN<iTcUZBJNO~FP=Fg!=<^Nl<6U~eHk|gt zpWHbhI~%4VZV$T;z1-Dkh=3?2$(DQzwIYS7P8j$!P-qm1L`>U)yT+5o0k>S1$h?5h z_Dih%4`JW)J#Odt>}*(yUTEE%$cxm}NbC`TJv{zfwE`p95Rp^3cmW==%<W6uzeZm! z?b7JWZTJ|gKdCqRo53xRsk0h-p$k4d;1>9s&5fa45qEA(!w*>N4ebffxd@nNHH?8( z(Y!a^3o`OCd)E3F*4k_1vXA30;M&@-7P7CCvwZ|Q%_|n*_}l<RRh2R1L4ivggIzoa z8yFav5SW0mrIBGacU;kqRi72I%}z8VSdn+Vdm4G6!UC|m=UBzs<oP!}BwkQsGC`bw z92O53i-Q--jNuqv$#ow~j?fN<d|UFKrMTgSnG=O<(P-!+3Yz6JcthMk(_Y+c$H3Lh z7L8|&S<1uZ^Fnv!c?Nwry>>7^{1m*GX6H<fX4QC%SS+|isR-sPH;rHL1X{|m3)O^! zCDP0Xpd6?5LgrfF-zH^3=Kc?PLMlVASE^CNUBR;MyOJ-z4tS?KV^WfXg90e`N|B=c zb=-T04T-Yuh+rHT2Q;mvnGi%x#CWQaFhNOK@y>YqhnN^WwV8i9!U>uOrUj;^h2!uz z(LtANyyYw0X9rls+4V)=Y>DnvQldCKNFt2;gXfOAbHZbVhzMDVL6ryunIRkghSR{R zSQXPvAZg*A;?0A(tWCn3^?|K~a84rLLT@3`Q&>H0xa*zaiE+`$6^aOl9AJtA4B$pL z-JN!#z(564$gCE^ib65u6$g-TipM)Me7=IcIkm}WNN;4YKojC)W6)$KGA%p{X)1Wr z8=gQf+l?BJU-El(uYj##WW%qNM-m$qj_GV6!DwwNgNXndVAQBM09q48R(!q2TwOBx zrmbs_w%MZdqqiB^#_T0y3!N{LgXn;<EcJtqkAr6#Ju^twr=`-%2EV`zgnpZf`q=Pr zB&$U7r;PNH6xVk3sGwsCoiBQK@O_pV>*?K$2gxL)^Z^AlF-NE&iYB&WBS_$6-;Hpp zCRXOVl0ch<hPmHO(zTb1d_Vq%!JkR~H>o%B$6)XKJ22IVJSIqmk)eIST_V?lEs>sv zq%!k1D}#`|PHz_GrbL8chy@D?4R3?gC-H8{n{DHWS2!;H&Gmb+dMVqP;SoX<fh6Y) z&n5)KW@e%%{@B*FS6yy7dk!bgez8&C6izX2-3_dw&S-?xJOxG(8Ud#+;B?(D&$OI5 zhm)<BoW>@~qqD$?IG+qPg~_z48`6aEFomzf&$B6<a$j`^$woA(!-?v?CrS|^Tmwp^ zZ5BZ6B+e2&5xH+Bg=CEhBYOhAnN%kf4FM(YH>-dm-~*gkqgnW%1AgWD!gG#VBfU|g z1A2qnvZjjceh#FE-gwfQ&|4Yp3nSLQ-}M5;9U%@BByE7Hz{C|qaL55#*nN<mM-un~ zR_Ir0#5<ffMQ&!D93pb&eDX2DLEuaHq$nrPD+d!3R$|TkOHV!?4p24y&YUkrjJJ-> zfZrJ}WYf4Vp!LMupn~{Ba>F1bp+MnQ5!|l57@@%5ghsg8dW_YqCmv`5cVYsKTt%RJ z2IP<z<Y}oU++b2czZBO4nB~XwP8#9n_h2*0x8~r++-9u{PDUd|+6QiE(E!^m-}req z+TG&3>scq*-N++MPKbqB=>t8K2h-swYtxZS=mkC{LdM6LD2O~le(u7T+6X@~@$N+j zGt?Pyow=E)IxHU@`YR%I6h8#BG{MA2hkb<Tt49&<NF+l!ecAek(O3iLl#bYa8V(Cx z$*sCFwrPHKuXBQrK${_SN<0|u+}&By8_+5LEO(dNNM`P?h|zO>(h`@RRjlv`J%yzK z4a5TB3hH}B`>pG6c!Vx#foCg5vpq!9DKnBVY7BKx=)MgO9s^enay~HmqPf)K#Kgq> z#C$xbWUBj_wiSm{=#myVw=SASnV*)`i7s$*Q;hy9P&Zwk<eGrLH_^%h|1K6Ta(KaD zAUe3rCyTk!qhZP66|nlzS{7J$E#|R);vKb$!nq~~c}}$&VvTYrD6kF8VF(HNqYbyn zpVs2-f}T?&^>_A3O_4QNTe6y*6dxC?L9&5KVN5pGEWrxW+y#deMTcG|v!cRQE%S59 za~c~R7Q)iyG#=Eze(<#`-L=LX8z9Kv;(s6qpuMv!(9AcHB}iRVHj-A24cvJgPzucK z5-<!IkfD*N-sAyqE|Yd?!!0t2;{v(yrLo~ExD*v~U4lVr5wS~w4b&SvRUT~GlzQW0 zH~qieU3-=8LQe5~A&v{)(=I{=lALP9gGOmd&iFVk2I;x>#U++dp$Y*04&q$^T^i+- zpi8~<8syXn=TPpo(wk66g~v)11xdE)UMNvG#)1+hk`}<bZ6y(R?-Q?b8tI(BJb1xB zs6>(mNSZIAF-_>Cf=&?c7~pL3o-ckRynrDoW!PgJ^y?i$CmTod1q~&L573u?6xl$z z2wA~4R`DWv!jaHo;qYr3cZKq14&Vw4&rQdF+%Y@sp`6yv(LLdN3^DhJK+Y5}x%wWB zfmbtf#)Cc0?ZRm#aN#}@3ocuvL-3Ix)>_mm4?Yt2Zs2FrE8-Pv705LP>MTfwMF_08 zOU67q;Ps0aUhrr3vr`nncQ-hM?3!JN$JFN_xp%Kw{Jb_KTA?m%hxU?ZKS8U7Y%}se z$2dm`%=}c$BBI;svyF<%FHiob2R|wZYnuO=mzUQ*uRW@{1j6o`BkYeJ8+|?d3py@j z8UNe;qj^EvU*8`-z9#rXu3QHnA9MycW#x*3RwPb*4nUX5B=TelG!iymU@7#eajq>* zal{_#|9B5CUiIFC-#PvUS@^VG+Ksue@Z}Nb*mO5Gpk!k_ncL{i#gl=JnT-%;;Tmzj zmD9Szi)N4^<xwPw|7<7saRC*mYdn#PKf9hA=)G5t>waDXjeDL$vIO1Qxh=UDb`4%{ zDh-2u$0}el>0Mxk@X~0B=t3f1%zWhrI^2YfMiUH3yU2^lcWvV}%~(I5)*mX?myR3j z$esv<de17L;M%&-5m6<lVw(Z00#(k)fhKnYOv`G#SeR+V5SE6r7(?j=p<#Z!zA4A( z&=h`YA$t|V4zVB(zn>I_>m|dKr~VdFt(g!l5OCnlr~FymDVk@7nYEB$q@tk6G89gP z(3DVwQxKAh7WN=e;{_C;Q@&B!6gO$1^c7Bim(vl*9C92Qw8&<?XB*^G5r&w7;(*cQ zr`Q$0S}Upn_y+=4itq6Z##kFX9%YR`#Edq?Q~u&FDUue;SZq!#a)8rNRMU8Pfhp!& z37?$S-p2X5k^a!PKLKCEmk=Eh3cfbEK=!<l@E5yzL7XB6e32%~YiqD$Occ^@J?G`1 zhnda`Z^}(Nf0yAB^6-Kjq;()(02fGT<p&#qu8$4r33Oc61NswQ5H(1=R?kv{w38(= zUaQxbG0Id+J(AjNX<2iXNv-l}B4=u{r80@*#q%45uR4`@oN_)<KXPpnP4-PhHgGnw zfl<YVYzS)}rG|~0&jhA3_0HLZ*P4QIA}mK|$#E5V5*A!%Nd|muupuq@!R|GS1)HlE zvs7AnY+sI#@MBx>nKf8xHq+G1U~N8Ilf&%xB?<cQ+y@KHTUl4+K0vZ@OThxTT;b<q zk~AesVj^Q?k>nz=J}t#0jDw6}oROdlkKcLlu%WleX3WPyOa%Mc&;-p&5~ae=F7pgx zO*1oyo6^E<q-1d993sb6;I@HewgtEC>?PF4LtnC>#r+VFswf#lZ72r9QB7!*D!7uO zmU-EkSL3z8w2uX+?JQPWDpfeUc%wrXi3b3wI*o@yqPS-6&086$!Eef2LVvd4vWs<Z zrk1bK_-YOdG`&l=R6Clre1a}qN4DUw3sR@qj9|zCBr^-Uz9}`J8q<5gZwB29W2pA6 zuwyK+?~o<vJIETh(4jC9T6Pw?Qs8z{hLR5v$W-M=hUfrebn#8@5`N26W4P8%ZSO;e z9ZD@^zl9EkiEu3;)Rl$*$_A}flq`7PZE~ga_a;<F6vFGipij1Kqm9>XCX!rfM{g(m z=)a+E6Y`S$ExJ7_5~-!gDaAA6R*n@sGDy2Zdeu~ncP0lqdHYaqOlCwRI+jq!3OXw& z2;D?%pPv;RwtW35;2OkxX??rHvOZPcDGod3uE8<F5P3ijo1#jSdA*xW!&brWt%&Mj zv=#kD$|&{|HJluu48o^_xt|1lOzQ}7fhLul(54#8QSlQXBTuDcbU!#ii>f)fn4x_{ z?l$-FTXMp;NH@X9k8>j*lB#><a4V<<hu0OVjwnxnGutOSJS>coxP`tc@Zhzs7Cfd( z`^EieiUGI8IN0D~92yvIgcSiw<0cHue97MMP3^Fy6L0bSUTPFU_T5CRkC;DPqM9F* zC9Dc6C~7T&29)yZw(bzXfZE63W4N}=`PqzxhlK>ATstU~x|aC4ZRO$cDSWJPpTcmW z3F3x)uLSrMDxFTm;F0RzbgxD$k9GqKL!>lrMvYOZ`+*leJRW4hXB#VH3;zfoh%TOC zdKG+7>3datcn*UFpKa3j$YJ;cd_2is&@`LkL&!A2huc&ZeCnljY&gC6kzv8mncP%T ztV)wN!DuT}acVp}h8fcl;h`8&ZITMw6L^}_N%$2!c)=#<6-h6r*wIZZrP2DZ@&}1g z?$&CGAG}%uK_M3^Ab0i%|3U@v#B#wCN?-UFYMrC;<jOJ85lCspm9M~kgygK1bQB8e zwWzuXko*IXa3ZOgn2llXl3jBkcLK6j^ict?*alJ2TA;0KdKygvjElwY{9oaLTrTy( zT=fSvUh~(B_P<f=FONf=#&YM9MDS!Zf~1|9td`_wDRx^+m?)Irj{F8(hX5L6Y(vrG zC@Cl?unHxe0hOWt5Kh`)Bspl&l^C``C7;M@<srq69pK7hJ$rQP>g>{?vSVeN)`jhh z+UMqEW~3&^BX|}b8WeyczXG`+Oyt1!Y}lpE5$DsB;9F_lnOAW>^PC~k5wa#D*Fi%p z7a*D1e>!d{q6fI7GC2S>O-BB!EThE?rNZL!@Ze^)=PM)$Q`!zFMxWyRyuKXabiiSg zkEpxpi|pG_r}ol5CYjNfV7kSGDFy3-LjZ~{0Wd%YirFQ^fRI3roM)ACo@HeQ861>s z4Vg-5E`SFHq`5Pi7La!+hIZqQ6vR;t$S9gSg#Ey~S?odDkDX{(*f0$pXA|N=LlBb{ zb1VNR-+Jb4VBI2G_lQ_mTG6l_z30M1?Z_^s`+(Rg{QY0j{w?Xd2RObJ(l1gv_KyM4 zY>K(R`7QTlS-!1fo1kwr|1I|qS-#yOy^9<m;Dykr&$=R(W%+iev>(m597l4JntZFh z=>;#M6-yE%Oh=E8jphKWI50PEdbQWLsJBK2*E0ILMS5a1Elpo@J(r(_zTNwK^h_Ft z4l9@#Sb!gh1JT6#6O7h;HWkip0-fDnes&Al4D3xa<NZ}}#t`Xhi8y1Jc3EtndB!i{ zj4?MZ3Q66Z7UDa8zLxLm*d&~9)9?7%TE5$YN^&sd;lya~_4rwNzQbAdP9O@z#b94h z7O)0^^R^54f(X6?fDg5+ZxeJOfw1@m|4D#PeokwIPkdK5i=eZ92XP=@6uv>cc<%MK zJV?-?1-E;>hKu;_f}kb-B)+41(rVOyI*x>g24inG?_qCkjo=ZE%VYcucS>)AN9>35 z(-7z6xbS&E0>+87=HupBzr%SnB{3${;o)cT?MFm!%eQrGjuejloBNj6URb`}B7v6p zHY2IYx_XGux;v$t(Cp4}q%f<=x5BUKSr;@K5<wh_oO2Ga$<KTSj`kI;OL{DO%Eaw5 zG(z;XOo}kiKzw)J=es(#5$D?UyMOz9w?%q~dQgFXz1Mro>pQ@BJ@r)2NK3)Kf{&uX z=exvv6HV|v%i*iTeWSU5anV6GK_ek^4%2#;`#wurjc9@6h`7RTx{Es*=kx7W>7+Cr z-}=ZW*b=jaEVZn=L!s`>kRz#9Il|}4X<WCRK(LCtOR%N_)-=!E72jQ<{Vm^Zk?zE; zp?RI|J1)NCXKDFv8zb!;XYRe8;0?=n^%B)QV{WBqJ%}XrUg5jMC~@&FKu;-%0wziE z=Bt3aD`W;g%S!r=WD9B)N2yqiZn)*{swFx<N6&X;!|%d5HkB<u626x2wz0N|j(Aq2 zeT`Z^)6V<59juVcpcZLfGDzTIS+5>*bfd6doJUsC`7P2K&-r1_J6oik{G3~)I~2h? z{5w6xLl5!YR_T6e4%W*|^ZHI}q=)!!8*9($k<s{_t6rr!cy9Xg@8I*EWUR${xtZ?u zNd9aPGL7T0U%<ywIKEjaVI<Y?p8o(zc2>wKk4%FP>qe4NDN&8G@89^RCp1ns&v%qB zISF?F^E!mo#W|xRt9(q*Etu#lWbW37iE37vTZvr3K*9SQKKc%|j0`b5+Buf*EcgYo zzLCCSy=~=0U2|9d7Sde2W!lelF67T-i1TxsmO`)g!$~o2`sTZK@OgLmj{MT>Abp4P zn`zvQ@3K-u#kp`kjn+Q!@YNxFr%QE{Lh)5ZsD)3FcR_RQ+<ZmfVLj;=V>7;tjd1Tv zeBaD>=oi1_&%cwl$(pM(z6%#Si*wP|Sl%}AzSOa&`P-Wi>waG<T|4+JJ2!m%JK*~P z$2T>>^BsS$c<h1GL#$UXea`tlG0y#+c!M4xd@b^S)?^p%xe)$Bw({@vFt6|E{_dB? z<I85=DqZ&Zc9-;s#9x&x6r<A<<k5RzhpUH$+|D2x-pgrS$A&;|JC3x>%}#|k+0+3t zKp&b{40s#A1^z=pAIFj6mR{e|x;n4%X#5u5sa1f(aimqA^;<rlPUH47Kd&cE7&^gz z#{1qP(NEle@!e(G-}4>Scp|s_aA7Y0it}$JbTgWFXZ_BGct#)4+J3medp%(fTGp$d z9*M77TGlH9-ZZ}s>sj>a^{mF^OSe9a{&MOA0_Vo>fb-qJ*?u?@qwWPB{EZg59+tO! zr}VG{iE_9o+xzW(lJ>QHHw*8NhVSU@wXPTM^W9eIganhsS2xgy_<XmW4T5zF`eBR| zf6e(B3K;!;zTG9gkFMyBBPjh8FTeQK7{=%GdBeGbZRO`(l<S5w48F29Lau}nuN~!d z-oj87K={O=F$ve>gf7A5k42ZDcUQ<Cw=N;RJ5DfqzJqSkHVzOb!X7}rCSPv==n^3K zYXI&0H<P~#IDdr&!#QL5j{7|<-))2IrZwOT_5M!qjpsYO&o#t1;jr1Tn&88RZ|!%v z`4DbW&e!ZobvBpF-HP0N-2(DrlRlpC@boj#rG4R2lWqn!)ke)(-CimcaWJ2bz~lp< ze!Ao~f*sTVpNE#9Po%Z6D|(SmBw4=C_&}1SJ)(zdKx3JgToLaK4q$#NqGf)(MX6FT zLVQ*1Q&?wLb$dTJIeB@VAN(Tj9GS*WrSZ-Z-yfkN@1OM>Mc%bfi7DYR8oYCjKEZ=W zu8GGP82j*h($F2%CM5+^TN|5q5eQBTNhzp8CeM*i1qf0hc>xGNF4_maJNXyOdF7e= ze2nu#uS1A#MH0F9!d;9kQ~Y0^G+ksLndJ;v>kH(tEf;j<XJ3S&S~&ZLDfnN=%SDQq ztoB1rQ#0)+J*j5|6XLzv<N8<+?j1~+PBpkF_YA&LI7-lkU6wRY>pnQJC>;@AUMLkj zli1r?>Tcaf>%WXoZ5B8Wn{ajooW;(9U_glIHFB#Zy&t6}@uGqVUf9AAVdgnkV7sWS z(CBP8-#v{!+^6*o0%rJ9p5u4!p@!0i(*$!!uuYL<bmEraOM(1WP#Z*9xgv9nJEgfd zl$l9m+_gnX@}}>E>h`ovB1X|dQgm3;99B<z48RMlkrG7sH*-tqj(GC6uvVm4t1YdC zH<98TVWB+t47GT{GEY21ikw+@gN!pB2f^Wl*}zXAGE!z)87WDTiIE90Q9%JLLJmi! z7Gz*s$RAG~E7s4(`pDa`UOS(AVqPn_k(%Br90hMpi<8FM+|Mmw?@h47&rP*0ZqF%B z*XqCIo>_9>0dg?9$FJ>ilzM7g0CQu0E!NG&_vpRTe5Dn3Y3_1~tA$eroMqT<y@0cf z;DmINlAQ_eG8UdsjsFX9iNg$&6SyA-a5UBf;CHYIDNpa}bpTg^gp&U)^tO$#(7OO@ zqRUcDbZ`)AO%*u_0VnD~Yll}4`P1-YDAH71R`i_3ZRJs*NDv{)-TTt_tO~IndSdxx z@uD-9PwK9jw5z%Ej(LuzsO3XKs!o19DajcRza{4}I4{jCRk%4RgOV3I3I5VNxzPAs zu{a~Jtt!!lP{F>G2M#8Nca>bFlorC77a1p*!x9@APD2@3m>jB`xrIEZL7Y(z!O{k6 zqMxuQm&H4E!DJ~jb-|OgK->iQaG$gRVyz5X3o$FH$l2<TVmwx1MWV`G(*+A%(w2y| zQfaOBSS!z&L%AjJD}pU3KVM<!J-{j;U3ktR2Md+_QM3x=-D}{*|C{}dIexZ4l69o( znlZWmd$FwX$eY@T_$JmLPwNZ)cpux)@S}u$?ga2`4*KB-V-$x(feRr{Av~19puM6* zgKZ&x2UFP-5^xzqpUQ&#+_V&AbtGnHWM()-|G8le->BKbXF81b5&GFawiw;7$2x10 z5O+goLR$c07ud$T&fe2W99{Ed6gHFSq5@@jz@ZSB$w#P2r@Y)8IF6DN;zEM_9bmdV zIggt6fi8wIP8}@p1ckCB;X~TT_5e@hQ2{>*qqp#;ks-?8ba0`G7qzC*G-Mtr3d-FW zqqZjK3Xq&04*V!m2R@9%n{-g<zmc>)y-Cosmi>!*lzF{Kh`b;QLJ=3AR|qc<Qe?4K z7-%v|yl<q-O0V#>9x6CZ+DHP*L-7D1c#IG-a*ZU1=I6i&jK;29l#wICeP;R^&Lxjj zH{9#UbTifqnTr|EJU*T)DY|qAc)g9Ygl@C~iUuPH8XXl%S;{KtVUfVWAUMxY4iCkp z@W?%$w=MF8yU=<ROd|QxT<*J7zLXiYTBd-5%kFvj9b`dtR3r**6gfW5#t_4%+%SG# zv>Y)UYSWSW#kz(g?KYg!@ree>z-g{nE16&zj<t}_AA+(j8N{GtgPd|lr*TC5@`i^; zMBws*M~;DpFKTc2=oM2NN?@y_yP=hef2L1>mLe9-X(`sU&~j?acnMiR-n9Hf8hYqQ zN(yildGg%e^5n@w|6?;7{>5t;+$CPkoxeu`^za&A#{(a&a~;+J9lRlg+5>5<k7&YS zCT~%MA8SrRd~k@k3zLX{kK@>}ro0ww;;td|1_A2MfN+ZxKi!j_pjIQ=ucFr!W8mCe z)`GRj0Oy8hIRu^YCSnExmx;VS2RaYd|9{@6Un<AG>qI?4IpHOIb#-h4>ItB~&=U;( zo$5pBO@ttmS*=?`2CumTtY&sUf~x%XFp)0~UwsSWi5AF1gHfwu1soBCF5-VzPoU;$ zwjp{X#>8cdF>#i0Y1yGA(e4@3*?g{ASuvbjw||_KwSLf|8_aoW2aGRApHI%;G<wle zbE;bYg$G&080FK~VlpNTbdOA%HI5a&lTk2!kQk}<=s9Kb5YYO6seAoje<!J?b+vfA zlj!avff2O?ftD&(cbaDmjul!DGCP};uEx?o0`Z`b`TVmHPJc*MQK{<Dskr{Ae?jts z^C9#{@L?T0&(cT-{{uY|PYf?JvB*`@|J<Cx%SnX}o&!5?IwIxRgXe#K%=g&J;*gVv zT!yR^<j9$+GXICXcLA@exElWV%s!XooRb?6t`Y))AYdSOKv6?NxF~`MsGzSJA&>|p z6oPnbt=8VHwYF9()T&iVZ7a0(wQ6g%7PQuudaqi%6g5UYN-)}s)|~%u&CEGD2?2fk z_5Ggbd;Z2@_C9;>S(lkvvu4ejH9pJg%Ey6L5r`W%Ieb9a*)G!yBAkSov4w+YT1^vC znB1>BYSgI7qb3tuV<4vxRpBg0o&LWx|1o{i*85DUclxA^xc&FVK7CMnV49x$zc!Dm zXTFnf>#$zr#<Q*t&!Y~B988>)P>_K7M3)$Xe_$?$RAk_P=xYg{(96dXKdUow;}gx( zZ8I+_LLDJE3elV<9a*f#sKTN7)06&{w9o(5xyb+NyzSqelThcOytF$1sjYL_yp5v? zd#TZ4Gyyv_GBj1?qV;1zVXBs1=l}7!jfqWY=UJ7~9>;+jQoRtVJ`j6ax>T2~vjjO$ z?VfPa8yNRYfS)`wrIhjXKRI6-{eM2kvGMq=u4n85GT+A^F&Wp=ox_k4J<0g;sra2@ z(PLYk1WjPJDbYLo#IF>Gbm*pi^u)=6mvexF?`AT76TC!Umni1whygQ=Wkw(hkJwKr zS;AEH4N;Zc-^M<h;L+AjzEt|;+pbSW@jWJP<(MPrlT7>aablBsAH6X<*&BOplQi8? zyeduW8Zknt5few??L4-qumB-FEI+^4bjOs=_HXFO6Ic_y)_!N~QK!HM>|8@dE$|2# z5DesT79Mld0ielVHJOFW{1gor4<R!NaC4V&#VDpOP_{DsmA%LXUR_Pi091W6YtdYK z2d+%Tb`-AK()29l4a37MH#?I)=M|`ea85sm;SNci94n{c9<$&q!e|7#?|ZlV1C{m9 z&plQjc)N6P&4f!<oz?3&+y!&GU;5#|VfH{=W9v5lqE@db;zmef2z$i&=;a}*YZ<qD z`-F-^Xlia>i0<|kTSlRjA$!&jH@DBh5xdXa-nPe}SrcIHkc`XszZ?G@o15PmH2wrL z1m+t~$2b;i1-2?icWv!3={l#|RElq!6MwV>t6La%-=wXoLG}<P_nyHM`h>`;<Swan zS=CDerI+>W^s*bhQnCtNTyM1N)Z>NEC)&EQkxOVnDE<dWdcm+we3E2c{iox>Ctm74 zQN@#M=ioFSoJwm-dZLIxshEeM%CHP>IR%Nh(<Xe1otM+@aH)J*bTN)LD)!!Sb@40K zda&shWwSmIBv1^SoyUwW7&$a30a}<l%g@Wx9QZ^;F%6}EVq6bo5mOh3QX)YnV?~+v zZhafl{G+#eU!v6l2c0hz?A7@3VPz*qFS&G3Z%8S6(k<8-j(oNL>l1~ZH2?KlUC4P! z*aA|X<-I0rA$(_-^>JIzvtH}YJ})+C{ML<LoaVP)t61d}Nz=PrSvTo%R8Jk!)7x8p z<Pmu&Yo_tKxS$sIF@12~sDHy;>=3x4bc@sGC&As+aT@L$^<?V!V{lKMxAVzxH}lst zzBj3D_>U9Ypf`WaHUWDc<iVUT9EDxLGT-sV^4{1m((rFm1F>P?o8G(ZUc65~jixsR zvImJXCzCahihXBolcxQo*(PgMG3^IB4rhav1(d#C_Px%0vU>!K4_#UxsAU~{pw~~_ zc=m!M!|C@K1^UE||Ek}qPC*vPS;kx=4Kk4iLu&~3O{cHrS}o!tn~ram31r;9GLWNh za^G;xHv!%oSu-4`5&1~^vRWhxrui%{dFIAuWcRnNp2}r$V7SPOz;N{;Ul-RD83UtP z<BHWufFw<112g1Mr{=%pde=9JiF9S~18M6>SI*fqa%W3o0j5g$EHRM+evdTsWnBgn zqi&KJ<-rn7cA1#t=Y+On{3q09jyA6SkZK0Iyc%Sg_So->o7AjfYJ}0p%zVPyKg@iW zwGEl?>YM3voX~stH4ZVWif482wGPfMG^-tkRKZ93^(jFUPu%nk*4GV;?-SRB_FEZY zEjHj)lw<5=N7?9+CUz3E))K|i9d{){RRk>RWlo)G$wX6_K5bC`xS`|n#}*Ap#jixK z>RIQ5udMR{>lTHtmB2dOdSCMFRJ#a(?w8sTN;LRBr=}Vm=7jE+z|5r13@mhJ11lQ_ zALfjvr0&d-spjm{ln$L91HX>_J?RnQKjw_4#9R~qWJjt!u@;0c)KlHhc+ZMnIld4R z)<_01U0bY(*C&SsV)nyw8f3+{zXhXVX$ONyo5D3L7AleQxh(ePn)1J?KY*_iF+B^* z*mz78$Ih5Ot*WxDboel>VjLdM@nI5hR3>hN>rC7=K3o(*#T0{fR+OE8S)o~M?>lbf zamO4zwOU%iqzOfAj$m6>-oV@<S@?7C8+ya{#(Q%GK0IH5mx$PgPOY6jA&ZVOv*y?t z)m5@CXRzSx1A|3&Cb4h^*Tuq&=wK1$Tv)*(C(B}SJQz%yD#vn7K5G0p8Jc?IKwtU4 zdQPjgF&J5#W@BK?MHbUH4`E(F;MtXIiMf<!R!~ZI20C*>YTv1uk6B$bP5-U^UprgM z%+ahKkv2!GRg=9jvJQRF^bBg;I6y2sp(iyjv$5vfd@Mx|w#(2qE1%8U!=1DX<^&wa zB-#~0*>dH$NLC!tTE(`TT0uT?!muMnTNQcLJtkCb`}IhVk>L@_V10Hhi!(*T24^t; z@<qG!G}B?}Jl-M%AeiY{<HipeIye;*g>gH0X4sQHBjdIjY})D%yb3iybn-!BEHL8} z<zW+Mvk=P#Y*@50b;KZVmT*nn7`6)y96ffBac2-52hkQU3uQ~$gQV;slpXSZ@OYv4 z01eF&4~Dd&dzK;0(4iJf;bvl;Dtw$PoU)JaJ~4BIrJvCvdFIg>flJ^6bu?`%opdDL z9pi8#F>1EAh`m=*HAzXrQV#PK7pxHFbi6DNrN)E0?h_+(lIzx#Z)BBsMsPdj)2@@{ zhg|t7>BJIV$jo}|-krn3sOr9!*mS#vKUMI@`?K(#C_%H?8FO1rHjyuhl^XUq8ytP! z9uisUG3Zl~L>*)+d@$5Ry!VVXa;jIDm_nSXr<@~;@m?~~lmkQxn10Y_q0CIIw1@bZ zG0mPV9hgO|0If<H^)QtbjV>HHLe`^M;XFzoWsWD4damvMy8mq8B%y;@R<Rd%bOaOs z5V^~~E0$<+WHNMEOwJMfL&0+n!h8sa9I(tP)j|bjWaMSAn1ARMRwH*S;p1PEwlCmg z`!amI3qD?L`4%Zm8Nx=?xSKFmF&x3<>`g3+$u$pa9b;o@T7VJU-?Ulz#YQ%wM$`|t zKw@7e0zT(+_x^+}Q#~w<h>#XJP4j|Zb=}t<d<G!(J`#K%tcfJggph>;i(GHRhzWj@ zvW~E!t;ak<_;oo!d`g-rC9KZE5hWb<z)+&5q(0=gq*Y}^O=;Q}SYuXw>?ed{AFNf; zn0^o1fX4r%f5h<avjcMj_0qnK9p-NO;Ad*GhY!nUwOEV9Mb=qfji7TNuw?N{JX}_Z z)<<_lv-ISgRbftluOMdZEB!uA7O-sDU4sT8gN*QmM&$Uv<^O}s&8Q167kbQG=^1IS z-d4SyxNGOvY@9PwXJ;KLu|;xG%u6$LrhnYAM^CS=Du+}#JhL`0M`y8x@ho(>n9h!! ziN2l7c@UnTxjc-})Qj1$EE@wO(l*%NT~nh}&BB_6C!IKNZhf6PUL8N<m}ygG=1;3E z9yCA{80f*?8y;wFlV;85EsK|W0^4Lu&6?U77OxS*^H?)2#d9GrZECqJakHEx;r!^# zEU_-fM<*)_86JyeFJ`A@3@-*uFN=*v%qf+a$i*Oj%rVEDaLfsFXV0qR#7u~*tN@*X zpu>F6;q&kEcLHPDb#~n&<$DT$5kmhzIdjU;Z|3=F^f!6GW}eU3)zAFG&hv?`vaCPP zLgwJ|pSTyM<}mh5u}7p0o4w9-AjbCpyXVi=(q5e&RqLSxu^(C1CJ(z0`4jCw?zQ(A z#})d9*?VmDjd=p=3Se=f*eBm}oRhxO7$x8AG|r-bvS46$8h_j_<6LoLlYVM-e6u#2 z=7;eAzq4ZM6K@8`hF+64D02@r%gC!H?=n>-^Q?SyVd9}{e*`+9O!C4KIY`>L#x$x? zVZ|US8pxoYb5ijoljWPk9FA)1;7t6=@&YFdYz~hIdEen@iSHpWWe7qMN&_NG7(+0& zxaA@T<WOrwrfj>9lxUm9QnvK1@DZ|VdoTpqz@I$tHARvf2izOlVMwA)*)b{BXH06+ z!?3Y%cHCixBMGFQm91hrD<<yFhaHHNnlrn8R$cAPnu7)*5&Fq7$oeg%jX_Q7V(f^- z7yys{h97f$l^cFQC6=`aoY>yq@5lr6<BvOb#xZ?H9j5WXufm_>(y-w}k4}!dJ=gM~ zw@%(yt0r0))=WP$V_EEAjXdc+hz_YaeqH<(`_roBASCdpO~n0Y?V3+Yr=|^jI9zJu za2j<Aa=KkLIWIuZNh;TZg+rnr??rPQli*?I_coqX+WfvnjaBvk*8E=199CnDyFh9_ zZ0Fl|O501DZ?|~6QQ{6i-;NzL-xiB;-}$z+QJC>CjRtJfjEDG|9@0j^j1;YgZoI6w z^Mg_o<s9rDN?iORONX(6r_s^m-AUW6tEuV7Zb0#=Lu7le=qi?Sto_?j<6s!y1=~LB zL^jxYX_I#^?UTJ67G<$;C#Si+Jgj9Dchg+z*7)+-zLxUklQI0?Ip0=nd+Y5SY%cOp zG4~gFSTKTB;(RufibRz7;6cA<)qGH$7@m_sE+hn#m574|<_yUl!ektGd1-?S=#wYf zv3G%#oln`Uwa_}`z@lZTLi$SBLzQQ6<q#s;+gx}kxT1eIan{;0(I3)rwu6Q_D#u}; z604}!eX#E>VUtwEju5$GXs|Y{1p*TqM5Y%^^@ygIq@+iZ%V|)KHGL&{ZqDK0OkrI5 zlWiYUfaAUDXgiMfv9#tC1<-7a1k^?{5~UXJ6~D>KE@G?`gT#bwx98fxYSV&@n*-w( zev!2Oyn)y~Wk#D?lc{A*_isU?4;p#(FH7J4VO~>B;{YPFu!RZVWtPHHs|2_^qrjcR zK&hBSEbAq&Bq$40)gg5v&T!ujh4MoPECZa5Cx(c@oQRW!i!Cv#i*!-){5a#cX62O` zKmKCqZ}FZ&UJ>KzAeS}JVZLZw)rh*r0;gLjKw>6c)#x+gqh|eT?fTF*X*;R)A@--& zzW+a49kOTtI{#sVv-K-Y!@0@(E%FI}zQf>b&2fjo+To2kj`nBq{?DIVY;iwP_>qSD z&BR3eINT9cpigY^gE?+uw+YYFaX0HwDV~SDn>m}Nzf+gRj+hMAeb8#Olq?I;DLWtj zn!%SX?@b)i7hQkp0)M>TM-|{4mz#qp4n_qWaYh$nwZt*p1aC?jLNRk{?@U>TWB-X+ zSeNNieif27WeY`42L}WV|79O7@o22f`8qV<_cN-%`1|-w;^o{MPprVQ&7qe5C-#jq zg{tK7*RuJ=#(^}!Roz%LMvYd5<HYX=3$c-#zznapvVhBC?-d*e#(R?jPg~gPQe;A7 z&AAiCjOIWToc}z1<oK~gv8dSvXypNCnXwNr3)f;VaAqhw7{jmtk-o2%h^2vf{P5ut z4b><!$cEx^g`<X#96mB{Sl-Y<66rH%?3f%8<08k;0H27}Yq>1;KIG@|-d6$_B=PZ% z5PZfPY(j8}g*Jyx3Wszl;qWo$);{=%#ZZI=?ofxuXY@z!_3XQ$PL38l)Pw#VL@gi= z<U#vy@Ty}eYOI+}ARaKwi?vsuBCU*tIGUXpTn7eZsfgH<<HpMVoDAzbUii^_J$^vI zT5e(KUwuMYtSEkBSm+3W8(CYWPf}GOkJ#g4aW`B3vT3xvPGCh(z*Z9sCjHoC4U?8G z(^9cnngv_xt`uH9VAm{4rTsqdc=ay$6R&zeURDg>90~u$j>0jFGNVzRBy>8zE&_(x z1ZPXm!o-U`(m;W2n1Myq4-C?jh!i|w_=MuIqegN@)3E&FJhP2Q+Ri-q*J=HzOzf}y z4*nS6%dBWnZVugY2sX(;SOcHVAn>8wUqo}Ijfja}mK3s>6>y}RyY2;EfRE#}KVqsT z&oG$KeSJS`wc8c&WevO^TT04;BCgi#Mo2Byino!qqKNc?rW3li1rA=D-LA5*>k*^) z<NO*4YLl6PqG?Ujq9%xYV<gSJQS|#hE{@3<#nwi)TiQsPjcA+ttE!QR=S3<rl%mb3 zZg$@(2i|eC3Ok_)HtvNo`!yHYbJ_Da(Z`sKto_8E%YM1QOWBLU-ZnLh{l4pK)*Yv! z8NKMG>XPF!CeMsW<{2JGSVjXGQQ7p&`I#V*qC9<3+MCsLF#GgrQ>)9%`fz}Q+2OsV z|3|&)SGTAUs#t6X!&NwvPQUCN4-sNH63&c-v5tr31j|)!5wrJpTozBPQwGA3puhzZ z^f1W?8iUk3{qqf$Zqj)XQn!5O74I`O7gwpwSYJ-WsOVT`6Fd)OWXb`ZPGd<jA{zA; zXPJ7JB@?p=(rr}BHf_Q_vo5d4&NzDd)auHLgIY#9Uv~E4%gx>?s$BRols)w6e4%0@ z8JTPc3&EdNh$t@-Iuu_bkv@FsX&{C#iL2qu%+NZ4jb+{XDumR{ckTB!*R)lrjOamp ziNwwm2Zcy9qlqA-oP695b0U$CXUMdva(KhR4aL@%Z7ciw@Z=^nNELeL)vV^6oXkkc za2@OEF^t=x%vfe9CP%#5o)h&VnbF7@US^hxg)@nS7{Gc!paT&`2;ej+QBY7YxnQy= z`GuoWjVIgL#HH=541KRp+qr4;3*HxNt~l;k9gWSc(%HTH5)lwHqS?`m>?RfiV$rPF z8Pa=wLXfBWQl84rjxP41QI!2ux5_n*C&vkt>C?qydiuQS^Td85eh~dMq5;YHp_XSR zE>Dkq;q>@?b)?u$3sfw6B-WDgoWM()%1E`TU~QR-)*#tJnHeDt?ZM$Cy+I|p7(*t+ zkO_{7>Fk@rZp?8-V+uvpGyRU>k+vSK3^K84QZgu{zIVZE-q&lcoUXF7>QppVt0Ga_ zTBKK73)jw9Sv54Vh_o>lms|&Q>_lEiBiT`wU!7#?-R64pQMh;lQ6+1RJC;S5e%f7L ziia}x*f_sQ9-=SZpa!UU2p~HKp*xNknoqpn6bF&kX-9-6n_rSq2-8SruR%%73@Kj8 zE=?<=WNZp{rMELQwi`AD4P+Ui+G;*kT~SIT;9i_!3(!GaN^(UafJT>^pujzi>|hBc zmbrczgM>1;*|zoTKK=1V_GQi&UF3+toY|Vj4mqMcnh_0W^mN9E7Y#=kNjUu%X7$^Q z^7AL)k&!<(e=M7n(i)PJ-!nrOrSk@b<HoiO?}D05Q_DDbv=2+r@v|~xStjZ!4XCG` zq`Dd^O6DRloo2@Ba!j|&cHPd7X0z&M)|4J!di=4+;JQ@NM^KptlN{4B=Jnyr_t}zv zt?YH~k1r9zd!Cb$QI;KNrg~K*5?zE$7|=^R9fC1QzTk(@dtCee#f!X8*Id*uU()(f zCg$U0|1pd}C}w0t7SmkP<@dkEoD^^B`|#$wDynA4=rVDFjzlXN^ovH~ESPFMXd$66 zCWamsMRKx;%MuPn2)>f+Q_*N_F{_=h$(;X^Cd%3PoIkE=T$M~m#urOtDjFbXV)CDO zjiq>|`|#|$E&uecuer8<mX2jDL?JkCnie^!14rV2WA?d(=;id}jB~t5AQ0)<Z<p<5 z#j>+fEo@-UfGDTM82kpOiS|6x#&TU7tEsWAtmfpJlTVm8cTVk0X=^h?#FzJJYlG7J zU`9b7es0C4I>WoDX7f0e6`O)2oeWERx4U5NG!?610W8e8o!%#r4v`o#Gz%pwi-Gd6 zeN)Dsqb5!m->ZM-q>Yg?Lnh{Jnw;Ny{y)8M)qJBy<z%0rVp;QG>%na@T)S9h*C5?2 z7jwK=W=`x3iB^1=emlVS+ul6299^_<!F&P;*B-L(4ovdX$a=G;mnQ4YnsrLnbFzAG zUg}zrZFJ$Y4%vknFr$%P@;*ObREu7WlMzzdqR4!EUPY2`$o#DrtWL@NOKL7Wm}hCK zdQ#FeE@s7+{tvscs1=9gQ&PrF>%OIDza%;$>sAIkqP0mp<4+KO#!Z|03qx~oj3#__ zuJ73k2D~{A-b{u`&Y?PZPng+Z8(Nx~TzxYhZ1ylWw>4}mUNe1{{!-_J*|l9WFH2k7 z-KM_8yliDn!&v4?Jv5?b_KsMQnkvQIR4I%i9rnbOdvMSlj1%JqkCW98nW32YJ2V8^ zf$_HteNOr|A|pxjHZ=zSq!l&iOkr-Aq#F!UQ$k{FF*^|RvDqA#GL$<G$U-X|7(H6n zS4WqQE)_#^(U`uRaO+=|59Z94G(OzqU8~OV*3>i&R#CjTGBQW0KpH=SwG&jN<`6uI z(ubpry@zAT_;F*$j2wZ4w(Jn=c8VW^d+~!9m{UfISIlUYnK22e%<iQWSAw;bDg!($ zBXG3JSZs%eP{{a8%eg|mcMdw{2y4nqr<9<16!m3HEE#txSQ0k#)*im7Tf7IEx2~#L zF#@U9t9_vO5Lz>qaUPN^cAm^2GtcY8pu;f)J$jTJg9=AdEyU<xVq<zZ)ZCjV>XtKK zl^IbnQa`PQpvx277Gp>xi~}h;eOSrVSz5_*T4oF*e{XI?ZBr3$utYlXNU4^Cx(p44 z*cne5e`hmaHFL)C#x8Vo;sfTZ@M9RW#$No0$&?Y1$h;BG$fOb0^zK9-#}7H1G`+_N zKN2mnXEf9z{4jXT0T1S`-|7^8jHO?s@q>ZyJmxP%jWaVGg*#=EAE>0v-#>;QqL}vE zacHZy-<Y{-TKl-k`=u%r>%!O~W{8tVFhlI&3i3NSJ?zbh<m@KOc?y})>}AQWLo3Qe zJL^xTu-j|Os3~HRW{D=f-54i%+n4YayQxpRxoPQ(-sLrya@JdBWO^|(=_I#A0kacn z8cvLvvufff0Xvg+EhvZee$%T4)!`2qNZK*+?O4KziXw6*PL!53@#u+1%d$Hg*86Qw zxYwlkXXdSG{QDkjgGYLwuep2_v&0F^5|2c;p>3hCa5#twDj2FQXNpME%D^CDtP!~G zQ>`@n;5o9!rSv(;>33?rc(|s<ai5dqn4DhC&8Rp%GRf?vNXcmCvZuBSA15-qu4H!2 zJT{ZImyzUVsP<SU*L1)PX>&cCOwOj00!!LpA6_nYycA9{2dS2mF8gnXIhKzyPTRR_ zl8=nlH+c8BxvPxV*!qtcHkcV?4;L9vq<0*)U%F{zf6Z@<Su^k3Jq^EP9A^hc+L$Ku zS+;D;OnN4xIery{0A(hf<dz(ApX5}MGj94Udj4TLsa<<GL?^ZLYvbD(-X-`<l`)o? zEtqWcmaF5%=V1g34QX-YnA1x%qJWRllPxixI4{XGgI0x=F)J(Uh^!-s(U?CV73&V0 zzrH4Pg_J*A%KwVUBX3(PyJXn8Md_)N$@?!GgSja?8jTK*4yWvaJ!MbrzO~2i)!`oU zwqF>N2ta9AD{Qz(d2Q8CTb_#~X~vN8-M94Y*`=Hl4UXHJA`+o7edjJlj9@@4-Nu%0 ztYu03WMDE;@I<zBe>=Fw`XHD-VSOXEt2fYFBsOKL7$YNkJ4P6{2)7=4eD}8lGm?7? zz-y7Io9${*?{dU@j9Ngwao+zdk6ZT&SB~}7Fm;@U&o=b}b<BRJNo>l4MIpQxIPA*{ z$j}&ITAA8QV4S&tfC#fIN_n^+vm%pRo3OE%OdY5EH>^!PaftFgDZf9w`z>GazdU?< zs?QjHVj~}-#!2~OWC0gHf`A;0n-M_G2xgcKTfy`Cr2!+8Jtf&Jic(*K{~Mf1MH@}w zFLv<P#9Jo4^bD#$Bgk%DsX=cQi)=Lg{>bPJLi)X|Pp=6ZIce6XEe$t&3sjlVKuoAG zG>E}WR%<wB5^9J7r68xjdKi$$nVhB$Pz`0=7n}8rP^-{j#(ilkVzWLVG^CeKWR*}j zz}CnBI|ZQOkY`=@2H|8qG^Ea{us%QPCRSHR$=cVXiOd13#^^{ux^kF(YjPH(ml4hs zZ8xeS!Egj88M9BjKbne*i>r&POQ+DqZT%Rh4p%=bLpS%SpPM$n<S`TN4=O++#D&9^ z#(@WT#GIGc)7flyaUoFq2i-%niCf&$cd#GlsqtnnpNeF1N@B(olu5YEO5b#qSwj_K znlVh4zO^ce24jsVpR!_faMu?T?C2s_tttDb?OR5#OlzCpyWn-9y|`cKR4oTn270JZ zfjwkh_Yd31v2b;Izmu_(fTnZJXeIKDF@mt?oL43iBoIorSter{VUd&v)5%FrX-!vn zY~)<<{q*`ZHr}v-BGL|znIx1R>KqJrYE(ZmuoocU%%KndFl=l^b7U;~mXW6$)nlBC zMf@_(r(#)v9g*T8MiUYTU0IXH$w0!;(sX1^+R8y1=!8^^JMpR7Y2&<$PnCDAE4P+7 z@9;+=_))g>3Wh#ha0xQafq|?wBRyP^W^QVZQ8I@ajidA;i6&>pCyRHn@FxxLS~Z0^ zXm7lc;ciddC&$~w)=0y<7LS(EeevcjBf;C9rAgtR9Pi)s!F!u}7TX+W5?85=V3OzP zTlP3L4rxc}(m``1*CB`)KYo1m_-Yx1qz-J%E>j2AR**)^Hgy86huAy<D_IY~QtpJQ zbeN1Hm{M&G_o|K_a8fJoJWX3CCT?I_o!sQThA+!0H49l!3YXD@N(oGpq%l}~v<lax z=*+;)D}(X&kZo-AxY5!Mdg3x$8qNGaMI-b7(?-gQXb(irJ##J2L1efxwTFB5VvGQA zH5fFOfJ3xD16XL40aE%+_txMKLu2~X<978V${?|Qll0NPX@8-hbo)cp9BPT{Hd5|_ z?ym=S28>)!(IZ;$8HvA3Y?mYz(r-M)*nUvm7^e;CNSuKw8c(v*Q1*Cqu!GOp+^$E^ z9_TY^=WHUltU|`Frh|?-?S1?#<&N&YKJa_%|1nzn`e{xli_lex%W%;7rj{e(lVw~# zyd@I#07VLIQ4R%7^>KSXtFgC@mvYg|MGx1x*xRrtijJ0svt_ka*KlGHbq%-OKG-ME zo)rh-Q3d^;J!^EfG&;7aMrgznbQ1lgH!Xd7sPvYDsY<GEh)0N%t|Ik3hIp8-hDS^L z86&iP+sVfdh?vYipfOnD(CWj;*jn6~m;@1JmoZhQ7DNfxXNJVjjJE2w406);0K%15 z5ie#y%CD^i+1?s_Twur<Mc#D|Mk~{F=)u%EWN<{Ym7Z;*L|lP^xPbcJIrN9nBBKNm zkIVSyFm+!7JekmlgZ21gHBOC%n!$t3p_D0lCiJ1FRxML2`lpAH3VHBv&|~6%q|sCB z?IHfhA?OJidSnj<M6u`Ke@Ks+AEedKHU{tGMX#$+k#J8PX;(+-iXCRQ!w`p>S~;$A za>*dVZkS3->UE~hLYw;3**3MA(|*{mi{&8Hx87)l94{{QmNNI^ASfO{_#5@DzGBX_ zF0Lvzt6oQrPgSFFJ?d$fr}wGHn^cZETi}mFyP85foUBwD{Q*n=G*R=CJV333M`s+m zy~;At=psjcO1HE0XY`@}ChrPPC;EQPm|`rtrRbGYh(Fzz4?*<Ij2gSwbTXdFh9%Cv zi=vXU@Aku$5jA~3Kv*B{gJlvNMl?h*fu^_^Wx+`LLicr{SA$RW;o){Ym}h8hJ?$ph zw_Tr>`a?rJxNA$isbtrtjFRpfID72+K0Mlv_N~3yHFbUYBK;a(oF$_yPH+A80kI0E z$Vm3-vE8@y#8F3n9OLBr<0#LJMIRT-2eW|lyLAz4($0YJhJW--;Cpt=Nb?)st}jg- z*VkJ+sB8Q93X9k?YbN+}_IPU>xjNP(_Iucj8DmA}S)8}2KQU&Y^NeH6I2do~K{g2V zK{Nhz3Wf|BQaq#>=Q$xnCi>Kcjmu^FYZ@Kf)DrqD`&UYU*C#AjFA$nhst<AAEE|>! zI4&%gz_E0hHJ3EHZu0i3b7b$p5Vk>##`(2Sseb4S)=pHRnuBNzdpQ0F&PXQ_H3y;Y zj&tdu&-BL>edt#WIo{`LMvVgM1fU+NbZ;ty7+gcHD~_YG2(lgunaM)xg!VomnMTy4 z-lOXU0*88!LsSLF9zSu~ysURTi%;!HEOqz>4;(<CqbwG@#*JlVUbdyPy2N48KATb4 zU9p_f0f8r=%wW)JWw)nncR&M~Fuq74TA_!Gi42`IE`*HHRaLnID#`~BsVb_fs2X22 zI<F$XC~rvqXoVAedG*vh8)8`}D!#hxcQ3s7$fC>3o_unvdf=gluI%32eahKuYtAYt z_^;#FoO{KI3)I+70@|yi=gi!;rLJIS_x>&aYAD#D5?6h{vP?Z%IsMn)F>Sc6d$*y7 zal6iA)+au~<JA-DTk6l~KQj}5Ph2W~p!f`ji9p%cXP912wJaAwY+X<xwqF<GlB0~m zC4R(g9j1*<>%Ok%><jviiCwI=_y>TGTtQ0^!yl~5!w55CIKd?~4sro{Pso>$3>Y|4 z=iM;e`oys^5e5O1j9zT$I|Df3z=<NiQ1xBRJm8!SoPJ~Gal(SJWeE)IS_IBRp1E*& zRG-~ZK+HT&*GZ3=2R%J!iU3C<Nf5&$AaK~b(cjr3VbOv<hMJxueBjwqXqjf^7&?Bj z2d@N%fA#+m2AXg>$9lmy5*SBY|88R^tF|ySx#(8rj0`kI;^7Ny^neh-B&1iT&J-t{ zggAPeEeV4L4#>kil}n}M4M?3SKDGP0z|EEpWApB^FpMwtCxBtl|2P<<p(Ayc2E4L9 z{abw231!Z7kWYUQn%KS(Sc3*E26Y1GSbu(v)EEDKXUi=F_f#BD%C-LcTlBt9QZASu zs@$W%_hrlXp8Y4ZAJ*~2g4pl=6A4*`(KxsUxkNprww|~Z5ox4$_lb*(Uj~c;mhU}# zPiQ~q0Rvgq@7@zM8(?T)Ft7vgOj@m(OUZ_ZWHmFv8KXwqT_+hfF3}<A@xk<en;uQf z(*HO;GpYA)*!r0%eecJ%&3f+v3;hJEm5aR}RP<`B4w}J|9d*=AD)2t@C)tBQ7$cGU zJ!e<U=)TT(dm4ITtg0;%-&4xgvI9_D(Fp(2f7zy8rONIVV|9G@bs2R*<0EP2wa-|* zLt7{tAC5!r=g!Kc-eX>D4RSRbzox9dF-15w-CL9lETU8$PCEzf<(5@S<Q6g|JkZKu zBU9e8IG8rY{)T?{a%V}~W}$bDjVF>tJdq6ekP06Hc!Hw27$W`b;!gTWPomAg8#Hq( zbKdN67Ph_-`p>O7drVB$(HO3Y4d5T4Wbmfe5c5n-y|5g|j%n3rPa^%+9kOm(KjZik zBHhb4P5@-HACXD^_`>lnEOCY^&;=$i5^Dop-8XU;`T`k)WNm<1osrw>*TBF}mHirw zaeinxD2!lW0|hKs7!sTM$3c#R5nGId&n_Ob54mVeLGh^Kp+sTkywk86sYg2aULn2_ zf4BR93Z)aD0PV;?+AMxr7+nc-!AIFzWxAbajN;DdI;1Wjo0{~jd=9|KHvw;aS)&XV z(iaAMqr4)qB#s%)b{`M7ckPEY+7G&((w<uGaUuYbVKdI4qKxgEVP~=J0fmJ_h7=YR z77ZCSq+kq6(Ad#LI~y`dq44Baln3$$1&T&jP0dT{L3yY@Rh7j>etx)0`>(zB!AGjN z``Hgan!WYTJ5hi>xcKu|Tyoadz*Sq$`um>86FUn0;w?)Gc77D-KI+TOD?g+EwX<Lk zM5CSkzl*!VD$MyG@I7C4aS_EVpa%{RMaV-c_$*cV=Wt*h_HD*xv7{#VTZO|};aSKV z5jq1hhD@4j*qSHmWzqPQiaB%3FMqiuaPrHs?lWF|aqCC7?I=)BZ&A0QIez`>?v^dx zlL~gwY-y2R@F(Cf)+0hCZA}yc!eR}@Ud8sok;8c-oZ&NxqDgzSgyk6bGQt?EWOsJV z?Dztku|+6pqN?Q$K=-u>iN2d3&NmG}nQJuWd>Vl=D)9U*FTcD+FaFj&_gt!mo~mcw z*nNY#=9-W0U*6sE{cnBr6RNy$%kqMqI}4U?xmsNp+qrW@_n41<Gi=9>n7XZd9mp%9 zka>YU(ht1FH7C>hJw>Q~KR{soa6sHth7HY!m_RMvLR>l6=#Bo)ijgdq5?fUU?;QG` zi2_Mu!XPWUrr~RJ=p;W)Wv`fO2=FZdeo?+5BroIHt?K><ADp@UY(40+zg2my-LV<l zKK+@Gp7>gzY0Df~{nnQ5Bj3*2xpQRqd)<vgcI=3#*gpz(K-(6PqxIeAh9_a>K#tVQ z81yVij3=HE=QyCNX9sUc?2%p8$@3iKG>6n#4!IfL5yJ-N1_(=0JGC0iQiO=jEQ1jH zjatpX2}GjGa=t^R4AH&LcbIX^K_@&!M~V)=wENu9$-QIP8+?diFZcxR2Oq|mWGwr< zTpP$fn&IW=#C*X7M<1l2!$2_V6+_yfl8T`yvF$4>4vKCMD#Dv-@MfePpN*f1(ZAuz zmEb^2P1nDN=I63dc*L+lc>zD<*D~$$kB4#*^i49cKpHQn3BUw5r#QkM_Ls613*8I) z>fz9P-@gwlb*fcgSkRTxnnu?Y89Th}(2Kxg&fgRBc32jtmii-y$1<r#zZM5CkAtu@ z5xN*h*hI_j84=|@$NU{(Bi}mR@C^93!_s8tNyMNva0)COMu=<z^?7R8Ac5lz%?A!4 z*Mxgo#xul@z##~jUWF9G+Ab=Qj2y%8ea|1A=irpWyJsvtJ^M$gr+VP94xhe%6fLT@ zU?gNvAxU8-MY|oN9_C@xPPacaESsHa2lFUDWa*eEeT4m)rY&xwe8#-={h@F}%9r6d zxj7UCE4e$A_&;U?sObH)3S$!i?-8;xH%v}qg{ex0%>abf@(N8x<C>spH0;<m0ocs? z4r(~#oBS`rSA_>w47AeC&F$?dClXJexOrb_-}!p{CEfRY?FnS?*57@#`|gYN_@I~9 zJx0Blw{z#9kFML&{hEjbHDZfy9<)<%OU1?Ww$)^fI$}g_fLNFCDH#lJJl+x^oJ*)5 zKN#}ao@WIa6Wddyp|knc9A@SM<MsEt=o|;VUen*3A|d;}Nsz!Or<@V^FmFI^CdQ7U za2|tCRfTU18sYKP#L^u+WZ;mBsg^f>h5xmOb@$%KZr>G~bY$jmf5@;i#x^e*b#o+? z^_g|*tuwm5nIGytS>3fopL=A1uU^QA)tvLuJI5ZY_T}%~nf*~ERcgjdGY2#$6%a3o zE&PMRfgqYRTRFtGpz-V?tgeYxCyo&*u_t1klq(fh<b=5I2BWG9J30+aR%4*x61D8I zkAB<s=3ARS+H<iw<!cvr|NbI9W%FP6ZPH~Ib^m^i{%-dqGZL-uzB;yJ$58dm7PVv8 z&YfA^TT~<Bept7-ix@pk=9c3`>t`@UFB<~B93=?C*gFowHzgYf5d?!|@eL0&n2ryd zY~XnKJaxQjazpH}6dqFH?^x%*wyHaC#r7Ya)?Lu}n!l+<KiQ~WUvcZrjp~haAM;nM z=Y!pE=I+=Yd;Txc?K^VS;NX^EB5&spV~;%+`{B;KL=YC!-^{s+Hs<GPqFdg}&y22z zJx`JNTjGs=sB;t#K0`6n#zGp!_<g^X9iyag6Q>Xx#1o0@yRY+zF(U%Ulg;h4b~8^x zzdZ+)FA$dF4((F2xD+JMLE}h8mMvu_#$3z<f`FcFdRg!V|5#7rvvaLxt1sX0ty)!s ze^(7h2LtgWI*V}y^Xl{R<Rn-A)81yDYymePKyvONw-U!42_S*h?L-+kxq*R`)My$% ze`-tjUNu&d`kR062PaG6QkeTM{4>ryu0Lm1nYk}iUr0TL5AIsAx;DyPYsT-1?%MZ; zc$3|Az{~aO-F47g!YLaTN{CgCAG+%>ZSHP&&1#PKg1g4W)_cWW$5{D#+g)dQlT+Ac zdlOX>R&E+Td1?3zFgW;hv`lb64u21OtvIaW+wNMUh5XoE`;>pDyAF7TYM;9fdfTZ# z`)$Z8(6_tmuy=y~ox9HTV*UVk9rXtJ9LHwh#=K&`++Am3D@o#z?Je<>uyWJz$xFj$ zfZ#B@wWY0aWkXv-;fmJv7j9@?-PBe%r?qwU+Q!22(z1$ETF-55Yb{*7w&C2`*0n3` zlcUpqJ-W|Zh4R{|jT<&Lx3(0PO)e`fEw8RP#*}qTVO!g(hD~j)P0heO^8C`t(<>*J zmzI>Rm|8iZuw-rFw8D}Ng=OW1C3AScw6NrY!m`T3lFfx<#uS#EW?>2<B?2N1g~H~I zg$;#m8yZ$Nu4~w^rm%IDqhPW{*Zw<sMeDk{rVY&-+nO6%3i-ToL)*sImif&q8e29t zt}NWtva)eQVOvvU;mq|7E6CiFqY9JMlus^gYHM46^pq)^H*cQYVBVVCx?%N{wYH3n zQ|8aBt6#9VzJxciIk$Q(UYl3wt@Ikm8@O7*Z|l7ay$!@1U5)39Je|XDt=z5k8o4X? zO7VcJ@J`{kb4hKaLi~f)^8LA9Eq7}vFa4XN5Ap8NA5&Igs<cyqyusTDPJ(eE@F$Z> z`78IT!R44VyyUu#zg6I~$za#Scb3j0z4Q5IvNzqU<X@qrgmPBkbx`R|;JXrVFZ8CF zs}1~H#yj%s9R8KJOU>N{=1HZw-ps#DNX+$Vz35DGq$EW}{~Rj>yN!G=+;4-*2DsPg zts~#yt>L#;DCu1XlY4PDozs&|{jKxrs5z;@jg;6-Ny0M=UHI6>@50CVJX-;*7VaB? zS_r>d40NHrjWVRZXVM-Tc+cMT{^ls2_pO_9I9qC3P8(ky?M>ltv-z7$IXz`f28Ru_ zswwb19gmItGT)mA4fWmv+EqRLw`GdFH~%Hh1IvE?3mk!f*1YA5CmSO|1}h}&HJ1Iq z`26P}4fDJK$kRd0<p(3HhvKO=9NqE=)|Cp7=!G8M8rW9GBA1K3@r-m6knNK=Rk8%C zra+gphzeRu742>+EoC|s9^=jMj`fa1@2`PdwO~FAtY=e8bD`q|??mW130f9<Co_PZ z0!=a+oQe<4=@<-_Ga#So{TFMuXJgiH@V?JF_~*U*@D}OtzTjQuebxIe<HfDsSCsF4 z&ikhKuGiL^@Bsetz)YY{hkw|nnn5B-~Wi+8ox>3xII;>+Gm-kXdpH+%1>p!a9o z@Ai4GFlJ|XJH4OcH?U1b*m)bn*CSiyFrWRa_ZM$3qtDCUbKXlV9OSXbeIW4_@;Ul) z2>X|Z5d?1po-`vlD|wVERHM}x?|W!yV_8owR^!!?oYgu}O;Sgx5^sx|jE7#SDpTdE zLRG3NRjsC~X==JUS{<WisAJV}7%XelOjgG0@HMGtte>OivM=ETb)uTDPErfhLUpoQ zq)t(b)e^N-ovKb#r{iU^T%DoLRR5*UQfI4kRD(KKtxzjfqgtg_t0vXVe0+^stJbL& z)vDI3PpJ)RqiR!|)cI<&x<Fm1E>ah(OVp>;XNbJ?S#_DZTzyVmp+2v^puVWSq`s`a zqQ0uG<m7~_)YsM3>Kp1B^-b2}u2tVw*Qx8(chn8U2;Zu{t8T;(_9k^Rp4i`4x2oGX zzvl;PyZWKJ9eco!)lbwNYKPjXeyV<^ey;9R|E=y)zfgCpd(^$^m+DvQKJ{yLzj{FZ zMm?y0t9Gf~>LK;8`ki`2{a!t){-FM-_OO!unD;a9=jw6J<^F}YiwMwndjIY1_Ad7x z^uCDy*^j)3IBEKRcEvoUo>tGWX85dnPCc*w;$5ls;@|$FdP%*^c`-K-yL7*In|F=3 z)%$_>bv!?>We3P#y$94j^@@5`y{6jL>#9S&q25$)sknMuy`%Q4PIW-NtGd*C>V5S$ z^>_6T^-uMI`cVB#eWbcof)2)XjeP|HtnDGzCy9`)BRZ-HL8`NLj?UG2dVn6N2kCr0 zSP#)d^)NkLkI+Zxk-9*S(uI1o9;1u&SUpY`>+$+XJwZ>@lk`!#L{HXJbg3@W<+?&w z>MC8Wr|M~Xx<1<bu|9?shBx%F`Z#93KjFlMhrK%(aaL${W_phztA59c!+-Mr;QbMA zp;g|K-ecb5-VP+pGu~6)(@3PZyz`JWYmlvLy%s$a`SU5{k&G)cPMnX7y1=`LvF~E< z)7~ZCrQT<}&w7`6aqnJTtLyYEU9V^BIo?NJx1Ou#=@aycUIK-BzCKAW&<pj+dXYXw zFV;)+QhlmEO`oopdH?YKsh8_B^qKm<^jZ3BeU5I>=js)DrEb)#^lIItoAr5mjb5wQ z=@#9p*XvK|4SJ())0_19db7SjU#KtA7wb#(r}by_rTVk_GJU!JoW4STUVlM<QGZE) zS${=;RbQ#U=6&e>OJAkGPQ=02^ws(s`WpRB{Vjd1{<gkOU$4KTZ_r!xR{dRlqyC=0 zN#Cq*(cjm%>f5|u>TUW5db|Fi*Y3TpZ`VK4Kh{6dcjz5@r~aw_nf|%HQ~$TVOaDUO zt?$wI>R;+#>HGAr_5Jz*{TuzD{;l4nck74r!}@pn5&e7psQ!cgqu!(cq#x6d>nHS+ z`YHXien$UUKdYb9&+EVFz4`_HqJBxgtpBR_=~wit`Ze9IU)LS_4gIEmOUL!w`W?Mr zcj^QBUEQVM)9>rQ>A&lL=zr=D^oROi`Xk+~6Tasw&O71+H$R9$DeM#Z)sOg5KgLo| zwx8qYa%}qmf1p3e&-VxWL;RusFn_o|!au?v=@<B;{6c@UKgKWe$NJ;^Vt>4Uq(8x* z=uh&G@=N^5{uIB|FZ0Wp5?A_FeziZ<pXN{ZkM@u8XZXkZ$N9(mHU3O2u66z_zuuqi z&++H_^ZXP16aD%AN&W(Vp?|W!$Untj>@V?``ltG*`KSBK{N?@`{+a%N`DgiO`{(!# z{<;1Nf2H5(uku&>O@6a~p1;Ol>#y@${8oRx|0#ciztL~=H~HuLoBa#?3;m1yi~URd zPy3(oFZDm`U*=!#f6l+c|GfVN|BL>Y{4e`o@xSU{>3_|?%Ky55wf_zO8vmRAxBP4U zZ~NEz*Zbe`Z}7MHTmA3)H~Qc6Z}M;UZ}GqH-|FAyZ}WfPZ})%b-|qj&|FQoQ{|<kL zztjJz|1<yR{+<4R`*-=j@bC8T@$dD2>Ho^V&;PZ5zyE;$8~;K7xBf1FxBrm;u>U*% z5&!r8qy8WKKl*$8KlzXOk8`rrlm1iw)BZF5pZ#b3=ltjWzxaFo7yK9fm;9Igzxw<9 zSNvD~*Zg+>b-%-Z!++C%%a8kS`|tSsIi>4>|E}NVzvsX2|IPoq{}2D4{s;bt{=fW> z{BA!H@UXpW?1urir(i5*4@_nt5{L$3oUNA~$O+^UA$kDu;0AG~_+Spe9vT=H7#<iA zI3h4IP!JduDD?gw7#$dc$-XGOsinEJv~+rCUBikEtu5K>8#gq!u0-!{YuwPdGBEet zh7GYbt2Z<@wybSvS=qe8uWwoHH@2(}u5E2uy)n43sdYn3u+{v#)cm_i{xzkRS4<6V zT+y_-!QRcT$Xval;rvE){c|%LR%~jsS8dH}SDLFpQ)}xQ^J+!u?2MJIZRa+wZQUGf zYi()Wn6<JQbT%?Ukh{!=me#h$wT;aU!8r}<)-?oYHLh)I2rg-AY-<S3Z&-Kk$_9OU zvp%^wxVU-sx(5H`re^=-jm^P^wd<Q20_XBpaJBhvrF<7|T)(jyY62JWz?X+iG};;h z&8?KS)|Pfbv%jIKHMCKRD+`*;Z)?~T-ef=Z*8^b%iQ8c7y2jO(<ce8kmY!MVF0VFu zWvRWdEUk3+(_KE(<+U!KZSyi)PGy;Uzs!|WHq||!=5qIanft!H!v0?FzAJa%mAmiC z-FM{<e!2U;Jo$Z{`+k<o>s{{fs&IH!IC?4^yb1@e!ojO>@G2a<3J0gc!KrX?Djb{& zSAL}{x6+kY>B_5g<yE@!DjoinuG~sjZlx=?(v@53@UL{`SGn@5T=`Y5oGMpNl`E&p zy<c5w>92NlS37#E-S^d1?zzLW+TmI4@T_*_SG)47UHR1x&uWKfwZpU8!R4?E>86!a z9lWUy-c$!~sw;1*D{rbRZ>lSAsw;1*D{q>kW16F5nk#>rD}S0Rf0`?Qnxki$qhp$* zW11^}nk#>rD}TBxf4VDwx+{0OD|fmpce=xKx+`a<`);QDZl-&Grh9*;!(*o7>r98w zOovacd%xDbU+bRNCZ9V#)jGJf4sM;pug-m6=gO~h-_LS+y~D5G;WyirH{0^Ps?<KO za{ari)RtT2`gv8U#jC2+(ot1v;Z&8{@~cWMo>ir`+^W)Kxfb85Qj2d@spWT7spWT7 znSqO4CYc-jxHt7mZtx&C^pP7p$PFIk1`l$B2f4w6+~7f8n`KNe8&|Y4D4e@C>r<N$ zz#AIR$ClK%Qrc#DX}K$NYGr22#!Y4z*$`OUyrChqzHy_-)A~&tTFt9v4t!aeMXRi= zI<pbe&$@=T#+8|^Esc$0>1v9#H8Jei>y6P>&F3etV;ce7l6=5$vaX?Fg^XBI`s`Xu z^z8cChB>om&o;~>pA|Y~^2T*5)@QD2-L%16<*vZ0wiXkS3_WWbSG7fxKeRQk$UavH zObt(2=2l*m0n9#3jbZ~=G;dh3Y2B)|jTfXo7|`=u@~gDhQbS?dZ>i#J>8V%p(rDbk zsMOXNnrZM4)!MAiX0vQoZ?oApn`5)NHk)U&6Kr;(&F0(eB%3X;*+QEwGFkT8h7GIH z45VJ*KxnajxWr~lZFZ{7PP5tRHd|)1<tEF#sBuH9xyqoL?M2&W`%A=BxA`rWtObFU zDK&3j-PnAAxrmqsU@uKGFqfGv&92O_DSXrVuqk`f`b<~!ru7-N>gB?e$~&e|-f?Ae z<%;AbTOt=0Z!XZ0Hf}^G%G}W0vf9*F=E{bR%?+&=G&fl4*0yX~XQ(q5f`ME(>f|!G zdUC_sHroj0-V$iu7F^6vMpKd30t=STpC8&ddE>^?ico{iR@jV6mmjHL$*2*@sI`ry zl_B%2(mtzn?2>{bmNo;!5GPlmlMVl}l3X_p-3&OTGiQZnL2^S|pb4S_OXQz6{)x;? z(I06@U4~~`B{JM#^UzFFRH(t0IJ0#%6|*MXVDo5QPX~#v=(#qK%bW--E3E~C1~k*q zN|S}_9SrQrqOgYQEsRE!Me5NTtuTl*rY^(v4sxT-L-n@AMw3P7^uUg;?zy&jlv|Nr zR$dmHlhzGmtJ7|xb9=suHuYSG<{4oSYBpJTp2HkLXE2{<F>kiqndfk9ws~Y;3Vl8A z1l@dI^n{**qv!Qp$4*ScBqqWsDGpJEMaxEql`J+t?NMxP+D&M_Wye~R1?B@du$F&9 z3+(qT_WK2CpTt_yZbA#}_bry4Ee-2iH@0nPUEkCgUg$_}btEseB)6I@YhlwSI?;wr z>(;XJkky)g7dpkl-e6&$k_IleA?+q~iiN$wW{d4t8%-8n+{2~l#-3|avE^lU%q=go zV{Unw9dpZ_?p#)Fb)vHBiqH~Uc$>|Z+DhGID|M-(aFe5Osikm}$%0FzZv;2VzgbJu z>C4)beivTqDu0vBqo?&?8{M3Cy)5ne!k+8Ua!dC`CW|ajHJ!*ssmt)pdh;~g&}g}{ zaO2vBjZOBtHSOAVcq0-r>f4&EY?YpGuA(!|u;i}I*XBBRW)C{<p<$4@&Yqc^znNPr zJ<MfJk03GkS#>KKS283c>KLh`^=ZH?`sVlC`aZz2>w5u+&P)4lUK*0~`hGXB_je0= zaE>laD`R0=84LTA5nb5xQTD>#<t<GsV`*9$OZ$|Oy|njt%X;38IiYG9VkN4%jyZX1 zAJp}Hk((x1?VB=rK%%-gO*6LFR<zoeoM5#NtW-7EIXyDfy=WV$d$Fgq+%!RIAI>qo zz<y<LC@(cPdFi6m{F0j{LhZL!cG_>9<a7_x3Uxx$Jjm&hnC3n=O<<ZI^3o-xEz3$s z`!roXx~Dy~Wr|d^zgnqize$&g?rG0AF(>`(11tK>^?+W2&px*D&RplEOFQ?pr_`vG zapw2jGzn*Z$XeX1`z-GHEN@Ag)U<_Kv1YHWP&3ytC(_)59&SgBG&4UB=q1eDXKBqM zH%)+<r@3j8%lweNtappI63jfx>5*UNKDxYzj2yJkbr_<~U5ieHgow-(n~t#x#p<mw z#@rye?5~;gL}3=I5!KNw<F36~n)Y&Jp_pvU?|EYNNn&Px2^t82TBa~z2O+SW8y^S( zDLi;$!}|3N`lL;I!6pVg1H(V1snuVCfyjaJ>zbNl@^Z519QPo3A2AxAMa|ix%uNQ6 z%tfXkX08S~qf_!z^J8$0AQ5i0;LQkEQCp{5HpS8j%IWiI%)M`lh`ER6CSt5u=F${a zS?Z>|Zc1C}rm~f8DqHEMvXyQsTUqL+*lw!Iq35=oGG}VAbHCEcGB;Is!*FGp`>xDQ z&C8r=q0E^UoIXa-bX#7zE6+|pODiiJ9FENqiBnnOrv4SKoJ#k+(tTg)rv8=g{VMl+ zmHWLa`MWbcR5{Z?l`{!cIee??L#G*GAKGlQ(~Lk4Z8llvY028k+?>1$Ewe9PXtQ<A zEuyS##1`7JGPCi56__4r=7x&0*%s?^Yq%(@x73guu9Vf=i9fl)zHGKNcrh0?RFFHv zhBHu9IzvKbmE%U0<Mvc{Kh<$zs-t?Uqk5|2=2S=h^knXSpXm%DGo2x7rsMidS9^7? z{5n^DovXb%_k5On?hL1u&Tv{e%hkp#N5?EzE3+JavmAc29Q;`hpIHu%S+165IXY)K zyk<GL^$w4E2dCb_sdsSd9h`axr{2+B@8Hxsxb+TRy@OZp;MF^L^$wn^&&t`353?Qo z*$)0}2Y<GMKik2Z?ciCPMrq}2TYi=6omH-PRoUKER&Nbz<hEVZ&opqjH*m-e9C8DP z+|WsG=p;9A$qig`LnpbRlibirZtx&Cbdno7%j#=QeUdx)wGMu*gKrIXJa_PG9sF7c z-x~0E?%>xt__YpxvOicu9`8B$wGO^*Z)Nqiy^%Zk*5Jpzqrc9<uXFIN0g&g8{yGQ0 z&cUy9@ar7?b&mcz2j8~mvU=N|$sPT+J#+8qx9ypG2j8}5?j8Ns@W{P`Z`(Kb4!&*I z+&lQTU32f~w+73ydTX#Gcl6tK&b_1GwsY<s{kENR@94MfoO?&VZRgxO`fWSs-qCN{ zd0D+}=j4ul+pf8H^v-thW;=RqJLmayru$-d5b;-DniMC~4fxW^>4yB$O52>tUAM8# zk$c-MDs6Kst+dUJ+<+rD;7TiPHIlpTYSE!vx#!c}`_tXMZC-ruy0LABrIpj%_ioNu zIo+@sJPkX@-TTuV{?i=(wpjt+{cf8P_wGB}EV)nO?Zl()PT=X@v!>3{D!WdE*Pmf8 z=HT+!<TSrN9EWf{#^*H0cvZ%nBN2X(co976Dg0ZC`FELG$-ft>3;7q15&peQUB<uH zs_XdoDfN_;!nYAThmP{ptl9IIP(naTqilJi)--Nt;WvRNDPa7U2#S?=`;d+qcX5jS z>GHn%LG1F_<)JTRjg1`@yCZ9F)~?W%x$)e1_SoDTqI={jYj3PN^zH1q*<)j0ik+D= zBQHA^$+{u-Kxk{$Gof2@Zk4}m9eW`9uk49AH)c<aJ&^TG&Qn=qDQj$KXXvib1EGgP zf8g1zp(jEeq3-a|a6$O=@LA!N;ctf@2)~&d&&bWF&Y6+15@<K%#$(S5)QpQVcIMok z@qEUs8SiAqa>_Hu<lLB9lX+_Ffy`SoAIy9?a%Sv-NGOsUsg9hPH5T|^6397E<&;y# z4LRjPmHmrc9{E<}-pH=V?<0Goq399O$<Zaz<<a%gi=tOXe-`~6c<#-f3%+T8aAKGJ z6I|?{yl4Ni$J#$O65Y`2@0l#~C;UkLP0XH1$u}fZ><;@!NxOKvPs)ww+?s@!tb^zt z`Lj>tsqh<&buvZ&C4bb9{5i}dkDZy9ojp-%Oa6erOG?h#3)a+i)~;B@K!W48j<e_H zW#`Pujq|VIKM@GKa-Nc>(iURR%U9H^D<xJPyCZvU&I~AfMrvQ`o_a5*7S5DEfo=IO z7#r#h#ipL_kf;1UBj-k7C%GfM;7@)P+N9Lj^OWL}`91mWC(Zlt_h5bt?LEBgdkq$F z((+Mw3D)pS=+3!O+M3C4&AA;u89wG^)62d{zmlGq$seH%_|tgx9f@DyM7;Mh@!gw& z7ohm*4aZM!F8+Tf@HYw%y;HnGyz`de0eCup<BWG+vG*nZj>MPhJNN_s7$3TccxT;- zKj2;bmE&i3H>LiHze?kkRfU(<gLnt-!b52qzDRq3_81;^$Kql40v>@c;cs^W{@t(P z75F+{Nhh=8_#Hd~yYS;XReXl<3j7d1qchlaqrJ26+Y5W=;IS9+8t}*);+>1P-6XFO zFS{vT6MlAO?E9Ll=6dIe7o4{SFSvEyIy}~{_txW`cANJpywkRO8}LuN-P<U>X<nOn zrg`V%mv*0b0iIuPd6$acm-kuxzTWjNSMTY3?{j!=4fk%tUu&%QLp-#~ydC&tRd{#f zl~v{4gJ0HEJfo)T>39$wqi1=)!VhYp_YhuCi@ZnhgIetU9#5#H-lO<Jo#y=kKd9y2 zAMu1b)7yhD)LGu2@P<0adklZ5bG^s$h+64Aflt&1?@7F$+Ps(Xe>&g$D;`i6c>C~p z`keO)K2M+bUd8L_i+DJFS%2AU$Mfl{_$+-5@23v^b$p-R!0+iB-kW$nebajj-=}N6 zINnb;cyHtRwADL+@6(OmyZS@l^SbaG8sPmC&!BwHVH)NSQxQCaMyM#BK^%@Go<S-L z&!D4J4!%I8YABvSQ`HFZ08*pz06Jb3iPw)BkJry!H37e$6VyaJe-^4q`23uvrr_zb zTvg%gbEc{mPaicEAD>lfI$l1XQb&tVkD7%~&qZpsc=4zc@ZkA^nvW09Rq7=1*-=aI z*LgsliigdE>Qa1c9#@~mf95%L75+1O)z|T$c~M=Bzs!F14ZLLDRoCGs^PajMPno}| z?})FAy20;eL-1DoV*=_XJY+J|&G^Q|)U9~OWUJfojTxY}N&o1+gZ{B3(XMVw)G)T) zhOeyhPE9;Oe~Hq*kH=^BZ2F7B<1mXif1Y@dt6aHH?Bm}D6YrX5*?8UFmx%K$$NNp< zO>Z}QzaCD!&aZP5Z}8+D^VM&7V|Sty|J>cY^CrJ`C7$*^OuVhi6LH197RuU9FU+Q2 z#=LtHZv*9O?>Atwn~mwWCGJ;0NW7zd#JfM|n>)$xO1!UrL8!@lI4JX1V5lfj@alqs znD+`X>bnw;0O4^JO1!2<CSC#3E_F=euWEkcDRmNGFG#$uPED)?`XjRQBJmr(_#<CD z!JB{J&DYd%iI;eL4{yH7n>X_29`ojdy!jAs{)smqFlE{||Hzviy!k!ed<cp23MF?X zUgFKag2mfl@fKgaM7eJm3{FeDY~E_;t;cxl8J_N;ybhqgPFZhLRy$=q1|OcrfB6;O zf72UiAkIj<td6JLS(G)OG8ZIX<n5Q#>C{Wm8^*t{Bo6T8U7ozllXv0K)70lHiFWVR z#Cw!80I076^>v`WZs?t1Ah+{HyMz3?p?4Q=3TK|?P2o(t<ILl{8RyNL!SPSDk*5>; zxO>%H{gqmN6>n@?*YEK4et7U6JUBop`}tx&cy@uwhx{6%KFUd_CEk~BptXxO@K3{) zcX;x)nn5~^--2owT>Js)M^OHA@;ei6LDyX9yC<=WcKM9=TiU?Gw68Z4zvJz=8c7>E z$&0Fmq)*b8k{EP?Tc_8}K9zE4o{`uK2Au{!;oU3XcQ<cH%et4R&++sX>a#2HS@{l{ z{sOgoc{+!u?|?yAEriz7i1MSsZ9i|lW8OcXt0#H?Io|&Z?-v+qPoj*4)ZJ-`Q_Wi| zdF#24ed|2ldg!ok1=KGn^&aZsUO4_M!2y203qRk5pYOuYcX{IhbvK;5C-E?EJ<D77 z;{bdQRPc>Ri^LN+;`ObC2vQ`EUpp!59m?8IS)G*iOIOw}`1)zex|3SGEz!l3cMKlC z1k$gN3xe4j{PGs>9pIPO!0eOMm*7Kd;@^iIC7nR;6zE`m8+CxBF!;U=W^bihjg<ZX zU-bHwcXN;`x$0gcS#qUZ+K;8Gr(A*gH2rcJJ>oX{<PV_dM_}E<!TX?E=(`(g{tPw0 zK(fxIWuM9pgk@+a8GQR1a`jQ~k;JQ%k(Gu?9NgpJ&KY;o6RH1Gq2SW)KhwtljBLD~ zcK$H^Z2;})6g3Y?bQ`TM6MTx0+%e?(TS#x@ed19{eFMy12ea2H^>t+AGTxJS2k~wm z@9q;x&%1Z>?sL5R9Pd8IyU(FdMS*@iz4UBq^LYASx&(iQw$>xT2Y}BVXgCAB4v|xd zpLlWl;s?mTZe(fzc{L2_HX-qXnuMGv<-VFU1MH4ZJP!@`sl~{zQ^9DYH#*VGSoBpm zwAlMLE%fJ!_1>L{X^bU#j36_dB>NM6?J971j6QQ2a;cHhK96i#MTsvU8Q(?z{S+DX zdwBRm`qA&8?R{ut<e;V8O>Nzi_#?IR0=2UXNjD3;PfhHkRMYe6MF;4SU6g(RdEG^C z?4pzdaAg@I!acOGd!heVye;F-`|$KqsNI?9@_xo|_tT=E<{qgH{FmYH+v=CRmEp#~ zyZL4xFgl$~e9MgqjD@`W7IMbQwD-+8_@Iof)U1_h2iSqKgg&_}@wm4pvDUjN(E{u` z?~25ay)PzihF^EnQVw|cCO+f+I&m>0^A=jng+TrplJPUNxKDe(Ph0|iJE*Z7?{#E# zM}qw$i8gBOvtaf!YVOnU_GjL|xbNm$V#`pAp9bSgsmWDf{XDgK8MS#mwfSkd^mA(T zChFi4>fi?IU@djfPR*`?vTNYpPpILGso@;B_zfAUpmPUp?jGvp9_r;D+T1;i?7yOZ zL^>USUvC>(*#yLQ=r=!ST!-)I6=(>iExc^BjYsH7zvqpoX??GwcXZL?%1JYjtH&{} z9-r6^F0ZTk^s)u?=F|91;P>tuZ@~Fsa7}9S88h<zma9L(g{LS@M&{T1jC?my(&Ow8 zS^`g(CBEye=|13H)cqbk^+(jjS=7ae;Jg8xpQJ8wsEY`7F_XFoQx{F(o<m(^gL{m+ zSV3I`!T&z$VxISAcQ<u05Dc2Ai)^rHqAmtf7h&q6l)B&;$3&hQ*8Mtl@nh;DpSqYq zU1WppdDO)`=#PQ%@#^^Q1JM6~n%BLbx+tSA&ZaIR)I|^qO5ug*7t7FrexBG3W_N<c zpMiW2P~QN`&)~}wK=~adOAQM*U!|l!P|_bL;ZaK14>vog$@Y|_$)G;+8O`(I+^c*g z8r7@x$yex;R#PbQGLSwZiDK|sbk4cRkR^#{>4$F`{c{cX7omMzO6$A={JzN8{&Vz# zU+|pq2(CWl{gSc&K5G5f)Y@+n9dP$vXm|teifnxz?mnzOMN7CX@gs2jBRD<^j*rsX z9;Kyq(bBqTY5S@7!Da>-VjtKgfop<;g4YE9#jhN&%S^D;>;XF#il%|@bly1z&0w%M zNN0P4^|fBHzK;Am-e6`LgZ&)R0McxB!p<d~K$_3}IqZ^cB7c(<C%xkh4)7j3wz9h) z^KwZ=-A{Sr;J^gZQRvKN<Q1f9pw=Z`^y-lfvq?nd_U4fmkrtCqgCnOy{TZaoc>ikB zH~9Tq<kym4$Mc_1_8r{sAis;>?&jU!lJ6ot#PdDC_!G~cAb*dM(jx^K|0CT`sX^rV z+z+9ahjKlfG=lph$O}lLxGwVssi|B~<9a&Roc^j#BvGSkDfxNbkEs^Y2GT~-dzAY= z>2IXJlm0>aC+P#yhlyu3uyu$OCS{N^NjZrZbuKB7G=MaaG>DW>8k~4b4<QXDp(pC$ zq(ahY5|Np85os)GT;fe#Od3x*k~AUFp(m0ibw8z#qMQ=)$>dYWOUbDNUCwvZgRUg6 zBCjTgRt>HCXwnSQaikhjEom01p6Aq+o<lyDd>%PG(I=A6Ctsc@)$6$CBrDxYzMlM3 z<QvF8N6Y#=>5HVVfa8^<t4LRqt|5JkbUirV!uubBXCm>e?{`1t$H)hAGS-m9n?5}7 zM<hD@kz5yWJ&L?IQR+|Ny;9zT9>0<nS)F*%pUU&;q+>|T1bk@m>&Z_dE#>`FdFM3V zKa<}Z`0ZTs72K~Pt>(I!-&%ODmG{<@e~Nq)zi%d8K%!0hmy>^v{0j2VlYfEyD|~k) z=_(TK)W4o@zr(jTkZ&R1O8#B)8_B;%eiQl4<hPK2pZr$x+sL<(|A2fu`47o&C;t)o zkI8>Reh2vu@}B~Od4vDoq+gKGH~n9d?jzk#+67*_$sZzrnEZF-kC6YK{892hkpGc< z5BZ<SA0vO9{0Z_W$)6&Bn*15^Ka)R8{v7%9<bNT5fjW4J^jFd=q}NEVlinb`1rOdP z?I-<>K3M1#G5Y?5v?K9Z6(PMxdY|++(%(t{ApMi{LE^J|5~+kVh4f+Kv%XK7Kw3&_ zA+0A}Pr8A$m2@NNCekgWTS?nU+ex>ReoVRpxTCykbeL)A2h)+Z$0T0x_Hh3Mn%ZDw zc^Uci#7jCm@q+#w`R7SrBwd?$M_<Qp-$}gSd!!uF08(Y*C4Y9}9e*zA1k!wdJ16m~ z-$ec<DNcHa^tZ%I0p7<_SIwMzT4EcJw*q+&koN$28<6(^c@L1c0(lRR_W*ehP`3hg zD^Rxrbt_P}0(B3NwgPDzkhTJ8E0DGVX)BQS0BI|hjiaD%DtJdoQBsVQMOse!GU=<N zuaUk^`UdHn;9pGIOL~!S75fs!{&<x4Yjvl-ot<f`*sb+oU|O(%!$MvRUyylRBscm@ zEF*Sw?Cz}YoG;}S3@9CVWB$&;tA;fV-!tNhBaS;_*T^v=UoJScpsC=RQLl~}GiFxN z@}j%PR*yYr>@{O=1;SD2gtDvnRCM_N!ZNv2c8p?`lzpMQu{=J)Zpb}m59AYO|Kp$8 z+xs$>NA?HGPCs@RzscT4tS?v{#pd`C%Nf`k)hO(g^mT7GX%1-~X));=q-#lck$y|s zMS2hU?~#xz$ovjueFt*B13BM;jPF1OcOZj1kii|u;0|PP2ePvRx!Hlt>_A?2ATK+R zmmSE<4&-GA^0EVY*@3L=Ku&fbBRi0f9muf`<WdJRN#s!nvPa}j2lA!^+0ub*=|Hx0 zAWuYgbkMgu=-VCi?GE~O2YtJPzTH9J?x1gX&_6rqn;rDa4*Ft;p*jxLaj1?%bsVbW zP#uTrI8?`>Iu6xwsE$K*9IE3`9f#^TRL7w@4%Km}jze`Es^d@{hw3;~$Duk7)p4kf zLv<Xg<4_%k>Nr%#p*jxLaj1?%bsVbWP#uTrI8?`>Iu6xwsE$K*9IE3`9f#^TRL7w@ z4%Km}jze`Es^d@{hw3;~$Duk7)p4kfLv<Xg<LrT71lIXLD<q93jUg40#*$h{>q#4U z8%h{A;*1M%WOp2S9Y;3Ck&AI;VjOuGM;6ABgK=bF964u8-$&{DD19HL@1yj6l)jJB z_fh&jO5aE6`zU=MrSGHkeU!eB()UsNK1$z5>H8>sAEoc3^nH}RkJ9&{i)AOS@NyGZ zsPjlIqz$Bv@*6!kP7jXLgX8qzI6XK{502A=<MiM-JvdGej?;tV^x!x>I8G0a(}Uym z;5hTn05j`M(&^0M&LG{5W;le@#2lxYw1%{nv@UTyIztyaLl<Lk7h`M}V`dlQWf$XR zm%ku!y}yuj3aNqnX3|$kSCXzGy+wMPv>zDL(e}E~_PWsYy3q8x(B8Vx-n!7-y3p3T z(8#*b!n)AFy3oA3(7d|Py1LN1y3n?|(5|}Bmb%cEx^##XCS{N^NtB7!(uKy-g|^a# zM$)C{kmiw2B&{R0l0HScg+v5RG>9&=gD$j#E=K$=M)@vA`7TEAE=KPzM(!>~$u367 zE=I>LM#e5i#V$s~E=I#HM#3&e!7fI?E=IpDMm|erJ5;tqWjj>1LuETuwnJq*RJKE9 zJ5;tqWjj>1LuETuwnJq*RJKE9J5;tqWjj>1LuETuwnJq*RJKE9J5;tqWjj>1LuETu zwnJq*RJKE9J5;tqWjj>1LuETuwnJq*RJKE9J5;tqWjj>1LuETuwnJq*RJKE9J5;tq zWjj>1LuETuwnJq*RJKE9J34w%V!L-Vv+-k?@%@DB9i(RxEsWjU8N0VLc5i3w-md;m z`UmNsqz@9?8ONSv{NB#^y`AxUJLA}sjAKtSj&Elydy=tyJLB1ter}?LG3`lz0{2y1 z&*yq6*G=SWxNqTlJ?TQOze&2D>l;X0NjH*iBHco|m9&ktopd|t$D}(*Z&FU2^bYAC ziI#vz0v@xS?CxF6Pj*3J36zyUSqW5?pwsU{r{9H6zYCpy7gUx&WeHT4KxGM3mOy0* zRF*(t2^5w<VF{F#KvfBplt4iVn3sTg2^g1vaS0fgfN=>Jmw<5z7?*%?2^g1vaS0fg zfN=@?`2&gb>9yxGf^{OxiO)}(M_No0JM-y@z4Ye2$n{R-dM7iX{mAxCdiP%BdnfX} zliAOHWPB$wzLOrm7dhXFobN==cOvIIk@KC%`A#Ik`Kp<;hP0NnE^$7xzZ2QtiR|x0 z_ID!tJDFkZXNIw#8ODBQ82gbHdyy7<8524g6FM0aIvEo>8524g6FM0aIvEo>8524g z6FM0aIvEo>8524g6FQjz>}LkBUtdMKnsg26Tcqm~dl@e}(f0Qvh4!N9??=nu&-l^F z_|b_}+RGTyiDcS~WZH{lIv>e&K9cEt#+6Q_(_Y4wPR5o_q|{!<mrll)PR5r`#+Oc{ z)?TF6UZmDu#+pvXnoh==PR5!}#+pvXnoh==PR5!}#+pvXnoh==PR5!}#+pvF-Ti30 z`_XpyqwVfT+ue`0yB}?LKT>cnQgAO)a4)N<fy5wcaS%0jfEwFPjqRqU4p2+GshtDV z%5Jzn2<{Jp`-9;AAh<sWP9K2N2jKJpIDG(4?}pR6;n)E<b^wkYfMW;X*a0|p0FLd3 zTL<9QZn$*-ZXJM2yW!AoIJ6rM4T3|1;Lsqrvm37Lh6}sl!fv>*8;TA<(E%tr07VC& z=l~QQfT9CXv>S?cL(y(&m(I@GSF>8gOk1?8(|LXdDP7CDoBO_+RzB9oAy|SBp>Zh= zm1PY$s@9O!lGb_AezmYdW{jgrV@O4$v7`ySJCXEnYG{n-Z!(_0$#~9e)Qi#<I~dpB z^ha=AKrY(bbaK()X7HP6arNY^$M_3KtjYMNkVLa<AWv#{(9=u9yPPsa%liWPS9o?M z=_=Cy*V(ziM^RmW{Lb86$b%#hmV~fK@KpsLMMXq>RzOifZ56d@KYwlie-U~6Y5V`H zExxUyA|fj4A5z6uT8xj{qEy8#Dzs5iqi#|bA;Yqp1Z1)ygoi-p|2-#(Sss1x-}#)K zvom*QXU;kI+~2)(=bV2B_3_LROtA?}u?bAE2~4pGOtA?}v1uPf_;-GT3hidjy9H`O z7d^~1j5S^dZ4S1$&q52JieQU93z`hw2F-(Z1zSQ6<>ZL19I=%nwsOQ)j@Zf(TRCDY zM{MPYtsJqHBertHR{B_1Gr}%MUCa79TFW<Cb2K);4SU{(J#WKqw{f->&ep=&1aoY| zZnx=KN3$LW-2hF5I{#%B{KL>}Nd9p%>n%_d)cNn<r{+~r^Q!1;Rnym+P5ZS;+pnu> z(XPQSUd#GTXf^w*p*Z^!-08Z&<0_lzkIm*v)AY%z>62AcORK1*Rn*cdYH1a<v`X7I zT7T{&?cNhq(_gEmzgDg7+<dmt)@eJ}-o|axHZDr5dMuJ18dTHPZQ^dz+-(yzHLdO5 zIM$5rQ(LR3tyT2zW+Q>LwuKW}PvV%#l)shrZLA;UT(j8z5bK9oKf-!8>qi5RwsI2^ zYSQ*^GuxyM+`?Mg!6w$*xrUvT*+rReD8DE0Xd5@7zb0)T>H7tPk>X&axBw|0gA~^y z#U<uaBz76}1L$pNHTys1IY2e*IAzwrCy?km#;_aNzXkH44Acy5g<7E<&`xMC5_X}I z;20#nz(G1leStHQ^%&?fo^RX~3`PTk(ZFCdFc=LCMgvRSawI+hng~sTCPViG3(&>_ zw6OqfEI|`X(8LnZ#uCuRS~Ri5_TlasCqokp(8O9hoZlm$bD&YsSjt=y3`P@!(ZpbT z1>1fET^}5SHkP1?wP<0joyoR4p$9qFL(n78qe05fW!vNIe==xA151$p5+uLGwy>Rh zNBRqp{#qoTLh>ma1l34?Z78300aOI_3|i5|5@G^{f+(7ZqKSoQVkDYahb9)Ii6ojx zqKTy1_1mmhQ>Ge<Q%3qmV$+Rm$F9*t5=|u0L=sIT(L@qWB+*0?O(fAo5=|u0#7H!; z5KSb}#6mQYL=#E05Jd}7v=BuLQM5o3c(7f0kVFefw2(v#Nwkne3k%W0LbR|DEi6V0 zg8KyXEk+CL(86N0kVFe#qlJZNVI5jXqJ^Z^iE~(wg2qzrk|2sEqG%$DCX#3(i6%y( ziN$DQT}Pc*r*&c``|gD3AEA-2(a6_YALg>{amu#WiN$DSF&bHnMv`bGiAENpk#*Vi z0j(s_$~vtR`S1l$5yZ7K>uOlA91VDAz(WHbK2JPL6P~4sdf}mo<!E9#()W<OhvYpZ z?;&{)$$LoNL-HPy_mI4Y<UPDj6Ovz!<UJ(69Lak~-b2D3ezOU0(}biwB<&$-4@rAS zdO4C_j-;34Q=5>ghc9hHs>_k6heSO*O%t~5AyE%+(}ZtrLXsYm^zblE_}C_F*+X(3 z9;FFy(u5~z!j3(BY!jZN39r$Fv^=EcA+6;|$HQJdq~akJkCuNJK6N-x>qg*vdA5Xf z;z%csbmG`&Gg65ol{8XGW1m&nr;mL$AfY(+*^HFpNGXn#;z%iul;TJ!j+Ej^DUOul zNGXneK8KXjNGXn#(nu+el;YT8J(7wep*RwXBcV7FiX)*k5=tYXG`3ieE!Ja;_1I!P zwpfKN)+4nzw&)|ZG`3iU<l;y!jx9DLxj2%GV~h1jEsoUU*xz&5Up@9$h5a?-4XUue zW~3NLigE1E$Nqfm&&U26kYpVDtHS=8@d)+UUp@9$k3{20G>$~m*k2X)*Nj(az$-K$ z;W+kJh5a=n={S;(Bk4HyS5JJsBN-t$8tF0CPam{_K4=3Ps6zvFNPoS#i{Epgc~B)~ zUuOLZ>(%W41fHieXrj)nVJ%*wiS>4#>pIL82s8GT$2!8ggl&v{IgESJe{G=u+JN-y z=)*Q3{W|9|%3T4!jdd%u9ohlygmyvSK)V_L;+*tz8|ddYxH(WRRLI!sai*tx0`y&o z`=H<3;GPO`e)_!)^m`jz#_wFl<J>9GG-w8NPf&+e>(FW)T3wG;*V7knaCdW_0O=XV zX07Q-zqkQSuSd)4?I3;+;Wz(*rt8q?dOMzNSMmFLe*c8^jnGYOpUU>>5OSpd+(7@i zK|RSF%00>Ur=a=JGZ5pgb|Lg@=y~V`=(o^f==ab|(900xjr6}8=zllR|8AiF-9Z1l zf&O;`{qF|)-wpJ?8*DAK2HM1Rd=2>!y3v+;H)~pJyEmu{^)$qXg19%LI}W1`4QF24 z2(^F=nr`lBnVYF^Xj)t57Bsp74K|~_W@%l~LI!CzBh6-{*^D$ZNHc>3Ge|B&9jQZl z8R|z1QfsDuh~zRzYz30aPzUO;|2k~G1)Fcd=3B6Jq@=B1hC9e`2N~|585^&|rnz!$ z-7+R-ipZpQH1;<LIte-j0uj;kP1EyD8^$~s-%HWMNYj^U#Lw2^XKS%<5Bv7$ZOE95 zXP#jF6#HL>Ukd*wW!_`Wm<Ro>Mr__Q+u*kci|7^0*o=pLdyMR*@Vm9xxQC5<4k!&f z_po!19<z+qc=Vdn&P5PoFW9>0jA#8{!P(A@kPk5<4*T}7Zx8$Sux}6h_UN^wU67>P z7b=4o19ArjDS9m_dMzpUNa!f&=%A54Un70KM)z2VXQlZ1TIz%6GFOW_;nB;M@gR?$ zwu}jR^tRLVw$t>s)AY8}?zzx;5OWl$Hy%B188h<SF|03S&Gl1<Ja;VXDXgdRztdPx zXFY@UEv#qp-w#8xp*hf8XdX15Yk8hB_<ZV<N3SSNpR<vkQHr*vmVRd=y`vO;&qnH( zNB#2XDW&NtrR*83&!i03XnB4}+fz$@^XMU^X?tqvA<0;kN4@jtwWn!|YUwGZ>9wcn zwafUGXYb}b_prW~-}kY;pWm}6_b@aYniDLt=%3zvn%;bx-hA4=0WE{xg5H7Nh2H1b z4>)!u>s74(%9^<r)J2b;REqlO(VI$9Cp~&pDe9$1uPQ~|^ypd1_?X9NfQ*rOj0ng$ zna3z@in{92(@N8qZlo{WXgw$ir6A^S(3ftc9j&Dut)(5UwY$0Ay}_bTUu^$}c=96Z zuC$$L=D`%=z0-K?BD{4GbvTWuE^KczS+9W-^y36wH?e;^p4VXpN*;u@X}c(G;$_U1 z+Qzn4Xgjn6+6nD~zA;7A`81xl2+v!D=PlZ=jg<aN8c$k;4@l!hi|_+!+tU={2k67l zmmI`4Z7bP^Md3w@@CVXYp`XIGsr;S}-3tF8<sX6`fdn1XD%r=`{v`AiW#&WAK>rIZ zgnkV@54`~W7FrDb9(oCS8QR2ud=2@~c4#N(5hP73qiA|>(7=PMLcC)k-mwVpn8rJX zf^w4!4GSuebU9M4M7kA7wgMy~NI8uJ%aLFOp0UEY34S6p37QN|3CfXLC6cPZQ&!+9 zEAW(+NU9PkRU)BEq*IBP6hvErR4PHP<sjE`kZU>8DMvb$c*$&Jn&xgQxtmJvrjom< z;7-!qMVhOwBwp_@aQO&y&5RSSHi<t^am7jec?y4?;>sIM6XPikbduurBtAXGm2Tup znQspL3VMp)PxEBbKt)hb<W<ZXZ^P9l@#!h9Se{&N#Gj||=P9nV5r5u@KX1gJr|{<~ z%d88ocq3Q5kt^QF6({lODSUbgpPmZ!q7TV=i9tM!ryC=f&9a*Hr);Ta9q0EN`1Y&b z%vCeTg1Iw1G2yD^iZ^h@8@S>PT;a-&tJ}cUt>mg!a#bt$yQ-C3)kdyrGgq>KD_O~v ztmH~IawVI2GQ_L~WY@w~Y~~8&-<Zk4Y=lBa9qwU$AM`8eDSkgqyJesvs2E~q1Ttws zCN11^3-{c@J-6^ro4Lmp-krEKNPut?Alw89Hv_^=m_}$b{1(<el!2O|txzkp1KJ7g zWp1ns4TVNRV}b<eH351}fL;@z*MvJcNPtWepwR?qGyxjTfJPIb(F8~|0TNAsJ~JTC z49GJ9@=Sm<6QIlt$T9)4On@jeAjt$MG6RZCfFcv1$b>!}T1t&rN{iY`i`q(y*-A?& zz3rt~{!%P|DVDz!%U?>1)JlugN=wj+$8W`>x8luP@#d{q`BJQWDOSD|kKT$0Z^b*e z;+<RZ&aHU9Ry<!Tp0AZL#O;hy%z>C|i4WYuT%-{5vT~UzcM~)bngmUTrUc74_cG4C zjB_vJjh6jK#J|t1Q5hBQ90`|E@XitN&e88a%$E8Gqu&P|=^hxYqJ3UP`@D+wc@^#R zD);|8$~~21r$e^{t7tPbw3n-BCs)xnW@sB%(KcpuG+RclJ4davN38FrjEq{}&-&jP zt^R;=tDwI@A3`5PpFp2M*(2G1=QpF-L{kni*DMzr$*<AOMLQq50J;$RJ~j4o)?MSe zF;G?vbQR-mp?r{44Bt}&s)~WAV$|juc~06fwi^RI#XwFmkW&og6azKI7~3siY`1{1 z-2%pT3mDriaKV^vPpB6J&UBHK8-e;jB|!`X6$3%VKu|FdRLnitbJ)&t-{U#vL}&=a z+YF$l7>FqbT8e>|VxXlMXekC-ih-75prsf{DdvuWxK7Yf3}p1}Gu@6c;Fvz!Z65>P zV0qSo24iS&0~(BVj04BA#(@hM2QFY7xWHaX+3P6NJ{BAU;l!+r1y5u94CrV4{%`1i zAbDndFKc;jyziKB3=dbsETRlEh%$BoQ~^B)ErNanF`t`RLK$WVWtbh5v9Ca{ajw^) zKS9iZx67cnpm(5mp?~&l`g8Vw3DrP6r^Z@h+2hD~*BWO2w)Yt`(r2VjXS7eWoAq9N z4gC@#$d9Iv&kPxC%EzXB?8&FL`q+_=9r@H&A3O3nQz3Tb;~kRNlFu0nskJ^f<YPlV zHsoVNJ~rfI6FxTKV-r3$;bRj%y7tkvkFI@m?W1cSUHj<TN7p{O_R+PEu6=avqiY{s z`_xJwUHa(JrzZO7%BLp!=*dSnKDzPIjgMY@?l4I$^tsDIWa}eaAKCiI)<?EJvh|Uz zk8FKvn~(f_<mV$hA8(gLDoLbLNUL-;HRoEXMbLKcsuZgm1PzAfBk3rFrQ%^@cv!3l znh4E;9)@N^b2#f})?1(^Xg9z2BEinl_YD8Ajen4l_YC#4h59K^|MwYz=bt)9-Q}6u z{-f^gEz7>6?r51daNm*ljJ7VlXcNVo$MNQIym=gN9><%<@#b;7c^q#Z$D7CT=5c+l zP{*~^A%PXNY<09`b+lx4+}R3RusT|<I__!(ceR4^*J;~P&E9IZR<pHQ|E-39tKr{j z__rGVt%iTA;ooZbw;KMfhJULuE?GALg?Y~u4<kFm0OmFI3f2ePg7bp+gW-^AYY1)* z9&6hXOh#h=_J?s4!&_0HpUy*&!9V}>>MGk+5KP1sb^Sg#M-R5+!}z*kj&s)k!oMFh z1{;F=JInm5H7N2BJ^@b;vWiC-<=pQ>TYivF@L}+a;I-go?yx7jm6+*o==aa$n#al^ zZEeAeT>a~O|FJC-WP(cGiQp5=4SEDO1~)K+oZOM^BuAMr^UO_fij-*^7K{(>C!2-| zCbbO+J`4Uswzhvj^#}PdF7WM#8F&Z%1dD=HP#ZkawG*7Z-=|9+LCJo*OmJUN-?lSY z+Sb_iQE&=R!c4Ge|1t;u4yIAAg<jnOpWsFIM1r-!$8D4MwXmQy7;`}J12!-t@Lzm_ zYR;5pyK0eoOmLK}f<e5i(D7krzoERQuc96?TQu;%3WeY9->h7gJ!i>EHQQN|^Dv_e zODtxKP%qxn>8J^T6e<YHD6s*{el=Jb(7FeIY1<$><kM9j^k-q01qS1FKjRv@N6I1r zYW$>ce{V*^Sr*-OY*&d+E_)qRaV_s~u6BFqyl#pFZ()sJN!hk3!Dv|r&ji(Nds)9C zzdApR%5{8#*V$Ls`RmZu;Ne63fWA9EVomKIvCOVd(A;%xvbC%JbXf-dg+uxT+q;Sf zWIR9clU-u}y<OK6JkYt1)-3CTMYLO6$F|OE?mChk;m!kS2|CODu<M>=Q+9dIA$o29 zbn9fg*1_fbT8sQ=mnRAS+Ewz<xNOgK@FP3#?!dkKO69=)T;V=)%Pz5x&#c&IPlwc* z|G|fv`hu?if!Az1q!y*~f5a;A_yZY-;i-(Ce_xH#zV82#wk!Bk=hooXPHzA8zP7<$ z*GvHifCT9ENL+<N7Bc^_SjOQ<N@)i3ws?DVg<{R$R7MV@3p%1J9H!9~255AJBQ*EX zkwjOxju;E=(G^}|%x;jzQaC|lDV(TL6uzr7n1_(f<#Wy*XF0{xGKx1;V<`+Lmcn{w zO?oUNcw;KbdpM0OXA)ImGc$U(v7F7^=3Tr`M1B-=u0~WiPa`Uf(ufM9HKM}#8d2dw zM<ObW)rbn?G@`;KL{yk+E|p9|=1Pr_aJ5EAxP}M`{miw*MmXKvt<et_X!L^@HTuEt zHTuC4jehWwMn9<3=m#%r^n+J4`oXIj{opl?e((p4e(<_RKlr0YKlqDAKUksB58l)0 z2k&e2gAX+N!AhbZJYiN5*`UIFq0tP!(r5-riDp1#1ELw2Z4%AEv`RDsvt6PYm>m+$ zfQSbY&A`=Y24SKZoI}I|iDOW#aSS3F$DohKF(}bE2K_XS!9a~;aJa@XID)zCGn}I| zg251tU~sZVFc_v042Ek2gVQyF!MPg2;5?0BFi9gAOx6enw-Lc$y>q+9F1SNu7u=_@ z3+~t01;5hR1rKQKf>|27V7A6CcvNE-%+=Thk8A9LdAt=nN-c7LTI2w=$a1yFaw2#f zg^eD~5@N>Ucd*f8Si;yS3F(<Ve>^Dq1eRPz3Qq(LOLi}p_xDbs<jE}g%-|fx9OKhi zdhnjtaC-Wuv-HH$bfg(uE5g#w1bdET>CJQPQM?gGzm2yw#O_Npsz|Bk{bHUqOJCxP z{D3kNVWb~*;3{&DNt}@~YQi<tlWSSZs1w&Q!X&k#579<m0=vD;Vzq9RY27H*y3t4L z#z3tbuGWo0>P9Vh@pqP7#=F<RCs>NLwzyhbT&*nwwYCh@+LEKSrN7peK3ZE2r?%{7 z9C8m!AFVToYn?fq+S14LB`a77;}4~bR+Le522p0PGnjYUk8_SAd!y8%T&+d9T8qeX z&A7z?@^js67!zjPVgNb1rov0TD%W~twO(~2%hYb(&fen$CQP0wA|{bzDwll9d2WH} zAt8MjZ!aP`NpCVs$@_K^qojm-SZ+$mD|M9VOHQd{O;j>UnKCj;9Z$&<-4pp9;tt{a zB;uHa$S!p<$4WGl5Lu>p>q%ppgvd6<n{^u5Bt+IJ-tE))CYBn02G?^Y`KL<AKXn%T z+3wl!=a7ji?4IkM3;#X$d+_JE=fRJ3Nm@?Es8R6a+;QB+CGI6$;ic}S@Dd@#btOWI zt3JY2AK|Kx=%GF$SA9gD`iMOB5qat(^6(Kia?}KO0%yC)y$ODzI}!e7_hxu9Nx@HX zry#MZ?o^~P&7B56-JK3U!<_+ti+c;a#8~O4UZ$UVnSSbJx~Z4xre3C-##re=eyLf= zQzEVOAkWmp@DgvO2f3zZ!%Nha9^{*v123^xdXRT&F1$ow=|TRfdGHd4r6=Bs=M`k4 znvY(dcAtiS#(l>0A}iIi<}i)V(u?d=3*aS6OE0oiRlx6Y_aI5~J#lw|8yFs_So%NY zd<qdiD{R9?azAx5y(IsWamfHh+ay__;Ct8}lrOLaj2RW$Leq_$P(>WuQ=i84vP1<U zKU6VW#BY|W-|VY?vrPSFU;O6boc{>CXLr2k(Ukv={SJ9fkFm$_FURsUr<jaUWPc@V z)NzzK9uFIq+)<PqVu$eWCtExTIi#>O@<<Kk8cwyRG6pit4l}*UDRmm}eV%SlH+{)0 zHNx~EyVM!HgLfw5Vr68RI?MDY(-f9Qwkh(p<Eclp{d{{qV@AZC;hVTKe2=wbxr=dj z9DB(;Wd`88f57+U78@h~)D_&_mG(;h@hVHYVDaf(C$VWb^Y!+6#@cRRl&uWUek0d8 z!A_7jQ+YSFh>TPd*?zOdy6hx<IyKo&=BlRHDQuZ$r*Y01b_U-+wLj&YKeIpMoaCzF z`&KJYux_)rQT{G_7yo;=y_-8F(hc7aSo|9qs~$v#vlz20BXiY5@DDSevy2Q@kHF7n zUS}C?i9GR|XXkOAr|r}H*R%Fnz8Ba9d{@{CzMr$t@x90{;`=w2C=BGYdXewn+28TK z#4h2x(pK{QihYIeSM94@?Q8ZmuJaG}5Ad(s*Wv$YiAX`dt3SanwM*gOuy4S>Y2Soj zW|zVL+5Q>+E&CSy+xBhvckDax%k6UbckR3IF&jfZ#O~qyefvK5{(=2~yIyHm!ZXqg z|5r=yTykdp4Zg}&!GCB!g#XBX1pl%97=E=~4gZP#1pZU|Dg0;lGk78a@l7Nktnn-R zm5E9`Ao%rmJv`5u(A{Q69m~k3^)>t!X0eu$Rm+EGJ`y}JgRo&@262VN48k&Z>eIko zb{BGPvu)UOU;~q*kgt$jTaM{3?XfAPJ?>@(l5wlMk*r%eCRf^K+%<89_$ICpEu-uB z+BWCX=H{4o%$Q3%TL3S}u{ULkXzc_)_NEOzg6&7@%p7UCjkerj+U;ZE2eGub-11J{ z@wAjD&{`X9t;5<{8*t$%lo`rm$j*7Hyf4U-r|oxlZNIx|`(2>zcQLK^8C+L;`+XK! zJB_yDQEkNyZTJPW;$v8hxsWBIZTVrE%hMQn?@sXSW%B+M3kls>O3CbbIVGiaH^lQA zPkVnQi_w-oUt4<OMX(rc?@P434{3Yfhj;kyWcyt#Ve&ja3O|P>Y#w8YkiqeBw#;J* zlf&@|wmivV$OHNmNM$}K!SLK$=PH2}!eHrFkn5{tjWimiEJ7a1H{c~!S;#EoJ$ciC zB;El_81o*{$|AfsD1DWcEcv`a_%XahFUvEZu!KPypMt19V==rHE+dGan=j!7l@}X% zztAY=a6lXhbSoJ}4LM4&OOQtcykPTE-aBLjPBBLbZy?Gz(-z)CEM**9MzS+xI4$L^ zL>W&J{2t-`#8$R!XK~FAvlD)o`G&oMQA!n~7^0=^g>NGo0+;9*-Z$sNI5?>)O{rrY zdMyrly@_$q&B=wAXlgylf!Z5B;zZak$i^zN>88jgMBdZBY%g=lDAUjB2Oo8!oVmZ# zAO0|62^sRC4uCJ`t;vWp(7`4Z_vA_LQ~06IQ2zZ?XBhlx&S{h!?tm)Dg?hTlBOfYO zM-J4Hlo{n*054J8O38$JAw1boDLK};6#g>iBsgS5y&V1u=L*g<-Wku{E1myj3mH(s zVH2DQ@Pf2*6>0TWq?M~kt2Y@@XRufBR&R2mGTKO{PoJZj9OO)<Pn~Jz?B>jSKwU;r zS6ES3cST(}in^kpu704RsLLpD7V5H!y7Coug~;S7^U?%+Mak$X^V0-@Mak?b^V9@~ zMHPpIvv62A3x|cXa9B7ChZ%PSc|aqI#*Ct|h@vs0Xe^>=%qSX*C>k@aps|ReF{5ZK z;*NGlgD1{+&u9Au?gj8;Tq5z1&+|g~i`<LgFLp16AM1{VALmkA6`A#SuLXOVEbL{n zu$RfgUSY*vR<T!Dv6ofs6;|wJ$?y3;oaa{eRuI^2?ros4+uhsYf8qWD{+I4A;b*!t z;qP$ofWOnd6aFsuF8I4$T2RGmd1L{-m-9$eygagj-VZOa@$$$D`T)E{$m_1?Enm@F zcSUdcir%^_ddpYz)?LwCzM{A8ir(@Sy>(agmapiofGnbT8^v%ris3?v;c~JtT%Rlq z*Cz|Z^^t6&9Q(ZcJW^fcQgg}SDKicCfa;8*y0D_U9LeWtXySD4Az3})JF#6pyx_U8 z<o1LYB$uN|u9z&JjFu{r%OTrmZ?FpsTiQ`wi7kOIwY)V$2GG9n(m%Fj0__Jcz2p!X zLHolWW)Gu`^q4K#LCfI>g87VMzW$2&jAFhb@`TE4$id(|qc|@tnL^<O=Y<vL<tff9 zR-6}AoEIT~=x}hDpgpT-uQUtog%s_TDB6oC+AAf$=()7<-?Jk*^C&xtV+H?(6#o^F zZxoNAD6oLMqj(I(f(7Isy%=5)VU8lgkRrld$wta{!G*bs3rz<u9B*Y7r=Y{AqQfwG zO0T7)pu-56N`J)vlC6|2*W2qs34#<u_Q&?e?EQ)T3HM9>QuYdV3}<1-9L0_y#g0a? zV=<XcCxeXyI~qIH$}CYqkWo9`PKOs98MU|ApR!kQWW@g5{v2M=WW)-ZELJpGVsE#< zWcy4zlWV)f-T{B7y%SzgW>`_CB`@kd@b}t#Irct#AH3jBD|u2WFSxTvac4+zXOZI0 zkmAlF#hoECsM5C~i|QN@(qr~9j+$%d@-Ko%ixrQSkXe<snCz-g(g%1-pKi`)PF7FF zsZp}6$_!UQt5LG9%1l?mtWmPB%8XY*u2K7ID>GjOzedT%Dl=dO#YV}>Dl=gP%SOr0 zDl=jQ(MHMADl=mR*G9?KDl=pS-A2jUDl=sT<3`EeDl=vU=|&al8b!JhMY=|jZbXr; zQKTDDq-zxEMil89MY<71x<-+1M3Jshq#IGBYZU25K)UZC8Ns+=#kf{6Zdfs{Rg4=} zjB6F+h85#l#kgU`xK=T4STU|uj2l*rYsnp3%{f1}pCjQf>=*D~+ArbbHV$87Yv5~b zExe#%OK#aU@Cln>yCCE4ij4CW8FyD?oKMc#I<D5U9<_Ue-2k7oN%)O+BYeuH;L|n@ zUvKN-8!WhmytIw*f~s>ARfiN+=P0TUDXPv<R2?E`El&l=S=)l02(~ult_8g)!p<Xy z?GCmG&MqdG?JnxVH})HBY`5KwjqR~};P=|S@PfaM;_p($-^Gf*OUQSdXAC)R^FiT) zxed8)3*ZHLn@~}x2)-w?_Z)KH^1NKJcn&#mOWE5u)EB%BI0Cs1Hg_Hnv${Kb959vz zA%;yi(|z*92{)MIB{`ZoS<;M{;iOeN$(+si$!3&fS~C|(qBU@^94Tj(<K<gEj&#-e z4(T`E9G<h{`HyukqqUnu{^`|P)&YsT&T_N%Uu07!!Xt5Qm+qHO{hw!GKj<;!k^YTj zzb5x}NA~MO&U~#ovk&>G?PSbeLC$Q+nk{*=C3E&lGG|NfY{{N2`LjPHgZ4+{(Eiw6 z&GLz6(*Bf8+STOJ{+w*uUyx5*GHS=ksokDcTk>j4W^Ku>E!njtzqVx9mK@u4WZ9NH z+mdNpa&1etZOOMS8Mh_pwq)IwyxWp_TXJtp_HD_(Eg85a2e)M5mOR{&iCc1UOE&KI zeB6?ednY-$ceyX1^#b~C@_ce6{h5B|9+sizK9*B;d~cYum2tM=jIE6^w}Y^*GLN{| zxRcB?j8@GgxBFe-8s5cW%qK=2%Fuskx0)R6qaTEQU^_jW$5~(OF!D<eOe}5;Bz7hH z`+=#ybmC5pQ|qj863*K8%=YYY=$}NjTzgsU(3!(lhn`*M@v`k0-9}{gZ_ioG)(uY5 p+33_cp0l1k-RPMPqJKG(KH~VSk`f&<?bJId`DS}q%bg@g{~r`OMEL*! literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/RobotoSlab-Regular.ttf b/latest/_static/fonts/RobotoSlab-Regular.ttf new file mode 100644 index 0000000000000000000000000000000000000000..eb52a7907362cc3392eb74892883f5d9e260b638 GIT binary patch literal 169064 zcmb5X2VfM{_CJ2h%xrqH*=!Qh*ksd4BcxKpl17IB0TMt+C?SM^^iDztL+==>geFp! zst6(?K}0}AMD!s|L_wbv5fPKg|8r*(#P{^~zW?CtopSfybI(2foLLDagy``h5x3Uq z8JUhLjx7mm7LL1?)>)mqEgN-yG_DH?>0Z{lTldr^t%6z*w&V#Rd`#zV4ddRu60w#L zx(5C81`Nv|G5yArcL;Guf4iaq<Hnd8Jfl^F1V6*`#swn=51a2esTCnUmkF_7Iyisy z2;6tW_$IV=gNr8?w7c%yfRN~7LccvxI4FPMvmX0aV|+h6Pb$O>eXyeu*V(uZE*v&y z!l8SfpWzzgyA3aXbwK{@kb<X#gv4UFro-|ljF6u?{D9{Z(BCvXf7qZA#lEKr(?<~^ zzd7R7(PMmj$GH&Zc@@KDju<s)gdJV*h8P<C7ZHIQ97~$+_`IKM^IwUh9c~bE>Y+YH zwCCUNKC)^~^%@6e*B_Vmgo(TO!*}fZSAT(9b833lY_KoXMzTHAJ|$mqNAe@9i6_Y; zI(##Wyh4WK;dA??*b7Rybcrq@GT<zi<1u7?TgyKq1$EQd2E0jFO%^fr#+6Cj88LCx zXksCxrrHLBU4Is7B6MSCF=JENiY_L?Xtn5zanXu{Rg-Pfb<$GmK|09?Nk`e9w4>+9 zHnxh4VvC3)KTcAmiKH!ELA<y>DX0G?OL=3AxP(mP9mrT|C}}NqC7DtM#%MzNNE66J zsgQKQ{XWtRl1(efQo4gA^51c9Fj+1Ild1d&X{qxkY4SCaEVm-9<pwzB<M6>)zoQ*W zl9dqB8Zcx^8%Z;H7w+#Rt#u<wYsDMSx024X5$!g#MR<0DOq3-OqR6DVe4I4YjU&GD z6cQ=VBgxV!(ucJm>v>xe%)+sTJoH~e#<NV44LA#>%{9-YEYeFlkE0{$#jaw`xulmI zK~mToB$qX-`9=B$=d($QZZV0ILrHUKD*9d}t)!Wx7w=4RB@Z%={fz5tBvu+vB9!%{ zg|vgDNM*z<H76t3d!!}(kgP)M3wS5eTV#>c7jv&A>GC1c7x$Xchh&xX8R@}qk~K;* z(ubFjBEFq8mHLy3;#!hOIs27NkpfA3-i(ao9mx>Zlk}6#*q>C=iAiK5y+Q^vGwH{7 zV{dknA#w$ITRubHR?2Zbi8Qr~CGk=Wa5jZ>ma0jnY)6uHoa9T}NhfIvX{W90cT!LO zjl{4`SmQmc0eBZ{SG<6i2c(y79~q@9B8BWaX~Jr1s^tr$9mXkC4iFc4BWcOfYO18( zWH4_|3V8$IC!I`SZe$JHOUme1B#9p+rF<PJq{m4cT0?r$-^n;$UNr}MG#B@K(3zwQ zXlx#TL{^J6Nhd&)Ye;>0GT`1x5`eQ*C7g7W*5mqp(pi}f8fr&gk=_A5SCGY03h|H@ zU`=hw5Uh2y^bX)DBc*ITsV}`s%={<PU#6tJG>goU(#ZhO{t*5Y>pX>ZUn3*Mz9|iA zYLvxfjGO{m{*)vr^T-g;V>{4Tg54XWx!qT!qw*PPtb_r!&ZM~#1U&wZF;0U%LvauE zD*r&5$XO&wv5;(~DegTb&2+z#j=Cy*_Z(<xBIzl20#5IdZo0Fip<GBBON&U6^c!H0 zCv9YJtn&m3le|f`JO=k3l6*OsWGKhbj>aMGZ3fT2PkPJXKe;_=rOP7ux-O)<ynxhK zPT@KFO07t5<u1vPJxMFs9XRMqMk&wHw*X^AkVf)Y(qH+OEKxE*e+Nl>ofB!I3@17A za^U&^X%3nXS8kFB-C*#fg{0fhA&u=85O>L+MDPQ)eE}SW;Mpd?dn>`4SVy69fy|Su zFqatH4`csAMoB@~qfsP`KOpNQck&u&zJ&frN_0PwDBUj7NZLcf1Yb-41~0u0K5GP= z0vF)5j?!e30^ZJ)b4V}c58{C_yXvY*tP)4M+jRzB$CB>g{~}2xBXsqE<4_V0I&LPn z!TKp_s&LXmu1_4~Wx%<LF?_Kn7)zc6+8>Bx2;|c(Vu38P$eEz4?KnQb-kC@&_{aqL z=*w$}QFjt}*hyO1=}D%pA$a6xtScJpKa24qFrEuw@PHnGHmhsd5y)8w$lE@+SBi6J zDY_X#7#d9c$rH#MN=LF)nolO-ejbi!`UWx6Uq}S|f#k7=q$#@sSuzkZb~O0$0C;5w zSth5FWxCy@1M5Q4adhJ|u_ud38s7zcAHcc~18*kKVmax|-vG>yNvQM#=?|XHSB8;d z9U;SXiDZ~Ep9~c;Kyd`lza$xuVdc{2q=j7~DPlWnwn<yabjbkO?L$^dvEVUZlFaNN zcfKUiz!kI<*1Ml9)*S_mUx3DjkWAJH*2OZC$1BLRx<hgz!zEWTOmeO1iFN|t0{LoB zHc7{c8)&G$w2X|vy!EA#INIR&oQ%Nu^;uh-H^JJMk^t;MeWexXu0QU50=f7tWTiV` z9EtPQ*z?}t|3{z?542_2x3|!?0!>bY9LfV8?m}LBVP3iBvJ`;xhGaZ+Tx+Z=M+ygS zV<12KK)w!zTv$PR^2s=#0$BC9KZ}gu#gJ`Vaa}={v$sjPki(E6^SKVVD*-*c37ONB z)Pvs2fQ;HIZ6M2}k4S%kBhW)PP3J)N%bbjohk$l&LXJ(wdEGT50n%m2`3>ORNj1-e z{1kdx=wA6vlBykTuukYZ_H&J@=}@6Z|Lzca6*~3h13J}B=v5qnY*oz<FZ8L<sV^Pi zrRFamnl2Uk@}CZ&L!m!kKA=Oqg&x7tfNiRI_(FFI{rU1C^ybTl(3?2Kn#6qn)nZ*j zXA8UGZ(CtY48U_?PXMO>*}~q?bpAiI!WPl&fmJmRu#Vq=x9`zD01gANwonb9!d3uY z!B3f3ORlh6gf5hY?E?FuPLICaa$nnho)4WP>>Ah>|Jll+HM=#L3Vi)n3)_do{t!0M z%dN17giZ3lS{n^PW^1%$YdQ3U*mtoX|JPR7Tf*kiXhiH=t=%PTA7OvJ+zJ~+*c_S- zB52@q;;$XxT}=)MS@3s<kPSjEymYX(HMfLpK>HZSkry&S$c2{<AroFcG@0=79AfO3 zk2)Fj(p=iSkVir$)g3n3RC5Azzk}m}4VJ&kDj~1x4gp`?@iKgx%oK7{972x0d<eYM z%C(o*P<O7$IU(cf<eZRoIP7kdKAKD@sac`CR<oEruPKv{5PSKjnlW-;=%DpApJ~s9 z{Vn(e`&4Ih3!42eTN^YY_7(dUDddK>$HL|kb{1?b&Ax&SrP+*vR)t*(TNv|vBy1~< z-_dGzm6#89ouE&RcQBsd7csA}nd;yYeFSU@Y$^>N!H1Ah3hY14{ulC1zy+8zxg>a9 z*hPY_gnce#l8`0B78kNf*b>547rY92q}lect3;nV8vf5#TPL1tJ`sE+ewr*6d@Xde zfJyTS>g3ecnh@Pyk_o+;SqHZ!e*lxPQ-xhwXD8X~NH2$m*elqKnvGW{%LMPhhSg*V zY)S<-pg8|e8Tf*a>SUa-V_<iSL)fC?dv#+A{0Y3&wJ+odY--JRt8IlX3fk!{_CS-r z|JlNZ)$B~zuEM_5@GfwB9(Wh_F6`6)g!8Z0HQWDs{Wr3`4wwJb)~)xSTb<Mq^Zdhe zjoyS#5;_oc@B$a0D?v9eUALE}LZ<xpeOtd;zo*Xs`KR{3WN59QROc`KQ(H%O|Jh1E zf{t-$dIhwr=_cV1fDf>jo$B^P_#0xc>ROH8K>u~Lq14&K@N?mZc!&di8p<ay&La|5 zM=N#XYy2mCkGg%XrPI3kG&%4)i5GUPuyyFSWU*-R$7>Hif=C1*N*?ZrGe06J>1c10 zX++U1Bu1P`ASof6$S$&*yiZP(Psv^KfT+}!>S+iKqp`Fb?MDaG5?V@^(Ko1-KBP6w zmnE}Yc8q<*K4#yrUpVEQ+jCcL=4E^VU&i0yR(^!P&p+lD_$7Wt3XvL08B%Adzx1j! zQJN!NkiL{|Nx#Zec9RVOG@xa`?0`oBzXbeVzoW^~WHbesf=r>NSW~>Isj0as-89Bj zYT9DjZrT+n2O0uB1A_uX17iaF2C*O|$Ti44$R{WuC^D!`P+riWkh4!e{6kXVDc979 z)g$8LOiUyQYkUK1+(S-~kH|&xJ$XoKs2g>sp){N}qS-W$7HVtUME7Ei&zX1a8c$=5 zSFuL&VvVz~#zlNNui*RmyZi({%Rj>!i4-cuN|{oYG(Z|5O_JtGpGsGy+tO2+$@%~i zkP<L0U{k>3fG1cZF&Ru=CX*=yYm75Bd9lU{tnsbCtg(0P8uc%&aiF$FiZxbYja2fg z`4v&9+q7fN3EHaWeb7Pzj)piQalkL4VL0mJ2&^&GQ1yxWJ<S)WQS(&`Syg?xdTaHm z>b=z!)tjr=SFfp_jnPKej1oPnWgN7oYt{3r-w3IC8^>N8TX1Z^_r-yzWK|nNzU%&- z@y_Wx&+hcP^Yo6xtz1HGW!>t0tK+ToZ~bmH|JLJH{4MF`b3$$+B6)Md&7n7k-0XW} z@y%{G!*0yFzWv688{=<`xH0TT{*8<qF*hRr^^wD;*t%7;+(yFy<(hz}_77u_>sSxM zgf!@-V_;ne(b57cqMm>INBfG~=rIGI<#k=?I$YhsyiPa}d1NU#&fq}QlKoWItFC1? z>&{+o*+ull@qhVayJ~xJ$%j6nztX4lH~I__no|0ZNla!6(=j`EY}3ee=D-}86LV%R zWCoeZT$vlwGk0cS9%L4o&FV7~3uHme%!0`rGM9z0P!`6*SpzbUKHv}G`#&OOEC*cM zi}hxG*ehf{>&yDFJeJS;vjJ=%8$=e6g{*)LW`%4BD`G=gF(R{z*)TSoy~;+gk!%!M zLYA`WYzCXn=CHYJ9(_!I0jC(*CiVu~%qmzZo5p6cS>#Q!ll?*7VpXh~sY14JnJe(v z_Ha9HPxf*L?ntcMiR|OfWIuP|uH*oBBL~SLuIKLDz&*H;dvY)CP2T4|u-Z@Xdb}48 zBo}xP`4mznn1}FCaPep45)b3Oc{uqTv9HTKf=7}scoexpz9d(9H2I2r&0}~&9?Ki? zI3CXv$iK)np2(BH|38p><UUU(Ka!uwzY$^m8FKF-dBmHL$Gj;be!uYM<Oy%V`|uP} z!&@RyY~ihVDo>-7G6=kM{tC~a5|ybUDZDT5M?I*KdQwC@c|IS&`$K+)N)D2vBtwpd z(*`txMoKywMWbm9qy^;z`5^w7|3VwmSjkSZhZKtAPx!Aio+i*lnnaUnV_v`q^QZhb zUdV???vjB&<G<4;v?+hi|DeribJ{|ZXbNp9F^TgcK9m<z3vDI2NqU+}(<CR!nOE^@ z$whLd>3lpN$0u+^Ci!GOg=Wx9uJRhblrN*LX&cD16_ST!q;2_1$&;_*tLY$GAbCq( zbP|6=r_kke1<&ERL=lk{@QL={U#Ofy*4qB++P^%0=|X5D=qbcEBqBo>>4+V%Cl17s zI6+#w5Le_X^u(PQhzBtua_>dFNj>62e4)eqNdT!2i5>`<ZYIGbgoKhX5>6VB2og!6 zNHmEd4M{9%MB)%BNg#<Ni6oQ8qzP$Cnvv$D1xX<-iG{QxsU(f0lMIqcT9Y=UEon#E zlMbXK=|nmsOVEXMCEZ9i=}vl(o+O9ll3t`Y=|f&2eMvv$5|9g_ztcZxH8|BCeCY<B z)Po=0nFsTP_V8l$m=E)VuJmUC;LkvCXb=kqhlYYX!JG6|@+!3O05X`4BxA`;GK>tN z)5vJVY8R1GGM&yRBj{qfgbX5M=o~ta&Ltnv1qAVIatJ&>7kWFN6w@-YoGyfB8;V%g zXu=^!eq(lmQ^o$#Vmb_ZZ3vk|m$C@<IvtOl981TE-Gp=;M~moiItFq_h4iVRRg5ym zI3q&xK#s|p%yA%Pq?~Lb!^t|bo@^lFp-DFq$bBn`vYPS=qOCN_G|*%{k!6)ads(H7 z-Z_EhK;N<)lQk<VC(vri^)*==i?hbLxhAV)M*cu+xVUu8Fj-^8Nv!B`A}hyKU@9xi zH(4FBa`JG;B%V2lvm|krl;@k5o15!vC6T$gW-H0c8I+qFZDmm=j3b5Q0|YrOE5|CE zQ>}_Q)i*FO*GluEtvt#McuWKL$^BDJ;>mtT$|3@Bnr139m0`Gjv2sXRmz=yT-~6t* zIp$nEvvkYB1787s?NrfLDaxu#i`)+~Ps>Y<w#v9Pr<zSxVouGsPV0}!tWrd@Rf#eQ zh*-t|E6wPim#zV!v)v?-=6!ZjNS-O9%$zTfrmd0q3Ora%zL>3UIx7z`=cn7gY!|gp zmNTq0KRw!NABFKuCaZl~JAne6m{W7D4&tgSt{iX`ZFPt;y(5wS;$r|NvO1>anac8j zd%zoQb&P7CowH9z({qEZ&V$SoqODF*?Yrc(?`FH{8;JV`?Y?u=KH`+tJ!hYjQyQjE zwK_!RT1lFfg{1DY7atDzuu@MTfrn(}?4!U8wj#9*c*V5#5rJlWt?t~{_FR00g=kN6 zv5eLLzI7h(_b1Bs5n?c7>1kGyvLEtRL$?cHku$P$h}FrQYRbd7hn$@$WJYRgS>8Tp zInp{T(l-c;cST2+$Y`ru)IKU&ebhcCTKA}ZT(pL$eUfNBfK|~NqxLDH^^Dr56RlU& zK0DERNA0s0ZM`U~UF839ZXe8D58v^{+@kfv+@kfz+@cM@+@h_IxkYQj+@cM{+@cM_ z+@dvOZqWuunVM_#6B30bJLj3wfY3a#0r_aH!4ZMc*3c+xNTf9clotjfYYp0{BRz9| zW3#EOd(MB}#12PW!(ZT&dRoIGtkf8*p|8Qq%l+%4h$vH{22ErX^tX+^!6kL`iBsZv zP{?+Yo?>piFM=8YRTS0$2<m#}fq?QGM_Z$#V!WD1TVwv_DRzDUdNc&`h-Zi?#?)Hy z7#7{OtgN-UH8>}yKh|KS;N=)fjUJdKHVSit_VAz9#j0dP4l0W=n@r8iFjk{KADd!q zV^}32C^8~V);z&SmM%F5n2DQw53o?~lbb3y+YS-}^I=AFCI~wXR0=L4kv1{K(((qH ztvoG%Aefh><@@41FBhDEZuyuP;?SI#-`LlTaWVlt8f`2LVH*lFKp@}(IEl2%*i%`2 z7vIZAmk@1qd_ws7ngetH91*)0C)NWO!YYT>uE*RQ%Z%4<TkXIhCR3&vc#8xPL|YTI z<pVNSiye}k6Ju%)F)iS#y@|nILSG23+TsxiEn|S$hH;xjGuL7jFhyGvYiCTWLu;PU z30OrP=98k#rWmpOOvtC^xiR}fsRt-K`NeG@|IgcvU)<Ju*M0RbeVRmBV<YRH{AJLl zQPxJ0W!Q4Dw`Cyy|C$)cj<JSf{$?6R1ijQD&<a{GgH&Tcxi%P^gBu~uUJzE@68|^l zwEq7`ECM@%SDTv~`v$(Wae=wDkhBm>u0vglSY@EVuK=VL+7}CJiG>+$9J8MY<}k!q zqrf1Rf4JWYa)5dmtkLL`8f9&WCQaZb1K2ZVLX6j8BOQVP9Fqp*Wkl^Kq&ZG9aYDsO z>!|%yyVC|I+MTwdPYXP1C;Et!_M(qC=^*-ula8WK6P$DseZ)y;(MOzQi9X__i|Eq~ zCtXD!aneon5hvNAk2vWr`lR5bhv*|tdWt^cBuDfSC%K|eQ=Ie?eZ)y`(MO#05q-qT zD^b?C7ijJ)F04to-A_A9##x?5HMrdv7x_`v_!qtViwmvy0PRfl9;ls(u7jei2`{=9 zhzqUjVC_tFE!56L*CA2X#1~zQ#D&&%sCFj07Hems>#(RutKA?g56+q(#CJ60ZhPyQ zuF%7DQSK2tSk(he5R&OuZXRLv$}pMQTV1-ew<_Iw<yaGZt>L+OFu1xycGWU@e=9Sm z!#YwT_B$!~@W4mzekt5OqigzpCp%rlK82?53#RkB<XA29a<r>ZaRocWb_x3|_Z?a@ z+bS*GC&Rk_@4rgek~l<tjN&adMFb&F)X&J3H9soRQm2|9)%Lb}nipRUh5vh-_Mn&H z6$h{^_@8^&S$2m#=We_cAHz>d!H6uKkVEBO^1F&ju_$@U6lJq=Oy{KArTf{gtKAm6 zhxSeFC)i(f@N-CanBj2A(ZR8g;|9muPBBi?obEWMI!|&w?)=Q9oy#hhORf&CF|L`e zMXpO+ce<W*i*cLbc3B^#pQS(N9_v2IeW&{mhQ@|IhLau+9+@7SJ)RkpjLVFdJUu)+ zc$RzK@k;P2_Og1N_IB`Y=Uwc5u3k*N@_NsF0(`dlobqkwyT|vEAM;z}x6SXGzq@}A z|Kt8w155!q0V5C_I)>PgseZ5etLpy*DYVXXGO%f2S>W}cQ9;+tPUaHx_24$a#lZ)I zpM^w)%nJEBv_t6W(C1;D!nTDy3-1uVGyGbEga$ntOlYv9!SM!<BZ4A&MNEr07;!G* zcBEZo^T_^@lOk6{9*?{l<rI|=H7n}fXertfJtz8kOxKvr4W))f4G+h9$4-hp-N>y` zpGJ!sU5`tNn-X_A-aWoY{F3;u6Jis_BwS34NSv3%lKLl|NDfGzlzg*s)5bFzUuhEF z<aX1{rmLDhZq~fng67`M`!wIx{CSJ47CTbBQ--HpY}vHsHjAC5$g;`ubE^rhZl;E& zPD?$V=8=|{R-Se#y>I%S43d$Vu_WVeX4lLet({sIw?5G(s?Cx%58L)=Yi;|iou%Ep zcGuhIwg0+9P=|sJmpdkP+|tRe(~8dSoy)U)vZiER?&8s<SC@CYx_8~xEwkIsY?tip z>{Z!Uva7nsbkFSGx5t8>4n6aFzMB)2(<5g?&fVOU+-13HucBU;dN=O9s`pQQI`rB3 zO3*9TzN~N8zGwSI^_$l3eqPtSoq1}0ul#rVyY(;Vf4sjspkTnkft~}G3}S;u4Z2y- zslYneeekrwcMC0rD++%a(tOCKfBbiB$kicFi`<K1i#ik)6wN5wP;{>7>Cm{LJ%)}N zx}vyoai8K@#jA?X4YM0IX_z{^VEE}*?Oq-D>WWt{j7S;r^T-vW*eJ`WKBMN0S~KeK zXqV9`qgRYRHv01DpT>BOi5W9%%+)bh$DSSMJ+9BVS>tw$duQC^@loTm$Ilsmc>I;| z&nB2ABuvPguzA9jiPFTViCGipOnhhJ<%!QH#ZKxpY1X9ulkQFqnw&X#*5oadFHL?v zC1y&&lx0))Pq{s%YHHNf;;9R!o-R>J!b`@K94t9q@}xAOG^cb?>4nn!(~_o*o3>@z z;c54$yG&1?-go+<=@)0D&M26%ZpO`-KKPe2bHmJwvm9n+&YCyt#H?qt<7Q{i-aPy6 z9M3tSb7JPSnX_dsnVU0r)7*#iO!Knl&6;;&-s9KuUMqj?N||R_kFxTzYxCLs@cCWm zPnv&t{<Q^cLDYi23uZ0Yzu@LV_l2noix=)%_|u}eMbj3YTx_>Ed-1Bp7ne9JX}4s~ zl3hzKEvZ@>yfkm=yrtHq*Os|0OIkK?*|KG)mOWk`y1du&dCN~PS68I3n6%>fipMKE ztemy-)XJx;VpkQe+P3QUYWLMytLLr0xW;`=)|#?47hZRIJ?r%)ub(ZqE6*&SSAMMg z$=dL>{nxHpdv2||E^b}Ux{`If)?Hn%tZ%%&@A@U{Pp*HqA#_8p4NEqh+HilP-$u*E z5gV6nJhk!uChtvcHjUe~Wz&^69NuXBMxQsPy<vUh=4NGc%;v()Yc^l1AQhI1Q5D-N zzTV=#rQMb}TTX6yvNd#T->s{*p5FR&Timwc+qP`GvfX`qhwYQLZ`*!-hsTa_J9g~2 z`lj+`(>IIX-2CR1ozl+cI}3KM*?DfK`c~{)1#fM5>*lVAT?2P*-u2F|3%hRbdbZnT zcku4UyF2YJ*j=)F+3sz--`#y-_wC(J_c-hc*pslQ&7Qt{#_TEEvtiG{J!ke@+w*X* zve##C%-;09z4i{@J7e#vy*u}w*n4^J4|}VuZq{IHV`~R%o^_0Mo^_qoYCUDWYW-;+ z+2^q@d|&f@S^Ea=o3L-ezD@fM?mN5h_P%HPUG@j>Z@j<5{=EHT_RrhDZohT^sr^^? z|9n6?;C&$KfaO5;fx-h*4lFsa<-nzbu?PDfoOf{7!7GQzq1Zz`4wW4`e(3IDm%|Z< zvky->yy@_<!#}+3@^;MIS#M8xd-K~@-f?@!@=n1!Yu-8W&b1@#NYIfEM<yIucjWYu zr|&j?xA5K5@7_M@a5VPlz@r<Eo;v#MSirHa#}*wseC+zM=kJ-`>+s&V_tw34{JqD= zO~-SNk2${S_~Z9|-f#Z?g!gy6f9d@vC;U!WPE0tl|HSPN+&@VDVAKa&KDhjWdNS^0 zhm(aT7o2?e<i!u|K1}&=%!luOc=uGqsWGPxp1NCUs?4e!SGlh8Y~{1lai@z<?>K$` zqkxZcKAP~+hL7GoV>z?n%#JfRKMwsk=i~B^FP?Qd+vDt-vzI<0pEUpE@F!L0nw~2; zXFYfGyvO;>^Tp?voj-B@rwgGM`d-*@;m)TXpJskK;nQ88UccymG4tZIi)TOc_^i!m zQ$E}F+1*RQm%3hBa_P+H?w@CUzTxw0m%}d?Uq1GQ@<rb-)_rmRO8AvAS1y0q=F1gd zKD?T8b<NeUzl!*(@T*N<-Tyk~>q%dq{Fl?ey8dh3ziwYkx;E?D^>1RoDf#B~H&3sJ zUT=4O%=I<bk6r)ihTn}2H%e~oxpDKR&&}+cD{fx8rQB+ItLRqwt+ThD-;TXqbbHI~ zo8LNp+xXjo-!A#~%(v>DxH}{6Y`Js$JJWXs-);Nu;oYFSeeTY>d+_ev?}NV2`F_n0 z<cH=zjQC;O4_EIw+-rVs_`ULbr|&(xA9FwN{;K<@??3sm_{Tjz-v24$r>vi>|91O# z_P_W4?D2D-pEv(}^?}QS)Cc1p?09hXVerFA4=+E8d({8Ysz>|r@A9LYup1a^Y~9!d z)OJXSEBae}WZa@Om5Hcj7mkR63rW|z>-CZ$lIqO*c-u#Mi~J2V0Uxr%b7rSL#)lZI zB`S&5!d~%3+%e5!adBkaiD5iWa_y+1IHkEdFiDcT*z1@qyQVo~cxRekKfvG5*QcJh zmnST6OlA9XbMua*f!u5`CkARqJdZcvFq*Z)%#q(>AJmYn)mcAMU3v}m?Yg>a4URM4 zreAxOwR#05>B#w%s|B=t0qwJhZc_8au}IyrKrLXQ6eVvWGTW&pmOnv_NEAu6v~;ou zxFJ-Qg6cCw;!_Dl%#tF5FUd@j3k1RtyX{S6&QV?|%e)Igw~Qd8Uyz57VvM8-p<$t+ zi3v%`iSb5HPop^@)EuN3Jv_Z|;i2e^=ETs@<m7k{&-l0`-mrA}*$c<FZP<R~)YK8< z#!cFA?(~I&>vmm}*zvU^r!S!sdX>htIJa}_MdLTuy&rr$Z^z`J`4f^-E8pC8&hY;G z?q6P%%V$nTksj$-^P^lSS0W<pi|B4LqPHoQX3d%+K-r`*Q*<m<Y$_Jg8@sGiBwcT$ z=n%3c#3PL;irft=G0N#7w!a`duSi2eQhc1J5g?m`LKAJ^CMMbzL;oMo<S^>ham&22 zEnDWjwsl#T_HDa#ZPzY~H58ZPHg2`c61P;JVeF$}(wfpeyQg(5-L<Q<-Qa@u9or2V z(yr=!$)4S%ou=*DHLd;N!R<S>D=cjHTbeW~4Y}ENH9tyUW1WH6ttKSXk{0X6Ih8|0 zy!D9g`(d-NWwKniG^8K8al~nz(-bO6wdX9|9Mm`|D9RjVHu{9?3}UUx+MbCOV~=z+ zDG5tfbY41hm;wX@%W+A`RHul2<k-q&Jl9asZsCGX9X@<(!|5S|htcc?G1gA)j<D~# zXPqqkO0A(^w^@*)t`6_rY>{hHQdyG*`JKAt(0P;I?lWL**EiojJgxuY_F3xSRvU6= z-psuz7c_5qw?m^CdcZ$@O5Dh0{C48#^nRhaNiF)0w9)A{sXk5D_|)5C1l@v31^srx ziC|GZ(??P+7*z14+(f;L?3keMQEDSrrVK=uKyPtzk{Pk!ww|Q>Q@2Qi8%g%^QkdT8 z=8n~d68$KevR4Ut?d->8A<AC$B<oDeSj;PQ%uqF4-Ri7vQ5%dYeuYIN;x5K^#MowS z?0ObYF}45-pcUDssAmvBxe?$o$z7l5#=?^0J&B%~)erV4A#=}NnjWI;p)FaaI=1@r zSBi(wTl5uY+LPWMUi?b+C3T!OM=I;br$VN<5I;*j7iT9&2YWl6!oi2mLf#+`lJ0?} z(2!&qd8-gF*`VV*j25X^8_{rwHymh4ta|B#nTM>i_?6u9S7{G*%kXu%>f=0GU%mGV z1^~cqQ3=^lI*bTuh$RU8#N>_=(paD$LUTb-tc!^7XJ~@SO|W^OF;H*T2POvU<Jm^K zL>*D7zDk!?a@YN8BK>4P-EJG#OZ}KOBi}%>x>}qht_etz?+tK6Kwn{?qr`aHtbeyx z8^%_)>3^klyEdz`*8rY!<U?k%gP?dXiwCX=?FiH&(Sq{~J@T1=ATf~5RK4gu<|DGQ zlq|(Z4{{dYakseE_6Ca5weEptOw^;Y@~jOmQZth)z^Sb-zC09PaH6)pUS=A<eLKtB zHdTp++?WWS^RAUG0Ty4v8107MkQ}u##7KnX2oegyjhTa(Uhn1}ALp(Qvxy76ChHO< z?`L0LdH(Fmm(MF-n>l@6+4PxnS)_VT{SwJOPnwG(QvE``AMxJ%@4u&ZfA516#{t$@ z$lDsgX-`ZRf1N^+3nVmEmNX)!NbqR-!{`o#Bq!^2i6MF~W8lPF-_e~nt0$HCNomsL zKF{y_l?eQ_hHi4hI{buegyz9_We&-RK_MF<;W<YIIwtIfC2FgayDC(con_&h`w>6A zm)Si`=Mfo?jAN|;Fq*?q%xx1J)GIJKUY}3Dnbv#SkkyOcV>0D;EAK6wrcP%}cH2Ie zxi8+4Gi+t~Lgg4G-|ZX!bD7#t-mbn62r_Ga<hKD^1ZiW*a6;15NOdHDDnbK+&_RZU zMAj)fSt$f8I+;L%Q_8zx3p5EXbt95wl+uHP3=wAcU=t)bg@UOS*Z@+K<{&wtg(OI{ zIu#^(nCZ}6Glxx?IC?%{{{7>#4~Gq#IZXZIlQU|S%#SUcJatjYyj?tg=Gdt-=8jOd ze*fi1y$&>td}q{0cfNc_89i^_?77qGbbl|6PYoo_($HPch~xw`+uO;Iy_BcQe{z&0 zIi&&1&J3o7!JyYz3X0u`-AhbP3`|5~H&7p@<4ZsOxT5-LMfE5)<6`wRdQ9=4_sb9a zm6Z4$ew9C}YRY!AM6tJhfWIr4JCJm;w1+~V0sc_mt`vKkY6nzOqC;tqEXf=jO`*Lh ziWCu5=>qKsNQ7<xI7TLRI*<f<0FS|Dy}f574GZK+Ny$m>Mh}qo3(ajqtS-zDsE1La zc5E0uvfanu|9I=juQJ>JTJhAf`IE;C@!pcnskCIIIyfkrG4<)Kf2mK;o>IomvcA6X zKxP{~udm*$<*!KWy$^D;?JaE}bU@{dI>J(70kA|QkbsT~`$OzG=>{$kY8$qP*nT5V z_w%I$(djV1Fr&fM*-jxo)W^;>lE!&@=|YA1q4P?@{@a#7Aclzn_n^yc6vEcDTOJ$Q za73He4=GaP&3!-o;kOH4s6WuyU4s^dyg6;++@*45kk4{2|L^Zf2`$vepWar#Matdp z6zxTes$cDrKK7HZ&#zhXuGohT;IUwh280}ib=S&9zIlRLVJdMTn`lBw@8KZ?24P%h zPIh-U1j4oql!Db~M;f?Qx<x#`RK3Y{2fr#C)zhl4x_$k6ngeXG?Lz5svEPy_aOOqK z$Y3|LM7eVC7@k3NbD6=+k^Wmq1>-LwTuASi7(tk7b;_UH1eVP<d-?qPX~RlZtG{2m zqE@Xa88+qLCr|vcZo|Y$udgndT;5>r;33mz6cx^r5=Olh5p`_x*)P60JNZ~t#9O0I zeD+yY`GoS<Cr(+oi2D~WdTr#ZbLL?EjAR3T_UE1lV0)n*sN@Y^_ky)7rDDf{PYD(q zw2w_9iH-leJ$G?>vF9N$R5X)?B_=>F5r|>}vJFf2^fcg6tvvAXq&17Saw&XCuP>fb z-LX4Vr+$CG!^V~YElNiWTWVUqaM<bvv%h*Ir?sKFpYKq!`Yi<Y@9JCXVgG=Y{`KgM zzHQ4tICXB*`u9*(rRg0+C(U^G0_UhPa04mm#3vs?Y#Kw`d)G8UztCYe0)R^q5Q*<6 zLPzG}`$3W~csUH;qkIHah)Vzw{)oLDV|e|Ou%Y;(X6?9=^m=+d_eaT=jpl~(Dg0OH z2<3pCOvB-(7`<d8>OzdPWB2Z?Vbw(*%hKEx!<~=m<dt;N$KrbowE(O67yMtKCLIa1 z1OVGm_^4d~CE?8p&V|nBn$C9<lqz&R4*o^eah@s;p1h^{*cKZMQ}H&&WqwP8L85@c zAZAYtNlpx#%6nG5$$DgG^MDW4IV;uKr+(He9+)4t3!kLXKmciBY3c&pXvPyN5P6|O zxeS4&IUKe6NS388plfFdLP|JH5EwpY_i&wiB-GIhlT>J=I$;lk6^>Ipsu~&=49Ffi zq<85t&VM*q`SrpviC)V2^R#@~t9{0n<Q9z@kf*$H^5cWkuZ&3Q(OWG*Q5GX<YBS}C zjQVcWe)O<(bEll8C`@t)!`_6$8irirD7E4ah3M=cF$Y1acHM}bol}}U%x%&QD<VeW zVCcFLovxlPJ=M}UDL5oJ*lY+64swKhrwE~{5o{=g02Ha0E}knwFeST_Koce)fjIYq z6>cI1?H08?4oylnXu?g|VSoLbwnM$*mh_ui=I-^~mLa7bB_-azMf~LDc6#-Fb)Wi) zTIT9bvuM+tgDGL@pY~U0sd)wiJ%@6R$#mr(&mB|SwHz7+W3Qo4lloI<(Wh6`Pr9|w z>h$Oo<+Mpcl2rZn@NVDkMP=t(YMi=Iou{^sG!Knvh>|WV-Ok)qr|Rm3E8|)^`M5D3 zCzr2n^py<9Y=>+`g^s2Vot>Zvi2}(kq!fyIgvkNvD6wAX@02E7ZTP}^y}@8`hmcB6 zh7#2DArIteg)5v~Osn6dPll>}hv!uv88BS!M?a?*ZYw3OvibQpt|cV~>ZCp~l(1Ab z5`%Kh=J^gV7+}AI2;Hcs0tPOD+89rDqtKCzwIV3C;_#is4%!rqrk*ts3Ya`RC<!sw z_xJGg@bxk}I}!tR*A$E-+$Eby0llpcON=+@v0p;Wgaq1bq(D}AhtkP|X0B1Iu2-j5 zR8&;b?71taPFEMvwnZ~nEKu*u*2>EK*F*fy&N=frY_`dMrB#1aKbSpf+Ol#!p=jJ# zaAs@BODlM#K51e}st-nS2lx!C02@SjA?O6~7eKsdt}L`8V|6A`h}jTg)(i}A2DBlA zQwvH<f(4}4$Vw>0Kv14!ogWgrAphGZ4=xYb92GLZWz{zIj=BPsK|$N9TJlF18a7wo zuJ)={52Zw3P^-I?(k(Q_h$6Cz=~;qbU|-6Cz_kl1uwY?2L5$l2%PiHAatDEB*n@Do zVZmaz0bm_=U0o@0^>+1gcY_#rq0S0aw~4?bBZ0L@_0mIo!}~@-)SJ|w_Exv5-&SuB zsC<6*-o3N3ReeLf{}DuVg$;dc|Cmi3E`EH0iWmDd8n9|KkY#~a!+<57%u<D4Ol9o7 zz$DEhiX_WQ9%u$7dQvXn(<C(@m1SL5*ibrWov@A!#9#~07-1d7Ynu*FC=9X@9+5DB zTUS&_ecyDe{*Xmif6m&v?Xbb5ZvIehu(tZQ57mlVn05gsJ!x)f0!WCf3zQw~dc>U= zjD}j601Pa)zXAhuT!X+v;}Ou@pVNa&#O#B1xK$rz@zv)ms(<}+a)-65CmaDvl0i!s zKudvQZfDHoPY~JxF)<FW5(c&c-c)2L0$yiB2w{e`!_m=$m<%C7I?u?EzYq^lpb?jF zqy=#axTFh~=V#Pw>S7d@HQfAbc3Etr`T0N9{PxxOH8Bt9!L4cIX*q4}P218ngSx5D zJ`PV%-&1RR)IZeYaRIcYgHWb6T*+SnSN^22CDGr-*-j^MVn>OeueX<n!Ohi<18wLh z!Px8tX93hDD9xFt8w^G;B=BTN3^eNWu&5K8F`Q^p1(&wAHFK<BCqYagsOn!Us#C<L z+^DqFPqnAN`Jw$|wy?PAJ=IIJ5+Y6lu1pYp7r^C6>RbHalq)b{1YD4B8im_jGZB`s zO>dhm6SKXTz&5ZpAhOihmw_11ND?fK4DOJOl-q+E#Ns#ukrd*FFd#vi*_Z;mp?!J; z8A4<zK`cy*R=sd-v^^MD@muAkXEJ;5wW-6(Drli>E%mD^`S80hK2he*UOt)6@GGsw z@nFpDN19raT^t=md_hNv8({FM=V^3@|G-6P>F=@ZX)ydrjQ}H_V)u<YY7^hoED#OC z#L8FG)x+q8*VHt6_cb->RW*O-3mOHwz36W)rKR<%uU2obS5o4_WYu1{t~U6jJizBF zXu!c<!j=n*8n|ILBO6yN4_$#C-0vzd1p>egSK_KSBmzG+Ue)%$mQBTu)90?W3@Wx+ zIHUN}WQHyh^97J(OM;iDi!-zaXa0Wmyqz5Fbas%pLivMZ@Rk+ih@d#8nRQ0JKEzX~ zFBI~csm@SKW6%uo!l!#deDW1pZ7@@9AbSX6sHmu-7Zv&`-K5cmw21yO5+BtE)Lu4< z^DF%$U)uPB61Tm~7hWXV5`n<62n``H#HbUrYAVcW0hcgA5Cg%YyiguxG}ICbKzkW7 zja}uhDk`hf6&pO2?3hwZEzd!gtg7(~K-M#U8bpIXMmi(zngdxP;;#QQHbMd+)`hY` z69!=}RFN%GBIl^f)$8hAbra2_J~W69tNi853*Uc#;p>O&yn0gYV^cLP=r*;N`XN(k zEA@D_R}E3$hx&mJrOEh<*e^YdLg*eizC_p?aJyNm3y8QC<T@msi2p*A!4bEqAo$;u z_;`D`gW_ep6zwK-PaL$mWUiAALZ{cN^gwp!9_4EFJ@u1XB+<kb%a^ZEKas5uPo4f* z?OKPU>bQ*)CvMj86DSV{ehiSd4J@HTS=+)lu;~9jj1(?xZ4aiCbuS6nzd_iN=`?Jv zdMK_a`5(}BQa#cC;)I{v-2V@_lf&e_BnUOph$x#h3yDbq{yz0wK-N69KH>>5ku+QF zWecg+VxuIoL5LaB*i-LHf@q*lbG>UVBN6%cGQ!B!g6DsWR3L8L@bN=}!eWa?=a-F9 zPt_rpZ(X%ywR%t9`}xVDEe*r0)5oS+6lMCRQ6tAMQQc~BT~a-+Wa8*K;8_u;D+R6_ z2pg#Z<gf?AAM7O?2|_`7*+%*^>Jec^*vL(Atxb)+NLYwaQJ6j+$qOhom~~;H!HEgM z!cLb4tqh4?HDLXYx8A?|K)v<D4)u?&D?*!W7`}4%s^j0QRW#^_*Z=4sv5TQ`vxoL8 zjcsy$i}lLzT<ZE+!{#N$1LwvhU)lWDw?o<sK7w_LxWNrgzQtQ&HB|!nmMVgMP-uAq z(Q+3Ni_@e(s1{$+1RE>?1mvh@fYfR=#1W($J6zTG1RB+2E^op-I=;P5(`fMnR9}H_ zVK;$mAv@}MySXCTf>&gyCN~fX6;TS74H~tDgy3r-!da(eG+YSf5-(JaKv5#D;#up8 zW96GqLuyo1sGmH0q+Y40(6r5ot#9qz#w|jVR-O2Fb@ji+xozEe^GIH*@ol&z#1(3X z!ukLdzzG)43dPFn)(j<M5X_;YUh&Db8pbSI3Ue<rPzj_NGwCN|Rqr=d?=ke8+{jqf zY4m7*z@xO(?fDHk(5-e(Ujz_)V@`jeXMNqAoiHb24XL1Ts5grE7-R)6P@raCG9?hA z@o@Kq-2<WS<)!&1@yQ08o&ywS9mKtW<=%>;zDgK%+C!bg75}$a(oe^#A6nI$K1x0H z+Ftd;vGju6$gAr5Vfr?Ir>f1-qddr~wAA(ab^dtf%qkZ-$W`cLxc0KJEqqC&C0t7k zy1PLwBk&K!=O$=F2zKE#X+cC!_#i+HT&6nBYXhuS0gEPbCf%SG&!kt!0?^R0^j|a8 zV!D2o+F-PLN&RfB8d~DX+OZa%rKQeldwR&ZwA8cu!|KDHB_+=EglciN>0#m1wE<in zB-CPdcXJgm!5qV0p}d+x8P{rHI86YF!zzIlV1uPr--s&~xgKw@G+IZWOjff*d{fPt zM4!lw4ApyBS3_y3q3X6;F8G^{<*o*S52Pw3m@d#W(8tb*4Zx2i;BDA^T*^ZSg4eW= zlI#L&-A24!LA)ZoDpI$CvqOZ^M_^Tpvl(d<Hr{Q=A5XY_^*b(a@>}K5{L7@7;EshF zKdx8LFn?uQZDfRFcw}%vlT6D)h{y>2Gctmlld%1n|IwrBG&)WG?)Q?lx_7j3f{|xP z0o=7Y2||bBHWD^kPQnmR&B5=oymw{m@1NWF!Am_u*Swe)9xNkxj|Mgl>nIcka$Ssy zER2ZAAod!V7_T>b(dlaGv17`#XKmIhGi>9uW?%6j%xf=lM$kC|{z9=kL%?0ga|on} zA&}{yW)AADK1?I$(1^p^+!QzV75lQf0j<b{g$vY<uPKo9IQ!>ZjEuODq^~OA<>ew3 zgYRTZN9j+H#S#&@7~H7MuefWe8#7Oir$24{o!><_Nr9d$gzWa0IuSG8$mwk9;DtnH z7<>_35O@=2CkPD6TSTrQArShn^=`coXHgW=%?^n-VGf4`6A}>~91{|Qfy_vp2ZuO# zL<WY|MpzK)jE}F4T<gq<A|~u<M0N%WO2iElZHa2`Ywy6Cyp{i^_4ltnnJ~27NV9QG zyGxVbxkFi2^#}bon=egVm=l$0ZkxY#Rr&Ukey@fGj=I#W^|8IxzZt_l97~q;P2E2t ztF;j9tmYZkm5iLF(ErUWjUDXaYdS+M`T8(;3#kz4(5#HPh!DIM+Vm3sW^Lq1q?ODD z#HvNaRtpqCwu622S~Od4OReklHr*s8->NKHm*Bn=@;83<pffj5&s)%YYDh?F@A-4- zll$teE}iGgQ~gS-H@E4ao>2cddOxR~8q_}LbcNWSUdSK(4EzU>bW1CDL}Oth!E}QA zi2%HYc-$xeXth9!P%NuW8BkJB_+c(W5Flq00R0biCPHaKH8ALXEw1HNr&(bUu$KK- z?t^t-z3ZpnpZ_@H({%gwk>=qUYiG}zJuydF@D)wC7x6t!?9u+=&Y*}Jn<KV;gV_X( z(h}g(lLQOT)zt+=;jE=P3|x{$L{Uo>2xJ0$k)i`Kg}Ddv*Qf)IYluLmFsuY%!uIs^ z5~?d+2q&t=y_5A?RL#ia5?>#5`o@hjdCL=oZ>a9C{$|dCoC#r}le#aQJH1^8TK~Qg zvs+rH(IbAP&u93R&?gnAv)a<9=~?%W+Ti7PfKyLfEr`JxdyhbpFiC7t`dq}gZDD!< zDncUys~}@<FX7yJ)%UKicZEr>5KrofaFZNFfJ{WS-HpaTM4g12jldum`Heu3HEVra z{goPyeSNDsmGd>P4P2evvFZC;1}t!6^p`0{8vQWpdm67kyEa)~_i>ZBX^lJbGuumK zpD}oqRnUO&XTL<o(^pWca6E<Qr^O_M=n?qzOoMv?jG`<C_J=^TEjQ>(d<`NnptlpQ zHdst>R&DOZXhdGCR`zGUd1!M`MufL}yl>C!+qZ>*!gnltZTEYQ4yz<(aR1kqRXrAB zpSx)Lt+waC0Du0_hG`ayg0O2yFq0K8kf$5OJ|cG<KeHqRfKY}S=h%W?0-G9j)?*?w z3nmf)3xjRHp$0TJS>yzSQI}|=23v_o-R}3g^Kn6Wg8R1nS34cfh)-VCde-E`6?q@s zsVrNVD@dTn!UfD;?0!~<d4F8K^e8gqb^p*6uMJMmq^5fnr@OSHk2AXbgx{6|UQ?jE zo`7yOdjnn>C8+gr*Sk1lyAeJHIS>Mxt&O&Lr3r@;n#&ksG<(P%BClJ=^N?0HBTviC zXdYY&T-d_Kn+NPUA+R}mRF~P2I6;u&Td?}FPCYJOt$rd<%3S75>zG<SS@WkEbQxg- z0h2v6D*O^#IRW5-6@=)&NK^qLZIA1MvLahm3yR<sgw=D!)R>GGR#sxqWP~mA{7U4` zA4Bf_0vlon#@B<MMRrQ?su&)NMV48F@i9JQwv31fX4DfE9LA6!ELi@__K3xE5yaoI z>vdCtpR-GnzEwv|tW;L!Za-vizgE`e4B*fFN@=}Hj8lv6&6wMVw6rw$!7K!!85l~A z@B{048$I-H&Io28dS4sNz?W))c@Z}9gk23mfw+x6zShQjIhKK_UkWWO`F;ScoP}Iq z@5yS*LF%pPVh7~cORFZ(0GLlc>Mpgdw=kay)$L*nq;Frq$J%PR*Rnf8YT7Wb!J*;X zP#ZO>-EK@)JGKxrwvi~_StYt$@JFmIhA5Gk=%|q3KvR7Y7IQ)zfapbJOjQ1mZot3T zP6R%+zzB#d#29S$K%U&Tsal5A)Asq_RE7orNpf-6_iX2cEycxa!{T?0*apgbQZc-E z@Kgr@<jA4D#?;4&jUpCy%pN$fPw}^RRD%GVKG-yS>G0|wZRcwiwo9v?sKq3kgGU}} zydG<bhE4Z^MX(Cg&}n32V{_NP=Z}Aayg7jF=8{xVxL0G4kz=~g40{3H8$J4+zf%1` zK*O9DPw3jZ8i77+l1<kH0iL?JhLFy902xy&3XN1q7E$wI&=QRZsuME=^j|B*dQs`d zO)9HZH*Tp_l}i^dShj4@q9rWsAx&1#KJt95o}-D6cHO+W%X8=L+dDCDD>Y9l!MtAZ z2oc9X%t<2k10d%l17)%i>I23$NLOsB5PF&rwkcvELG(O5#B2;Pi)frdlN%ad-1WBX zeVC@^YIo8m{aOJ(9o&=F7JPi;X63-uiNFmXzhqJNgpiQ&Jr^udZ}>@D{7PrF>!g05 zJ~zUQNJ~}c`<3!HkNngjwfa$7+jFoVfG@y38*m$8ctJPAt|9(@h$_2^REskLc8mk+ zI?G1W%RCzZBRj_MDzw0*&CvN%NZTac-wNj&XZo#3a1)`!iiE|zPv5AVv!Ltfu&^<m z7tXaw<<{xrpMN0yO**ti3KaF0Puiri`YqZ#I0~kR?Bga4))-5qkqaAJgpplP48v0G zDX|EVQHNa{x0vBmW2X}XYuQ8>2BlleoVm1{A!cq*uSU*3BRUoN3!wPX()Hc?>ZG@o zwyD+21$lAV#{1)7XC1=awJ{1Rdx-i<Xn?vr&R=2_8lLLRtbdGAz?caQ3wt?6A?h!M z2IebQn1Y983@PYUcK*!0W0OyHq$@&##<mzTen45}nOg@ZpK8VK&IoGIr<J9hf7I&I zCHtEs{kF8eU-yhw+4Un=l+1e9(!>ULtC}B~Rc;BogwKr34x>oWD?}+mvKJ|B5l{mu zLUm}Hss&!Xh?iy)2%~_)Lo(ayptM{j!a;h-bUod7{(Q>>pH`l}e#J=>7QOYB+*18x zS@o+OQtaiq?p{mRvZc#FN|eOH_In*Ua$gc<Y2b|_SvwukF<K8X0+Gp~RGZzFT!IA! zTSQYOnx%)iG!w7ZysI<!c)$2JhFDKenNnF$JmfX=(xsJC)Xz8d?0fqG6}ofU?it-X zv5_{V1|(3_CK0JUV9=9)j#X%2KzYB2RTvPf_%lj?_`tatH;{?HI+JeBRadT5m*&#V z{HRCunogZqAtDv7RoQ$OLI9Yr1?qEpVm^NYI<1XUh}Z~3A~YHNVMqtDa2Wy~NpXV_ z0Sb3RZG-}|#=kr_57X(mEkg0tl!ac3-_;FY)mQvym(X>6)dw3dMJo{(HmVQ$(RKW& zXZ3e8XEJMb*0N>H7Xbm6s%~ugVS1=~7~kz8f+#kdX1ul^|F8Ij>p#UO41ZCoT%>nX z#?Y4PCu8W2{%1eQr*Dl>KcOjO)ttP`m-E#gC0=w9osKw(69Q|pV`-_ETB?rnDk*WK zZt6ovTWrFtwwGSf@P!zGuMe^oB4+PqkJPBh%KYg@3Ihup1;VYhJPaP5A;GXb5UddL z2IV55nsr?pWda@rywWTA>c9r&GrZb)cqrW*TXynqsIDDA4^286tlXMR5Avg~f9x5y z*->6gm0_(%@KtW5r5@Gy%h)ClZ9hjq?tB9H{x2~MfCsVqKVlfY=(}#)tG2SX>KK#? zC5RYC8TZ&mQ|D-V)KXo+HYzRP(}h`r;ZlHf+*}#81VCQ5#2ymbS>OPA4fzher>Ln! zA&~Ho6NOofx*&KLq5@iExJ4Y7jsI|KK~Yh`)(^vnzmna(d-f~C)fLGPcb*?Hb@}9x z7v6f1Jl1?@)`cOPqGR3|e16sec;jO1RqA6J{~`v0JECH@E(U_+5E3Kn*Q<{eQSayr zm?vv63#$~+(Nx%uM8Hg2;;R(Dw}A%E2tno$_43R$5;9qX)&{&V>jkv&M!0$cc;Di_ zz53$6;_#DO3x*CY*n0A5@PS$9hi-~&uxZ$ZS%=JHlOMcwVdUiHQ%9WN`49mv0rNz< zRJzB_FiS;zR7886oe+wFq(<xwY=`=B>}F?ZFo8c#TBE8%D*(0Gt~M7k%qE3v{quW! zXXGyL-n@UKw0;ZUnw7Jvd$WG=srl^AYiCp2#l{x3cc1q`MrM4>sE$IPE>g>AH_!@4 z1nO@qh)};=8wL^>6vC8ttHhsL#xGH~3t|n0HIBSW4u!Ye)zTRyqB8fcb?hBcQiKw# z|Mc!T^1fUaKgo;7ozWn_30PPLCH0XE@GywP8wsYte|q?~f_}}(w-x+*{l(Ak*nj1I zCVjfHa{rMd`zs4~H2sUCKlz;Z-G7JDpfeGbG${PLYffD(e>(hBB(0=u#E?QoM97!g z*~2-pvsdixkfMfCAT-Z`Do&0ldlSiOdwZ?O#v@Gv@Pv28*4Pq&p(GSmaeV{yk4W5m zIHT;w3v_{apfO&D2pY&I4EW>PZs~NjZ!8!Bjr1+0zCR0d+fHd!BZr2uO2vAIo5#-J z?S%JA`wtl7Kr7hbmAxvOZQovA?tE(S%C*$x+`Z3sDdR@1oUJ}yEB3K(&3AH^^axf_ zLt?SC@bPwcL&!4F*Hu_VL2&JnRpF`i^k7S~&c>FYF4Uo55yIevE{ll@5B2m2l29^j z6HYpaC+!W3u;f~EB-u+VLJ<Y~RMd93i&BXoCbjH%WYC~@I?gC7i%V>hw5)7#y90Uo z``a&DuqvTRV(g*?Rihv6+WF|w&Rvg+Q&L-{%r0Bd;n0ABW1UvcUzXe=rSZxIuXj2! zsQ-Zui|4b+$JF1b{jqnco%#&4)eLdqWbkwl$*`oF#QQ7tK&kd39*jU1L(M4x_kve? zAy5mq3aia^p!W8N&1%XjDA3mjn}O0-1ZYJelulHXYyUL64<)eLzn8+<a`Jrj0Bx*J zr=_aqYN@Z$@i>yz1M}&-J*hAC?Lm*ojXbI=CvTs$OITgICT*Y0ni`>1tAAtmLaT~B z5%NgH{{?TEEhbQzkTczd^`cd1itLIG$$WI+dKvEsfWJ`d9=}Sk*JJKo^#eb{@IN#V zWA#w=(ge_GJboJp`x^=dvn2a-iK6ls`}h)z0ShS50ckS)L{M!U%|lL)iU<!24hk}a zD~Of9C?*ODZpk!r1=1LG6+#w^Pb8kC7X%7{?CBYz#Wsa-_7u(=x=R!CaxybfY<pe( zTxQ2Um^*L7l5-DkztS^3jXK`?0pUD;Y~%c8E9ZRv<VN+4*lxjX+syqup+ivHtmSlX z-v#0E^ZM`l@ccD}EuK5Rcke+hTfV!m_reBo^YgcTeB-P#Zo~NA0|qqBIMmI_$Hg!( zV^BdeH!mlTf$6<PV4IOO(hpqZ2Lx_CEe4n>5cgUV=OuZS7%vNcYxDKjYQ)!HOFx`B zgC9=QYFg#*<x{YC8sL|hdRnqwM9>!)Wstgf$%x5?4g!2xB=I1N1)E5)ktF=ql1`@; z-f6Yq_Sp~yMtkgHLY!cpAQOi44?&fL*%3P4%TuU$p)p`0zrd!@7|?nlZd%o-C>kaB znXy15UbRmYmPmWoZ+h>&P3x@^Th_Z*zk-5(y?RwU(VVAGXpXw$$y0U51iAq~-W7&C zOTPNGdR6VuvX#~AFYg_{`^tuuO23{9M@<;Jphy4N>Tjs3DyH@z`XY6;`V7C$WmU7( zO7)c5iQ<O`fX5<skjtPe6JlTBFi#I?pkOL12)v;r-j2#54<v(<K(sH4;B7HaB|Rt* zWuzg2kwKC8z9|$@aC@Z9{w4};46Ch`6hZKpLg1{2odXXX(Q*8Y9h=LVHBD<<L6w~g zX0La0QRl@MyT8^xyBRxajP+@lGO1|zgoKvqNsXM9{xcTMQBTL`L`-cKJUlffI+mce zwJ90P)A%w`+uC$238iD7euGtyrRg=_2&)9qO@x=Vj30Iyw9-+~3h5$DT#{jMH@Krj zR_L;cbUa6<3`=g&Ui{>f#S?caeq8H6QX{?=qv$^LKkw%rM8ZR)qqKKc_|eMhnLHK0 zaHVVox<N&#r`BlC5gtw)q#HC&5Y^c=pc394Lj*;~fN;EmAd30zdlNecs*~*g@)p^j zaRG1dW=#^~z2m$a`3IuT6NR24_DEjP63#_svPNUb+@fGmd+Vy!$TFI3c8obpC?*(V z=05*PRuf((I{My9>b+)HYD#J|ox|()Qd-B2Yg+Z{)PE-X>aTP~oBs#h?N;~jt}{zo z^sDbv)V^_pRz^2tmx!b`=`(1{#%&?s1tQDk06z2|Z8uR4JhZwY`%Dg4Ci*ing}=`x zf^G#Kh22scHvwNl8;E=Xeq2tVM2njU284wMZcMHdc1XcYSv{n1<;udMRWsTqCbVvy zkl0o_QM7h#QSr)^#mQ~jBqz5QsTIuC9;|Rf`UP{jk_bx}Tp|z;R1V%(!V3d3%Y{_X zUT|<$gsmk0+{Ak!qEJsG16ZC|0h>q*)bjo6EIMUB&8&J4^qNzy4xsDH>DoWsp~VFr zMzXc+to#vTiil=HE@^I<C@T?FT1=~C1r>G2DsAjY)5W_oZo;QP&e67!ut$*tsa>=V zF?)8l+Dc<GA{&Fl-eAg(g>%>Bj(MHYA#Cjosx)gK8JA*-QwA)UHYRJtkhzM0V+dQ! z?#QR%i)LH8;HSw@<Det{fB&8gj0;8T`2wUgpaZEgaG945RWA*~%z^a-eCxR)I)mDm z2pVB8>NYfz`zxd%Oxq^azO|_lWg^{?W@(erICC>o-Yi|ZqjgH__6L`h9#&`t-r?xh zrtNHLWRrxbCb8j4-|^#zC-?U8?w9`RlrgU=F-@Aqwrnh1Hms+gbd1(uJ+?d{xL&9c z_y)E-VZ0Y|)n0d*`pa_pw4zqozLSbr(=FJ>egw4=NKts8UV<|pMd)jWnhDLh6ND$C z5(qF+{5~zbW8?#0B!5D~KmmUZ3TUM%d{)%7Zf%OgPgPW$8eTA9QhgEOR(B1vqz0PR zMsiCLQ-80lZEIHcQe2=Dl-IA|5jWwdqgtO(%?yI!jK~BQDKaN@H4Mm;I|18n)J+1m z5idmW@Xw+!*7UxrQhtvf)ylw_9p#^WO63=2U&A$=ZDb?pAcR={IUg&c^K{VZ(`>|L z;CQgwk#58{T?yVv5wwfo4Z`7+iMPk<Twv|FtKL)6M~d8%*zqup7{ZdNhf}K_8<y+Z z^la19l;GGkD{s`WMvY=ab#ra|(GR~BxBxsa6Qji)C9KqfNwqg1^KEbHnc<#<&;@%+ zX*7GCEuP~gzK8ef*a04e?}-?zuf-d8094NxA_Jk!x&W)jGd3dpj{xh$qZ>9HJGy@3 zv0XVmyXE9&XXi@eRvi8RNP7>!sH(1O_@3J)J()}<laM-@OezpU2%$3xz4sQ7DiC^? zo`4h;5Rl%a1(c!!c0>V{popSUL{Th&U9nd(C;!^#-bn(2KHvNMzDjrqnN#=Kd+oK? zKC))o+QWy}_8m34&$OOn#!!@xw`i2KL7A&OBT=0OzQ${GPo#v`=pLvmqLY;;2R8u+ zNxVj2-HN^IB)+J8k^KA^^9%6{2@1sDvqb1IRKM{YeBmqbTj=NFYblkzF7=f+;MeKQ z0Ya#Sot9A?M3rp_SdfB%Z;zd&nkImvA~%5*(`m(Ye7am@sdSl<-15~t5Rbv?uv-0+ ze4qL2O`kcPB}2o<{A_&YDFt|y)ZWvEWJjYJvA1+Mx-!ZZg7IPb0scrh;d3>7t_sqP zil_=%62ydXr*xenKgvRp8M9gK7AKxz%ylNlxD9p??>WAt8NMw(^|Ue_C*8u{06Ar| zG|w|PQIWw_VLG1BV7)F=13_p-whIRiV_+6Ua;WB`NG>o~4Gx3>4Up7;F1WEi8*Z`q z_kbUVmm@e>?-2rE#?c}ONSAM5k@jXy8q}|sQ>S)vQbK%e4SVy*=3<TPp@|qPPE#X( zk1|zl44ZA%m*AuEmMchUE7eolVucOBg&0pjqyJG~f(i~%{7fz)fL7r^!Y7Aar&4^m zqg-eB@NN@E7tViCk-vWG<oipf<wl{tMBct?V*eR)`iz-0Y_O;=DY-B?xAy?H`CS@c z4#JF&VK<`Tp2C{PVqqMSsPWK<osPQz4|lMn`}tVu0Yn53ko@!jzncl+mhSK*iJeXo z0u)fuKNM7f4kWnY2xTD^Am}f7sZI-}@0?0%&Vx|OeGNo0HA3#}eLhkS2z&I#$6Nfo z=Vx~3_2s_oXo6N8p~Ztd#%pi({tR@fIHv4uNHJFEB<?DZn9r2=(YqxObw~aR)%-B% z(4u?`=YVx#ZTR70)|#~`=FhXX#r!aT0qWqLS?6Lzah;0!ll;kI){#Grt%4=%Qn3>} z((kbrZYf)8<7pXbgRW>MJl+I<q!EBcP{K}wd@hxZh<8GyC~;8D>LAL9;71`~c16~- zrHYI%DzBYD^H5-yLg{`{<&c+Si43=+G&ePs5i%2Qb;9}0fqRUI*=`U~3wN{{vUcT& z@eE|tKHJ)~TYJxh*<}Syb?-ZM?rC-D$MX4kxfopCsRd`gH0Y_dYnJ{xoVg#jGf-4B z(`LUmf}cAi&%fA?m3K*YGY<+t-fp8jn&1R&Rh&)a+SNy}_ja63<V*Z4$m%c@_=x-t z?LIOnxVQswHIX@y`{OU+2@#M6xL)y*aa5m~4C<eey#o=??lgI;R71*qRVb~I-T@tt z1%Js@Uj8Nj1?dTtLj|u|vt|`B*(pb|<hz%Se!DHUSoz6&Wy_?=cq)t<f#bRjkr?oH z2iWIoB&-(UUnXNgB&;c|DCor*?hH3MJ5DOt5P=n}H8Ns`&Gu#5>*2Zc`4<S1HkN+# z{Ps8IvBGzr?0LwYnX$0RxZ(VfWy1?bl^|iV{gb~Rd-R@<8g}Q`mOi>KJ$_qkoq=6? zvV>J#FLxX`=8=t95uBSLPy#DOKBczQP%4mydIrTtMqspcGu?`6(Q5*QP*8q?q!2V9 z^!_18w<{|A0#$Xi2=<f7A!5Mw=+rcBR40o`&6_nUXk3t+lhv?J!}Qc-S7JOtHo<{- zvum^3p+v&?Cz;3>Mj-&dm7Gy6sA4{zh8A((I|U6s-L~)W=O2AOa_GoeFUr~%N2fed z*K=URdtZ7R$?W0HMGHH(%zLrCW5?Z@S7$7~TNyBUNg(<I&ae;Z*JaET>$g7MYxK<V zox}Ad&vfh5p$9L&HeK6xGB0OItxlVIH~e5?xAu1_wf8R45@rcLmJE%LZ`Jy^U+9=c zFCE@xnI+>5k_o(tsR1B0LJANMH$rY4H`8x7;iu#jxCIQ?#!Pa;X+d@gkVL9RSQPEA zBhP{AQD}R>gEwPorGL>B{^`X_{A(6*p~u>KYDCY*{KrneC3nhb(&7FlUw3+$xpquj zuw&P<MSC@UCV%?%p}(ONGV1MXEY?#`8(P|I^N3{*ci67T)>(^2l>hCQ<kzU{J8Ku7 zy7q+F`}We)Y8~}SoB|7M5b_ZC3ZMY|ejG}?B!~l4RqF(>g)F?LR#z{`b-Ljr5p1f~ zDX*b?!6%)>KXR`Z-#c9{pEk}`VZ}@}Nj+R;ll*mAlVF&jw2m7}E)J{_Y!d3&EShQ= zf%~D15lK$`0Oam07GLhp73qp1n}qN~q>Hg!Fhhh>186V|ln@y)?T~JF!ali#eX5^J zN#wlYS?%T*^&N~%a=n2W?dA_3G`uV|Rc9Sz3zCsgZsv08{Q2lc&Sk4aayinr=4|_~ zmQ#W`JZ#OGw%6D6TUSTk9%j9=uiNrE-lE{3Pf1T+mZITH_XZb%^3AP01r97AUSO3W z=d7t=@I#PAu>#No&qlBls`yG~RWAH%Bki1mw6l*hVer$c<(y#^APj?};bW^sv!dMf zLtp>old`)vP|mqjzOZt6FC?93An6Pag?C@ewv`#@798$&NvwWv`Le^`b!y@LtwjgQ zI@9=TW2cY9j=Eu~@P;NiiM38lW(%cssUE@)?`Q$uO_XXX{h)4Ru>`dU)W{L(=BMN8 zSMmuYDLpMU1wRRtJE}p%e+VjuWvwDG`S|NNH@V0Nk=4boDD6NTsU0s}uz;pw6cFv$ zLG>=8uBd#b{E8PW(303w50!r+xDRG2k>Y&l6iw|E{_7q8FwF^EJWOmj;v1nxM2z1m zeu&6gfm?eEKcvv$hal}t3>+idY~<*6;^#!sjYlyAc9EgJPGynyFoKa(z?1aem{n7h zNE8o@%?kPp%(sv3Q;h-R0)9fdy3$Q-P;q%7JFyTKw(sok`D8+51?8id_hAV^M1R@K zJ4O|=Ux@r7=0*AwRKsJZ8Y9RYQOX@hi%G~Q11*(gIHnRpYOp^fcs^#Wye|ociswk6 z2B=%f1MA%MW}tW>SPpXc((Bi$l;_5mrJFWk;kE2o-n`@Pj^1y{ZHZ+Uvv+5+3Sym$ zbrJlVaEgaQO+gi7Bq8J?;$K02LfK5Z$coVi3RK$sIPCW$YuD0NuUrXgpfalA?uOp? z#J+x#w>wWBWPDC*-a&gG^GzluN0Ku!Gz6O|=BrAmaaSYZ;wc3veP{VNjr6_)8mH?d zi1(nbMY-L%RSYmjGZp1aMve(aSJ2mtN*?jhQ_T()H9fW|p&kn5T3Va7Gzxl*r~bws zSvf+-?eA5@oLZ;(jV$b^_La+93Jy*o@~6Y_mbz(wkYbkHc>faO71%ad0t^-7tK>z1 z`X`1;-WP^yN37<%{^A)VVy#ZL%^YSm{t&jTko5?zzy0nfUVeOIVs0!(8s4<!<Y~QT zrO=|{7_aTx@2&UB%W0I`HOs)hinL-zeq(QudAMb1a>cin0f-&JkC%FRx;vSg$SiWc z1R|)a42F{oKzJ}BQn=50KM=n_v&5B$W=n7Yz4|?22*j%&AB%eZ<k(E0j0i$a*V&yE z5|!zsWQ))bptnx=(Um2h^r~YwjK>bxsq$+71ug!<RmlCT)rv04^6J%}H(KY8&5h5k zJ2-3a@mB%@Sx4Z$b?|S;ApdG5p^Gg5LTCGHma7-|nfI>YzJRZdIZD`%B)r)T$tTvC zza`cliUSgf&=LEA?#7D0+%LfNWN?Ta5PI^tIFLiBn_WLQyJ6jiZg(<BkU%0U-=BZF zDzsT*&bNfvm3~VRQ$D%(l*jYxID=ujehD#58^3hl!Z$sh*XDf+hSSOw53X9h{K1uK zl*u|3uhIBnLnl<xP8)U{J!Ht}>bxhm%%q`0%@?-s1URTRx|;~L0h7W+0jr=}DIEOB z7DixdcP9hS#Wom8R*ShAxTg(E1<N$rRx`R!e_@u?bfTC(r0L^^-nd9-y~4{o$mj7n zf~`~o_!;=F2+DEHiBKwvs3SpMfW_)YBwg5D6W@)7@x@8UzXD4{Qt_r!P7lLP1G4AH z_na`9i!H(%x7xSw=}HQ0j}ywC8x@sTQDxPsus8yE-=O!U?bjQM_ZjFCDj$IOQGyNQ z5iYnumk=aZg+K0egGNcg57HNA*n?1&6usbc+){bhqk84t^mlr6Yyaewi7ndRss65W zo6!5Fta~+O$WM#^QHF={5|4kkddN3kAm=CyK>%a=OXeuy8<_-Mloz=%V4{7Rj#1S> zO=t6FMqLq{p%MF<=hxg?c(*I%cEq~Yp0G(p_wP?E*xKhG1UsxLo<PJ5EA?R9E7&=V zkR>KKBEzllB59mhb->4@G!ufmBy@U^tutv&Fmo=vT*R@VY#TuV)hnO~$up2_Vy&uw z>vQhjFDtK}6V*@`5QdHNRY<8<8C$nTd-pSocd@S`imIb_@87@MsE$G`g1x^>U5WQY z+<lEDMZzj*PCFv8#E<|*2cs1tR#;lXa4>FQNBu1*62oZ)EgXgRCV35G#-IuMc0~FH zje8<)`#;E0PPL{!vf*M`S@anAP{B8Iq*!m|d6^BFrS00LdHci`--a%Qf#80Xga3O7 zzK2yx_BcaBEC?!y<0{UraAJJ8BhD(W@jofQ>`=8!gBVtDeZ`AKTwj{4G_vA5<tMd^ zk6#}FzX2S3;qD<frpls%-5}LFTF@;PcLl`FJMimSU5Om>R4NT{BCH{IHMM?y8;pIb z6ETgfeg<`k?~i=+sr-_ntbbtmI`Hd{J~9OSdLA-I?ZVIgQ1dH(hB5u}Y;E%!jkD)B z=v3ZdcZn7~4Os;6G1P1FTiUn4%TSYp9&ZYq?E+XenbK8qh}<$f94(FDak_w5<mTnb zZ|zw9(DvV_tKR4}YifK?>x%wz*W|aW{|qduxLac=5{C?)`7^+6&|L6L*{aq1c*S(@ zBU+y|;lKS7K|f=Lx(h#pYN@d|7Qp4?^WZr|Vw&7BDi6YEp}a83=Ax261MjM=Do2kq zb>{<1c53pvR_)ui)(+}ZSFM_==lAH5kH3bWzd`+yO~TJNwbhUS#$~GF`(RL$KKMZW z5-K#Zv;>LORP74lH-~gv4ER5iMN4M(=`~|UuRb$JHp|Rt(j=p1Q!TdV<Vn4Hj~&}P zvuWd6wVE{(W2(=)vJ-e+Y?PG>z@oDPn?FYAp+6;n9(LXB1_cVwz7f9qc#44e*tFJN zYURY#uHj7X(`4YxnI-iG)z7FC8aUe)J$_i%l?^cG67@5sp7slVKKRST5DE~d9i&|k z7^Pra8QCuwYP{@}u*G^f-Oeh?5QWVKUx=JKrQY<yHk)!X8jqRQzrmh*=}okA1Mj^n zzjlqg9vGOPg>}POQaWkZ;o$^Oo*kg6fl<T1#}NR@1fDWwPg0c}hvJe)TvPak{c^8! z@{bQ|*O5s92CDHJ7z}<^TfTr5SL_#iK-FRxA)p?jpoo=0^2FQ(hY#6-t57{-*S3E_ z^TK|fg8u!|Vr!(N)QC;{HosS|d{6i8o*JnsG4ZKs_?Zl+>jkz%CmSYe!i;l4%8h1C zSPomV;NW3=(*PP5Lyz1S*go{Ozo~Z4_x%t;b^ZG6i!*cwFGX{^#p-7jjj{f~;42#A zo?4{s<re%D>;_VDFqC9_z_s;YU+%aYE=o2t=|1%mJF4G<8vyQC2&{^@9=NAqePQPW z15N1$>nbU&@DWsp8)3yovB6kSZY<Bp=UO(gj`@AtSXOQA<6-KhO=<$D9AiiJZr#ow zkr39sH}<e`)gICXt`wXN2b3+M9T!8X9M#LowdMW%f^v=VhkumMsb2%c()sV$MzL1i z_yLw#F&%4lN4-S2CM*+_ivzD?j`yp-vo-o0^ZRi;CD6{qj!394qz$13KJm_hyYxAH z7XAp|xgOk(Lj3`JMR*JJ2mww)$Vcl}HFCP;^iLR~M@m9z_%{zfNGUvdk}D@q&c0N< zT<|?U;D3mGf-jdvxf6V?=n`pO-fj+7IhJ63j2$CY$HBe?OHkRv!y*M@QxV3>1@IFo ze#8^N2IKhp1YFFh7NyFSB`huow%`fu1htgJy`fw(+(f{kW~nsoPXe%oiNcOqBqtb% zu-CX5q(3OKd8|8@4Y4>)S6nxS3(Z{eeS2lk-v^kV(uz-n#N^*yH=%bKt)EXTLBXq- zKpbMs#lWdlqxKKh!H24lTLd>#tRrCyRleLmqyUs-Twz|evAQ3}lBz2xtll*Ezcmz? zR1c$>hWUol*s7~F$rz}Nj0sJgEDZq=@F>J;`ZSst6170BMzJgV*p<<I-~_%_=W8bN zK~>UBs(gdnMBZ1C;Ag2r@mUspnoUB@AzUpDA<$r)C5Q$|2;mUj`1zCesHGd&7C>#V z+=@x-^YbJ8z%SG<RMhuc!-!&$BlIVMePeS`C`nn5f<2+~lSpfPs@nI4di#g&Jugr2 zKE(1L1u7uQ;vZ!N-iPoyo99aV3}X^%RY(NN2tH^T7y<(Tr4|_mF~90qRjvfoB7Enn z5-9MUE^Up-<a(P_9xz`rSDj5I`SiJ9w5nb4x#6UO28NRoj+cq4_)tkP31oxmsG!0b zo@k|rpbr=Ur4frj7tRpi1mA$6ZiyCw$rZdnk$V9bsbHUQr}7R~;j+Sx%BRsq<57Ne zwcJW>wHjw$^PV%#sCnkW8AjAe9IRldXfUCCg3KUgv{{gUprV5*JpidqH2|)b1sOxq z8o}^T515vg2!X1!I%!#%=_$zxsfnq;m+h!zB#8}_hX$iO)JS|2hDO<MJLoXv?EB;| z6$3)f0q>3;Lzq-~+IRdUYxJETeCVQ5{X1}3UIp+Eu)uHM;pg}JmHF*?;e|aHSlp+d zu!L3wakS!BKlzk@)|e23#>$Z6yLP`MpY%35w!8Egt$Cg#=^m_ks+8@i4V;7M;wTJ* z3<7KiLQbKB031r3I-GYbPO6lW9vx+BAdvSDH~{Xx1hGA!fO)woQe~ZiLx56hgHnCv z<3u31@(m638ov%&!LIvt%t7cP{3+YcJ}%oJd~^SA{9@EwG}bdwEbTWo190H?`_96p zwHR2^T{t731MhHAwO$AvLOe<^DhBt9I1da(7=}HHOtCsra30+C4b3c)S&0azK|0Me z7;Ff@Sqm<R{Mq_FZ$0(Y>BlzmFlK{3P(Bd@Sc}pJSTqkUi)PLn4S%83(Ju|l`6p3j zn+CAX&*mX@Fp;n1ALTvEpB#V;gAw=50ag(UW(x9IF-%vIU9zNy_~An16jM9`1{Ik8 zKpC+C0*!$yE=g%A&IJ6mSVAcL;I-UTB_cwU%1T`@5eV|~)o3bzr6v1W^{DtJ?luGL zxtoiqTKDdaxmNFoi<kA8o|-nj=Y#jDjmoe0^eD=M5g{GAckbdV+U?SQk@tn&Zw%<k z-s~~x`iodfSz5v8s~)Uz1m@7m(;oGv3Y1UuP-t%u<qjw;I+Gd#GLS|xBuI^rg3tk^ zjU(*_tp>^HjK~Zak3cDcMF?6A5h_et1z;ACPwFKjuArlhvu;*!<2SBcx$CRn4eK*~ zq4$mM8yl4||EFh7ojY#KLp2}lJAdth2`jX+kDlnip?1v^^WXixW^LX?JNU?T@A{de z2Q6DMy8PvwM%(92d~7q$cLZ?#RJAogE#k;T1xq+08cq!%2jYEHpcx1BNE$(B2l2Rs zM+rK2?qr)$2Z14ql&A=S2m$jIlc=e^`HN-zvk<4#KPWytx=TXawz2O3`9F0ZLnTW{ z`3j!Q&MCE09kRAIFtkB0@8X_4<&kzHW*buRotmM?N>1>h@p|hp^$8ZFJ~1pfR6sV6 z+%<3>fo{lViFssA*bIRYAj4K!Sxl_g%A6E&WD&HXl!I&rRu&~%_RDWP)nRMbnhjUA z?lEXc@%eKCFSv1di8^>p`&G-AJ+!U(!PV-o4{WQQx+v1!u1VIQ%=Y~2H|<|RlsWw? z`~LEzz?9|QVY|+s-(_ELIr`#GEE70b72hjAsvU7kgjO+@6XSLhIkReQAtr}ZHLWqJ z$yL(1vCw$WNDR_$X$hTTCv<kxL{g|e#(oPW6*EER!LWsx62J!3)2ECYF|7CCuikj> zFHL@7>D^Ojj-7J$?2MTY+%xf^7f@0E`}1$yVA=iWCAwy{TVHx$sor|%pcd_Wt?SjN z-Q5#A>O1#8jwxUcQ}}#^^k1A517gJy0-`nqt}*@)>`M`^;cKUaa#96MB|G>Rh>IK! z07xK17@jWJqZo5Is$`tG${T#&{7Lzp7i}CbPikJ2U8`-^!u|IxU5WIn7XmM{dH;=9 z9~v^uno_IP*tU<?>)o(Nx+}--sI_a`43@u_)zRn?Cfs0%S`&68p6bkCJR}x}P6>E- zkR3Oz20@%A`iyc%{4F%h2Da&TkutRjGh=*oPQ-uhblXHQZ#|io6p<5LGrcIc``sb+ zw+%b=QrYCGy=JE<xeaTE>JP>ycJ1Az&#Rx_cvfw_Vs48j<!|DrD^dwCt$5glV1YD{ z-zLNBmBGePDh2YWvJu}*>;oI=<I!^*CWBD`=a2~bR!C$RmmTy&<A|#9K0R=6ifkuI zaM|wt_D-_kLzW6%@Jow?FgUH1lz^JNNmUpN5Cu?*;HeQd2#f{a(i8g%BWqwRrtu^x zQ7XR!K*jE_S1Y=Xt!C}M^{3APIK_h6=Y<3<N{C#(RleVNcU%=esErV#IO(<`ZbqwG z9Cx_@I=u*^$kE1)HPyn6>N{jjl5<@xi4BnBVg^PI^?R`&BB5E=jI2`?i^Y41EgBY? zlkOkq&#WD53>gy34u@wZ1z9Z+;<67NmGzAtugX8vuPHyI`gQJgV@GzHyh-)zR04X+ zR9b_f;P^bIy$W9iyv#ayYRG(~;ssL*kOzcrF4lv|eP|!WQ%U6%xO6ID4FfQ)cFAsc zxQ%Nm1fP`g&BoSWwRY346)RqRWz*zID`&`)JR|c`TlZ}6@yEN@Ok2qOuC#bCOVg~j zF`Y+F*}Qef>~%Gwk~)rWyDzu5r$uf?W_WPUiFa4Oo|Un2(2i##ArH)?4mexeu!j!f z4iesN2>yZW4hMzAxdm7z1Iv?1iV3j>A<u+A-dauxj}Pf=r&_qH+NSbtWhH8;vei4j zYG>~&AF6EKf-}4rZ$u34S{QB+J{`qD3h``keoSx{*2)Jflk*KA0C@x(*<n+T1RrS# zQkYsKzL!jm`LJxrhP*N+9l!Qd*}`SB=TR~7GWP4Y{7REX-U{VYG%t_jukt@%`u@vh z{9U7pnAT$$>X)uyOwc0pq`}veSpjOiQ2K?h2qiPbJRC9ztYEFGQW8rdBIV6Q{+o>y z`8@T)<)$xwt;$c%n)1N1#}8~Skta7FSwFR9uOEM_P&>c-q+Yc6i_IDLJ)f1?b$px0 z>h<=tte2T#s|WgJ##Po3Yc&e{v;g}QhR6+(FIgk;Heq{ABY=CB>vE?UlwV(J-w^CD zl||@La=Bnf)dl?9fy0pzLCOR<6}dtAej{<h9$cYpZF~OS$g}($5+spdu}tqpQ69eI zJ$7LS)~6Zjho8bY1kOZ(5`<N89gR!{@mkFDf~7K)yC7Fe`3fDL6==`G^7xP~s0S%e z@twJ~qUzXc)$W%&eGY#@ZM4xlrd@;3z=erq1(s~YXGUZ0y|5=vVp+%Fm9Bw%CQb=T z)bLaYTO)Fo0?l^|G+$Vo@Z1zRH3x6BP_N0o$vE5DzM{g#Ta|*mGdZ5$zdrtMnhUnM zR>r7$LyOq{jSn(?PcdWnkLG;ypZwtE&)NNrGKGzvI2-#hi6?2(unsjOH!+kD=}0kA zA>`!{U0?E4oflmFP`RbcStHtJ#Y?6ogM<`LOJKosW@L{j_|U8_8#(ocRgmxF*Liu# zyfHmGt2_7V+or#Q<N7oIysS(=^tigRBrQEGn&p49hgtgE-~P36n}2{=EFH0hzj5sf zKjq+c<;hCq=WDiH$<3fWgYQnYvJNTLlMJ24un+{5RKEe{5hDN?90b@@Vp~Q;MpWr| zX)I503=r4ZUCgYJ&E*%S0`HG_MbyZ?$(m04gMVn2$S!0{9VLv<s1OCR3;8%lF<=3s zJQi<j1y9kAU?0;d=D`n?lA`PuJY>dRN<g$=bg-GYW#-p%OLwXx$}TQEEf!>QXo<`{ zr8TpnV~X*xkxzg(*UpyjTBeuj&mC0q8(?SoPyBM(FZ@sA<xLxvJETbN{^o~vS=mwE zUyk^B+gv6s9$g`A{E5G0=MC7KF|0O={>*%jC(OqBO+~)Of%QuxUzW6w5&B^CIP*o2 zqfwO576d?{R1n7>IZteOnv|9d^%R?%O3%@r+<0&?eB%q>1n@o^DNl&S!;3jp&`};f ze(2PbQ-+Nnp?36~Y0}~Nnd!UI(|1pM`&j#?YNPvkMaj`0b{=3g`S}Aozdv5Wl*OZY z`KAi~{Pd|)X0Wyuo0&QapKtUGc@91U@fp!o32h7j9l#@mUr1FXpkDw?tRyc|I3eCA zG&5k5%NZ97+D%v>Ra-{0Xh{E1!WqhghJ$D~N=K~LJj@6FE}dc#N65=}AC-Zuy|nJ( zXZbsSeb3)7d*<r8`Fgw71s#`t|Bl~{<INsF^Tr{r^KbYeHh}rdYh>@}*UOdS8C#KK z?K^hdxUm=-a3FQ7b_B8JEKg9h&=Cnia{;-)sJy9xv6FDJ(B`Wq=ZxbU)8SwcYIAP$ z9e}pP0gt)e9||}Pf4yJ7=MaEI7~YfNF&JrG3oxDAgd<9J&g^bUb!#|udvH>HE5C4p zpAWC^46&<@sJgChv+F&HN_+L<oT7k`4GPjB-r3$4<pTM>RF|e~2ni^f!$-HI<6_u% zy&le3q*PPN_0$DV+k#VO0WaF37m3%{WC>Fjugd5ZCoIBhPj-j-gDB*J(Kl4O$iu>s zs-K7V7;Z)?ath`VL{BVn1oe80<D8Elp1vzBeb+sQA5V;*pq=KwK!>gTtSe3K(N7%0 zK0TDJ-JTte(=}u2)ETTDAO38&E#5!-J$u){XZzAQ{QK_%JFnCD8S=z`Xv8H>mfCq* zgE%V3M@NAR5mzGwYygU0$sht%GZJIS5;ErB4fJX(J%Nuz8bGxyT7KB<$>9+I9s_7b z07+>ZNaZ|BMhIf$#7r)XOEj#w4D@tOxAnQdvvBWqP2Raw-m$&e#?~vjU+FKQd(_qH z_(yq8Wc<$`ynjWJAKb8V#rkNw_a{O+)Y$;vXzlAECVUt*APP<#kU$sQO7I(S-VmPx zy9e;-lZ(eS0eV1ww^{3p!RtM6kL-F&BsuZUnH4@n?-Q=)9mUR-j^0D)?bPkxB+up5 zo67!G^jwyjNRnT7ta}ZN9cn`;VgSji0P=M*?mKb+(Qb^QKU0{H63PsEWCEy(iHUK= zBqiCME^BfUwORqK$)`Q*1pEjz0Fi@@Jaxs#=hb$VvXNggne(r_=Q$k4i#O_}ty{=S z)z|R{tMLyppYHzS<jLPPyZ3uOfv?yE#q<uc4Tw^f_sHJaGxyM%14H*)iE*2nuSr#^ z+Rj8$IYx^#f%T!BMMFw?09ja^6^lj1SrHYyE|)9Ql>yb3WEV8H13)YxK3tW?wr?t6 z`}kOMm8|4W#Ee6Y4X8?N<ky&u_bYF9sQ^hq=4B&ERM!yTPGOe_&Eq-OUVQ0WsPtI8 ze;H@TyTSYCnn@E^<Lozpt4uwDU1Vudc`Lw52eJSBiFp9y>O1>LZ>lJ7M-4|e(WSv8 zyuqm^u`R1{jm<-U8?7yxia7MAap?DU+*<VGUxe!|-PrGu9;AW9{|eb_ocJyg5$C_- zXK1Lb?yh-}Ht)G=M;>GD#5W48If^(4#IYn5Qa@Dz{74>nAOsF^fH3kgG)8etrS7x| z2(RGK0rRB@Q_#|28V#9zA;(G@=T7Z2pw8RMysHFUN=q#maRfN?jclZk_<ds$5x|B0 z!#UO@tYJ71BcK{#D7z(<O}PN*SBOx__bnoTUky}hyu!jFVrT%RDYk<BKvp2eRwK!t z?8H69_{e}%I|meU`VO)>0Bab)Mt;K>=U;nMDG}rCj;&v{Y7N<pHeZ}5``#F+*XsRX z`>cD`)49#Vx_yXo+Hm7=-@pz6J&hspV`2HYRuXH6Gpcn%fh=S|b@*74uU<rwsKFxs zBGu7YZT<*ia9oj_!trz|IrY(oiN*(S0b|ylEqy)W(2Xzl#LewEPmkK9hI$+MkLW5N z=aGcm-dMyL8_qZ4&17AflRXtv;(h8mUpEO#?!w=*oWuLsOxo{>OO20<jtWH)e3nJ_ zSDH3y*dVuFHt44TlD}d;sEOEO$QS_h_b(*FEcd{`2~P*FOKiCLtlr`KBC5X6bBAxK z`ceJ*c~BsWp*3sVD6f7bj3&%xiXgh00%td)ek_O16Y2cspo*~yd&4*d>Wwf|{A!iI z<>$Kax~tei{(EZ6tjJ7zTw?p|9wn_=(sEq#QZPo7S{3)I(>^iIo@uYsG8L@w;#EAS zGh8WBfR$%)YjAO~T^_;qG|ti0C3Z*GNj!!9Ca!-VyELh*!@dN4O&aqq-cmcss{Ozd z#RdBmYfk+!2EyOUq|=*1^^jm4nI-r>k~ZEFxY^WngaA7dvi7|q6jx$Z1bS16$yKk$ zuOvTE1P7~ZBDWS;1MxtrZHvdxUBoZ`_^v3rKe%+;GrP9$+O=uTqx*&~ua&Z-S@|PB zun09}_#<^Po|yak)%V`gCqKM)#-jOK7EGD6qG|27pe;K8eX<L<hol4TBrk-T+(6?5 zYDdIUg(LwULnwfW+yt3p!s(3Mgi}h0vN!PMCK&Q6)%qNyG9yEQoy^IR`<CkRi^BAh z?b6Ya1i#?-A|r8FmcJiBD{ja|D>Y?rxW}+u1|EdWwKfuGTX0&#EXa~+iWCL!Rxqzo zZh?Lk@XkTMVOk-Kf>9xYt7tqLHX9we2;diaB1Q5a=c-L9aj3VkcHL%l$;wZTi%E~j z%FpDlv1_7vz?2s;cAqihI3p9gIU<*8mby)NNAEuBAi%EE8NqnKE7W#iT^*F2z{`M# z0g5QFX=nkXMnZl=&ZqD}7z>y*SQ4Qc>Ql~lKylMWF?7|lY$zD{PJcm^?bx^V((aoO z8ns0|CUSn_{T;zKY+^RnOOA-CTvcEHi2C4nMPN*E#LuqOD?(6z8@VE5Og)W53ZK8; z&2mM83XF0u+*Lc|sYU+<En+fn-gxPT=obEZK!LSQ)6`Vn?;dt)*5!6OvzD-TwQTE+ zw-?OUm9?_mrdto?Ksc0_y<fj5pC!E_1wFbBY2RrT7+(s|`ujX08Hym04yDKi8u5S& zFNdTJg7v*aVi3%x7*7(tFJu1ooBDZ@Qd1M+f!}4N*3L+CyW&$4QlLQ^LCV+29mcV^ zn{$Vl>;I5C+~MU1S-0{yI!ZOlSr7hrc?~-AaWB2~)=P0^u`j&+_6tw2oS%PW^~b~& z7srj^Z~pi*KRuMb9;zIC@0sV$E0N{jy!YJG7qI+vNBIt|T%0BJqM)oH@ej}vf)chu zK+br%+Z!*pfQn2ZCz~zTOx41kR=(RtOA7PdKKkm72)d3q`IWCWw}5SL7Hd_$*@gxS zq@$%o(!_>dY^0r(_8@l!KS7R<1C$3#2PYcgoGc9>r&IV5kO~8h(M|`*oktyjOf(pG zQN$*6F?}`3$`hr7o}BgLpR{&MHWnQp28Uu4PWP|yYhI44arQdP7WVn=-6gRxa=g!S znCpc4#^*4;c=B;bKFBD@P-M6|v0z!^^2K1REMF-07}Nr-JIpeY$mrVw&k{b4VJGMT z5}u9utIxWDzk&Q}Df_Ne4k%^c7-sFybvG{-Su>;3&B(Z$duVwbV{?+vNEJ}zgW(Yd zPfdYHGi@Yxnzi?{pwTh>FT<5Ew-M8GN{M(mv70t>+{uiQBO!_rDz{TCB8@u7@?7cD z5eNQiYiuk=OD`e~S2z=kxqj>Z`i6{8k_kW3M`5hg!wR|-Fr|QE$u|S1G2HOYRLDdQ zmShB{<eLeuqafW?cg`Xrkh2sGtnicIwL7g)1+kGoD^}NxJTQgI7FNH7?3F*Dv6@a= zHd<E+2Tij-!t&vjS2}6l$9ygtURR*)79=LY?1;fTkwz?n)D)_04G!{?<mj*fG@nEU z!5WB4Tm(s|%>z$=K!8O-yAF6gH~_3C;fi?L-0s*|Nph#T(_)ij(SR$a2B5l7DJ0n$ zh=R16eajqCAOV{|Ho4NzRP2^qcC6YI;ArNFX9YH(e7P~76W9pvV^tpK-)AasTWqoX zvN1RLhmu$%sT2vdo5EKPMP*Ga#oIA8f`e2Els`NVs5Vq+R@ejN{sy4@08a)c1(cYw zF_=?ybQqxj=-BAku&6MH&1%fY|DW@z+y^m-CvKX9xe>Px+~+ErW5p|m*m@8ABA3+B z(+&mNdJLpvP<TS#J?V(TsX$Xzq;ROC4pKRYv{Crg4<WVihydGE!P`*K61gqPSHkNd z5<!?m^|fYyjBwCoi8w1GX9>@!N7M30St9F&mdRf}THbVtJ9FpVuY4FNd*72Y<$%x5 z4qcYzUZVciWj-IwkJ{0vZqU50OgU4l8H>B3ZPKo>_$FCr==^6@d}*1cy^Pb8PPbJd zqH_%JD!qmssw~lw=%9(2z}#WY3&qGQqg4g9o}xu4eB5v-01*k=h*NV!FFi4XL<x7- z@M4+J&GL1n$%55;FO=PdT}xu)1i$Jp{;1=9dOfs{eGO_vpz8Iq47P}x)7S;oY7$H2 zNrvO(J$-At8l0g96@O|qa7XBE&7d<Bii%(KpwrUR;*cyP=1&;@mwar9f>JHo5J5G- zNy3tJqoOc@r=_N*W~62S?XcR@2tzQcZKyLKsYRKW!Rl0mnNKB99??yb&T{kYJ*_d; z^ro?Aw(MfzKgsu?XUBT}!H3z!9WwG_S?ygLSqT4S%TBhZ^l?qAQ;Xf5^VYg|zA!vP zxe*`Ns}OZBmll-D&DY(SUmOb-2<_Eq_~CVREAB;x1Ql@`UZNTdJ5~VPhT85Kyi(-$ ztJv7|Qn_7m8Sxq5sOwTJixmxIsuKHX(GApDaP0x40fBZPy=o>=fj!Gp&-}>CKc!qs z(3Rpz8)W6NBM-bBsWyJ9>4PgpUPUSA-(QUUn!nG|zFx*WY)&nQr=5Oqe4=CbHm!Nr zO~+S8mYzRf8oBZ~=AcMJ@L;Y77I;(7K)8vhLN`Rmsdpe~_y6b_D6n&}O}OTF>={^% z3SvAMfKPlq1I@_7B|q`rcLRD3pM3c>?|6DNSjPB?6UX!SzL;B5QvA8vXzkjL(-Wc} z=(}NysJScgZs$jPbneu1eftibI@9~s785ywIfM!ZEPymLm?LR68Sfg3xfOXZIp^Kr z=Mv&C039L42B$zcw(w36yNgTlZK={Dab5^tK*wI$7F#0oZ)ca6)8RJuynw%=z9!bI z2JLx(Kgw>=aTqCkxFQsf3m#@@3)Eu42@wP~q0DE-<Mg?<6vX4$<vhxGh-lM{%Yn91 zJifk1-_U@El@X<-D<ckh9fxe}d|)>Z`<x%&H2B^3z2sY$-{5Ji8GnVnFZ(~u`^Z0G zaBwB@cHXOYf({irc)DX8!5CCZY$RHdvsxMgatg<@z&iC;aYAnwg*z&vYy7-M5`ty~ z!DiTOrTS2me&#WyvRZ&bWE%y|;_~H?p{yjVpbCPXCZDm9$MLWD*-b3^nYjFPdr)Sq zyGd4uxpj|B$CF!BI{!%a+)lNdCdXt3M`RSl9AWm2Xw>rMLfQp(n&%crvYlw7UPrbp zj&c<C;P0~9!WBEqvU(IoITl;wI+^(SBO;6O-EWIPIh*ziiZ9@=>=XPIRL=doh7hR* z!Se=$iH#$W2Pt7ll9<i5|Nn~!$)QF4Mikvud_>l-A3XYA-!A<Je|_wbSCfw{EE;pq z$Z;>qGrDwWIdEueed&SH_3dW45=#bbcx?Ypz2n4T?fZ1yF6M*#s@ZV<qKN}QmFz}a z8q~W2y7EQKlqB*+%h6Jl-R|pV<X~Xg`06`TX*bCem&cUq>@vJ?T5g@YAXWfBNNrRS z>qYxBiH;jBseHHWm5eKBtS!c(9>sY}lAs0{j3gDZY#}&o3bl$LXw{*C8T8Kx8MniX zkgasOsKUs6r~d5(4Z#CdbfxLEcD0+N#NwQ|+r+%fdM!n#;#Kp+Z9PKRDNaPMzK$rI zi281%;|51po(Khz8<Rj{SKq+;i8^6xSWqC$1i5QyheUSUjEZ3<U@fXe#Zg#Aw-FVC zFz#~Y<pCC<wX0fA_RHS48Yt<bdz30$jHOhz@-yf@a()jx^Bc>d18XcKUIyP@>ccRW zIErb|B_SC8iNu7Uy{P5JOM)R&fKx<t$Iuq^4pQdSZAXY6MxZF<WUEFXn(&#AJHa2y zP@N6=!?&$Z-_M^g``vM59UAyXBlnWMp}>l~n`x7&vjMG>@0|V5eJHCcs{f}xl(d@+ z$n8lQ9?)b`(WhcqY~gFHVbxl(x(2dLyH|Z&HezuQB!h78Cgw8o52gvGAP{d8`eNRR zvpfX;@sr}z^LTu|F?-*-C@R@~`b<1BYG>?IDCK1TrC*tN60toP=q>%qd{&UsNNVT3 zp<mH#uOVgBh#%csE>M2OvX?SM^d|S`gEi_`;g)iweA2T;hE39(<O()!RI4VmJ|cnv z0uxdO&k&EZriGZzfhYiXv_LAxVq{)?lJm`*f?-dQusey8U1X?l(#eM*FcNuHePWz9 zix@b~c-i0#C=HXkW&u+;lGQzl=91Vh{m7fAkEXRvggIx!i|>uEYmdlDoIkhx-YN5A z>qJCk#oRkptsQEG!}yo|JAO4Rg#S#t%mRW!SloAZ_=C+tf>=BBe*Edh>;8V_KUpkq z?0)ohi$w|7{k}U&{#I*#O#Ku4V2AZ<?P(F^pcO!yFi9awgwSDy6DcBD`1vRr#*M*x z__*VdkWq|`j*Q0NkD#oAm0<B|v8)jqny*=|+G~;RV0o5!o=Vvj@hkYXgSngKR~;0( zE+SH*bCQp9aupg(iNtM>k0U1p0ENHABH<Mhc0!zB+GFHBlmR3jW+=HEM<!89z`b@0 z@`}aq_<XRTa7{$(7D#!L!R}Z(VSK@i#)MSR>NlFv;>5>Tc(rkH?5=xfp~vvNsvGoG zXvmp2cF{>T?~e|a8&(iF92&C(2Z30Gm(LL)Fp4N!B}PF!4X}ZI7zNUeHYZFDEHzmi z^a?RRiYoInM4%IM%Gg|iQ<VNS*|^Z<H<az=gN>Ck4Io`+CiUXS^y?T)j09{cI;s*| zq9*WU`)DUc4-Y&TBD>*3mM|2;mZ-?{HeiG~F#T%j6A=gg&VYfT)SDQW90*N-@^X-N ztM8#XI*iGvgUP^{{@?Kj-2STM(7)mjP%k3C*hSB8r91o{@CTqxEa>=q7ms<D!3_=? zGknBoW!oc!K78=%mWSV<V~2+1<0tj%jw&UUY_z@%V-3Y_CLy+hhXcwQkO$PpI!xpt z^7hDs7;Gi-;BwVK)s8F0l~N<AhBGdP8pq(LRv{0S!^N{=AP@h<9Zppay|h%BEAET; zH*Z^G8ly^K>X!K?0X@N%;-w)454ol>BRRylNJdODM$GGf#T+mlgzo<f=1_emm1{3B zhw9@u7ys5#dw;%ps5qhh!BP83aQOOpdRu{m02qY}WMP1IDN@Ii4X~jI5D5SY3D^UE zk)hhDD5CD3Y&CY#OzSf#F#&vf!Vb|L(qR07QBQ;z18pGY3(y7x53t_|3xPf)i*$_~ zv~rOu^NDPQ?04S-t;f4Ewg$9#d%-t1{{HrHUareeu32<^C4h#-PiG|U`>{iBe)`Ld zulbuFEYthW6z9Gbct^7_k7z^@@a8ZBa7h`VC%Ouu90f{xn5_!Ot&oBolr)H7N=K=K z4|PDXxI4*O)n&)(tPeJ@C^L2?Nk)Wa@Nxw?5OHlQIwj0MqT;PjMc<fn6;c@g6BbR$ z@wJaJOfAnl&-{H&WUL?ZS8;5tRjp*Os`<DOFX7Bk|1lu2=zK3zXE&^_8es!T4k0=1 z2F#91T1lErWP8KJ!AEeq><vU&5kO)mxy1rgsGs9=?<%nb`N>lL8(Q)HvHbAJ2_L`A zP6_XdpBy%nMe*`6;{g>1@BzhkR@=RO)T+aVFCl;5b_5$bM%cUr=#F&5+g?lR=INZC zCR_YmQ1pwFvD--RqJ<2O3;ME9Z%}MOAu{(>_<<nQ-=suRt0shd@T`L-D>y865rO@y z8VNFb^n_S*<T>w&R$BWvL6syF`YBCX`Z{WrzVZq-<~?=G&!VRmt5j`J*kZG>7Eot- z(nORH{)TDcWI&??0<6Sk#XX>vM^y}DO3-{B6QPyYFhkO^M=KL>*@$Zd+7a!98EVlz z5Ss#CCFtHHvhE=IplGz0#FC7AK*$IR0|d*JVojd_KLln)n>e}8ZJX^qcptLRW6^Fw zTYQ_Qdq<YwW;{qeEX6s}x8fYd!ux^}0ipO{=b(cj#Ro`Q6K-YcPbqhiKBG{EA_ej@ zkUxuylOVnwmz)@n9}t`DLLv=48QIMt1HGQNc>vg7PoAOp;jU6O<fdm}^oZeOL@4nJ zKf9G(`o#z(Dx|}!*Ffz@QTa%|dSa(`BgOcKAchUc_`zQ#q>YNa$V<lR#)Hjj(GqGv zHpZe9;BBu?cYy(|Mt4a{O3Fw|Pa?Vt5}2U7_!5{x0m^v)t7agelS&L4KDFW6Q|`ok z5|$eNJ(}1B(PVt?lh;dL3a@xxOoUC~58+yCzR55NA-w1%Cs>7GKQfp*P+O7u0Tmb; zcQgqsJWg04E;H^4*bqH%qR6P~I)sn~(FIRzI4EnFf_e1qI4Zu2Vj!V{Q7FRVW~B!Y zl1&QYzuu<Lobu!5zOg00Z2t5Pt>$nKhVm_11lGTX!F8eYW6=?vN5R_zVD10|6+SAy zaSXs27$ADLx|_vp$OE~}YT{d2F1{R)l32zq;%yZ^DaGtOh;Lzc`_>fBmT*bQ(V~x8 z3A;W3*lVJ}90p8KV9_a#q%Q81vc~BpE&vWsqLfGsiDZ}PVPr_Xm>Dx4nY5BsYSjmP zd1TzateiuWp8l|GLjSRg-kf#!uvyx{8y8QV>(je;pL3_w^cxq87cM9<eqC6srqg)V zArE{M>tl`w>;!W>M*R4H9*=hP?B0Q^GP5=h*;!WBw|(Knlf!y+gRq!4<=JCx+q7wW z>{<DeH)ZUEiDRmMrTg9iXKWJeF})jzDI#pB<3qXthbshE9eHxltPxx=oG^dpXOaDg z$tsSTj|b#%I1(K3fZJ`v1j1zzn%mWGxX<GHfKT=|I=UaL^p=ht69<l*J@x!1{^VP` zcVED6Zr`*QZc-!OcFtXei?BObyM`6t>8HRQ%#nt824=VsTI6IVD-wcSO>xCXf&!V8 zfae+kp@|v@-7{#2f;UfayQ~xf*6{BU=<7|PLm^x63A3|m)l5g$0Q--$M_7>HLsFzC zn}!t+Iq=FH3KA2g$_#?ZyrA>~Y_Wby@C)DiAzYCYP<g9=e|p%?n(n2|%O3&3e0`AU zNhh4~S7X>f7WhbcbLD5E9R7Sk->iMh-)>gx4EJ^`VM|#Z?=J*K7>P_?i^Z~{`CY{t z^u>8j$2*fH4f71HiS$#Z1w}exz(^26Y8mc0RO_av$bPy`*e^v|@V)T%fY}ODfi9L7 zNl2wItO95~gz)+G2w;AGcE6Tcwa}iz<q8+6pCqvgpi15DnIY)fe2G$hu{|L!?D)ly zKQCAIcool15#NAkXSwfPy8K7zMT*(55OUEuW;6P}9$AVfXxZ~dL)g&s{LLyX2Aok~ zetkqv)Im`jsC#}$A_5qyB<-Rv1b(Z_g;*n8Y}|4}J`g71|It2-47jg$9h-;$BZ571 zDz17(?9v|gZV?|iY1HNu%g0XQgV+T&=dfN?$<7*Z(8c-dwqkjloJe;D{5h5C5kg@& zP$>m%QM~aO3mgC}GjyHtTOD2&6=?Xz5^l6VF?FP91W<huV{%~}sV<9>GWx`%sTW(b zd3)KtZQtjqEV(#b4`(U-68&2otQ;us7F^6;W(|Bi<}|!@bFeO?hX`*f$q9Y>Kn52& z2A%`t5RHDLB!>|w;SS&&fc`Hjh0sGIdVrs>gCh8@5<?U#<`YANFPLLczp7RZzM+re zDRvx-DCd;2k6Eo-*0E?ZzstALTWLut|LyIk6#RWTw7A$-wXDUVtSNuTcizii!XnFf zy(N7!);JznW!NP+Ac3NvXPAa60C*z*oE5k<fD<Yw<w{C~QZ$4eDdPa36Ia@p4OU*9 z0IYwWvl>~-*ao(Wtzoj*g6YPFH0S$$)97pN$;<Lgu@{wlvuUaCyn64e+Mhh^PhIR! zExhEdJOvR}<REI*%!KeH?GXWKc*p_UAW=i^u8hihe}9oO32K485@$FY*paAiuqO%+ zm$G3790Gk7LH)5?7_MmL{|e5U58#HFh*N2~VB-Tc{y%<n^K&b;<Q4o}<PU<%x@6<j zX!?^O0W8*gR9;=Y^8=d22j9HQuA_~Pork~sjq$(iEY9HB^k)p6?7zevlj*_KIQAzM zJB2(g=H{oQG1*U)*9SuT8^ubJLTMr2)cpL!)I?iSF*Q)n?EoijE_f%1J5mwb0oFxv zJ;?M5Ty(odq0%avEiv(oRKLwBCzNVU7u~~;&AISa*>bhcgJos!%;CqTFRT-Y*)YF@ zd<O=a;6Jx?XK}3Gm3J(xgP6@T0cS7!#TM_}S#0CzNh%LQp_wd!PwY><<{P8LvCz{e zBoGz6K~lp8b+c>NN=<PmITOj@Vp2G9)M09aSbiYPi$4lgg=BM3kZ526s}tadze>IN znm23Ogb0^*R5ze5#YRo2d=4aTl$hC_w#--r-v;Lyt|hjyf$%Do+5G%%x6o>CGFV>) zSOo29v89y{NDcP=9XB+_x9tN~=5igv(6zC{GPuE#ALUu<K|KMsCCDF0bD#vZiNLzq znHg9X&=pC+I)pfY<V^b(BrwoekkG0H$s^_VEL*bJZ)*guqOlxERo`KoDKAs~I2h|- zbB2@aCzqf2$F}>9L~^n)I$DM}1>_2H7i)LB{jYXL2CT^C@0%xr&UOZGsXS$wEKzS5 zys{1J=O}&_;+LW@8fO|_f!Z8_ke_9=<fr(J22enkmn<w)10+G07S55Nx2Qew4xmyA z6s|@MaJI9vGSlK}m@K!ttZrbnMjSq9gK98@fPm_vRY27bN@J)V$d@wCwN+|<?ccO& z<^7$ervz_hE#AKOT^4lj<oQeZALp|>wz{jJ%Y-dY?MT0O?XImWem1qil!hgfiylmO z?fa=iuaBP{xvOUS!IIanHqLF`E50Oa*M#}=)=povc(bzGR1l-}NWgjw)?>ta0An-O zqZTBIkTn6Ii|7uQ$0zZR{68FhQce)44m^Akbs^Duc#UwjO<H5)M&aaZJChqXAiGv6 zm{2ue63D8Yuki&nVzrp{#gIxeRL_+5qXvwg^wTTZ9a;}8=sICD!;B{uuUxWx`NDZq zC$}2s3faP%m(6+UI`8RQ0=4}dw{v#yb-SxgyGOfj-8c8|*y1jh5WVJ7LHmR3S7QmP zw0w-3aKqXua$F5))ys&9MI*g_@J9>@tq37MCm1z|E212sAx3+5TX;xhXrw#I59A+E zX~3u<wMP8HgqH~_jZ&9bHBhWKgz5Pgd^>|EJp&)bJL#2c{<1P&4!C~$)VCpW`C2*n ziXlhOcCltcik=85az6j;s-|6K2{%SD>nED_F{h#-p)U&kZ0d1Lo<8t-SZsu1$eqAP z1m}ckWMa%zac|B<sOQ~g_%}B}MjIJ1>PU24fwv541Cnht04+2^W}nYn?k9UM$d(oJ ziyuU-L%JNeLMVm$@T}aQ_|(IzG;P&krS?-xHEror<m=;osi&QQhlSc;FiXg#gI_Nk z7%D<Hs!;`HNz@`ZeOeaOf)yx`!-A7!VJJ!m&;QG*EW@cgz1a)K)@4C;o5b=NdwI?X z_5>Qpl@FOYQ*m!u#P&AtdSjZFBpSytDIY#wZ{&8PDQ<Lt#7NnSe+~c+v{?)R<e5q* ziI6J>P(=hV2XW<|qo`0@o4&AnQr+lCEiyQ<aWH>>Eq`Vt+aa35cIqTMN@fIvu2-~r z8RdtK&afB;w4|nJef3=Iq6O>WqR1MS21JIz$oyE8fgp6L@*rF;+%Qwm6bl19!!$iY zUCOMM68$5=@4x8;-mDU;)JE^SGCAXp8dK^)w&<^BXwv%Te=AMV_=_r*;OsqHIezd) zfQhM)ID%rog=PU56|(@QG)TZOFdiZ@(R#vo*fm2Q>y`=BqrO^zfF)q7w}{xv%V`3T z8>n^+EBkSy=yLMk=h-Ay^A3Hv73qG&Se-3>p*QXU|8I<^sC5gpl`qJT#JJ#i3hfW% z-2y`V;q05*A3;(;NKiokP!^2nQVRA5L`D}%!J7bQ4scmz9br~htCm@wtme(AJS3-X z9V%T7M_r*c40aG@8b0*WgdXbEcQ~lKsaeiig+Rb3LZ73gWbsbAM75|2hcGWS$F3gL zpZMtVQ<D$W%{d5s;?e=V{{+G)PA(kVf8xacBeNFp3mJ7A-Zy7*Tjrj`+jMQjUeq3y z)h{l2kAL`OFZ}c6hqC9=7ifOBVWs!@L+clmP}92Nh3g-ZJu5e`*XGZzUoSj)?D#pn zeZiDvv$3<lKedh8Pv)A9^Nenpk2PyiV6GXd>PWY&S=Cxe0Rcfhq@bV>09U?MgP(Zw zs<m$Qe_u6UDW<4O|L3Y{=(3rbqh{+5mz~^s_vTtzn}_Z!JMpmIzAqsuW#jv|D=cjH zgt2Ok7MrW~-ELYowXvd}eT`o}b+#@3IeUt^UOTHQs}{`VmrL%QIOdyg#!gsJ%v^I9 zus16g?Z=Z?G`y<<n<B;yc(Y(^I)NIKiDA-caxrD-yb`L1REQ!9oUk;0JpsZ{sP5+n z|18Z9ym@NY8j0L0^oIZ~BiIRs+y#1<JMFGq%@8a``|WC9MB**=>2$NRO0LYGeo|gG zYuMeh-dr@c|Aev+pPqCmCu`rhBVXzp#*Hg3{)%8Mg0F5|ELmXuS_N^5SU_M}+M%j> zKt$}8d1&%zV;%<g<^ORW(23FobN!C<SgqtL{HZ79TEn~b7<O`EVf(&iWjlv#&dOXh zaPL{I<+yS4=JDUXDPty17)$t<@7F49jFx>eG@)Jqe>Pe|%{=@)Yy#Ei;n4wLh{g|q zDto}n!nWd&cEi-6q6D6)(fN(4<8x804XXqng%DL4cQza>l<*T5`3;u$#~;jvX0lK1 z+I`~0ZhRD*7{|K*4g@Ed4dQ=&pl^JV|6ay#yvBd0u@phG=L?aK`q#0*Ox}Jhz6^mm z7K1~XBR^jD%;|~`pS=!sj0c82ux!cFF&N0?1eST4v@bp_)rT&FHpaGVn4I9#sU5Ut z$OWf*kXI#|2{QU{^k`wiuo9FK!zmTee{=-(l-4Y61@<gY6aVHY_`Pgn&bIvWGmn49 zKWWX}r}@Wind^mp*O<E_|CAkjZ0<gOoGsr!XFnUezj!}u&qwW_vrl~f7Ihc;5tidz zxjjj6Vialti5sB;xHWWU6~b+eV=wBV@Ytt1?5x89*~t!QNyY5jvFro!vmVeK%6#39 zErYIwZzt(TA=Qoy9;`H_UBW_w!8{^L4YNX&##WcaVC=X_w4ZRsbDx>SlG{z1ySQ<7 zCckiRZEfS6@ne(2>(!rgFP5TMv$H8W8oo+a4|O}h(?=RhL#&|g*-#kZuoNF*jk{?d z&0aQ@mhR^7r^9A^zm2|M81gg1GTRHL!p8bZHTelknRWoUQv&e6=Fk!xBu$V?q^~_+ zfB*vJn{Ey(@=PO#q&ijqfa#O+ven>_Hu<tOTq{T<ivk};Epj8ew4l$FpRV~8rNl%h z1#12QK>_|jMaedNt91-C$0I@0SM~l;%&!K+jtBIQWkK-_b!j2}vGF(w;gu>^K`l}f z;#{FxF#c&dapK^?UAuZbb?PK067hXv$;6VmvuDnjHf8XH!4t-f8C5iVSl2;a2i?`b zU*BFmJY76pI(2B*wpEKd&FeI8+L+$M#H_@uTAArEY+(sur~yDK-i8U2JaHNfo6%CS z@=)LUd)t5f`K{moU%$Wg=P8M@HgU+{Nyunt*R7kyzL2#^g9lGm<xzEV>elWien)?Z z-(~T$H~rSz=cd2v?S((B`bpgQNxr|^^roMy{-SpoIkJnM*{D$_hig)VuWL5M*Zx&s zd;hBXnqSkqju_Du-_x+BR-@YAy~Fq8DUq`IFv}!h>nfBuLvZ7xfxNl!E}^Gfk~30K z<TO`&Gzdpls!j|*h9EU1E*7Lgg{ZWO$OQ)BHX*<>4I^pQYW^C`1%9R)u7_pf2D)rY zDzs)<o(4*$#hnY)6SqUxfLy1#l~g6q#vC?_qSgzXHMn)7ApA#;4`!YCBR8f7qmfvl zvPEY3E#17L{1=%YZ^cqFt!wg6Dub<S3(A^=@W<H@b!Q0c&bM=G(43)d8q<H+6JZ-$ zIu4aDw{C3px_nJ$ty}R6<yU2Xqzw}qvobI&Ngbn47LgHhhPUQGkgJt+xTj|R!<eKn z8RTUD-_szcSTg^J1s}g~@u+uc>E+9m1_>TLd<4pWHhV7`X%Kbx=G3_28=vyFa|a*| zqDXBpR;q~xp$a>M`d1qg`bcMiQwi2CnP_DGk#I%|8hJJ(M-b#0GKS`e1%Xmi<71;D zLD2G7A@~AIhg?sd;?pA#@DuUCY$jFRseU+xFPVDp*G%EwulZ?04T-3pOSSv_wA{Uj ztt(=$|9Il$b>7_v<a+CFn>lkQ#h&@lo+`#$rueEl0-yp2za8%g+BJb)A#2du1e}If z7MXIm&6JcA$bpd&ryvXRZ^YnpMS+9m#%K*14hjTrVe;L~+EYhP<p-vEGl3g*46na= z#Hmj{ExUU?H6c=_uUy^}J&2%HwbC_;-80JDI#%5kTe7fy=gMA01$=32iL&?bcO477 zKUL{g5&l0w=ZK}DIE^%lf_wxbFeJ!P6@*pCL`TzZnCh)!#qGeLg>W!fW4`ruDo3|^ z+ls|hM(Uh9j6z(qPG8iPE89_W8v;H%x=;dFG02zrAVYh_As)qn;<M;c#FB{*i}8T! z=Nm-zKj`NP#Df$f1p^kR2b0<aRt_ge{xfwxHz~4eqf>mdLHs8a4Sx&T;rO9cXJA8R zExOzwBdsZw++kA5gQPFO1C)yc0}|8*S^;44*iDi$Frav$yx>F~K3a0&y%x0x$Vgiq z(2vfOd+-e#H<l_><^}V6SrY%alyAV^eY}aK0?PY(Hovrqzep#H{F6@nQ*|-!LOf;q zfkjENF?d5QNSY8RNgi}Qoqw4P#$xCe((^>glZH0Ac=X9k0iYAT6m5_}aYAN6B#J5r zMMY0xvQG;|q`4|3q-P=}*W{P0y1f2g`SnvXv4;lOO8paS^0&ae{)>O5%FEw8_Qp9c z7vw|iC%>k;v3`l9W`K+a!?6c97tUn?c2|Y3fFUCsMvewdNuuFv-AMir+bV!%tJ{`| z6sr(~1D%NCUnm$riixyZs-@wa_8jF96>-eF!s6stj^)gsC_lDLki-EaA52tSv-wvQ z(nm}ASFW|L%~MwI;)iKXX`^MVE7iO$)Q+IOzO$!;o!S_|n8(3Hq^CiV37&&eK!`68 zP-ZDagkGr&<mV?I0zkh8{~$9XH3glVNUFt_EP7PZ;u2$0$o<}y?G9&4Or<rp9o3#g z9?rksa8AEE?VXSkh|F&8{Du`S;TQO`{T?1tx#}QM1hPQ>8@n{EqYw_rZpu4(cSRJ- zvp)P#6oq56i6uczB|BkWT|J%b76qK@Na`4-RiB$$eQszIqs!>P>6_#KGBd=Qx32{8 z&8*Ov*}#XR9<4jIgURMk&x_m1qGs?P`7bpe9w=sJ5E=N{bLT2K{k3Z2T=j?mr~lY7 zs`J3KFfY`4>hEH|QYnh0I(?NzAsI^93v@_B_7|}?0vS;?3WQqL`+@r6)21=d2~^?Y zN2N-sM$x`gXuSB!MgKz$;&kX9MJxS}%KcJb8R?xX_vr?S`E<v881~6c=Pyi$I*QdI zODfHYnpD+*^NM%kjx#cl17k*R$&C(YD6$YUVwE$x?a?zWA@c_n^@Y-ZFSgjaTNK6q zOSy$A=28do3Ds>o>CD9kV_piQntCdb_9Of_E(GeL#EB8v`oZ{1;5`aC1%}E$k*LLA zqP!CR2+|M8m{C&OtV9-d(quwYeM!G+_B=-hL;96cRYBj^Cc3DDH`>+V?WSZb_h)~= zsvdhpRgIU2nVssy3j}^L#zHy1L<vewBot%|hdDB;4K&s0wMWfMVX}}Hk##|@(9lDP zOcq5}$StF88pYj)Qj@EaD^NAaY6a99-y3?Rsu)5rC8$I~9xVU0+jxqqsv!h(N>oZ< zS&X;9at7-xG_jC_(BWSg%`Wja2jdk`3X)aiBJm>N31Cp^#WyK(9|^^;##2DU#-X87 zbP~m?DjxmkGl2AzZw8$p`rhEC$Djc{=!U$JA!~HI_khm2@3j}>?**rw>gwE53y&ws z2^UV$C`(Ky1^fb(8V8WVDLoMq96H!8^Jy^G8GquYW`?#*lExK9>bHF!eB*|9=hQ5v zUB6{%^g_&=BtN^ZD~()Kg21~|#!>+kipnZJTEf3{txbA(^6K6EdGSt&$`IqdAirRA z#T9Lh_6jn=4aqM+7Y#WzS_aDwOAXTlhaN?{MG)0iWQ5uzAWJ8@lIoNa5tT*=C@C_T z9apjBD8xvRfuTUnoB%6B*wbYFA~%);N~$9VPoD_Qb-T7^!fU--KirG|!1v!M)7kW; zSC2ZIC(K%K?YZZ!O&Xaqxw&`2v<dov5mSZ@nHKMMCpy^*R%-`}>qlww2L9Wb((m}Y z7RwM8wfE!iS!4d@ufJ^NzYGcqmK$vRu4Ria9{l}@i<kFcl`-Fm;Ck*xFCtXEN|QVh zG~dRV$bZwM{b<svDfZ(;eh`dk6-~Z<bEou*Z|?AkVm$xxJxC$JX>-{Bu|z<<A!O(f z*sxhGfgGWLfvMFf<qvZdERMyMBETQ9SnBS=9jzNJZ1*9*{>nzZZO`rZJ2E5g8v5Ak zhYl1pN$s2cM}D5(uvz;ydd<2)v2ji(>srz9Ert%7>kmB8_{E<!z03P0BaeR1Ul}#w z)eca?ST%OeHceYGW6X%1b+b3ZV<Ei^{ZHJ(XtLdbIJt@qW*ZI;Oj!i>J|E7Y;pM<x zY)=YEN;g!Akn94TWW75sB$$g>=V&R~;P1d~gzo@VK$s7oE`(1|LlhKQ_J(eiPY~@= z2x@#4vRAZws1kzkX=(@!Iws|yAH+4>H3uoblLQMgw>StOmLP0`(|D&L8b+<!5FL_3 z43Qk$YD1(-Y@b8~4N$qXC-hNV+oIA%5eLexrEiArMK!>&N6Y_Kwi83zEUD2Sg>|Cy z)fje{-V6oSY>p>3F(IZ#xD}#pOhIdR*jrgmaw6bB8+Y@Zxe$lr4FN<6!zaTWL!bc9 z;{XcH;p2)GjqxPk{9Rxw-R9f+dHhA0l<8(#b8P=98xp^D>&iPQhp;B{OXZ9HT|R_p zFOup--4M-J@R+Es3Fs74V7QV0)MUd?CI&n18a#bW6s48IRo0L<8h}tlL_gx4R8=)u zb)l9hMF^9@`^-Us!+%s1m2cg;?)F7RSL8gF^q+M_jWD9a;++?@Pq5#xeX!L+)JarA z;SGY*LSzBCKNVUU8YrNt;eW)t4z8|Q`y^DRZm&p3j4Qcy>EJ`N3<}TE4Wo_^r6&`G zgxbMkv_XxDJ@-94L#iyx-Zd{S#(R~%#)B?=MOkWE@wN86_9_s>G&=pbmKY1Tk+FDi zgo=#F2qS(X6#@}`1MU`eT4c3IyA&3Qp^YYpF$i9)p(sB~U<r^d)yQb4q=<412U6QY zGXnbO!hA!57i9$oDz1FVFZ07&cdGKbu02`9&zT>ymoIte!q`pivg;oAz9k>p`RtD8 z9jqU#F(Tr`Che|S5h@F1L;1t})VRUt_}{ftmL@k>3KP%#!GAf0lO6zjJQDZ<=_`mT zXP8(t%c~Iq$BH6CIyM?mCgSEHw9=J+g1=4`5C(qkn-}R3xsphUC<-O9p~1kephE=a zy++m+<`wM;4a5ONB{Hyhm@qR%B)%~_`Hd_5w^5@Xb|$&`HluImh6ku`W}{=f%pRF` zR_jM=(%zEBePf=zTGc1BK_}()%D$Mb`DHCfoF!DEI7t{5*bVZIg4zdN*>K!;niHZK zqiZ}ae;=GHif6@LhX)e{!&FsQ%n)<2NXcFm&ied-*07o-vcGo|pY%Hm{goox1@h}} zh$@s)!+%MaCzr(VWCuU@w;9!*KK{m8E*n4(hEd45I$QXOsAGe486qm`J*+T8mk6#G zDs>RvB8!iG5%QA0kk*!EwN-V!CA$gsFouf812;#u2%0d`o)EIt*YJuLKayWQS`SXk zq0Nup6f3b)B{g_i>?cPS@!yixB|bD}<<hD+sS|qilHQtN6ef$NN22zRJVh+49gG$< zVX0c$!m2f;2wWh2(IkB6h7u<Bzp54xQ7y)Pb9YeR3U{I~7H&9(k5;{+0j{-4E5i{t z7Ff99H#O>&KjIE^dBys6(1L_-2qvVPn)DboixdoD+|W<e?f)1zRv2gD)^Q^cx_R6} zx#0E#r$*DI<bb1+;c*&yXmATO8NOYqvR`F|jO?ynuPjq9dbFP_1GXA35p#y2ZzEwc z$g07FS8v;B@Mc7YO%P9*gjPcFQSoRd6bPx1NEQhr!(e0}MB^e`1A8I^L^RqqhJ(wA zu8reaeRdar;#d9-e^t5u#aEMecFC^y#?{B(vXsAnQY+&t`1w-)F~6S;VGYLD2Tdl+ zz0{Te_i<)B=X~cktTo1~hU1LHQ}qkXog9yI4BvqA*Eqit8;ll6sIG-A0Ubj_EezT8 zZZIX{^7+&fl9O-;;T0f?V4(ECadFV0jzH~>QLttZnvhYFf0nr?WUn%u@ev>W#J~UO zIR93YU)nHp$@ZPwR%>AzoR%5f9(?t+N+rRKD>mUnnbeU_Q^RmB;-wCrwkQSBqkscz zB=Ug4BLAdn0KO>T908XL-qi>kVjba`Xf!~1FZ>jwF!5h>)c`_+R3?=^+-ao7M3j#h zpL*e&n+Ljm4I82G-cUqsG=tm1uADe|?c!;D;=^n2*|dBUxCM`}f{F^s!^fzk5tgLJ zc+iPidaOPE%g#RD9MIA$tWL#QsjsIO#wiijsrspC)hjA>;F4hifVHvql8VFMuL{7U ze7FEwanvmqK{>PP6vQRjlHAEe{k7Tyk_hNm@cD~XstuwpWG<@H!uCQdB|!GqLV&;d z#{kiST}82<B2!4KfuT#4iazO-0Mrc#9aMalpP$f^v|6D365)z);j;wSIGp@IG6&T} zRq*mTQG`z^>{K)Jp3Cx~wBno(l#_xkHqTok&kx(NBCc*?NQlQ)x1q8vu2|;Z%_{ej zG##70+565jTlR?#+1)!ogX!S@pqCihs2!BT;48QAc*vk(^+NIDQT2vOt7ceSaXO8- zgR%gKJFHf8TaLCyMT85ry)YIA9Uf;=vJes?kPha|VRw^!5IIhA!>@S-lfGdi$&3M$ z<r~*L^w65$PnP|_c9VlavFs+f@wOSW_g0QgA0qBiD%~V%hmNr!V+@!d@GJ`9P@F-p z7hN2HY*^)<<XvEF2>=-rQWH{=5~Cd9VZlZxF?xlojZeS^q#;v31w98MEg;L>Zm?AO z+;j94l_kU<btcQ|&j<OJ{}}p0#vUy0^k|p6*SCH1Qq?46Xs3Lwj}STp^$B4n-lqo9 zST!X=ro<PK`~iL-uqFKgSX*)VsrxK82h1PY=*p0tm63+nJQ+Q&>@HDquSX(qrIF(> z0N8TrK4JPQ@qrvGRi7AHdy0Nja+OPR|4#R<rl}mGsqpXKoUt=Kcjq{2gjKk#UTJCS zl+Mc+FM6=&v{XgWqi*C6n#Rr^9&&mFoAuHF{yV=W_qwZ3KVMI*W{ue%s6<CKZt=|# z`>wKfEkd23{4%Ld#aG&U*tdGLYj8B=bjF|~Cgux>2X_Nb6p^}NQ*iuH0E`_J6Nmi+ z)3YaTA=(|e9ht=LOd|USuMb#%H5pY=zDtG3#BsG7tAQ3yaBgWmWLgjT!UI!|-S_C~ zxeI&Tn;x>2wf<nqhu=<{a8D8I+G6xQYH(2DZ%Ii^{pHE+2mILNdmh?6cfqXtjMCl< zrzY;sPCGcSWyeA6{BzA0whS&={8S<TgI`r1-jBn{q{ND=T1{x;h&jf<K-NXlBAE#X z9Z&`815q;rp)nXtY&6O_1m0p))?u4{6jn?zJlW}X(;ST>h=G%j>q<3dYrzIWnH(9a z+fG*fA}LwczSy&Li9TxRIr;f%Qw9N>cv04`K6m7;p?3{0WGQuqj8X&q2mdNx8L_I( z#V?e}^E<TZvgz(F-3GGZJ@qB8?%mL%BsF$+zm6HT<c$wx6xI$Y!H{G4%Xq_{0Gyjm zFGC3Kor6(3KDfRGH8aT-gJ%Ofi!chP7Ytpc<d5-)b;Cm;0LSb)_#r8Aw3U89mHuTH z;TYRp0)R+y5u2B?5~!8e?tg^#aDIldhaY`|Jsg$bKAmoVV5;1CXpae5b;{%!n@SeU z#P00}CHdT`Nn-czZ#gz8+O?p~!h0U_zCQH5HtpN4>$w4Qv-2mFE!evhbOFNLC_s$F z+~UOCGBf^dZh}&1*lz+;>tx}F{D0Ja2YeLO_W#_O+1X7mn_fuS6i9#op-7WWq1ONc z0i>7EOQ-??l`bf~gepaf*u{cid5Q>jefEOwJ+Su%?BxGF_s;CjZi4#W&)@I!`THz+ zI=T0pbI(2Z^pl-RX9(P!S3k45Q8N#0)+su$6EBS!Hhyqw=JVMx6GyRM1!C;s?PL0s z4U_4po;kX$-;Ft`OGk}tG$76yKe}*upCS4UUc@+GwyL>kABVfwKtkWzs4#?qQt8<% zj;7fmMR@z5GLh*k8IeT@RGIas0$f;;*}2(h(8Gg6h!M&B%0UBxD5rRf^^*CdjvA}i zf9q0<2Ah`cSK+~DgGs=Ig$=%j3rqd0=Z~InptJ3l`b-_qcslDO$C9wWQp!b(dua*k zkqqIY-1j8Mp{VAf=EfVFOWGc}iV>Yo;aCL1&x4f=9p(W(si{6p;<HgVY{A6aY$yN` zx^!GxC~&df|6*$;Z_<$cs<NLA=`nGZ8X7wICoc2vJ95H-`eA5<`pbveKff1kOg$%n z#A65A&2Jx8HSeAQKk1hQ3Xl(-a1N(%4vi`MfqEoS2+X0PTOCvLAtkhi@Hr^Z6cBUA zdq!`WrZCMk7vP)4Q^pflVJhSz_>ct=Axa+TEO?htdSL556yaJn!e8>^IF<^2GMjKR z<t-m4nW2CE0&wzBsfV}5!!RQJ&Sv3bT<`-imPZB!03D3;c^c=FC&8BRR!6H+F5y+5 z@WR7Z2VOWWf4mTiclrXRwb3#kW_~~j^CIXiY&hN#m7_FqHoa!2fRXyc{Xj^MvD$JN z0ZPnfoYRn}MlLvJoKhv37{G;U?yF&2V9JlXStKL@`cKH2u!IN&*cdcm&`4$HiQ-<t zjfCiIO4cR@QpuJ;-X2wO@&P0wZ4VE$c#_l+d1wcyfBC##qd(4y8Jm88>9r;6uDj>u zm+x7zNevFZ?q?<X^nhM(|C{%Y)G$$fSfl(E87}=7jJ$dlQ=6+-6;5j#Mj>>-T!DTW zFThukMU{+Rm@_EFuoln|Sfm!=_uzAh_W_Ned@kYsrP@p}H3cqTu2l%2mHWcN)fW!_ z8?WB`*WX&usNjau)wgWkJiHfz;az@~6H6;w>^{I+f0p+NYvW4Wn4ET@I&b&CSik=9 z%@RWZDg3z5186>QI(hV|D+4R0LN0}ZJy=AM$5GL?9nJUov|i`{MzT4eO_$O!xeVUg zD2h_?0RPok9hQ;$B8CI}6L)sSW|BRv9?x`f?S>fQqlm-Ym3tMgR!(w{F2M`FR?$uh zel7SQ@Zwz!UZ^Kr@R;DjLdcHCGzfac$-!&^G{gI-N0ApdL;2T{h`S&o2aSMxY!-`( zPh#r(w*$<h2!P%q|8~Ul2t>;K$ti8qBdU5WY;)pSTs*l8wY5S@FL?D8@algtM-sdX z#p>#FB(pGe!J82WE~qs}GCgbJtt;j)XHexnV$E#q<kM^Kf8dULAAb1w!)Nc`b><|< zeex4sM?1wWRd?kzxnt~^x8J{4n{ey8>6JI{ym8sQ&AVo5FTVLHpW%JGyiz@{xFnk4 zjh|U3w(1?JU!nUC=Xk^RJ1DQTePH|^ex~2MM;bToPk-+Qy+TENn{37#C_s&zrW#cG zN=1q!(foQu@xYAba8a6xXXK0*v)xB1SJ+Z59~o^CZZv_ECF~}ROrY#alo-Nshs@3q zBl=HoQgB*5Hu}v@UAu0+j%rUDDIYWHQ4%B}kCT3n;%=BlPrqr=ZOTUWn-2BGHe$@1 z9lLejJm4|nLzn(C>n#25+mn8m@0sn>iaHDZpx3CkI(6%^`MSG7pFHf@3wsh>>F3UD z0$U(SPcp#Fvq`;BB(h{OXYo70Pd*3y=y&ilY-uP5u%#;)GB_ls8?6x$CXn2qjWjYb zQOs1w@3m1rmUkL^;b;8bgfRNO39LJQFV+q3JN;e<`aPg+{H9E}$v1G^&{NutTv@mn z#8)E|6OjGu!_Za>S5_E+^PML0*b;ODnbcIsn-D3}od#`y1|E>2Lm>=YSgzvG$r@AA zk<kvLntE`lsrvNO`dqf^G+U?a=Hm|89DOyd*%^6fSy<C4p>G`&cNm)RyPE;(AgnA( z6`_7Gyd9;;ZZ!U&ZZedj#5XZELW)v`nnjz<V=L(|Y>0+K>+}(9Z?&TCq+NGjxq^LH zU~pzO=o%)`Y<pr&Sn3#PivPqqXJbq#@gGkt=01TIE2a+{K4ZqP;nS7GLDQ!XYF9pG zN;#eH1`r@hI>*l!KSNzboj<eV?_f14&h11N4%nUu#Z7w7_u}`|2Lpc(cZdHT{XU9q zFd@Yq&x_MB{|&w%bA_lVEj=H;j~+E&+DAfOQ9q;>QVA~CbrhSquD=`{g673izrM0& zhbNCRF@mAm1>1%I7UTq>vCR-EB!ruUF}x9p*B0*GvrDI<4)l(}7S76~l59=~?o#JL zOY)G=<CfDx{1*yj^8W|11_P1@5D@G2`+xo|m7KXOUg>aPWw+Vc*|WQ?I(T4Z_c__w zv%0Q6;0Zgha`k}&D_0#<mX&qy)~9c`ZhhEuW!<~>DZ@{fJL0D@`giY7k<Uy)3%|QN zv~1bouEo8U9BbdIRr_O0lp7b{eb<tni;o>!eC37i<HvXJ)vcnUTQBcV^1r){AJ@HS zw+R!vU4FAfomoO>4)5AFR-+sTMbq3V@Z`gT$ln8r^(4kX>H(8FI-@9e-sxg3P;W2Q zY|`Ihxtru1eI{GxWYqiu9d@K`ayVZn$L)eEjIV?25d62E_=mX?zJ*i5sX)Y`S{3QG z7g(<T&L&+~j_V7Y`T`Vf-Nx6;lcp-eY%ai~Jpk*Xets(uZY!Za)qq`=O5`R=Z}31c zJZAas`iO<Y`-ZJ#<ortDJ^UVd;>2hm%qykq6Un=B#=4N~l#vT;pzPY^6Pq_5(_5?T z^!<8g7N&(M6K;IukrDDD&jB`{C2@GR$hRnQwiDv6($bOmn+#_hrRO6dAF&P2?Z*G% zQ8P#()R6K~9R>^G#!`$)v*QO=FD+|oryEv0*tw`h7w3bvJLkDOZ{4Y@?7eYAS{8WD zD(OU5xNp@-z_Fo(o+7C%I0UB?9O4KGc0jF13NsrK${b-}Ylpo&oN1Vwj5rd!f*~P6 z{ZOqRQ^GHg(ifT<?{kcW8s_IwKLu9?@=p>$5+m;s+)n+CQMOuW&uBp&Ab3S`=`Vf> zye~L)a>8Hij9f2S&W$|8*p;Ti4GYvG2ejSWY#*I`?tN5|EFLv_mW|zkMwx5}d$iw{ zmWK{iSBKs;ZpUpqHoWlptH-oCGdC~Wfd2;(0$uJ)tqgK73SD`cNz>euBhV)TT`TM? zm+HFVW98n$Fct#MKZFWhAZ5(7VU#|C_UPNM*~)@p)j$~A?Q(y#d8726WVnWsn<Y1E z+N7XyeuFG(<&~0TdKFRk5Kh(2C}&3PgfGw3X*$2NqoAu8gDCJE(@p1Tp>p4gG=~1- zF7k~c4`|oMO`A6EQg*%gVu$8QMRCa~lUvTa_0BtO_x^tR%&+=*@{p=Gq*i&-4&AWe zXr6v~gJ)WgYlCbnqT|=^kk@aZbELDz+#uyeu7e>LD;3>r>M;!|i;$l*h?m-qX}}N> zmGThsnu}IxhNG89L1kk?IX_=C9mC;9qfmkOmas!}6yZS9&2g;!FRD`XspvS_*bHTr zo+7JvZfrfhFy@*C?Jww`ZonTb`9j;-#W5{rT(jX$_N5-nzJ#%V<i)6{T@jHi<EMpp zEQ<JvxgsO>L^@wO7PaUOur2CBzqAbiKB>rPY%R5y!rZ~_+qP(&n;xvF_2I{l;}jJs zAzt<paqt%YQnS$SJt7$@&y&?HRX0{|UsAPAl~;ExD(cj^xI;%4esJ}Q0|!^GI<T=% zw{B&9y7uUEVTz~q6g6F&u>RQMo{R6^G+t}nYeKi4-NyH6dF9t7$Br%OwfL^P7IRtI zW8C=e%Gr|3w~}m>r6TmE?gsdi5sP*l&rXYw<@))Et{{yC%+LbVj56VpdHkO8S;#BO zCzHwtwKFd@9b4FHOyfPb+_3Y7dq&PqZ-jas?Ybdhvij}op`oD<hJ~?r?mKsEUEXf} z?y*DGZ%|%s*rV5!$$B+&zc>XjsCZK)#{;$}!SYeC9a<3$UFpd&VH#u|Xo$Dp|0O~M z*zyt~uOP}LCbLn?0_uRndzLz8cwUtYJhwfzd-uu5cI`QNtb9Pf^1=Q4m;bc?w5QZa zu|6%I)F|hF!g_h`rpF%JG<)--k8U0~apJ(){U=ZE&pIF?_@z2VzH*I-1fnx6x=}xC z<YJFfwyHyLrz4QX;y4}`4K@b2xr$36*;nYq{{R{9bkZV2@n~BLcWBqo+N<rKI?VI0 z4a3&4CF)nQeuN?Hv{O#hZ(z$k7uXrSH9OOnpUp_jk{Aj*m8uLJ$CHpJi}kbVj$)*) zD80>y5)p7l@-_nwYvugFlf&QDUt%R^UuNkZsnyz^!%qy<*L7RlMowvY%dl2$S=Wo7 zu-^K)3kCWkEn2s`R>>=Bt$)etHE&P)&g7b(wZ69dN!On&!6WgU6ecgnKj%W<ApP`Z zh4j-0-HE}lLzBXhVFuSb8uKIXycnSxg}KF$qWWZ~qAX1#WrU;|qW;<t)QPD!I}-m; zW=!{(q?bse|7+i)FJH3zuYHQ8F?%gI3xDJlAP7kDC*U^)_<asu1Abt>Ty_p#icK89 z#|`{G!9NS#>5W4nlnU_BqNfwwwn4TIg>rCMBNh_ekU2u^M%GUkuNT*5$9!xQBL_*L zYEURTbV+KM228{7l!XO*ox6}>)VdN)XV4=VFPNhr!dPJrlMH{)dMHj!cK<y~0W^>? zQ)a`44jRz6PmgY$O50qMS3e7#eNuP_4Tr|^<@|^w!yW>C?FqJfy!3sc=8AkPr!SRM zf`8N~{1bXumJ9UN;MtF6L2C2*plv2-n*rKt25mc{`<bR{NL!TDAWaRTNB}zSfr~(6 zg=mbv31K!Q>HBDG<dN1U?BB2$r|RFZjv#3=WBtl{cJJJ=s6*S<1&vrbOQ(RfD=Io7 z!=U9P@ajxK%SptmFQGtE(6XhVrGkGg-Q!M#uUSRThHP_Ss)-F*AFv3ZkFp|h7jtNG z28LZi(Q;7f01q|D-gvoLJ!Ra)zw$N4CMUc9%7@U$z&;`T7B-5Ci4AfQZa7Ga@wc>n zi@bRxUmj16MY~|gP8FF2F%p+=yyqE$Zn;h}Iz%KcCXRiHOr;Y2qqpAGKfm<u@Ix(? zxUcWowCqUMvBfJ_9I$=s)+_Wk-uPKR%MxDxoW-|kZhPwM=9k-icK3}XL(lG9dKP;# zsa;JY8|5j7K<`GEB<xG_noLc2>TNIKdARoUe%l5NcD<BfyGVbDe)JvnAJt>{y=eR% z3^4p2L$3|kzi7z=Ll_z0$T6MkIVH<aL>#`nT^{M#qb44S@Z2WLrE-y{uk8-~i4F2u z`Q?o$QL%Xtd1q3!yiy^bjMoOB=T7<H$|<EpUJ1>SzG;s~5{edw7fsf%FZx?Ruc!WH z8FGDev|zWL^}M(Fx09?3>))@RI`mQ>dDc$+F6xh9L!QDLB5cUuhnwcPQX*spYgk7o zBa4-EB+=5Bn|9HyFm{~Y`3!pQ@$|=04p|HPsY@^3@lEftZ}z|R`)@BE__nO~cXvF0 z>Gzp8FJAS}<dip7Ro!HJZs~$s-bhJ)WA&n??DEI@t8eYx`4%hqxcDR1^z9wh@8~a` zFFyJLi=Uh~0cUjR(98N4lk%qMU%W^`YgTiI-d(QJ8liQm_CO?^4cr)Hks@G1`wL~n z^tVQ_A;-4YYhEuryg0gT$K(4lJLV-i8zv4MQtr)#v8CK~DkONlO`9_6(r4hi8(E~< zRHe+;LhxN-PGTtdjw%sa#>IP+$!Noz9E1+-_N)GvTM8Byb##v%P+aU@*d(~gLU(cT zfU)k5MGFgJ#D6Jw7y16ng!ZNQFUrKyUM!(m!^EB)@9x+$v0<|W)~nRR|6SvRo}KQY zf7d*o_38*x;M_M#2bDL}k718#4@5iY+zXNN2K5!K5^(aZz$wmnCG0u<gEj0P&o9dd zj(w6PuhGk8dHo>ey#rSc{Lt<p{GDkimZP_CGtw&FRy%WF27Z>tL$4SpJ?xfRS3@$d zs=4gB0W=8<3DV>S`S>1ID(c_G_hhk-m(s!eXD#2)<KNrRP$nPip(Bd&75LN!jR@;F z;1?vA8FMkT+(LUj&bOyGvkm&p&H7aNs~QR2^?pYdgyzINuv||A`7LxBY_3Z>MoI`8 z6vNXvRQeGjUwZ&~-Ozu0Zmpr^eWw)^oLoHaHTeEE4wy?cYlORU2>g>l-QLKgKwh!z zP2#7TG&39#SAx<G6cv@h%0QtbrDm7~9vR48q2bnWoug)4DDNiE!38C12hD#rI`ZbJ z;-v#JTFmP(XFS@cQ~v%?`nz&?!|aEiOHbV!Td!jBY-%%(bp7xvKZt(<R-mX}0<4)* zk^5TmBc!KMjxj{FLS{Gb)&vcT8gs|-%xnf%9B;4(w;6TZp)Qfs^HVf$GqM%PoD&d| z0VJF|h4gRaZ}+#k;o8*;E?*|-)~);Ul>vvRmE&i`ug-->EnM7dg9+S*UT5D=uXpKA z%2<t)ZqsKvG7-xT6H}((|Lu&qsr{turIFHDX@WFGnjy`Ws-&Bw<<e^DR`|@eNa&cb zdE@%q*50ye#j=}kT)c2j<;-bQCrunbZuF?(!v^;+>y480;`Z&@w8%+I3=fjyz$n75 zFl-|mE<55Vh+yMiLof>;l#yC5WI_v<u=ilEG8nPA8^E^^T?5c|BQ~1^GF&;7@TDOT z3jvM)F8;Fq3_DnSfyzg2E|T$^ZTVT5a^tvhOO{lOUBc3bPH5Sre#2>FPwwf~p}1Q& zx4XM?qE-E7E&I#bgdt@UhyMP|jAv~1&rJJm3TyF<?JL%D+Ld>01%)k|Rk2<y&NGC? zdWJ&o2K#<Kd42oV?b=*_<@*`@4}0b`{)b#TV!?tD(?`vpKkDt?JsNcii?}wodw0)! zZ+Gm~tK;<2-n~nAG;G<ZvDUL}Xm57I<=(9AxfwIg>8G_cmOAUmky-kuN3J|1H_oY_ ze?;jvi~sTaHDU{ONP2Gl`dhA4UAhwcdzJVHZmi4mhJCkV6kd#a;76K~27i461Wq&3 zLgD(c)z1$?OQe>q#DQdL@l?woXotj~*mxJ}9l?40uk*?iSBkEbsu4-`y9_(BapfUJ z`3Gy8-?D9CUhlT&&YkOyLS1CR^}W*cN>k<K?_0D_%DuVQlC3x0q!l*r(4tw-lvaZW z4LR!Rp$4yoq(<*E+>^cPT1cM;kSn<vVO*}52_302c-zQ&Fz+O+KyTf&eA|m3j~-Dm zWVHT8D3Uz%cZvI{a@sL(`i!~yZ|d3y_mx-W)>}7WPHI$D{HW%$29MDn<CheTmOWn$ z8#HtR$s$>TM;~3}*1{hj4LG7AV4!lD>@vDRlCw>T%4JI5r=O-xJdfLC_Y0>ri~xT^ zbf>&!f&8_n8GA<7+u;63>7&^h_;pFX+qnNvaI5dR!wvXlLdEj2r6Y1P>b1&j-?CHN zlIFMd7(F%7xgaE>NnX=|jj_%MY>+KYw&)PBK3VqZ)A;wV1MVg2yYg$=Ymmw=!0k#D za#^@0c&a$PtWJKz=*1VlF#31$Ia%AgYUS;Ac~eQ(&Yd<5@6vi<gN()lhjnSRA}_tE z4Lyx!%^IRLFDfo%A>Ai-Z=My~bz1krY`*75@>#ozJ=3u#W>E4o6Svs7x4F65xZk-g zTIRS~iNnMQt<p|iI<AxLdsZyprOEnH)}@`zR@TXW>-K&fnC;$XZg(@Se8!A&ExJmH zPtsD7`}Hbr(aKH%9>Vjyd|tZ+d&Xc-XJnmt=2BZSyffN?)oTyf<*glibm=s-THZ6! zcCS`Gb7r|#*r7w=d$15?X{!2}(nEU_N^=U<ONoY+i}ObFJN%hl*s2bKDLv#Pr=K}2 zv%J+$j4W<GBPXqS@8Km47UtAzseYmD+NFJS;o9Myn<P2gkLlPbnP8rRJ$}(%#U2UR zBPvM1?4p+vf94tj&`X~Vr}ZD@BhQ>ZDqqJ+T6Moxt6JUT8ivNjHQI?2+R|leQhH|k zutDA0yY0{#CAnsx`l`}fTZZ*Rv3^L96$e&m!-Z9P%V!Q9dRAuXyY&?tpMOn#ivVS8 zAhdB=nx}rI&d|1bf8Tu51r@;WF1CF)%b+FB$V$%ZFKpz%&<c0!SH!(3R}VtHo&U$@ zf(2U@%D>CDM|SLdM3XlU8a}jq`0kfwG+NLqH*BcXiu(2~QqO4M_r2;Gc7qlVsii%j zGUx>8#Hhr&_Rb#}d)k)%t6qc16VVpUPt*gruas-*I3A5ER-B)&3o+DnNDh{vxFXBg zu1DF<GJXD}Cc4^WG9pVW*z%{es&JKEt_iQIie9)dx{BSwe#E*8mq#tJu9H_g1V5Zr zFE%DbBAwclN%ZE3!DfX{qvdw4D;pA%zh-jpH@+S|aQv(fPNU}pNusbR(<Y7&(SQ8s zoCOPRdQM%tXHUPIGZMFq*mnpT0|}vp`fbAo^&g|GmCO4LfEZ$^fBRO=QFj3X*f69Q z30EU;Xb7<!=xS8cWc9aa-_<{5Depc1lPW*HY|ipy$Cl4o$`)y-o@dQiu!}{r_Rl}2 z&A;KBGg(jk>xPAbh9r9jbD2l{85tq$G^6XAfnq$$;6-3a9{)N^*FSpQ^9bSfQPsWo zR;g?CA76d#H62<8p|btTffKj9zUnc;0c&G!$y(f2?SW8kPa(X=?J4fZ;}#V{{=+e6 z@czidR~lnYr2vTvy)bexT3>!dr_lpg6Z5O|M~wA;#ClO!FOuveqs1u<Gw1~TZAils z|HKkK*t>cTSAEO{c2w&Jd4Z0gZFkT%9qXV?v)AXwoo<1oZG{~847GdXA0E7bR!VX2 zT+lW7#Lg8rAG&wLgjH#}hdsNiXbNlg>(HNAi?h45u~R?0^ZL6#%}c%{^2b2~TMl5R zbByA=%=3OJKgsO3Z>e-mL*}pC(mS!tbB>-FH5@5A`UW<Y=Y<`nmy4C@_lOtFptIZn zdyu`0YCqf;zK2i}(=f<+zvmaR$`$_G${;#>#Dl?OiN^Ujx!q~hS9l){GMLrG{h!?X z^d}f{KWEaQIhYHrhNpO@A3b~jQElwl`J?1@FrG2_0en<}wYXj9gTd^cEIM3!CpFfS z+4lY{aX8ykp&w_{=Ih1R>z|C??x``5-NUAbEk;4iB)v^iRaF?9px<GlYw*Eo>=glg z`MX-k9mAr`8T<t%prmBBJo2z$Af(gX0d6vArDfoE={)$^!+!ar@pkDN8}$p;!#QZW z-*`JkS&el$LFL=zD{m<6WzTQ{CHEh5{<jrluXyZ*a1ZYARb1J&;{DHf?)SQ^d%<Nr zUR{gT!<8Yjr^sCN%0XFv-0)2g#o0{*4~N0C?>HVGi4ogaA5|MXX^A_JbNv)<b(((u z;zj*KmVWUfbDh3t>(*m;Z{2#AoR3K}&#?A2Ep;09sk3K3{P3Ap&wlvfvqC-$t;tsx zVIL>=<D|w#*l3>^*^bsi!c%Ryssnessgfz{^$RI2lk3{_u&#GrU-c4Z{nWWL`3XLf zUr~x6<FyCyCe+VY3XwzRtF3Yke$B5U{57R0pe2alaiUWc;LpW6Dcr_}&IN7KKOTtm zQ$scLR*on=7Vba){7)~v`V|e&oLf~j^ZvJAsCnmk{Tq#)+CS&!b*xF}LG{~g-m>xT z6Nj~-mDhLcT9)5t=lbfyM<3B9k3qv2ZvPE6_!RS7K{sAsEAAzwJE=p_HGo*_H&k`3 zr7?Yi%?FEorkI*<Z5{FZNq{}t<R1|mp^FJ-;<YX`BeD=3yN|3~b(qGs>z{x4p?-1y ze&Qg{&IN03StyU;S$;d8e*gWa>1V)(oC)=PtWB~sl+(q|t#`gI40`;NJvoJi#B1>^ zWC}YrU9Wglub9S;so_pf<Gy|5e>xX0j=Ul(dgNldS6B}o@wM=~KsMV5SGzN|6+$HV zo3SS1CdRtUwz3Z%{(x;>#_lZF^@l#zK0U5`%4zL*Pn2R)ZoaZWvB_V@FJ2sWxkedy z<%r76+`e?ceLeO`#y(Ek2k*UT_w6+HF`DVq^nvs$)<}PU5!>JW#L2GgV3qy>YgnZZ z>w5Z`Zu$@mP<oUdi^CrJdn_B`CQk3KcaE*93S~|7S3+SK8+fT(upfWJ47`ku3@e<I z>RkC}pABNiSLui8IQ6?$v4_-fddcpOSiCsKv$sZ~OU#1gfiWN#=+zr<<J(v_40wc) z?9Dbjjl7U4mR-v}!IL;wzEK~9%(p(<Aim}(Rp5)61Q+zSns1d$weG*rzm15VaU+eU zrpl#X&z}43mvd)-KfP+!tQD(fRjy<^PG7iinhkvV;>D-gf-PGX=!X|=-MYwxPacQ$ zxnD-mIm+H5n{Xbo{~k6AXhOD@%6l^|d-$^ooXUYyC4PtAfC%E(!WNhUX~YvPN&3{m zxG-uQ+cK`>(1BxTA{+ms$L={hd-rb&8yI<b8{0B!X8Zm#D*I{c&OUN@%J#j#Yb3m} zK5*WT_4BZPF6UYJicFKr`(}|p!IwmD76&NnMqD?d;=3mg|6r3(%pWniYTDGphbu-+ zozTA$vvNN<{KSV!S=rJY*Xq%?KZJ3(J*Q6TJ8Jlr;r)A5jOeVbx%(K-tmdDvw<@Jg z{N3U5JX@sB<QmS)7Oc`zU9>5nmPo*VNc|9!RC^#Ti0+6&H7eXck(tv$7FU}~ZF{a0 zG_tdK8QC+hIsU?H@7@2cjh$LBdd|%0W5$n;Kh#MMi#wdHe6F8M%$AjNkKX^<?Yp$_ ze&ZKTowTTRi!ga}8K0RYOLIZ9w?MNbNI=K&jAW-_TYKGIrj^eV1Da=1gK5J>gIe2O z#T!e~+sy1XZ%5PH2Az2ByT>2<l|}6vG(Tn8_z6p9s=HF+HzmaFUo^3Kn`a-m^Nru0 zVXdD2&2wLemW>x3T0W{`F3t?S)D+SS!hthpMFVF|jzZ!}B#H@n!e_;)1E(+Cs&@vL zXDB~iz}Wh)AAJ-FzFW4F5X2vfGzd662OQ#I-xf&04>!z7Pl~}P1WQYEWHrEfVajzy zynLLVem@@^J8<0mUmpEO&4P(TDn5Vk&QJH<GIGND^^-=fa?R~~{enf;_noZ_9k?_* zcipgk4?VPR*!rC8r31GgKI|FLf7-PE1E)-p$8;MttXI#`qv;NI23&irv?X6N2I;jh z#%PMbIv3L1!R<t}-M9^ibbK&*eWR)_Pk->;sYidPk^WJ-sU)r4?4bh}CN3L2ZprKw zo2JfcR`~KgcYOT&)B2I)|4vHSoD|FUcWc>d;h_yf$1NurG8}(fqcr4p64!$=5Q}b+ z&DPw#m^G4bTON;ZW&qH0_=esPv=gn5l)I~5O8K1UUe>r{{xxk%y525phu5yyRz7RH z%qHB#w6@*zn_UazeDs<nv-(V*u!8Kg2{k{<pJ8pfkBMP)w!mGG-g4XPzM$-IiMvb3 zYdY<dwIhqyAMSi@=k5<~Sp1L%S?%u9uS?fu?5)<#8@6szUmG@e?$lO8k`jiOPFpx@ zn%1~=+a?{ZfpnJP+lEo5WboW6$8l=3N4g2TRAyonnxEO_qg7Q$_2CY7@NRwdkC?lZ zbknwN<7AiTca*WBg&WZbc>IiY(uha7?&>5b{8jJf`sOGP*p!&sJ8$WhJ$I}E(EIw9 z_Uh5Iq^Kl<4Q6MSJsOqB<n>E#ST}W|7Tly|$Kv9$Oen}gZvU(({5<}`eFRVY-ADFe zi^=)*a{Ctco0v7W!_rO1*R6f@#l`M^;R8!M_v@xKbVe?Yj2PCdI5TI>4YM~MUGe6M zBl>`bIl;X~c5BxGW~Ja6`515w1+M(vLDCU#zKZ*ZVAHYX(~j*Jq>q$)%DZ<z|Ip&a z$5~wen{fxH*ZhpCt%m>eJ1BqKwL{l|kFMG9<e;9I0I>3=V;hIKJB=LCrKmiqd&~BH z`nGG)UGCF%NOH>P4$~JdoZewfO45+F6Dlk9g2IyG=FQu;XB!)}Xx_MSYqYONj00!) zrIns_-a((7_P>K$y9`h3-+2AO<F~DP_#Ybzr!`B>@87v?@9=>*u^w~#mvqU<Shry2 zj$_NeT(m1Xa&c5Ri!X2`^%&i+RS}Jf!v6C>msITUuZN3w*zjiiYsO0IiEY~+JF#`! z$zy|i^%_*(yJtB|Ub%bEiZ7S%-MgIi7%-s6SG@)d=!LV|h}dC_5*Ry-p)yt@cBn|z zYI}LIHXT_uk$885A5L_J*%j`qAU~L0h#(G5E6el3jy*2FJ@@8uT{@2$)4A)|frVL_ zO`B$B6>8J9``+#{e0Y~GLx*;8HEoiWE#fq?G(nvvKW}>rvW8+m;X$a2!d-I~#wxCC zZ=yF_J>!+nuGh~G8`Lu|_kQ&zRuZc})o;M91#Jr^bb`hMdfkG!a9`vj`O}NrEmR?b zetS{=dW+gu_k467&7BpRckt}SHMeZobjzCca=!k#{uawaWm-A1FdL#>-4}VMo_O-4 ze%-03o_w71I>KTy#euClj7{h;Pw&^?WZy!GS(J(q1h=-l^hK)Bdj><l%mRE@m6w!k z26lqBj7;S#eb@&}hAf`2^|n*USycc1%;#$t>o>~s$rW<+ZHEU<*}P+oc9Kc|x^M2c ztMuWJ(NZPwcVT^!nMvU!Gs(A7r_iib$IiALyLHa;n=5a@W|y9O{qoG2t7homzJ5l( zY*S9IU9f!n$_>Yq!kgwSx@pC9?cjyC&J2E_Apen>XFhxD5v_9N%4I8-fGoJniF!9R z4l!fuZ`>0+)3x}T!n}BTPhAk!#$AC}0K;%(0f_H;rAJmUc6<hdCtG|caPUufQ{%R# z)cf&dgC4H<q|&x`KKGXX#`o|4KC)LzN>Ph`L%x5ae$Omc=~<SL8(q+L_44hfM$Xgk zUsf@8*|PEDmnsMIMl_Gx`bu!HvoNz^&W4RuZ{0p?@Xht(+U0g0ozt|sJZ|UnAwieF zlhydaZ8{E}TiUr)K2)}FVOd=NdGq>%&k$l&sWzJOYW>~@$^@VkU`m=*ww*nD+A~wW z=~d4X_87wKUsUV&vOd$4@2|9xA7ceLuY)+Rbgbk5HgLTyn$N}+%~-sLXg}Fse#i4- zLE{<S&R+QP<41q7p$qtwMXT2=m{pM|uUFFU(Z^>tl4bpukKfaOIroe<_vU-IuX(T& zvU#Kp*sGND-XFXTVpm>H<@Ywo_jTV`(4gt0E<2xa9~l1h#a~~1Q@_Ys9UOaW_R%Ht zm#?#(&P>{xn0D!GT&oWH4=;ZLS7A%^{fR>x!=avOWgX|7efPy}>rT)e9R)asgFm9V zZ$BlL`xdyhkB;Y&B5|WoK`J$uC`cqg27wl<EN=Pe%4a`1e|Fi!Ez?g<t~}{kx?;`D z#hHoAXRclO>HNiJRrI3SA9_CVe8zq{@ccjT&p3SkTkb3DhrH3_*z>R2=|pxO&zHX& zz54WXA3u2NyiGnichrP&gIB-!+~+4>{ss;!+lEmS=CZV+{%QG}s+OMk$1Pgt8AFTQ z-BKHFUA*r8*VbqgMqUSeQ7@*ZV(&~uml1z*C6JE;At&&*;QT_wSviiTS_7LZ9;N%F z&k^b|aY}Mfu-y92k%#ZQ{MPgHCXHJ3m~8*y)FYoUxsT_mQTtr4&AYX{VJBDDk#}v| zanGdT(?*qObDlYQkLTCe`Y|C@>xLDdo>$fdv!!|M+7-Y;{;6;~<OAuG{sU>PzF)bg zIrHzU-!Fan`1j~Jzh=^oWlQ}g(4yu1=v&V3%e&(Py8oi4?=bj`cse<TWDxKIexfQ5 zNWnVez8#XtD13@n5ASZ>@a7>8z5C3;q1zg?UVZJAJATv8p-@jc#<XJP@o!pnHv8&d z+qg!5p==52^r$%v+U^@O6{(K!1?)+-kKuE*Rs}i*1m*}1p5Upz&|I&1LBFgYL)wda z<VtV0yG`EBLm&C{vwIir&isZw@Km4Wh`R={hWM-3q>=h(m$DmQdQyMwAD4^sm@9Za z;fnlSbqV(M=PTZW!8=5NPk$mc)hcn76Pus70QYYEhu^Yfu-1{?8+RRj;@{utA6<M` zzYqW7rEQz<V$;T~Xx!?}eMdjjFWsdr*}ZJi@WoA9e|X^DH@|vTTeE@t5M(~LLjeqd zZ(c?wzsBU)GN!}OFaw;oP0^3*zt!kZu?{uJhw6U%?T7Aq;f1>%eoG#p|E%w2BUlKC z8;o{Md-R{>=TOcdJ*QtjS0mLtZ=UZ%*v}F>pjM4yvt|<X0>9H%AC#T?7hltfw)*vZ z7VVTzCEUK7CMfLLo4{VvUe|x{9j9J%Uc3FMdD=$~nETP$TKwte*%pF(#CBIZ+V+=! zW}!*)$)tU^-|=FdC;QzQZRu|Bxn>3NbA>vsybQVQ(__(>1yjqTqn*%Wm6v}!njLvM zBKQ1Lo=D|BTdaOsPu36b+QkN;*^JEdt`un@cw->ozN%eG{P0)oO0{75%$s-V-@JET z|9<<@nK%9R{8@eH(Hn0*uy4iEgAF!JpSfmj<&4|Z<}>fiYxLNHb8ozHZsB7M8yuVY z<g2e<sh+!I`}~D#Z&gw!-@0nXwB@kuNCuAtY>|M?Yq$I9wX$%!(*2}dCioxx^jbM= z-Q7($4SxMM<~aEov+JMytH+)WsqGfen6e>#<Ju|P)-HSZt<o;tnC)Nhu>}27{Y(8I z{{Bj8y{&19%rmTO)f3M=wRH=<1vS6n9VLG`)ipSdCq#=lFIRzFbw=Z-ocrR7bNY`^ zt@iEP_bdyWJ#XG@<khWx<>0}W^<PX^w&%X8!9#CC4$?gJfK2B|^>z3e1DAFJe;)Va zIZ8wg{2?Q~nCCcE%SrOh@`L<){EY7-@Smv$jDZy`^*&Kiq81Odgd4%u0eevPIjqY_ zrlA-C9q)>fO^IRzxd>@}&}UJpMGe^`46NmCzG$8h>W5JG4_AJ@)a1Arj2FXr4m3(a z5(;{yFkD<TN`ghr=RU&?ivS1OXF@+hZvad`Kf_Yl5TdPT_x@*}-7gRO<<hy&KR<Wr z7Zlvyu77a`D(rrE1wA_$I>=qQpyN)za`q)mcTXjh|38JB`@L<^yr&EL6a0-cwaKy< z?kdCe${%Ikly~U<7hXV~|99WjHBtNGjuA-g-|=?c6SbL?4IZbSW$~1!6&@BGgg#`f z*z8b=PAn*pM6EmKx1l393Uq>k(89yaCZqn8)GQc(Gy7AbX40CY6-ACN^*mhtr~dtK zau2`xrhd}spQ%sX;klnKh1_cg+rTTWS&d%vrF^fg1Gu%s?T$qHJu41j!BX%<1ot%o z3QELKjur$)MXeC(EsY^wV4F1JRjRnA%9$uCn;~eBJyk~$5S7nFvHM<p@uin6ML*ws zgR-9vsPH+yLw~|s<HL$}9H%ND+*#xS+78<@C<nZiB<H{@hs<xOm<>lJAN8gM1(EoT z+&tvCX&B&$YPpFp9MN)_QoWH;ugWm9jA}DnFRE#yj65@kU#yQjCBOA6<pee;aD9{? zOr+s7|Hb-k0@kla-@D!tIyNLH#44J@i-lZ_2IUUW{!h_}1|oz9PlEQ+sb9c8dzq7s zkOsQ@$Fd+t8rpB6A)@BpO)aj^9BwbQ9H5{B#hx%>r66R+*Fn9UEc7H18wVr%+PiOP zz`hmIk2oKL!_D(CPKEcGM<IuXfy%YdCncF!iK9k4a5*f_Xl=kAyV>pRPU%s1h!-D* zWdEQ(gWQe1C;<_N7UV<4Zs#=;aV1ukK(2Z)ev5pYf^E#-0zoha)A!pJHcI|aH$mol z7z*l;lV2BZd;M`^ue1AD6RDrOj|Dd>e*yo|lu}!e8bti<Kp5T;;sY=!NW$!I3z$tB zQ+b8UWcpBXW}Wqp>b-dH!SkKzPC+K&PR(UM-~|S+q@z-fdioV)%63)3g9iN%j&-9= zge0TH4iQIYqXtSbs3deaMDqozM&SvjiCSq!Mn;p2CQ*rKDgxm^4covgH0$JEd!~2a zTydABpV{@&FgKd0%HRhKN-o9&iC$uI5l$}%Gg&3fWW~Rc!O9rVXVXUDeMajeYuh;L zsL(eUy(_}(r3{0mG2%Cd#c)=NiVMjABYF2v3)sJs-Ho!>y7zYkVe23XK>U6Cw+-08 zTKa+Yk;c2nkSuTnn^aJIR0wtiPXw9&Dj7mdGN5!bF+R>hh)@v1ONX!kI4Y!7IEPX0 z;U)x@bMV6+0}(M`9%qAIdUc*ds0lzya#CVKyx&=b8E1ifD!I&_PB26g58{MKuGgGI zb1u{-V=$Q=BdcJLNRaG`tW1QCBBKV3dZKbYDLN)Ln%Y7DA9$PPN_#4;)ycP3r8J8T zti2ZaXd>Xof_1Kyfwh*~Thm$@zO|}r9%a3#>wq&d41H)U&_QA&0d*p^2KEOpIyN@i zmPYW^T*R8&?C695z0<d5MNJ>z+Q^+}S&bFb^N+PiJ@ml`J_fc_$Zzto?HzPx!+QMw zVkQA-w-?&uNa~lHh*BpPdh%s5S%slV1D-IoNs&V_SG2ex)7+5nR29oB=y1h{P>MLZ z_TiO>*@)|tS3fs99ZD$NHE7)w6O?M~OZBOP#9Q2(@MtQ|jJ1ZWrzvb`;XD!jlT@4) z=DFgSM3<g^fEo>NqS0nG+r^Q<nTfUdyK7milKp^pm)62q7sxq=1^?<={EfA&RSln0 zZ>hPvsVhAdO@hHjC;*!X&*@bGjE*4)?HN?BAmHQgsb$T*($^3|rI?-o8s~z>IcOoJ z6gLSVDx<Q*y5P>pMt?c%0qw)P2Y)*)dsIj-f}WUCORd}ht!R%~o1XMa`qpZPvpFZu zrX8IP-b}hr2oVjHFrPIEbzPyDLg~P%6#EVejWHR+jRIT3kxBgx8Oy-YBi$uAJ3GgY zlLwq)ZGKjkwJR|Qa8T{Fy$AQ7tj*8PvUW8xMtc*T#o1Y)$9?l1Bbd4t_-I6dLVW`P zM=H@-z|ZMy*`q@G2DHKC9?R;i*hh5Sidu_jxiT}-q4OHc)6Ky8q@Q%L`*g^*oc5LM zL(r$0y8zQN(DF7IeNM3=Dl$l*sgOVDC_Yi<ueBl3P=6aoB7@fCenQ&^bjK^`JaI;J zo~XM?kgj(RPQcx+ugaR;MZL<PH9{l6Tml%Tc69Ub_Hg7Kr-I7R*dVkd1kpFB2R51C z#++=%nin>0lHVY^Ag6$3u`G06$jS+&?S1>d8?b*Rq+pCR!hL<<{@5HKa2)|pw+{}7 z1Kedal#Kt&Ab9crC1C$*)Psab6Wrrk7B<0K=?4YX`#XZwU?Kwu?FUA1FdBM#!3gD) zz!U^8C1{X)v!(&G2=k+b7U2hrChhH-A}w&wYl2GCHp~&!8Xa!^;L(apSg^YmC_zEN z{V*RF@HiYH{ZL$LB~TcLEYt#75#|aLZ~?G|`@v>=E&#TQ1_{z=_Xt0Dz$F1>!7J_v zD#LS5Hl~+4wP9$5piv=OLi`~NT30_9?9y)OEmV2otgZ${uoQ%5m^5TU@T^h54CVX} zVChuqzP8OZe?kxKdVg3@xp1N8YiXW)Hed<yzc-}d1w+A;LzEC1nk5UN{>s4;O+_?e z8;V)Ryu#Y(2n$~ht`Y|Qcp0dB*N!C}+P7|1$CZjqBN;SUFIB!FzrUJ1nC>%TM!3&& zSz*nu(irzhO#OqfmssNr*)HRxFwzFv58WfQW*G<D8v}xeLCID6p)pB3=5av@=Mvkh zbf>4wEFJSUsauI?<{u29!_wrmkR%QR;vSy~nZjX!KJJw%{oQ3T;n0m@q3V;2wc~-q z{x+2P*<e9aQ@9{hwee?2^s(cvE4=Gy6~##CrlusMC#IvpZzu`_;^p{Y%br}0SoRch zBw$Z$h;7Y1$vyTz+LOx;%br4ZKz8P4Wx(e4Vyi&rYYv9mbKlkuM>uHgk1jbt40IdR z&&hUW1|ke13)wlC)0y8%@BW%ZcM{f>cVAFhP#4n+&`1Uj79uh_mG}{v%sFFMoN6{b zK!N*)n)@c;86RtVpLi^RcnqZra3mBz6HnR%#=e3Vh{uYlOSXbg6j+JB{boO|XgD27 zr6&0gr-{74_Kufd#afjMoq=m%AuNYC3K}HPuWPLaSnF2X&$LzpA6(T>1(S9b6%Mro za=?I2E`}<Nmyy6zRY*z8lF_kFu2KWOn(wgYUfUU36F&)D?RYf@!LtUP+PfYjGfEbH z$NT^!of`A6Or09>d-XdZ<GGH2lndOAz0zaIbU+vLG<26~0DY`JE+l3iU<^nS4K*PJ zBm_64xEZrUt=4!~KLBmBaX$k#L{Bnf`X#}EMiNi~QBepl89X;cXZYSTEqAiaxRZzQ z&I1n!0&ECc(8O@Q7zl#<XDF9wtZz}P`ML4+eD_VPSII`;-KO=h7?vd3{wM4C?vhxq zS~`GtxRtxPsar#>hRcco)imHwSl0s7t6qEI6!hkIgx1BIIwXZ=p!&3H8aTzZYnc61 zyNb0{l~egD;9E3o!N;5)zPl*)sc4%ZHFoDyovvsfca_!rb?hcsYrD8#O^D|P8fWzY zcn&&tVr+~v2>ml@#0?Gz*Bb)O2B|`VjGA5HZpi3Du8J!iO@32uZV)}h+Wfv*)~;le zkquwh+E^IN3%>YkYxDbOS-V=IjD-@no6gW?_lI6VcTgMN00N(ChwIn^(Jz9Z9I0OT z`F-^60h!l1o_ZhquPu|3ZPU<d)Soc@48nluf;6UY)1`M;uNSh&MRXs+>0ZgkfHv@< zrX*u%DTBEYg$4`?#5BVLim`|`P4;Pmbbsgua{0u2uqMJJ#jujN>}*(koL9s?90%_{ zz@bAt^-iyI7ek@4;!|rAjt*@j`c;5d!k?*-?6UZ@r%K=9bp^GoK0nhXX@|{z6^|)j zUwE{!wy+zXptZergC<SQiKxqJ2+#+iWEi#r_|#B!YFiC;Xo6%lc=75UfY(memF<vv zyL+U>$qu_0ISkhgl7%<ZaJxEyqoZ!Wb8KvERxGtN5#G}f;m72-YW4tJcP<_%O?FRc z)l?1+@>4x|XF~@J1fN>xMH3P$s0>3Rf`Y<J{1xCPO~_R84Kxo>f+I)~C*1WuwqFs~ z@juf&Y9YiRrg);+9tA4w3?X5Sr9rvE5FLmF>H>b1SVf8Xo+P6EKE|$+w_o@TD)c_; zWT8uX&)6>Qkq=`p_z}HGmo#yqR<bp7NNwQ$x7E`B>po>NOn5K6#Gq0_o$QYQq>b}N z|26n?n-k6!KXN7enoXsS3F)|r<VWV}B)P6_a9syDlf7<a6P8$&UNr7C<{=uQE$LI= z*nDrA(48yUaJ*?7-NB~rOjDG}k>3<IMbYf=SaU6UgrP)pG3-;JDex*A{oj(^$j`9; z4y2yYy#L^r%H44?tY&j=mZ@q7K^p_if;N2uXj9Favau58bO{~Qq!8ql5%#fxPJe|& zcuP5ryfQ`5$oEbQ8dXdC@lM0Ho#RS}&TCRisJx0pGil_*mo#4=kx1t?iG<?CT+;LX zEemM*oc{&BJWglfg<b3vn?Y}ki79v?06j=Hw1}gIzeYg8!U^;Y;7{Ig%gYB`K69Nx z;J6F9bMaDNcW)Cr?BQ=d(M2lbCX5d=>+#DBTD39$%zBKzbL<vyjyvF69B!VYT{E#$ z5Xco#nm=Q8qq%nURnGA{+RuXH4(Tui#ZY%SoueJegTh(_-<WKR0&6^<qz@P-BJ?Ej z#D>Fg!zmj6y{n!g@htpU8TJ-lTyt<%c4-IvWZlTGoSvGb(Ck%3!dP?|si8~>!HZf1 zEs8s9CEG-r2`Z+_L7_5qR0Lfk(S3)!aw*A?iIEA;C>V$layZ=-Q%AEkL=2zfEai|t zAChu|@`^26!o;+^$Oza34Z;x`PpcP$DM+zQ26oU;WSKLoX_V4LJA|spUP>m$F@3or z?xcG05^<-g(sI_HX!>XI4g`SyDB9tTIt4^J5Op$m_A?uQk1e(!y~pUjTZb*^<JCVf zx9hS3=^~0VgiP)cfa^}_JliQvcTd3^92{gKtaw9AVR-q-3E~&$fp+MS=(YUAC{HY& zG5$EiZJd-~2{wiM@E32i1%G;@;h(CX35~!@1d@W7MMElp;dTgxh5+UBDmHOO2Du(6 z&e*tNUW1&hK)X21<S%jl-2cmElQ{oftP1|$|C{so$t=KvJGG0|gUtG0-~b_u^>V~_ zxh`VCcMqbRK~jZ#EFFLSSY)u->cOf_gKD6986kiJ>OOhS@m@6{DhNRXS4K*b<?IdK z*H<f_S$tjs_dV<*sf{$mJ%}HC^Nd(HBl2MTp^B55Pa8gwI=SDg5@Adioqa*0`Z<B8 z?spG-vP_)$4(V6OG9%Usl?areh_mk^z_Iopg?#@s)+&5KK6x%^utVAkL=9h*U9(;R ze=pczGLrr$zNl8v(O$B*A$h=U4ftZff7Pr7;w#|4203Uj8btFI>M=~i!W9g%2SJR( z^n*)Ofl<YWZ1N_$(2>n36iHghZV1}^JY=GXXWE;uF<9@e{Aly(B3;Fv(u2@NaPEao z8evb$ammSsk(PkxBMMQ^NC2VX0ktFE4o?nZ77*^_XQj9#Tpl(XH%Vg2yTEmlM7b2b z<|t+dVec~YQ8>On8${r{lV!pN8SEaImn8=|Ea+kiH$QL_)gZ~vf)GCu5mFi!R~u!Q z%hk-)tVv^7BLZ<stKfPn;cbz10`HyD?eG+!8+G%>*!wDI<7V1{_7H-HG_XIxyHTS? z?HaXfbB!~{z@CFZFo^T!v1ZG8?_y6O)(l(Oi#n7f6KABkKn}p)3g?g*kXIXLVUhz~ z(<T>Z?2~H(*ImpFxdvOWPBdYGAOWWg_64+qKfw^B73WGD5?-F|>PsSL#fKN$zz*nJ z$vU^-m761@hmVOI^0g-YA!Zm#&6P~UkHPWMrqF%i?-j?39YBBb0i<I#X@nQ6PUJKo zhxf~ltcX8B&C9YTEg=&S&*wP@TwdoHcXS$}ZLl4)Gt;2E*Q1ep@I69tO--Ts$(V71 zFrwFTpu9IsFT#9CV{Q>L38=AKG`yzH*g|JCb^{%+g`e{$ArG!4UrIOQZf=A;fai_& zLQ`Eh2D~m#w7ruR>_g@ooI=p@aPz^U#?^@DZWTB-qp=hDHMxyi^DR`)1NOc|NBm^w zckHd14!yYqvkej6h{uJGgQv`r|DeKXRNb(M;SxqKR=fq6kOg;-H|qoLy&RDV0Uz+M zSoxS1?%iWG$7OHLJXGw%{=|e`6{?~VgFU?dV6_-y(-4(YxG(`4vdrxcaHP-EOuP7e z!!;MM&m(r(yAN(VWa!kIo~*Cbz@1}(AHH=3Fb8CB7?~<0BRE~2v_0-!OTav}<~md@ zV=XV7<fVt(8i4viMm}rqqNh87ymWcCo!ch$d^Fx!a|f#?KN4OQRj~jk7sDxLM4q8Q z`_VNlEG#7~1p`B4qwPFim4mexfst{3IkYyxiG1n12S{z)tuVk$RlJ~*y#=JPAg!-} zranrBgoGr8Bw<~rv2G{55B&CAH?idE?2+EbFST~JOgG_$%@T*K&Ug%iQHoJ03r~s3 z1$1WI$ieL1>;@tWh|Aw{to?wnBQVDxN9xYcX^#Y6B%aH3aK=XaT0A){5!|65E1Om} zC~bk9+{~OW5^ciy5=)T+(7Y4qQf3b(x>(@fg|wN$|0yp>ozTbsl1U56ydw?eEdt*3 zw21Ify77t>7lL#*B^a({y7AD;kU>xZYIBkxVALO}3Y0vKW6TW8$aI1#I7WiE9KO@8 zCQY!1ph*w;cI<)t%zCMUD3B@`muw@~ED?k3xNx+wG!K%$zGSl|su(qjQDJaL8U1&$ zM_atPYwQI?leR?nhMexz><LIs<iMvU#UuYF#)&)4lwcexP%v^h6eRi331b30^5Tir z$w3a#pjj|jdnw6@2`C$j&2;7<m4oij74&pnWc$f`f3|VHtiCshd&%RR7-|+7f##kv zju{(aM>v8NID+|1&p`h#i7b(lM6~McIbs`c(VNl#lk8Adtsf$JLUW73L0A}b$ry$i z$2p-qk_^twkhKoT!_X$xDS{K7&N#?m?q;TauJs&K_lYy%GPtL)PaplLgb8)YI06aj zZ$Kgx8zm*i#iErbHiC3a3)~2_;zBH<#E|zXv{_WN>C?vBqK>d96217_(wLu3rBsPG z9{NB?FeU?$5{%6dd85nVHRf@rVdsy)4mcNvPK3w@rxykGUQ9G*L9oauXG=;E;yB@6 z47LxYeK=0NjD3c%Ew$vDB?Awz8`*poxz-u<8DTjG4l~YSBj|&ipxQ8tapVTL7-BTZ z2eUyH1~M8DYdk0DTF*Y&xEDTn*#@bjzE`U6&h`p7RvZy7%QRq9rd3UNQ=HKXUx(Az zcAr0e0qgJT<5GKf8#HqRg)w}<N?`#gMLP__)(IqbBVGYr&zro0`^)Ky^>2o6B*P7* zKtPK7%Zl-62LLG65HR}eLBRvN*!!O6y!6CVYvBRhR62S1rqPSvn~7-Q06aq$4lv++ zI}lFTx#K+#OUUQLwO5ca3T6Xy^G6cbo)Ys-f_fh|x`$jJ^5yA@{KiUjcQ2<~9+1<B zmr}5-Y?}ys#V?bQGGL7?Ml+X<;=IC_Y>D$$vM1q7MlM+G*e;;ep!6UP1QCMsA_o^) zBoSV{2l5bV4_!Ed-E++Lj)iwQ>^QGq!Mk|hYQdh0*&!Vu&oQ(n0QSrb19C8|ILCIL zL+W?Jp7z0xwb$wgi7s`)?#h%=+yN0dsW#w=9B$)X6EyeP%Yx=R*bvyuxN~VKiSYde zKo5n&aQ%Vw2!;ERp3(@DlMED$JUmW&ZVUV1mv*oqFdB4tuIJVfU8m<loB+kyz%aFs zz^8iR3~KJ8eFQJ!_T)%Bmd`fSOv0T3om_D3XR6>w{~$iLse5%lI*Ghch3>m0XLG7_ z4)PRogRTq|3mT(j8c_r-&JQmdw`u6P0iTGtzt1ly;?h&EiJ;p;%14=x-SFFfA%E*S z0v>MfTHx7<u39@t{$$mY5h*UF?$jC-ceKsIyz9DiQ&Uq@8>TkIOG|cF5QRjEpE;Zs zn^wgCcS`GF)B4t@h4H2j;a#we6Y@fhQe$*YD6M;a0YBGaE%4vY7Q;7(tQ9aA4jo)p zH$`D{SaM(q);2<C<+huE^>*oN<WeBoPu!!HQOrLOLdsR9R0`i}9Cx}Cxpto%YA)V1 zb_e7Ta+fk-3_)E|F%~K*0<I(l#)}OPsIN{))VIKnv6+Q_^u$6>lUdUyjT<%0Bd28| zhN3f<oC$Y0=uLgC(nUT9*I}Uy!PcmhzK2~6dLtdk7Ke+D!O1WHBOo(~ZLK*S&>al< zgnL5vUrema<;!y+`IKwpGc~wAz;S{M`3mw0_U%=0YTAVB9SjPN6(^`dc*49mwQS*! zk;8}$m3xjU=|XP#aKc;L#*m4A_#iIKBzJNW7mM_i2O^Y0`0zAYE^ql6`Q(;3qaD(> zkX!JtabJ@bh!vTcI4Lt&LnU2Sv?yL;L5osD3*ch59u^OK(f;DRek6I|#Z8lTv~iHe zNSd!rt$k+X<`idUaAP2jkY|LY@utiNUoRH<#q&v?wJ`W_6Y`6(OCH{SDDMirRJ=sU zFZcxFs^h@lW^@heo)PtocILV8rx<5LxXhux2!i+K&_350`?LY?L08PfBCw}b?1S12 z&2B?>1?UD##9SUy3iY&QaDd>Uyvjz{N8rPKk`{cbrMKaOKy0*W<9zr#Osv4)b;U;i z0Ild4ffskL`0)Cj&d7_GCRJC3OPCvG?j~>(kx`pN19IL#rPz!6<qSFkQ44y08xnqc zsk&JBsx0`;Wh>#aKn9?RS?h)(*E3)r74=jB^;IHxXHE6Y&(Cj@-zF+iU~1G?&CxsZ zz7|$IDaW*fsOu8v=TQI3zVQee)|Fyf=f3kj+iK$rnNp!|A>F~mS1vASOkyMeUri>n zsSf^37Rcce5N~?6*TxNdq{08k_b_?$PxtUUJHI^yU-Eng%en24K44u<zO-v5Hdl%D z*1?xX<Q1{rI{A{z4liF)y!B@I5qr726KB$XCTIT1trL-gKjO=5&puvz4F1Tb`z<E_ zY{2x>y`=k6$rWrtRt$4W>j3ivrn-cZJDd-RcyFQ{Ph<2MR4_Ij!q-p)n~G|Qu|9k% zIq;Zr`&oJe>m!bf$g#|dq43%}09Nu>+7<gGSQ@A<MwT<Bj>7lQAI}y>0x<-Pp*$v# zcQz_Ii0e$*de7SMgTE>71@UPE{<LVM6;bV)fFBVZTr-EgLf{YtB>=(+IPmM#AF>MN zicx5n9F-oGPUULCOaxXTl-fh`qe$;r8!u_DL~ReTZx~u_<|fIg7s1oT@sg2JFORTd zMoIPpHHw?@1V*IwBqpL(v3_FxOca&)kPU^WiSL^YJ@&l48PU^sUf_?fS!ePS#K%N| zKMbs8YwCfCdmzd($V#=5&S)=^!AAa45oCX{)<v8h>`deA*uQPpk?#zrCZV4lbbP)K zSP}LR#b&KY{?YLf9Yq}uuc_ktKl0$9+w4X6mJvipU)Cp6Ej2l6o#j<^Rp&HrNFysV z(k#_EoQ^!VQuv82xruwnCzBROb0c$+ONmM@n}4374IA6*%<3h&ieyeRXE6g=z2H<| zd_>^N?F0+1Q>8Cq7Qha);0OEFFdFKrn6gwGaaRk`QRIqpAF>6Xsiol(W~KY%fVY}b zE%}RF8)_rZ()1Mxn7J)sfq5q@g)M=1ncET;z~$l~f3u?YnWUyNMpi{066Q10jdKY$ z?OAay+{f(2!;YRDyTE;2-JP(XUGql=%77ge5q8^<AcstWQ6ElbTCHhjWbxymmyz>; zz>U|CTX5UWcA|!SzdOu=mRUuf1>FV$5y3zs_ZUNdAi(^~<&4_#Oz*b{q9N&*N-6`t zbpNFVQ77(XtgvaL{M>9mPBzb7+))d?c0&%0lhFObpH!r!A)CUEYzl{iD}QkoYMFeC zVQO{pEw{%kbh@4Gg*_HnE9W!LYNLxr$vKo97g#GN&fG?F#)8A`((lkQ>&O(QM@>9D z*0VODhrveg1HW}7U-T}vbHevxfqf5q9QqGpTb46!k_wGG2fZP1^C^=k;Iv4)Grj+e zkx(&M7gvzZ0r{5~Rj$8UaM+_{fz|xZp$Rgk@DRdI%mq`Z+`(#<8{}3uE9SFvI40&@ zOqMWr+s<pnlj$vO&1Ge^9EDnO+zs-T*n?6q;Yo%;FX6C_xV^At5D27{J_Ub{!=wr_ zXAB=>ZVrrG{23D+?~T{DhtfV!)MvD(y<pQoE?2WVkO2g}-)}EGsys%IC^@TuegFrx z1OtGA^_+_2hvw}{_(rkVCpw021iDe)a~Df4LR({>Oz8cHDy1aG!FwNAElCngu}y?t zg_>>haB`n1Y-k)l>Lqyr2i6w3+dmUuxd?|LVr}Hj1(Pl%;+nN{xG9UwW=Ds4L<qnH zh(wsrTJ2B)&lTrMsa{-oP7#ks3tTFsM{!S3)e?vW<E}E`pep57Bq(_sSO^_=DBk-D z;cpm9IG`qlY=5>C{sz3kXmW;>e7KUWb{+!0iaG*e2Z;@X=485!;P>iFN)Cl(G1M5l z81e1t@Gm@X<8=npX%Fnl_vj??TzbnMrj6&f1GnsqZNSNOZ$odCz=hMtg3B(}AM~NV zAU<6D);F_3>%xT4FfrjWUEuO8ow)^<T`UfB#{B8!w}&qqv@S%fyLj>7{sjvjJ5ZzD zjbdA|(Gk$WOl<sZ0>4e`LI~GTU}WSt2z<T`z-I?$=c&ZQfqQxF0qaJF6;Kyue%sL* zAvfLrq3D}XNW4JJ^}%lns;?#Vfxz1>C&b4%aX}CmltMy7CZYves4q*<0qKQ`NlC?g z>T=2!)Pj-y0C5Ay8(mZC$w5_Z=*i*Aq`7%XiM(|YC6k1?@Gt`g^d8gp3xE7bf?=tE zL0$!ae5HGOYJ4nQT!jsDQ1zoVLZv7)fUr<CG)%1sVKN4M^BJxf4P6pRSqf@Dl0NYz z5zzTD8JC4a^uh7kt}Pr`tV`#PrS1-GOWKvRY~G|z(>8hav$HbNk^xhAD60Po<bo)X zL)p7#ANm}m(>ZXT<c-E1c@;5U^kj*Lc_cT4%9tLElqvYY@PZ)k15PA|f@)G5Vw=>Q z1+tNx?(j8g8h5#%8-g!yD%$CaYlyHoPpAPM2G`72GX)*E?{bB)XBp^F?jC^9uT8?n zFl8X>QLPw6@?ApMXB?d4$OguSsvX0V$3cuKlSGOQxgBv5FnDRgI}Qf*{jFMJV^;$0 z?3MrM0LJI?0N+%c0ohZCd%jk)x@I9dwx%RSMItzhsf=`9|H-%DFU*|gIv4R5dl>6# z?6nEMqr00k%7L6-v1TN`J77Cc^p2$O4szU!r6<t`F8JYuSZ9=7G4~hW@)}3Wx0P%@ z?tI<f{uZ!qwR8$?E`S%pqyg({QGVZ|9&J`Vd|AJq@g?vV`=1N=uA+aE6y^?2PK@Wk zszA*AR^$4#1=igV;S=cV2Cme2TA04(wB>7S!~NE_qZd##vPLjLuW|j%6hRD|Sbw_S zna^!9<R3f4={A>5sksCSXQzdzV)kYlWd8SpzG+0?BL;mR0DUn}EiTM%{f^Vt@*UNn z#ntg0r>o^VswWG>cd7CI>v39nzoVKkI@Oe<1ni4bMZD%?JR=PReE2DcA$|ipx_B)? z7a4|0<p!Ss54qIlgHL={*^!{Ld{^@Wz8h%c@LATYUQN)&gnQSkc@+P3f{nxH{f=r# zGdSNlF_h0Cn|z18ZN-8=I4<{d8d7~I%~NlfiMS^3A;@Rt2p=lF7wiFp*3TgZ5&Up^ zYC=@7mzTx2yspLaZ6&)AcfRg#c}}I}+iK}Faw=(RSgmzMZKd~H@bW_H+1(_^_!9gn z_UE;cmhUQtCJ=XGSR)74;AK7^#`Y2MW(?u=h`@^lBiG7tJS_!<J{*7X9q(IV`L2>Z z4gJ3Mcibmy`3|#Vkq3pjf~o%NJs+@d1-c6)1DnkBdf3@KqZr7MEw=Z(-=5?!R<fCR z12~@>vuMQ~e#-Bjp+>GO3M+~W%=uE>buGy6JF-uYLPM@4YhV-5yfA+mwnr(z)rJJg zu*w=fZ_V}<eM@?aac?Uj(Q^Q2ruW|R?=(lich%A{NMXnEoOJVki}k!Zow437c8x?c zE;9nwlLOY<A>GH%#^qfPysi$m{XpMwUgz%t{7&0pQ3gL;FWLGY2-(7EX}RN5OQWze z-Ehm@RlXOr^nNF7{c?O6D1**=_ZG5h7i))UKi(C=yJ`9$KJU$hQGB<Dfy?k+gG_%J z<ikaLw?jG(TpY)fyt0aD*xf?wJ2~%EOOJ3`H*f_jg1^OgiC!9t?{-QDA=4pqGyT5v z>DllykZ!dL8Bug5S-$T)J5`zwXYvC74u0*ydNsbw%Qn{|`I94L8mAu(iGhtKeZ^&N zPI@#+NyySCA<1S7Ic1S)duxigoJx=5(huL^{>rOt{M;<xO|7Yi&ZUmyB>BX8l*idg zoSWsloi%fD2fR|3pGO~gp5T8DAIWCaBqHZq!guM3#(HQONwVH|zCwoYilx&vcI9s& z&5J9xab36r-I2QmzHByhVR~a?Y~noXc@FbgaG)RMK(c%2JJ7E{zXRXpWJC!(XkX>D zz?Z{!FTT^H${v^TRZJ90iOe^~b5x;uZzf;SceGxJei&aS#_%r*Us_MSwbplYlpS?^ z7qA}qV33FSz$tbX>)DDeZ<}~uC@+Oxx0FQleM$2i<#XOl`1p5#?;wXSBgOk2y;qhy zEY_o33*!6KB=bA*20TG{Sl)oC<q^2);sFq{kbfug0KDJP{k<P~0Cm1qA`Wl)_I4JI zHxMriYS_Fl3qNbnQr&C8opSof?(NNWy2knSGhtx)&PS#By(a$rTi`z&_y<2+2p!4t zEnnAn_r<z9q-|V|6*RPdOZY_z{hP!5kO9MJyv2Cm8>9vaeiPsM-eK`wwR8yYu;X}> zJnwhV&1e>!NmudRTy`DT%?bk6<2f;weRn{{+pu0E?|OxvBeisC;>*s+O(eeL+BEox z>)f{QX<x6-O);fAk)q)^9*fcM0uTO9Yti(b<^A0&Jr2%x952ZBe}DfG@ZD6bNOOzn z^|h`S9Pr&v=_hm&srBw_Jp#Vl&3Z@^aehtmvg%phbDBvfWRC^L+u;GDw;wJY>)Wq) z<MZqM@!7+s3VPS~!U<oOB;+Vx6OE@yj<Shdj%KDr89IW{C4Tk7DRhZy=^;M*7CNrq zcU+$F_2@h3xIGgAA=hy=aesP4Uc4=MoNP*V%HS^-zu(aj==sF;C-EI$&+^?a=|}$l zMFo7vdE5IP@(w1`?RG};)%e{4zdCL*`4BEo&W9KnH-pRNj!jK|CEwg(Z6V>y{aG%K z$B|JId1bvt`xL9NlbwmC7AOeNP&FbFC;WQsl2gm5Rwo#0Heu};t%}yht~pZf7^3-+ z8Z;!7cDkdHI)mgxYu`^%$6W|tBYbirkXXbW4Gy#(?MdziYW*2RNwO9{gHeT<>~1cx zAphS&Bs=J8ttyRQ<4*Uw>Njg{1HZJlz@BHoZU^k}^?Iu^?AEFb*ytb+oD(Q(uA?La zxsJRd!|)~6Ah%vVt}XJ?C*Rluu~^E1q8xBlk$9jF5x8RPjBH&6URtj&l-fh0ECBaE z2z>x2i*pPjS~o?ra!on{7Y1dgq16EDXURwN2ia--%x2-tj%jneFtrsh>0jYKQ6EgC za&phJ=xv9jXi5vg*}xka;NUcx+5tBFq5dvl<9u)&un`~3!~esY5javiI1HpiV>?2R zXZgqQL`#McF;ATWZ^h+A#peotX3eYUU%g2iCE$er=y86pj@GoPd58KpM@C>mk&F)3 z62QaVP*9&ko^X)|#sk6JjfqNNo&rX!%M;wq+8ll_L`<QTq+qlGz(P+yzZ*ehCI1V! zIH23KxCf?>x-;<qmsqPatwr$y`1PWB9+{$|7C}~uqnIrcgeZbL2Zzn8VBp4~RD2FC zKR0;4V`F8Ola*dCHZ?XSAuc==V^W=Fz7_4`t^dS6x!4DpF17Djzy&j|R)7Z&6?vko zuBE;c>47*;?&B5s3?+QpVITAaGQFXoxYaXRr*~TTKdm{a7W(92Jw!CUcg(Ny39Hw2 zx5Uj7IhMRuL#)?{;LFE)Y3>xW#DwQe<6oHph1h87;t#w)KVKaHey<TeLVV)t`Ttje zgp&R(XK&B9;8uV&L92xLh;VcXQe+fQCsLnQ2mE)qNRWtVss$wtUA5@k@H&;oMnz@E zIj=&iCRh*sodPm+(fukQE!RlMwV5$ko_{HFm3kA6nqr-LZiJlbkPws@YW4>s9(%=t zPc!@;-8b|hpt}L#KqC)Sq(dSIg|G^mRHJ5;(mXgDBQPPe<iuDfjW}S@a+GG|3i6x> zv2HfO(-P}KHh6PW{8JkcyfLylD7C?x)L_)U@OYD0i{D+uXrvsst9ES08j*pxLS{dI zJMnj0nfU#Df~5_9AH9irPh)t8z(>evS6C$F%uq@=<qYze3)YAuLgDSZ2-*I3_WtEK z+5g_S6ZO$qC~6*gKN+E`9${;0zNffp3ivZSOO~_<4AYU|fH&kQ{Mt%CoHR8gq=RMs zs0s;rw2T!XxwSzqBL1l?H9IRiE117c6KcLzzSE|WtezmrIg-%5j<Df1KayV^RbHq& zP!+^WHSEG4e+7yLvim6=4?P&r=G1)1DTmqgZX?dn4=(Olduc)AXjgPr208^b5cR;Q z7aFNH6u99eawMV09brd-8*-9>lEmsc;9SS8Gu~{ln1M@ti31FVOd&;yqLd_8W=1-i z_oTU;z$u8=$)(}_nW0T4oXD=^?+@PFiti}n*zfg$bVc<Yy}bc14oZ-a&I-Ach;z73 zyk&{B*0X>^la3C3hoZ14D9=a+`2lB;6l@C$#)t^0MMf7bK*$gk=V>Xxvp;r$vmd9B zkLQe1q+?xZnuI;5{&Sy*U0*9Hnsf_zx~032uB?JXq$?XA7bP?333LWN?ZsPQ<cxyj z+$-03ez?f(9Zc(yN=EX-$a+WY!H^{23#<Gn)<>ux3pgO|Gzt0!-E$OG#fAh!9wy`U zBV<Vgf?l*7@ffPVk*UQ>ok)*$^2#mXgm(fy6dsSyqqPQMEoeKDDA$6Hf?p^GA;G#b z&jG_~{E|AIF)>_csyTx*oNGHnXUKU(=nxe()K><vT<a<RneKqI6tP@>mSRoISyq(A z^GLV%EdTrrz2_(DcSSz_6oS=~<9>wA20t4b9?D^;aNWEeKKfhh1_ZBhzV*TfU5wp= z&Wga<!fiHWk=W3nr%nztcuU|s3$eU-aTjJua*lKkWXGEFLad40k#t1Fa1?Z|)Tzdh zB0(AiNJI&VV6{I*@6Z8?F)(f(Yrq<0fpMKV!N`ac?=pIugc0sMcO7~S*8jilTi+94 zP7yKso`j?D!&S1)h|%Ny1G`G0AylS`_YZ&J{qxn+afvnp+-DjtB0)b2K~Zs^aNl?i zD&FG;lqJ>x6pIm=-2q9nb>++Q?9xar)*P|sH)<?53WMF^#OOd|=Co*@g>j4V>e$WM zjkb*5b@<LF{{5}~@x{aX<-VJ8TJN5^`K~RGU(m0x%!}JE_fX|ma+>+ZjZH0Q5w8}s ztC}q4k=^;}gzmU-IG_Jg-}>9%NUBF2Bi`+{Bo9!JN<3|;Kqci-l%2w02`oD`3QnOS z37)f!w<mdd4!R(Cu9AHTivd#k4|GCb8Hh!Sdh>9QxWtP>&3uxUu-jtn+%M9S`072r z&rZZkchcLKla5?CZ~6-QFY!KyXnBn^ILi5l#S0~iE|m?*EJK9ii0ft+)25}RHBM`c z26{+hX`XH5i~s*<+wl7*&KAA^jqV@WV|CoSx^ElZHLDK$e_<y9X4`pjwp?bsZJg~S zoGtQR(UU~8p{YE&I>e)eXe0(UIFNX#$ke#Nnq$c;tY8{I(Iia^R-nrTrGz&lX_#L> zhh?(#gxJ>J{7UHP|Eo5~|I|MFZ*32v=f@TvxKHqaU4>*tr8IOI8ErCTB&xyqfduvn zT*?*&)nJzS@xcFv9mD(K3A>8h`mk$we*;K#xFSi5^Gb9S-pbYr9iu5F-a*m*j+>Aq zU;j?q=x?xXM6Xey`yqQylS+UidcPzv|JeklY%=@2dz)?|eTOFCQ5yp!=}@o9fIgFy zoDRI9^Z5EmVIT0dRN{7fyC#8{(BDz$50%)zdp5aEur&3G3hWa_&JwIW61?OTv5Ju- zcfU67W(IPQflFoz?j|_~g`W#bvK&sg61D;_c%%$yl%#^usD8n?mC4DBCFdn0={d`l zUJu=X6Juj@=vE3`)Xe`vUoL{aTqS<5h-lpxG=RPVo>!&xG^Bf}F_;|}2d@x7L_QK( z+hmhM+qKz5#g}2mWTXAG%d2k?ZK*GPJ*uLKMxiCNYzF)SIw*SE3KB)l0x~8gB0VfJ zJP2J8q<XBLJ)({YvhnfexK)g<l{;8R$lmmFY0$2G*VK-ILu3bZ|L$mJo|qyFn(^FD zq2Id*_aVR?z7y|rXzlxJFq>gE7!M#?{qp2ZF^`AaKyxiN5IL{^$gYp5ZPyE)v_0q5 z!@-j<HU9T|ymx_D^fB9)v~L&U*Uve>R<co$4$!el4UlNu2+GrlOO48PYWpIO04Ipb z*D`}Mc%p7JpC{;~#ADE!*8mDWn?tll4Is%avkD1odgT`RdcAVXuc}JaIeFz4T)FZX zQI8EXLX${cM6Vmsc?1jvqo8&N7KWl6rx4SC3l@ZgzA-)<Z8gXHzwY;5^P}FK9X4yk z0aFjaRN!tH8377X>kuGHUSixMkSrh<m^+9KUV{8k9~W_cE<e68&f|UL(?WiPlYS|= zP^in$>&S+prh2If$k)RSb)Yqs1J(;FdQmbiMl5i%jZC445~>UhLo?hM*xPsqsC^Ti z55EgSUb+4sd2a$=WpO?HKQqr=l6!A9AnZ#*SOf&J5+bNcAS{ZY0wSQ+0D(k8f=O`e zuTZPi)>`-01ytOSDplLs*1gt>Ytf2J)uL9>5b;6+LF-a;|KC~ek_EN>yzl@0yr0)N z%yXY*X3m*2=bSln=8Wop#sd22CeDR9MeSzktS80>2GvEmu+<Rl{)ukmBvDZusT4)( zWLAtX`fx>a3BKs%=qIN;*id3#==5Wf9}h@<MxsX<50sN)4^HSPzs3dK%xR7Px%TTy z@INodPfhQ6w&m-|qaWADPLAg)mRM)Ua|$<Z=h}p?aAw*+tV{bF<qqa-UD|KlIMqpO z|8e`Z|4l;s8|5-+fIZuZ?Wgg8kl;A4&V2Z8?bq|(1pHTvt>7Q7orwR=tya+tp$>w( zb>0M^&XHhrnLaRfA=3wXd?mn8EsmxS;y6-$0C^gxf92Yn#1W<4yTF!jy1|rh?3UT8 z4-)+4%f(1>+F{N}B94nWs7;NBsExi?;u%TC=U>xJ!dNJ0ty}L`?omDv6rQ+Aac6(! z(B5qjKthRe;kS5(iRthPb#5@%a0`~!oc^UmKGj6Y5Il*CR3bd+B?LutTRiFVyx2GC zeB<GpA*BOxAhB5FE2WU?&oZKC*|FZ}7Ngs$y0~^mc?PNx?ina{t6!x#+B&Hh!$Q+k z%p^%f18vVz3s>qtW|Z(t6({Lp?|y}EIOiyQ9+Z6A_<L7Hz!*TBB#)aICkZ<rGD21> z`&M^`$5xBPI7#E(_r*yTHm+TtsG)5crKzk5I>&MeNCU(m&9C$vBq4?Z>mF+UEFWj= zv8U`X>mMBCi)Xj$CA|)UrCDteMaN3fofTgbA-aKH717gZg?H8={ELkrN4|o4o~`d) z{5XiEhke<>IL&Uf>?{>T4;NG^GJsrpRbyU;A8T@k`8t@hwN}T<v^LaCDpHYNMrMx4 z$;7x!UBw+2dAFK*NNmmA@7yj9f&%vFeA60X^oUWjXuzx_wk?#<rffLsc1~z@$3>nY zMlNd`J-Rk{yj{?{-*m=OROjZT(11EAG^Tqe2DzWcc~m;$JE2^a7XB?~EJa4Da{zsJ z#b}E)BYdP@>v+t0N$F*yvrs~ZVEdBgY_Tdu3V6<9%vn2Rr!xTu=vau#WUBfO`;mWx zZ@em(%TW%x4&`1enJ+t4rOQSIC}Om5<k3@0CKnav<*E=|ERMSz{G|$4=M?vymYy0) z!z13~oD{&jTS-!a8)L-x5`cuwh{p^$X39~;lM3=DPEh;0^ht4pd#hb!y)vTvZdE(J z=-duxv@=V!1DwyL$2HDNM&X<%%4twp>CsbFnOz!$tFdZPMoKWfbBoeK@fICRdxlIN zq5<mOre4uDF^>L^o}FrJ7+MENuwj&o3z0$7N=px8zCa@|heC4H9a1jAa$)udT8o8^ z&7|jf#&=rVwv|rpcg&f0UCxU7Uv@qf`kS}6@ypTro0<QWi((`9x=sCn$b(WHJ(5QQ z6`S~(kac##XZ8vr_k5*M9)T2i5ZcKroq&W?;)%d+9LosrO;=j5;=yrI2Q?odMvoaV zAi7o?iFAzeK5BRXQo`pvZ^{~hij^~<FS~KHT>+v$35lkseiBo&xt7yMj_%jr951NG zS_yC$`nCU834BuY)wsUf`I#7@^!+}{D1op?cF=8ZHQS0<s$di2Vpxb-Y0?8(1(?Y| zkLaB}qEAfUDuY%}G5+Ues_cH0?Q`xPnXP<@`m<w^)!}&2@g)!~cue6;C#-Q?6+Y4y zPP>WEn)J580n@fo%90L^EcN^VToBKAa{k02Oh$_fq~9ISdLnCys2I#@S+xYaTBd-X zBwrLi+Mj||B|-z)_=ZaKk5)@nF?i;693PO;HFE0I{LWeGWuJ<QnKQW<ZZZTjEc=tx z;-#Z1MB|Qz=8rKxwKvPIW%1=VR0^CkJFfDa5w#y7$NsM16dT3O#1J{9biUqC%KR$@ zHtVW+p4kFKr?KdOfFS<B8E70tgLT#ZWxYO1hjBpk0#kKTQbyAB+=;zd%8V_SD!N$E zag}?IN86!UL>z^Gv8i_!^>R*Ki25=?IH#C+saNTO>ZC4CaKIakwc6xl-x&e)H9w(| zIA%p?4<0%*IXQYpw62)Y-75SMXH&B+Y+!mS!pSGb$#LeKIt6>T^Qpx~8KMo?+|@c# z&o(qReF1iSZN%@7*6Q<R5aj_b&;KUiji#k5yPwGij!%eurflxfQx?z-I$J|<9AS4^ z!f|}D{Z(qO7Zpj7gMQKZpbUF1h}MG>_`wvq1Fh~m`y}+i4m8>`L&?ZKiU&Nz_iEjA zKq^YPRP0FE7Pal0wR2agPb+yK=>t?WXL_GL3?@5wMb1g<-|!##$FPR%f7QgD)v*)b z&|`3uTq<sIJ}w<TvrML@95HO@zyax~rnyNn**)gyqe><f<<mTM=%YQSWnxB}Oi4{S z3w1FhQ$w8p?WS`Mf#W7G@x%P&e4>#k|Cc}#gBAZ5_S%Oy-sQV})+heicl;t=5qt2n zOG||)omV>VgyUz=s+cB@6~|7UGPzjI#37+keR?q)*K1y*;qN~(^YPJYynJGCfxrJL z&N-!x(~brgqXzfK4j@P4HOji+1Rn@d=*Z>Bv}71lckmTrQc_XxV_4wGM~j82Q-zp% z{M6%TvzxK(STRM=tipn5!+Pn4LEHar-zxgt>eqYL5_H=CN6v84u!q#xN`SrEX=jeA z_AIlofUg!DP}!Tc&mU7@m^z%kM?cuXgY<+<xx&WwTAK5@wB0bK#~Zuh^8eq?YsE+0 z|E}Rd1&W7kfRuG4lurA7?fRMTKiK8lX@{?w_v`(=MqXE{y4c_AsJ+GA_w@!vbU$xu z;#OXEqUf!>A(%jHEAKaN<4v=^WJYJ!vMj-0;Q#HjQ06jsgJ>0v&xK#HA4%y?)y{3i zl7j{^(Ir_(K!zlcwnX2R)~7@X_df9xS@7yniz}ne$)s6>2lXE|U|9SNSdJ!z7p;nf z*{d~A)wxR1z>Uzrv{K9`)J1SzC9o2!P)iK`V19Nf$5wHe^&4Hb_phdG_%CHMAgjj> zR*}|vs6pvq(X&>ywN(M6PNwc$+qa&zYGhzg)tev#t2v`+sq;$dkZ%xwt`&b{(?m+D z2+5R?@<{$JlJ8r;NECYC`f?|E$JBV{jEd>g%F9Z-$-0bAvd-Ax6J%YrSjb%ItkPBA zB<9%56^9Y1Ln$W#eu^?-^&sPfPz^cun4_n5lW)2)(3DzVJ;V4x>anf$W9WE3yqf*; z->e@KjSI7-KbdF+-F0N<O!Fa7c#S^vI<6we&e&LhALBh{-*8MvhUT!;aoY7aYsjIf zZmi6vv9q`1da}=F4mt6lL#l%odsdUx$wuJ7%*j291{3Dwb)px(DafmDn3HSiwYcky zTn*xc8M)SPD)szW$C^r*AJ;k0p|)V#?s0w`4PM)Ia*T_^p!nn%9LHeLw(SHMs+nY* zu3`co76xXGtdPK%7VEXwm`8*VW7YB3aY&NQx~qXh+qV<osCHh2cHu=mz@ZjkqA~9} zukQ+$aa3Hc7&NvH6U$cX4?1pynI~2gD@4b#HBCNzbYSDCsSZ>HFWS$~8(&{k^IT}` zzdE<Ji=Tz)1M1nkg1<X{=Yxo00RwhHrR!acb`y2{Rtz{g5(e~7Pcsa-Pw%vT>HRqN z6<2xHe@dUpHS%5g0EkS=hAt?ZnW)l}T*B|`b$RQL7^^|^^&X2=<r-XS{;Kyk(Pk~D zo`b(CIhD|MBdLgVrF?@m6oEJtim@j`(V4MFp$QFEIM=Xv_o(rtbTb8u!ukAS2g^bi zh~jd@oKI$<i`8tQJ8X3d#`%%3XRG01gk&A%d}v|(A@p*3=@J1*g9*OEIVm3YRH#+` zXiOgVh2Ts~2o%M~uv{-z3aJj&&QwHkFKwJLwhb{IUrNSAM(-T{XZ{=GV@p~4KVWDK z%kU`Y-v-{^{hc+XXW<KgkC{X)`f+)7{M2sO2-w+V`htZF9BdbNVr6(D%*Wu+Z<^wC zI<{4&nh)z1Fe<aNh79UU<l+>3a|ukHBXcY-GyZRymnHbW)j7Y0m#Ouq=o!CJ*Eft0 z7^t8zwG++Dn$BW1%hk(7QJ*))lX7;$xD2k%T9M{sISSUL8rHh0scQ7cN{=m=CKRun zteMvLuuP;Yu*V0h{xmRXUX}nuwex^or#n0hP!rtYFi==H%vz~|L-Vl&IR4k4QEXt* z^S}gHZWGJC6&3&i9O8|4?-3oZP4!6vEVw8z-eR!$o!fM*Yk2=R^@<vP(YSD`<1wqn zeLZY7=EP<C1sjX^5#u*JMfLr=W}JyMU{O(;2gCi-utDKA<_bp+8;XSzy+B90j2b;L zX-elbwO$8}>6Ljkx68z_K7Ouq887WN`cavx=QBH=Z$ievL52-gjv1^OBs=O{8%J4x z8O4wq)?Dm1r-8YcL%-TVV`5CQRYnLa(}s&|ku_3z6S2EQ^WR0x<)->IpX73svpd6a zMmys?#tu;}+TfRHC1Y?r7(58aLPw4s5yTlmmLHK5!lk>+@DNTW!%HKDF;B=IU#d5R z=><S}VS&=naGD!9Pz6af8p*h^qef;88#rX(kc<Ht{rjkBqG=<Brzw%3#sRX{ce%j> zm!q7oxINmr%!92&@o>=qK4{Zu-6EeOM-DeF8kMbE6l+H!W3g@0=F={1QaY02FF0Er zzD?sgpcgae9jE%{DAgA6l>2UEjnXr^?dkD3Be3Gia^)$bv{Yg^os4N!g^k5jJRcJ1 z?Xe;4M~+bYeUgli`Y|0oPt3Q7dN5M!dOY8up0xj<9;F{#W&Bt4z6<O<%DS%oS5hI` zPA8>ev&XiMYnKXik0nrvL?~V9xXL1`kHDedO2E-=21ja5z<JxW-7|r<pILf(dP)eX z!=X2RLHKl^+N$X3*9#_0Aa&f0PNEjWe|6a@M37b!cU2EaW4J20(AygedOI>_=wKD} zHZwEZ?hmQ}cP|*ftO`|stHs?S>gVjfUKvFG^5~Fc?2XLUO^DTO7{E8zJa8aUi^mKc zGit=JA)NojxemH!O|!)v_xG@tyHzS(i52r6Y(MDGY9#~59Tj$6`ANlM#w*qk-2e?< zt2^%RVeNJ+z7>vw>)ZS#)wZXkg<w~cotmpEAs<L^n>@^s>}o6;d)_mO$0pdcw#Z@Z zqGwNNj!5>!U_%YGb}cqr`F%-P@O=RyM)=ru6$Lf{N^>ZC24?|jV2!;;+qZl_QuW2` zTYhH?bHtF-P+EVC2qtxc7qucP$1x2j1(KtOvoB2*!C=yS6Ui(Fd*ZUSGd+Gbd&%VD zN%?tQ+(%<)vunHF?>gf^+%5vFo-<b*DExs$9QZg2*B7Yf2&UwKe<j;r)p?XFW2i~Q z1nU~ci30|yrUWY3ViXy4uIhWn>2G{%JK@78ZZCb)Szr47B9R>Gij5GR9ZIeS@1CS& z{Oh9FK?Nh4>ry8ebmph%zE>^-47eC>QZ-$eXU3g&>Xf5OiYFBo<mGn9OpG?}>w=ft zn4*nQc<C>E$%%NOa{@`p#QOAspOvsgC*V6AUIKwGc!?8<#!KXG@G^wJ@6d_%Phoii z)9P&}Haq8*HWi4ZU^l!3h&;$TQ6QL9&5nLgAgKrB1OnfVkjcgBK!@%KG5ux6%kC~X z*$lhrrF;;M94JGb28=H`l<W(!0;Z?b)hZfSaxk#eNlp<Ve{v``aMUhpcyPk-89H?6 z_@U#~R5fc@jBZk+wiZP<6~4_~=w|c0mz^J#ZkSmlQ@ahLq+n_=DYcrFl29-uv{VgT zmrw{Q1c9QQ(=tSAYH&XE!`vW7GwGUU(kw42DN*hpC9_IqDf5f+ljwnVdg;B222VQP zYMif#TiNhA%sIQXZm0+ak6?B(8V@w+C@Drq-ts&VEQO=_l9PNK`o<DSA`wN=7lIdr z;01|;&3f-oWZ`gR&hRXy<>|4eLrF%*+7RDwyWs5B`MaDeOD``GsVUP$FjOuALFg;c ziN5^hb3{rhWED_!755IaxWv{G45Z>d6CH$|>8vvn6$+0d)@121N3%531FdC5<H~E9 zlMoL#2l5zAERxg2JeZD=J?M>t`e$+;Mht^+X?q}s3ZWmRyC|YyqJiX2!pQKYF5}P0 zB(IKR6XnyYZs!_@BaIy+o0>|`o>Y+QcEJ^!j=JF~ikFaz61os~BE6Jv<yFsosYlen zv15Gcoi1bW7E#7|o1E9(7t>uLHUhx_oWUPFOC1-k!f-}$lEl<7$#+^$M3k91hLGg? z+;Wcbjgpb&*F$_acA=qL&P{dBFFhwu1fb@G-3>^uPzro0C7ESR0-!=Yr$xtGe2}3= zC!eGYyvd<yX?nn=+5u+-*z{>-rMbuE9((i@{F(~7a3)19F`Vewb_wI{4mMjab2gWz zbFO<*q7X9?R3^pH5&$i%u?JYRwv6f<kTa;XsLO{S_&a>JxD=J(8}WL57rfqa!BFRg z(mus`GSF2J8VE`aYC}k#(3$@Yh6k0F#fnG{DXIRS_tN6hk>9POqWzSl*PIgiiMVfK zmRb)UJ4ObAg(w_3%=lwO3>o>LT;G{7EC<q3Qj-aJ8%T(-6AXstJE2f7CHMPw5+%$+ zGe;JUEK)O}(W4Yq=k!tzzWkT21WJ^y&ALx?yd!UKzQE&LUwU1|bQwyShca@EX4eS> z?t|IDP?EsC#{>05wUJb!@TR837-H|VUO^A!t=dP^V&Wx3Q+v9l_R>;=#?li@Pdsk+ zteNFyit48-F_Yhg>ifiaq|)7z`gP$2o5TsCLXF6gA|*5tjy?gDcH#@(^2s7pnhHli zW$-7(1vD%w5Q3Ex0@j~`pf=;6M@f^JspQ|0W5<l{#3<4dW%Ll=tDR`t&z`=EU;)>b zUR5g6QjZg%l-VG*8|Uzs6P>se!D8^3=7f^dLQ5@mM)68Su&C0nc}OqALpo#C;Pj+< zbLZd@P<~iG(%bS8HP7k1z7OBm>-#a8!<<C%lQ@0K@}6019Bat!V4#!O$;?!?&rXPo z#(dWEArnh3N{d(tHf>lGlRW5viYIhqwr23g(Sv+W2_;O8;+!_MM^3Ajl@5!cm|ULO z@lZT|4)aiBx7aFn;P=h>^<IHja;JDz#^2`5XrL-=C@Mr1Z`+AmbicO>h;1WI389u8 z5<=<(jSuXSj{D<#-Kd*2Y>kz(&<%(c)We=PJO4~(4j!G~tIhv7DMh!wjldhJ>+-2S zzzn`X`S_J;dt$;G`4;heT-wp&a+t40;dNCo1{X7BSr>St6St%kK@hy4GQ%4Lu$0ES zg>v3kkcUhlp-kN76<MhDlYV^@FpvrcG_TTrpk@x4;0J2vkSj}<Ph`#-!vof{=v>u{ zvlDv&LmaiE4bP$Ys;+h?WX^1GlAW#Atg~~obCq2@XLwiKD3i3}nFcot)c8)o&1Rw` zR66ICuFDj`z%Ur*P~vb$aYSrJi=!h%p!6_!0!dCVY3VnkNf6#CC!6z2`z4?#Mcc9s ze$rICV)!Ax@9e=&eQ9mBNKP7uaAC(*982EvLXlL8bkP{XT}@A{QPO-q?f89IR4GK| z=T01tvXs*mO)T!4{sK?l4F7|j@g#2NWS_w*hWkMHUlczHG!#rCo_tb>tu~?L&{=A_ zk{k~$Zz8_+Oh+k(j)YK}tvVsP(>PL8MBgd<n4NdWair(nt4pg#AuSRqh{*`*5mual zA5T{%C4Qmi`vzIc^v^lWod#DhKDd<a@rcnQM|2-znv7Ii{CbStukhnncCFFcu5}yh z0%H|^`ZL?@0Y4!%;WfG~m_p}vK$UXM5ZxF}=W*5vKk5YBZljF-A<Vzs4-@9!^r4-9 zgP#%1{1fqm2tA7lnU7hUnz9L;HRJeEMu>00kJ1SbGtA=S?87efv)Q>{^mZ;Oy@)w? zYHWZd5Kwf&+ZiX(DO)gIq$USbW6THw<BSpnY9dQYGo&<hs1WhVcsG*DP>jjal%10& z(3F~!W6PO53d=wu(yV0wdJ16*V4W&Dw>5;dBn>YJJ^1=e!*{b2d8HWg8aq}Ezp*7_ zOO%0+9sWI%S-SSIq5t6HdOjEDRpM6XcOuKVru538%zlqx_B$F~33>}e>CG48S9wf; zA-5z<EXuwDgTl7cGisx=;hu-5#VJ9c>_ojA38u&K2@UG`dICPxeEp)*ACAR>P>2PA zxq346m=r^;ul#5%2#_IL0euN*jhYOi<5tn-VGyg(%3N!bI@Ysi+SD#&nl_a#V9w!* z;+64xlXFm<sO7TK39xIbIeHwc2}G)f&Nq%-J7w-nm)|~wH9aa_!OY>K_|t8R&f%5L zP+eLzdPFw%gBbqI5tjycQCwN8fjZ*yza7eq5AAd6->$~-48`XdHQ;EA^L--u;uA0k z)gdAF9(D{C*>r?MNrWLsd6;QkK`%F@q@)Z^8BAQu%w8&*n;Cyt3afk<s`53wW)JWd z^zEQ3e*opj&TWsEPT6JyJZgyE6rsxx27?2G11Z0Ey!;s*55@hVW9{GSTuvVoTPdOK zcs96*2Wd237FDqS#$#|UrkvP*XUaKV<6$f3nkB2fj*0u8nN@o|N`ZAxLU+{$LcNlq z%2TG~Se&hS9d~<AjqX99OygU!Rea6aR-;QtsEMN~Nb7)l`CmH%u*4G!`($WlOFaGn z<tV=rW$(EF-};1dlm-d5(3`A32>uM6$}#>KdR-yG*JX?Nf^`Mr5{zTZB1mFsp4e?n z6O>f-Fqe&amjG?Fedffr3_R1-ri(al@C^6qbp+klrkz{FD%KJ32k2bBGOlW46J6X> z%e&S9t(x}hHGz2h(OEuZO@Q_fSBu#ATX@vbz)5UGP4Xt41tkd%(e4Qb_Q05vsP(21 zD=YqD?EbO#WA{J#P33QpSb7rumgKEgBY=%XD_NU63=o~GP<?s4+K1=Y_WR@2c+)f? zZgUQaF$#t(b#}Hf7TSY>fyT==0l?`I25K;UU~C4FhtZ*iC+G;O53tcMYgRBMmQJ)9 zpWjnW*-U|e!JZP;0||AiLcw7ALEGCC`e8FZ*S#EUpM}F^KoOG1AMksy-Y})YZEvaL z4~l@-AHZKp$28~(oKd4j6^+6q(nsxcR-_g4dr`XKB4b-m=$p-zFFWk4=~5#V1PHf> zXQ8c{iUZN@G@WS8Mv(2P+8CVLUY-Ewt<Jx&m*eX*3d<s=O(so5_XM*(PkD(*E~VSB z0cpgl@w7792FwIXS5@0NyAO9|a?Z}NUCE-H<(;}O<FeND<*ik_)Qq<0+UZVCGgUj? zqF9esd)WT%xo*w7jGa3QyOL94lCg7Z9tQs=EWGRSDX!u1Md_5eU6Nn%$L??vIyQk^ zW4tXv9s;A5hj&_=w&HQ{j%Yn`_-rleK*=8YM`Bg<<#CL=d(C;=$Ek65o#vs9;vhcM zz=5w;^gM2_gkShrB3FuvUWCV^LM_6>pyPgNkmnc^IMDQ!TKl=n>|xgSkzd&IYuLj~ zj1M@eLmeJO94=J2LFyP1f^nyVq1tlwlvm<crUF5#0Wc;r$L_N=?ax+nG@<?Fq6ELQ z&h2L#HkM!7@BPo)ukH5<?Jwtip#ELjPvZeWwI8Q%%QwDj`?c&zXupv??C~z5xzRqr zJYbHLV;3B17+hV+Al=Q~`(gCx(UV3`Qi4czhlzcm`@+bf1X#9+wa6j(Q;|sG1TfPd z)TJhACbprEEpbb!(Hy-AOYaG+c!jEWsL=Gk>7V&s`e!re{+_A!8?vV6&!gXS6X5ig zA0_;yF<6u6v?S#2VL{CvnXM?oZgPaC4V>Dh5Q7t&!ivGhn>tz}?uZszTO(qNh(S2v z`7~1mvtDm>)xIZ?b;Sx=B`DQc>UhX|udk#FtXn18yxL11?MFrHoUF!S#D@h5^&~oq z6g(YUJa>71qsooJqx2kg20P_Op`cvh5d7a3-cyT}+7ll;Q_;h^pE0^s=A(xZt2*I~ zQ5cy~%5a13au%!*%6+)YnWFc5ZZy6xxr(RY%%%0RB1odBG{4)~uBO3iNfdoi;<B#d zLMUaA=H}=iq=uHvxwm?(OjYHwZcDja<UsT^?1@T`N@%k|vr*Y_-%%<XuFqXsA3fAp zIa%xd^Mgi?)ZwjEf12}MwT_+u#}?6uj?UN|$9U-sOMHYTjF#?jMO8RB8Q__*nM%CT zt4wUhR0Z2FEuReIGs-?unlG}m`uF3sYd_w5Z~}cspTLa5M1lzic4Wb^rA)pVpG3H_ zN00YXZhb`D(IIyfOvl3SPd71s)LAsn^|qcm;=AA{f!m(QQ4W3H;eF|e?6jcklOf^y z*xMI7st<M2yHeGQzZ;7V%uSWIAALs<WsWY^o1Mpw$;bq_-c%jiFJ@pIqUbmQ#&S`B ztmz3x6M#pcw*EIT>R2iXFqU&pQonD5kr*?82@{9ICcvmxJO2|HpXvhR7SYbBAmBG& z1pJ-*5}JvsBuWv)ny03Y-_WHaMvN#JQ850<KEyH6T^rK{b>EsfWdht=IA<v6)Rxv1 zV*fsD|FSqHg5IDYICaznZaX*>_g#vkfFY{8IjSL!KeAV}yIC25&P-qHeNqX1z1i7= zT*m)y1Ue$?TuJO}?}86+d9l(Kqc}lL17&zPe-lcI3i5Na2?eLoVSKj?E>cxL#BhNO zs2Sv}D{UBswL2GE%tV3sIUL0&p|&csH?t*$6^jkLqyqDeQ$SLZc0oy`j3`=^?l^v2 zP821ohZIga?)F{f(>~P+IN2(_@Y`vnn1Q;C@hHqzrR#BkYroy-09WI?<3aD~o~t^+ ztz-oXm6Gv?g_iLRBJ@bpqZ<6<sMo#2#~jgpTo-pd?44zNE%iDvKFXTke+?-ShphX4 zaAhp<xC<q09&TkU4$)vpz>w3C?m6Aaj~vCL=zUe5922QjI@dS(QX{~<#~CMTAM!-I z&l52ZNfHf$MET0!XO=(iM`+r+MSO%DAqEu|I=5?^;kXDuA``OGp&Wf&U#F8n@R=Ri zcO>qE#(7r5aJ=VqGZqtI*dkUl7TL`=9<u5VM}h;P)$|hNh=B@hMS(Km&8SqvrZlb? zY+Bz+=!?zHTj*QImCo#oj+%wO%`S*;FnY?z2(MaLF>nH;<8zlLb`lCt4iGBUTh(Ra zx9Kq!gOM@zy+O|RN>5`o$xnH{Bhc)+L+UHfS2|vF3BCu7s~fngat*0AOE5O{y2yR_ z4G+OO$N9y**+)YViDWTy#6UMGc@S?T>AiYB6<7l2RvrHiFGuS+%=r}a+5Vw4jWMH% zT0rdT-W+<@f80o)FK4(cDoXFA;z}3g6crSWF3Qd<$jr&;mzgd4sL<2J8KXw!4EJTa z`9(KYJ@ejs&z*T~;a6YXA*%oU=Q}!n`}I4QTz=|#qeoq^@aLCac-$N@Y;Pu`t90hH zXE!byyy4)+f2R#zFAm-D%!#wbXVXvI`zYK6d@kwO<5BRyvvfQV<p(`l>=ZY#Qt5Nb z`d+BKT=9zb6SuRgS2Xm(7MmrCZyE<%t-VG;Rl1;ck{*AgR;!e!v=+?NJG0|P?<zBX zwOx3;8gF7F)aWR=+;d!L;$))7x|mdmjR)&mVhP3XcL{H$g##6JiVI!Yaiix6&j|`X zy>Cs&7Ze*^_PHv3s^|EE9L}R{SE?SxiSZD}+NLT);Ydm{hu;ufkb{U~!38Z$ZzaGq z*2454buq?!I){b$qu&Zq{InzL03L5|!>2Sn2TUC<aQ#Ph07xR%I@K`}oV{n@7^!&S zBvXf6P95xv)MttK9pdev`a{etr%B&xrE+>XO+nA0i6f%i+4a^7>_-`~lSMf6fkJ>| zE_KW`aLiS8wA(t4{BCvV=6_oq<G@w-JqsH>st)Eb-S#YafeA&|v)XK0K&7>N79`9Z z9@N*K9ditA@4iQ2qpM=dervh3{BY$?p}mh7yvO(1Feb2HILPWA_u0TP5fdKoYB&%5 z5ZhwIMpzYmQxU1zWn*m@Wwd>_XNnpR@jW(-2hMCz{H(`4Ha@k-22;#x-f^k$G^ke3 zo7AR`Xg4#N87{Jg-d&TV&u(!J1CKlRe?L5O<NpSDP5^gnO#kS;w%ZKNiUR7wUX1iG zXBV(ISk7J-QO5co#-B40ZXWt4VdYe>RuKD1@&EW)AhSAdbRRWiVwM^cAKUULP(FK8 zFeBO6v_zw1%fHLS_)OFHu%~ED+Juge1*T=ZL9_l>y^pGXkMFk^8+|uX_Kt7ZZ=aGJ z+i#D>CbSwhn~E1zO4lGWPD%<9<2py08T$=iV8HA2Md>%ajKY@qGVx^wm@V$z_S(mM z%SLzH==+i3`=b>uKQXxUo({akVLJR?`xN5qd_%i23nn&2h#q&@(+qHabjNkxhrEAL zI9D-21u+kljB|TMzEb)akvY&Dh3g%{wlSPwJWA*|{?%wh95RRFdHmdaHQLlx9cO;B zQ68i|;bSym7zYhtA6$AMS!Bs9<&;FdfsS8#R+&A;0aY&{B~`uBANg8oNg);?sMa?q zlf}cqre2gLqLWpd`WfQ*AF(ghF8rxud=l!;8fNyRV!arhHQI)-P7*`qP{L2C`hnAP z$mkUMjGW`ZIp;^P{Z%-GIO*LhEtP$*1Sx@v33jQs$r=4fDPRZ<f<)$Isvt`QxIk}q z7;}9&S2IWHBEz%$^k$hPMG%avJQcXgu%B^qk8}i!5o~$$%cP~jWT|cJh`9O4Zbn*G zR=<8(IaxXVhV>gd9HnbSHj(4{jT0zXnc4ZC%s!r+?4sfft9NB&Wam#RDjb#LX8Mc7 zeS7wZReOc#==k{SygOch9gRz@y6&25u6z0p&ovu2Hb1?6-}=Gs=^HN^yy5GNuix5y z!8zB<)(wMULI1b6UpN!#OU3gt9W4K-ToP*#x|bu%vHQT`T$aP!Grc%V;lnOC)HuGA zO&@y)e^X4ZS5m)m#TvaCsI?h6qq8%tYJ0*RXs@2EU!`?8=(1mbx_+=s+9=)}yrJWX zyE~59`1R+5*F(O}Na*1Ev}1%rWYE67dnqNvPrM!GG;GZrGLYK+NiJ-cRw;|>638aW zkGUE}oNaY#FI|d%`iLBqL!}~S^g`!04bpnHUuoKz1w!fEY}iEQE-DsU^<H|%TW{SV zgLmxSeZ9DTjd<y&9n(bfPdkR!cU0b^o9ljW<AsAaY#4mu#vS5csT(#7`1;MS?;fyz zeX8_!B-41|;IHKQgBlMGQPCI$j^L05hIns`hivHP+=@(q@su+>*hA|w{FyhfLZudb z)dU=cK@ESOFU2>V0W;hgu5?_D*I@r~y%VMi1--ii09B8E36kBvfBl~2V*AA%yT#J) zcN|;Q@&1Lh{|?V38&4a&;a?j&0%B;&h7AKdwsp+zzkYp+sP4FX@OtPvto5}MI)3cC zv-24oz_m$m1_$%xRBuh>F=tijis)G!>LiZXIUMOp&fo#P(>;O?DxM_8u>qp~`&ijY z0y)a^6+H|9)G#?mw}_t2F?C9}(>a1R9!1BGy>GIQFRIrQcT%^9a|cv=JU7#x%F;8U z=MQA0vppHq<CT+{7IIZfCQhIwU7Mg<Mv!+-KvlZFZHYRMps=9Zi3F-88aFe+%`HYR z&~q8B_k)w=v;k^O)cgBqrn5LXctD>F58}I=DW7{R>vf9Xs#P48@1m0$JD(YB4rJ8R zU&UK172I9*e+%z_Sy$|2vaWRjm%l9mE_i{$t?&21#h%}I?BM|^NdPcpU?>^R?3Rzn zQDKZ-$;nhIrlGRg>KJ<Qu)~8*)M2ZW0+auU1el0buW4$ZsRxOX>Zhy4fIg}or++5( z5UNjMPb%34>rwS^R+(H0Cqh=z(^`-Wz_C9wJHysfLO-oE@Wl7$(of^4hxu7-e=cfU zd~fcM!2qLd+;)Sms=)5bb=X)wJUhAv*RRj$tDt|bG_X`Cy`$B@;#oi)=!l7Xa8)%! zha{G+dZJV5sML0!Eu}+j!q}03VURj?ZU7Tvm<D`T$<!1tP!lHz4#?zPE>Ury(44gR zL*n(p8^+(41q)%h930QDj0;BWshe`#%_2|aZ4!sR-*N9{@A~if`m;OUytrfA1>%r5 zulLvY$&-6;*wFjypKVO-xJmH_(X>&n>rMDG;Y8yqW-BO%4jPz7@E5^sigE5yo#V3M znLUpxvPBXzb?0Q-t@bsW)96?-WWPm5dUF49-kc2niV9q9>+p}BL|ov${d)H+D7L(< zz^(sa``eF1QnRy@LqmHFm^W<JtigZF@MS)Kskr@=j<=sq=~yGK-6(gC?kBy!2&PS5 z`1K_V7RXhZ8#bi=`+e0`FsbK-+3GAg+RC{>ef%CT;px~zf~gJRhNQ!G!BQPqR5M!3 z2^8BUr6bKmj+GKoVNn#59)<@OxCgElYcB2>)7Y`I<CS$Cqb?G4+ivN&=OXduIzAq? zPW<Ddj$d6YZ~FSnzKY*I*-@IZetlo*+bEj*ZrG5*0Smu}A@}VVsM@S_DmCXEsoIRd zLyzi5n^n{W{GobibBufSAzlc{wApW3%aM~>!i@&e#jb8|Z-ZX9Ux9nWF9~q4uH)1* zUwf^x<CG@4YvUDexJhhX_QH#m;@+mP`xEi5x8t#X>(>WGdPiGu{rY}lx_6^jjOw>x zLx^L~yul3{`gOeRHT+SZTWMmV);O-ud4$`Xi}@|*RT}R|wFc{0S1KEam2)bihg6za zKg_>8+swFDXSO>>fH1$<8QI*iLD`bjyiD!uhZf`WGRDoBsAnF(+Gt=5pK4`0?%Ybi zYdt$-ex`$?!+Y<NKk>ff<~S<0JlA4|`04%5%9W+~d6jY$Gqs+eOr^>-#Hq;0P^aPY zpHy+^#RA&rQjt2_k)JBwy&juU8-}8OPj9Fyqd-x=Sg@V{#Jld!FHiidDlh(@|F_H< zD$bmqr*CD6OJYxlsgm_wfyH;2y_VEE)?T};M&;RS536sp?6nvBuG$r%{_}A%{r&dZ z554`_UbBzgX|~t6;u6``ydR>R&+K)IGXXzzb3fG?D~j!PdO~|L657*Cx4~tgB~$Y; zf)I!LS~z|2y*1YoXN}+6YnSr>Vy`{UC~?4Ed$H8_v)4Xng#44e_B+SP-S#@!3Ay9# zb<pYKme}i%Gs;!RqN_HfU_WWJ*Qw3|_hoyXp3t6*g!c4OZJ1GC*OaxQvZ*p_dHve+ z8){ZnH)YMNuU}PLm6e~HS8#Iuvihd_togN-%TBIZwXU|Z!8|-F;lWW|Ud*y@o>JA& zSW{n@l{X<TH#dJ$!4zHMl&q$vm6hw7>Z@z0`G|9JCzKRU$j=?0x4gJ;OxF0?tjSs9 z8?y59v&PTl{oJha=Vj#;W{p2LYxwZ2@rz8gsyX9rEeQ?Ds%gxs%xY?=Tv4^AvSD>r z{YneU1k-5q?}X*`Yo=8<)HF8LRMutjc~wJGV}0G6n&nk>ja4hM*43@3YRGD;uF5J~ zTe+OfJ~=Wg3Q+!p-0G&LwMR{yc<#C9PN>vxO{i~JHL=!|(KvC=>}eHq=U0s9O=pHv z@6<U>PL{L6sU)xDYB~4TI_EnLPK~n)2MYCcCim+3RqIsoE8oe5*bAJKxwnkeM9PAf z)bjl@?pE>UI{mAm)0amb=8L1grNpc*Wu8I}4NfENQ?1XUEfYw&{N-a(Eg-B;yp8I* ziNBS!ZJlmuHQyPSk8sZ6n+Z;dQ^>yxs_~Sw995vu8N+wufg#J8tgjmQH;;GJ-I@HW z-p<v(&eKl{_4T>@%Pc})FX{ws6g%U)z|u1gvuI-@rKtXB0@h0Ur^;DF-r%g}UOn)1 z?v)9hFrC<66LgQRai-Cis!tm!v4)Zq=1lDhn@!wT*qp<&<<wQj?<#7|0&8`;c7=f^ z%1{(g28C4ep83`Jn<IJNwTJS-Z?2}LCcZq1$?rtxT>UqJa^hu8pbZUB&qOev*p5c- z%yDJ|LxnRJN~@q3Oqp;uW)$kb$XPVAhyOf-Vcu+vgX3^wEIcxab(H{oGXz&kb<&)4 zCj-vh8;eLL){uVqf(>v6q6ZFUEovy-KFh%)4I9Y_c(&Rja|FaO7G38^8Zm)}slkvB z*%dlPkY6zbQv!%noT<*yXcxyirJ$>vrcbBYGw7yS0CJpjJOG^lF!P)f5o{*|)B<NA zh+D)d!Hbz?FXa^b(~0H%J(d9~ojaV1ogX`o<4MxuT;g28>Bu)bzjE$$E)y<Z=GQt0 zvGe~N|Bs)bS-ne~s#~0UoKKxY$dB8dtDH9HYG<GGQ)jcYm$=-wIs1jz`8%snA2_>_ z=Sld#{RZi>1&4*82r)%W6=}|!&ikD8xyyOS`KR-i^BxNg8N_ew&7QAJ&LQoGaz21~ z9E0!`8X|@gh%HNGi{Z|#C}1PRNHI!`=8%9fVyqY^juhjajbehBC~{GP^YIWV6h-)0 z7K_Pv_8mne&8gyOaSSHMQc)(##WeOLSD*vT6tl!^ahy0_%wbpUTzoQ56eo$3#eA_q zEEK1RMdDPkSS%4siA!+0I756-oGB{BGO=8&5LIHOScNsIMx4b=x>l?ab)sIZ6=#bE z(I}e4I&qFTSDYu#7Z-@{i~kWn5bMPT@k4Q;_>s6sTr7SpE)kcCpNOA|%f!#b<>Ke! z3UQ^lN?a|j5!Z_AI92zT;(Bp|xKZ3hT=q@kW^oHKCN_)Ph~9FCxKrFEwurkq2Z{5% z#l2#i__erC+%FywzY)I`zY`C#i}4TQkK!Tmuy{l~DjpM$izmdN#FOIB;wkYL@wC`3 zo)OQA=fv~k1@WTztJoo45-*FtIlpD!%qz|xoIg5Gi=CX=@Ox*w^CRae=Th;ibFcFZ zr+oj(c}%<}UKekOzl%4;TjFi;59e~ROS~iA74M0Ea^B8O#G-9=?joYXCg*N+sOvbR z>tXS}^Q8Dd>=qxga^5WVh!*j&*vo0MVX;r_7p=tWI)EQ(yEr616`zTJiO=z<|5AJ< z{w=;19U{U2!ybg?(Sv2)$EqgL)nz~iC2?eBs!WsVGDG%~y=5QVKKsgkvcDW42g*Tm zupA<X%3(4~X3OC+M~;vq<tRB?9wEobv2vU|QjV7s<V2Y(^JKm(kcF~HPLjoPvMiBD zIosqEIo0`C9xaby#`<eco_N-|4<WQ%mck8QgjqeuY0ob^e|2^^FTpflb^hkOf)=*Q zdBb_lc^#JYiE|dLW;M*U)~S<aFrc$xNJ_jYad8ez>OAKH#NqdyA2|O*MC$d<51k9q z(H@cIa+;hjE94A0)A`!zkhA1$d7M1ni7?NZBTtZX<ve+!JV~A`=gS3hp*%${lBdeW z&gae-a*13jPm`z1GvxQ=nX*zYlgs4_StVD>RkB*v$g|{XSu5AbI$1B*%ClvIY?MuM zojgaLE6<bX%M0Z9<^RYZ$n|oA{Gq&1{zzUVFP1-+m&i-yPvlSKW%6h8a`|&2oc&u~ zA+IEY<45u;d9}PoUMsJYzmUI_*UKB^jq)bBQErkq%Uk5Fa<jZm-Y)Nucgnk*N97iI zx7;d!g=V@(-Xrgo+vKn1ee!<!fc%a8t^A#QQ2t*2LH<!bBp;TK$VcU4@^Sfu{F8iA z{#iaH|0183+vPLzS^1oNUcMk-lz){w<V*5p`8WBB+$mp`ugTZt8}je+P5G95TmD1t zlJCfO<$Lm<@_qS%+$}$pAIWC9N4Ch1<zD%T49k6TzigFl@_;-j+vOqosr*d-OMWiD zkYCEL<iF+DvO`8(N5znHU0hPU7=rw6lAG)X+@Kr6Se@#ox#@0(+sp0k_Hi@azHUFa zzdOJk=nirRyF=We?l3pY&31>oIqnE|q&vzT?H=KdamTvj+#}ub?gV$Do9pJe`EG$* z=oYz?++ugKTjCz&PI0HYN4v+k$GW9%8P?Ki?sT`po#D=OXSuW8<J{xjIqnJWTz8&( zqI;5ivOC{h;4XAeaTmF#x{KW<?o#(O_jLCR_j~S{Zl$}-UGA=MtK60DD!1CLanEvB zyS45bx6ZA1*ScrB4Q`{`<gRnianE(nbI*4#aKG>VkNX36y}QBvp?jhGBljZrV)w`H zCGMr}Pu!onm$^T4FL!_LUg2KpUgcixUgKWtUg!S8{iS=odxLwUdy~7--Q?cv-s0Zs zZgy{TZ+Gu-?{x2Sx43t^Tisu|_qg}E+uUEf_qq4G54gW^f9w9vebD{A`v>=r?nCaw z?j!D_?qlxb?i22x+$Y^XyHB})ai4a#yU)1Ky3e`KyDzvex_@<dxG%XcyMJ?Ead*0} zy05vfyKlIEci(j1a^H6U;qG$Zao=^{bN}hS?|$I!c0Y7Ka+}>fZj1Y|yVw214ZHi? z{cfw<<{oely6x^E_fz*X_h0Vk?icQt?pN-=-LKsaH{x-yn@j9|9=5Mw=w**gvM1mP zdO|GOrh3vm>7EQvFJk2N;XL=go_?PGo&lbLo<W|$L_!<t8Rp4y{^iN`49DD_<6l=- zlbf4c;#*U>yrI4>b!}BcP5lZ~@usSVsuiAD%PJc}t5-EtRn^s2)~%>n?pD;Ta;xfA zd28$IRyBI(Ro6GvdF%DR3-!P2)W5pa{DNX{<MQfrE6uMN1<9)#D$l7x{a=<`xqMxd zxoWDZU7@c$)%EqO^{WNBGm=)+H!Z8Gtv}b>R9{!$n6jdV<}@;AP`{EZ>*|}TYO880 zy)!G<tf}-)uc~dT^e(8bYO3_jsa&&cMWsBoMxI#XonNzRO{IHcb&Y#sV~w}6c5QW~ zXBlsKSLyFosPFt$Ya45T#&ZD=T=kH-M^mMzrk>JjO=;)VxDD0yzD8ACo>ymXQ{_7U zI`gT!mKv6m`01@*Q?<%~TrfS)z%xDH=96?@m}`C)<`&xDB{na!dAZGJm^{yvQ<!Jp z&$H#^72D^NZEnBMv)|_znEUzmyL|gyzWpxWewT0S&$r*_N57wDzn^aN3Y*(@71(wa zSa=F-eFe6@0$X2!t*^k=S77TYu=Nz!dJ1ek1-AS`TW+B(uh5oPXv-_K<rUiY7us?Q zZMlWE+(KJ!p>2PmEx*W?Uu4TKvgH)na*Av@MfUwkxd#487Vb$F-bwcRNk#U#ZRaH0 z&PleNlWh5uZ26OH`IBrrC)svRvhAE?>n*nJEVlI(+xm)aeZ{uCVq0FZEw9*?S8U5G zw&hK>a7?yvOt$4uw&hQ@<xjTdPqy$(ws1_ga7?!4PqyVxw&j=D@=I*_CAQoWTW*Oh zx5T!y#FkTLzbmufmD%^p?E7W59c31;Wwt$Kwms$c{c`($xqV(9eQxnoZtE?#^-i<x zn`XbCX3L*uzn^aN3fsO4+rAmLycq`XMY-mAksaSfxu)DAJI;%8O}mP64ID+erk<i) zQ+`pdX=hQcDYqy$TCQntQLbrkQLe#vQLe#vQJ$_BYfUuQ?c=xZS90ABat$B3ZU?z; z2f1zsxo!u!ZU?z;2YGplw#qavuSX~>t4%q39Spdk>KrUgRVx(D=jZ0zGK&k7>l)W- zG1B0vt!b$At*vTQ{Ip_SL%n`A&sLw8XPT9lHz~OaYtWj?rm7Xm^>tNM$_iE;YN|%; znCr&i%9?Yc*P%u#u8TfEoUEy=T&^URDt$(|0eVKo42_%_GiGSykx%!XJfU&T^0mn; z>(@2ttMuhq+-k8JDbZ6~wX!J~z0p*&Jaw4@FeaW-^iTDo5@6<GOp5hhUemCA-I|rP zRp-S%=oP;g{VL(Lm?%uR7c0(`9(yGt0mcTTQd5<$Ot;@xZn9}6n{KiSlg%*MOq0zr z*=&;?XR_l>HpgTqm~5`e=9%myouy)UT!m(!`UMR5=9`BLOt#Qur<iP!$xb!dVv{Y= zS@H!{4fXmeiEcI*P3M|B0o~pDUMSiNs;*?!^XApYn)CEUKofwu)MTJ9lj~}1nSNdP zy0v~?_PVvnw&-<hlT6pE3tcMj=t6nNmdTYZl9x=0T$pxqfsWMJh)$H;P*b-`_gC_Y z%Ep??`txck4Rp12>(*%K^o44Hy0FlxOYf=)m9<TV2-R-`pnhAmMc>kzih9j6cj25l zzQzfSjkyKBN|P-&8J(_f(!VOBM^r|yHRcxj^s_?qtk9xM6&x_I={huU>dJSb#$QSl z>zdHDAj>VA?wbzCl}(;%fc7j<|1|MWpezP|pfYypFEdJ{ztZHsGF_Cf(v(<Mzlx4o z?XNU>a9VtT1eeFJb<KH}1?J_J(}GGgQ{M`m`73N4n3$Eq>Z>qyROu{Gf!=7CL7*yj z>94RgSDD;bVM?shS#V~&?%=BUwP{DbVd;7Kd7+sJ!!Wce;YV;*{HtJf{Mt8LGXr0Z z&iu1&%VBi7<+Dx8YYcW~+cwsiJTN=fd^!6#S#wtKxOl<Av*OpG;}cpEQp_pJ4pD`b zmW>Xpve2A_N1@t;AHF#T9kn|1%%NgWE&urDn(yn(_j40I3DqV1@Xa;f*BNxyRj#dX zY-*@qTV3U!XF;yFAkQ-(*Xt~0UiCT#QNy}5wX8>^)F=M(oowoEFm<1tP+h1Y;fL>J zQ+I>O=9{k?brzf-$5OB{eyuw;KhMbA{5&Ib^Ye_%&9}O9-Xx<F<xMK^Eii>QnQWoy z)ODs)7g`9{SqK*z2-oS%yHJe{?>hBw%ECnWQr0E@@-MWVzs}^rMe)`K&rP^qoN#@9 z{Mxs~z<q(v0!w0~6SyFD=`X9$PyLlu20QZ_YbzV8&2@dkwHff5B_vfeRU6)_M!voZ zmT9qMul3jZI=w939Q#lsNMEOxMdxq&r{Ny@GA+(X^zW2u%d1u(l3{g7>R?4eWv2Q1 zetJch%2F#jRS=w=@ZIc$M$Yc~-R#ca&5gG?I4_}$c?o6A>rzH=Ui_ofd7aB!m{7*T zgfbR(DI;}Z=kFHB-wj!&Y7k;Ls=f|cerg^}i+_=xz*x<jYK{*_wQp)NHrIx=nwKnN zH4h9|)z@ipo@!q-L~37*mzJKuNX^5UdK8$ibQ|(>^^c51R;ur$C$LcSt>K;KTgy4^ zgM>mY)6@^r;v7@|PETN%`bI_~r!-|54r!hy@<;nL4qLL~isr82isqX{o@k%OzX@6H zXC4^Vr>}c;VtnSY;dlBvBaz$Lr}0vQhR5mq=?NT8-$<F?Y52^Kf0nTzfoqyV4O=tU zhN<c6kY#E1K^)rw&CT@fUY(ek{Vahj(i0e%ewv=Zx%7?H#hoeMa4`KSEzZC6@8FU+ z7-?vsYcNDDt3@Y*Lj=l{O-EaWLKVgsqkq7;%-!VKN?}%3Bf6tT$zAhfVZzISdCFv? z?`J5hPqbzFj#t;<DQ61fw>5Z{@WZ7Bk1E`IeC67;mGXpja_%|=p02|^xw_t6fPu(X z<4&ut38|N(MW@*Z(cb~B@tLMsdzAi>L{0i4Sv5>w^|3~$=%@OoceQGSzur`@C0s%I zG+DPUln78-mrq0XeO*MzKGZ(~+KQzwbzz0McFJp~w1svmTWF`Ug?1`iXs5D;xps<e zr>YznZ_3HDrUo<j%Pq{aQ*|qb3-j!Ed3I`^XH5%v*0f;tF@ngO^73tYX8M_1SYYcZ zu;mumsegejr_eqxwBHxnsehq;zsTM%viFOk_pRxn$eIR<tVy8AwzsIlw@5R4-?=7R zq#3gBT%9E^iuP9WxzQ`%V)NqpCR<Zer<AouY@u~4lB>>Jj_DCH*HGroFs;rvhKsxk z0}Z*xN?wJT_>=3_=glw%FXqA;3UX`Mum*}kYe*<8ve+oH*e<rei!Bz4E!4#p>SBw{ zVhepqG`IK5tU;vA8luW9*2`?~O|#`sv*k~-y*JH1pKhO9!)c*4oEA>Ey)oUwG2Qmc zblbk^wtdrW{nKrGrrUN*x4kso!a3cxYr3ts!nUKr)>C2Ysj&4_*m^2#Jrx%23R_Qw zt+&F~S7Ga`u=Q2g`YLRFwm%DJSUk+I_0O>N&#?8+u=UTd_06#L8Jk9K;S5uLksX~y zc61e)(Un(W3~J<tE-K1&J^a@7kn4KLbv@)7PI3(=xvrO7*GsP9B-e0~YdFbuJIFPh z<QmSrigMkb<hK5DTYtH&-x%z8ZtE|%^_ScFjRBA6w*GQkf4QwcIv$K6kN0f-<+gr9 zZ+R7l-pFnJ#^A?q3;#4*|1?{_F#z)1!avQ{Kh4%Z&DKB7!avQzKh4%}=sB;#&@;J( z-_SF^E&PU_`EBbr^vrJyzcD=W+tzRBo8Pv6L)ZMa^&7h8w}syrEb}Ui!IIp<Z|I!g z7JftL{I>8LI_I~A-_SX~E&PVg`EB7hbk1)JzoGNI3Pb1Q7Jft5{I>AUu=UNb@ESVj zc?r{fWp_~QFF!ZRPD*t3xrHSf{M<rA&g6F37;@yd85V_x+;R&IxsmJY$aQtOg{B+H z?Qk{CVOZJcCHDOi``eHg-`inq$S}8Xvi;u984F7^nrWv-2f2NJvTgrl+kQh<)Nk(_ zGUB)W&X6U)qwTir(F`ZrY2P!Z&fFriPJ}z4Mla^z{Lq91Z$BJ|a7)G)HBEa~hO8qI zyUy_<c+nB~w~XT7#bO2jo-fYlUpz+m_d;<Y|NcT;&%dvU*HkHd8^CkuNJmVcF=qiK zcvNYWt)7V0RSk9AQ}wCj(f&&WYD!-+V0|&)>pd!t*cx0GT;{t%N8!98v@LX%@4B?j zX`4fb(oPQCr?0jJ`}%H4=^r{2tPW0PY4eG|-cUnub7+h2&eU4pZ&PbiYePGOn*+N- zU#6}MeW{+L-oRGFZ6U|^knaiKbH0~+ukozb_qMN%eKLdn!~LiF&+xBEZAfkKUz4`k z|DgYkR2ERF?c}u0!9S>4lLo4%Npq4;Njfv>f|M_lE>B&Vv?b}W;AW!nk4P>}F6HVd zl_!@{*Un(IsyX$BlrJgc<diQJROT;vS#neIP04pA-;?}Ua&z*(1F3<+z)^t{14{z6 zfonqB0$XY6HsDj624jE0D?(S9Kh+xZr{1%FheG-<?TJuBr@t*B{iiSz`};EVCFM3m zQ}7D&M@d)lc9)d4Ikh%gU$hqj_o+YgL_O6Q-$wa11$L>wl>X|^w9EV(oJ#w?RQ;v? zsQ)Tea%dZOIi@6ZRba2K37o6D!M-W|)1IJzH}kJ*|CgkzQg6^tp@!fe)K~PZEhX4D zctuM8R1c7CQT?xbe@hC`2B)e&Rk!H@)nX03hFJI16}n}cQ$49GsXK}tg$w@FT@4$h zQtOw|r0+-H{jPZz{C3B;f<2DQZr3{%E)5<PE=k}^!JWENQJc<dq17AIeT6&5*-sd4 zYAh1bn~|5npTw{42s{JF;=h-S_uf?e0F|fSK<%eD7(cz^7|C<-&l`q+-U568Pvvi< z_Rkwdc|YOn8~GdKY{QFgEdE&!;t}`<{_^p(dx%mW<F8QrWfkG4^%VYrPvfIB8E>SQ zsO@j~*d2|J-8=XMzK6%%an5e%Bm4sQ;Folwv!B0(c=mmYUm#vX_yvB2r_oZjvPkC) zJoo(0nfUAloJxH1`Z>$+w;ShF;b%9|saD%foEkjnW;tgmKR9PKesF7?HTbOE;H<?z z?JnnR{L{8N4S1;C<1{MoG^a`Vra9-}nfADI9)4gSIUDc*`^5R7^8a!!#Q*D{bCEbC zGo6d^;2KD@u3>V7a}S<cdCmj)W)(OO<DFH6Z&a}?#)qgxmN<{$p*7uk9Dk^J&a-$! zo#ecLKh%8ZMLePwI)B9{YLT-8f2bwSOL#<`=Ddtg)EUm-@QOOqc?G|yWzJ4KqgFVt z;v3cAyoMK4lk+})Q0F)w;0bk}vm4K+i<}SfeflvzPM69{oo4)>eu~%9&*aaX7Ws3$ zpgxvY;sdo8|EH^+Pw;@c)(PVS^$TYoUQjnV`|*I<<Q&8Y>K3P6e&ssOA^eAWIbY%- zlqmxE2MrKGJcI^`5FSE9MT+te5~+9y9VycB3Ca}%@CYgvgOw+c7>*~<v0{Ys{t-vu z{WD99#sB9xF%A!)dE!WXe-?>cJbsplN%;JnCW@8EkC=?F&q{F=-acoGDayA;RN&il zftabhdBpK}@?0WLz?bI=F<1HSh=us=JSi68Y4eo$A-*=Rhzs$fc}rZ0AI&at6`nNj zimUOPX%*MtEpt%ZfWOQkaU&ixpNX54&kVbzJJ{TNGk!82aT}g8N#b^VWJ2ODykt_v z7JOuSiM!P(iDWTK7DSrGmdKOHxGnh1x(<H+c((S!JGD3O%#Nsi3V*_%Ryx0nJjGSI z`W^Xzf1ipR)X!4!zI{9r=2@Ea=g3}XdxUWi*~8sgk&k(@Uw`#y-q=o!UjE(d?B#BI z<X({<35!KM5qLWWsbv=8;Ni$Vc2ESl6B0M@d`sj{Vryi-*v9pPk$vKikx#`#>?nAI z!$TkE8$n5L>VNOytKE^;`2D=_MLrTkBD<;KX)z`8zL*nvO`O1&b0d4iDUqGj`aH6F zH~+Rr-sA0ky!{DpzbB4~e5~JG6#1uqqnS7U#*>#Qr-gF%P{uyWXr_$6QRC}iY&Y-j zb$aWXrbhlLj-|%wlrx9&=0@J-?f1l~;LGa_;NRVm13Wp%lY=}t2+Xg8?cI@P=flV$ z%IQUod#G^_<$WZk>ROw5yV=&dhu(NS@&Ug-)K~9=&kyl{Hdx&cG>3rZ04222##T6E zJ9m6QpHEs8`Bc42tJ}f!7nG9^JX1-F`0W(~z{3rst)y+h@L=Q<S~m+!KOA|0UccA* z3-t1A<aO%1hqpfvL+Gg!h<G}W^j&%^T6>$*!I$}wHfmScYy&@g@vv^!{q_NOcXM|) zeY+PZlDPi}P`nIm|KO_=d44lJ)h6bF$3>AjIEX#O)gwUuC~zvuOQt;sf#e{N90Zbs zyz!)X7)p91@+@z?$y<NI!Sxa7i*M8@i0q`CuJ8xA)5ZwNpsY5^+D}=nl=Y}B>yLc> zI%Pcw{<cKgd9q)(<1uP_9C}wR`<OeQ@ZJILe570U9cY`<S}9Z4PKymBZPeaItG7gU zsgV$C?><`giS922_a{7mk}qO+c{hzwlP(_BBPTstE`4C2GUX~9ybfJ2j@(Hp2Y|Xa z&)X^cfW_bxpne-@768rFK*P>e=pzkTmW3qCpr;lC;qM|ZI?qQwqzvGs#&}D@w4I3l zikgwlrvSl*$gNP<r*M{cp|Fpj?ydCs3t~1DuqE;gZv`p;SVqbMsPTJ@{u>w_TOuz~ z>c_Nf4=vjRoh;@(^{(P!8NB;};$yt~7VkdDyKnLCTfF-gV<JfH$1>i&M^7HBC_jNS zJpg?f&eV&x+=uM$<+P|V9{IHsj=bS~8F|m?fQxt->jU5nV<PW}ag2mqeorDzrB%m* zquG(i#eBy8DYRy=lO6esb4uhFVCToqFQLxg0qKL0SKyBs)cu_00^6bU7pVVMM*m5a z^nEze3zYT_9OWQ<V;!8}1#mYHn!g-)J_Q~)BGmCPJ@iOq2fgwRz4A0WBHE!=A9sh) zfBEDmkk6xSiz2TA?=0G|II@>-+W2N4-?V8y`YAZv0E7=j+MVBW?@v(h>->hxQSU#& z<v#Hky_IA!_7L^#rJgp+bw08D6TZ&7pU@7&JwDZZ{V63Q=*hj2=fK?oG^PcS-_wp~ zoz)!=ITu8Zpzaf#iz8P!mqu;_NB2P)&pVGq);mu`Rv}?7g+i*R`4)K4Sx{J`^Frhd z+IJVdl;-S#6ShRy4-sjir+!GweoJrt!1*`V9g*|tu^-UV4b*%Ct$mxGyO5r{fu8#T z82TN(w;7!O4>-RGoY#W$W_oco5M2Z2eob$FpWaLZgI6n#4sAUQjQ2xZ57QS9(-#jT zp&p|@6c;)Gp7z0`_ac!7fbIUk^BVB9As6@Ae*dSImd`^AFYw0eP}&~kW_#rCwCC@% z<yG4925s3+TlR=KjHJ1Y*hSnk^?%%X3}~DxnfN5VxEqRVhhrM)wTF`4gMwaxg2MFV zW=eU5oi2+bmpiM!{*!Y-#}Awh9gl(gap3-V+FD6luLSpL&J!Ii;C`6%RL4i)eundG z$3Exzj<1~;I^F{JCxd%0?S35G&vy29bb$Nb)LaejQ^9?2aL)$e2nRDpGHBscaK8=Q zXM+2w;69ZWo(1k_18;~{9xIORH~_p)irF2l;64xBe-GRTz`d7N=K{NunTsQTrj^@i z(Sy|fcWQi?8h%R+JE`G0N>#n7F!v#){FPGv%GWRQb*tteTam5X=wZb@{NO$l`IE`G z`;f0bq8%TCt=(Yj17;IR{Hr)iDDtw_kY+*03(!1HAy?YcYAE%B$PTD?GZ_3c7<`hp z{muC!&mX2|AAyg-dFlC&q2xEfW($=32yOou3Q)ZAZ7ASbaW*}E18v-bezcX*yp8Jz zNe?l0A0<78L=fy-QuCb<`;e~l+~YmcdylV=?-YMi(pmgHm!$NwkP~1IldJbH9nA<- zdy-CpL!J(llYyfIN}Iwi&Av__nd<bFzi@iV>&b6)`l2cKb<;?_NHd&X?kv)Aq&fUP zlbxW|<a<eB(tf9}hxgcdlp5*lq?2+wUUx=DUUJ5ej_i2S$s;cyO`_ImaQF&%!VJ<( z(rnU6r1_*pVCqz`vXpco?_Wi_n)}z0|APE_p8uM%@8kFV<bUAaL%jPJ@~279@cbp} zc$w!r$qyj|9g-Ig9q4#n^dZmWcRzZ)Ki30EgZMp|d?;xc*LhAKQOxyZu1mNkGPdB< z1F?X63(3!l^c8ia22vyG5aoVK`i%51(&wZvNMDk^io8VB(3hl-<R>MOl1XWicV#*$ zgVc-Eo79JtN$MN<MD`=~C!vYSfut-_HfcC1hctpTGO|~WB8?^;K^hZjkz+~YI$oDY zQqFkt3FH&WbIIugB1V5A=?7UzUPL~L99Si=%A-g`ZkET8N=fCU>7)vt(^qmP`7H9; z<lsaePd<lyNyn3N4cB#C*ORX$KbyRP{30mp$D~V1m(j+{Nmr1rB3(nej&uWUzMc2K zqMeb*ORn4Tx*H<z&1q5nB70qM;0}tkxI?%e%JnevQ5{dZV|Xu@_khPOgd!(J-gS$4 zUP78eLTh$`#jPMefwYkKPvM<Kynh<^E4jCfd^x{Yl2&nD!@WA*tLMG7<Y$ww<Nmp% z^GML7`y=v;$S)@UG5ICrm+{@@q$^0!se1$8-pIE%k#8j5M1C{*E#$Y7ZzjKu{C4s? z$nPY-i+l_D-Q-)ze?@)|`Mu=Z$bU_KANl>{zoCxbk$zA5Bk5t%qol`4e<D3iyS9@* zL;fuJbL7vHzd-&X`CrL*kiSI!GWp-gUm@Q~{wn!v<gb&zLH>90H_6{3f1CUt<nPc2 z?~&do?IwLh+C%!7^a(iFM`|T~#u&_Ua+opvnsh(>EI>L$`jqq;>0hMJNnen@jNB{7 zk;aoIlD>-E>$;>dq=lq9(pu6Dq?<^aNVkwSlWr&7NrGp(TS@njwvq0m-eJxpWW{9k zf)Zw$QzGv;FY$XP`g&jZdmed7<aL=Ec}HGE{$tXmq+dkB@_O#w7<tEaNNJ>Aq{7JS z?u<y-okcp1G>3a<Mm}__$@h}Nr2VANBCmURAA8dzW=)exQzDzF`2lKvfSMnm<_D<x z0czev%@0uX1JwKgwQi!;P1L%HS~pSaCTe|vnl@3>1JtyMnl@3>CTiM5O%G7hCT8YG zB4vsr`(=O>B!x&Rq$Q-El72?|Iq6E$)ud}9``uBbU8HyUb|x|<9jzf94&4HWZh=F$ zz@b~<&Mk1_7PxQ=Tvu`27C3GT9JU1x+X5GDfqS;VHCy1AEpW^hxMho|X0}m7T1~1Y zt#Q)fa4m4S7C2lB9Igcp*8*p1fh)DZky_wJEpVe2xKRt-s0D7+0yk=b8@0fRTHr!0 zaG(~rPYYb4g;C$ah*zV%#hvS<yYomVlTPFJGSVv2I?}nM^GFwyfP+!g!YFEC6tysl zS{OwwjG`7sQ46D}g^|$0C}?2>v_SPOSo12NANn4wguzM}tc1Zz7_5ZBN*Jt!!Acmc zguzM}tc1Zz7_5ZBN*Jt!!Ackmguy@<41~cz7z~8LKo|^!!9W-cguy@<41~cz7z~8L zKo|^!!9W-cguy@<41~cz7z~8LKo|^!fjSJ-VW18Jbr`6_Kph6^Fi?kqIt<idpbi6d z7^uTQ9R}(!P=|p!4Afzu4g+<VUDGGg>P%|OB4v|?lX6HSNOh#Oqz2vw5;$}i4jhI{ zhT)81xKJ1l6o&hR;XGluP8g08hTDYUC}HdnsgaA(87@YyUW{D57`b|}XjJ#0<}lP8 zhML1ra~Nt4L(O5RISe(2q2@5u9EO_1P;(e+4nxghs5uNZE1MD)0d%Bn=NgXT*e_pm z@AJ&^rTYHKs>YkFY5XKu7yK~vht%iN*7wfpb4g}t<}-aq^lk2U+TeHl)%AaJV8@`W z!IK6*IQZQmD(F@=w%`ZUE?w-vYA^0~Y`xF31664nYQO2<*-QOTwHs6It7I?tUUrgV z<HExGx$`wkN5jNN>^k>g?MWt`%FJphN$GU`NY%_FYDlX|wWKwXgGlstBzij%vK<N7 zjznumnzbX%+FdM1E>;isWKt!+Ye<)oE+<_<`h>KP)Jh#C=wj{YV(sW*?dW0c=vM9M zR_*9j?dVeN=u7SBNbTrH?dV1A=tb@5MD6HA?dU@7=sxY}GVSOx?b1i`laffuB+5jm zXh)xDN0(?vUuZ{HXh%<IM@MK!H)uyMXh$b#N6xn+<J*z%?a1zSWOqCAxE&eXjtp)` zzP2M<+mWm7$gp<gS39z+9l6zx%xXtowIi$AkyGu+sCML2JF=-Axn!Vh2FhljYzE3^ zplk-pW}s{a%4VQ!2FhljYzE3^plk-pW}s{a%4VQ!2FhljYzE3^plk-pW}s{a%4VQ! z2FhljYzE3^plk-pW}s{a%4VQ!2FhljYzE3^plk-pW}s{a%4VQ!2FhljYzE3^plk-p zW}s{a%4VQ!2FhljYzE3^plk-pW}s{a%4VQ!MuW~ljva-KY6>&>Uvqsw=?!K(0c6=B z(x;@)NdF>zPWpoMW#mJo%&SP(50S1PB3(a3%Djq{c@-)9A(G}*B<+Vtn^)cR$WA2A ztL_+n7jZp@>xEjrz3Q&!cOBPjN#}EYE$IfXZz63X-9p+-x}9_<X$xs9=^oNH(tV`8 zlouxLCw(5->2XNZNBo7<$WS=JP$1j^WIKRt2T<*RGYo|@423fcg)<BV${j$t11O0e zNcx=g1?kJk4j|kCggbz62axRmsvSVG0|<7|@*T8%2QA(~i+9lC9kh4{E#5(kchKS; zw0H+C-a(6Z(Bd7mcn7=2J<QCKNfpf7XOL!+W|QWVlzsKo2xnT6uIBeINY``k59AMV z?=R#}lb+$;AuJ>gsULQ`LFB_olS#*sjwdZ7Rb!K=A+09WlGa4tMqacbFWQh7ZODr@ z<V73$e=GWbEBb#c`hP3jVi(+E7jmQxInst4X+w^*AxGMfBW=i$HsnYfa-<D8(uN#q zLyoi|N7|4hZRqE%=;y8S3er`iYe?6TZiwtc#<Zb}x59;Xp@+AkgSR4c+K@SIaHU<y zoi;erE;!RJIMds3rnlitZzGG^;7+@cM{UTXHn`L-WKtV4sSTObhD>UMYwdz-?SgCV zLO!)2pW2X5ZOErK<Wn2+sSWwmhJ0#6KD8mA+K^9e$fq{sQyaQyE4pYax@ar9Xe+vC zE4pYax@aq0a2H%~7hG@`D|H^`<;kQ)*qlzqX0ViWJ=YJBKZB*FA9jLj>;*NX)udX| zn#g7_eE>`!0MiG+^Z_uv9ZYWrV+X+40Wfv|j2!@D2f)|?Ft#0R9ROR~!PWt=bpR}F z2SeMz&~`Ai84PU(Lz}_QcCfM?ENll0+rh$iAUXg<2Y~1R5FG%b13+{Dhz<bJb|Bgg zMB5czGRG%I6Li^GTRVw)u+rF0#a^+Ll&HBq#P6=!TPD`Ke%NCVuf>JX;zDR~A+)#< zT3o0{EiQ}sTsCPqDTg$IG{y<av84Y}!$ZT^i-xfm4THI&6NDC9&@}eCgSZ|_uC%`r za-{)I<(|?4E67=oKpPC94TjJLL(pQ2TgknsMp(mjqE`4L%21l&CFGa!>~hi-r0=3B zvZ95SvllIAFIvuCw4A+YIeXD^_IA=D-{Lo#r27fw?jyC*7a?Z}mcY|UpG5Y_jij4N zw?_84N0Vwv7m%(aeG%E`5xl3qILH?V`Qjj79OR3Gd~uL34)Vo8zBtGi2l?V4UmRox zbSidk_0>}H(~y=Ak@Gb)e+YU$1U(;uZVypfJEgT#n$kHALAQr=sTJfWkSa+vq-ZUd zaeX=I3X-bv6Y_neR#LR~^BH+BF!EktCbW~8&}+!ALt1{#i+tgnNIIExD$;EUJaQ@d zL!`&J_Y&{#B)!4={{ZrLBkwyObN>_G+ef~i)J8f$I!OAI^e@uqq_0R{N4^k})R(ot zen|H`<YXbgOUS2@&mvW0ORpiVCe@PGL|)Lca#-XGFw+cXn&m34Ye=g}wWNz8JDIKR zWVW_b%h4Nn2U)7+sF9(Ev<%IRd;u1l-6QC|LS$tTSeeYdqe!fHf!S8~Sgxm&&?vO5 zJ%JqiJ{;l&IK&I?0-l{tIy3Sb*l%X`_bNTmj4W2Y(25*BM1Qxs>v`vgq@PmPWjy~G z`Q_w4C%=OH%E<ffH9WtT_u=bW4u8UZC5!iwD|y^X-p)JVky+(V<g@C<R`*N3{WmER z`2u-;2%2j31i4NjrID2U9zyRvK`*KvY^4WV>AffDy(hqYE0})*tUm!pTft~67<>W@ zJ^==wfbNuJX$3=1fR$D-(F(1#0&OdhwgOEnkhB7Y;^?ikww0E)(!wX;>XV?A$yjfX zg1V=WFM*?@K~ZxvbaN28*$>^cKr;uRgFUpQnU*xu$9rf+Gp%T*70vYH9{O+(eYgib zXb*bOLHckHeYc;MHPd%$d>x>V_Rtr5=!ZS@ff{cI=mRz84uJdp;C(+h-w(c9z_l8O z2f+0n@Vo~c@1fPr;8l&y1K_m<ytaT-HBJwJ$2~-Y%3<y^k``mpLzitqmu>m~Iy)0E zsj4fF-*<0UZ*+Ba)748gBE-=U6pbLO8lwUtf=X0mV$AoU&WMPt6BCz+EP`7!s0fH_ za9@CO{M0yVa1z|2Ah>ioG6`MKRjEfCsvIb`2HyP6sRo(`Oq_b(dGFM%`(C}}-gEwU zIq%O^HgT0rT;X~%lkfA8`N&f8E@Qi#?P`Ai1bq$qr|4g@l^T;_yNyvBkM?(nHhC%A zDBBv+XoG`;)8ODVI5^GSX#xwUxkF9fDDqu`zLjkb*@kRKb|5>ET}UhKaE=LHPJ@@z zwiqcv%7gXx1lsy1BHu^24)Ajt{G0|qr@_x@@N?SIw*Y=l+lk0zWGXT{XyU0f@l=|4 zD(iVF>%r7%+sbhQ?wASIJKpLKzE1O`*7KCsyPkYMneY4uPpgTiwBC&-Z4BSX^8G5d zS0mSuK8f@x2=@^jo(6}fwRX%S-vZJXB8!m42)!!qG2{tk3Gx*34DuZE0`d~F452Rs z9G?cqr@`@QaC{mZp9aUL!SQKud>R~|c8$oF$R^I?D`Ydmv(XyX%2sOGo}j6q!tgc| zglpqnWc_873>%oYn^~Up*JcglZ=bRi+xR8=I@)M8jPm!UoDV`q1v#EVmb>{ick^rR z=GWZKEO#@@9n5m)vXpVLQ(4OR7Vg^DYM;P@+_A0PsjS)<u`hS>``ySrh}e$>L5?fP zas^qgAj=heEw(~!Lq(9|th2O$BaD9>NBQfC^hQoWuyP>i6bL$HXgk5h>*E1@`WTXU z0Uy+o0-yQVkw)xDBV|27Sx<mqq#c(4U8lfoK4m@u!WK`_h^O$)AJAz_f#ZDYfOrWX z58>k>d_07Yhw$+bzS&Bi9NTTdlXwarPvPS!d_08@GEd<xeCkMo`jMc|BZ=*5q>d!0 zBMH!vv=<Z9lLW{;g(vZ;D+v&M3UA`$O?>Y>blQW|n*?Y+<^4M&SXU#Pk=7tVT}e<^ z64aFhbtOSvNr0qM7Vl*1kQhR{)OHJe+dW8vrjnqkBxouLno5F2eXytx7WKiRKK8T` zd)i3-O4vT^$2|u9OFK0|3qabc30eUuS^+6q0V!GmDSIYzHp0jz^)Nw8K-#hidoJ7I zY`F&NWWtVQJC6Stk4!+WLne|wiSwAub_(06Y^Slki{E~Q+>6XZ?nmY$i#WF><OwL( zWk?m)uR8F-$37@7iQR7mBl{q^Bskfp4kxI?2~b@MPw9i~l6XtsoyPam$;<iUF?~Fy z?}qaIeB=`JG3;|Wzx@>b3ev7bzlyZ0k#XqbNxPoyFOVCM>ExS%P`=zO{$n=V+en|o zb}rxVBLA<Ddy#p;lXy-aB$%RglA?8zqIHsTuOn|DZz69aE0C4!|1SH#$M$`;AFyR) z7n_g(878p{3D98@+mHYuCb16*P+}4rkpL-5dp|+zM%w%dS~$|~PtZ@6#AYNwjw#v( zK5YZvC6J9s5@EEMwt<gtY{WM<;u{<B;yzy7cdeZJ9wZ2SJhqR=_VL($K^=AT$9S3u zwnhABidi@1c$X9&C4x7JU}I8vlJdMCW&0(v4!rtTYHEhxx8WH)#=%PwO7K3viq|N| zV?^*65j;i&j}gIRMDQ39JVpeYl)^Ja@C*?=L!^Tb795qr(nqjSDXe@1JC$-3rW`v3 zjsi3HBu)J>X_Qc`d<1(XxCl%{+9bYDL2g99ll*rh_aMLKF5)%a1EeoN7LsQXvKV;; zc?@|1S%N%;JcB%kynwufEJHT&A73Gxk!{Ehj<bv7;svqXN$xbhoHxsJzF6-Fb}+^0 zdVgjxoyuKfRGGWF5zC$Au5QF~C$Zc~EVpkmw7@*1H>1sikWtjBa(ZcI2OF{88?oLS zvEI$x9qFx+o|<N?capo(jP>@pBO9^aN$!Y@L^NZ$lc16$mfOd2`&e!t%bmn>Cmo}x zTuC!m(#(}Kb0r(G-bt)?vVdb2R0f+k^JaQH`!nKws-E=*&bpbi-oRNmbJopmXWhbC zGiJ)nmqExVJ>w0W@dnO#182DJ>^5+Aa#qrB)ZF2$nmMax&Z>no*}$1Jb0*E4Ni%2C zLjN<Pl-#>5+`AUeK>m%9Sw<JjX{XF)I|sQPS;+T?@K6ScAe|9LI=LrXxF=h<<}F<F z7Or^<|J1@YZeeu%LXhex<RauU{FaQa({}(~%;G^Zc#sSpB!dUZ;6XBYj|`q8gXhTL zIWl;T3|=FHH^|@xGI)Uu);ojc%wRb)Sk4TVGlSL3V9_#IvkW*gixtaY#WGm03|1=x zj?97~vsk7KmMMe9$$%ZR)Z`2`IRjqIQj0U-#4I&ALru<5lQRePDd+H+IecOczm@Y2 z->00zU*xdMIc#qZo0`Lp=CGqVS{?2Clylh39Ck2=9n4_|bJ&+0_9cgX$<gz$jdsO6 zq!rmi+w2m2`@y|qKceqUddT+mib;>yzTU8XJz>@K+Z~}N?6AFF-Ral+4sr}aKOsJG z6@Ksk*W*QhAU<pr{%aL}DT_Z^g&$gl@5$nKR^fB9+Os9SSo?ag+V@_~B9HW7&1L(~ z^jy75zW0$2k&lp7$S25Jq<yc}pZQMD7VqyYV77?7VS6y&hB9(^4l)cGj{JxjBp0(i z(8m)89mPRKab~A?0u9BnD$7AUaga@%db%7$)6mw>69>V>K`wC+OB}=!2d%^ztqar7 z6Q-XhOg~SUex5LM6|%MhsYJkamOEvmNHxMJCdefYa*2an;vknesHK4?)W8#J;0ZPG zgc|nu0rg^^laP~<KICOo6O<AMp~OKbaS%!zgc1j##6c)=5K0_$5(k;YK_zhzNgVXi zz*B4BsWr6q2gP}E4Q>5F4UT?Ko?x6O*uWEvxAh6d+w}>B=@SamClq#<lJ|1*<oku< zAceS-exb>vPerch`!A3ikXan>Hnwxw9^5|^$964eyg$oWf0l9nEMxpx#`m-CN#tqd zS>$=-MPw<m9C?{zy@I@oypAxp79<e|NyI@CaZp49rKN$=(m-ixptLklS{f)V4V0ER zC?O6)h=UFqC@t~!eM;EP<;=~?xBIfv?xUt=wO!N7b`KVWwgvAj9!g)*Imj?%IC3#^ zAMzmb8uABZC6Zy@+E%vPg6)Jhm2t#6uM695$Ux*gWCSu=`UR0%qz;K8^++G2FVY_& zKW}#}<K3=h_6+1q1okjH1mRpPGr%p!vm@!Vt3n1Kry=BZmm^mq<B;o-Um!Oiw;}U_ z?T+*2D(l?KY+pfMMP5hVK;A^&Mphu7AzvVWLe?Rz?7Jt}&Rwb7-&dB!mTtwCN<Uea znzV%)Bx7|4^_O8o_w|uU4|vBuvb;q<xQ~qIfd4tTpDe3Zy%K*^N?%!nDWRTTgN#Qe zAlD%idCnIg7a|vtM{+VxQ|)|?oH=sl$eAOj*zz1XbL7nNRLcX}vIujB@TN)d9<!{G z)0hXrOjWa#^ySEEegl!>Ws~^%P5Ai)BQPyqjUtmIUKj3N(ynE0<RoMo@*jxIv&tcO zRc|}81KEk}QZM}lqcSaw%Cy+;BeOv^bCBDSh0L>f2w6-^;SuC9q!o{Cm}BAC7J^zL z=oKKA&TM;<))xfRkMAS-KAP`i(XT<Dz?L~kjPSI8F*bpAHi0V=jP|rJ+S9^lPYa_x zEsXZGFxu0?Xip2HJuQs(v@qJ!!e~#6TZU}nSYIKVk!}3f4$zQ6DuM)v;R|DnKE^Ja z(t9g6gOHA9e7Q2XgE^9&gLtqKZEG+g7#X~=cSm5Dwfe0;+<E3x$exsjZ~j!0C&|p= z4xgYIbjDeANIvK*&$z=!|Cei*<Y0BMn5*$SWI5tju<Sqm0TJ*2fEtX6f?+y*G`&L_ zXZ2C=+u)bMbiFzgJW3m+g89Mpl;pDp-z5To^x&1CE?^WX_%+XCL7=||_XpF0vLM3z zR6fBF=BgGkzZL4h{Jwi{3Sf%~h6LB{y)rl@SR3>T<_1^gf6K4wXVA~SZTsIuXTHH< zKS3is4JNol^YCoZ54o>$PlE1;Nxxb1uL%Aa{G1$9_x?TjoKkh*$yUklhx<@|BJA<! z{BIpgQjpmD7RN~)NXJU>2?ieSScj%Dv;2skwj*iTrRSbc{(0qh2)gavLCWXII{hu5 z1NJXIl|h2p$d%09<dZL<*ram#cHpD;O7}XDCR+af2OAmRGr>Yie<fGnnMFR~;KYDU zup;n-k9i{5;PqfbFrQh@hkW#Z%iEX0fEi)=^T}T~J#uoack;VRz2RHOQl0-%)?t2a zIq>y>#&`&2A$T+Y+=H3?l0V!0+U%XkjCLa>Hn<bpZG!ud{Z~%UU)v{NruTjOcH8{Z z`ZoK>9`vg7`KDUm?(FnDi6WCd_FJ_45hU%~e|UO&v_tniVmjx559f2FTB^V8e@Y$m zGOt`dkpowy-&qmMA?pLzwg0JTj<zR>UUBF@69XdqiVZyIbC{e*vMonQZ-2P_wX{#k z>qkmIkTZCY*nvYnV#yeL<|F4Rb(MC;A)nyVLz2ERp?x{b*Q~u#&OQj127e0#f3<xM z?@@!l?6-6`?#p@Tw*7y!{c2$XXdgFRj<tdKip9}4)`Q=UH+^V<N%U}Mr6`Gkm4^|@ zBhkZMVfeTR1R&AF$IuS@SN6FKZjWO%dbkI1!^@d}FR{YCG*<XTjS@bIUbVGE5`V_h z8?J%|{-KecwNo@!cmT1&>zSROU>QVA1wBV_8vD%CZ(%td6uy;th&x%%5C#DALyZ_d zOCyE{YsBynjTj!P5yR(t5-~hNBZfz6#PIn<3{Nr_2v>#~t+BsjH1_w$#QxTs%QWhD zCQ-kG%<UT8yGWyZmuPhF(;D6Tj7Il9tI@sBX>{-N8r}PXM)$s`(Y-HebnjA)?p>zQ zy~{Pa_brX?eOse@f2YyCD>S<I9gXh&Z;kH#y+-%`L8E(DYIN_r8r}PzM)$t2(Y+rK z-TS!tP$POj)rj6kiRd-V3~({yOGK|>wzxamv`9p+`AQ;s&1Q+{HQObkmk8iN#PS-A z<t@@!-V%-FE!9}wP8!P_(OBMUjpeP;Sl(J<d8ZN+EK$72X%ue{jp98)qj*o$DBhDa zinpIe@ea@^-mx0Rdxb{vPSz;iDH_E)Rik*PX%z1b8pV5~M)BUHQM@;66z?q>#XD1@ zcxP!8?;MTdovTs2w-ZNqs+Qocl+qGPq?BN0QL!9NIXsqmi^s9R`^DlY(LF#u!f<0L zlf7usoybx`ALU83Cxq|DQYL$ovkyxr%6)%kXbxa0qf8FOmkna6piF9SF{Ls>nLHhD zJD8=4==veVmPorYs`aEs>q)IL;V_SsrH&eN5qYG})N7rIQD-iLljkQaF>24{)Gmp> zucrRI1U_5F;<OgUv=-HBEvnX9)J<!V)ml_eEo$Wa|IAWCZ}pex>sUH#y|P-btk$b; zTCciky(-pv)kW)7wbrZd)T>rzt?y>3*4ouwYgc#bRW<EiiI)k(l2dD9)UlrAIo><o z6nQ6jCqT?9^{qtfTZz^;s9Nb!=?YiPwdQDz)9>m{q6RXXjT(5g)<CB<un@+TRw6lf zdjZ7p#`5+M_*P2b1TD2;+Qa3<=tN*!sWw%xtVqm`#Oc>iW4oDJI984|b;7G+V(_Z; zBF{<oB-SU}lUesBioXDkl|JkxvHS&atq?Pz5&Z>lt`L`_as35wuMioe(fyA4e;Q|U zIxY1YSXh35eg-Y}8v8@|SVHzpdnWo>_AK<X?b+yqEwsDvrVK$p-$M5ePs#<H+lBT* zba_93weo%ds}{tn1+i*D%G83Cs0Ari3sR~Uq*N_PDHh~v_8Mo$akOjfHR$8*c=T)S zwdnAvpii_DxmT0yB<{mxI~je7oq|5qPDP()r=iOm2I|!Y)vFDvR~uBQHmFc-P@&qO zGPOZvYJ<wu29>D|DpMO&rZ%Vo8^jm_Tq}#X=MUM3&==dqrV`$jhs{y?=7CE1R~|)| z_YYLU!}2)#Zo8Yi1fvOO9@qe`QHnQX3lLlIhM16px*K+rLQ^RWC&t2YLd_PQ6ZA4y zM*gr1(??bA%Ap8le1v@~bcCeR@zx6%P&$($*05HsVVzpTm|DX+tl@V!{xR6ZB5dMu z<o~YwE<GSUTo3-`dyKGjh7$$uLwHe6AWtvsW=Pmk$ayl>(_uZa46vk7ieO6V%Q^IO z{TK)7@A{i6SW^ZN5jMyTq8H{=cdDs|Kjk!{b55rpE(VXv4@?)hR47I8slX(R{T)jB zIqn?#sCc6SYu>29dZZi4Rh;k6=U2E@Ojj)OMXWD&lph#YF5&7fb(ivwW84_dinlIs zp1gH|Bad}s>D#-4UcH#Sdx7&DM~@LPYecO@;9MC``n8Ud<0j~c(RJ=R&T68YNXle4 znPX0MQ(6Da{fuK?Pft?~w*CgzH|nU;P3|W0&vY~S-&t-JSIRpaSl{8WT5z)5$vwP_ zKEfE>EO(>-in(MlI9l#Ozn3{>F+7BfLd|#cInG1wA^z)O_b}^6-J`4@caO9Fjr$Gj zC*6~*pLS2Pe%3w9`g!*}>lfXNte3i_te3mxtm7`u*}hEQR}CyK|B3zzePA`Pxe${M zqsy!4uesOIU#Cy326mU<qQ61kSPd*M|AqdhdlUUF_ZIrw^p(}X`tm#U6>bIkJMJCs z4{xPlz0$4Z+TV5Wa@Fs-_t4*W@1uX<K0yD_eTe=?_eb=P+(+miyN}W7@kU?mR-=F7 zK0#mO)}XI-Ytebf1#8}ML22Y27pxhj;(4{uvl)XU<}38SGixpeSIlN~<^ZAd1`NtA zZ@}QJcmoEdafgn|?Q}c2w|m`Q%5dNUQ>-wr90nQBbP=CwYVoOsrW-sm^aAiIq+(Md z{uRT^TQXSlmJGa`^){=2Ey8aWoBaD_itv@R>eSaV%Ev;~BMWU#aG(JN{tI45ysuI3 z8^ZT~54|T#-uoK$zDMDEPbOVFZb&_@0R^6d-j~I|IoA(=DL%MVeQ=@r;4<~WCF+AK z@W7{WF5-i$z=dbCmw4isdSZhg9)>4Am&MS(I~+ZaTZN&{7>NfJ3_D6<JXng=H`mf% zcriJ}LmS>vGaBD~DT^^<SURcCwu~MBm=y8c)#|yedhU8+OJ|TilO+Uu87!`F)XhV` zk0lB(*#o4^X9>~A{2(a{SPblT3pw&4{JmlPc`0{KynYD$yc|6a7n;#G??hoodmUXc zwKZ=LO>5dP!P}q$Lx1&3j!85y`g<&$h|ySuE^p*1g)8h6j=6@#1A(t4o!Nz?e`dZw z7bIR`B#Of*dhoyw>v*=plV@Pw`zz0TJ+oSj;)Yt{J2s&UDz7HeLt0{gC*Gr$zH)ir zMi$<_TB1LsWhj_EN*qXzlx-}|Y$qn97PPU8Uj=Q{D%vo-0ca2UUPEVvzHBTC{@^`g z9t3Qr)^lC~=`h(60bS^opqF~3rZdcbRp?PKO1fZ_V#O$Bicu_Ves!cniA|n*uO7XN z*M+#&qr9WgyYlW11Iyph=-uegk9yrb%A_KgQepH%@9XvD-}`y}(Fb?~$T`phCBX1E z$dtnJN2!C^Z!md=c*D@;%|x~E`wd5j<Byypy$jJtF*m@2=kH?lOT0@s&S*vqqVWCw z8!7Pm5koxA8;35KsYo$XrDCQc#Y~m({7vOoK~9x0{n2uUzmDi*P!#tW{<>Y<4M9;M zZ#VeKD1HhlekxS_#Ap`yDF%M32jz6J^xn3^PsQ-lF~dMnl!c$}1md9uOU2-+I}u$F zRSdqm@1qN@iYcxNwZm1RcDO3k4p)WR;VNTKW&9(m=*lR%iYmG?imsxHu8g9qsG=)l z1zklIT^U7JQ9INQ1w)*}cuCX_v%}EOW!xkROWknv^Xz%(BkTzDk&L56L1WZbMOsI} zPIoo>0W4+OVJXuNONA6m6)TnsDV8c$EEQ5LRSaw04IJl2dn35&CW}Xex9(>2U)o=y z-(qh;pKhn4-)e6~pJ8X9&$KhqXW3ck@^+_Exb1G^ICJbA^tpB}y1ePB6t25F(B*wk zg>c?6;-;9a5bir>W-Br)g#V5i+KSH#;lP`RF7JUVgbVL}ba@+8A)I*g(dC^`C2-?m zZ4|eK6}MT%ZDGZ2Rf^l{6}MF>ZmU<^R;9SDUO4pFcZprXU47D0b77`yr6lYI$r(j* zAw_awVW~5?HGo}b;i^LyJXZyt>x3>CE+mX~=z`wDir$2~u96f%Z(%s>s=zBOq~wuY zjjKVgb<EO-*RBp-TDryX+ts5>d)LBq2Olb2cU{RNZQo)z@4BIP2j>~Zc}FSEGm7&f zu;2CM437uf8O3%X;lD!{Y!^~&SE|^qLa|*;v0W5ayn$dZL3qWA@M_y3JgW$=S`l7U z5ne5<d1vB@&vJt~@(?$KeFgJb#e5~O=wUGw`IW$?hs99*R|2cv2y{V#VMT#fQDBj9 z?2#^5ut>3>X~Tk}-Ds{w5MfLaVF>oUpO8}!VHEzopYp$O@R2gsjRji>I<)RecO}1G z<*wp-Vddjj!Hc1GcrmPa(JEdviWe)K;Kgdii^ffIllWgjjWIXHO+gpz7<1Fy&p4W3 z$Ef?c`#HKG$fy$pSploxO&sB7cMIv$-E_|FR(C7<3^xN^kYz}bWif1jv(ay3gfj~3 z-yC$on#IEYM}EPY5yhHTv1UZErd6yNQLJg<1^hKwbDo<=k-X2{$6oil`}r5apcRTi ztKkd87sDC20NlTj5!3>DFBWkvf=y#^2rfn!gc^fO@DX&usWCVOA43<k8goy$C(s46 z#^4xSf-cB42G`(I=z?Eka1K6$E+{qz_uzBrf@NcH5Waveh&Bcn;Y;X(Yh!Q{E<+b| z8&h;^6x~J@-5N!=QAM{#(QQ=Gtx<FvRdj0<-9{DN8b!BJMYl%LZB)^%QFI#x-O|^o zxHhD?wpej(NO5hk;@Xhn+G54EA;q=DifcoPYl{`vh7{KpE3OSGt}TWU@l&4KXN);V zVMhEM{R_sPqc9{kp#O<6=qOByjp%}ai(yRs5`7)x(osdjg|H|7g<33_xDXb__2^Bm ziL*_(1o{TI0ez#}h~Dg)(UUHTo^mPlzq!AmryaNjwnZOZP<2>QwN+FdR#a^jRfiQ- zTbLN>;fINF3*|(xwSkcl^r8s66lTWlqzKNgfT3|GC3%<IMHy>#t(39dZa4ZKw+CJD zw^96EtN6P@@pm;Wj-|%H+}H^eE|}ZE;21_1<ZWPbjG$LAi_U}5u@b&U!Qx?<9c%fu zuAmOQjk`xm>C2jN$h%mJ^j8bcDgf^lnxgB*kGsP364D>jM_!+A20|Cq+nm9=j~OBi zLgqXn5CRFyaplM!_%i<=vZjH~x<J?1b99c%Z1nHhQTV%g@T#sRP10$xd%rXP^AA{p zc}Ev-YkaK(Pw>;<$Si!=ec(rZT3B7-bZujG{nm`G$_4wa_u2*%?C;@%6*gGmgMAl9 z*!N(B6;4=Tg%w^{VTKiM*j2E@u7)307-HAJ5Gx$9pTQFQIXtn#6x#q-Y@RJv_+o`I zRybpYHCA|Ig*jHZW1C=)75-RZkQEMDVUZOcSz(eDE?Hrd6+T&Elod`{VU-nLSz(qH zZdqZM6@FP^m=%s$VVTYI%nH-2aLw+tPw~{lwBAnVSq`Q}Qx608Y}#UTSo&#SU4QR? z={XxnZ`rx#W;?=;G53J0CYZ(aKTU_TcqYh($QF8f-k}y{X+h*mjYN>w=gS9Wr_6hR ze;VP<XMF*w9xb%}<%fKw`&pjhc!uFw8Jo%L(HiQa<t$&;D2LuW-GBK0{Uxo3roFa5 t&9Yx%8wYfgm+;o}OCfF3p0qH9cztxcobpz<6fDt6S(6^pe7$Aw{{w{>--!SK literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/fontawesome-webfont.eot b/latest/_static/fonts/fontawesome-webfont.eot new file mode 100644 index 0000000000000000000000000000000000000000..84677bc0c5f37f1fac9d87548c4554b5c91717cf GIT binary patch literal 56006 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�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Χ}4ZzXD^bT4LX>3gK@n9cUCK-Z-%h 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 literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/fontawesome-webfont.svg b/latest/_static/fonts/fontawesome-webfont.svg new file mode 100644 index 000000000000..d907b25ae60e --- /dev/null +++ b/latest/_static/fonts/fontawesome-webfont.svg @@ -0,0 +1,520 @@ +<?xml version="1.0" standalone="no"?> +<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" > +<svg xmlns="http://www.w3.org/2000/svg"> +<metadata></metadata> +<defs> +<font id="fontawesomeregular" horiz-adv-x="1536" > +<font-face units-per-em="1792" ascent="1536" descent="-256" /> +<missing-glyph horiz-adv-x="448" /> +<glyph unicode=" " horiz-adv-x="448" /> +<glyph unicode=" " horiz-adv-x="448" /> +<glyph unicode=" " horiz-adv-x="448" /> +<glyph unicode="¨" horiz-adv-x="1792" /> +<glyph unicode="©" horiz-adv-x="1792" /> +<glyph unicode="®" horiz-adv-x="1792" /> +<glyph unicode="´" horiz-adv-x="1792" /> +<glyph unicode="Æ" horiz-adv-x="1792" /> +<glyph unicode="Ø" horiz-adv-x="1792" /> +<glyph unicode=" " horiz-adv-x="768" /> +<glyph unicode=" " horiz-adv-x="1537" /> +<glyph unicode=" " horiz-adv-x="768" /> +<glyph unicode=" " horiz-adv-x="1537" /> +<glyph unicode=" " horiz-adv-x="512" /> +<glyph unicode=" " horiz-adv-x="384" /> +<glyph unicode=" " horiz-adv-x="256" /> +<glyph unicode=" " horiz-adv-x="256" /> +<glyph unicode=" " horiz-adv-x="192" /> +<glyph unicode=" " horiz-adv-x="307" /> +<glyph unicode=" " horiz-adv-x="85" /> +<glyph unicode=" " horiz-adv-x="307" /> +<glyph unicode=" " horiz-adv-x="384" /> +<glyph unicode="™" horiz-adv-x="1792" /> +<glyph unicode="∞" horiz-adv-x="1792" /> +<glyph unicode="≠" horiz-adv-x="1792" /> +<glyph unicode="◼" horiz-adv-x="500" d="M0 0z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1699 1350q0 -35 -43 -78l-632 -632v-768h320q26 0 45 -19t19 -45t-19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45t45 19h320v768l-632 632q-43 43 -43 78q0 23 18 36.5t38 17.5t43 4h1408q23 0 43 -4t38 -17.5t18 -36.5z" /> +<glyph unicode="" d="M1536 1312v-1120q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v537l-768 -237v-709q0 -50 -34 -89t-86 -60.5t-103.5 -32t-96.5 -10.5t-96.5 10.5t-103.5 32t-86 60.5t-34 89 t34 89t86 60.5t103.5 32t96.5 10.5q105 0 192 -39v967q0 31 19 56.5t49 35.5l832 256q12 4 28 4q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -52 -38 -90t-90 -38q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5 t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1664 32v768q-32 -36 -69 -66q-268 -206 -426 -338q-51 -43 -83 -67t-86.5 -48.5t-102.5 -24.5h-1h-1q-48 0 -102.5 24.5t-86.5 48.5t-83 67q-158 132 -426 338q-37 30 -69 66v-768q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1664 1083v11v13.5t-0.5 13 t-3 12.5t-5.5 9t-9 7.5t-14 2.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5q0 -168 147 -284q193 -152 401 -317q6 -5 35 -29.5t46 -37.5t44.5 -31.5t50.5 -27.5t43 -9h1h1q20 0 43 9t50.5 27.5t44.5 31.5t46 37.5t35 29.5q208 165 401 317q54 43 100.5 115.5t46.5 131.5z M1792 1120v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47t47 -113z" /> +<glyph unicode="" horiz-adv-x="1792" d="M896 -128q-26 0 -44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5q224 0 351 -124t127 -344q0 -221 -229 -450l-623 -600 q-18 -18 -44 -18z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -21 -10.5 -35.5t-30.5 -14.5q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455 l502 -73q56 -9 56 -46z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1137 532l306 297l-422 62l-189 382l-189 -382l-422 -62l306 -297l-73 -421l378 199l377 -199zM1664 889q0 -22 -26 -48l-363 -354l86 -500q1 -7 1 -20q0 -50 -41 -50q-19 0 -40 12l-449 236l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500 l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41t49 -41l225 -455l502 -73q56 -9 56 -46z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1408 131q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5t43 97.5t62 81t85.5 53.5t111.5 20q9 0 42 -21.5t74.5 -48t108 -48t133.5 -21.5t133.5 21.5t108 48t74.5 48t42 21.5q61 0 111.5 -20t85.5 -53.5t62 -81 t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M384 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 320v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM384 704v128q0 26 -19 45t-45 19h-128 q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 -64v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM384 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45 t45 -19h128q26 0 45 19t19 45zM1792 -64v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1408 704v512q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-512q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1792 320v128 q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 704v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1792 1088v128q0 26 -19 45t-45 19h-128q-26 0 -45 -19 t-19 -45v-128q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1920 1248v-1344q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1344q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" /> +<glyph unicode="" horiz-adv-x="1664" d="M768 512v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM768 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 512v-384q0 -52 -38 -90t-90 -38 h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90zM1664 1280v-384q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 288v-192q0 -40 -28 -68t-68 -28h-320 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1152 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1792" d="M512 288v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM512 800v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 288v-192q0 -40 -28 -68t-68 -28h-960 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68zM512 1312v-192q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h320q40 0 68 -28t28 -68zM1792 800v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28 h960q40 0 68 -28t28 -68zM1792 1312v-192q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h960q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1671 970q0 -40 -28 -68l-724 -724l-136 -136q-28 -28 -68 -28t-68 28l-136 136l-362 362q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -295l656 657q28 28 68 28t68 -28l136 -136q28 -28 28 -68z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1298 214q0 -40 -28 -68l-136 -136q-28 -28 -68 -28t-68 28l-294 294l-294 -294q-28 -28 -68 -28t-68 28l-136 136q-28 28 -28 68t28 68l294 294l-294 294q-28 28 -28 68t28 68l136 136q28 28 68 28t68 -28l294 -294l294 294q28 28 68 28t68 -28l136 -136q28 -28 28 -68 t-28 -68l-294 -294l294 -294q28 -28 28 -68z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-224q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v224h-224q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h224v224q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5v-224h224 q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5zM1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5 t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1024 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-576q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h576q13 0 22.5 -9.5t9.5 -22.5zM1152 704q0 185 -131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5t316.5 131.5t131.5 316.5z M1664 -128q0 -53 -37.5 -90.5t-90.5 -37.5q-54 0 -90 38l-343 342q-179 -124 -399 -124q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5t273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -220 -124 -399l343 -343q37 -37 37 -90z " /> +<glyph unicode="" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61t-298 61t-245 164t-164 245t-61 298q0 182 80.5 343t226.5 270q43 32 95.5 25t83.5 -50q32 -42 24.5 -94.5t-49.5 -84.5q-98 -74 -151.5 -181t-53.5 -228q0 -104 40.5 -198.5t109.5 -163.5t163.5 -109.5 t198.5 -40.5t198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5q0 121 -53.5 228t-151.5 181q-42 32 -49.5 84.5t24.5 94.5q31 43 84 50t95 -25q146 -109 226.5 -270t80.5 -343zM896 1408v-640q0 -52 -38 -90t-90 -38t-90 38t-38 90v640q0 52 38 90t90 38t90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="1792" d="M256 96v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM640 224v-320q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1024 480v-576q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23 v576q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1408 864v-960q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v960q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1792 1376v-1472q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1472q0 14 9 23t23 9h192q14 0 23 -9t9 -23z" /> +<glyph unicode="" d="M1024 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1536 749v-222q0 -12 -8 -23t-20 -13l-185 -28q-19 -54 -39 -91q35 -50 107 -138q10 -12 10 -25t-9 -23q-27 -37 -99 -108t-94 -71q-12 0 -26 9l-138 108q-44 -23 -91 -38 q-16 -136 -29 -186q-7 -28 -36 -28h-222q-14 0 -24.5 8.5t-11.5 21.5l-28 184q-49 16 -90 37l-141 -107q-10 -9 -25 -9q-14 0 -25 11q-126 114 -165 168q-7 10 -7 23q0 12 8 23q15 21 51 66.5t54 70.5q-27 50 -41 99l-183 27q-13 2 -21 12.5t-8 23.5v222q0 12 8 23t19 13 l186 28q14 46 39 92q-40 57 -107 138q-10 12 -10 24q0 10 9 23q26 36 98.5 107.5t94.5 71.5q13 0 26 -10l138 -107q44 23 91 38q16 136 29 186q7 28 36 28h222q14 0 24.5 -8.5t11.5 -21.5l28 -184q49 -16 90 -37l142 107q9 9 24 9q13 0 25 -10q129 -119 165 -170q7 -8 7 -22 q0 -12 -8 -23q-15 -21 -51 -66.5t-54 -70.5q26 -50 41 -98l183 -28q13 -2 21 -12.5t8 -23.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M512 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM768 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1024 800v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1152 76v948h-896v-948q0 -22 7 -40.5t14.5 -27t10.5 -8.5h832q3 0 10.5 8.5t14.5 27t7 40.5zM480 1152h448l-48 117q-7 9 -17 11h-317q-10 -2 -17 -11zM1408 1120v-64q0 -14 -9 -23t-23 -9h-96v-948q0 -83 -47 -143.5t-113 -60.5h-832 q-66 0 -113 58.5t-47 141.5v952h-96q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h309l70 167q15 37 54 63t79 26h320q40 0 79 -26t54 -63l70 -167h309q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1408 544v-480q0 -26 -19 -45t-45 -19h-384v384h-256v-384h-384q-26 0 -45 19t-19 45v480q0 1 0.5 3t0.5 3l575 474l575 -474q1 -2 1 -6zM1631 613l-62 -74q-8 -9 -21 -11h-3q-13 0 -21 7l-692 577l-692 -577q-12 -8 -24 -7q-13 2 -21 11l-62 74q-8 10 -7 23.5t11 21.5 l719 599q32 26 76 26t76 -26l244 -204v195q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-408l219 -182q10 -8 11 -21.5t-7 -23.5z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z " /> +<glyph unicode="" d="M896 992v-448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h224v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1111 540v4l-24 320q-1 13 -11 22.5t-23 9.5h-186q-13 0 -23 -9.5t-11 -22.5l-24 -320v-4q-1 -12 8 -20t21 -8h244q12 0 21 8t8 20zM1870 73q0 -73 -46 -73h-704q13 0 22 9.5t8 22.5l-20 256q-1 13 -11 22.5t-23 9.5h-272q-13 0 -23 -9.5t-11 -22.5l-20 -256 q-1 -13 8 -22.5t22 -9.5h-704q-46 0 -46 73q0 54 26 116l417 1044q8 19 26 33t38 14h339q-13 0 -23 -9.5t-11 -22.5l-15 -192q-1 -14 8 -23t22 -9h166q13 0 22 9t8 23l-15 192q-1 13 -11 22.5t-23 9.5h339q20 0 38 -14t26 -33l417 -1044q26 -62 26 -116z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1280 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 416v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h465l135 -136 q58 -56 136 -56t136 56l136 136h464q40 0 68 -28t28 -68zM1339 985q17 -41 -14 -70l-448 -448q-18 -19 -45 -19t-45 19l-448 448q-31 29 -14 70q17 39 59 39h256v448q0 26 19 45t45 19h256q26 0 45 -19t19 -45v-448h256q42 0 59 -39z" /> +<glyph unicode="" d="M1120 608q0 -12 -10 -24l-319 -319q-11 -9 -23 -9t-23 9l-320 320q-15 16 -7 35q8 20 30 20h192v352q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-352h192q14 0 23 -9t9 -23zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273 t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1118 660q-8 -20 -30 -20h-192v-352q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v352h-192q-14 0 -23 9t-9 23q0 12 10 24l319 319q11 9 23 9t23 -9l320 -320q15 -16 7 -35zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198 t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1023 576h316q-1 3 -2.5 8t-2.5 8l-212 496h-708l-212 -496q-1 -2 -2.5 -8t-2.5 -8h316l95 -192h320zM1536 546v-482q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v482q0 62 25 123l238 552q10 25 36.5 42t52.5 17h832q26 0 52.5 -17t36.5 -42l238 -552 q25 -61 25 -123z" /> +<glyph unicode="" d="M1184 640q0 -37 -32 -55l-544 -320q-15 -9 -32 -9q-16 0 -32 8q-32 19 -32 56v640q0 37 32 56q33 18 64 -1l544 -320q32 -18 32 -55zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l138 138q-148 137 -349 137q-104 0 -198.5 -40.5t-163.5 -109.5t-109.5 -163.5t-40.5 -198.5t40.5 -198.5t109.5 -163.5t163.5 -109.5t198.5 -40.5q119 0 225 52t179 147q7 10 23 12q14 0 25 -9 l137 -138q9 -8 9.5 -20.5t-7.5 -22.5q-109 -132 -264 -204.5t-327 -72.5q-156 0 -298 61t-245 164t-164 245t-61 298t61 298t164 245t245 164t298 61q147 0 284.5 -55.5t244.5 -156.5l130 129q29 31 70 14q39 -17 39 -59z" /> +<glyph unicode="" d="M1511 480q0 -5 -1 -7q-64 -268 -268 -434.5t-478 -166.5q-146 0 -282.5 55t-243.5 157l-129 -129q-19 -19 -45 -19t-45 19t-19 45v448q0 26 19 45t45 19h448q26 0 45 -19t19 -45t-19 -45l-137 -137q71 -66 161 -102t187 -36q134 0 250 65t186 179q11 17 53 117 q8 23 30 23h192q13 0 22.5 -9.5t9.5 -22.5zM1536 1280v-448q0 -26 -19 -45t-45 -19h-448q-26 0 -45 19t-19 45t19 45l138 138q-148 137 -349 137q-134 0 -250 -65t-186 -179q-11 -17 -53 -117q-8 -23 -30 -23h-199q-13 0 -22.5 9.5t-9.5 22.5v7q65 268 270 434.5t480 166.5 q146 0 284 -55.5t245 -156.5l130 129q19 19 45 19t45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M384 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M384 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1536 352v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5z M1536 608v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5t9.5 -22.5zM1536 864v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h960q13 0 22.5 -9.5 t9.5 -22.5zM1664 160v832q0 13 -9.5 22.5t-22.5 9.5h-1472q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1472q13 0 22.5 9.5t9.5 22.5zM1792 1248v-1088q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1472q66 0 113 -47 t47 -113z" /> +<glyph unicode="" horiz-adv-x="1152" d="M320 768h512v192q0 106 -75 181t-181 75t-181 -75t-75 -181v-192zM1152 672v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v192q0 184 132 316t316 132t316 -132t132 -316v-192h32q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1792" d="M320 1280q0 -72 -64 -110v-1266q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v1266q-64 38 -64 110q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -25 -12.5 -38.5t-39.5 -27.5q-215 -116 -369 -116q-61 0 -123.5 22t-108.5 48 t-115.5 48t-142.5 22q-192 0 -464 -146q-17 -9 -33 -9q-26 0 -45 19t-19 45v742q0 32 31 55q21 14 79 43q236 120 421 120q107 0 200 -29t219 -88q38 -19 88 -19q54 0 117.5 21t110 47t88 47t54.5 21q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1664 650q0 -166 -60 -314l-20 -49l-185 -33q-22 -83 -90.5 -136.5t-156.5 -53.5v-32q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v576q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-32q71 0 130 -35.5t93 -95.5l68 12q29 95 29 193q0 148 -88 279t-236.5 209t-315.5 78 t-315.5 -78t-236.5 -209t-88 -279q0 -98 29 -193l68 -12q34 60 93 95.5t130 35.5v32q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-576q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v32q-88 0 -156.5 53.5t-90.5 136.5l-185 33l-20 49q-60 148 -60 314q0 151 67 291t179 242.5 t266 163.5t320 61t320 -61t266 -163.5t179 -242.5t67 -291z" /> +<glyph unicode="" horiz-adv-x="768" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1152" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142z" /> +<glyph unicode="" horiz-adv-x="1664" d="M768 1184v-1088q0 -26 -19 -45t-45 -19t-45 19l-333 333h-262q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h262l333 333q19 19 45 19t45 -19t19 -45zM1152 640q0 -76 -42.5 -141.5t-112.5 -93.5q-10 -5 -25 -5q-26 0 -45 18.5t-19 45.5q0 21 12 35.5t29 25t34 23t29 35.5 t12 57t-12 57t-29 35.5t-34 23t-29 25t-12 35.5q0 27 19 45.5t45 18.5q15 0 25 -5q70 -27 112.5 -93t42.5 -142zM1408 640q0 -153 -85 -282.5t-225 -188.5q-13 -5 -25 -5q-27 0 -46 19t-19 45q0 39 39 59q56 29 76 44q74 54 115.5 135.5t41.5 173.5t-41.5 173.5 t-115.5 135.5q-20 15 -76 44q-39 20 -39 59q0 26 19 45t45 19q13 0 26 -5q140 -59 225 -188.5t85 -282.5zM1664 640q0 -230 -127 -422.5t-338 -283.5q-13 -5 -26 -5q-26 0 -45 19t-19 45q0 36 39 59q7 4 22.5 10.5t22.5 10.5q46 25 82 51q123 91 192 227t69 289t-69 289 t-192 227q-36 26 -82 51q-7 4 -22.5 10.5t-22.5 10.5q-39 23 -39 59q0 26 19 45t45 19q13 0 26 -5q211 -91 338 -283.5t127 -422.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 384v-128h-128v128h128zM384 1152v-128h-128v128h128zM1152 1152v-128h-128v128h128zM128 129h384v383h-384v-383zM128 896h384v384h-384v-384zM896 896h384v384h-384v-384zM640 640v-640h-640v640h640zM1152 128v-128h-128v128h128zM1408 128v-128h-128v128h128z M1408 640v-384h-384v128h-128v-384h-128v640h384v-128h128v128h128zM640 1408v-640h-640v640h640zM1408 1408v-640h-640v640h640z" /> +<glyph unicode="" horiz-adv-x="1792" d="M63 0h-63v1408h63v-1408zM126 1h-32v1407h32v-1407zM220 1h-31v1407h31v-1407zM377 1h-31v1407h31v-1407zM534 1h-62v1407h62v-1407zM660 1h-31v1407h31v-1407zM723 1h-31v1407h31v-1407zM786 1h-31v1407h31v-1407zM943 1h-63v1407h63v-1407zM1100 1h-63v1407h63v-1407z M1226 1h-63v1407h63v-1407zM1352 1h-63v1407h63v-1407zM1446 1h-63v1407h63v-1407zM1635 1h-94v1407h94v-1407zM1698 1h-32v1407h32v-1407zM1792 0h-63v1408h63v-1408z" /> +<glyph unicode="" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1920" d="M448 1088q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1515 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-53 0 -90 37l-715 716q-38 37 -64.5 101t-26.5 117v416q0 52 38 90t90 38h416q53 0 117 -26.5t102 -64.5 l715 -714q37 -39 37 -91zM1899 512q0 -53 -37 -90l-491 -492q-39 -37 -91 -37q-36 0 -59 14t-53 45l470 470q37 37 37 90q0 52 -37 91l-715 714q-38 38 -102 64.5t-117 26.5h224q53 0 117 -26.5t102 -64.5l715 -714q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1639 1058q40 -57 18 -129l-275 -906q-19 -64 -76.5 -107.5t-122.5 -43.5h-923q-77 0 -148.5 53.5t-99.5 131.5q-24 67 -2 127q0 4 3 27t4 37q1 8 -3 21.5t-3 19.5q2 11 8 21t16.5 23.5t16.5 23.5q23 38 45 91.5t30 91.5q3 10 0.5 30t-0.5 28q3 11 17 28t17 23 q21 36 42 92t25 90q1 9 -2.5 32t0.5 28q4 13 22 30.5t22 22.5q19 26 42.5 84.5t27.5 96.5q1 8 -3 25.5t-2 26.5q2 8 9 18t18 23t17 21q8 12 16.5 30.5t15 35t16 36t19.5 32t26.5 23.5t36 11.5t47.5 -5.5l-1 -3q38 9 51 9h761q74 0 114 -56t18 -130l-274 -906 q-36 -119 -71.5 -153.5t-128.5 -34.5h-869q-27 0 -38 -15q-11 -16 -1 -43q24 -70 144 -70h923q29 0 56 15.5t35 41.5l300 987q7 22 5 57q38 -15 59 -43zM575 1056q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5 t-16.5 -22.5zM492 800q-4 -13 2 -22.5t20 -9.5h608q13 0 25.5 9.5t16.5 22.5l21 64q4 13 -2 22.5t-20 9.5h-608q-13 0 -25.5 -9.5t-16.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289q0 34 19.5 62t52.5 41q21 9 44 9h1048z" /> +<glyph unicode="" horiz-adv-x="1664" d="M384 0h896v256h-896v-256zM384 640h896v384h-160q-40 0 -68 28t-28 68v160h-640v-640zM1536 576q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 576v-416q0 -13 -9.5 -22.5t-22.5 -9.5h-224v-160q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68 v160h-224q-13 0 -22.5 9.5t-9.5 22.5v416q0 79 56.5 135.5t135.5 56.5h64v544q0 40 28 68t68 28h672q40 0 88 -20t76 -48l152 -152q28 -28 48 -76t20 -88v-256h64q79 0 135.5 -56.5t56.5 -135.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M960 864q119 0 203.5 -84.5t84.5 -203.5t-84.5 -203.5t-203.5 -84.5t-203.5 84.5t-84.5 203.5t84.5 203.5t203.5 84.5zM1664 1280q106 0 181 -75t75 -181v-896q0 -106 -75 -181t-181 -75h-1408q-106 0 -181 75t-75 181v896q0 106 75 181t181 75h224l51 136 q19 49 69.5 84.5t103.5 35.5h512q53 0 103.5 -35.5t69.5 -84.5l51 -136h224zM960 128q185 0 316.5 131.5t131.5 316.5t-131.5 316.5t-316.5 131.5t-316.5 -131.5t-131.5 -316.5t131.5 -316.5t316.5 -131.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M725 977l-170 -450q33 0 136.5 -2t160.5 -2q19 0 57 2q-87 253 -184 452zM0 -128l2 79q23 7 56 12.5t57 10.5t49.5 14.5t44.5 29t31 50.5l237 616l280 724h75h53q8 -14 11 -21l205 -480q33 -78 106 -257.5t114 -274.5q15 -34 58 -144.5t72 -168.5q20 -45 35 -57 q19 -15 88 -29.5t84 -20.5q6 -38 6 -57q0 -4 -0.5 -13t-0.5 -13q-63 0 -190 8t-191 8q-76 0 -215 -7t-178 -8q0 43 4 78l131 28q1 0 12.5 2.5t15.5 3.5t14.5 4.5t15 6.5t11 8t9 11t2.5 14q0 16 -31 96.5t-72 177.5t-42 100l-450 2q-26 -58 -76.5 -195.5t-50.5 -162.5 q0 -22 14 -37.5t43.5 -24.5t48.5 -13.5t57 -8.5t41 -4q1 -19 1 -58q0 -9 -2 -27q-58 0 -174.5 10t-174.5 10q-8 0 -26.5 -4t-21.5 -4q-80 -14 -188 -14z" /> +<glyph unicode="" horiz-adv-x="1408" d="M555 15q74 -32 140 -32q376 0 376 335q0 114 -41 180q-27 44 -61.5 74t-67.5 46.5t-80.5 25t-84 10.5t-94.5 2q-73 0 -101 -10q0 -53 -0.5 -159t-0.5 -158q0 -8 -1 -67.5t-0.5 -96.5t4.5 -83.5t12 -66.5zM541 761q42 -7 109 -7q82 0 143 13t110 44.5t74.5 89.5t25.5 142 q0 70 -29 122.5t-79 82t-108 43.5t-124 14q-50 0 -130 -13q0 -50 4 -151t4 -152q0 -27 -0.5 -80t-0.5 -79q0 -46 1 -69zM0 -128l2 94q15 4 85 16t106 27q7 12 12.5 27t8.5 33.5t5.5 32.5t3 37.5t0.5 34v35.5v30q0 982 -22 1025q-4 8 -22 14.5t-44.5 11t-49.5 7t-48.5 4.5 t-30.5 3l-4 83q98 2 340 11.5t373 9.5q23 0 68.5 -0.5t67.5 -0.5q70 0 136.5 -13t128.5 -42t108 -71t74 -104.5t28 -137.5q0 -52 -16.5 -95.5t-39 -72t-64.5 -57.5t-73 -45t-84 -40q154 -35 256.5 -134t102.5 -248q0 -100 -35 -179.5t-93.5 -130.5t-138 -85.5t-163.5 -48.5 t-176 -14q-44 0 -132 3t-132 3q-106 0 -307 -11t-231 -12z" /> +<glyph unicode="" horiz-adv-x="1024" d="M0 -126l17 85q6 2 81.5 21.5t111.5 37.5q28 35 41 101q1 7 62 289t114 543.5t52 296.5v25q-24 13 -54.5 18.5t-69.5 8t-58 5.5l19 103q33 -2 120 -6.5t149.5 -7t120.5 -2.5q48 0 98.5 2.5t121 7t98.5 6.5q-5 -39 -19 -89q-30 -10 -101.5 -28.5t-108.5 -33.5 q-8 -19 -14 -42.5t-9 -40t-7.5 -45.5t-6.5 -42q-27 -148 -87.5 -419.5t-77.5 -355.5q-2 -9 -13 -58t-20 -90t-16 -83.5t-6 -57.5l1 -18q17 -4 185 -31q-3 -44 -16 -99q-11 0 -32.5 -1.5t-32.5 -1.5q-29 0 -87 10t-86 10q-138 2 -206 2q-51 0 -143 -9t-121 -11z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1744 128q33 0 42 -18.5t-11 -44.5l-126 -162q-20 -26 -49 -26t-49 26l-126 162q-20 26 -11 44.5t42 18.5h80v1024h-80q-33 0 -42 18.5t11 44.5l126 162q20 26 49 26t49 -26l126 -162q20 -26 11 -44.5t-42 -18.5h-80v-1024h80zM81 1407l54 -27q12 -5 211 -5q44 0 132 2 t132 2q36 0 107.5 -0.5t107.5 -0.5h293q6 0 21 -0.5t20.5 0t16 3t17.5 9t15 17.5l42 1q4 0 14 -0.5t14 -0.5q2 -112 2 -336q0 -80 -5 -109q-39 -14 -68 -18q-25 44 -54 128q-3 9 -11 48t-14.5 73.5t-7.5 35.5q-6 8 -12 12.5t-15.5 6t-13 2.5t-18 0.5t-16.5 -0.5 q-17 0 -66.5 0.5t-74.5 0.5t-64 -2t-71 -6q-9 -81 -8 -136q0 -94 2 -388t2 -455q0 -16 -2.5 -71.5t0 -91.5t12.5 -69q40 -21 124 -42.5t120 -37.5q5 -40 5 -50q0 -14 -3 -29l-34 -1q-76 -2 -218 8t-207 10q-50 0 -151 -9t-152 -9q-3 51 -3 52v9q17 27 61.5 43t98.5 29t78 27 q19 42 19 383q0 101 -3 303t-3 303v117q0 2 0.5 15.5t0.5 25t-1 25.5t-3 24t-5 14q-11 12 -162 12q-33 0 -93 -12t-80 -26q-19 -13 -34 -72.5t-31.5 -111t-42.5 -53.5q-42 26 -56 44v383z" /> +<glyph unicode="" d="M81 1407l54 -27q12 -5 211 -5q44 0 132 2t132 2q70 0 246.5 1t304.5 0.5t247 -4.5q33 -1 56 31l42 1q4 0 14 -0.5t14 -0.5q2 -112 2 -336q0 -80 -5 -109q-39 -14 -68 -18q-25 44 -54 128q-3 9 -11 47.5t-15 73.5t-7 36q-10 13 -27 19q-5 2 -66 2q-30 0 -93 1t-103 1 t-94 -2t-96 -7q-9 -81 -8 -136l1 -152v52q0 -55 1 -154t1.5 -180t0.5 -153q0 -16 -2.5 -71.5t0 -91.5t12.5 -69q40 -21 124 -42.5t120 -37.5q5 -40 5 -50q0 -14 -3 -29l-34 -1q-76 -2 -218 8t-207 10q-50 0 -151 -9t-152 -9q-3 51 -3 52v9q17 27 61.5 43t98.5 29t78 27 q7 16 11.5 74t6 145.5t1.5 155t-0.5 153.5t-0.5 89q0 7 -2.5 21.5t-2.5 22.5q0 7 0.5 44t1 73t0 76.5t-3 67.5t-6.5 32q-11 12 -162 12q-41 0 -163 -13.5t-138 -24.5q-19 -12 -34 -71.5t-31.5 -111.5t-42.5 -54q-42 26 -56 44v383zM1310 125q12 0 42 -19.5t57.5 -41.5 t59.5 -49t36 -30q26 -21 26 -49t-26 -49q-4 -3 -36 -30t-59.5 -49t-57.5 -41.5t-42 -19.5q-13 0 -20.5 10.5t-10 28.5t-2.5 33.5t1.5 33t1.5 19.5h-1024q0 -2 1.5 -19.5t1.5 -33t-2.5 -33.5t-10 -28.5t-20.5 -10.5q-12 0 -42 19.5t-57.5 41.5t-59.5 49t-36 30q-26 21 -26 49 t26 49q4 3 36 30t59.5 49t57.5 41.5t42 19.5q13 0 20.5 -10.5t10 -28.5t2.5 -33.5t-1.5 -33t-1.5 -19.5h1024q0 2 -1.5 19.5t-1.5 33t2.5 33.5t10 28.5t20.5 10.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1408 576v-128q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h896q26 0 45 -19t19 -45zM1664 960v-128q0 -26 -19 -45t-45 -19 h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1280 1344v-128q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h640q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1280q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1536q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1536q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1152q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 192v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 576v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 960v-128q0 -26 -19 -45 t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-128q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M256 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM256 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5 t9.5 -22.5zM256 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344 q13 0 22.5 -9.5t9.5 -22.5zM256 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-192q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h192q13 0 22.5 -9.5t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v192 q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M384 992v-576q0 -13 -9.5 -22.5t-22.5 -9.5q-14 0 -23 9l-288 288q-9 9 -9 23t9 23l288 288q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M352 704q0 -14 -9 -23l-288 -288q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v576q0 13 9.5 22.5t22.5 9.5q14 0 23 -9l288 -288q9 -9 9 -23zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5 t9.5 -22.5zM1792 608v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088q13 0 22.5 -9.5t9.5 -22.5zM1792 992v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1088q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1088 q13 0 22.5 -9.5t9.5 -22.5zM1792 1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1728q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1728q13 0 22.5 -9.5t9.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 1184v-1088q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-403 403v-166q0 -119 -84.5 -203.5t-203.5 -84.5h-704q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h704q119 0 203.5 -84.5t84.5 -203.5v-165l403 402q18 19 45 19q12 0 25 -5 q39 -17 39 -59z" /> +<glyph unicode="" horiz-adv-x="1920" d="M640 960q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1664 576v-448h-1408v192l320 320l160 -160l512 512zM1760 1280h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-1216q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5v1216 q0 13 -9.5 22.5t-22.5 9.5zM1920 1248v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" /> +<glyph unicode="" d="M363 0l91 91l-235 235l-91 -91v-107h128v-128h107zM886 928q0 22 -22 22q-10 0 -17 -7l-542 -542q-7 -7 -7 -17q0 -22 22 -22q10 0 17 7l542 542q7 7 7 17zM832 1120l416 -416l-832 -832h-416v416zM1515 1024q0 -53 -37 -90l-166 -166l-416 416l166 165q36 38 90 38 q53 0 91 -38l235 -234q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1024" d="M768 896q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1024 896q0 -109 -33 -179l-364 -774q-16 -33 -47.5 -52t-67.5 -19t-67.5 19t-46.5 52l-365 774q-33 70 -33 179q0 212 150 362t362 150t362 -150t150 -362z" /> +<glyph unicode="" d="M768 96v1088q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M512 384q0 36 -20 69q-1 1 -15.5 22.5t-25.5 38t-25 44t-21 50.5q-4 16 -21 16t-21 -16q-7 -23 -21 -50.5t-25 -44t-25.5 -38t-15.5 -22.5q-20 -33 -20 -69q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 512q0 -212 -150 -362t-362 -150t-362 150t-150 362 q0 145 81 275q6 9 62.5 90.5t101 151t99.5 178t83 201.5q9 30 34 47t51 17t51.5 -17t33.5 -47q28 -93 83 -201.5t99.5 -178t101 -151t62.5 -90.5q81 -127 81 -275z" /> +<glyph unicode="" horiz-adv-x="1792" d="M888 352l116 116l-152 152l-116 -116v-56h96v-96h56zM1328 1072q-16 16 -33 -1l-350 -350q-17 -17 -1 -33t33 1l350 350q17 17 1 33zM1408 478v-190q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-14 -14 -32 -8q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v126q0 13 9 22l64 64q15 15 35 7t20 -29zM1312 1216l288 -288l-672 -672h-288v288zM1756 1084l-92 -92 l-288 288l92 92q28 28 68 28t68 -28l152 -152q28 -28 28 -68t-28 -68z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1408 547v-259q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h255v0q13 0 22.5 -9.5t9.5 -22.5q0 -27 -26 -32q-77 -26 -133 -60q-10 -4 -16 -4h-112q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832 q66 0 113 47t47 113v214q0 19 18 29q28 13 54 37q16 16 35 8q21 -9 21 -29zM1645 1043l-384 -384q-18 -19 -45 -19q-12 0 -25 5q-39 17 -39 59v192h-160q-323 0 -438 -131q-119 -137 -74 -473q3 -23 -20 -34q-8 -2 -12 -2q-16 0 -26 13q-10 14 -21 31t-39.5 68.5t-49.5 99.5 t-38.5 114t-17.5 122q0 49 3.5 91t14 90t28 88t47 81.5t68.5 74t94.5 61.5t124.5 48.5t159.5 30.5t196.5 11h160v192q0 42 39 59q13 5 25 5q26 0 45 -19l384 -384q19 -19 19 -45t-19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1408 606v-318q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q63 0 117 -25q15 -7 18 -23q3 -17 -9 -29l-49 -49q-10 -10 -23 -10q-3 0 -9 2q-23 6 -45 6h-832q-66 0 -113 -47t-47 -113v-832 q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v254q0 13 9 22l64 64q10 10 23 10q6 0 12 -3q20 -8 20 -29zM1639 1095l-814 -814q-24 -24 -57 -24t-57 24l-430 430q-24 24 -24 57t24 57l110 110q24 24 57 24t57 -24l263 -263l647 647q24 24 57 24t57 -24l110 -110 q24 -24 24 -57t-24 -57z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-384v-384h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v384h-384v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45 t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h384v384h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45t-19 -45t-45 -19h-128v-384h384v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="1024" d="M979 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1747 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-9 9 -13 19v-678q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-678q4 11 13 19l710 710 q19 19 32 13t13 -32v-710q4 11 13 19z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1619 1395q19 19 32 13t13 -32v-1472q0 -26 -13 -32t-32 13l-710 710q-8 9 -13 19v-710q0 -26 -13 -32t-32 13l-710 710q-19 19 -19 45t19 45l710 710q19 19 32 13t13 -32v-710q5 11 13 19z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1384 609l-1328 -738q-23 -13 -39.5 -3t-16.5 36v1472q0 26 16.5 36t39.5 -3l1328 -738q23 -13 23 -31t-23 -31z" /> +<glyph unicode="" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45zM640 1344v-1408q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h512q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q19 -19 19 -45t-19 -45l-710 -710q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" /> +<glyph unicode="" horiz-adv-x="1792" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v710q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19l-710 -710 q-19 -19 -32 -13t-13 32v710q-5 -10 -13 -19z" /> +<glyph unicode="" horiz-adv-x="1024" d="M45 -115q-19 -19 -32 -13t-13 32v1472q0 26 13 32t32 -13l710 -710q8 -8 13 -19v678q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-1408q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v678q-5 -10 -13 -19z" /> +<glyph unicode="" horiz-adv-x="1538" d="M14 557l710 710q19 19 45 19t45 -19l710 -710q19 -19 13 -32t-32 -13h-1472q-26 0 -32 13t13 32zM1473 0h-1408q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1408q26 0 45 -19t19 -45v-256q0 -26 -19 -45t-45 -19z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1171 1235l-531 -531l531 -531q19 -19 19 -45t-19 -45l-166 -166q-19 -19 -45 -19t-45 19l-742 742q-19 19 -19 45t19 45l742 742q19 19 45 19t45 -19l166 -166q19 -19 19 -45t-19 -45z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1107 659l-742 -742q-19 -19 -45 -19t-45 19l-166 166q-19 19 -19 45t19 45l531 531l-531 531q-19 19 -19 45t19 45l166 166q19 19 45 19t45 -19l742 -742q19 -19 19 -45t-19 -45z" /> +<glyph unicode="" d="M1216 576v128q0 26 -19 45t-45 19h-256v256q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-256h-256q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h256v-256q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v256h256q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5 t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1216 576v128q0 26 -19 45t-45 19h-768q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h768q26 0 45 19t19 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5 t103 -385.5z" /> +<glyph unicode="" d="M1149 414q0 26 -19 45l-181 181l181 181q19 19 19 45q0 27 -19 46l-90 90q-19 19 -46 19q-26 0 -45 -19l-181 -181l-181 181q-19 19 -45 19q-27 0 -46 -19l-90 -90q-19 -19 -19 -46q0 -26 19 -45l181 -181l-181 -181q-19 -19 -19 -45q0 -27 19 -46l90 -90q19 -19 46 -19 q26 0 45 19l181 181l181 -181q19 -19 45 -19q27 0 46 19l90 90q19 19 19 46zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1284 802q0 28 -18 46l-91 90q-19 19 -45 19t-45 -19l-408 -407l-226 226q-19 19 -45 19t-45 -19l-91 -90q-18 -18 -18 -46q0 -27 18 -45l362 -362q19 -19 45 -19q27 0 46 19l543 543q18 18 18 45zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M896 160v192q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h192q14 0 23 9t9 23zM1152 832q0 88 -55.5 163t-138.5 116t-170 41q-243 0 -371 -213q-15 -24 8 -42l132 -100q7 -6 19 -6q16 0 25 12q53 68 86 92q34 24 86 24q48 0 85.5 -26t37.5 -59 q0 -38 -20 -61t-68 -45q-63 -28 -115.5 -86.5t-52.5 -125.5v-36q0 -14 9 -23t23 -9h192q14 0 23 9t9 23q0 19 21.5 49.5t54.5 49.5q32 18 49 28.5t46 35t44.5 48t28 60.5t12.5 81zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1024 160v160q0 14 -9 23t-23 9h-96v512q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h96v-320h-96q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23t23 -9h448q14 0 23 9t9 23zM896 1056v160q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-160q0 -14 9 -23 t23 -9h192q14 0 23 9t9 23zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1197 512h-109q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h109q-32 108 -112.5 188.5t-188.5 112.5v-109q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v109q-108 -32 -188.5 -112.5t-112.5 -188.5h109q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-109 q32 -108 112.5 -188.5t188.5 -112.5v109q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-109q108 32 188.5 112.5t112.5 188.5zM1536 704v-128q0 -26 -19 -45t-45 -19h-143q-37 -161 -154.5 -278.5t-278.5 -154.5v-143q0 -26 -19 -45t-45 -19h-128q-26 0 -45 19t-19 45v143 q-161 37 -278.5 154.5t-154.5 278.5h-143q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h143q37 161 154.5 278.5t278.5 154.5v143q0 26 19 45t45 19h128q26 0 45 -19t19 -45v-143q161 -37 278.5 -154.5t154.5 -278.5h143q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M1097 457l-146 -146q-10 -10 -23 -10t-23 10l-137 137l-137 -137q-10 -10 -23 -10t-23 10l-146 146q-10 10 -10 23t10 23l137 137l-137 137q-10 10 -10 23t10 23l146 146q10 10 23 10t23 -10l137 -137l137 137q10 10 23 10t23 -10l146 -146q10 -10 10 -23t-10 -23 l-137 -137l137 -137q10 -10 10 -23t-10 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5 t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1171 723l-422 -422q-19 -19 -45 -19t-45 19l-294 294q-19 19 -19 45t19 45l102 102q19 19 45 19t45 -19l147 -147l275 275q19 19 45 19t45 -19l102 -102q19 -19 19 -45t-19 -45zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198 t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1312 643q0 161 -87 295l-754 -753q137 -89 297 -89q111 0 211.5 43.5t173.5 116.5t116 174.5t43 212.5zM313 344l755 754q-135 91 -300 91q-148 0 -273 -73t-198 -199t-73 -274q0 -162 89 -299zM1536 643q0 -157 -61 -300t-163.5 -246t-245 -164t-298.5 -61t-298.5 61 t-245 164t-163.5 246t-61 300t61 299.5t163.5 245.5t245 164t298.5 61t298.5 -61t245 -164t163.5 -245.5t61 -299.5z" /> +<glyph unicode="" d="M1536 640v-128q0 -53 -32.5 -90.5t-84.5 -37.5h-704l293 -294q38 -36 38 -90t-38 -90l-75 -76q-37 -37 -90 -37q-52 0 -91 37l-651 652q-37 37 -37 90q0 52 37 91l651 650q38 38 91 38q52 0 90 -38l75 -74q38 -38 38 -91t-38 -91l-293 -293h704q52 0 84.5 -37.5 t32.5 -90.5z" /> +<glyph unicode="" d="M1472 576q0 -54 -37 -91l-651 -651q-39 -37 -91 -37q-51 0 -90 37l-75 75q-38 38 -38 91t38 91l293 293h-704q-52 0 -84.5 37.5t-32.5 90.5v128q0 53 32.5 90.5t84.5 37.5h704l-293 294q-38 36 -38 90t38 90l75 75q38 38 90 38q53 0 91 -38l651 -651q37 -35 37 -90z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1611 565q0 -51 -37 -90l-75 -75q-38 -38 -91 -38q-54 0 -90 38l-294 293v-704q0 -52 -37.5 -84.5t-90.5 -32.5h-128q-53 0 -90.5 32.5t-37.5 84.5v704l-294 -293q-36 -38 -90 -38t-90 38l-75 75q-38 38 -38 90q0 53 38 91l651 651q35 37 90 37q54 0 91 -37l651 -651 q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1611 704q0 -53 -37 -90l-651 -652q-39 -37 -91 -37q-53 0 -90 37l-651 652q-38 36 -38 90q0 53 38 91l74 75q39 37 91 37q53 0 90 -37l294 -294v704q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-704l294 294q37 37 90 37q52 0 91 -37l75 -75q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 896q0 -26 -19 -45l-512 -512q-19 -19 -45 -19t-45 19t-19 45v256h-224q-98 0 -175.5 -6t-154 -21.5t-133 -42.5t-105.5 -69.5t-80 -101t-48.5 -138.5t-17.5 -181q0 -55 5 -123q0 -6 2.5 -23.5t2.5 -26.5q0 -15 -8.5 -25t-23.5 -10q-16 0 -28 17q-7 9 -13 22 t-13.5 30t-10.5 24q-127 285 -127 451q0 199 53 333q162 403 875 403h224v256q0 26 19 45t45 19t45 -19l512 -512q19 -19 19 -45z" /> +<glyph unicode="" d="M755 480q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23zM1536 1344v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332 q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M768 576v-448q0 -26 -19 -45t-45 -19t-45 19l-144 144l-332 -332q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l332 332l-144 144q-19 19 -19 45t19 45t45 19h448q26 0 45 -19t19 -45zM1523 1248q0 -13 -10 -23l-332 -332l144 -144q19 -19 19 -45t-19 -45 t-45 -19h-448q-26 0 -45 19t-19 45v448q0 26 19 45t45 19t45 -19l144 -144l332 332q10 10 23 10t23 -10l114 -114q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-416v-416q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v416h-416q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h416v416q0 40 28 68t68 28h192q40 0 68 -28t28 -68v-416h416q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1408 800v-192q0 -40 -28 -68t-68 -28h-1216q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h1216q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1482 486q46 -26 59.5 -77.5t-12.5 -97.5l-64 -110q-26 -46 -77.5 -59.5t-97.5 12.5l-266 153v-307q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v307l-266 -153q-46 -26 -97.5 -12.5t-77.5 59.5l-64 110q-26 46 -12.5 97.5t59.5 77.5l266 154l-266 154 q-46 26 -59.5 77.5t12.5 97.5l64 110q26 46 77.5 59.5t97.5 -12.5l266 -153v307q0 52 38 90t90 38h128q52 0 90 -38t38 -90v-307l266 153q46 26 97.5 12.5t77.5 -59.5l64 -110q26 -46 12.5 -97.5t-59.5 -77.5l-266 -154z" /> +<glyph unicode="" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM896 161v190q0 14 -9 23.5t-22 9.5h-192q-13 0 -23 -10t-10 -23v-190q0 -13 10 -23t23 -10h192 q13 0 22 9.5t9 23.5zM894 505l18 621q0 12 -10 18q-10 8 -24 8h-220q-14 0 -24 -8q-10 -6 -10 -18l17 -621q0 -10 10 -17.5t24 -7.5h185q14 0 23.5 7.5t10.5 17.5z" /> +<glyph unicode="" d="M928 180v56v468v192h-320v-192v-468v-56q0 -25 18 -38.5t46 -13.5h192q28 0 46 13.5t18 38.5zM472 1024h195l-126 161q-26 31 -69 31q-40 0 -68 -28t-28 -68t28 -68t68 -28zM1160 1120q0 40 -28 68t-68 28q-43 0 -69 -31l-125 -161h194q40 0 68 28t28 68zM1536 864v-320 q0 -14 -9 -23t-23 -9h-96v-416q0 -40 -28 -68t-68 -28h-1088q-40 0 -68 28t-28 68v416h-96q-14 0 -23 9t-9 23v320q0 14 9 23t23 9h440q-93 0 -158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5q107 0 168 -77l128 -165l128 165q61 77 168 77q93 0 158.5 -65.5t65.5 -158.5 t-65.5 -158.5t-158.5 -65.5h440q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1280 832q0 26 -19 45t-45 19q-172 0 -318 -49.5t-259.5 -134t-235.5 -219.5q-19 -21 -19 -45q0 -26 19 -45t45 -19q24 0 45 19q27 24 74 71t67 66q137 124 268.5 176t313.5 52q26 0 45 19t19 45zM1792 1030q0 -95 -20 -193q-46 -224 -184.5 -383t-357.5 -268 q-214 -108 -438 -108q-148 0 -286 47q-15 5 -88 42t-96 37q-16 0 -39.5 -32t-45 -70t-52.5 -70t-60 -32q-30 0 -51 11t-31 24t-27 42q-2 4 -6 11t-5.5 10t-3 9.5t-1.5 13.5q0 35 31 73.5t68 65.5t68 56t31 48q0 4 -14 38t-16 44q-9 51 -9 104q0 115 43.5 220t119 184.5 t170.5 139t204 95.5q55 18 145 25.5t179.5 9t178.5 6t163.5 24t113.5 56.5l29.5 29.5t29.5 28t27 20t36.5 16t43.5 4.5q39 0 70.5 -46t47.5 -112t24 -124t8 -96z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1408 -160v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-1344q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h1344q13 0 22.5 -9.5t9.5 -22.5zM1152 896q0 -78 -24.5 -144t-64 -112.5t-87.5 -88t-96 -77.5t-87.5 -72t-64 -81.5t-24.5 -96.5q0 -96 67 -224l-4 1l1 -1 q-90 41 -160 83t-138.5 100t-113.5 122.5t-72.5 150.5t-27.5 184q0 78 24.5 144t64 112.5t87.5 88t96 77.5t87.5 72t64 81.5t24.5 96.5q0 94 -66 224l3 -1l-1 1q90 -41 160 -83t138.5 -100t113.5 -122.5t72.5 -150.5t27.5 -184z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1664 576q-152 236 -381 353q61 -104 61 -225q0 -185 -131.5 -316.5t-316.5 -131.5t-316.5 131.5t-131.5 316.5q0 121 61 225q-229 -117 -381 -353q133 -205 333.5 -326.5t434.5 -121.5t434.5 121.5t333.5 326.5zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5 t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1792 576q0 -34 -20 -69q-140 -230 -376.5 -368.5t-499.5 -138.5t-499.5 139t-376.5 368q-20 35 -20 69t20 69q140 229 376.5 368t499.5 139t499.5 -139t376.5 -368q20 -35 20 -69z" /> +<glyph unicode="" horiz-adv-x="1792" d="M555 201l78 141q-87 63 -136 159t-49 203q0 121 61 225q-229 -117 -381 -353q167 -258 427 -375zM944 960q0 20 -14 34t-34 14q-125 0 -214.5 -89.5t-89.5 -214.5q0 -20 14 -34t34 -14t34 14t14 34q0 86 61 147t147 61q20 0 34 14t14 34zM1307 1151q0 -7 -1 -9 q-105 -188 -315 -566t-316 -567l-49 -89q-10 -16 -28 -16q-12 0 -134 70q-16 10 -16 28q0 12 44 87q-143 65 -263.5 173t-208.5 245q-20 31 -20 69t20 69q153 235 380 371t496 136q89 0 180 -17l54 97q10 16 28 16q5 0 18 -6t31 -15.5t33 -18.5t31.5 -18.5t19.5 -11.5 q16 -10 16 -27zM1344 704q0 -139 -79 -253.5t-209 -164.5l280 502q8 -45 8 -84zM1792 576q0 -35 -20 -69q-39 -64 -109 -145q-150 -172 -347.5 -267t-419.5 -95l74 132q212 18 392.5 137t301.5 307q-115 179 -282 294l63 112q95 -64 182.5 -153t144.5 -184q20 -34 20 -69z " /> +<glyph unicode="" horiz-adv-x="1792" d="M1024 161v190q0 14 -9.5 23.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -23.5v-190q0 -14 9.5 -23.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 23.5zM1022 535l18 459q0 12 -10 19q-13 11 -24 11h-220q-11 0 -24 -11q-10 -7 -10 -21l17 -457q0 -10 10 -16.5t24 -6.5h185 q14 0 23.5 6.5t10.5 16.5zM1008 1469l768 -1408q35 -63 -2 -126q-17 -29 -46.5 -46t-63.5 -17h-1536q-34 0 -63.5 17t-46.5 46q-37 63 -2 126l768 1408q17 31 47 49t65 18t65 -18t47 -49z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1376 1376q44 -52 12 -148t-108 -172l-161 -161l160 -696q5 -19 -12 -33l-128 -96q-7 -6 -19 -6q-4 0 -7 1q-15 3 -21 16l-279 508l-259 -259l53 -194q5 -17 -8 -31l-96 -96q-9 -9 -23 -9h-2q-15 2 -24 13l-189 252l-252 189q-11 7 -13 23q-1 13 9 25l96 97q9 9 23 9 q6 0 8 -1l194 -53l259 259l-508 279q-14 8 -17 24q-2 16 9 27l128 128q14 13 30 8l665 -159l160 160q76 76 172 108t148 -12z" /> +<glyph unicode="" horiz-adv-x="1664" d="M128 -128h288v288h-288v-288zM480 -128h320v288h-320v-288zM128 224h288v320h-288v-320zM480 224h320v320h-320v-320zM128 608h288v288h-288v-288zM864 -128h320v288h-320v-288zM480 608h320v288h-320v-288zM1248 -128h288v288h-288v-288zM864 224h320v320h-320v-320z M512 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1248 224h288v320h-288v-320zM864 608h320v288h-320v-288zM1248 608h288v288h-288v-288zM1280 1088v288q0 13 -9.5 22.5t-22.5 9.5h-64 q-13 0 -22.5 -9.5t-9.5 -22.5v-288q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1664 1152v-1280q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47 h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="1792" d="M666 1055q-60 -92 -137 -273q-22 45 -37 72.5t-40.5 63.5t-51 56.5t-63 35t-81.5 14.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q250 0 410 -225zM1792 256q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192q-32 0 -85 -0.5t-81 -1t-73 1 t-71 5t-64 10.5t-63 18.5t-58 28.5t-59 40t-55 53.5t-56 69.5q59 93 136 273q22 -45 37 -72.5t40.5 -63.5t51 -56.5t63 -35t81.5 -14.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1792 1152q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5 v192h-256q-48 0 -87 -15t-69 -45t-51 -61.5t-45 -77.5q-32 -62 -78 -171q-29 -66 -49.5 -111t-54 -105t-64 -100t-74 -83t-90 -68.5t-106.5 -42t-128 -16.5h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224q48 0 87 15t69 45t51 61.5t45 77.5q32 62 78 171q29 66 49.5 111 t54 105t64 100t74 83t90 68.5t106.5 42t128 16.5h256v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 640q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22q-17 -2 -30.5 9t-17.5 29v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281 q0 130 71 248.5t191 204.5t286 136.5t348 50.5q244 0 450 -85.5t326 -233t120 -321.5z" /> +<glyph unicode="" d="M1536 704v-128q0 -201 -98.5 -362t-274 -251.5t-395.5 -90.5t-395.5 90.5t-274 251.5t-98.5 362v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-128q0 -52 23.5 -90t53.5 -57t71 -30t64 -13t44 -2t44 2t64 13t71 30t53.5 57t23.5 90v128q0 26 19 45t45 19h384 q26 0 45 -19t19 -45zM512 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45zM1536 1344v-384q0 -26 -19 -45t-45 -19h-384q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h384q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1683 205l-166 -165q-19 -19 -45 -19t-45 19l-531 531l-531 -531q-19 -19 -45 -19t-45 19l-166 165q-19 19 -19 45.5t19 45.5l742 741q19 19 45 19t45 -19l742 -741q19 -19 19 -45.5t-19 -45.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1683 728l-742 -741q-19 -19 -45 -19t-45 19l-742 741q-19 19 -19 45.5t19 45.5l166 165q19 19 45 19t45 -19l531 -531l531 531q19 19 45 19t45 -19l166 -165q19 -19 19 -45.5t-19 -45.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1280 32q0 -13 -9.5 -22.5t-22.5 -9.5h-960q-8 0 -13.5 2t-9 7t-5.5 8t-3 11.5t-1 11.5v13v11v160v416h-192q-26 0 -45 19t-19 45q0 24 15 41l320 384q19 22 49 22t49 -22l320 -384q15 -17 15 -41q0 -26 -19 -45t-45 -19h-192v-384h576q16 0 25 -11l160 -192q7 -11 7 -21 zM1920 448q0 -24 -15 -41l-320 -384q-20 -23 -49 -23t-49 23l-320 384q-15 17 -15 41q0 26 19 45t45 19h192v384h-576q-16 0 -25 12l-160 192q-7 9 -7 20q0 13 9.5 22.5t22.5 9.5h960q8 0 13.5 -2t9 -7t5.5 -8t3 -11.5t1 -11.5v-13v-11v-160v-416h192q26 0 45 -19t19 -45z " /> +<glyph unicode="" horiz-adv-x="1664" d="M640 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1536 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1664 1088v-512q0 -24 -16 -42.5t-41 -21.5 l-1044 -122q1 -7 4.5 -21.5t6 -26.5t2.5 -22q0 -16 -24 -64h920q26 0 45 -19t19 -45t-19 -45t-45 -19h-1024q-26 0 -45 19t-19 45q0 14 11 39.5t29.5 59.5t20.5 38l-177 823h-204q-26 0 -45 19t-19 45t19 45t45 19h256q16 0 28.5 -6.5t20 -15.5t13 -24.5t7.5 -26.5 t5.5 -29.5t4.5 -25.5h1201q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1879 584q0 -31 -31 -66l-336 -396q-43 -51 -120.5 -86.5t-143.5 -35.5h-1088q-34 0 -60.5 13t-26.5 43q0 31 31 66l336 396q43 51 120.5 86.5t143.5 35.5h1088q34 0 60.5 -13t26.5 -43zM1536 928v-160h-832q-94 0 -197 -47.5t-164 -119.5l-337 -396l-5 -6q0 4 -0.5 12.5 t-0.5 12.5v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158z" /> +<glyph unicode="" horiz-adv-x="768" d="M704 1216q0 -26 -19 -45t-45 -19h-128v-1024h128q26 0 45 -19t19 -45t-19 -45l-256 -256q-19 -19 -45 -19t-45 19l-256 256q-19 19 -19 45t19 45t45 19h128v1024h-128q-26 0 -45 19t-19 45t19 45l256 256q19 19 45 19t45 -19l256 -256q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 640q0 -26 -19 -45l-256 -256q-19 -19 -45 -19t-45 19t-19 45v128h-1024v-128q0 -26 -19 -45t-45 -19t-45 19l-256 256q-19 19 -19 45t19 45l256 256q19 19 45 19t45 -19t19 -45v-128h1024v128q0 26 19 45t45 19t45 -19l256 -256q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="2048" d="M640 640v-512h-256v512h256zM1024 1152v-1024h-256v1024h256zM2048 0v-128h-2048v1536h128v-1408h1920zM1408 896v-768h-256v768h256zM1792 1280v-1152h-256v1152h256z" /> +<glyph unicode="" d="M1280 926q-56 -25 -121 -34q68 40 93 117q-65 -38 -134 -51q-61 66 -153 66q-87 0 -148.5 -61.5t-61.5 -148.5q0 -29 5 -48q-129 7 -242 65t-192 155q-29 -50 -29 -106q0 -114 91 -175q-47 1 -100 26v-2q0 -75 50 -133.5t123 -72.5q-29 -8 -51 -8q-13 0 -39 4 q21 -63 74.5 -104t121.5 -42q-116 -90 -261 -90q-26 0 -50 3q148 -94 322 -94q112 0 210 35.5t168 95t120.5 137t75 162t24.5 168.5q0 18 -1 27q63 45 105 109zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5 t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1536 160q0 -119 -84.5 -203.5t-203.5 -84.5h-192v608h203l30 224h-233v143q0 54 28 83t96 29l132 1v207q-96 9 -180 9q-136 0 -218 -80.5t-82 -225.5v-166h-224v-224h224v-608h-544q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960 q119 0 203.5 -84.5t84.5 -203.5v-960z" /> +<glyph unicode="" horiz-adv-x="1792" d="M928 704q0 14 -9 23t-23 9q-66 0 -113 -47t-47 -113q0 -14 9 -23t23 -9t23 9t9 23q0 40 28 68t68 28q14 0 23 9t9 23zM1152 574q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM128 0h1536v128h-1536v-128zM1280 574q0 159 -112.5 271.5 t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM256 1216h384v128h-384v-128zM128 1024h1536v118v138h-828l-64 -128h-644v-128zM1792 1280v-1280q0 -53 -37.5 -90.5t-90.5 -37.5h-1536q-53 0 -90.5 37.5t-37.5 90.5v1280 q0 53 37.5 90.5t90.5 37.5h1536q53 0 90.5 -37.5t37.5 -90.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M832 1024q0 80 -56 136t-136 56t-136 -56t-56 -136q0 -42 19 -83q-41 19 -83 19q-80 0 -136 -56t-56 -136t56 -136t136 -56t136 56t56 136q0 42 -19 83q41 -19 83 -19q80 0 136 56t56 136zM1683 320q0 -17 -49 -66t-66 -49q-9 0 -28.5 16t-36.5 33t-38.5 40t-24.5 26 l-96 -96l220 -220q28 -28 28 -68q0 -42 -39 -81t-81 -39q-40 0 -68 28l-671 671q-176 -131 -365 -131q-163 0 -265.5 102.5t-102.5 265.5q0 160 95 313t248 248t313 95q163 0 265.5 -102.5t102.5 -265.5q0 -189 -131 -365l355 -355l96 96q-3 3 -26 24.5t-40 38.5t-33 36.5 t-16 28.5q0 17 49 66t66 49q13 0 23 -10q6 -6 46 -44.5t82 -79.5t86.5 -86t73 -78t28.5 -41z" /> +<glyph unicode="" horiz-adv-x="1920" d="M896 640q0 106 -75 181t-181 75t-181 -75t-75 -181t75 -181t181 -75t181 75t75 181zM1664 128q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 1152q0 52 -38 90t-90 38t-90 -38t-38 -90q0 -53 37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1280 731v-185q0 -10 -7 -19.5t-16 -10.5l-155 -24q-11 -35 -32 -76q34 -48 90 -115q7 -10 7 -20q0 -12 -7 -19q-23 -30 -82.5 -89.5t-78.5 -59.5q-11 0 -21 7l-115 90q-37 -19 -77 -31q-11 -108 -23 -155q-7 -24 -30 -24h-186q-11 0 -20 7.5t-10 17.5 l-23 153q-34 10 -75 31l-118 -89q-7 -7 -20 -7q-11 0 -21 8q-144 133 -144 160q0 9 7 19q10 14 41 53t47 61q-23 44 -35 82l-152 24q-10 1 -17 9.5t-7 19.5v185q0 10 7 19.5t16 10.5l155 24q11 35 32 76q-34 48 -90 115q-7 11 -7 20q0 12 7 20q22 30 82 89t79 59q11 0 21 -7 l115 -90q34 18 77 32q11 108 23 154q7 24 30 24h186q11 0 20 -7.5t10 -17.5l23 -153q34 -10 75 -31l118 89q8 7 20 7q11 0 21 -8q144 -133 144 -160q0 -9 -7 -19q-12 -16 -42 -54t-45 -60q23 -48 34 -82l152 -23q10 -2 17 -10.5t7 -19.5zM1920 198v-140q0 -16 -149 -31 q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20 t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31zM1920 1222v-140q0 -16 -149 -31q-12 -27 -30 -52q51 -113 51 -138q0 -4 -4 -7q-122 -71 -124 -71q-8 0 -46 47t-52 68 q-20 -2 -30 -2t-30 2q-14 -21 -52 -68t-46 -47q-2 0 -124 71q-4 3 -4 7q0 25 51 138q-18 25 -30 52q-149 15 -149 31v140q0 16 149 31q13 29 30 52q-51 113 -51 138q0 4 4 7q4 2 35 20t59 34t30 16q8 0 46 -46.5t52 -67.5q20 2 30 2t30 -2q51 71 92 112l6 2q4 0 124 -70 q4 -3 4 -7q0 -25 -51 -138q17 -23 30 -52q149 -15 149 -31z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1408 768q0 -139 -94 -257t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224 q0 139 94 257t256.5 186.5t353.5 68.5t353.5 -68.5t256.5 -186.5t94 -257zM1792 512q0 -120 -71 -224.5t-195 -176.5q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7 q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230z" /> +<glyph unicode="" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 768q0 51 -39 89.5t-89 38.5h-352q0 58 48 159.5t48 160.5q0 98 -32 145t-128 47q-26 -26 -38 -85t-30.5 -125.5t-59.5 -109.5q-22 -23 -77 -91q-4 -5 -23 -30t-31.5 -41t-34.5 -42.5 t-40 -44t-38.5 -35.5t-40 -27t-35.5 -9h-32v-640h32q13 0 31.5 -3t33 -6.5t38 -11t35 -11.5t35.5 -12.5t29 -10.5q211 -73 342 -73h121q192 0 192 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5q32 1 53.5 47t21.5 81zM1536 769 q0 -89 -49 -163q9 -33 9 -69q0 -77 -38 -144q3 -21 3 -43q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5h-36h-93q-96 0 -189.5 22.5t-216.5 65.5q-116 40 -138 40h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h274q36 24 137 155q58 75 107 128 q24 25 35.5 85.5t30.5 126.5t62 108q39 37 90 37q84 0 151 -32.5t102 -101.5t35 -186q0 -93 -48 -192h176q104 0 180 -76t76 -179z" /> +<glyph unicode="" d="M256 1088q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 512q0 35 -21.5 81t-53.5 47q15 17 25 47.5t10 55.5q0 69 -53 119q18 32 18 69t-17.5 73.5t-47.5 52.5q5 30 5 56q0 85 -49 126t-136 41h-128q-131 0 -342 -73q-5 -2 -29 -10.5 t-35.5 -12.5t-35 -11.5t-38 -11t-33 -6.5t-31.5 -3h-32v-640h32q16 0 35.5 -9t40 -27t38.5 -35.5t40 -44t34.5 -42.5t31.5 -41t23 -30q55 -68 77 -91q41 -43 59.5 -109.5t30.5 -125.5t38 -85q96 0 128 47t32 145q0 59 -48 160.5t-48 159.5h352q50 0 89 38.5t39 89.5z M1536 511q0 -103 -76 -179t-180 -76h-176q48 -99 48 -192q0 -118 -35 -186q-35 -69 -102 -101.5t-151 -32.5q-51 0 -90 37q-34 33 -54 82t-25.5 90.5t-17.5 84.5t-31 64q-48 50 -107 127q-101 131 -137 155h-274q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5 h288q22 0 138 40q128 44 223 66t200 22h112q140 0 226.5 -79t85.5 -216v-5q60 -77 60 -178q0 -22 -3 -43q38 -67 38 -144q0 -36 -9 -69q49 -74 49 -163z" /> +<glyph unicode="" horiz-adv-x="896" d="M832 1504v-1339l-449 -236q-22 -12 -40 -12q-21 0 -31.5 14.5t-10.5 35.5q0 6 2 20l86 500l-364 354q-25 27 -25 48q0 37 56 46l502 73l225 455q19 41 49 41z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1664 940q0 81 -21.5 143t-55 98.5t-81.5 59.5t-94 31t-98 8t-112 -25.5t-110.5 -64t-86.5 -72t-60 -61.5q-18 -22 -49 -22t-49 22q-24 28 -60 61.5t-86.5 72t-110.5 64t-112 25.5t-98 -8t-94 -31t-81.5 -59.5t-55 -98.5t-21.5 -143q0 -168 187 -355l581 -560l580 559 q188 188 188 356zM1792 940q0 -221 -229 -450l-623 -600q-18 -18 -44 -18t-44 18l-624 602q-10 8 -27.5 26t-55.5 65.5t-68 97.5t-53.5 121t-23.5 138q0 220 127 344t351 124q62 0 126.5 -21.5t120 -58t95.5 -68.5t76 -68q36 36 76 68t95.5 68.5t120 58t126.5 21.5 q224 0 351 -124t127 -344z" /> +<glyph unicode="" horiz-adv-x="1664" d="M640 96q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-119 0 -203.5 84.5t-84.5 203.5v704q0 119 84.5 203.5t203.5 84.5h320q13 0 22.5 -9.5t9.5 -22.5q0 -4 1 -20t0.5 -26.5t-3 -23.5t-10 -19.5t-20.5 -6.5h-320q-66 0 -113 -47t-47 -113v-704 q0 -66 47 -113t113 -47h288h11h13t11.5 -1t11.5 -3t8 -5.5t7 -9t2 -13.5zM1568 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45z" /> +<glyph unicode="" d="M237 122h231v694h-231v-694zM483 1030q-1 52 -36 86t-93 34t-94.5 -34t-36.5 -86q0 -51 35.5 -85.5t92.5 -34.5h1q59 0 95 34.5t36 85.5zM1068 122h231v398q0 154 -73 233t-193 79q-136 0 -209 -117h2v101h-231q3 -66 0 -694h231v388q0 38 7 56q15 35 45 59.5t74 24.5 q116 0 116 -157v-371zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1152" d="M480 672v448q0 14 -9 23t-23 9t-23 -9t-9 -23v-448q0 -14 9 -23t23 -9t23 9t9 23zM1152 320q0 -26 -19 -45t-45 -19h-429l-51 -483q-2 -12 -10.5 -20.5t-20.5 -8.5h-1q-27 0 -32 27l-76 485h-404q-26 0 -45 19t-19 45q0 123 78.5 221.5t177.5 98.5v512q-52 0 -90 38 t-38 90t38 90t90 38h640q52 0 90 -38t38 -90t-38 -90t-90 -38v-512q99 0 177.5 -98.5t78.5 -221.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1408 608v-320q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h704q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v320 q0 14 9 23t23 9h64q14 0 23 -9t9 -23zM1792 1472v-512q0 -26 -19 -45t-45 -19t-45 19l-176 176l-652 -652q-10 -10 -23 -10t-23 10l-114 114q-10 10 -10 23t10 23l652 652l-176 176q-19 19 -19 45t19 45t45 19h512q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M1184 640q0 -26 -19 -45l-544 -544q-19 -19 -45 -19t-45 19t-19 45v288h-448q-26 0 -45 19t-19 45v384q0 26 19 45t45 19h448v288q0 26 19 45t45 19t45 -19l544 -544q19 -19 19 -45zM1536 992v-704q0 -119 -84.5 -203.5t-203.5 -84.5h-320q-13 0 -22.5 9.5t-9.5 22.5 q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q66 0 113 47t47 113v704q0 66 -47 113t-113 47h-288h-11h-13t-11.5 1t-11.5 3t-8 5.5t-7 9t-2 13.5q0 4 -1 20t-0.5 26.5t3 23.5t10 19.5t20.5 6.5h320q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M458 653q-74 162 -74 371h-256v-96q0 -78 94.5 -162t235.5 -113zM1536 928v96h-256q0 -209 -74 -371q141 29 235.5 113t94.5 162zM1664 1056v-128q0 -71 -41.5 -143t-112 -130t-173 -97.5t-215.5 -44.5q-42 -54 -95 -95q-38 -34 -52.5 -72.5t-14.5 -89.5q0 -54 30.5 -91 t97.5 -37q75 0 133.5 -45.5t58.5 -114.5v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 69 58.5 114.5t133.5 45.5q67 0 97.5 37t30.5 91q0 51 -14.5 89.5t-52.5 72.5q-53 41 -95 95q-113 5 -215.5 44.5t-173 97.5t-112 130t-41.5 143v128q0 40 28 68t68 28h288v96 q0 66 47 113t113 47h576q66 0 113 -47t47 -113v-96h288q40 0 68 -28t28 -68z" /> +<glyph unicode="" d="M394 184q-8 -9 -20 3q-13 11 -4 19q8 9 20 -3q12 -11 4 -19zM352 245q9 -12 0 -19q-8 -6 -17 7t0 18q9 7 17 -6zM291 305q-5 -7 -13 -2q-10 5 -7 12q3 5 13 2q10 -5 7 -12zM322 271q-6 -7 -16 3q-9 11 -2 16q6 6 16 -3q9 -11 2 -16zM451 159q-4 -12 -19 -6q-17 4 -13 15 t19 7q16 -5 13 -16zM514 154q0 -11 -16 -11q-17 -2 -17 11q0 11 16 11q17 2 17 -11zM572 164q2 -10 -14 -14t-18 8t14 15q16 2 18 -9zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-224q-16 0 -24.5 1t-19.5 5t-16 14.5t-5 27.5v239q0 97 -52 142q57 6 102.5 18t94 39 t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103 q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -103t0.5 -68q0 -22 -11 -33.5t-22 -13t-33 -1.5 h-224q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1280 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 288v-320q0 -40 -28 -68t-68 -28h-1472q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h427q21 -56 70.5 -92 t110.5 -36h256q61 0 110.5 36t70.5 92h427q40 0 68 -28t28 -68zM1339 936q-17 -40 -59 -40h-256v-448q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v448h-256q-42 0 -59 40q-17 39 14 69l448 448q18 19 45 19t45 -19l448 -448q31 -30 14 -69z" /> +<glyph unicode="" d="M1407 710q0 44 -7 113.5t-18 96.5q-12 30 -17 44t-9 36.5t-4 48.5q0 23 5 68.5t5 67.5q0 37 -10 55q-4 1 -13 1q-19 0 -58 -4.5t-59 -4.5q-60 0 -176 24t-175 24q-43 0 -94.5 -11.5t-85 -23.5t-89.5 -34q-137 -54 -202 -103q-96 -73 -159.5 -189.5t-88 -236t-24.5 -248.5 q0 -40 12.5 -120t12.5 -121q0 -23 -11 -66.5t-11 -65.5t12 -36.5t34 -14.5q24 0 72.5 11t73.5 11q57 0 169.5 -15.5t169.5 -15.5q181 0 284 36q129 45 235.5 152.5t166 245.5t59.5 275zM1535 712q0 -165 -70 -327.5t-196 -288t-281 -180.5q-124 -44 -326 -44 q-57 0 -170 14.5t-169 14.5q-24 0 -72.5 -14.5t-73.5 -14.5q-73 0 -123.5 55.5t-50.5 128.5q0 24 11 68t11 67q0 40 -12.5 120.5t-12.5 121.5q0 111 18 217.5t54.5 209.5t100.5 194t150 156q78 59 232 120q194 78 316 78q60 0 175.5 -24t173.5 -24q19 0 57 5t58 5 q81 0 118 -50.5t37 -134.5q0 -23 -5 -68t-5 -68q0 -10 1 -18.5t3 -17t4 -13.5t6.5 -16t6.5 -17q16 -40 25 -118.5t9 -136.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1408 296q0 -27 -10 -70.5t-21 -68.5q-21 -50 -122 -106q-94 -51 -186 -51q-27 0 -52.5 3.5t-57.5 12.5t-47.5 14.5t-55.5 20.5t-49 18q-98 35 -175 83q-128 79 -264.5 215.5t-215.5 264.5q-48 77 -83 175q-3 9 -18 49t-20.5 55.5t-14.5 47.5t-12.5 57.5t-3.5 52.5 q0 92 51 186q56 101 106 122q25 11 68.5 21t70.5 10q14 0 21 -3q18 -6 53 -76q11 -19 30 -54t35 -63.5t31 -53.5q3 -4 17.5 -25t21.5 -35.5t7 -28.5q0 -20 -28.5 -50t-62 -55t-62 -53t-28.5 -46q0 -9 5 -22.5t8.5 -20.5t14 -24t11.5 -19q76 -137 174 -235t235 -174 q2 -1 19 -11.5t24 -14t20.5 -8.5t22.5 -5q18 0 46 28.5t53 62t55 62t50 28.5q14 0 28.5 -7t35.5 -21.5t25 -17.5q25 -15 53.5 -31t63.5 -35t54 -30q70 -35 76 -53q3 -7 3 -21z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1120 1280h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113v832q0 66 -47 113t-113 47zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832 q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1152 1280h-1024v-1242l423 406l89 85l89 -85l423 -406v1242zM1164 1408q23 0 44 -9q33 -13 52.5 -41t19.5 -62v-1289q0 -34 -19.5 -62t-52.5 -41q-19 -8 -44 -8q-48 0 -83 32l-441 424l-441 -424q-36 -33 -83 -33q-23 0 -44 9q-33 13 -52.5 41t-19.5 62v1289 q0 34 19.5 62t52.5 41q21 9 44 9h1048z" /> +<glyph unicode="" d="M1280 343q0 11 -2 16q-3 8 -38.5 29.5t-88.5 49.5l-53 29q-5 3 -19 13t-25 15t-21 5q-18 0 -47 -32.5t-57 -65.5t-44 -33q-7 0 -16.5 3.5t-15.5 6.5t-17 9.5t-14 8.5q-99 55 -170.5 126.5t-126.5 170.5q-2 3 -8.5 14t-9.5 17t-6.5 15.5t-3.5 16.5q0 13 20.5 33.5t45 38.5 t45 39.5t20.5 36.5q0 10 -5 21t-15 25t-13 19q-3 6 -15 28.5t-25 45.5t-26.5 47.5t-25 40.5t-16.5 18t-16 2q-48 0 -101 -22q-46 -21 -80 -94.5t-34 -130.5q0 -16 2.5 -34t5 -30.5t9 -33t10 -29.5t12.5 -33t11 -30q60 -164 216.5 -320.5t320.5 -216.5q6 -2 30 -11t33 -12.5 t29.5 -10t33 -9t30.5 -5t34 -2.5q57 0 130.5 34t94.5 80q22 53 22 101zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1620 1128q-67 -98 -162 -167q1 -14 1 -42q0 -130 -38 -259.5t-115.5 -248.5t-184.5 -210.5t-258 -146t-323 -54.5q-271 0 -496 145q35 -4 78 -4q225 0 401 138q-105 2 -188 64.5t-114 159.5q33 -5 61 -5q43 0 85 11q-112 23 -185.5 111.5t-73.5 205.5v4q68 -38 146 -41 q-66 44 -105 115t-39 154q0 88 44 163q121 -149 294.5 -238.5t371.5 -99.5q-8 38 -8 74q0 134 94.5 228.5t228.5 94.5q140 0 236 -102q109 21 205 78q-37 -115 -142 -178q93 10 186 50z" /> +<glyph unicode="" horiz-adv-x="1024" d="M959 1524v-264h-157q-86 0 -116 -36t-30 -108v-189h293l-39 -296h-254v-759h-306v759h-255v296h255v218q0 186 104 288.5t277 102.5q147 0 228 -12z" /> +<glyph unicode="" d="M1536 640q0 -251 -146.5 -451.5t-378.5 -277.5q-27 -5 -39.5 7t-12.5 30v211q0 97 -52 142q57 6 102.5 18t94 39t81 66.5t53 105t20.5 150.5q0 121 -79 206q37 91 -8 204q-28 9 -81 -11t-92 -44l-38 -24q-93 26 -192 26t-192 -26q-16 11 -42.5 27t-83.5 38.5t-86 13.5 q-44 -113 -7 -204q-79 -85 -79 -206q0 -85 20.5 -150t52.5 -105t80.5 -67t94 -39t102.5 -18q-40 -36 -49 -103q-21 -10 -45 -15t-57 -5t-65.5 21.5t-55.5 62.5q-19 32 -48.5 52t-49.5 24l-20 3q-21 0 -29 -4.5t-5 -11.5t9 -14t13 -12l7 -5q22 -10 43.5 -38t31.5 -51l10 -23 q13 -38 44 -61.5t67 -30t69.5 -7t55.5 3.5l23 4q0 -38 0.5 -89t0.5 -54q0 -18 -13 -30t-40 -7q-232 77 -378.5 277.5t-146.5 451.5q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1664 960v-256q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45v256q0 106 -75 181t-181 75t-181 -75t-75 -181v-192h96q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h672v192q0 185 131.5 316.5t316.5 131.5 t316.5 -131.5t131.5 -316.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1760 1408q66 0 113 -47t47 -113v-1216q0 -66 -47 -113t-113 -47h-1600q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1600zM160 1280q-13 0 -22.5 -9.5t-9.5 -22.5v-224h1664v224q0 13 -9.5 22.5t-22.5 9.5h-1600zM1760 0q13 0 22.5 9.5t9.5 22.5v608h-1664v-608 q0 -13 9.5 -22.5t22.5 -9.5h1600zM256 128v128h256v-128h-256zM640 128v128h384v-128h-384z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 192q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM896 69q2 -28 -17 -48q-18 -21 -47 -21h-135q-25 0 -43 16.5t-20 41.5q-22 229 -184.5 391.5t-391.5 184.5q-25 2 -41.5 20t-16.5 43v135q0 29 21 47q17 17 43 17h5q160 -13 306 -80.5 t259 -181.5q114 -113 181.5 -259t80.5 -306zM1408 67q2 -27 -18 -47q-18 -20 -46 -20h-143q-26 0 -44.5 17.5t-19.5 42.5q-12 215 -101 408.5t-231.5 336t-336 231.5t-408.5 102q-25 1 -42.5 19.5t-17.5 43.5v143q0 28 20 46q18 18 44 18h3q262 -13 501.5 -120t425.5 -294 q187 -186 294 -425.5t120 -501.5z" /> +<glyph unicode="" d="M1040 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1296 320q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5zM1408 160v320q0 13 -9.5 22.5t-22.5 9.5 h-1216q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h1216q13 0 22.5 9.5t9.5 22.5zM178 640h1180l-157 482q-4 13 -16 21.5t-26 8.5h-782q-14 0 -26 -8.5t-16 -21.5zM1536 480v-320q0 -66 -47 -113t-113 -47h-1216q-66 0 -113 47t-47 113v320q0 25 16 75 l197 606q17 53 63 86t101 33h782q55 0 101 -33t63 -86l197 -606q16 -50 16 -75z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1664 896q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5v-384q0 -52 -38 -90t-90 -38q-417 347 -812 380q-58 -19 -91 -66t-31 -100.5t40 -92.5q-20 -33 -23 -65.5t6 -58t33.5 -55t48 -50t61.5 -50.5q-29 -58 -111.5 -83t-168.5 -11.5t-132 55.5q-7 23 -29.5 87.5 t-32 94.5t-23 89t-15 101t3.5 98.5t22 110.5h-122q-66 0 -113 47t-47 113v192q0 66 47 113t113 47h480q435 0 896 384q52 0 90 -38t38 -90v-384zM1536 292v954q-394 -302 -768 -343v-270q377 -42 768 -341z" /> +<glyph unicode="" horiz-adv-x="1792" d="M912 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM246 128h1300q-266 300 -266 832q0 51 -24 105t-69 103t-121.5 80.5t-169.5 31.5t-169.5 -31.5t-121.5 -80.5t-69 -103t-24 -105q0 -532 -266 -832z M1728 128q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q50 42 91 88t85 119.5t74.5 158.5t50 206t19.5 260q0 152 117 282.5t307 158.5q-8 19 -8 39q0 40 28 68t68 28t68 -28t28 -68q0 -20 -8 -39q190 -28 307 -158.5 t117 -282.5q0 -139 19.5 -260t50 -206t74.5 -158.5t85 -119.5t91 -88z" /> +<glyph unicode="" d="M1376 640l138 -135q30 -28 20 -70q-12 -41 -52 -51l-188 -48l53 -186q12 -41 -19 -70q-29 -31 -70 -19l-186 53l-48 -188q-10 -40 -51 -52q-12 -2 -19 -2q-31 0 -51 22l-135 138l-135 -138q-28 -30 -70 -20q-41 11 -51 52l-48 188l-186 -53q-41 -12 -70 19q-31 29 -19 70 l53 186l-188 48q-40 10 -52 51q-10 42 20 70l138 135l-138 135q-30 28 -20 70q12 41 52 51l188 48l-53 186q-12 41 19 70q29 31 70 19l186 -53l48 188q10 41 51 51q41 12 70 -19l135 -139l135 139q29 30 70 19q41 -10 51 -51l48 -188l186 53q41 12 70 -19q31 -29 19 -70 l-53 -186l188 -48q40 -10 52 -51q10 -42 -20 -70z" /> +<glyph unicode="" horiz-adv-x="1792" d="M256 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1664 768q0 51 -39 89.5t-89 38.5h-576q0 20 15 48.5t33 55t33 68t15 84.5q0 67 -44.5 97.5t-115.5 30.5q-24 0 -90 -139q-24 -44 -37 -65q-40 -64 -112 -145q-71 -81 -101 -106 q-69 -57 -140 -57h-32v-640h32q72 0 167 -32t193.5 -64t179.5 -32q189 0 189 167q0 26 -5 56q30 16 47.5 52.5t17.5 73.5t-18 69q53 50 53 119q0 25 -10 55.5t-25 47.5h331q52 0 90 38t38 90zM1792 769q0 -105 -75.5 -181t-180.5 -76h-169q-4 -62 -37 -119q3 -21 3 -43 q0 -101 -60 -178q1 -139 -85 -219.5t-227 -80.5q-133 0 -322 69q-164 59 -223 59h-288q-53 0 -90.5 37.5t-37.5 90.5v640q0 53 37.5 90.5t90.5 37.5h288q10 0 21.5 4.5t23.5 14t22.5 18t24 22.5t20.5 21.5t19 21.5t14 17q65 74 100 129q13 21 33 62t37 72t40.5 63t55 49.5 t69.5 17.5q125 0 206.5 -67t81.5 -189q0 -68 -22 -128h374q104 0 180 -76t76 -179z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1376 128h32v640h-32q-35 0 -67.5 12t-62.5 37t-50 46t-49 54q-2 3 -3.5 4.5t-4 4.5t-4.5 5q-72 81 -112 145q-14 22 -38 68q-1 3 -10.5 22.5t-18.5 36t-20 35.5t-21.5 30.5t-18.5 11.5q-71 0 -115.5 -30.5t-44.5 -97.5q0 -43 15 -84.5t33 -68t33 -55t15 -48.5h-576 q-50 0 -89 -38.5t-39 -89.5q0 -52 38 -90t90 -38h331q-15 -17 -25 -47.5t-10 -55.5q0 -69 53 -119q-18 -32 -18 -69t17.5 -73.5t47.5 -52.5q-4 -24 -4 -56q0 -85 48.5 -126t135.5 -41q84 0 183 32t194 64t167 32zM1664 192q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45 t45 -19t45 19t19 45zM1792 768v-640q0 -53 -37.5 -90.5t-90.5 -37.5h-288q-59 0 -223 -59q-190 -69 -317 -69q-142 0 -230 77.5t-87 217.5l1 5q-61 76 -61 178q0 22 3 43q-33 57 -37 119h-169q-105 0 -180.5 76t-75.5 181q0 103 76 179t180 76h374q-22 60 -22 128 q0 122 81.5 189t206.5 67q38 0 69.5 -17.5t55 -49.5t40.5 -63t37 -72t33 -62q35 -55 100 -129q2 -3 14 -17t19 -21.5t20.5 -21.5t24 -22.5t22.5 -18t23.5 -14t21.5 -4.5h288q53 0 90.5 -37.5t37.5 -90.5z" /> +<glyph unicode="" d="M1280 -64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 700q0 189 -167 189q-26 0 -56 -5q-16 30 -52.5 47.5t-73.5 17.5t-69 -18q-50 53 -119 53q-25 0 -55.5 -10t-47.5 -25v331q0 52 -38 90t-90 38q-51 0 -89.5 -39t-38.5 -89v-576 q-20 0 -48.5 15t-55 33t-68 33t-84.5 15q-67 0 -97.5 -44.5t-30.5 -115.5q0 -24 139 -90q44 -24 65 -37q64 -40 145 -112q81 -71 106 -101q57 -69 57 -140v-32h640v32q0 72 32 167t64 193.5t32 179.5zM1536 705q0 -133 -69 -322q-59 -164 -59 -223v-288q0 -53 -37.5 -90.5 t-90.5 -37.5h-640q-53 0 -90.5 37.5t-37.5 90.5v288q0 10 -4.5 21.5t-14 23.5t-18 22.5t-22.5 24t-21.5 20.5t-21.5 19t-17 14q-74 65 -129 100q-21 13 -62 33t-72 37t-63 40.5t-49.5 55t-17.5 69.5q0 125 67 206.5t189 81.5q68 0 128 -22v374q0 104 76 180t179 76 q105 0 181 -75.5t76 -180.5v-169q62 -4 119 -37q21 3 43 3q101 0 178 -60q139 1 219.5 -85t80.5 -227z" /> +<glyph unicode="" d="M1408 576q0 84 -32 183t-64 194t-32 167v32h-640v-32q0 -35 -12 -67.5t-37 -62.5t-46 -50t-54 -49q-9 -8 -14 -12q-81 -72 -145 -112q-22 -14 -68 -38q-3 -1 -22.5 -10.5t-36 -18.5t-35.5 -20t-30.5 -21.5t-11.5 -18.5q0 -71 30.5 -115.5t97.5 -44.5q43 0 84.5 15t68 33 t55 33t48.5 15v-576q0 -50 38.5 -89t89.5 -39q52 0 90 38t38 90v331q46 -35 103 -35q69 0 119 53q32 -18 69 -18t73.5 17.5t52.5 47.5q24 -4 56 -4q85 0 126 48.5t41 135.5zM1280 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1536 580 q0 -142 -77.5 -230t-217.5 -87l-5 1q-76 -61 -178 -61q-22 0 -43 3q-54 -30 -119 -37v-169q0 -105 -76 -180.5t-181 -75.5q-103 0 -179 76t-76 180v374q-54 -22 -128 -22q-121 0 -188.5 81.5t-67.5 206.5q0 38 17.5 69.5t49.5 55t63 40.5t72 37t62 33q55 35 129 100 q3 2 17 14t21.5 19t21.5 20.5t22.5 24t18 22.5t14 23.5t4.5 21.5v288q0 53 37.5 90.5t90.5 37.5h640q53 0 90.5 -37.5t37.5 -90.5v-288q0 -59 59 -223q69 -190 69 -317z" /> +<glyph unicode="" d="M1280 576v128q0 26 -19 45t-45 19h-502l189 189q19 19 19 45t-19 45l-91 91q-18 18 -45 18t-45 -18l-362 -362l-91 -91q-18 -18 -18 -45t18 -45l91 -91l362 -362q18 -18 45 -18t45 18l91 91q18 18 18 45t-18 45l-189 189h502q26 0 45 19t19 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1285 640q0 27 -18 45l-91 91l-362 362q-18 18 -45 18t-45 -18l-91 -91q-18 -18 -18 -45t18 -45l189 -189h-502q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h502l-189 -189q-19 -19 -19 -45t19 -45l91 -91q18 -18 45 -18t45 18l362 362l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1284 641q0 27 -18 45l-362 362l-91 91q-18 18 -45 18t-45 -18l-91 -91l-362 -362q-18 -18 -18 -45t18 -45l91 -91q18 -18 45 -18t45 18l189 189v-502q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v502l189 -189q19 -19 45 -19t45 19l91 91q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1284 639q0 27 -18 45l-91 91q-18 18 -45 18t-45 -18l-189 -189v502q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-502l-189 189q-19 19 -45 19t-45 -19l-91 -91q-18 -18 -18 -45t18 -45l362 -362l91 -91q18 -18 45 -18t45 18l91 91l362 362q18 18 18 45zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1042 887q-2 -1 -9.5 -9.5t-13.5 -9.5q2 0 4.5 5t5 11t3.5 7q6 7 22 15q14 6 52 12q34 8 51 -11 q-2 2 9.5 13t14.5 12q3 2 15 4.5t15 7.5l2 22q-12 -1 -17.5 7t-6.5 21q0 -2 -6 -8q0 7 -4.5 8t-11.5 -1t-9 -1q-10 3 -15 7.5t-8 16.5t-4 15q-2 5 -9.5 10.5t-9.5 10.5q-1 2 -2.5 5.5t-3 6.5t-4 5.5t-5.5 2.5t-7 -5t-7.5 -10t-4.5 -5q-3 2 -6 1.5t-4.5 -1t-4.5 -3t-5 -3.5 q-3 -2 -8.5 -3t-8.5 -2q15 5 -1 11q-10 4 -16 3q9 4 7.5 12t-8.5 14h5q-1 4 -8.5 8.5t-17.5 8.5t-13 6q-8 5 -34 9.5t-33 0.5q-5 -6 -4.5 -10.5t4 -14t3.5 -12.5q1 -6 -5.5 -13t-6.5 -12q0 -7 14 -15.5t10 -21.5q-3 -8 -16 -16t-16 -12q-5 -8 -1.5 -18.5t10.5 -16.5 q2 -2 1.5 -4t-3.5 -4.5t-5.5 -4t-6.5 -3.5l-3 -2q-11 -5 -20.5 6t-13.5 26q-7 25 -16 30q-23 8 -29 -1q-5 13 -41 26q-25 9 -58 4q6 1 0 15q-7 15 -19 12q3 6 4 17.5t1 13.5q3 13 12 23q1 1 7 8.5t9.5 13.5t0.5 6q35 -4 50 11q5 5 11.5 17t10.5 17q9 6 14 5.5t14.5 -5.5 t14.5 -5q14 -1 15.5 11t-7.5 20q12 -1 3 17q-5 7 -8 9q-12 4 -27 -5q-8 -4 2 -8q-1 1 -9.5 -10.5t-16.5 -17.5t-16 5q-1 1 -5.5 13.5t-9.5 13.5q-8 0 -16 -15q3 8 -11 15t-24 8q19 12 -8 27q-7 4 -20.5 5t-19.5 -4q-5 -7 -5.5 -11.5t5 -8t10.5 -5.5t11.5 -4t8.5 -3 q14 -10 8 -14q-2 -1 -8.5 -3.5t-11.5 -4.5t-6 -4q-3 -4 0 -14t-2 -14q-5 5 -9 17.5t-7 16.5q7 -9 -25 -6l-10 1q-4 0 -16 -2t-20.5 -1t-13.5 8q-4 8 0 20q1 4 4 2q-4 3 -11 9.5t-10 8.5q-46 -15 -94 -41q6 -1 12 1q5 2 13 6.5t10 5.5q34 14 42 7l5 5q14 -16 20 -25 q-7 4 -30 1q-20 -6 -22 -12q7 -12 5 -18q-4 3 -11.5 10t-14.5 11t-15 5q-16 0 -22 -1q-146 -80 -235 -222q7 -7 12 -8q4 -1 5 -9t2.5 -11t11.5 3q9 -8 3 -19q1 1 44 -27q19 -17 21 -21q3 -11 -10 -18q-1 2 -9 9t-9 4q-3 -5 0.5 -18.5t10.5 -12.5q-7 0 -9.5 -16t-2.5 -35.5 t-1 -23.5l2 -1q-3 -12 5.5 -34.5t21.5 -19.5q-13 -3 20 -43q6 -8 8 -9q3 -2 12 -7.5t15 -10t10 -10.5q4 -5 10 -22.5t14 -23.5q-2 -6 9.5 -20t10.5 -23q-1 0 -2.5 -1t-2.5 -1q3 -7 15.5 -14t15.5 -13q1 -3 2 -10t3 -11t8 -2q2 20 -24 62q-15 25 -17 29q-3 5 -5.5 15.5 t-4.5 14.5q2 0 6 -1.5t8.5 -3.5t7.5 -4t2 -3q-3 -7 2 -17.5t12 -18.5t17 -19t12 -13q6 -6 14 -19.5t0 -13.5q9 0 20 -10t17 -20q5 -8 8 -26t5 -24q2 -7 8.5 -13.5t12.5 -9.5l16 -8t13 -7q5 -2 18.5 -10.5t21.5 -11.5q10 -4 16 -4t14.5 2.5t13.5 3.5q15 2 29 -15t21 -21 q36 -19 55 -11q-2 -1 0.5 -7.5t8 -15.5t9 -14.5t5.5 -8.5q5 -6 18 -15t18 -15q6 4 7 9q-3 -8 7 -20t18 -10q14 3 14 32q-31 -15 -49 18q0 1 -2.5 5.5t-4 8.5t-2.5 8.5t0 7.5t5 3q9 0 10 3.5t-2 12.5t-4 13q-1 8 -11 20t-12 15q-5 -9 -16 -8t-16 9q0 -1 -1.5 -5.5t-1.5 -6.5 q-13 0 -15 1q1 3 2.5 17.5t3.5 22.5q1 4 5.5 12t7.5 14.5t4 12.5t-4.5 9.5t-17.5 2.5q-19 -1 -26 -20q-1 -3 -3 -10.5t-5 -11.5t-9 -7q-7 -3 -24 -2t-24 5q-13 8 -22.5 29t-9.5 37q0 10 2.5 26.5t3 25t-5.5 24.5q3 2 9 9.5t10 10.5q2 1 4.5 1.5t4.5 0t4 1.5t3 6q-1 1 -4 3 q-3 3 -4 3q7 -3 28.5 1.5t27.5 -1.5q15 -11 22 2q0 1 -2.5 9.5t-0.5 13.5q5 -27 29 -9q3 -3 15.5 -5t17.5 -5q3 -2 7 -5.5t5.5 -4.5t5 0.5t8.5 6.5q10 -14 12 -24q11 -40 19 -44q7 -3 11 -2t4.5 9.5t0 14t-1.5 12.5l-1 8v18l-1 8q-15 3 -18.5 12t1.5 18.5t15 18.5q1 1 8 3.5 t15.5 6.5t12.5 8q21 19 15 35q7 0 11 9q-1 0 -5 3t-7.5 5t-4.5 2q9 5 2 16q5 3 7.5 11t7.5 10q9 -12 21 -2q7 8 1 16q5 7 20.5 10.5t18.5 9.5q7 -2 8 2t1 12t3 12q4 5 15 9t13 5l17 11q3 4 0 4q18 -2 31 11q10 11 -6 20q3 6 -3 9.5t-15 5.5q3 1 11.5 0.5t10.5 1.5 q15 10 -7 16q-17 5 -43 -12zM879 10q206 36 351 189q-3 3 -12.5 4.5t-12.5 3.5q-18 7 -24 8q1 7 -2.5 13t-8 9t-12.5 8t-11 7q-2 2 -7 6t-7 5.5t-7.5 4.5t-8.5 2t-10 -1l-3 -1q-3 -1 -5.5 -2.5t-5.5 -3t-4 -3t0 -2.5q-21 17 -36 22q-5 1 -11 5.5t-10.5 7t-10 1.5t-11.5 -7 q-5 -5 -6 -15t-2 -13q-7 5 0 17.5t2 18.5q-3 6 -10.5 4.5t-12 -4.5t-11.5 -8.5t-9 -6.5t-8.5 -5.5t-8.5 -7.5q-3 -4 -6 -12t-5 -11q-2 4 -11.5 6.5t-9.5 5.5q2 -10 4 -35t5 -38q7 -31 -12 -48q-27 -25 -29 -40q-4 -22 12 -26q0 -7 -8 -20.5t-7 -21.5q0 -6 2 -16z" /> +<glyph unicode="" horiz-adv-x="1664" d="M384 64q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1028 484l-682 -682q-37 -37 -90 -37q-52 0 -91 37l-106 108q-38 36 -38 90q0 53 38 91l681 681q39 -98 114.5 -173.5t173.5 -114.5zM1662 919q0 -39 -23 -106q-47 -134 -164.5 -217.5 t-258.5 -83.5q-185 0 -316.5 131.5t-131.5 316.5t131.5 316.5t316.5 131.5q58 0 121.5 -16.5t107.5 -46.5q16 -11 16 -28t-16 -28l-293 -169v-224l193 -107q5 3 79 48.5t135.5 81t70.5 35.5q15 0 23.5 -10t8.5 -25z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1024 128h640v128h-640v-128zM640 640h1024v128h-1024v-128zM1280 1152h384v128h-384v-128zM1792 320v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 832v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19 t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45zM1792 1344v-256q0 -26 -19 -45t-45 -19h-1664q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1664q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1403 1241q17 -41 -14 -70l-493 -493v-742q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-256 256q-19 19 -19 45v486l-493 493q-31 29 -14 70q17 39 59 39h1280q42 0 59 -39z" /> +<glyph unicode="" horiz-adv-x="1792" d="M640 1280h512v128h-512v-128zM1792 640v-480q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v480h672v-160q0 -26 19 -45t45 -19h320q26 0 45 19t19 45v160h672zM1024 640v-128h-256v128h256zM1792 1120v-384h-1792v384q0 66 47 113t113 47h352v160q0 40 28 68 t68 28h576q40 0 68 -28t28 -68v-160h352q66 0 113 -47t47 -113z" /> +<glyph unicode="" d="M1283 995l-355 -355l355 -355l144 144q29 31 70 14q39 -17 39 -59v-448q0 -26 -19 -45t-45 -19h-448q-42 0 -59 40q-17 39 14 69l144 144l-355 355l-355 -355l144 -144q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l144 -144 l355 355l-355 355l-144 -144q-19 -19 -45 -19q-12 0 -24 5q-40 17 -40 59v448q0 26 19 45t45 19h448q42 0 59 -40q17 -39 -14 -69l-144 -144l355 -355l355 355l-144 144q-31 30 -14 69q17 40 59 40h448q26 0 45 -19t19 -45v-448q0 -42 -39 -59q-13 -5 -25 -5q-26 0 -45 19z " /> +<glyph unicode="" horiz-adv-x="1920" d="M593 640q-162 -5 -265 -128h-134q-82 0 -138 40.5t-56 118.5q0 353 124 353q6 0 43.5 -21t97.5 -42.5t119 -21.5q67 0 133 23q-5 -37 -5 -66q0 -139 81 -256zM1664 3q0 -120 -73 -189.5t-194 -69.5h-874q-121 0 -194 69.5t-73 189.5q0 53 3.5 103.5t14 109t26.5 108.5 t43 97.5t62 81t85.5 53.5t111.5 20q10 0 43 -21.5t73 -48t107 -48t135 -21.5t135 21.5t107 48t73 48t43 21.5q61 0 111.5 -20t85.5 -53.5t62 -81t43 -97.5t26.5 -108.5t14 -109t3.5 -103.5zM640 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75 t75 -181zM1344 896q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5t271.5 -112.5t112.5 -271.5zM1920 671q0 -78 -56 -118.5t-138 -40.5h-134q-103 123 -265 128q81 117 81 256q0 29 -5 66q66 -23 133 -23q59 0 119 21.5t97.5 42.5 t43.5 21q124 0 124 -353zM1792 1280q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1456 320q0 40 -28 68l-208 208q-28 28 -68 28q-42 0 -72 -32q3 -3 19 -18.5t21.5 -21.5t15 -19t13 -25.5t3.5 -27.5q0 -40 -28 -68t-68 -28q-15 0 -27.5 3.5t-25.5 13t-19 15t-21.5 21.5t-18.5 19q-33 -31 -33 -73q0 -40 28 -68l206 -207q27 -27 68 -27q40 0 68 26 l147 146q28 28 28 67zM753 1025q0 40 -28 68l-206 207q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l208 -208q27 -27 68 -27q42 0 72 31q-3 3 -19 18.5t-21.5 21.5t-15 19t-13 25.5t-3.5 27.5q0 40 28 68t68 28q15 0 27.5 -3.5t25.5 -13t19 -15 t21.5 -21.5t18.5 -19q33 31 33 73zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-206 207q-83 83 -83 203q0 123 88 209l-88 88q-86 -88 -208 -88q-120 0 -204 84l-208 208q-84 84 -84 204t85 203l147 146q83 83 203 83q121 0 204 -85l206 -207 q83 -83 83 -203q0 -123 -88 -209l88 -88q86 88 208 88q120 0 204 -84l208 -208q84 -84 84 -204z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088q-185 0 -316.5 131.5t-131.5 316.5q0 132 71 241.5t187 163.5q-2 28 -2 43q0 212 150 362t362 150q158 0 286.5 -88t187.5 -230q70 62 166 62q106 0 181 -75t75 -181q0 -75 -41 -138q129 -30 213 -134.5t84 -239.5z " /> +<glyph unicode="" horiz-adv-x="1664" d="M1527 88q56 -89 21.5 -152.5t-140.5 -63.5h-1152q-106 0 -140.5 63.5t21.5 152.5l503 793v399h-64q-26 0 -45 19t-19 45t19 45t45 19h512q26 0 45 -19t19 -45t-19 -45t-45 -19h-64v-399zM748 813l-272 -429h712l-272 429l-20 31v37v399h-128v-399v-37z" /> +<glyph unicode="" horiz-adv-x="1792" d="M960 640q26 0 45 -19t19 -45t-19 -45t-45 -19t-45 19t-19 45t19 45t45 19zM1260 576l507 -398q28 -20 25 -56q-5 -35 -35 -51l-128 -64q-13 -7 -29 -7q-17 0 -31 8l-690 387l-110 -66q-8 -4 -12 -5q14 -49 10 -97q-7 -77 -56 -147.5t-132 -123.5q-132 -84 -277 -84 q-136 0 -222 78q-90 84 -79 207q7 76 56 147t131 124q132 84 278 84q83 0 151 -31q9 13 22 22l122 73l-122 73q-13 9 -22 22q-68 -31 -151 -31q-146 0 -278 84q-82 53 -131 124t-56 147q-5 59 15.5 113t63.5 93q85 79 222 79q145 0 277 -84q83 -52 132 -123t56 -148 q4 -48 -10 -97q4 -1 12 -5l110 -66l690 387q14 8 31 8q16 0 29 -7l128 -64q30 -16 35 -51q3 -36 -25 -56zM579 836q46 42 21 108t-106 117q-92 59 -192 59q-74 0 -113 -36q-46 -42 -21 -108t106 -117q92 -59 192 -59q74 0 113 36zM494 91q81 51 106 117t-21 108 q-39 36 -113 36q-100 0 -192 -59q-81 -51 -106 -117t21 -108q39 -36 113 -36q100 0 192 59zM672 704l96 -58v11q0 36 33 56l14 8l-79 47l-26 -26q-3 -3 -10 -11t-12 -12q-2 -2 -4 -3.5t-3 -2.5zM896 480l96 -32l736 576l-128 64l-768 -431v-113l-160 -96l9 -8q2 -2 7 -6 q4 -4 11 -12t11 -12l26 -26zM1600 64l128 64l-520 408l-177 -138q-2 -3 -13 -7z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1696 1152q40 0 68 -28t28 -68v-1216q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v288h-544q-40 0 -68 28t-28 68v672q0 40 20 88t48 76l408 408q28 28 76 48t88 20h416q40 0 68 -28t28 -68v-328q68 40 128 40h416zM1152 939l-299 -299h299v299zM512 1323l-299 -299 h299v299zM708 676l316 316v416h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h512v256q0 40 20 88t48 76zM1664 -128v1152h-384v-416q0 -40 -28 -68t-68 -28h-416v-640h896z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1404 151q0 -117 -79 -196t-196 -79q-135 0 -235 100l-777 776q-113 115 -113 271q0 159 110 270t269 111q158 0 273 -113l605 -606q10 -10 10 -22q0 -16 -30.5 -46.5t-46.5 -30.5q-13 0 -23 10l-606 607q-79 77 -181 77q-106 0 -179 -75t-73 -181q0 -105 76 -181 l776 -777q63 -63 145 -63q64 0 106 42t42 106q0 82 -63 145l-581 581q-26 24 -60 24q-29 0 -48 -19t-19 -48q0 -32 25 -59l410 -410q10 -10 10 -22q0 -16 -31 -47t-47 -31q-12 0 -22 10l-410 410q-63 61 -63 149q0 82 57 139t139 57q88 0 149 -63l581 -581q100 -98 100 -235 z" /> +<glyph unicode="" d="M384 0h768v384h-768v-384zM1280 0h128v896q0 14 -10 38.5t-20 34.5l-281 281q-10 10 -34 20t-39 10v-416q0 -40 -28 -68t-68 -28h-576q-40 0 -68 28t-28 68v416h-128v-1280h128v416q0 40 28 68t68 28h832q40 0 68 -28t28 -68v-416zM896 928v320q0 13 -9.5 22.5t-22.5 9.5 h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5zM1536 896v-928q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h928q40 0 88 -20t76 -48l280 -280q28 -28 48 -76t20 -88z" /> +<glyph unicode="" d="M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1536 192v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 704v-128q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1536 1216v-128q0 -26 -19 -45 t-45 -19h-1408q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M384 128q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM384 640q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 224v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5 t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1152q0 -80 -56 -136t-136 -56t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z M1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M381 -84q0 -80 -54.5 -126t-135.5 -46q-106 0 -172 66l57 88q49 -45 106 -45q29 0 50.5 14.5t21.5 42.5q0 64 -105 56l-26 56q8 10 32.5 43.5t42.5 54t37 38.5v1q-16 0 -48.5 -1t-48.5 -1v-53h-106v152h333v-88l-95 -115q51 -12 81 -49t30 -88zM383 543v-159h-362 q-6 36 -6 54q0 51 23.5 93t56.5 68t66 47.5t56.5 43.5t23.5 45q0 25 -14.5 38.5t-39.5 13.5q-46 0 -81 -58l-85 59q24 51 71.5 79.5t105.5 28.5q73 0 123 -41.5t50 -112.5q0 -50 -34 -91.5t-75 -64.5t-75.5 -50.5t-35.5 -52.5h127v60h105zM1792 224v-192q0 -13 -9.5 -22.5 t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM384 1123v-99h-335v99h107q0 41 0.5 122t0.5 121v12h-2q-8 -17 -50 -54l-71 76l136 127h106v-404h108zM1792 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5 t-9.5 22.5v192q0 14 9 23t23 9h1216q13 0 22.5 -9.5t9.5 -22.5zM1792 1248v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1216q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1216q13 0 22.5 -9.5t9.5 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1760 640q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-1728q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h1728zM483 704q-28 35 -51 80q-48 97 -48 188q0 181 134 309q133 127 393 127q50 0 167 -19q66 -12 177 -48q10 -38 21 -118q14 -123 14 -183q0 -18 -5 -45l-12 -3l-84 6 l-14 2q-50 149 -103 205q-88 91 -210 91q-114 0 -182 -59q-67 -58 -67 -146q0 -73 66 -140t279 -129q69 -20 173 -66q58 -28 95 -52h-743zM990 448h411q7 -39 7 -92q0 -111 -41 -212q-23 -55 -71 -104q-37 -35 -109 -81q-80 -48 -153 -66q-80 -21 -203 -21q-114 0 -195 23 l-140 40q-57 16 -72 28q-8 8 -8 22v13q0 108 -2 156q-1 30 0 68l2 37v44l102 2q15 -34 30 -71t22.5 -56t12.5 -27q35 -57 80 -94q43 -36 105 -57q59 -22 132 -22q64 0 139 27q77 26 122 86q47 61 47 129q0 84 -81 157q-34 29 -137 71z" /> +<glyph unicode="" d="M48 1313q-37 2 -45 4l-3 88q13 1 40 1q60 0 112 -4q132 -7 166 -7q86 0 168 3q116 4 146 5q56 0 86 2l-1 -14l2 -64v-9q-60 -9 -124 -9q-60 0 -79 -25q-13 -14 -13 -132q0 -13 0.5 -32.5t0.5 -25.5l1 -229l14 -280q6 -124 51 -202q35 -59 96 -92q88 -47 177 -47 q104 0 191 28q56 18 99 51q48 36 65 64q36 56 53 114q21 73 21 229q0 79 -3.5 128t-11 122.5t-13.5 159.5l-4 59q-5 67 -24 88q-34 35 -77 34l-100 -2l-14 3l2 86h84l205 -10q76 -3 196 10l18 -2q6 -38 6 -51q0 -7 -4 -31q-45 -12 -84 -13q-73 -11 -79 -17q-15 -15 -15 -41 q0 -7 1.5 -27t1.5 -31q8 -19 22 -396q6 -195 -15 -304q-15 -76 -41 -122q-38 -65 -112 -123q-75 -57 -182 -89q-109 -33 -255 -33q-167 0 -284 46q-119 47 -179 122q-61 76 -83 195q-16 80 -16 237v333q0 188 -17 213q-25 36 -147 39zM1536 -96v64q0 14 -9 23t-23 9h-1472 q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h1472q14 0 23 9t9 23z" /> +<glyph unicode="" horiz-adv-x="1664" d="M512 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 160v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23 v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM512 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 160v192 q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1024 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 544v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192 q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1536 928v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM1664 1248v-1088q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1344q66 0 113 -47t47 -113 z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1190 955l293 293l-107 107l-293 -293zM1637 1248q0 -27 -18 -45l-1286 -1286q-18 -18 -45 -18t-45 18l-198 198q-18 18 -18 45t18 45l1286 1286q18 18 45 18t45 -18l198 -198q18 -18 18 -45zM286 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM636 1276 l196 -60l-196 -60l-60 -196l-60 196l-196 60l196 60l60 196zM1566 798l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98zM926 1438l98 -30l-98 -30l-30 -98l-30 98l-98 30l98 30l30 98z" /> +<glyph unicode="" horiz-adv-x="1792" d="M640 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM256 640h384v256h-158q-13 0 -22 -9l-195 -195q-9 -9 -9 -22v-30zM1536 128q0 52 -38 90t-90 38t-90 -38t-38 -90t38 -90t90 -38t90 38t38 90zM1792 1216v-1024q0 -15 -4 -26.5t-13.5 -18.5 t-16.5 -11.5t-23.5 -6t-22.5 -2t-25.5 0t-22.5 0.5q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-64q-3 0 -22.5 -0.5t-25.5 0t-22.5 2t-23.5 6t-16.5 11.5t-13.5 18.5t-4 26.5q0 26 19 45t45 19v320q0 8 -0.5 35t0 38 t2.5 34.5t6.5 37t14 30.5t22.5 30l198 198q19 19 50.5 32t58.5 13h160v192q0 26 19 45t45 19h1024q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103q-111 0 -218 32q59 93 78 164q9 34 54 211q20 -39 73 -67.5t114 -28.5q121 0 216 68.5t147 188.5t52 270q0 114 -59.5 214t-172.5 163t-255 63q-105 0 -196 -29t-154.5 -77t-109 -110.5t-67 -129.5t-21.5 -134 q0 -104 40 -183t117 -111q30 -12 38 20q2 7 8 31t8 30q6 23 -11 43q-51 61 -51 151q0 151 104.5 259.5t273.5 108.5q151 0 235.5 -82t84.5 -213q0 -170 -68.5 -289t-175.5 -119q-61 0 -98 43.5t-23 104.5q8 35 26.5 93.5t30 103t11.5 75.5q0 50 -27 83t-77 33 q-62 0 -105 -57t-43 -142q0 -73 25 -122l-99 -418q-17 -70 -13 -177q-206 91 -333 281t-127 423q0 209 103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-725q85 122 108 210q9 34 53 209q21 -39 73.5 -67t112.5 -28q181 0 295.5 147.5t114.5 373.5q0 84 -35 162.5t-96.5 139t-152.5 97t-197 36.5q-104 0 -194.5 -28.5t-153 -76.5 t-107.5 -109.5t-66.5 -128t-21.5 -132.5q0 -102 39.5 -180t116.5 -110q13 -5 23.5 0t14.5 19q10 44 15 61q6 23 -11 42q-50 62 -50 150q0 150 103.5 256.5t270.5 106.5q149 0 232.5 -81t83.5 -210q0 -168 -67.5 -286t-173.5 -118q-60 0 -97 43.5t-23 103.5q8 34 26.5 92.5 t29.5 102t11 74.5q0 49 -26.5 81.5t-75.5 32.5q-61 0 -103.5 -56.5t-42.5 -139.5q0 -72 24 -121l-98 -414q-24 -100 -7 -254h-183q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960z" /> +<glyph unicode="" d="M829 318q0 -76 -58.5 -112.5t-139.5 -36.5q-41 0 -80.5 9.5t-75.5 28.5t-58 53t-22 78q0 46 25 80t65.5 51.5t82 25t84.5 7.5q20 0 31 -2q2 -1 23 -16.5t26 -19t23 -18t24.5 -22t19 -22.5t17 -26t9 -26.5t4.5 -31.5zM755 863q0 -60 -33 -99.5t-92 -39.5q-53 0 -93 42.5 t-57.5 96.5t-17.5 106q0 61 32 104t92 43q53 0 93.5 -45t58 -101t17.5 -107zM861 1120l88 64h-265q-85 0 -161 -32t-127.5 -98t-51.5 -153q0 -93 64.5 -154.5t158.5 -61.5q22 0 43 3q-13 -29 -13 -54q0 -44 40 -94q-175 -12 -257 -63q-47 -29 -75.5 -73t-28.5 -95 q0 -43 18.5 -77.5t48.5 -56.5t69 -37t77.5 -21t76.5 -6q60 0 120.5 15.5t113.5 46t86 82.5t33 117q0 49 -20 89.5t-49 66.5t-58 47.5t-49 44t-20 44.5t15.5 42.5t37.5 39.5t44 42t37.5 59.5t15.5 82.5q0 60 -22.5 99.5t-72.5 90.5h83zM1152 672h128v64h-128v128h-64v-128 h-128v-64h128v-160h64v160zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M735 740q0 -36 32 -70.5t77.5 -68t90.5 -73.5t77 -104t32 -142q0 -90 -48 -173q-72 -122 -211 -179.5t-298 -57.5q-132 0 -246.5 41.5t-171.5 137.5q-37 60 -37 131q0 81 44.5 150t118.5 115q131 82 404 100q-32 42 -47.5 74t-15.5 73q0 36 21 85q-46 -4 -68 -4 q-148 0 -249.5 96.5t-101.5 244.5q0 82 36 159t99 131q77 66 182.5 98t217.5 32h418l-138 -88h-131q74 -63 112 -133t38 -160q0 -72 -24.5 -129.5t-59 -93t-69.5 -65t-59.5 -61.5t-24.5 -66zM589 836q38 0 78 16.5t66 43.5q53 57 53 159q0 58 -17 125t-48.5 129.5 t-84.5 103.5t-117 41q-42 0 -82.5 -19.5t-65.5 -52.5q-47 -59 -47 -160q0 -46 10 -97.5t31.5 -103t52 -92.5t75 -67t96.5 -26zM591 -37q58 0 111.5 13t99 39t73 73t27.5 109q0 25 -7 49t-14.5 42t-27 41.5t-29.5 35t-38.5 34.5t-36.5 29t-41.5 30t-36.5 26q-16 2 -48 2 q-53 0 -105 -7t-107.5 -25t-97 -46t-68.5 -74.5t-27 -105.5q0 -70 35 -123.5t91.5 -83t119 -44t127.5 -14.5zM1401 839h213v-108h-213v-219h-105v219h-212v108h212v217h105v-217z" /> +<glyph unicode="" horiz-adv-x="1920" d="M768 384h384v96h-128v448h-114l-148 -137l77 -80q42 37 55 57h2v-288h-128v-96zM1280 640q0 -70 -21 -142t-59.5 -134t-101.5 -101t-138 -39t-138 39t-101.5 101t-59.5 134t-21 142t21 142t59.5 134t101.5 101t138 39t138 -39t101.5 -101t59.5 -134t21 -142zM1792 384 v512q-106 0 -181 75t-75 181h-1152q0 -106 -75 -181t-181 -75v-512q106 0 181 -75t75 -181h1152q0 106 75 181t181 75zM1920 1216v-1152q0 -26 -19 -45t-45 -19h-1792q-26 0 -45 19t-19 45v1152q0 26 19 45t45 19h1792q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 320q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="640" d="M640 1088v-896q0 -26 -19 -45t-45 -19t-45 19l-448 448q-19 19 -19 45t19 45l448 448q19 19 45 19t45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="640" d="M576 640q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19t-19 45v896q0 26 19 45t45 19t45 -19l448 -448q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M160 0h608v1152h-640v-1120q0 -13 9.5 -22.5t22.5 -9.5zM1536 32v1120h-640v-1152h608q13 0 22.5 9.5t9.5 22.5zM1664 1248v-1216q0 -66 -47 -113t-113 -47h-1344q-66 0 -113 47t-47 113v1216q0 66 47 113t113 47h1344q66 0 113 -47t47 -113z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45zM1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 448q0 -26 -19 -45l-448 -448q-19 -19 -45 -19t-45 19l-448 448q-19 19 -19 45t19 45t45 19h896q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 832q0 -26 -19 -45t-45 -19h-896q-26 0 -45 19t-19 45t19 45l448 448q19 19 45 19t45 -19l448 -448q19 -19 19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 826v-794q0 -66 -47 -113t-113 -47h-1472q-66 0 -113 47t-47 113v794q44 -49 101 -87q362 -246 497 -345q57 -42 92.5 -65.5t94.5 -48t110 -24.5h1h1q51 0 110 24.5t94.5 48t92.5 65.5q170 123 498 345q57 39 100 87zM1792 1120q0 -79 -49 -151t-122 -123 q-376 -261 -468 -325q-10 -7 -42.5 -30.5t-54 -38t-52 -32.5t-57.5 -27t-50 -9h-1h-1q-23 0 -50 9t-57.5 27t-52 32.5t-54 38t-42.5 30.5q-91 64 -262 182.5t-205 142.5q-62 42 -117 115.5t-55 136.5q0 78 41.5 130t118.5 52h1472q65 0 112.5 -47t47.5 -113z" /> +<glyph unicode="" d="M349 911v-991h-330v991h330zM370 1217q1 -73 -50.5 -122t-135.5 -49h-2q-82 0 -132 49t-50 122q0 74 51.5 122.5t134.5 48.5t133 -48.5t51 -122.5zM1536 488v-568h-329v530q0 105 -40.5 164.5t-126.5 59.5q-63 0 -105.5 -34.5t-63.5 -85.5q-11 -30 -11 -81v-553h-329 q2 399 2 647t-1 296l-1 48h329v-144h-2q20 32 41 56t56.5 52t87 43.5t114.5 15.5q171 0 275 -113.5t104 -332.5z" /> +<glyph unicode="" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61q-172 0 -327 72.5t-264 204.5q-7 10 -6.5 22.5t8.5 20.5l137 138q10 9 25 9q16 -2 23 -12q73 -95 179 -147t225 -52q104 0 198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5t-40.5 198.5t-109.5 163.5 t-163.5 109.5t-198.5 40.5q-98 0 -188 -35.5t-160 -101.5l137 -138q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l130 -129q107 101 244.5 156.5t284.5 55.5q156 0 298 -61t245 -164t164 -245t61 -298z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1771 0q0 -53 -37 -90l-107 -108q-39 -37 -91 -37q-53 0 -90 37l-363 364q-38 36 -38 90q0 53 43 96l-256 256l-126 -126q-14 -14 -34 -14t-34 14q2 -2 12.5 -12t12.5 -13t10 -11.5t10 -13.5t6 -13.5t5.5 -16.5t1.5 -18q0 -38 -28 -68q-3 -3 -16.5 -18t-19 -20.5 t-18.5 -16.5t-22 -15.5t-22 -9t-26 -4.5q-40 0 -68 28l-408 408q-28 28 -28 68q0 13 4.5 26t9 22t15.5 22t16.5 18.5t20.5 19t18 16.5q30 28 68 28q10 0 18 -1.5t16.5 -5.5t13.5 -6t13.5 -10t11.5 -10t13 -12.5t12 -12.5q-14 14 -14 34t14 34l348 348q14 14 34 14t34 -14 q-2 2 -12.5 12t-12.5 13t-10 11.5t-10 13.5t-6 13.5t-5.5 16.5t-1.5 18q0 38 28 68q3 3 16.5 18t19 20.5t18.5 16.5t22 15.5t22 9t26 4.5q40 0 68 -28l408 -408q28 -28 28 -68q0 -13 -4.5 -26t-9 -22t-15.5 -22t-16.5 -18.5t-20.5 -19t-18 -16.5q-30 -28 -68 -28 q-10 0 -18 1.5t-16.5 5.5t-13.5 6t-13.5 10t-11.5 10t-13 12.5t-12 12.5q14 -14 14 -34t-14 -34l-126 -126l256 -256q43 43 96 43q52 0 91 -37l363 -363q37 -39 37 -91z" /> +<glyph unicode="" horiz-adv-x="1792" d="M384 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM576 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1004 351l101 382q6 26 -7.5 48.5t-38.5 29.5 t-48 -6.5t-30 -39.5l-101 -382q-60 -5 -107 -43.5t-63 -98.5q-20 -77 20 -146t117 -89t146 20t89 117q16 60 -6 117t-72 91zM1664 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1024 1024q0 53 -37.5 90.5 t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1472 832q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1792 384q0 -261 -141 -483q-19 -29 -54 -29h-1402q-35 0 -54 29 q-141 221 -141 483q0 182 71 348t191 286t286 191t348 71t348 -71t286 -191t191 -286t71 -348z" /> +<glyph unicode="" horiz-adv-x="1792" d="M896 1152q-204 0 -381.5 -69.5t-282 -187.5t-104.5 -255q0 -112 71.5 -213.5t201.5 -175.5l87 -50l-27 -96q-24 -91 -70 -172q152 63 275 171l43 38l57 -6q69 -8 130 -8q204 0 381.5 69.5t282 187.5t104.5 255t-104.5 255t-282 187.5t-381.5 69.5zM1792 640 q0 -174 -120 -321.5t-326 -233t-450 -85.5q-70 0 -145 8q-198 -175 -460 -242q-49 -14 -114 -22h-5q-15 0 -27 10.5t-16 27.5v1q-3 4 -0.5 12t2 10t4.5 9.5l6 9t7 8.5t8 9q7 8 31 34.5t34.5 38t31 39.5t32.5 51t27 59t26 76q-157 89 -247.5 220t-90.5 281q0 174 120 321.5 t326 233t450 85.5t450 -85.5t326 -233t120 -321.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M704 1152q-153 0 -286 -52t-211.5 -141t-78.5 -191q0 -82 53 -158t149 -132l97 -56l-35 -84q34 20 62 39l44 31l53 -10q78 -14 153 -14q153 0 286 52t211.5 141t78.5 191t-78.5 191t-211.5 141t-286 52zM704 1280q191 0 353.5 -68.5t256.5 -186.5t94 -257t-94 -257 t-256.5 -186.5t-353.5 -68.5q-86 0 -176 16q-124 -88 -278 -128q-36 -9 -86 -16h-3q-11 0 -20.5 8t-11.5 21q-1 3 -1 6.5t0.5 6.5t2 6l2.5 5t3.5 5.5t4 5t4.5 5t4 4.5q5 6 23 25t26 29.5t22.5 29t25 38.5t20.5 44q-124 72 -195 177t-71 224q0 139 94 257t256.5 186.5 t353.5 68.5zM1526 111q10 -24 20.5 -44t25 -38.5t22.5 -29t26 -29.5t23 -25q1 -1 4 -4.5t4.5 -5t4 -5t3.5 -5.5l2.5 -5t2 -6t0.5 -6.5t-1 -6.5q-3 -14 -13 -22t-22 -7q-50 7 -86 16q-154 40 -278 128q-90 -16 -176 -16q-271 0 -472 132q58 -4 88 -4q161 0 309 45t264 129 q125 92 192 212t67 254q0 77 -23 152q129 -71 204 -178t75 -230q0 -120 -71 -224.5t-195 -176.5z" /> +<glyph unicode="" horiz-adv-x="896" d="M885 970q18 -20 7 -44l-540 -1157q-13 -25 -42 -25q-4 0 -14 2q-17 5 -25.5 19t-4.5 30l197 808l-406 -101q-4 -1 -12 -1q-18 0 -31 11q-18 15 -13 39l201 825q4 14 16 23t28 9h328q19 0 32 -12.5t13 -29.5q0 -8 -5 -18l-171 -463l396 98q8 2 12 2q19 0 34 -15z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 288v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192h-512v-192h96q40 0 68 -28t28 -68v-320 q0 -40 -28 -68t-68 -28h-320q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h96v192q0 52 38 90t90 38h512v192h-96q-40 0 -68 28t-28 68v320q0 40 28 68t68 28h320q40 0 68 -28t28 -68v-320q0 -40 -28 -68t-68 -28h-96v-192h512q52 0 90 -38t38 -90v-192h96q40 0 68 -28t28 -68 z" /> +<glyph unicode="" horiz-adv-x="1664" d="M896 708v-580q0 -104 -76 -180t-180 -76t-180 76t-76 180q0 26 19 45t45 19t45 -19t19 -45q0 -50 39 -89t89 -39t89 39t39 89v580q33 11 64 11t64 -11zM1664 681q0 -13 -9.5 -22.5t-22.5 -9.5q-11 0 -23 10q-49 46 -93 69t-102 23q-68 0 -128 -37t-103 -97 q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -28 -17q-18 0 -29 17q-4 6 -14.5 24t-17.5 28q-43 60 -102.5 97t-127.5 37t-127.5 -37t-102.5 -97q-7 -10 -17.5 -28t-14.5 -24q-11 -17 -29 -17q-17 0 -28 17q-4 6 -14.5 24t-17.5 28q-43 60 -103 97t-128 37q-58 0 -102 -23t-93 -69 q-12 -10 -23 -10q-13 0 -22.5 9.5t-9.5 22.5q0 5 1 7q45 183 172.5 319.5t298 204.5t360.5 68q140 0 274.5 -40t246.5 -113.5t194.5 -187t115.5 -251.5q1 -2 1 -7zM896 1408v-98q-42 2 -64 2t-64 -2v98q0 26 19 45t45 19t45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M768 -128h896v640h-416q-40 0 -68 28t-28 68v416h-384v-1152zM1024 1312v64q0 13 -9.5 22.5t-22.5 9.5h-704q-13 0 -22.5 -9.5t-9.5 -22.5v-64q0 -13 9.5 -22.5t22.5 -9.5h704q13 0 22.5 9.5t9.5 22.5zM1280 640h299l-299 299v-299zM1792 512v-672q0 -40 -28 -68t-68 -28 h-960q-40 0 -68 28t-28 68v160h-544q-40 0 -68 28t-28 68v1344q0 40 28 68t68 28h1088q40 0 68 -28t28 -68v-328q21 -13 36 -28l408 -408q28 -28 48 -76t20 -88z" /> +<glyph unicode="" horiz-adv-x="1024" d="M736 960q0 -13 -9.5 -22.5t-22.5 -9.5t-22.5 9.5t-9.5 22.5q0 46 -54 71t-106 25q-13 0 -22.5 9.5t-9.5 22.5t9.5 22.5t22.5 9.5q50 0 99.5 -16t87 -54t37.5 -90zM896 960q0 72 -34.5 134t-90 101.5t-123 62t-136.5 22.5t-136.5 -22.5t-123 -62t-90 -101.5t-34.5 -134 q0 -101 68 -180q10 -11 30.5 -33t30.5 -33q128 -153 141 -298h228q13 145 141 298q10 11 30.5 33t30.5 33q68 79 68 180zM1024 960q0 -155 -103 -268q-45 -49 -74.5 -87t-59.5 -95.5t-34 -107.5q47 -28 47 -82q0 -37 -25 -64q25 -27 25 -64q0 -52 -45 -81q13 -23 13 -47 q0 -46 -31.5 -71t-77.5 -25q-20 -44 -60 -70t-87 -26t-87 26t-60 70q-46 0 -77.5 25t-31.5 71q0 24 13 47q-45 29 -45 81q0 37 25 64q-25 27 -25 64q0 54 47 82q-4 50 -34 107.5t-59.5 95.5t-74.5 87q-103 113 -103 268q0 99 44.5 184.5t117 142t164 89t186.5 32.5 t186.5 -32.5t164 -89t117 -142t44.5 -184.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 352v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-1376v-192q0 -13 -9.5 -22.5t-22.5 -9.5q-12 0 -24 10l-319 320q-9 9 -9 22q0 14 9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h1376q13 0 22.5 -9.5t9.5 -22.5zM1792 896q0 -14 -9 -23l-320 -320q-9 -9 -23 -9 q-13 0 -22.5 9.5t-9.5 22.5v192h-1376q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h1376v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1280 608q0 14 -9 23t-23 9h-224v352q0 13 -9.5 22.5t-22.5 9.5h-192q-13 0 -22.5 -9.5t-9.5 -22.5v-352h-224q-13 0 -22.5 -9.5t-9.5 -22.5q0 -14 9 -23l352 -352q9 -9 23 -9t23 9l351 351q10 12 10 24zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1280 672q0 14 -9 23l-352 352q-9 9 -23 9t-23 -9l-351 -351q-10 -12 -10 -24q0 -14 9 -23t23 -9h224v-352q0 -13 9.5 -22.5t22.5 -9.5h192q13 0 22.5 9.5t9.5 22.5v352h224q13 0 22.5 9.5t9.5 22.5zM1920 384q0 -159 -112.5 -271.5t-271.5 -112.5h-1088 q-185 0 -316.5 131.5t-131.5 316.5q0 130 70 240t188 165q-2 30 -2 43q0 212 150 362t362 150q156 0 285.5 -87t188.5 -231q71 62 166 62q106 0 181 -75t75 -181q0 -76 -41 -138q130 -31 213.5 -135.5t83.5 -238.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 192q0 -26 -19 -45t-45 -19t-45 19t-19 45t19 45t45 19t45 -19t19 -45zM1408 131q0 -121 -73 -190t-194 -69h-874q-121 0 -194 69t-73 190q0 68 5.5 131t24 138t47.5 132.5t81 103t120 60.5q-22 -52 -22 -120v-203q-58 -20 -93 -70t-35 -111q0 -80 56 -136t136 -56 t136 56t56 136q0 61 -35.5 111t-92.5 70v203q0 62 25 93q132 -104 295 -104t295 104q25 -31 25 -93v-64q-106 0 -181 -75t-75 -181v-89q-32 -29 -32 -71q0 -40 28 -68t68 -28t68 28t28 68q0 42 -32 71v89q0 52 38 90t90 38t90 -38t38 -90v-89q-32 -29 -32 -71q0 -40 28 -68 t68 -28t68 28t28 68q0 42 -32 71v89q0 68 -34.5 127.5t-93.5 93.5q0 10 0.5 42.5t0 48t-2.5 41.5t-7 47t-13 40q68 -15 120 -60.5t81 -103t47.5 -132.5t24 -138t5.5 -131zM1088 1024q0 -159 -112.5 -271.5t-271.5 -112.5t-271.5 112.5t-112.5 271.5t112.5 271.5t271.5 112.5 t271.5 -112.5t112.5 -271.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1280 832q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 832q0 -62 -35.5 -111t-92.5 -70v-395q0 -159 -131.5 -271.5t-316.5 -112.5t-316.5 112.5t-131.5 271.5v132q-164 20 -274 128t-110 252v512q0 26 19 45t45 19q6 0 16 -2q17 30 47 48 t65 18q53 0 90.5 -37.5t37.5 -90.5t-37.5 -90.5t-90.5 -37.5q-33 0 -64 18v-402q0 -106 94 -181t226 -75t226 75t94 181v402q-31 -18 -64 -18q-53 0 -90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5q35 0 65 -18t47 -48q10 2 16 2q26 0 45 -19t19 -45v-512q0 -144 -110 -252 t-274 -128v-132q0 -106 94 -181t226 -75t226 75t94 181v395q-57 21 -92.5 70t-35.5 111q0 80 56 136t136 56t136 -56t56 -136z" /> +<glyph unicode="" horiz-adv-x="1792" d="M640 1152h512v128h-512v-128zM288 1152v-1280h-64q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h64zM1408 1152v-1280h-1024v1280h128v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h128zM1792 928v-832q0 -92 -66 -158t-158 -66h-64v1280h64q92 0 158 -66 t66 -158z" /> +<glyph unicode="" horiz-adv-x="1792" d="M912 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM1728 128q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-181 75t-75 181h-448q-52 0 -90 38t-38 90q50 42 91 88t85 119.5t74.5 158.5 t50 206t19.5 260q0 152 117 282.5t307 158.5q-8 19 -8 39q0 40 28 68t68 28t68 -28t28 -68q0 -20 -8 -39q190 -28 307 -158.5t117 -282.5q0 -139 19.5 -260t50 -206t74.5 -158.5t85 -119.5t91 -88z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1664 896q0 80 -56 136t-136 56h-64v-384h64q80 0 136 56t56 136zM0 128h1792q0 -106 -75 -181t-181 -75h-1280q-106 0 -181 75t-75 181zM1856 896q0 -159 -112.5 -271.5t-271.5 -112.5h-64v-32q0 -92 -66 -158t-158 -66h-704q-92 0 -158 66t-66 158v736q0 26 19 45 t45 19h1152q159 0 271.5 -112.5t112.5 -271.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M640 1472v-640q0 -61 -35.5 -111t-92.5 -70v-779q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v779q-57 20 -92.5 70t-35.5 111v640q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45v-416q0 -26 19 -45 t45 -19t45 19t19 45v416q0 26 19 45t45 19t45 -19t19 -45zM1408 1472v-1600q0 -52 -38 -90t-90 -38h-128q-52 0 -90 38t-38 90v512h-224q-13 0 -22.5 9.5t-9.5 22.5v800q0 132 94 226t226 94h256q26 0 45 -19t19 -45z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M384 736q0 14 9 23t23 9h704q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64zM1120 512q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704zM1120 256q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-704 q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h704z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 992v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 1248v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1536h-1152v-1536h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM1408 1472v-1664q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1664q0 26 19 45t45 19h1280q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM384 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M1152 224v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM896 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M640 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 480v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5zM1152 736v-64q0 -13 -9.5 -22.5t-22.5 -9.5h-64q-13 0 -22.5 9.5t-9.5 22.5v64q0 13 9.5 22.5t22.5 9.5h64q13 0 22.5 -9.5t9.5 -22.5z M896 -128h384v1152h-256v-32q0 -40 -28 -68t-68 -28h-448q-40 0 -68 28t-28 68v32h-256v-1152h384v224q0 13 9.5 22.5t22.5 9.5h320q13 0 22.5 -9.5t9.5 -22.5v-224zM896 1056v320q0 13 -9.5 22.5t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-96h-128v96q0 13 -9.5 22.5 t-22.5 9.5h-64q-13 0 -22.5 -9.5t-9.5 -22.5v-320q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5v96h128v-96q0 -13 9.5 -22.5t22.5 -9.5h64q13 0 22.5 9.5t9.5 22.5zM1408 1088v-1280q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1280q0 26 19 45t45 19h320 v288q0 40 28 68t68 28h448q40 0 68 -28t28 -68v-288h320q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1920" d="M640 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM256 640h384v256h-158q-14 -2 -22 -9l-195 -195q-7 -12 -9 -22v-30zM1536 128q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5 t90.5 37.5t37.5 90.5zM1664 800v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM1920 1344v-1152 q0 -26 -19 -45t-45 -19h-192q0 -106 -75 -181t-181 -75t-181 75t-75 181h-384q0 -106 -75 -181t-181 -75t-181 75t-75 181h-128q-26 0 -45 19t-19 45t19 45t45 19v416q0 26 13 58t32 51l198 198q19 19 51 32t58 13h160v320q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1280 416v192q0 14 -9 23t-23 9h-224v224q0 14 -9 23t-23 9h-192q-14 0 -23 -9t-9 -23v-224h-224q-14 0 -23 -9t-9 -23v-192q0 -14 9 -23t23 -9h224v-224q0 -14 9 -23t23 -9h192q14 0 23 9t9 23v224h224q14 0 23 9t9 23zM640 1152h512v128h-512v-128zM256 1152v-1280h-32 q-92 0 -158 66t-66 158v832q0 92 66 158t158 66h32zM1440 1152v-1280h-1088v1280h160v160q0 40 28 68t68 28h576q40 0 68 -28t28 -68v-160h160zM1792 928v-832q0 -92 -66 -158t-158 -66h-32v1280h32q92 0 158 -66t66 -158z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1920 576q-1 -32 -288 -96l-352 -32l-224 -64h-64l-293 -352h69q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-96h-160h-64v32h64v416h-160l-192 -224h-96l-32 32v192h32v32h128v8l-192 24v128l192 24v8h-128v32h-32v192l32 32h96l192 -224h160v416h-64v32h64h160h96 q26 0 45 -4.5t19 -11.5t-19 -11.5t-45 -4.5h-69l293 -352h64l224 -64l352 -32q261 -58 287 -93z" /> +<glyph unicode="" horiz-adv-x="1664" d="M640 640v384h-256v-256q0 -53 37.5 -90.5t90.5 -37.5h128zM1664 192v-192h-1152v192l128 192h-128q-159 0 -271.5 112.5t-112.5 271.5v320l-64 64l32 128h480l32 128h960l32 -192l-64 -32v-800z" /> +<glyph unicode="" d="M1280 192v896q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-512v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-896q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h512v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1280 576v128q0 26 -19 45t-45 19h-320v320q0 26 -19 45t-45 19h-128q-26 0 -45 -19t-19 -45v-320h-320q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h320v-320q0 -26 19 -45t45 -19h128q26 0 45 19t19 45v320h320q26 0 45 19t19 45zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M627 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23zM1011 160q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1024" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM979 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23 l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1075 224q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23zM1075 608q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393 q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1075 672q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23zM1075 1056q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23 t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="640" d="M627 992q0 -13 -10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="640" d="M595 576q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1075 352q0 -13 -10 -23l-50 -50q-10 -10 -23 -10t-23 10l-393 393l-393 -393q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l466 -466q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1075 800q0 -13 -10 -23l-466 -466q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l393 -393l393 393q10 10 23 10t23 -10l50 -50q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1792 544v832q0 13 -9.5 22.5t-22.5 9.5h-1600q-13 0 -22.5 -9.5t-9.5 -22.5v-832q0 -13 9.5 -22.5t22.5 -9.5h1600q13 0 22.5 9.5t9.5 22.5zM1920 1376v-1088q0 -66 -47 -113t-113 -47h-544q0 -37 16 -77.5t32 -71t16 -43.5q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19 t-19 45q0 14 16 44t32 70t16 78h-544q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h1600q66 0 113 -47t47 -113z" /> +<glyph unicode="" horiz-adv-x="1920" d="M416 256q-66 0 -113 47t-47 113v704q0 66 47 113t113 47h1088q66 0 113 -47t47 -113v-704q0 -66 -47 -113t-113 -47h-1088zM384 1120v-704q0 -13 9.5 -22.5t22.5 -9.5h1088q13 0 22.5 9.5t9.5 22.5v704q0 13 -9.5 22.5t-22.5 9.5h-1088q-13 0 -22.5 -9.5t-9.5 -22.5z M1760 192h160v-96q0 -40 -47 -68t-113 -28h-1600q-66 0 -113 28t-47 68v96h160h1600zM1040 96q16 0 16 16t-16 16h-160q-16 0 -16 -16t16 -16h160z" /> +<glyph unicode="" horiz-adv-x="1152" d="M640 128q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1024 288v960q0 13 -9.5 22.5t-22.5 9.5h-832q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h832q13 0 22.5 9.5t9.5 22.5zM1152 1248v-1088q0 -66 -47 -113t-113 -47h-832 q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h832q66 0 113 -47t47 -113z" /> +<glyph unicode="" horiz-adv-x="768" d="M464 128q0 33 -23.5 56.5t-56.5 23.5t-56.5 -23.5t-23.5 -56.5t23.5 -56.5t56.5 -23.5t56.5 23.5t23.5 56.5zM672 288v704q0 13 -9.5 22.5t-22.5 9.5h-512q-13 0 -22.5 -9.5t-9.5 -22.5v-704q0 -13 9.5 -22.5t22.5 -9.5h512q13 0 22.5 9.5t9.5 22.5zM480 1136 q0 16 -16 16h-160q-16 0 -16 -16t16 -16h160q16 0 16 16zM768 1152v-1024q0 -52 -38 -90t-90 -38h-512q-52 0 -90 38t-38 90v1024q0 52 38 90t90 38h512q52 0 90 -38t38 -90z" /> +<glyph unicode="" d="M768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103 t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M768 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z M1664 576v-384q0 -80 -56 -136t-136 -56h-384q-80 0 -136 56t-56 136v704q0 104 40.5 198.5t109.5 163.5t163.5 109.5t198.5 40.5h64q26 0 45 -19t19 -45v-128q0 -26 -19 -45t-45 -19h-64q-106 0 -181 -75t-75 -181v-32q0 -40 28 -68t68 -28h224q80 0 136 -56t56 -136z" /> +<glyph unicode="" horiz-adv-x="1664" d="M768 1216v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136zM1664 1216 v-704q0 -104 -40.5 -198.5t-109.5 -163.5t-163.5 -109.5t-198.5 -40.5h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64q106 0 181 75t75 181v32q0 40 -28 68t-68 28h-224q-80 0 -136 56t-56 136v384q0 80 56 136t136 56h384q80 0 136 -56t56 -136z" /> +<glyph unicode="" horiz-adv-x="1568" d="M496 192q0 -60 -42.5 -102t-101.5 -42q-60 0 -102 42t-42 102t42 102t102 42q59 0 101.5 -42t42.5 -102zM928 0q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM320 640q0 -66 -47 -113t-113 -47t-113 47t-47 113 t47 113t113 47t113 -47t47 -113zM1360 192q0 -46 -33 -79t-79 -33t-79 33t-33 79t33 79t79 33t79 -33t33 -79zM528 1088q0 -73 -51.5 -124.5t-124.5 -51.5t-124.5 51.5t-51.5 124.5t51.5 124.5t124.5 51.5t124.5 -51.5t51.5 -124.5zM992 1280q0 -80 -56 -136t-136 -56 t-136 56t-56 136t56 136t136 56t136 -56t56 -136zM1536 640q0 -40 -28 -68t-68 -28t-68 28t-28 68t28 68t68 28t68 -28t28 -68zM1328 1088q0 -33 -23.5 -56.5t-56.5 -23.5t-56.5 23.5t-23.5 56.5t23.5 56.5t56.5 23.5t56.5 -23.5t23.5 -56.5z" /> +<glyph unicode="" d="M1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 416q0 -166 -127 -451q-3 -7 -10.5 -24t-13.5 -30t-13 -22q-12 -17 -28 -17q-15 0 -23.5 10t-8.5 25q0 9 2.5 26.5t2.5 23.5q5 68 5 123q0 101 -17.5 181t-48.5 138.5t-80 101t-105.5 69.5t-133 42.5t-154 21.5t-175.5 6h-224v-256q0 -26 -19 -45t-45 -19t-45 19 l-512 512q-19 19 -19 45t19 45l512 512q19 19 45 19t45 -19t19 -45v-256h224q713 0 875 -403q53 -134 53 -333z" /> +<glyph unicode="" horiz-adv-x="1664" d="M640 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1280 320q0 -40 -12.5 -82t-43 -76t-72.5 -34t-72.5 34t-43 76t-12.5 82t12.5 82t43 76t72.5 34t72.5 -34t43 -76t12.5 -82zM1440 320 q0 120 -69 204t-187 84q-41 0 -195 -21q-71 -11 -157 -11t-157 11q-152 21 -195 21q-118 0 -187 -84t-69 -204q0 -88 32 -153.5t81 -103t122 -60t140 -29.5t149 -7h168q82 0 149 7t140 29.5t122 60t81 103t32 153.5zM1664 496q0 -207 -61 -331q-38 -77 -105.5 -133t-141 -86 t-170 -47.5t-171.5 -22t-167 -4.5q-78 0 -142 3t-147.5 12.5t-152.5 30t-137 51.5t-121 81t-86 115q-62 123 -62 331q0 237 136 396q-27 82 -27 170q0 116 51 218q108 0 190 -39.5t189 -123.5q147 35 309 35q148 0 280 -32q105 82 187 121t189 39q51 -102 51 -218 q0 -87 -27 -168q136 -160 136 -398z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1536 224v704q0 40 -28 68t-68 28h-704q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68v-960q0 -40 28 -68t68 -28h1216q40 0 68 28t28 68zM1664 928v-704q0 -92 -66 -158t-158 -66h-1216q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320 q92 0 158 -66t66 -158v-32h672q92 0 158 -66t66 -158z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1781 605q0 35 -53 35h-1088q-40 0 -85.5 -21.5t-71.5 -52.5l-294 -363q-18 -24 -18 -40q0 -35 53 -35h1088q40 0 86 22t71 53l294 363q18 22 18 39zM640 768h768v160q0 40 -28 68t-68 28h-576q-40 0 -68 28t-28 68v64q0 40 -28 68t-68 28h-320q-40 0 -68 -28t-28 -68 v-853l256 315q44 53 116 87.5t140 34.5zM1909 605q0 -62 -46 -120l-295 -363q-43 -53 -116 -87.5t-140 -34.5h-1088q-92 0 -158 66t-66 158v960q0 92 66 158t158 66h320q92 0 158 -66t66 -158v-32h544q92 0 158 -66t66 -158v-160h192q54 0 99 -24.5t67 -70.5q15 -32 15 -68z " /> +<glyph unicode="" horiz-adv-x="1792" /> +<glyph unicode="" horiz-adv-x="1792" /> +<glyph unicode="" d="M1134 461q-37 -121 -138 -195t-228 -74t-228 74t-138 195q-8 25 4 48.5t38 31.5q25 8 48.5 -4t31.5 -38q25 -80 92.5 -129.5t151.5 -49.5t151.5 49.5t92.5 129.5q8 26 32 38t49 4t37 -31.5t4 -48.5zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5 t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5 t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1134 307q8 -25 -4 -48.5t-37 -31.5t-49 4t-32 38q-25 80 -92.5 129.5t-151.5 49.5t-151.5 -49.5t-92.5 -129.5q-8 -26 -31.5 -38t-48.5 -4q-26 8 -38 31.5t-4 48.5q37 121 138 195t228 74t228 -74t138 -195zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204 t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1152 448q0 -26 -19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h640q26 0 45 -19t19 -45zM640 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1152 896q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5t37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M832 448v128q0 14 -9 23t-23 9h-192v192q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-192h-192q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h192v-192q0 -14 9 -23t23 -9h128q14 0 23 9t9 23v192h192q14 0 23 9t9 23zM1408 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5 t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 640q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1920 512q0 -212 -150 -362t-362 -150q-192 0 -338 128h-220q-146 -128 -338 -128q-212 0 -362 150 t-150 362t150 362t362 150h896q212 0 362 -150t150 -362z" /> +<glyph unicode="" horiz-adv-x="1920" d="M384 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM512 624v-96q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h224q16 0 16 -16zM384 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 368v-96q0 -16 -16 -16 h-864q-16 0 -16 16v96q0 16 16 16h864q16 0 16 -16zM768 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM640 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1024 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16 h96q16 0 16 -16zM896 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1280 624v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 368v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1152 880v-96 q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1408 880v-96q0 -16 -16 -16h-96q-16 0 -16 16v96q0 16 16 16h96q16 0 16 -16zM1664 880v-352q0 -16 -16 -16h-224q-16 0 -16 16v96q0 16 16 16h112v240q0 16 16 16h96q16 0 16 -16zM1792 128v896h-1664v-896 h1664zM1920 1024v-896q0 -53 -37.5 -90.5t-90.5 -37.5h-1664q-53 0 -90.5 37.5t-37.5 90.5v896q0 53 37.5 90.5t90.5 37.5h1664q53 0 90.5 -37.5t37.5 -90.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1664 491v616q-169 -91 -306 -91q-82 0 -145 32q-100 49 -184 76.5t-178 27.5q-173 0 -403 -127v-599q245 113 433 113q55 0 103.5 -7.5t98 -26t77 -31t82.5 -39.5l28 -14q44 -22 101 -22q120 0 293 92zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9 h-64q-14 0 -23 9t-9 23v1266q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102 q-15 -9 -33 -9q-16 0 -32 8q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" /> +<glyph unicode="" horiz-adv-x="1792" d="M832 536v192q-181 -16 -384 -117v-185q205 96 384 110zM832 954v197q-172 -8 -384 -126v-189q215 111 384 118zM1664 491v184q-235 -116 -384 -71v224q-20 6 -39 15q-5 3 -33 17t-34.5 17t-31.5 15t-34.5 15.5t-32.5 13t-36 12.5t-35 8.5t-39.5 7.5t-39.5 4t-44 2 q-23 0 -49 -3v-222h19q102 0 192.5 -29t197.5 -82q19 -9 39 -15v-188q42 -17 91 -17q120 0 293 92zM1664 918v189q-169 -91 -306 -91q-45 0 -78 8v-196q148 -42 384 90zM320 1280q0 -35 -17.5 -64t-46.5 -46v-1266q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v1266 q-29 17 -46.5 46t-17.5 64q0 53 37.5 90.5t90.5 37.5t90.5 -37.5t37.5 -90.5zM1792 1216v-763q0 -39 -35 -57q-10 -5 -17 -9q-218 -116 -369 -116q-88 0 -158 35l-28 14q-64 33 -99 48t-91 29t-114 14q-102 0 -235.5 -44t-228.5 -102q-15 -9 -33 -9q-16 0 -32 8 q-32 19 -32 56v742q0 35 31 55q35 21 78.5 42.5t114 52t152.5 49.5t155 19q112 0 209 -31t209 -86q38 -19 89 -19q122 0 310 112q22 12 31 17q31 16 62 -2q31 -20 31 -55z" /> +<glyph unicode="" horiz-adv-x="1664" d="M585 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23zM1664 96v-64q0 -14 -9 -23t-23 -9h-960q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h960q14 0 23 -9 t9 -23z" /> +<glyph unicode="" horiz-adv-x="1920" d="M617 137l-50 -50q-10 -10 -23 -10t-23 10l-466 466q-10 10 -10 23t10 23l466 466q10 10 23 10t23 -10l50 -50q10 -10 10 -23t-10 -23l-393 -393l393 -393q10 -10 10 -23t-10 -23zM1208 1204l-373 -1291q-4 -13 -15.5 -19.5t-23.5 -2.5l-62 17q-13 4 -19.5 15.5t-2.5 24.5 l373 1291q4 13 15.5 19.5t23.5 2.5l62 -17q13 -4 19.5 -15.5t2.5 -24.5zM1865 553l-466 -466q-10 -10 -23 -10t-23 10l-50 50q-10 10 -10 23t10 23l393 393l-393 393q-10 10 -10 23t10 23l50 50q10 10 23 10t23 -10l466 -466q10 -10 10 -23t-10 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M640 454v-70q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-69l-397 -398q-19 -19 -19 -45t19 -45zM1792 416q0 -58 -17 -133.5t-38.5 -138t-48 -125t-40.5 -90.5l-20 -40q-8 -17 -28 -17q-6 0 -9 1 q-25 8 -23 34q43 400 -106 565q-64 71 -170.5 110.5t-267.5 52.5v-251q0 -42 -39 -59q-13 -5 -25 -5q-27 0 -45 19l-512 512q-19 19 -19 45t19 45l512 512q29 31 70 14q39 -17 39 -59v-262q411 -28 599 -221q169 -173 169 -509z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1186 579l257 250l-356 52l-66 10l-30 60l-159 322v-963l59 -31l318 -168l-60 355l-12 66zM1638 841l-363 -354l86 -500q5 -33 -6 -51.5t-34 -18.5q-17 0 -40 12l-449 236l-449 -236q-23 -12 -40 -12q-23 0 -34 18.5t-6 51.5l86 500l-364 354q-32 32 -23 59.5t54 34.5 l502 73l225 455q20 41 49 41q28 0 49 -41l225 -455l502 -73q45 -7 54 -34.5t-24 -59.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1401 1187l-640 -1280q-17 -35 -57 -35q-5 0 -15 2q-22 5 -35.5 22.5t-13.5 39.5v576h-576q-22 0 -39.5 13.5t-22.5 35.5t4 42t29 30l1280 640q13 7 29 7q27 0 45 -19q15 -14 18.5 -34.5t-6.5 -39.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M557 256h595v595zM512 301l595 595h-595v-595zM1664 224v-192q0 -14 -9 -23t-23 -9h-224v-224q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v224h-864q-14 0 -23 9t-9 23v864h-224q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h224v224q0 14 9 23t23 9h192q14 0 23 -9t9 -23 v-224h851l246 247q10 9 23 9t23 -9q9 -10 9 -23t-9 -23l-247 -246v-851h224q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1024" d="M288 64q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM288 1216q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM928 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1024 1088q0 -52 -26 -96.5t-70 -69.5 q-2 -287 -226 -414q-68 -38 -203 -81q-128 -40 -169.5 -71t-41.5 -100v-26q44 -25 70 -69.5t26 -96.5q0 -80 -56 -136t-136 -56t-136 56t-56 136q0 52 26 96.5t70 69.5v820q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136q0 -52 -26 -96.5t-70 -69.5v-497 q54 26 154 57q55 17 87.5 29.5t70.5 31t59 39.5t40.5 51t28 69.5t8.5 91.5q-44 25 -70 69.5t-26 96.5q0 80 56 136t136 56t136 -56t56 -136z" /> +<glyph unicode="" horiz-adv-x="1664" d="M439 265l-256 -256q-10 -9 -23 -9q-12 0 -23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23zM608 224v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM384 448q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9t-9 23t9 23t23 9h320 q14 0 23 -9t9 -23zM1648 320q0 -120 -85 -203l-147 -146q-83 -83 -203 -83q-121 0 -204 85l-334 335q-21 21 -42 56l239 18l273 -274q27 -27 68 -27.5t68 26.5l147 146q28 28 28 67q0 40 -28 68l-274 275l18 239q35 -21 56 -42l336 -336q84 -86 84 -204zM1031 1044l-239 -18 l-273 274q-28 28 -68 28q-39 0 -68 -27l-147 -146q-28 -28 -28 -67q0 -40 28 -68l274 -274l-18 -240q-35 21 -56 42l-336 336q-84 86 -84 204q0 120 85 203l147 146q83 83 203 83q121 0 204 -85l334 -335q21 -21 42 -56zM1664 960q0 -14 -9 -23t-23 -9h-320q-14 0 -23 9 t-9 23t9 23t23 9h320q14 0 23 -9t9 -23zM1120 1504v-320q0 -14 -9 -23t-23 -9t-23 9t-9 23v320q0 14 9 23t23 9t23 -9t9 -23zM1527 1353l-256 -256q-11 -9 -23 -9t-23 9q-9 10 -9 23t9 23l256 256q10 9 23 9t23 -9q9 -10 9 -23t-9 -23z" /> +<glyph unicode="" horiz-adv-x="1024" d="M704 280v-240q0 -16 -12 -28t-28 -12h-240q-16 0 -28 12t-12 28v240q0 16 12 28t28 12h240q16 0 28 -12t12 -28zM1020 880q0 -54 -15.5 -101t-35 -76.5t-55 -59.5t-57.5 -43.5t-61 -35.5q-41 -23 -68.5 -65t-27.5 -67q0 -17 -12 -32.5t-28 -15.5h-240q-15 0 -25.5 18.5 t-10.5 37.5v45q0 83 65 156.5t143 108.5q59 27 84 56t25 76q0 42 -46.5 74t-107.5 32q-65 0 -108 -29q-35 -25 -107 -115q-13 -16 -31 -16q-12 0 -25 8l-164 125q-13 10 -15.5 25t5.5 28q160 266 464 266q80 0 161 -31t146 -83t106 -127.5t41 -158.5z" /> +<glyph unicode="" horiz-adv-x="640" d="M640 192v-128q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h64v384h-64q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h384q26 0 45 -19t19 -45v-576h64q26 0 45 -19t19 -45zM512 1344v-192q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v192 q0 26 19 45t45 19h256q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="640" d="M512 288v-224q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v224q0 26 19 45t45 19h256q26 0 45 -19t19 -45zM542 1344l-28 -768q-1 -26 -20.5 -45t-45.5 -19h-256q-26 0 -45.5 19t-20.5 45l-28 768q-1 26 17.5 45t44.5 19h320q26 0 44.5 -19t17.5 -45z" /> +<glyph unicode="" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1534 846v-206h-514l-3 27 q-4 28 -4 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q83 65 188 65q110 0 178 -59.5t68 -158.5q0 -56 -24.5 -103t-62 -76.5t-81.5 -58.5t-82 -50.5t-65.5 -51.5t-30.5 -63h232v80 h126z" /> +<glyph unicode="" d="M897 167v-167h-248l-159 252l-24 42q-8 9 -11 21h-3l-9 -21q-10 -20 -25 -44l-155 -250h-258v167h128l197 291l-185 272h-137v168h276l139 -228q2 -4 23 -42q8 -9 11 -21h3q3 9 11 21l25 42l140 228h257v-168h-125l-184 -267l204 -296h109zM1536 -50v-206h-514l-4 27 q-3 45 -3 46q0 64 26 117t65 86.5t84 65t84 54.5t65 54t26 64q0 38 -29.5 62.5t-70.5 24.5q-51 0 -97 -39q-14 -11 -36 -38l-105 92q26 37 63 66q80 65 188 65q110 0 178 -59.5t68 -158.5q0 -66 -34.5 -118.5t-84 -86t-99.5 -62.5t-87 -63t-41 -73h232v80h126z" /> +<glyph unicode="" horiz-adv-x="1920" d="M896 128l336 384h-768l-336 -384h768zM1909 1205q15 -34 9.5 -71.5t-30.5 -65.5l-896 -1024q-38 -44 -96 -44h-768q-38 0 -69.5 20.5t-47.5 54.5q-15 34 -9.5 71.5t30.5 65.5l896 1024q38 44 96 44h768q38 0 69.5 -20.5t47.5 -54.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1664 438q0 -81 -44.5 -135t-123.5 -54q-41 0 -77.5 17.5t-59 38t-56.5 38t-71 17.5q-110 0 -110 -124q0 -39 16 -115t15 -115v-5q-22 0 -33 -1q-34 -3 -97.5 -11.5t-115.5 -13.5t-98 -5q-61 0 -103 26.5t-42 83.5q0 37 17.5 71t38 56.5t38 59t17.5 77.5q0 79 -54 123.5 t-135 44.5q-84 0 -143 -45.5t-59 -127.5q0 -43 15 -83t33.5 -64.5t33.5 -53t15 -50.5q0 -45 -46 -89q-37 -35 -117 -35q-95 0 -245 24q-9 2 -27.5 4t-27.5 4l-13 2q-1 0 -3 1q-2 0 -2 1v1024q2 -1 17.5 -3.5t34 -5t21.5 -3.5q150 -24 245 -24q80 0 117 35q46 44 46 89 q0 22 -15 50.5t-33.5 53t-33.5 64.5t-15 83q0 82 59 127.5t144 45.5q80 0 134 -44.5t54 -123.5q0 -41 -17.5 -77.5t-38 -59t-38 -56.5t-17.5 -71q0 -57 42 -83.5t103 -26.5q64 0 180 15t163 17v-2q-1 -2 -3.5 -17.5t-5 -34t-3.5 -21.5q-24 -150 -24 -245q0 -80 35 -117 q44 -46 89 -46q22 0 50.5 15t53 33.5t64.5 33.5t83 15q82 0 127.5 -59t45.5 -143z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1152 832v-128q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-217 24 -364.5 187.5t-147.5 384.5v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -185 131.5 -316.5t316.5 -131.5 t316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45zM896 1216v-512q0 -132 -94 -226t-226 -94t-226 94t-94 226v512q0 132 94 226t226 94t226 -94t94 -226z" /> +<glyph unicode="" horiz-adv-x="1408" d="M271 591l-101 -101q-42 103 -42 214v128q0 26 19 45t45 19t45 -19t19 -45v-128q0 -53 15 -113zM1385 1193l-361 -361v-128q0 -132 -94 -226t-226 -94q-55 0 -109 19l-96 -96q97 -51 205 -51q185 0 316.5 131.5t131.5 316.5v128q0 26 19 45t45 19t45 -19t19 -45v-128 q0 -221 -147.5 -384.5t-364.5 -187.5v-132h256q26 0 45 -19t19 -45t-19 -45t-45 -19h-640q-26 0 -45 19t-19 45t19 45t45 19h256v132q-125 13 -235 81l-254 -254q-10 -10 -23 -10t-23 10l-82 82q-10 10 -10 23t10 23l1234 1234q10 10 23 10t23 -10l82 -82q10 -10 10 -23 t-10 -23zM1005 1325l-621 -621v512q0 132 94 226t226 94q102 0 184.5 -59t116.5 -152z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1088 576v640h-448v-1137q119 63 213 137q235 184 235 360zM1280 1344v-768q0 -86 -33.5 -170.5t-83 -150t-118 -127.5t-126.5 -103t-121 -77.5t-89.5 -49.5t-42.5 -20q-12 -6 -26 -6t-26 6q-16 7 -42.5 20t-89.5 49.5t-121 77.5t-126.5 103t-118 127.5t-83 150 t-33.5 170.5v768q0 26 19 45t45 19h1152q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M128 -128h1408v1024h-1408v-1024zM512 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1280 1088v288q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-288q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1664 1152v-1280 q0 -52 -38 -90t-90 -38h-1408q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h128v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h384v96q0 66 47 113t113 47h64q66 0 113 -47t47 -113v-96h128q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="1408" d="M512 1344q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1408 1376v-320q0 -16 -12 -25q-8 -7 -20 -7q-4 0 -7 1l-448 96q-11 2 -18 11t-7 20h-256v-102q111 -23 183.5 -111t72.5 -203v-800q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v800 q0 106 62.5 190.5t161.5 114.5v111h-32q-59 0 -115 -23.5t-91.5 -53t-66 -66.5t-40.5 -53.5t-14 -24.5q-17 -35 -57 -35q-16 0 -29 7q-23 12 -31.5 37t3.5 49q5 10 14.5 26t37.5 53.5t60.5 70t85 67t108.5 52.5q-25 42 -25 86q0 66 47 113t113 47t113 -47t47 -113 q0 -33 -14 -64h302q0 11 7 20t18 11l448 96q3 1 7 1q12 0 20 -7q12 -9 12 -25z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1440 1088q0 40 -28 68t-68 28t-68 -28t-28 -68t28 -68t68 -28t68 28t28 68zM1664 1376q0 -249 -75.5 -430.5t-253.5 -360.5q-81 -80 -195 -176l-20 -379q-2 -16 -16 -26l-384 -224q-7 -4 -16 -4q-12 0 -23 9l-64 64q-13 14 -8 32l85 276l-281 281l-276 -85q-3 -1 -9 -1 q-14 0 -23 9l-64 64q-17 19 -5 39l224 384q10 14 26 16l379 20q96 114 176 195q188 187 358 258t431 71q14 0 24 -9.5t10 -22.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1745 763l-164 -763h-334l178 832q13 56 -15 88q-27 33 -83 33h-169l-204 -953h-334l204 953h-286l-204 -953h-334l204 953l-153 327h1276q101 0 189.5 -40.5t147.5 -113.5q60 -73 81 -168.5t0 -194.5z" /> +<glyph unicode="" d="M909 141l102 102q19 19 19 45t-19 45l-307 307l307 307q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M717 141l454 454q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l307 -307l-307 -307q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1165 397l102 102q19 19 19 45t-19 45l-454 454q-19 19 -45 19t-45 -19l-454 -454q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l307 307l307 -307q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M813 237l454 454q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-307 -307l-307 307q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l454 -454q19 -19 45 -19t45 19zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5 t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1130 939l16 175h-884l47 -534h612l-22 -228l-197 -53l-196 53l-13 140h-175l22 -278l362 -100h4v1l359 99l50 544h-644l-15 181h674zM0 1408h1408l-128 -1438l-578 -162l-574 162z" /> +<glyph unicode="" horiz-adv-x="1792" d="M275 1408h1505l-266 -1333l-804 -267l-698 267l71 356h297l-29 -147l422 -161l486 161l68 339h-1208l58 297h1209l38 191h-1208z" /> +<glyph unicode="" horiz-adv-x="1792" d="M960 1280q0 26 -19 45t-45 19t-45 -19t-19 -45t19 -45t45 -19t45 19t19 45zM1792 352v-352q0 -22 -20 -30q-8 -2 -12 -2q-13 0 -23 9l-93 93q-119 -143 -318.5 -226.5t-429.5 -83.5t-429.5 83.5t-318.5 226.5l-93 -93q-9 -9 -23 -9q-4 0 -12 2q-20 8 -20 30v352 q0 14 9 23t23 9h352q22 0 30 -20q8 -19 -7 -35l-100 -100q67 -91 189.5 -153.5t271.5 -82.5v647h-192q-26 0 -45 19t-19 45v128q0 26 19 45t45 19h192v163q-58 34 -93 92.5t-35 128.5q0 106 75 181t181 75t181 -75t75 -181q0 -70 -35 -128.5t-93 -92.5v-163h192q26 0 45 -19 t19 -45v-128q0 -26 -19 -45t-45 -19h-192v-647q149 20 271.5 82.5t189.5 153.5l-100 100q-15 16 -7 35q8 20 30 20h352q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1056 768q40 0 68 -28t28 -68v-576q0 -40 -28 -68t-68 -28h-960q-40 0 -68 28t-28 68v576q0 40 28 68t68 28h32v320q0 185 131.5 316.5t316.5 131.5t316.5 -131.5t131.5 -316.5q0 -26 -19 -45t-45 -19h-64q-26 0 -45 19t-19 45q0 106 -75 181t-181 75t-181 -75t-75 -181 v-320h736z" /> +<glyph unicode="" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM1152 640q0 159 -112.5 271.5t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5t271.5 -112.5t271.5 112.5t112.5 271.5zM1280 640q0 -212 -150 -362t-362 -150t-362 150 t-150 362t150 362t362 150t362 -150t150 -362zM1408 640q0 130 -51 248.5t-136.5 204t-204 136.5t-248.5 51t-248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5zM1536 640 q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM896 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM1408 800v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" /> +<glyph unicode="" horiz-adv-x="384" d="M384 288v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 800v-192q0 -40 -28 -68t-68 -28h-192q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68zM384 1312v-192q0 -40 -28 -68t-68 -28h-192 q-40 0 -68 28t-28 68v192q0 40 28 68t68 28h192q40 0 68 -28t28 -68z" /> +<glyph unicode="" d="M512 256q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM863 162q-13 232 -177 396t-396 177q-14 1 -24 -9t-10 -23v-128q0 -13 8.5 -22t21.5 -10q154 -11 264 -121t121 -264q1 -13 10 -21.5t22 -8.5h128q13 0 23 10 t9 24zM1247 161q-5 154 -56 297.5t-139.5 260t-205 205t-260 139.5t-297.5 56q-14 1 -23 -9q-10 -10 -10 -23v-128q0 -13 9 -22t22 -10q204 -7 378 -111.5t278.5 -278.5t111.5 -378q1 -13 10 -22t22 -9h128q13 0 23 10q11 9 9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M768 1408q209 0 385.5 -103t279.5 -279.5t103 -385.5t-103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103zM1152 585q32 18 32 55t-32 55l-544 320q-31 19 -64 1q-32 -19 -32 -56v-640q0 -37 32 -56 q16 -8 32 -8q17 0 32 9z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1024 1084l316 -316l-572 -572l-316 316zM813 105l618 618q19 19 19 45t-19 45l-362 362q-18 18 -45 18t-45 -18l-618 -618q-19 -19 -19 -45t19 -45l362 -362q18 -18 45 -18t45 18zM1702 742l-907 -908q-37 -37 -90.5 -37t-90.5 37l-126 126q56 56 56 136t-56 136 t-136 56t-136 -56l-125 126q-37 37 -37 90.5t37 90.5l907 906q37 37 90.5 37t90.5 -37l125 -125q-56 -56 -56 -136t56 -136t136 -56t136 56l126 -125q37 -37 37 -90.5t-37 -90.5z" /> +<glyph unicode="" d="M1280 576v128q0 26 -19 45t-45 19h-896q-26 0 -45 -19t-19 -45v-128q0 -26 19 -45t45 -19h896q26 0 45 19t19 45zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5 t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h832q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5 t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1018 933q-18 -37 -58 -37h-192v-864q0 -14 -9 -23t-23 -9h-704q-21 0 -29 18q-8 20 4 35l160 192q9 11 25 11h320v640h-192q-40 0 -58 37q-17 37 9 68l320 384q18 22 49 22t49 -22l320 -384q27 -32 9 -68z" /> +<glyph unicode="" horiz-adv-x="1024" d="M32 1280h704q13 0 22.5 -9.5t9.5 -23.5v-863h192q40 0 58 -37t-9 -69l-320 -384q-18 -22 -49 -22t-49 22l-320 384q-26 31 -9 69q18 37 58 37h192v640h-320q-14 0 -25 11l-160 192q-13 14 -4 34q9 19 29 19z" /> +<glyph unicode="" d="M685 237l614 614q19 19 19 45t-19 45l-102 102q-19 19 -45 19t-45 -19l-467 -467l-211 211q-19 19 -45 19t-45 -19l-102 -102q-19 -19 -19 -45t19 -45l358 -358q19 -19 45 -19t45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5 t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M404 428l152 -152l-52 -52h-56v96h-96v56zM818 818q14 -13 -3 -30l-291 -291q-17 -17 -30 -3q-14 13 3 30l291 291q17 17 30 3zM544 128l544 544l-288 288l-544 -544v-288h288zM1152 736l92 92q28 28 28 68t-28 68l-152 152q-28 28 -68 28t-68 -28l-92 -92zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1280 608v480q0 26 -19 45t-45 19h-480q-42 0 -59 -39q-17 -41 14 -70l144 -144l-534 -534q-19 -19 -19 -45t19 -45l102 -102q19 -19 45 -19t45 19l534 534l144 -144q18 -19 45 -19q12 0 25 5q39 17 39 59zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1005 435l352 352q19 19 19 45t-19 45l-352 352q-30 31 -69 14q-40 -17 -40 -59v-160q-119 0 -216 -19.5t-162.5 -51t-114 -79t-76.5 -95.5t-44.5 -109t-21.5 -111.5t-5 -110.5q0 -181 167 -404q10 -12 25 -12q7 0 13 3q22 9 19 33q-44 354 62 473q46 52 130 75.5 t224 23.5v-160q0 -42 40 -59q12 -5 24 -5q26 0 45 19zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M640 448l256 128l-256 128v-256zM1024 1039v-542l-512 -256v542zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1145 861q18 -35 -5 -66l-320 -448q-19 -27 -52 -27t-52 27l-320 448q-23 31 -5 66q17 35 57 35h640q40 0 57 -35zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1145 419q-17 -35 -57 -35h-640q-40 0 -57 35q-18 35 5 66l320 448q19 27 52 27t52 -27l320 -448q23 -31 5 -66zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1088 640q0 -33 -27 -52l-448 -320q-31 -23 -66 -5q-35 17 -35 57v640q0 40 35 57q35 18 66 -5l448 -320q27 -19 27 -52zM1280 160v960q0 14 -9 23t-23 9h-960q-14 0 -23 -9t-9 -23v-960q0 -14 9 -23t23 -9h960q14 0 23 9t9 23zM1536 1120v-960q0 -119 -84.5 -203.5 t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M976 229l35 -159q3 -12 -3 -22.5t-17 -14.5l-5 -1q-4 -2 -10.5 -3.5t-16 -4.5t-21.5 -5.5t-25.5 -5t-30 -5t-33.5 -4.5t-36.5 -3t-38.5 -1q-234 0 -409 130.5t-238 351.5h-95q-13 0 -22.5 9.5t-9.5 22.5v113q0 13 9.5 22.5t22.5 9.5h66q-2 57 1 105h-67q-14 0 -23 9 t-9 23v114q0 14 9 23t23 9h98q67 210 243.5 338t400.5 128q102 0 194 -23q11 -3 20 -15q6 -11 3 -24l-43 -159q-3 -13 -14 -19.5t-24 -2.5l-4 1q-4 1 -11.5 2.5l-17.5 3.5t-22.5 3.5t-26 3t-29 2.5t-29.5 1q-126 0 -226 -64t-150 -176h468q16 0 25 -12q10 -12 7 -26 l-24 -114q-5 -26 -32 -26h-488q-3 -37 0 -105h459q15 0 25 -12q9 -12 6 -27l-24 -112q-2 -11 -11 -18.5t-20 -7.5h-387q48 -117 149.5 -185.5t228.5 -68.5q18 0 36 1.5t33.5 3.5t29.5 4.5t24.5 5t18.5 4.5l12 3l5 2q13 5 26 -2q12 -7 15 -21z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1020 399v-367q0 -14 -9 -23t-23 -9h-956q-14 0 -23 9t-9 23v150q0 13 9.5 22.5t22.5 9.5h97v383h-95q-14 0 -23 9.5t-9 22.5v131q0 14 9 23t23 9h95v223q0 171 123.5 282t314.5 111q185 0 335 -125q9 -8 10 -20.5t-7 -22.5l-103 -127q-9 -11 -22 -12q-13 -2 -23 7 q-5 5 -26 19t-69 32t-93 18q-85 0 -137 -47t-52 -123v-215h305q13 0 22.5 -9t9.5 -23v-131q0 -13 -9.5 -22.5t-22.5 -9.5h-305v-379h414v181q0 13 9 22.5t23 9.5h162q14 0 23 -9.5t9 -22.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M978 351q0 -153 -99.5 -263.5t-258.5 -136.5v-175q0 -14 -9 -23t-23 -9h-135q-13 0 -22.5 9.5t-9.5 22.5v175q-66 9 -127.5 31t-101.5 44.5t-74 48t-46.5 37.5t-17.5 18q-17 21 -2 41l103 135q7 10 23 12q15 2 24 -9l2 -2q113 -99 243 -125q37 -8 74 -8q81 0 142.5 43 t61.5 122q0 28 -15 53t-33.5 42t-58.5 37.5t-66 32t-80 32.5q-39 16 -61.5 25t-61.5 26.5t-62.5 31t-56.5 35.5t-53.5 42.5t-43.5 49t-35.5 58t-21 66.5t-8.5 78q0 138 98 242t255 134v180q0 13 9.5 22.5t22.5 9.5h135q14 0 23 -9t9 -23v-176q57 -6 110.5 -23t87 -33.5 t63.5 -37.5t39 -29t15 -14q17 -18 5 -38l-81 -146q-8 -15 -23 -16q-14 -3 -27 7q-3 3 -14.5 12t-39 26.5t-58.5 32t-74.5 26t-85.5 11.5q-95 0 -155 -43t-60 -111q0 -26 8.5 -48t29.5 -41.5t39.5 -33t56 -31t60.5 -27t70 -27.5q53 -20 81 -31.5t76 -35t75.5 -42.5t62 -50 t53 -63.5t31.5 -76.5t13 -94z" /> +<glyph unicode="" horiz-adv-x="898" d="M898 1066v-102q0 -14 -9 -23t-23 -9h-168q-23 -144 -129 -234t-276 -110q167 -178 459 -536q14 -16 4 -34q-8 -18 -29 -18h-195q-16 0 -25 12q-306 367 -498 571q-9 9 -9 22v127q0 13 9.5 22.5t22.5 9.5h112q132 0 212.5 43t102.5 125h-427q-14 0 -23 9t-9 23v102 q0 14 9 23t23 9h413q-57 113 -268 113h-145q-13 0 -22.5 9.5t-9.5 22.5v133q0 14 9 23t23 9h832q14 0 23 -9t9 -23v-102q0 -14 -9 -23t-23 -9h-233q47 -61 64 -144h171q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1027" d="M603 0h-172q-13 0 -22.5 9t-9.5 23v330h-288q-13 0 -22.5 9t-9.5 23v103q0 13 9.5 22.5t22.5 9.5h288v85h-288q-13 0 -22.5 9t-9.5 23v104q0 13 9.5 22.5t22.5 9.5h214l-321 578q-8 16 0 32q10 16 28 16h194q19 0 29 -18l215 -425q19 -38 56 -125q10 24 30.5 68t27.5 61 l191 420q8 19 29 19h191q17 0 27 -16q9 -14 1 -31l-313 -579h215q13 0 22.5 -9.5t9.5 -22.5v-104q0 -14 -9.5 -23t-22.5 -9h-290v-85h290q13 0 22.5 -9.5t9.5 -22.5v-103q0 -14 -9.5 -23t-22.5 -9h-290v-330q0 -13 -9.5 -22.5t-22.5 -9.5z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1043 971q0 100 -65 162t-171 62h-320v-448h320q106 0 171 62t65 162zM1280 971q0 -193 -126.5 -315t-326.5 -122h-340v-118h505q14 0 23 -9t9 -23v-128q0 -14 -9 -23t-23 -9h-505v-192q0 -14 -9.5 -23t-22.5 -9h-167q-14 0 -23 9t-9 23v192h-224q-14 0 -23 9t-9 23v128 q0 14 9 23t23 9h224v118h-224q-14 0 -23 9t-9 23v149q0 13 9 22.5t23 9.5h224v629q0 14 9 23t23 9h539q200 0 326.5 -122t126.5 -315z" /> +<glyph unicode="" horiz-adv-x="1792" d="M514 341l81 299h-159l75 -300q1 -1 1 -3t1 -3q0 1 0.5 3.5t0.5 3.5zM630 768l35 128h-292l32 -128h225zM822 768h139l-35 128h-70zM1271 340l78 300h-162l81 -299q0 -1 0.5 -3.5t1.5 -3.5q0 1 0.5 3t0.5 3zM1382 768l33 128h-297l34 -128h230zM1792 736v-64q0 -14 -9 -23 t-23 -9h-213l-164 -616q-7 -24 -31 -24h-159q-24 0 -31 24l-166 616h-209l-167 -616q-7 -24 -31 -24h-159q-11 0 -19.5 7t-10.5 17l-160 616h-208q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h175l-33 128h-142q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h109l-89 344q-5 15 5 28 q10 12 26 12h137q26 0 31 -24l90 -360h359l97 360q7 24 31 24h126q24 0 31 -24l98 -360h365l93 360q5 24 31 24h137q16 0 26 -12q10 -13 5 -28l-91 -344h111q14 0 23 -9t9 -23v-64q0 -14 -9 -23t-23 -9h-145l-34 -128h179q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1167 896q18 -182 -131 -258q117 -28 175 -103t45 -214q-7 -71 -32.5 -125t-64.5 -89t-97 -58.5t-121.5 -34.5t-145.5 -15v-255h-154v251q-80 0 -122 1v-252h-154v255q-18 0 -54 0.5t-55 0.5h-200l31 183h111q50 0 58 51v402h16q-6 1 -16 1v287q-13 68 -89 68h-111v164 l212 -1q64 0 97 1v252h154v-247q82 2 122 2v245h154v-252q79 -7 140 -22.5t113 -45t82.5 -78t36.5 -114.5zM952 351q0 36 -15 64t-37 46t-57.5 30.5t-65.5 18.5t-74 9t-69 3t-64.5 -1t-47.5 -1v-338q8 0 37 -0.5t48 -0.5t53 1.5t58.5 4t57 8.5t55.5 14t47.5 21t39.5 30 t24.5 40t9.5 51zM881 827q0 33 -12.5 58.5t-30.5 42t-48 28t-55 16.5t-61.5 8t-58 2.5t-54 -1t-39.5 -0.5v-307q5 0 34.5 -0.5t46.5 0t50 2t55 5.5t51.5 11t48.5 18.5t37 27t27 38.5t9 51z" /> +<glyph unicode="" d="M1024 1024v472q22 -14 36 -28l408 -408q14 -14 28 -36h-472zM896 992q0 -40 28 -68t68 -28h544v-1056q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h800v-544z" /> +<glyph unicode="" d="M1468 1060q14 -14 28 -36h-472v472q22 -14 36 -28zM992 896h544v-1056q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h800v-544q0 -40 28 -68t68 -28zM1152 160v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704 q14 0 23 9t9 23zM1152 416v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23zM1152 672v64q0 14 -9 23t-23 9h-704q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h704q14 0 23 9t9 23z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1191 1128h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1572 -23 v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -11v-2l14 2q9 2 30 2h248v119h121zM1661 874v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162 l230 -662h70z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1191 104h177l-72 218l-12 47q-2 16 -2 20h-4l-3 -20q0 -1 -3.5 -18t-7.5 -29zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1661 -150 v-106h-288v106h75l-47 144h-243l-47 -144h75v-106h-287v106h70l230 662h162l230 -662h70zM1572 1001v-233h-584v90l369 529q12 18 21 27l11 9v3q-2 0 -6.5 -0.5t-7.5 -0.5q-12 -3 -30 -3h-232v-115h-120v229h567v-89l-369 -530q-6 -8 -21 -26l-11 -10v-3l14 3q9 1 30 1h248 v119h121z" /> +<glyph unicode="" horiz-adv-x="1792" d="M736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23zM1792 -32v-192q0 -14 -9 -23t-23 -9h-832q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832 q14 0 23 -9t9 -23zM1600 480v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1408 992v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1216 1504v-192q0 -14 -9 -23t-23 -9h-256 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1216 -32v-192q0 -14 -9 -23t-23 -9h-256q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h256q14 0 23 -9t9 -23zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192 q14 0 23 -9t9 -23zM1408 480v-192q0 -14 -9 -23t-23 -9h-448q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h448q14 0 23 -9t9 -23zM1600 992v-192q0 -14 -9 -23t-23 -9h-640q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h640q14 0 23 -9t9 -23zM1792 1504v-192q0 -14 -9 -23t-23 -9h-832 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h832q14 0 23 -9t9 -23z" /> +<glyph unicode="" d="M1346 223q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9t9 -23 zM1486 165q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5 t82 -252.5zM1456 882v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165z" /> +<glyph unicode="" d="M1346 1247q0 63 -44 116t-103 53q-52 0 -83 -37t-31 -94t36.5 -95t104.5 -38q50 0 85 27t35 68zM736 96q0 -12 -10 -24l-319 -319q-10 -9 -23 -9q-12 0 -23 9l-320 320q-15 16 -7 35q8 20 30 20h192v1376q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1376h192q14 0 23 -9 t9 -23zM1456 -142v-114h-469v114h167v432q0 7 0.5 19t0.5 17v16h-2l-7 -12q-8 -13 -26 -31l-62 -58l-82 86l192 185h123v-654h165zM1486 1189q0 -62 -13 -121.5t-41 -114t-68 -95.5t-98.5 -65.5t-127.5 -24.5q-62 0 -108 16q-24 8 -42 15l39 113q15 -7 31 -11q37 -13 75 -13 q84 0 134.5 58.5t66.5 145.5h-2q-21 -23 -61.5 -37t-84.5 -14q-106 0 -173 71.5t-67 172.5q0 105 72 178t181 73q123 0 205 -94.5t82 -252.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M256 192q0 26 -19 45t-45 19q-27 0 -45.5 -19t-18.5 -45q0 -27 18.5 -45.5t45.5 -18.5q26 0 45 18.5t19 45.5zM416 704v-640q0 -26 -19 -45t-45 -19h-288q-26 0 -45 19t-19 45v640q0 26 19 45t45 19h288q26 0 45 -19t19 -45zM1600 704q0 -86 -55 -149q15 -44 15 -76 q3 -76 -43 -137q17 -56 0 -117q-15 -57 -54 -94q9 -112 -49 -181q-64 -76 -197 -78h-36h-76h-17q-66 0 -144 15.5t-121.5 29t-120.5 39.5q-123 43 -158 44q-26 1 -45 19.5t-19 44.5v641q0 25 18 43.5t43 20.5q24 2 76 59t101 121q68 87 101 120q18 18 31 48t17.5 48.5 t13.5 60.5q7 39 12.5 61t19.5 52t34 50q19 19 45 19q46 0 82.5 -10.5t60 -26t40 -40.5t24 -45t12 -50t5 -45t0.5 -39q0 -38 -9.5 -76t-19 -60t-27.5 -56q-3 -6 -10 -18t-11 -22t-8 -24h277q78 0 135 -57t57 -135z" /> +<glyph unicode="" horiz-adv-x="1664" d="M256 960q0 -26 -19 -45t-45 -19q-27 0 -45.5 19t-18.5 45q0 27 18.5 45.5t45.5 18.5q26 0 45 -18.5t19 -45.5zM416 448v640q0 26 -19 45t-45 19h-288q-26 0 -45 -19t-19 -45v-640q0 -26 19 -45t45 -19h288q26 0 45 19t19 45zM1545 597q55 -61 55 -149q-1 -78 -57.5 -135 t-134.5 -57h-277q4 -14 8 -24t11 -22t10 -18q18 -37 27 -57t19 -58.5t10 -76.5q0 -24 -0.5 -39t-5 -45t-12 -50t-24 -45t-40 -40.5t-60 -26t-82.5 -10.5q-26 0 -45 19q-20 20 -34 50t-19.5 52t-12.5 61q-9 42 -13.5 60.5t-17.5 48.5t-31 48q-33 33 -101 120q-49 64 -101 121 t-76 59q-25 2 -43 20.5t-18 43.5v641q0 26 19 44.5t45 19.5q35 1 158 44q77 26 120.5 39.5t121.5 29t144 15.5h17h76h36q133 -2 197 -78q58 -69 49 -181q39 -37 54 -94q17 -61 0 -117q46 -61 43 -137q0 -32 -15 -76z" /> +<glyph unicode="" d="M919 233v157q0 50 -29 50q-17 0 -33 -16v-224q16 -16 33 -16q29 0 29 49zM1103 355h66v34q0 51 -33 51t-33 -51v-34zM532 621v-70h-80v-423h-74v423h-78v70h232zM733 495v-367h-67v40q-39 -45 -76 -45q-33 0 -42 28q-6 16 -6 54v290h66v-270q0 -24 1 -26q1 -15 15 -15 q20 0 42 31v280h67zM985 384v-146q0 -52 -7 -73q-12 -42 -53 -42q-35 0 -68 41v-36h-67v493h67v-161q32 40 68 40q41 0 53 -42q7 -21 7 -74zM1236 255v-9q0 -29 -2 -43q-3 -22 -15 -40q-27 -40 -80 -40q-52 0 -81 38q-21 27 -21 86v129q0 59 20 86q29 38 80 38t78 -38 q21 -28 21 -86v-76h-133v-65q0 -51 34 -51q24 0 30 26q0 1 0.5 7t0.5 16.5v21.5h68zM785 1079v-156q0 -51 -32 -51t-32 51v156q0 52 32 52t32 -52zM1318 366q0 177 -19 260q-10 44 -43 73.5t-76 34.5q-136 15 -412 15q-275 0 -411 -15q-44 -5 -76.5 -34.5t-42.5 -73.5 q-20 -87 -20 -260q0 -176 20 -260q10 -43 42.5 -73t75.5 -35q137 -15 412 -15t412 15q43 5 75.5 35t42.5 73q20 84 20 260zM563 1017l90 296h-75l-51 -195l-53 195h-78l24 -69t23 -69q35 -103 46 -158v-201h74v201zM852 936v130q0 58 -21 87q-29 38 -78 38q-51 0 -78 -38 q-21 -29 -21 -87v-130q0 -58 21 -87q27 -38 78 -38q49 0 78 38q21 27 21 87zM1033 816h67v370h-67v-283q-22 -31 -42 -31q-15 0 -16 16q-1 2 -1 26v272h-67v-293q0 -37 6 -55q11 -27 43 -27q36 0 77 45v-40zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960 q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M971 292v-211q0 -67 -39 -67q-23 0 -45 22v301q22 22 45 22q39 0 39 -67zM1309 291v-46h-90v46q0 68 45 68t45 -68zM343 509h107v94h-312v-94h105v-569h100v569zM631 -60h89v494h-89v-378q-30 -42 -57 -42q-18 0 -21 21q-1 3 -1 35v364h-89v-391q0 -49 8 -73 q12 -37 58 -37q48 0 102 61v-54zM1060 88v197q0 73 -9 99q-17 56 -71 56q-50 0 -93 -54v217h-89v-663h89v48q45 -55 93 -55q54 0 71 55q9 27 9 100zM1398 98v13h-91q0 -51 -2 -61q-7 -36 -40 -36q-46 0 -46 69v87h179v103q0 79 -27 116q-39 51 -106 51q-68 0 -107 -51 q-28 -37 -28 -116v-173q0 -79 29 -116q39 -51 108 -51q72 0 108 53q18 27 21 54q2 9 2 58zM790 1011v210q0 69 -43 69t-43 -69v-210q0 -70 43 -70t43 70zM1509 260q0 -234 -26 -350q-14 -59 -58 -99t-102 -46q-184 -21 -555 -21t-555 21q-58 6 -102.5 46t-57.5 99 q-26 112 -26 350q0 234 26 350q14 59 58 99t103 47q183 20 554 20t555 -20q58 -7 102.5 -47t57.5 -99q26 -112 26 -350zM511 1536h102l-121 -399v-271h-100v271q-14 74 -61 212q-37 103 -65 187h106l71 -263zM881 1203v-175q0 -81 -28 -118q-37 -51 -106 -51q-67 0 -105 51 q-28 38 -28 118v175q0 80 28 117q38 51 105 51q69 0 106 -51q28 -37 28 -117zM1216 1365v-499h-91v55q-53 -62 -103 -62q-46 0 -59 37q-8 24 -8 75v394h91v-367q0 -33 1 -35q3 -22 21 -22q27 0 57 43v381h91z" /> +<glyph unicode="" horiz-adv-x="1408" d="M597 869q-10 -18 -257 -456q-27 -46 -65 -46h-239q-21 0 -31 17t0 36l253 448q1 0 0 1l-161 279q-12 22 -1 37q9 15 32 15h239q40 0 66 -45zM1403 1511q11 -16 0 -37l-528 -934v-1l336 -615q11 -20 1 -37q-10 -15 -32 -15h-239q-42 0 -66 45l-339 622q18 32 531 942 q25 45 64 45h241q22 0 31 -15z" /> +<glyph unicode="" d="M685 771q0 1 -126 222q-21 34 -52 34h-184q-18 0 -26 -11q-7 -12 1 -29l125 -216v-1l-196 -346q-9 -14 0 -28q8 -13 24 -13h185q31 0 50 36zM1309 1268q-7 12 -24 12h-187q-30 0 -49 -35l-411 -729q1 -2 262 -481q20 -35 52 -35h184q18 0 25 12q8 13 -1 28l-260 476v1 l409 723q8 16 0 28zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1280 640q0 37 -30 54l-512 320q-31 20 -65 2q-33 -18 -33 -56v-640q0 -38 33 -56q16 -8 31 -8q20 0 34 10l512 320q30 17 30 54zM1792 640q0 -96 -1 -150t-8.5 -136.5t-22.5 -147.5q-16 -73 -69 -123t-124 -58q-222 -25 -671 -25t-671 25q-71 8 -124.5 58t-69.5 123 q-14 65 -21.5 147.5t-8.5 136.5t-1 150t1 150t8.5 136.5t22.5 147.5q16 73 69 123t124 58q222 25 671 25t671 -25q71 -8 124.5 -58t69.5 -123q14 -65 21.5 -147.5t8.5 -136.5t1 -150z" /> +<glyph unicode="" horiz-adv-x="1792" d="M402 829l494 -305l-342 -285l-490 319zM1388 274v-108l-490 -293v-1l-1 1l-1 -1v1l-489 293v108l147 -96l342 284v2l1 -1l1 1v-2l343 -284zM554 1418l342 -285l-494 -304l-338 270zM1390 829l338 -271l-489 -319l-343 285zM1239 1418l489 -319l-338 -270l-494 304z" /> +<glyph unicode="" horiz-adv-x="1408" d="M928 135v-151l-707 -1v151zM1169 481v-701l-1 -35v-1h-1132l-35 1h-1v736h121v-618h928v618h120zM241 393l704 -65l-13 -150l-705 65zM309 709l683 -183l-39 -146l-683 183zM472 1058l609 -360l-77 -130l-609 360zM832 1389l398 -585l-124 -85l-399 584zM1285 1536 l121 -697l-149 -26l-121 697z" /> +<glyph unicode="" d="M1362 110v648h-135q20 -63 20 -131q0 -126 -64 -232.5t-174 -168.5t-240 -62q-197 0 -337 135.5t-140 327.5q0 68 20 131h-141v-648q0 -26 17.5 -43.5t43.5 -17.5h1069q25 0 43 17.5t18 43.5zM1078 643q0 124 -90.5 211.5t-218.5 87.5q-127 0 -217.5 -87.5t-90.5 -211.5 t90.5 -211.5t217.5 -87.5q128 0 218.5 87.5t90.5 211.5zM1362 1003v165q0 28 -20 48.5t-49 20.5h-174q-29 0 -49 -20.5t-20 -48.5v-165q0 -29 20 -49t49 -20h174q29 0 49 20t20 49zM1536 1211v-1142q0 -81 -58 -139t-139 -58h-1142q-81 0 -139 58t-58 139v1142q0 81 58 139 t139 58h1142q81 0 139 -58t58 -139z" /> +<glyph unicode="" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960zM698 640q0 88 -62 150t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150zM1262 640q0 88 -62 150 t-150 62t-150 -62t-62 -150t62 -150t150 -62t150 62t62 150z" /> +<glyph unicode="" d="M768 914l201 -306h-402zM1133 384h94l-459 691l-459 -691h94l104 160h522zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M815 677q8 -63 -50.5 -101t-111.5 -6q-39 17 -53.5 58t-0.5 82t52 58q36 18 72.5 12t64 -35.5t27.5 -67.5zM926 698q-14 107 -113 164t-197 13q-63 -28 -100.5 -88.5t-34.5 -129.5q4 -91 77.5 -155t165.5 -56q91 8 152 84t50 168zM1165 1240q-20 27 -56 44.5t-58 22 t-71 12.5q-291 47 -566 -2q-43 -7 -66 -12t-55 -22t-50 -43q30 -28 76 -45.5t73.5 -22t87.5 -11.5q228 -29 448 -1q63 8 89.5 12t72.5 21.5t75 46.5zM1222 205q-8 -26 -15.5 -76.5t-14 -84t-28.5 -70t-58 -56.5q-86 -48 -189.5 -71.5t-202 -22t-201.5 18.5q-46 8 -81.5 18 t-76.5 27t-73 43.5t-52 61.5q-25 96 -57 292l6 16l18 9q223 -148 506.5 -148t507.5 148q21 -6 24 -23t-5 -45t-8 -37zM1403 1166q-26 -167 -111 -655q-5 -30 -27 -56t-43.5 -40t-54.5 -31q-252 -126 -610 -88q-248 27 -394 139q-15 12 -25.5 26.5t-17 35t-9 34t-6 39.5 t-5.5 35q-9 50 -26.5 150t-28 161.5t-23.5 147.5t-22 158q3 26 17.5 48.5t31.5 37.5t45 30t46 22.5t48 18.5q125 46 313 64q379 37 676 -50q155 -46 215 -122q16 -20 16.5 -51t-5.5 -54z" /> +<glyph unicode="" d="M848 666q0 43 -41 66t-77 1q-43 -20 -42.5 -72.5t43.5 -70.5q39 -23 81 4t36 72zM928 682q8 -66 -36 -121t-110 -61t-119 40t-56 113q-2 49 25.5 93t72.5 64q70 31 141.5 -10t81.5 -118zM1100 1073q-20 -21 -53.5 -34t-53 -16t-63.5 -8q-155 -20 -324 0q-44 6 -63 9.5 t-52.5 16t-54.5 32.5q13 19 36 31t40 15.5t47 8.5q198 35 408 1q33 -5 51 -8.5t43 -16t39 -31.5zM1142 327q0 7 5.5 26.5t3 32t-17.5 16.5q-161 -106 -365 -106t-366 106l-12 -6l-5 -12q26 -154 41 -210q47 -81 204 -108q249 -46 428 53q34 19 49 51.5t22.5 85.5t12.5 71z M1272 1020q9 53 -8 75q-43 55 -155 88q-216 63 -487 36q-132 -12 -226 -46q-38 -15 -59.5 -25t-47 -34t-29.5 -54q8 -68 19 -138t29 -171t24 -137q1 -5 5 -31t7 -36t12 -27t22 -28q105 -80 284 -100q259 -28 440 63q24 13 39.5 23t31 29t19.5 40q48 267 80 473zM1536 1120 v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M944 207l80 -237q-23 -35 -111 -66t-177 -32q-104 -2 -190.5 26t-142.5 74t-95 106t-55.5 120t-16.5 118v544h-168v215q72 26 129 69.5t91 90t58 102t34 99t15 88.5q1 5 4.5 8.5t7.5 3.5h244v-424h333v-252h-334v-518q0 -30 6.5 -56t22.5 -52.5t49.5 -41.5t81.5 -14 q78 2 134 29z" /> +<glyph unicode="" d="M1136 75l-62 183q-44 -22 -103 -22q-36 -1 -62 10.5t-38.5 31.5t-17.5 40.5t-5 43.5v398h257v194h-256v326h-188q-8 0 -9 -10q-5 -44 -17.5 -87t-39 -95t-77 -95t-118.5 -68v-165h130v-418q0 -57 21.5 -115t65 -111t121 -85.5t176.5 -30.5q69 1 136.5 25t85.5 50z M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="768" d="M765 237q8 -19 -5 -35l-350 -384q-10 -10 -23 -10q-14 0 -24 10l-355 384q-13 16 -5 35q9 19 29 19h224v1248q0 14 9 23t23 9h192q14 0 23 -9t9 -23v-1248h224q21 0 29 -19z" /> +<glyph unicode="" horiz-adv-x="768" d="M765 1043q-9 -19 -29 -19h-224v-1248q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v1248h-224q-21 0 -29 19t5 35l350 384q10 10 23 10q14 0 24 -10l355 -384q13 -16 5 -35z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 736v-192q0 -14 -9 -23t-23 -9h-1248v-224q0 -21 -19 -29t-35 5l-384 350q-10 10 -10 23q0 14 10 24l384 354q16 14 35 6q19 -9 19 -29v-224h1248q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1728 643q0 -14 -10 -24l-384 -354q-16 -14 -35 -6q-19 9 -19 29v224h-1248q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h1248v224q0 21 19 29t35 -5l384 -350q10 -10 10 -23z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1393 321q-39 -125 -123 -250q-129 -196 -257 -196q-49 0 -140 32q-86 32 -151 32q-61 0 -142 -33q-81 -34 -132 -34q-152 0 -301 259q-147 261 -147 503q0 228 113 374q112 144 284 144q72 0 177 -30q104 -30 138 -30q45 0 143 34q102 34 173 34q119 0 213 -65 q52 -36 104 -100q-79 -67 -114 -118q-65 -94 -65 -207q0 -124 69 -223t158 -126zM1017 1494q0 -61 -29 -136q-30 -75 -93 -138q-54 -54 -108 -72q-37 -11 -104 -17q3 149 78 257q74 107 250 148q1 -3 2.5 -11t2.5 -11q0 -4 0.5 -10t0.5 -10z" /> +<glyph unicode="" horiz-adv-x="1664" d="M682 530v-651l-682 94v557h682zM682 1273v-659h-682v565zM1664 530v-786l-907 125v661h907zM1664 1408v-794h-907v669z" /> +<glyph unicode="" horiz-adv-x="1408" d="M493 1053q16 0 27.5 11.5t11.5 27.5t-11.5 27.5t-27.5 11.5t-27 -11.5t-11 -27.5t11 -27.5t27 -11.5zM915 1053q16 0 27 11.5t11 27.5t-11 27.5t-27 11.5t-27.5 -11.5t-11.5 -27.5t11.5 -27.5t27.5 -11.5zM103 869q42 0 72 -30t30 -72v-430q0 -43 -29.5 -73t-72.5 -30 t-73 30t-30 73v430q0 42 30 72t73 30zM1163 850v-666q0 -46 -32 -78t-77 -32h-75v-227q0 -43 -30 -73t-73 -30t-73 30t-30 73v227h-138v-227q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73l-1 227h-74q-46 0 -78 32t-32 78v666h918zM931 1255q107 -55 171 -153.5t64 -215.5 h-925q0 117 64 215.5t172 153.5l-71 131q-7 13 5 20q13 6 20 -6l72 -132q95 42 201 42t201 -42l72 132q7 12 20 6q12 -7 5 -20zM1408 767v-430q0 -43 -30 -73t-73 -30q-42 0 -72 30t-30 73v430q0 43 30 72.5t72 29.5q43 0 73 -29.5t30 -72.5z" /> +<glyph unicode="" d="M663 1125q-11 -1 -15.5 -10.5t-8.5 -9.5q-5 -1 -5 5q0 12 19 15h10zM750 1111q-4 -1 -11.5 6.5t-17.5 4.5q24 11 32 -2q3 -6 -3 -9zM399 684q-4 1 -6 -3t-4.5 -12.5t-5.5 -13.5t-10 -13q-7 -10 -1 -12q4 -1 12.5 7t12.5 18q1 3 2 7t2 6t1.5 4.5t0.5 4v3t-1 2.5t-3 2z M1254 325q0 18 -55 42q4 15 7.5 27.5t5 26t3 21.5t0.5 22.5t-1 19.5t-3.5 22t-4 20.5t-5 25t-5.5 26.5q-10 48 -47 103t-72 75q24 -20 57 -83q87 -162 54 -278q-11 -40 -50 -42q-31 -4 -38.5 18.5t-8 83.5t-11.5 107q-9 39 -19.5 69t-19.5 45.5t-15.5 24.5t-13 15t-7.5 7 q-14 62 -31 103t-29.5 56t-23.5 33t-15 40q-4 21 6 53.5t4.5 49.5t-44.5 25q-15 3 -44.5 18t-35.5 16q-8 1 -11 26t8 51t36 27q37 3 51 -30t4 -58q-11 -19 -2 -26.5t30 -0.5q13 4 13 36v37q-5 30 -13.5 50t-21 30.5t-23.5 15t-27 7.5q-107 -8 -89 -134q0 -15 -1 -15 q-9 9 -29.5 10.5t-33 -0.5t-15.5 5q1 57 -16 90t-45 34q-27 1 -41.5 -27.5t-16.5 -59.5q-1 -15 3.5 -37t13 -37.5t15.5 -13.5q10 3 16 14q4 9 -7 8q-7 0 -15.5 14.5t-9.5 33.5q-1 22 9 37t34 14q17 0 27 -21t9.5 -39t-1.5 -22q-22 -15 -31 -29q-8 -12 -27.5 -23.5 t-20.5 -12.5q-13 -14 -15.5 -27t7.5 -18q14 -8 25 -19.5t16 -19t18.5 -13t35.5 -6.5q47 -2 102 15q2 1 23 7t34.5 10.5t29.5 13t21 17.5q9 14 20 8q5 -3 6.5 -8.5t-3 -12t-16.5 -9.5q-20 -6 -56.5 -21.5t-45.5 -19.5q-44 -19 -70 -23q-25 -5 -79 2q-10 2 -9 -2t17 -19 q25 -23 67 -22q17 1 36 7t36 14t33.5 17.5t30 17t24.5 12t17.5 2.5t8.5 -11q0 -2 -1 -4.5t-4 -5t-6 -4.5t-8.5 -5t-9 -4.5t-10 -5t-9.5 -4.5q-28 -14 -67.5 -44t-66.5 -43t-49 -1q-21 11 -63 73q-22 31 -25 22q-1 -3 -1 -10q0 -25 -15 -56.5t-29.5 -55.5t-21 -58t11.5 -63 q-23 -6 -62.5 -90t-47.5 -141q-2 -18 -1.5 -69t-5.5 -59q-8 -24 -29 -3q-32 31 -36 94q-2 28 4 56q4 19 -1 18l-4 -5q-36 -65 10 -166q5 -12 25 -28t24 -20q20 -23 104 -90.5t93 -76.5q16 -15 17.5 -38t-14 -43t-45.5 -23q8 -15 29 -44.5t28 -54t7 -70.5q46 24 7 92 q-4 8 -10.5 16t-9.5 12t-2 6q3 5 13 9.5t20 -2.5q46 -52 166 -36q133 15 177 87q23 38 34 30q12 -6 10 -52q-1 -25 -23 -92q-9 -23 -6 -37.5t24 -15.5q3 19 14.5 77t13.5 90q2 21 -6.5 73.5t-7.5 97t23 70.5q15 18 51 18q1 37 34.5 53t72.5 10.5t60 -22.5zM626 1152 q3 17 -2.5 30t-11.5 15q-9 2 -9 -7q2 -5 5 -6q10 0 7 -15q-3 -20 8 -20q3 0 3 3zM1045 955q-2 8 -6.5 11.5t-13 5t-14.5 5.5q-5 3 -9.5 8t-7 8t-5.5 6.5t-4 4t-4 -1.5q-14 -16 7 -43.5t39 -31.5q9 -1 14.5 8t3.5 20zM867 1168q0 11 -5 19.5t-11 12.5t-9 3q-14 -1 -7 -7l4 -2 q14 -4 18 -31q0 -3 8 2zM921 1401q0 2 -2.5 5t-9 7t-9.5 6q-15 15 -24 15q-9 -1 -11.5 -7.5t-1 -13t-0.5 -12.5q-1 -4 -6 -10.5t-6 -9t3 -8.5q4 -3 8 0t11 9t15 9q1 1 9 1t15 2t9 7zM1486 60q20 -12 31 -24.5t12 -24t-2.5 -22.5t-15.5 -22t-23.5 -19.5t-30 -18.5 t-31.5 -16.5t-32 -15.5t-27 -13q-38 -19 -85.5 -56t-75.5 -64q-17 -16 -68 -19.5t-89 14.5q-18 9 -29.5 23.5t-16.5 25.5t-22 19.5t-47 9.5q-44 1 -130 1q-19 0 -57 -1.5t-58 -2.5q-44 -1 -79.5 -15t-53.5 -30t-43.5 -28.5t-53.5 -11.5q-29 1 -111 31t-146 43q-19 4 -51 9.5 t-50 9t-39.5 9.5t-33.5 14.5t-17 19.5q-10 23 7 66.5t18 54.5q1 16 -4 40t-10 42.5t-4.5 36.5t10.5 27q14 12 57 14t60 12q30 18 42 35t12 51q21 -73 -32 -106q-32 -20 -83 -15q-34 3 -43 -10q-13 -15 5 -57q2 -6 8 -18t8.5 -18t4.5 -17t1 -22q0 -15 -17 -49t-14 -48 q3 -17 37 -26q20 -6 84.5 -18.5t99.5 -20.5q24 -6 74 -22t82.5 -23t55.5 -4q43 6 64.5 28t23 48t-7.5 58.5t-19 52t-20 36.5q-121 190 -169 242q-68 74 -113 40q-11 -9 -15 15q-3 16 -2 38q1 29 10 52t24 47t22 42q8 21 26.5 72t29.5 78t30 61t39 54q110 143 124 195 q-12 112 -16 310q-2 90 24 151.5t106 104.5q39 21 104 21q53 1 106 -13.5t89 -41.5q57 -42 91.5 -121.5t29.5 -147.5q-5 -95 30 -214q34 -113 133 -218q55 -59 99.5 -163t59.5 -191q8 -49 5 -84.5t-12 -55.5t-20 -22q-10 -2 -23.5 -19t-27 -35.5t-40.5 -33.5t-61 -14 q-18 1 -31.5 5t-22.5 13.5t-13.5 15.5t-11.5 20.5t-9 19.5q-22 37 -41 30t-28 -49t7 -97q20 -70 1 -195q-10 -65 18 -100.5t73 -33t85 35.5q59 49 89.5 66.5t103.5 42.5q53 18 77 36.5t18.5 34.5t-25 28.5t-51.5 23.5q-33 11 -49.5 48t-15 72.5t15.5 47.5q1 -31 8 -56.5 t14.5 -40.5t20.5 -28.5t21 -19t21.5 -13t16.5 -9.5z" /> +<glyph unicode="" d="M1024 36q-42 241 -140 498h-2l-2 -1q-16 -6 -43 -16.5t-101 -49t-137 -82t-131 -114.5t-103 -148l-15 11q184 -150 418 -150q132 0 256 52zM839 643q-21 49 -53 111q-311 -93 -673 -93q-1 -7 -1 -21q0 -124 44 -236.5t124 -201.5q50 89 123.5 166.5t142.5 124.5t130.5 81 t99.5 48l37 13q4 1 13 3.5t13 4.5zM732 855q-120 213 -244 378q-138 -65 -234 -186t-128 -272q302 0 606 80zM1416 536q-210 60 -409 29q87 -239 128 -469q111 75 185 189.5t96 250.5zM611 1277q-1 0 -2 -1q1 1 2 1zM1201 1132q-185 164 -433 164q-76 0 -155 -19 q131 -170 246 -382q69 26 130 60.5t96.5 61.5t65.5 57t37.5 40.5zM1424 647q-3 232 -149 410l-1 -1q-9 -12 -19 -24.5t-43.5 -44.5t-71 -60.5t-100 -65t-131.5 -64.5q25 -53 44 -95q2 -6 6.5 -17.5t7.5 -16.5q36 5 74.5 7t73.5 2t69 -1.5t64 -4t56.5 -5.5t48 -6.5t36.5 -6 t25 -4.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1173 473q0 50 -19.5 91.5t-48.5 68.5t-73 49t-82.5 34t-87.5 23l-104 24q-30 7 -44 10.5t-35 11.5t-30 16t-16.5 21t-7.5 30q0 77 144 77q43 0 77 -12t54 -28.5t38 -33.5t40 -29t48 -12q47 0 75.5 32t28.5 77q0 55 -56 99.5t-142 67.5t-182 23q-68 0 -132 -15.5 t-119.5 -47t-89 -87t-33.5 -128.5q0 -61 19 -106.5t56 -75.5t80 -48.5t103 -32.5l146 -36q90 -22 112 -36q32 -20 32 -60q0 -39 -40 -64.5t-105 -25.5q-51 0 -91.5 16t-65 38.5t-45.5 45t-46 38.5t-54 16q-50 0 -75.5 -30t-25.5 -75q0 -92 122 -157.5t291 -65.5 q73 0 140 18.5t122.5 53.5t88.5 93.5t33 131.5zM1536 256q0 -159 -112.5 -271.5t-271.5 -112.5q-130 0 -234 80q-77 -16 -150 -16q-143 0 -273.5 55.5t-225 150t-150 225t-55.5 273.5q0 73 16 150q-80 104 -80 234q0 159 112.5 271.5t271.5 112.5q130 0 234 -80 q77 16 150 16q143 0 273.5 -55.5t225 -150t150 -225t55.5 -273.5q0 -73 -16 -150q80 -104 80 -234z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1000 1102l37 194q5 23 -9 40t-35 17h-712q-23 0 -38.5 -17t-15.5 -37v-1101q0 -7 6 -1l291 352q23 26 38 33.5t48 7.5h239q22 0 37 14.5t18 29.5q24 130 37 191q4 21 -11.5 40t-36.5 19h-294q-29 0 -48 19t-19 48v42q0 29 19 47.5t48 18.5h346q18 0 35 13.5t20 29.5z M1227 1324q-15 -73 -53.5 -266.5t-69.5 -350t-35 -173.5q-6 -22 -9 -32.5t-14 -32.5t-24.5 -33t-38.5 -21t-58 -10h-271q-13 0 -22 -10q-8 -9 -426 -494q-22 -25 -58.5 -28.5t-48.5 5.5q-55 22 -55 98v1410q0 55 38 102.5t120 47.5h888q95 0 127 -53t10 -159zM1227 1324 l-158 -790q4 17 35 173.5t69.5 350t53.5 266.5z" /> +<glyph unicode="" d="M704 192v1024q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-1024q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1376 576v640q0 14 -9 23t-23 9h-480q-14 0 -23 -9t-9 -23v-640q0 -14 9 -23t23 -9h480q14 0 23 9t9 23zM1536 1344v-1408q0 -26 -19 -45t-45 -19h-1408 q-26 0 -45 19t-19 45v1408q0 26 19 45t45 19h1408q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1280 480q0 -40 -28 -68t-68 -28q-51 0 -80 43l-227 341h-45v-132l247 -411q9 -15 9 -33q0 -26 -19 -45t-45 -19h-192v-272q0 -46 -33 -79t-79 -33h-160q-46 0 -79 33t-33 79v272h-192q-26 0 -45 19t-19 45q0 18 9 33l247 411v132h-45l-227 -341q-29 -43 -80 -43 q-40 0 -68 28t-28 68q0 29 16 53l256 384q73 107 176 107h384q103 0 176 -107l256 -384q16 -24 16 -53zM864 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" /> +<glyph unicode="" horiz-adv-x="1024" d="M1024 832v-416q0 -40 -28 -68t-68 -28t-68 28t-28 68v352h-64v-912q0 -46 -33 -79t-79 -33t-79 33t-33 79v464h-64v-464q0 -46 -33 -79t-79 -33t-79 33t-33 79v912h-64v-352q0 -40 -28 -68t-68 -28t-68 28t-28 68v416q0 80 56 136t136 56h640q80 0 136 -56t56 -136z M736 1280q0 -93 -65.5 -158.5t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" /> +<glyph unicode="" d="M773 234l350 473q16 22 24.5 59t-6 85t-61.5 79q-40 26 -83 25.5t-73.5 -17.5t-54.5 -45q-36 -40 -96 -40q-59 0 -95 40q-24 28 -54.5 45t-73.5 17.5t-84 -25.5q-46 -31 -60.5 -79t-6 -85t24.5 -59zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1472 640q0 117 -45.5 223.5t-123 184t-184 123t-223.5 45.5t-223.5 -45.5t-184 -123t-123 -184t-45.5 -223.5t45.5 -223.5t123 -184t184 -123t223.5 -45.5t223.5 45.5t184 123t123 184t45.5 223.5zM1748 363q-4 -15 -20 -20l-292 -96v-306q0 -16 -13 -26q-15 -10 -29 -4 l-292 94l-180 -248q-10 -13 -26 -13t-26 13l-180 248l-292 -94q-14 -6 -29 4q-13 10 -13 26v306l-292 96q-16 5 -20 20q-5 17 4 29l180 248l-180 248q-9 13 -4 29q4 15 20 20l292 96v306q0 16 13 26q15 10 29 4l292 -94l180 248q9 12 26 12t26 -12l180 -248l292 94 q14 6 29 -4q13 -10 13 -26v-306l292 -96q16 -5 20 -20q5 -16 -4 -29l-180 -248l180 -248q9 -12 4 -29z" /> +<glyph unicode="" d="M1262 233q-54 -9 -110 -9q-182 0 -337 90t-245 245t-90 337q0 192 104 357q-201 -60 -328.5 -229t-127.5 -384q0 -130 51 -248.5t136.5 -204t204 -136.5t248.5 -51q144 0 273.5 61.5t220.5 171.5zM1465 318q-94 -203 -283.5 -324.5t-413.5 -121.5q-156 0 -298 61 t-245 164t-164 245t-61 298q0 153 57.5 292.5t156 241.5t235.5 164.5t290 68.5q44 2 61 -39q18 -41 -15 -72q-86 -78 -131.5 -181.5t-45.5 -218.5q0 -148 73 -273t198 -198t273 -73q118 0 228 51q41 18 72 -13q14 -14 17.5 -34t-4.5 -38z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1088 704q0 26 -19 45t-45 19h-256q-26 0 -45 -19t-19 -45t19 -45t45 -19h256q26 0 45 19t19 45zM1664 896v-960q0 -26 -19 -45t-45 -19h-1408q-26 0 -45 19t-19 45v960q0 26 19 45t45 19h1408q26 0 45 -19t19 -45zM1728 1344v-256q0 -26 -19 -45t-45 -19h-1536 q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h1536q26 0 45 -19t19 -45z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1632 576q0 -26 -19 -45t-45 -19h-224q0 -171 -67 -290l208 -209q19 -19 19 -45t-19 -45q-18 -19 -45 -19t-45 19l-198 197q-5 -5 -15 -13t-42 -28.5t-65 -36.5t-82 -29t-97 -13v896h-128v-896q-51 0 -101.5 13.5t-87 33t-66 39t-43.5 32.5l-15 14l-183 -207 q-20 -21 -48 -21q-24 0 -43 16q-19 18 -20.5 44.5t15.5 46.5l202 227q-58 114 -58 274h-224q-26 0 -45 19t-19 45t19 45t45 19h224v294l-173 173q-19 19 -19 45t19 45t45 19t45 -19l173 -173h844l173 173q19 19 45 19t45 -19t19 -45t-19 -45l-173 -173v-294h224q26 0 45 -19 t19 -45zM1152 1152h-640q0 133 93.5 226.5t226.5 93.5t226.5 -93.5t93.5 -226.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1917 1016q23 -64 -150 -294q-24 -32 -65 -85q-78 -100 -90 -131q-17 -41 14 -81q17 -21 81 -82h1l1 -1l1 -1l2 -2q141 -131 191 -221q3 -5 6.5 -12.5t7 -26.5t-0.5 -34t-25 -27.5t-59 -12.5l-256 -4q-24 -5 -56 5t-52 22l-20 12q-30 21 -70 64t-68.5 77.5t-61 58 t-56.5 15.5q-3 -1 -8 -3.5t-17 -14.5t-21.5 -29.5t-17 -52t-6.5 -77.5q0 -15 -3.5 -27.5t-7.5 -18.5l-4 -5q-18 -19 -53 -22h-115q-71 -4 -146 16.5t-131.5 53t-103 66t-70.5 57.5l-25 24q-10 10 -27.5 30t-71.5 91t-106 151t-122.5 211t-130.5 272q-6 16 -6 27t3 16l4 6 q15 19 57 19l274 2q12 -2 23 -6.5t16 -8.5l5 -3q16 -11 24 -32q20 -50 46 -103.5t41 -81.5l16 -29q29 -60 56 -104t48.5 -68.5t41.5 -38.5t34 -14t27 5q2 1 5 5t12 22t13.5 47t9.5 81t0 125q-2 40 -9 73t-14 46l-6 12q-25 34 -85 43q-13 2 5 24q17 19 38 30q53 26 239 24 q82 -1 135 -13q20 -5 33.5 -13.5t20.5 -24t10.5 -32t3.5 -45.5t-1 -55t-2.5 -70.5t-1.5 -82.5q0 -11 -1 -42t-0.5 -48t3.5 -40.5t11.5 -39t22.5 -24.5q8 -2 17 -4t26 11t38 34.5t52 67t68 107.5q60 104 107 225q4 10 10 17.5t11 10.5l4 3l5 2.5t13 3t20 0.5l288 2 q39 5 64 -2.5t31 -16.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M675 252q21 34 11 69t-45 50q-34 14 -73 1t-60 -46q-22 -34 -13 -68.5t43 -50.5t74.5 -2.5t62.5 47.5zM769 373q8 13 3.5 26.5t-17.5 18.5q-14 5 -28.5 -0.5t-21.5 -18.5q-17 -31 13 -45q14 -5 29 0.5t22 18.5zM943 266q-45 -102 -158 -150t-224 -12 q-107 34 -147.5 126.5t6.5 187.5q47 93 151.5 139t210.5 19q111 -29 158.5 -119.5t2.5 -190.5zM1255 426q-9 96 -89 170t-208.5 109t-274.5 21q-223 -23 -369.5 -141.5t-132.5 -264.5q9 -96 89 -170t208.5 -109t274.5 -21q223 23 369.5 141.5t132.5 264.5zM1563 422 q0 -68 -37 -139.5t-109 -137t-168.5 -117.5t-226 -83t-270.5 -31t-275 33.5t-240.5 93t-171.5 151t-65 199.5q0 115 69.5 245t197.5 258q169 169 341.5 236t246.5 -7q65 -64 20 -209q-4 -14 -1 -20t10 -7t14.5 0.5t13.5 3.5l6 2q139 59 246 59t153 -61q45 -63 0 -178 q-2 -13 -4.5 -20t4.5 -12.5t12 -7.5t17 -6q57 -18 103 -47t80 -81.5t34 -116.5zM1489 1046q42 -47 54.5 -108.5t-6.5 -117.5q-8 -23 -29.5 -34t-44.5 -4q-23 8 -34 29.5t-4 44.5q20 63 -24 111t-107 35q-24 -5 -45 8t-25 37q-5 24 8 44.5t37 25.5q60 13 119 -5.5t101 -65.5z M1670 1209q87 -96 112.5 -222.5t-13.5 -241.5q-9 -27 -34 -40t-52 -4t-40 34t-5 52q28 82 10 172t-80 158q-62 69 -148 95.5t-173 8.5q-28 -6 -52 9.5t-30 43.5t9.5 51.5t43.5 29.5q123 26 244 -11.5t208 -134.5z" /> +<glyph unicode="" d="M1133 -34q-171 -94 -368 -94q-196 0 -367 94q138 87 235.5 211t131.5 268q35 -144 132.5 -268t235.5 -211zM638 1394v-485q0 -252 -126.5 -459.5t-330.5 -306.5q-181 215 -181 495q0 187 83.5 349.5t229.5 269.5t325 137zM1536 638q0 -280 -181 -495 q-204 99 -330.5 306.5t-126.5 459.5v485q179 -30 325 -137t229.5 -269.5t83.5 -349.5z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1402 433q-32 -80 -76 -138t-91 -88.5t-99 -46.5t-101.5 -14.5t-96.5 8.5t-86.5 22t-69.5 27.5t-46 22.5l-17 10q-113 -228 -289.5 -359.5t-384.5 -132.5q-19 0 -32 13t-13 32t13 31.5t32 12.5q173 1 322.5 107.5t251.5 294.5q-36 -14 -72 -23t-83 -13t-91 2.5t-93 28.5 t-92 59t-84.5 100t-74.5 146q114 47 214 57t167.5 -7.5t124.5 -56.5t88.5 -77t56.5 -82q53 131 79 291q-7 -1 -18 -2.5t-46.5 -2.5t-69.5 0.5t-81.5 10t-88.5 23t-84 42.5t-75 65t-54.5 94.5t-28.5 127.5q70 28 133.5 36.5t112.5 -1t92 -30t73.5 -50t56 -61t42 -63t27.5 -56 t16 -39.5l4 -16q12 122 12 195q-8 6 -21.5 16t-49 44.5t-63.5 71.5t-54 93t-33 112.5t12 127t70 138.5q73 -25 127.5 -61.5t84.5 -76.5t48 -85t20.5 -89t-0.5 -85.5t-13 -76.5t-19 -62t-17 -42l-7 -15q1 -5 1 -50.5t-1 -71.5q3 7 10 18.5t30.5 43t50.5 58t71 55.5t91.5 44.5 t112 14.5t132.5 -24q-2 -78 -21.5 -141.5t-50 -104.5t-69.5 -71.5t-81.5 -45.5t-84.5 -24t-80 -9.5t-67.5 1t-46.5 4.5l-17 3q-23 -147 -73 -283q6 7 18 18.5t49.5 41t77.5 52.5t99.5 42t117.5 20t129 -23.5t137 -77.5z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1259 283v-66q0 -85 -57.5 -144.5t-138.5 -59.5h-57l-260 -269v269h-529q-81 0 -138.5 59.5t-57.5 144.5v66h1238zM1259 609v-255h-1238v255h1238zM1259 937v-255h-1238v255h1238zM1259 1077v-67h-1238v67q0 84 57.5 143.5t138.5 59.5h846q81 0 138.5 -59.5t57.5 -143.5z " /> +<glyph unicode="" d="M1152 640q0 -14 -9 -23l-320 -320q-9 -9 -23 -9q-13 0 -22.5 9.5t-9.5 22.5v192h-352q-13 0 -22.5 9.5t-9.5 22.5v192q0 13 9.5 22.5t22.5 9.5h352v192q0 14 9 23t23 9q12 0 24 -10l319 -319q9 -9 9 -23zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1152 736v-192q0 -13 -9.5 -22.5t-22.5 -9.5h-352v-192q0 -14 -9 -23t-23 -9q-12 0 -24 10l-319 319q-9 9 -9 23t9 23l320 320q9 9 23 9q13 0 22.5 -9.5t9.5 -22.5v-192h352q13 0 22.5 -9.5t9.5 -22.5zM1312 640q0 148 -73 273t-198 198t-273 73t-273 -73t-198 -198 t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1024 960v-640q0 -26 -19 -45t-45 -19q-20 0 -37 12l-448 320q-27 19 -27 52t27 52l448 320q17 12 37 12q26 0 45 -19t19 -45zM1280 160v960q0 13 -9.5 22.5t-22.5 9.5h-960q-13 0 -22.5 -9.5t-9.5 -22.5v-960q0 -13 9.5 -22.5t22.5 -9.5h960q13 0 22.5 9.5t9.5 22.5z M1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" d="M1024 640q0 -106 -75 -181t-181 -75t-181 75t-75 181t75 181t181 75t181 -75t75 -181zM768 1184q-148 0 -273 -73t-198 -198t-73 -273t73 -273t198 -198t273 -73t273 73t198 198t73 273t-73 273t-198 198t-273 73zM1536 640q0 -209 -103 -385.5t-279.5 -279.5 t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1023 349l102 -204q-58 -179 -210 -290t-339 -111q-156 0 -288.5 77.5t-210 210t-77.5 288.5q0 181 104.5 330t274.5 211l17 -131q-122 -54 -195 -165.5t-73 -244.5q0 -185 131.5 -316.5t316.5 -131.5q126 0 232.5 65t165 175.5t49.5 236.5zM1571 249l58 -114l-256 -128 q-13 -7 -29 -7q-40 0 -57 35l-239 477h-472q-24 0 -42.5 16.5t-21.5 40.5l-96 779q-2 16 6 42q14 51 57 82.5t97 31.5q66 0 113 -47t47 -113q0 -69 -52 -117.5t-120 -41.5l37 -289h423v-128h-407l16 -128h455q40 0 57 -35l228 -455z" /> +<glyph unicode="" d="M1254 899q16 85 -21 132q-52 65 -187 45q-17 -3 -41 -12.5t-57.5 -30.5t-64.5 -48.5t-59.5 -70t-44.5 -91.5q80 7 113.5 -16t26.5 -99q-5 -52 -52 -143q-43 -78 -71 -99q-44 -32 -87 14q-23 24 -37.5 64.5t-19 73t-10 84t-8.5 71.5q-23 129 -34 164q-12 37 -35.5 69 t-50.5 40q-57 16 -127 -25q-54 -32 -136.5 -106t-122.5 -102v-7q16 -8 25.5 -26t21.5 -20q21 -3 54.5 8.5t58 10.5t41.5 -30q11 -18 18.5 -38.5t15 -48t12.5 -40.5q17 -46 53 -187q36 -146 57 -197q42 -99 103 -125q43 -12 85 -1.5t76 31.5q131 77 250 237 q104 139 172.5 292.5t82.5 226.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1152" d="M1152 704q0 -191 -94.5 -353t-256.5 -256.5t-353 -94.5h-160q-14 0 -23 9t-9 23v611l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v93l-215 -66q-3 -1 -9 -1q-10 0 -19 6q-13 10 -13 26v128q0 23 23 31l233 71v250q0 14 9 23t23 9h160 q14 0 23 -9t9 -23v-181l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-93l375 116q15 5 28 -5t13 -26v-128q0 -23 -23 -31l-393 -121v-487q188 13 318 151t130 328q0 14 9 23t23 9h160q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1408" d="M1152 736v-64q0 -14 -9 -23t-23 -9h-352v-352q0 -14 -9 -23t-23 -9h-64q-14 0 -23 9t-9 23v352h-352q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h352v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23v-352h352q14 0 23 -9t9 -23zM1280 288v832q0 66 -47 113t-113 47h-832 q-66 0 -113 -47t-47 -113v-832q0 -66 47 -113t113 -47h832q66 0 113 47t47 113zM1408 1120v-832q0 -119 -84.5 -203.5t-203.5 -84.5h-832q-119 0 -203.5 84.5t-84.5 203.5v832q0 119 84.5 203.5t203.5 84.5h832q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="2176" d="M620 416q-110 -64 -268 -64h-128v64h-64q-13 0 -22.5 23.5t-9.5 56.5q0 24 7 49q-58 2 -96.5 10.5t-38.5 20.5t38.5 20.5t96.5 10.5q-7 25 -7 49q0 33 9.5 56.5t22.5 23.5h64v64h128q158 0 268 -64h1113q42 -7 106.5 -18t80.5 -14q89 -15 150 -40.5t83.5 -47.5t22.5 -40 t-22.5 -40t-83.5 -47.5t-150 -40.5q-16 -3 -80.5 -14t-106.5 -18h-1113zM1739 668q53 -36 53 -92t-53 -92l81 -30q68 48 68 122t-68 122zM625 400h1015q-217 -38 -456 -80q-57 0 -113 -24t-83 -48l-28 -24l-288 -288q-26 -26 -70.5 -45t-89.5 -19h-96l-93 464h29 q157 0 273 64zM352 816h-29l93 464h96q46 0 90 -19t70 -45l288 -288q4 -4 11 -10.5t30.5 -23t48.5 -29t61.5 -23t72.5 -10.5l456 -80h-1015q-116 64 -273 64z" /> +<glyph unicode="" horiz-adv-x="1664" d="M1519 760q62 0 103.5 -40.5t41.5 -101.5q0 -97 -93 -130l-172 -59l56 -167q7 -21 7 -47q0 -59 -42 -102t-101 -43q-47 0 -85.5 27t-53.5 72l-55 165l-310 -106l55 -164q8 -24 8 -47q0 -59 -42 -102t-102 -43q-47 0 -85 27t-53 72l-55 163l-153 -53q-29 -9 -50 -9 q-61 0 -101.5 40t-40.5 101q0 47 27.5 85t71.5 53l156 53l-105 313l-156 -54q-26 -8 -48 -8q-60 0 -101 40.5t-41 100.5q0 47 27.5 85t71.5 53l157 53l-53 159q-8 24 -8 47q0 60 42 102.5t102 42.5q47 0 85 -27t53 -72l54 -160l310 105l-54 160q-8 24 -8 47q0 59 42.5 102 t101.5 43q47 0 85.5 -27.5t53.5 -71.5l53 -161l162 55q21 6 43 6q60 0 102.5 -39.5t42.5 -98.5q0 -45 -30 -81.5t-74 -51.5l-157 -54l105 -316l164 56q24 8 46 8zM725 498l310 105l-105 315l-310 -107z" /> +<glyph unicode="" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960zM1280 352v436q-31 -35 -64 -55q-34 -22 -132.5 -85t-151.5 -99q-98 -69 -164 -69v0v0q-66 0 -164 69 q-46 32 -141.5 92.5t-142.5 92.5q-12 8 -33 27t-31 27v-436q0 -40 28 -68t68 -28h832q40 0 68 28t28 68zM1280 925q0 41 -27.5 70t-68.5 29h-832q-40 0 -68 -28t-28 -68q0 -37 30.5 -76.5t67.5 -64.5q47 -32 137.5 -89t129.5 -83q3 -2 17 -11.5t21 -14t21 -13t23.5 -13 t21.5 -9.5t22.5 -7.5t20.5 -2.5t20.5 2.5t22.5 7.5t21.5 9.5t23.5 13t21 13t21 14t17 11.5l267 174q35 23 66.5 62.5t31.5 73.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M127 640q0 163 67 313l367 -1005q-196 95 -315 281t-119 411zM1415 679q0 -19 -2.5 -38.5t-10 -49.5t-11.5 -44t-17.5 -59t-17.5 -58l-76 -256l-278 826q46 3 88 8q19 2 26 18.5t-2.5 31t-28.5 13.5l-205 -10q-75 1 -202 10q-12 1 -20.5 -5t-11.5 -15t-1.5 -18.5t9 -16.5 t19.5 -8l80 -8l120 -328l-168 -504l-280 832q46 3 88 8q19 2 26 18.5t-2.5 31t-28.5 13.5l-205 -10q-7 0 -23 0.5t-26 0.5q105 160 274.5 253.5t367.5 93.5q147 0 280.5 -53t238.5 -149h-10q-55 0 -92 -40.5t-37 -95.5q0 -12 2 -24t4 -21.5t8 -23t9 -21t12 -22.5t12.5 -21 t14.5 -24t14 -23q63 -107 63 -212zM909 573l237 -647q1 -6 5 -11q-126 -44 -255 -44q-112 0 -217 32zM1570 1009q95 -174 95 -369q0 -209 -104 -385.5t-279 -278.5l235 678q59 169 59 276q0 42 -6 79zM896 1536q182 0 348 -71t286 -191t191 -286t71 -348t-71 -348t-191 -286 t-286 -191t-348 -71t-348 71t-286 191t-191 286t-71 348t71 348t191 286t286 191t348 71zM896 -215q173 0 331.5 68t273 182.5t182.5 273t68 331.5t-68 331.5t-182.5 273t-273 182.5t-331.5 68t-331.5 -68t-273 -182.5t-182.5 -273t-68 -331.5t68 -331.5t182.5 -273 t273 -182.5t331.5 -68z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1086 1536v-1536l-272 -128q-228 20 -414 102t-293 208.5t-107 272.5q0 140 100.5 263.5t275 205.5t391.5 108v-172q-217 -38 -356.5 -150t-139.5 -255q0 -152 154.5 -267t388.5 -145v1360zM1755 954l37 -390l-525 114l147 83q-119 70 -280 99v172q277 -33 481 -157z" /> +<glyph unicode="" horiz-adv-x="2048" d="M960 1536l960 -384v-128h-128q0 -26 -20.5 -45t-48.5 -19h-1526q-28 0 -48.5 19t-20.5 45h-128v128zM256 896h256v-768h128v768h256v-768h128v768h256v-768h128v768h256v-768h59q28 0 48.5 -19t20.5 -45v-64h-1664v64q0 26 20.5 45t48.5 19h59v768zM1851 -64 q28 0 48.5 -19t20.5 -45v-128h-1920v128q0 26 20.5 45t48.5 19h1782z" /> +<glyph unicode="" horiz-adv-x="2304" d="M1774 700l18 -316q4 -69 -82 -128t-235 -93.5t-323 -34.5t-323 34.5t-235 93.5t-82 128l18 316l574 -181q22 -7 48 -7t48 7zM2304 1024q0 -23 -22 -31l-1120 -352q-4 -1 -10 -1t-10 1l-652 206q-43 -34 -71 -111.5t-34 -178.5q63 -36 63 -109q0 -69 -58 -107l58 -433 q2 -14 -8 -25q-9 -11 -24 -11h-192q-15 0 -24 11q-10 11 -8 25l58 433q-58 38 -58 107q0 73 65 111q11 207 98 330l-333 104q-22 8 -22 31t22 31l1120 352q4 1 10 1t10 -1l1120 -352q22 -8 22 -31z" /> +<glyph unicode="" d="M859 579l13 -707q-62 11 -105 11q-41 0 -105 -11l13 707q-40 69 -168.5 295.5t-216.5 374.5t-181 287q58 -15 108 -15q43 0 111 15q63 -111 133.5 -229.5t167 -276.5t138.5 -227q37 61 109.5 177.5t117.5 190t105 176t107 189.5q54 -14 107 -14q56 0 114 14v0 q-28 -39 -60 -88.5t-49.5 -78.5t-56.5 -96t-49 -84q-146 -248 -353 -610z" /> +<glyph unicode="" horiz-adv-x="1280" d="M981 197q0 25 -7 49t-14.5 42t-27 41.5t-29.5 35t-38.5 34.5t-36.5 29t-41.5 30t-36.5 26q-16 2 -49 2q-53 0 -104.5 -7t-107 -25t-97 -46t-68.5 -74.5t-27 -105.5q0 -56 23.5 -102t61 -75.5t87 -50t100 -29t101.5 -8.5q58 0 111.5 13t99 39t73 73t27.5 109zM864 1055 q0 59 -17 125.5t-48 129t-84 103.5t-117 41q-42 0 -82.5 -19.5t-66.5 -52.5q-46 -59 -46 -160q0 -46 10 -97.5t31.5 -103t52 -92.5t75 -67t96.5 -26q37 0 77.5 16.5t65.5 43.5q53 56 53 159zM752 1536h417l-137 -88h-132q75 -63 113 -133t38 -160q0 -72 -24.5 -129.5 t-59.5 -93t-69.5 -65t-59 -61.5t-24.5 -66q0 -36 32 -70.5t77 -68t90.5 -73.5t77.5 -104t32 -142q0 -91 -49 -173q-71 -122 -209.5 -179.5t-298.5 -57.5q-132 0 -246.5 41.5t-172.5 137.5q-36 59 -36 131q0 81 44.5 150t118.5 115q131 82 404 100q-32 41 -47.5 73.5 t-15.5 73.5q0 40 21 85q-46 -4 -68 -4q-148 0 -249.5 96.5t-101.5 244.5q0 82 36 159t99 131q76 66 182 98t218 32z" /> +<glyph unicode="" horiz-adv-x="1984" d="M831 572q0 -56 -40.5 -96t-96.5 -40q-57 0 -98 40t-41 96q0 57 41.5 98t97.5 41t96.5 -41t40.5 -98zM1292 711q56 0 96.5 -41t40.5 -98q0 -56 -40.5 -96t-96.5 -40q-57 0 -98 40t-41 96q0 57 41.5 98t97.5 41zM1984 722q0 -62 -31 -114t-83 -82q5 -33 5 -61 q0 -121 -68.5 -230.5t-197.5 -193.5q-125 -82 -285.5 -125.5t-335.5 -43.5q-176 0 -336.5 43.5t-284.5 125.5q-129 84 -197.5 193t-68.5 231q0 29 5 66q-48 31 -77 81.5t-29 109.5q0 94 66 160t160 66q83 0 148 -55q248 158 592 164l134 423q4 14 17.5 21.5t28.5 4.5 l347 -82q22 50 68.5 81t102.5 31q77 0 131.5 -54.5t54.5 -131.5t-54.5 -132t-131.5 -55q-76 0 -130.5 54t-55.5 131l-315 74l-116 -366q327 -14 560 -166q64 58 151 58q94 0 160 -66t66 -160zM1664 1459q-45 0 -77 -32t-32 -77t32 -77t77 -32t77 32t32 77t-32 77t-77 32z M77 722q0 -67 51 -111q49 131 180 235q-36 25 -82 25q-62 0 -105.5 -43.5t-43.5 -105.5zM1567 105q112 73 171.5 166t59.5 194t-59.5 193.5t-171.5 165.5q-116 75 -265.5 115.5t-313.5 40.5t-313.5 -40.5t-265.5 -115.5q-112 -73 -171.5 -165.5t-59.5 -193.5t59.5 -194 t171.5 -166q116 -75 265.5 -115.5t313.5 -40.5t313.5 40.5t265.5 115.5zM1850 605q57 46 57 117q0 62 -43.5 105.5t-105.5 43.5q-49 0 -86 -28q131 -105 178 -238zM1258 237q11 11 27 11t27 -11t11 -27.5t-11 -27.5q-99 -99 -319 -99h-2q-220 0 -319 99q-11 11 -11 27.5 t11 27.5t27 11t27 -11q77 -77 265 -77h2q188 0 265 77z" /> +<glyph unicode="" d="M950 393q7 7 17.5 7t17.5 -7t7 -18t-7 -18q-65 -64 -208 -64h-1h-1q-143 0 -207 64q-8 7 -8 18t8 18q7 7 17.5 7t17.5 -7q49 -51 172 -51h1h1q122 0 173 51zM671 613q0 -37 -26 -64t-63 -27t-63 27t-26 64t26 63t63 26t63 -26t26 -63zM1214 1049q-29 0 -50 21t-21 50 q0 30 21 51t50 21q30 0 51 -21t21 -51q0 -29 -21 -50t-51 -21zM1216 1408q132 0 226 -94t94 -227v-894q0 -133 -94 -227t-226 -94h-896q-132 0 -226 94t-94 227v894q0 133 94 227t226 94h896zM1321 596q35 14 57 45.5t22 70.5q0 51 -36 87.5t-87 36.5q-60 0 -98 -48 q-151 107 -375 115l83 265l206 -49q1 -50 36.5 -85t84.5 -35q50 0 86 35.5t36 85.5t-36 86t-86 36q-36 0 -66 -20.5t-45 -53.5l-227 54q-9 2 -17.5 -2.5t-11.5 -14.5l-95 -302q-224 -4 -381 -113q-36 43 -93 43q-51 0 -87 -36.5t-36 -87.5q0 -37 19.5 -67.5t52.5 -45.5 q-7 -25 -7 -54q0 -98 74 -181.5t201.5 -132t278.5 -48.5q150 0 277.5 48.5t201.5 132t74 181.5q0 27 -6 54zM971 702q37 0 63 -26t26 -63t-26 -64t-63 -27t-63 27t-26 64t26 63t63 26z" /> +<glyph unicode="" d="M866 697l90 27v62q0 79 -58 135t-138 56t-138 -55.5t-58 -134.5v-283q0 -20 -14 -33.5t-33 -13.5t-32.5 13.5t-13.5 33.5v120h-151v-122q0 -82 57.5 -139t139.5 -57q81 0 138.5 56.5t57.5 136.5v280q0 19 13.5 33t33.5 14q19 0 32.5 -14t13.5 -33v-54zM1199 502v122h-150 v-126q0 -20 -13.5 -33.5t-33.5 -13.5q-19 0 -32.5 14t-13.5 33v123l-90 -26l-60 28v-123q0 -80 58 -137t139 -57t138.5 57t57.5 139zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103 t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1920" d="M1062 824v118q0 42 -30 72t-72 30t-72 -30t-30 -72v-612q0 -175 -126 -299t-303 -124q-178 0 -303.5 125.5t-125.5 303.5v266h328v-262q0 -43 30 -72.5t72 -29.5t72 29.5t30 72.5v620q0 171 126.5 292t301.5 121q176 0 302 -122t126 -294v-136l-195 -58zM1592 602h328 v-266q0 -178 -125.5 -303.5t-303.5 -125.5q-177 0 -303 124.5t-126 300.5v268l131 -61l195 58v-270q0 -42 30 -71.5t72 -29.5t72 29.5t30 71.5v275z" /> +<glyph unicode="" d="M1472 160v480h-704v704h-480q-93 0 -158.5 -65.5t-65.5 -158.5v-480h704v-704h480q93 0 158.5 65.5t65.5 158.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5 t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M328 1254h204v-983h-532v697h328v286zM328 435v369h-123v-369h123zM614 968v-697h205v697h-205zM614 1254v-204h205v204h-205zM901 968h533v-942h-533v163h328v82h-328v697zM1229 435v369h-123v-369h123zM1516 968h532v-942h-532v163h327v82h-327v697zM1843 435v369h-123 v-369h123z" /> +<glyph unicode="" d="M1046 516q0 -64 -38 -109t-91 -45q-43 0 -70 15v277q28 17 70 17q53 0 91 -45.5t38 -109.5zM703 944q0 -64 -38 -109.5t-91 -45.5q-43 0 -70 15v277q28 17 70 17q53 0 91 -45t38 -109zM1265 513q0 134 -88 229t-213 95q-20 0 -39 -3q-23 -78 -78 -136q-87 -95 -211 -101 v-636l211 41v206q51 -19 117 -19q125 0 213 95t88 229zM922 940q0 134 -88.5 229t-213.5 95q-74 0 -141 -36h-186v-840l211 41v206q55 -19 116 -19q125 0 213.5 95t88.5 229zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960 q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="2038" d="M1222 607q75 3 143.5 -20.5t118 -58.5t101 -94.5t84 -108t75.5 -120.5q33 -56 78.5 -109t75.5 -80.5t99 -88.5q-48 -30 -108.5 -57.5t-138.5 -59t-114 -47.5q-44 37 -74 115t-43.5 164.5t-33 180.5t-42.5 168.5t-72.5 123t-122.5 48.5l-10 -2l-6 -4q4 -5 13 -14 q6 -5 28 -23.5t25.5 -22t19 -18t18 -20.5t11.5 -21t10.5 -27.5t4.5 -31t4 -40.5l1 -33q1 -26 -2.5 -57.5t-7.5 -52t-12.5 -58.5t-11.5 -53q-35 1 -101 -9.5t-98 -10.5q-39 0 -72 10q-2 16 -2 47q0 74 3 96q2 13 31.5 41.5t57 59t26.5 51.5q-24 2 -43 -24 q-36 -53 -111.5 -99.5t-136.5 -46.5q-25 0 -75.5 63t-106.5 139.5t-84 96.5q-6 4 -27 30q-482 -112 -513 -112q-16 0 -28 11t-12 27q0 15 8.5 26.5t22.5 14.5l486 106q-8 14 -8 25t5.5 17.5t16 11.5t20 7t23 4.5t18.5 4.5q4 1 15.5 7.5t17.5 6.5q15 0 28 -16t20 -33 q163 37 172 37q17 0 29.5 -11t12.5 -28q0 -15 -8.5 -26t-23.5 -14l-182 -40l-1 -16q-1 -26 81.5 -117.5t104.5 -91.5q47 0 119 80t72 129q0 36 -23.5 53t-51 18.5t-51 11.5t-23.5 34q0 16 10 34l-68 19q43 44 43 117q0 26 -5 58q82 16 144 16q44 0 71.5 -1.5t48.5 -8.5 t31 -13.5t20.5 -24.5t15.5 -33.5t17 -47.5t24 -60l50 25q-3 -40 -23 -60t-42.5 -21t-40 -6.5t-16.5 -20.5zM1282 842q-5 5 -13.5 15.5t-12 14.5t-10.5 11.5t-10 10.5l-8 8t-8.5 7.5t-8 5t-8.5 4.5q-7 3 -14.5 5t-20.5 2.5t-22 0.5h-32.5h-37.5q-126 0 -217 -43 q16 30 36 46.5t54 29.5t65.5 36t46 36.5t50 55t43.5 50.5q12 -9 28 -31.5t32 -36.5t38 -13l12 1v-76l22 -1q247 95 371 190q28 21 50 39t42.5 37.5t33 31t29.5 34t24 31t24.5 37t23 38t27 47.5t29.5 53l7 9q-2 -53 -43 -139q-79 -165 -205 -264t-306 -142q-14 -3 -42 -7.5 t-50 -9.5t-39 -14q3 -19 24.5 -46t21.5 -34q0 -11 -26 -30zM1061 -79q39 26 131.5 47.5t146.5 21.5q9 0 22.5 -15.5t28 -42.5t26 -50t24 -51t14.5 -33q-121 -45 -244 -45q-61 0 -125 11zM822 568l48 12l109 -177l-73 -48zM1323 51q3 -15 3 -16q0 -7 -17.5 -14.5t-46 -13 t-54 -9.5t-53.5 -7.5t-32 -4.5l-7 43q21 2 60.5 8.5t72 10t60.5 3.5h14zM866 679l-96 -20l-6 17q10 1 32.5 7t34.5 6q19 0 35 -10zM1061 45h31l10 -83l-41 -12v95zM1950 1535v1v-1zM1950 1535l-1 -5l-2 -2l1 3zM1950 1535l1 1z" /> +<glyph unicode="" d="M1167 -50q-5 19 -24 5q-30 -22 -87 -39t-131 -17q-129 0 -193 49q-5 4 -13 4q-11 0 -26 -12q-7 -6 -7.5 -16t7.5 -20q34 -32 87.5 -46t102.5 -12.5t99 4.5q41 4 84.5 20.5t65 30t28.5 20.5q12 12 7 29zM1128 65q-19 47 -39 61q-23 15 -76 15q-47 0 -71 -10 q-29 -12 -78 -56q-26 -24 -12 -44q9 -8 17.5 -4.5t31.5 23.5q3 2 10.5 8.5t10.5 8.5t10 7t11.5 7t12.5 5t15 4.5t16.5 2.5t20.5 1q27 0 44.5 -7.5t23 -14.5t13.5 -22q10 -17 12.5 -20t12.5 1q23 12 14 34zM1483 346q0 22 -5 44.5t-16.5 45t-34 36.5t-52.5 14 q-33 0 -97 -41.5t-129 -83.5t-101 -42q-27 -1 -63.5 19t-76 49t-83.5 58t-100 49t-111 19q-115 -1 -197 -78.5t-84 -178.5q-2 -112 74 -164q29 -20 62.5 -28.5t103.5 -8.5q57 0 132 32.5t134 71t120 70.5t93 31q26 -1 65 -31.5t71.5 -67t68 -67.5t55.5 -32q35 -3 58.5 14 t55.5 63q28 41 42.5 101t14.5 106zM1536 506q0 -164 -62 -304.5t-166 -236t-242.5 -149.5t-290.5 -54t-293 57.5t-247.5 157t-170.5 241.5t-64 302q0 89 19.5 172.5t49 145.5t70.5 118.5t78.5 94t78.5 69.5t64.5 46.5t42.5 24.5q14 8 51 26.5t54.5 28.5t48 30t60.5 44 q36 28 58 72.5t30 125.5q129 -155 186 -193q44 -29 130 -68t129 -66q21 -13 39 -25t60.5 -46.5t76 -70.5t75 -95t69 -122t47 -148.5t19.5 -177.5z" /> +<glyph unicode="" d="M1070 463l-160 -160l-151 -152l-30 -30q-65 -64 -151.5 -87t-171.5 -2q-16 -70 -72 -115t-129 -45q-85 0 -145 60.5t-60 145.5q0 72 44.5 128t113.5 72q-22 86 1 173t88 152l12 12l151 -152l-11 -11q-37 -37 -37 -89t37 -90q37 -37 89 -37t89 37l30 30l151 152l161 160z M729 1145l12 -12l-152 -152l-12 12q-37 37 -89 37t-89 -37t-37 -89.5t37 -89.5l29 -29l152 -152l160 -160l-151 -152l-161 160l-151 152l-30 30q-68 67 -90 159.5t5 179.5q-70 15 -115 71t-45 129q0 85 60 145.5t145 60.5q76 0 133.5 -49t69.5 -123q84 20 169.5 -3.5 t149.5 -87.5zM1536 78q0 -85 -60 -145.5t-145 -60.5q-74 0 -131 47t-71 118q-86 -28 -179.5 -6t-161.5 90l-11 12l151 152l12 -12q37 -37 89 -37t89 37t37 89t-37 89l-30 30l-152 152l-160 160l152 152l160 -160l152 -152l29 -30q64 -64 87.5 -150.5t2.5 -171.5 q76 -11 126.5 -68.5t50.5 -134.5zM1534 1202q0 -77 -51 -135t-127 -69q26 -85 3 -176.5t-90 -158.5l-12 -12l-151 152l12 12q37 37 37 89t-37 89t-89 37t-89 -37l-30 -30l-152 -152l-160 -160l-152 152l161 160l152 152l29 30q67 67 159 89.5t178 -3.5q11 75 68.5 126 t135.5 51q85 0 145 -60.5t60 -145.5z" /> +<glyph unicode="" d="M654 458q-1 -3 -12.5 0.5t-31.5 11.5l-20 9q-44 20 -87 49q-7 5 -41 31.5t-38 28.5q-67 -103 -134 -181q-81 -95 -105 -110q-4 -2 -19.5 -4t-18.5 0q6 4 82 92q21 24 85.5 115t78.5 118q17 30 51 98.5t36 77.5q-8 1 -110 -33q-8 -2 -27.5 -7.5t-34.5 -9.5t-17 -5 q-2 -2 -2 -10.5t-1 -9.5q-5 -10 -31 -15q-23 -7 -47 0q-18 4 -28 21q-4 6 -5 23q6 2 24.5 5t29.5 6q58 16 105 32q100 35 102 35q10 2 43 19.5t44 21.5q9 3 21.5 8t14.5 5.5t6 -0.5q2 -12 -1 -33q0 -2 -12.5 -27t-26.5 -53.5t-17 -33.5q-25 -50 -77 -131l64 -28 q12 -6 74.5 -32t67.5 -28q4 -1 10.5 -25.5t4.5 -30.5zM449 944q3 -15 -4 -28q-12 -23 -50 -38q-30 -12 -60 -12q-26 3 -49 26q-14 15 -18 41l1 3q3 -3 19.5 -5t26.5 0t58 16q36 12 55 14q17 0 21 -17zM1147 815l63 -227l-139 42zM39 15l694 232v1032l-694 -233v-1031z M1280 332l102 -31l-181 657l-100 31l-216 -536l102 -31l45 110l211 -65zM777 1294l573 -184v380zM1088 -29l158 -13l-54 -160l-40 66q-130 -83 -276 -108q-58 -12 -91 -12h-84q-79 0 -199.5 39t-183.5 85q-8 7 -8 16q0 8 5 13.5t13 5.5q4 0 18 -7.5t30.5 -16.5t20.5 -11 q73 -37 159.5 -61.5t157.5 -24.5q95 0 167 14.5t157 50.5q15 7 30.5 15.5t34 19t28.5 16.5zM1536 1050v-1079l-774 246q-14 -6 -375 -127.5t-368 -121.5q-13 0 -18 13q0 1 -1 3v1078q3 9 4 10q5 6 20 11q106 35 149 50v384l558 -198q2 0 160.5 55t316 108.5t161.5 53.5 q20 0 20 -21v-418z" /> +<glyph unicode="" horiz-adv-x="1792" d="M288 1152q66 0 113 -47t47 -113v-1088q0 -66 -47 -113t-113 -47h-128q-66 0 -113 47t-47 113v1088q0 66 47 113t113 47h128zM1664 989q58 -34 93 -93t35 -128v-768q0 -106 -75 -181t-181 -75h-864q-66 0 -113 47t-47 113v1536q0 40 28 68t68 28h672q40 0 88 -20t76 -48 l152 -152q28 -28 48 -76t20 -88v-163zM928 0v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM928 256v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM928 512v128q0 14 -9 23 t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1184 0v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1184 256v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128 q14 0 23 9t9 23zM1184 512v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1440 0v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1440 256v128q0 14 -9 23t-23 9h-128 q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1440 512v128q0 14 -9 23t-23 9h-128q-14 0 -23 -9t-9 -23v-128q0 -14 9 -23t23 -9h128q14 0 23 9t9 23zM1536 896v256h-160q-40 0 -68 28t-28 68v160h-640v-512h896z" /> +<glyph unicode="" d="M1344 1536q26 0 45 -19t19 -45v-1664q0 -26 -19 -45t-45 -19h-1280q-26 0 -45 19t-19 45v1664q0 26 19 45t45 19h1280zM512 1248v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23zM512 992v-64q0 -14 9 -23t23 -9h64q14 0 23 9 t9 23v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23zM512 736v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23zM512 480v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23zM384 160v64 q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM384 416v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM384 672v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64 q14 0 23 9t9 23zM384 928v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM384 1184v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM896 -96v192q0 14 -9 23t-23 9h-320q-14 0 -23 -9 t-9 -23v-192q0 -14 9 -23t23 -9h320q14 0 23 9t9 23zM896 416v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM896 672v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM896 928v64 q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM896 1184v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1152 160v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64 q14 0 23 9t9 23zM1152 416v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1152 672v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1152 928v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9 t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1152 1184v64q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-64q0 -14 9 -23t23 -9h64q14 0 23 9t9 23z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1188 988l-292 -292v-824q0 -46 -33 -79t-79 -33t-79 33t-33 79v384h-64v-384q0 -46 -33 -79t-79 -33t-79 33t-33 79v824l-292 292q-28 28 -28 68t28 68t68 28t68 -28l228 -228h368l228 228q28 28 68 28t68 -28t28 -68t-28 -68zM864 1152q0 -93 -65.5 -158.5 t-158.5 -65.5t-158.5 65.5t-65.5 158.5t65.5 158.5t158.5 65.5t158.5 -65.5t65.5 -158.5z" /> +<glyph unicode="" horiz-adv-x="1664" d="M780 1064q0 -60 -19 -113.5t-63 -92.5t-105 -39q-76 0 -138 57.5t-92 135.5t-30 151q0 60 19 113.5t63 92.5t105 39q77 0 138.5 -57.5t91.5 -135t30 -151.5zM438 581q0 -80 -42 -139t-119 -59q-76 0 -141.5 55.5t-100.5 133.5t-35 152q0 80 42 139.5t119 59.5 q76 0 141.5 -55.5t100.5 -134t35 -152.5zM832 608q118 0 255 -97.5t229 -237t92 -254.5q0 -46 -17 -76.5t-48.5 -45t-64.5 -20t-76 -5.5q-68 0 -187.5 45t-182.5 45q-66 0 -192.5 -44.5t-200.5 -44.5q-183 0 -183 146q0 86 56 191.5t139.5 192.5t187.5 146t193 59zM1071 819 q-61 0 -105 39t-63 92.5t-19 113.5q0 74 30 151.5t91.5 135t138.5 57.5q61 0 105 -39t63 -92.5t19 -113.5q0 -73 -30 -151t-92 -135.5t-138 -57.5zM1503 923q77 0 119 -59.5t42 -139.5q0 -74 -35 -152t-100.5 -133.5t-141.5 -55.5q-77 0 -119 59t-42 139q0 74 35 152.5 t100.5 134t141.5 55.5z" /> +<glyph unicode="" horiz-adv-x="768" d="M704 1008q0 -145 -57 -243.5t-152 -135.5l45 -821q2 -26 -16 -45t-44 -19h-192q-26 0 -44 19t-16 45l45 821q-95 37 -152 135.5t-57 243.5q0 128 42.5 249.5t117.5 200t160 78.5t160 -78.5t117.5 -200t42.5 -249.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M896 -93l640 349v636l-640 -233v-752zM832 772l698 254l-698 254l-698 -254zM1664 1024v-768q0 -35 -18 -65t-49 -47l-704 -384q-28 -16 -61 -16t-61 16l-704 384q-31 17 -49 47t-18 65v768q0 40 23 73t61 47l704 256q22 8 44 8t44 -8l704 -256q38 -14 61 -47t23 -73z " /> +<glyph unicode="" horiz-adv-x="2304" d="M640 -96l384 192v314l-384 -164v-342zM576 358l404 173l-404 173l-404 -173zM1664 -96l384 192v314l-384 -164v-342zM1600 358l404 173l-404 173l-404 -173zM1152 651l384 165v266l-384 -164v-267zM1088 1030l441 189l-441 189l-441 -189zM2176 512v-416q0 -36 -19 -67 t-52 -47l-448 -224q-25 -14 -57 -14t-57 14l-448 224q-5 2 -7 4q-2 -2 -7 -4l-448 -224q-25 -14 -57 -14t-57 14l-448 224q-33 16 -52 47t-19 67v416q0 38 21.5 70t56.5 48l434 186v400q0 38 21.5 70t56.5 48l448 192q23 10 50 10t50 -10l448 -192q35 -16 56.5 -48t21.5 -70 v-400l434 -186q36 -16 57 -48t21 -70z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1848 1197h-511v-124h511v124zM1596 771q-90 0 -146 -52.5t-62 -142.5h408q-18 195 -200 195zM1612 186q63 0 122 32t76 87h221q-100 -307 -427 -307q-214 0 -340.5 132t-126.5 347q0 208 130.5 345.5t336.5 137.5q138 0 240.5 -68t153 -179t50.5 -248q0 -17 -2 -47h-658 q0 -111 57.5 -171.5t166.5 -60.5zM277 236h296q205 0 205 167q0 180 -199 180h-302v-347zM277 773h281q78 0 123.5 36.5t45.5 113.5q0 144 -190 144h-260v-294zM0 1282h594q87 0 155 -14t126.5 -47.5t90 -96.5t31.5 -154q0 -181 -172 -263q114 -32 172 -115t58 -204 q0 -75 -24.5 -136.5t-66 -103.5t-98.5 -71t-121 -42t-134 -13h-611v1260z" /> +<glyph unicode="" d="M1248 1408q119 0 203.5 -84.5t84.5 -203.5v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960zM499 1041h-371v-787h382q117 0 197 57.5t80 170.5q0 158 -143 200q107 52 107 164q0 57 -19.5 96.5 t-56.5 60.5t-79 29.5t-97 8.5zM477 723h-176v184h163q119 0 119 -90q0 -94 -106 -94zM486 388h-185v217h189q124 0 124 -113q0 -104 -128 -104zM1136 356q-68 0 -104 38t-36 107h411q1 10 1 30q0 132 -74.5 220.5t-203.5 88.5q-128 0 -210 -86t-82 -216q0 -135 79 -217 t213 -82q205 0 267 191h-138q-11 -34 -47.5 -54t-75.5 -20zM1126 722q113 0 124 -122h-254q4 56 39 89t91 33zM964 988h319v-77h-319v77z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1582 954q0 -101 -71.5 -172.5t-172.5 -71.5t-172.5 71.5t-71.5 172.5t71.5 172.5t172.5 71.5t172.5 -71.5t71.5 -172.5zM812 212q0 104 -73 177t-177 73q-27 0 -54 -6l104 -42q77 -31 109.5 -106.5t1.5 -151.5q-31 -77 -107 -109t-152 -1q-21 8 -62 24.5t-61 24.5 q32 -60 91 -96.5t130 -36.5q104 0 177 73t73 177zM1642 953q0 126 -89.5 215.5t-215.5 89.5q-127 0 -216.5 -89.5t-89.5 -215.5q0 -127 89.5 -216t216.5 -89q126 0 215.5 89t89.5 216zM1792 953q0 -189 -133.5 -322t-321.5 -133l-437 -319q-12 -129 -109 -218t-229 -89 q-121 0 -214 76t-118 192l-230 92v429l389 -157q79 48 173 48q13 0 35 -2l284 407q2 187 135.5 319t320.5 132q188 0 321.5 -133.5t133.5 -321.5z" /> +<glyph unicode="" d="M1242 889q0 80 -57 136.5t-137 56.5t-136.5 -57t-56.5 -136q0 -80 56.5 -136.5t136.5 -56.5t137 56.5t57 136.5zM632 301q0 -83 -58 -140.5t-140 -57.5q-56 0 -103 29t-72 77q52 -20 98 -40q60 -24 120 1.5t85 86.5q24 60 -1.5 120t-86.5 84l-82 33q22 5 42 5 q82 0 140 -57.5t58 -140.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v153l172 -69q20 -92 93.5 -152t168.5 -60q104 0 181 70t87 173l345 252q150 0 255.5 105.5t105.5 254.5q0 150 -105.5 255.5t-255.5 105.5 q-148 0 -253 -104.5t-107 -252.5l-225 -322q-9 1 -28 1q-75 0 -137 -37l-297 119v468q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5zM1289 887q0 -100 -71 -170.5t-171 -70.5t-170.5 70.5t-70.5 170.5t70.5 171t170.5 71q101 0 171.5 -70.5t70.5 -171.5z " /> +<glyph unicode="" horiz-adv-x="1792" d="M836 367l-15 -368l-2 -22l-420 29q-36 3 -67 31.5t-47 65.5q-11 27 -14.5 55t4 65t12 55t21.5 64t19 53q78 -12 509 -28zM449 953l180 -379l-147 92q-63 -72 -111.5 -144.5t-72.5 -125t-39.5 -94.5t-18.5 -63l-4 -21l-190 357q-17 26 -18 56t6 47l8 18q35 63 114 188 l-140 86zM1680 436l-188 -359q-12 -29 -36.5 -46.5t-43.5 -20.5l-18 -4q-71 -7 -219 -12l8 -164l-230 367l211 362l7 -173q170 -16 283 -5t170 33zM895 1360q-47 -63 -265 -435l-317 187l-19 12l225 356q20 31 60 45t80 10q24 -2 48.5 -12t42 -21t41.5 -33t36 -34.5 t36 -39.5t32 -35zM1550 1053l212 -363q18 -37 12.5 -76t-27.5 -74q-13 -20 -33 -37t-38 -28t-48.5 -22t-47 -16t-51.5 -14t-46 -12q-34 72 -265 436l313 195zM1407 1279l142 83l-220 -373l-419 20l151 86q-34 89 -75 166t-75.5 123.5t-64.5 80t-47 46.5l-17 13l405 -1 q31 3 58 -10.5t39 -28.5l11 -15q39 -61 112 -190z" /> +<glyph unicode="" horiz-adv-x="2048" d="M480 448q0 66 -47 113t-113 47t-113 -47t-47 -113t47 -113t113 -47t113 47t47 113zM516 768h1016l-89 357q-2 8 -14 17.5t-21 9.5h-768q-9 0 -21 -9.5t-14 -17.5zM1888 448q0 66 -47 113t-113 47t-113 -47t-47 -113t47 -113t113 -47t113 47t47 113zM2048 544v-384 q0 -14 -9 -23t-23 -9h-96v-128q0 -80 -56 -136t-136 -56t-136 56t-56 136v128h-1024v-128q0 -80 -56 -136t-136 -56t-136 56t-56 136v128h-96q-14 0 -23 9t-9 23v384q0 93 65.5 158.5t158.5 65.5h28l105 419q23 94 104 157.5t179 63.5h768q98 0 179 -63.5t104 -157.5 l105 -419h28q93 0 158.5 -65.5t65.5 -158.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1824 640q93 0 158.5 -65.5t65.5 -158.5v-384q0 -14 -9 -23t-23 -9h-96v-64q0 -80 -56 -136t-136 -56t-136 56t-56 136v64h-1024v-64q0 -80 -56 -136t-136 -56t-136 56t-56 136v64h-96q-14 0 -23 9t-9 23v384q0 93 65.5 158.5t158.5 65.5h28l105 419q23 94 104 157.5 t179 63.5h128v224q0 14 9 23t23 9h448q14 0 23 -9t9 -23v-224h128q98 0 179 -63.5t104 -157.5l105 -419h28zM320 160q66 0 113 47t47 113t-47 113t-113 47t-113 -47t-47 -113t47 -113t113 -47zM516 640h1016l-89 357q-2 8 -14 17.5t-21 9.5h-768q-9 0 -21 -9.5t-14 -17.5z M1728 160q66 0 113 47t47 113t-47 113t-113 47t-113 -47t-47 -113t47 -113t113 -47z" /> +<glyph unicode="" d="M1504 64q0 -26 -19 -45t-45 -19h-462q1 -17 6 -87.5t5 -108.5q0 -25 -18 -42.5t-43 -17.5h-320q-25 0 -43 17.5t-18 42.5q0 38 5 108.5t6 87.5h-462q-26 0 -45 19t-19 45t19 45l402 403h-229q-26 0 -45 19t-19 45t19 45l402 403h-197q-26 0 -45 19t-19 45t19 45l384 384 q19 19 45 19t45 -19l384 -384q19 -19 19 -45t-19 -45t-45 -19h-197l402 -403q19 -19 19 -45t-19 -45t-45 -19h-229l402 -403q19 -19 19 -45z" /> +<glyph unicode="" d="M1127 326q0 32 -30 51q-193 115 -447 115q-133 0 -287 -34q-42 -9 -42 -52q0 -20 13.5 -34.5t35.5 -14.5q5 0 37 8q132 27 243 27q226 0 397 -103q19 -11 33 -11q19 0 33 13.5t14 34.5zM1223 541q0 40 -35 61q-237 141 -548 141q-153 0 -303 -42q-48 -13 -48 -64 q0 -25 17.5 -42.5t42.5 -17.5q7 0 37 8q122 33 251 33q279 0 488 -124q24 -13 38 -13q25 0 42.5 17.5t17.5 42.5zM1331 789q0 47 -40 70q-126 73 -293 110.5t-343 37.5q-204 0 -364 -47q-23 -7 -38.5 -25.5t-15.5 -48.5q0 -31 20.5 -52t51.5 -21q11 0 40 8q133 37 307 37 q159 0 309.5 -34t253.5 -95q21 -12 40 -12q29 0 50.5 20.5t21.5 51.5zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M1397 1408q58 0 98.5 -40.5t40.5 -98.5v-1258q0 -58 -40.5 -98.5t-98.5 -40.5h-1258q-58 0 -98.5 40.5t-40.5 98.5v1258q0 58 40.5 98.5t98.5 40.5h1258zM1465 11v1258q0 28 -20 48t-48 20h-1258q-28 0 -48 -20t-20 -48v-1258q0 -28 20 -48t48 -20h1258q28 0 48 20t20 48 zM694 749l188 -387l533 145v-496q0 -7 -5.5 -12.5t-12.5 -5.5h-1258q-7 0 -12.5 5.5t-5.5 12.5v141l711 195l-212 439q4 1 12 2.5t12 1.5q170 32 303.5 21.5t221 -46t143.5 -94.5q27 -28 -25 -42q-64 -16 -256 -62l-97 198q-111 7 -240 -16zM1397 1287q7 0 12.5 -5.5 t5.5 -12.5v-428q-85 30 -188 52q-294 64 -645 12l-18 -3l-65 134h-233l85 -190q-132 -51 -230 -137v560q0 7 5.5 12.5t12.5 5.5h1258zM286 387q-14 -3 -26 4.5t-14 21.5q-24 203 166 305l129 -270z" /> +<glyph unicode="" horiz-adv-x="2304" d="M784 164l16 241l-16 523q-1 10 -7.5 17t-16.5 7q-9 0 -16 -7t-7 -17l-14 -523l14 -241q1 -10 7.5 -16.5t15.5 -6.5q22 0 24 23zM1080 193l11 211l-12 586q0 16 -13 24q-8 5 -16 5t-16 -5q-13 -8 -13 -24l-1 -6l-10 -579q0 -1 11 -236v-1q0 -10 6 -17q9 -11 23 -11 q11 0 20 9q9 7 9 20zM35 533l20 -128l-20 -126q-2 -9 -9 -9t-9 9l-17 126l17 128q2 9 9 9t9 -9zM121 612l26 -207l-26 -203q-2 -9 -10 -9q-9 0 -9 10l-23 202l23 207q0 9 9 9q8 0 10 -9zM401 159zM213 650l25 -245l-25 -237q0 -11 -11 -11q-10 0 -12 11l-21 237l21 245 q2 12 12 12q11 0 11 -12zM307 657l23 -252l-23 -244q-2 -13 -14 -13q-13 0 -13 13l-21 244l21 252q0 13 13 13q12 0 14 -13zM401 639l21 -234l-21 -246q-2 -16 -16 -16q-6 0 -10.5 4.5t-4.5 11.5l-20 246l20 234q0 6 4.5 10.5t10.5 4.5q14 0 16 -15zM784 164zM495 785 l21 -380l-21 -246q0 -7 -5 -12.5t-12 -5.5q-16 0 -18 18l-18 246l18 380q2 18 18 18q7 0 12 -5.5t5 -12.5zM589 871l19 -468l-19 -244q0 -8 -5.5 -13.5t-13.5 -5.5q-18 0 -20 19l-16 244l16 468q2 19 20 19q8 0 13.5 -5.5t5.5 -13.5zM687 911l18 -506l-18 -242 q-2 -21 -22 -21q-19 0 -21 21l-16 242l16 506q0 9 6.5 15.5t14.5 6.5q9 0 15 -6.5t7 -15.5zM1079 169v0v0zM881 915l15 -510l-15 -239q0 -10 -7.5 -17.5t-17.5 -7.5t-17 7t-8 18l-14 239l14 510q0 11 7.5 18t17.5 7t17.5 -7t7.5 -18zM980 896l14 -492l-14 -236q0 -11 -8 -19 t-19 -8t-19 8t-9 19l-12 236l12 492q1 12 9 20t19 8t18.5 -8t8.5 -20zM1192 404l-14 -231v0q0 -13 -9 -22t-22 -9t-22 9t-10 22l-6 114l-6 117l12 636v3q2 15 12 24q9 7 20 7q8 0 15 -5q14 -8 16 -26zM2304 423q0 -117 -83 -199.5t-200 -82.5h-786q-13 2 -22 11t-9 22v899 q0 23 28 33q85 34 181 34q195 0 338 -131.5t160 -323.5q53 22 110 22q117 0 200 -83t83 -201z" /> +<glyph unicode="" d="M768 768q237 0 443 43t325 127v-170q0 -69 -103 -128t-280 -93.5t-385 -34.5t-385 34.5t-280 93.5t-103 128v170q119 -84 325 -127t443 -43zM768 0q237 0 443 43t325 127v-170q0 -69 -103 -128t-280 -93.5t-385 -34.5t-385 34.5t-280 93.5t-103 128v170q119 -84 325 -127 t443 -43zM768 384q237 0 443 43t325 127v-170q0 -69 -103 -128t-280 -93.5t-385 -34.5t-385 34.5t-280 93.5t-103 128v170q119 -84 325 -127t443 -43zM768 1536q208 0 385 -34.5t280 -93.5t103 -128v-128q0 -69 -103 -128t-280 -93.5t-385 -34.5t-385 34.5t-280 93.5 t-103 128v128q0 69 103 128t280 93.5t385 34.5z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M894 465q33 -26 84 -56q59 7 117 7q147 0 177 -49q16 -22 2 -52q0 -1 -1 -2l-2 -2v-1q-6 -38 -71 -38q-48 0 -115 20t-130 53q-221 -24 -392 -83q-153 -262 -242 -262q-15 0 -28 7l-24 12q-1 1 -6 5q-10 10 -6 36q9 40 56 91.5t132 96.5q14 9 23 -6q2 -2 2 -4q52 85 107 197 q68 136 104 262q-24 82 -30.5 159.5t6.5 127.5q11 40 42 40h21h1q23 0 35 -15q18 -21 9 -68q-2 -6 -4 -8q1 -3 1 -8v-30q-2 -123 -14 -192q55 -164 146 -238zM318 54q52 24 137 158q-51 -40 -87.5 -84t-49.5 -74zM716 974q-15 -42 -2 -132q1 7 7 44q0 3 7 43q1 4 4 8 q-1 1 -1 2t-0.5 1.5t-0.5 1.5q-1 22 -13 36q0 -1 -1 -2v-2zM592 313q135 54 284 81q-2 1 -13 9.5t-16 13.5q-76 67 -127 176q-27 -86 -83 -197q-30 -56 -45 -83zM1238 329q-24 24 -140 24q76 -28 124 -28q14 0 18 1q0 1 -2 3z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M233 768v-107h70l164 -661h159l128 485q7 20 10 46q2 16 2 24h4l3 -24q1 -3 3.5 -20t5.5 -26l128 -485h159l164 661h70v107h-300v-107h90l-99 -438q-5 -20 -7 -46l-2 -21h-4l-3 21q-1 5 -4 21t-5 25l-144 545h-114l-144 -545q-2 -9 -4.5 -24.5t-3.5 -21.5l-4 -21h-4l-2 21 q-2 26 -7 46l-99 438h90v107h-300z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M429 106v-106h281v106h-75l103 161q5 7 10 16.5t7.5 13.5t3.5 4h2q1 -4 5 -10q2 -4 4.5 -7.5t6 -8t6.5 -8.5l107 -161h-76v-106h291v106h-68l-192 273l195 282h67v107h-279v-107h74l-103 -159q-4 -7 -10 -16.5t-9 -13.5l-2 -3h-2q-1 4 -5 10q-6 11 -17 23l-106 159h76v107 h-290v-107h68l189 -272l-194 -283h-68z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M416 106v-106h327v106h-93v167h137q76 0 118 15q67 23 106.5 87t39.5 146q0 81 -37 141t-100 87q-48 19 -130 19h-368v-107h92v-555h-92zM769 386h-119v268h120q52 0 83 -18q56 -33 56 -115q0 -89 -62 -120q-31 -15 -78 -15z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M1280 320v-320h-1024v192l192 192l128 -128l384 384zM448 512q-80 0 -136 56t-56 136t56 136t136 56t136 -56t56 -136t-56 -136t-136 -56z" /> +<glyph unicode="" d="M640 1152v128h-128v-128h128zM768 1024v128h-128v-128h128zM640 896v128h-128v-128h128zM768 768v128h-128v-128h128zM1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400 v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-128v-128h-128v128h-512v-1536h1280zM781 593l107 -349q8 -27 8 -52q0 -83 -72.5 -137.5t-183.5 -54.5t-183.5 54.5t-72.5 137.5q0 25 8 52q21 63 120 396v128h128v-128h79 q22 0 39 -13t23 -34zM640 128q53 0 90.5 19t37.5 45t-37.5 45t-90.5 19t-90.5 -19t-37.5 -45t37.5 -45t90.5 -19z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M620 686q20 -8 20 -30v-544q0 -22 -20 -30q-8 -2 -12 -2q-12 0 -23 9l-166 167h-131q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h131l166 167q16 15 35 7zM1037 -3q31 0 50 24q129 159 129 363t-129 363q-16 21 -43 24t-47 -14q-21 -17 -23.5 -43.5t14.5 -47.5 q100 -123 100 -282t-100 -282q-17 -21 -14.5 -47.5t23.5 -42.5q18 -15 40 -15zM826 145q27 0 47 20q87 93 87 219t-87 219q-18 19 -45 20t-46 -17t-20 -44.5t18 -46.5q52 -57 52 -131t-52 -131q-19 -20 -18 -46.5t20 -44.5q20 -17 44 -17z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M768 768q52 0 90 -38t38 -90v-384q0 -52 -38 -90t-90 -38h-384q-52 0 -90 38t-38 90v384q0 52 38 90t90 38h384zM1260 766q20 -8 20 -30v-576q0 -22 -20 -30q-8 -2 -12 -2q-14 0 -23 9l-265 266v90l265 266q9 9 23 9q4 0 12 -2z" /> +<glyph unicode="" d="M1468 1156q28 -28 48 -76t20 -88v-1152q0 -40 -28 -68t-68 -28h-1344q-40 0 -68 28t-28 68v1600q0 40 28 68t68 28h896q40 0 88 -20t76 -48zM1024 1400v-376h376q-10 29 -22 41l-313 313q-12 12 -41 22zM1408 -128v1024h-416q-40 0 -68 28t-28 68v416h-768v-1536h1280z M480 768q8 11 21 12.5t24 -6.5l51 -38q11 -8 12.5 -21t-6.5 -24l-182 -243l182 -243q8 -11 6.5 -24t-12.5 -21l-51 -38q-11 -8 -24 -6.5t-21 12.5l-226 301q-14 19 0 38zM1282 467q14 -19 0 -38l-226 -301q-8 -11 -21 -12.5t-24 6.5l-51 38q-11 8 -12.5 21t6.5 24l182 243 l-182 243q-8 11 -6.5 24t12.5 21l51 38q11 8 24 6.5t21 -12.5zM662 6q-13 2 -20.5 13t-5.5 24l138 831q2 13 13 20.5t24 5.5l63 -10q13 -2 20.5 -13t5.5 -24l-138 -831q-2 -13 -13 -20.5t-24 -5.5z" /> +<glyph unicode="" d="M1497 709v-198q-101 -23 -198 -23q-65 -136 -165.5 -271t-181.5 -215.5t-128 -106.5q-80 -45 -162 3q-28 17 -60.5 43.5t-85 83.5t-102.5 128.5t-107.5 184t-105.5 244t-91.5 314.5t-70.5 390h283q26 -218 70 -398.5t104.5 -317t121.5 -235.5t140 -195q169 169 287 406 q-142 72 -223 220t-81 333q0 192 104 314.5t284 122.5q178 0 273 -105.5t95 -297.5q0 -159 -58 -286q-7 -1 -19.5 -3t-46 -2t-63 6t-62 25.5t-50.5 51.5q31 103 31 184q0 87 -29 132t-79 45q-53 0 -85 -49.5t-32 -140.5q0 -186 105 -293.5t267 -107.5q62 0 121 14z" /> +<glyph unicode="" horiz-adv-x="1792" d="M216 367l603 -402v359l-334 223zM154 511l193 129l-193 129v-258zM973 -35l603 402l-269 180l-334 -223v-359zM896 458l272 182l-272 182l-272 -182zM485 733l334 223v359l-603 -402zM1445 640l193 -129v258zM1307 733l269 180l-603 402v-359zM1792 913v-546 q0 -41 -34 -64l-819 -546q-21 -13 -43 -13t-43 13l-819 546q-34 23 -34 64v546q0 41 34 64l819 546q21 13 43 13t43 -13l819 -546q34 -23 34 -64z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1800 764q111 -46 179.5 -145.5t68.5 -221.5q0 -164 -118 -280.5t-285 -116.5q-4 0 -11.5 0.5t-10.5 0.5h-1209h-1h-2h-5q-170 10 -288 125.5t-118 280.5q0 110 55 203t147 147q-12 39 -12 82q0 115 82 196t199 81q95 0 172 -58q75 154 222.5 248t326.5 94 q166 0 306 -80.5t221.5 -218.5t81.5 -301q0 -6 -0.5 -18t-0.5 -18zM468 498q0 -122 84 -193t208 -71q137 0 240 99q-16 20 -47.5 56.5t-43.5 50.5q-67 -65 -144 -65q-55 0 -93.5 33.5t-38.5 87.5q0 53 38.5 87t91.5 34q44 0 84.5 -21t73 -55t65 -75t69 -82t77 -75t97 -55 t121.5 -21q121 0 204.5 71.5t83.5 190.5q0 121 -84 192t-207 71q-143 0 -241 -97q14 -16 29.5 -34t34.5 -40t29 -34q66 64 142 64q52 0 92 -33t40 -84q0 -57 -37 -91.5t-94 -34.5q-43 0 -82.5 21t-72 55t-65.5 75t-69.5 82t-77.5 75t-96.5 55t-118.5 21q-122 0 -207 -70.5 t-85 -189.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M896 1536q182 0 348 -71t286 -191t191 -286t71 -348t-71 -348t-191 -286t-286 -191t-348 -71t-348 71t-286 191t-191 286t-71 348t71 348t191 286t286 191t348 71zM896 1408q-190 0 -361 -90l194 -194q82 28 167 28t167 -28l194 194q-171 90 -361 90zM218 279l194 194 q-28 82 -28 167t28 167l-194 194q-90 -171 -90 -361t90 -361zM896 -128q190 0 361 90l-194 194q-82 -28 -167 -28t-167 28l-194 -194q171 -90 361 -90zM896 256q159 0 271.5 112.5t112.5 271.5t-112.5 271.5t-271.5 112.5t-271.5 -112.5t-112.5 -271.5t112.5 -271.5 t271.5 -112.5zM1380 473l194 -194q90 171 90 361t-90 361l-194 -194q28 -82 28 -167t-28 -167z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 640q0 -182 -71 -348t-191 -286t-286 -191t-348 -71t-348 71t-286 191t-191 286t-71 348q0 222 101 414.5t276.5 317t390.5 155.5v-260q-221 -45 -366.5 -221t-145.5 -406q0 -130 51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5 q0 230 -145.5 406t-366.5 221v260q215 -31 390.5 -155.5t276.5 -317t101 -414.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M19 662q8 217 116 406t305 318h5q0 -1 -1 -3q-8 -8 -28 -33.5t-52 -76.5t-60 -110.5t-44.5 -135.5t-14 -150.5t39 -157.5t108.5 -154q50 -50 102 -69.5t90.5 -11.5t69.5 23.5t47 32.5l16 16q39 51 53 116.5t6.5 122.5t-21 107t-26.5 80l-14 29q-10 25 -30.5 49.5t-43 41 t-43.5 29.5t-35 19l-13 6l104 115q39 -17 78 -52t59 -61l19 -27q1 48 -18.5 103.5t-40.5 87.5l-20 31l161 183l160 -181q-33 -46 -52.5 -102.5t-22.5 -90.5l-4 -33q22 37 61.5 72.5t67.5 52.5l28 17l103 -115q-44 -14 -85 -50t-60 -65l-19 -29q-31 -56 -48 -133.5t-7 -170 t57 -156.5q33 -45 77.5 -60.5t85 -5.5t76 26.5t57.5 33.5l21 16q60 53 96.5 115t48.5 121.5t10 121.5t-18 118t-37 107.5t-45.5 93t-45 72t-34.5 47.5l-13 17q-14 13 -7 13l10 -3q40 -29 62.5 -46t62 -50t64 -58t58.5 -65t55.5 -77t45.5 -88t38 -103t23.5 -117t10.5 -136 q3 -259 -108 -465t-312 -321t-456 -115q-185 0 -351 74t-283.5 198t-184 293t-60.5 353z" /> +<glyph unicode="" horiz-adv-x="1792" d="M874 -102v-66q-208 6 -385 109.5t-283 275.5l58 34q29 -49 73 -99l65 57q148 -168 368 -212l-17 -86q65 -12 121 -13zM276 428l-83 -28q22 -60 49 -112l-57 -33q-98 180 -98 385t98 385l57 -33q-30 -56 -49 -112l82 -28q-35 -100 -35 -212q0 -109 36 -212zM1528 251 l58 -34q-106 -172 -283 -275.5t-385 -109.5v66q56 1 121 13l-17 86q220 44 368 212l65 -57q44 50 73 99zM1377 805l-233 -80q14 -42 14 -85t-14 -85l232 -80q-31 -92 -98 -169l-185 162q-57 -67 -147 -85l48 -241q-52 -10 -98 -10t-98 10l48 241q-90 18 -147 85l-185 -162 q-67 77 -98 169l232 80q-14 42 -14 85t14 85l-233 80q33 93 99 169l185 -162q59 68 147 86l-48 240q44 10 98 10t98 -10l-48 -240q88 -18 147 -86l185 162q66 -76 99 -169zM874 1448v-66q-65 -2 -121 -13l17 -86q-220 -42 -368 -211l-65 56q-38 -42 -73 -98l-57 33 q106 172 282 275.5t385 109.5zM1705 640q0 -205 -98 -385l-57 33q27 52 49 112l-83 28q36 103 36 212q0 112 -35 212l82 28q-19 56 -49 112l57 33q98 -180 98 -385zM1585 1063l-57 -33q-35 56 -73 98l-65 -56q-148 169 -368 211l17 86q-56 11 -121 13v66q209 -6 385 -109.5 t282 -275.5zM1748 640q0 173 -67.5 331t-181.5 272t-272 181.5t-331 67.5t-331 -67.5t-272 -181.5t-181.5 -272t-67.5 -331t67.5 -331t181.5 -272t272 -181.5t331 -67.5t331 67.5t272 181.5t181.5 272t67.5 331zM1792 640q0 -182 -71 -348t-191 -286t-286 -191t-348 -71 t-348 71t-286 191t-191 286t-71 348t71 348t191 286t286 191t348 71t348 -71t286 -191t191 -286t71 -348z" /> +<glyph unicode="" d="M582 228q0 -66 -93 -66q-107 0 -107 63q0 64 98 64q102 0 102 -61zM546 694q0 -85 -74 -85q-77 0 -77 84q0 90 77 90q36 0 55 -25.5t19 -63.5zM712 769v125q-78 -29 -135 -29q-50 29 -110 29q-86 0 -145 -57t-59 -143q0 -50 29.5 -102t73.5 -67v-3q-38 -17 -38 -85 q0 -53 41 -77v-3q-113 -37 -113 -139q0 -45 20 -78.5t54 -51t72 -25.5t81 -8q224 0 224 188q0 67 -48 99t-126 46q-27 5 -51.5 20.5t-24.5 39.5q0 44 49 52q77 15 122 70t45 134q0 24 -10 52q37 9 49 13zM771 350h137q-2 27 -2 82v387q0 46 2 69h-137q3 -23 3 -71v-392 q0 -50 -3 -75zM1280 366v121q-30 -21 -68 -21q-53 0 -53 82v225h52q9 0 26.5 -1t26.5 -1v117h-105q0 82 3 102h-140q4 -24 4 -55v-47h-60v-117q36 3 37 3q3 0 11 -0.5t12 -0.5v-2h-2v-217q0 -37 2.5 -64t11.5 -56.5t24.5 -48.5t43.5 -31t66 -12q64 0 108 24zM924 1072 q0 36 -24 63.5t-60 27.5t-60.5 -27t-24.5 -64q0 -36 25 -62.5t60 -26.5t59.5 27t24.5 62zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M595 22q0 100 -165 100q-158 0 -158 -104q0 -101 172 -101q151 0 151 105zM536 777q0 61 -30 102t-89 41q-124 0 -124 -145q0 -135 124 -135q119 0 119 137zM805 1101v-202q-36 -12 -79 -22q16 -43 16 -84q0 -127 -73 -216.5t-197 -112.5q-40 -8 -59.5 -27t-19.5 -58 q0 -31 22.5 -51.5t58 -32t78.5 -22t86 -25.5t78.5 -37.5t58 -64t22.5 -98.5q0 -304 -363 -304q-69 0 -130 12.5t-116 41t-87.5 82t-32.5 127.5q0 165 182 225v4q-67 41 -67 126q0 109 63 137v4q-72 24 -119.5 108.5t-47.5 165.5q0 139 95 231.5t235 92.5q96 0 178 -47 q98 0 218 47zM1123 220h-222q4 45 4 134v609q0 94 -4 128h222q-4 -33 -4 -124v-613q0 -89 4 -134zM1724 442v-196q-71 -39 -174 -39q-62 0 -107 20t-70 50t-39.5 78t-18.5 92t-4 103v351h2v4q-7 0 -19 1t-18 1q-21 0 -59 -6v190h96v76q0 54 -6 89h227q-6 -41 -6 -165h171 v-190q-15 0 -43.5 2t-42.5 2h-85v-365q0 -131 87 -131q61 0 109 33zM1148 1389q0 -58 -39 -101.5t-96 -43.5q-58 0 -98 43.5t-40 101.5q0 59 39.5 103t98.5 44q58 0 96.5 -44.5t38.5 -102.5z" /> +<glyph unicode="" d="M825 547l343 588h-150q-21 -39 -63.5 -118.5t-68 -128.5t-59.5 -118.5t-60 -128.5h-3q-21 48 -44.5 97t-52 105.5t-46.5 92t-54 104.5t-49 95h-150l323 -589v-435h134v436zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960 q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1280" d="M842 964q0 -80 -57 -136.5t-136 -56.5q-60 0 -111 35q-62 -67 -115 -146q-247 -371 -202 -859q1 -22 -12.5 -38.5t-34.5 -18.5h-5q-20 0 -35 13.5t-17 33.5q-14 126 -3.5 247.5t29.5 217t54 186t69 155.5t74 125q61 90 132 165q-16 35 -16 77q0 80 56.5 136.5t136.5 56.5 t136.5 -56.5t56.5 -136.5zM1223 953q0 -158 -78 -292t-212.5 -212t-292.5 -78q-64 0 -131 14q-21 5 -32.5 23.5t-6.5 39.5q5 20 23 31.5t39 7.5q51 -13 108 -13q97 0 186 38t153 102t102 153t38 186t-38 186t-102 153t-153 102t-186 38t-186 -38t-153 -102t-102 -153 t-38 -186q0 -114 52 -218q10 -20 3.5 -40t-25.5 -30t-39.5 -3t-30.5 26q-64 123 -64 265q0 119 46.5 227t124.5 186t186 124t226 46q158 0 292.5 -78t212.5 -212.5t78 -292.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M270 730q-8 19 -8 52q0 20 11 49t24 45q-1 22 7.5 53t22.5 43q0 139 92.5 288.5t217.5 209.5q139 66 324 66q133 0 266 -55q49 -21 90 -48t71 -56t55 -68t42 -74t32.5 -84.5t25.5 -89.5t22 -98l1 -5q55 -83 55 -150q0 -14 -9 -40t-9 -38q0 -1 1.5 -3.5t3.5 -5t2 -3.5 q77 -114 120.5 -214.5t43.5 -208.5q0 -43 -19.5 -100t-55.5 -57q-9 0 -19.5 7.5t-19 17.5t-19 26t-16 26.5t-13.5 26t-9 17.5q-1 1 -3 1l-5 -4q-59 -154 -132 -223q20 -20 61.5 -38.5t69 -41.5t35.5 -65q-2 -4 -4 -16t-7 -18q-64 -97 -302 -97q-53 0 -110.5 9t-98 20 t-104.5 30q-15 5 -23 7q-14 4 -46 4.5t-40 1.5q-41 -45 -127.5 -65t-168.5 -20q-35 0 -69 1.5t-93 9t-101 20.5t-74.5 40t-32.5 64q0 40 10 59.5t41 48.5q11 2 40.5 13t49.5 12q4 0 14 2q2 2 2 4l-2 3q-48 11 -108 105.5t-73 156.5l-5 3q-4 0 -12 -20q-18 -41 -54.5 -74.5 t-77.5 -37.5h-1q-4 0 -6 4.5t-5 5.5q-23 54 -23 100q0 275 252 466z" /> +<glyph unicode="" horiz-adv-x="2048" d="M580 1075q0 41 -25 66t-66 25q-43 0 -76 -25.5t-33 -65.5q0 -39 33 -64.5t76 -25.5q41 0 66 24.5t25 65.5zM1323 568q0 28 -25.5 50t-65.5 22q-27 0 -49.5 -22.5t-22.5 -49.5q0 -28 22.5 -50.5t49.5 -22.5q40 0 65.5 22t25.5 51zM1087 1075q0 41 -24.5 66t-65.5 25 q-43 0 -76 -25.5t-33 -65.5q0 -39 33 -64.5t76 -25.5q41 0 65.5 24.5t24.5 65.5zM1722 568q0 28 -26 50t-65 22q-27 0 -49.5 -22.5t-22.5 -49.5q0 -28 22.5 -50.5t49.5 -22.5q39 0 65 22t26 51zM1456 965q-31 4 -70 4q-169 0 -311 -77t-223.5 -208.5t-81.5 -287.5 q0 -78 23 -152q-35 -3 -68 -3q-26 0 -50 1.5t-55 6.5t-44.5 7t-54.5 10.5t-50 10.5l-253 -127l72 218q-290 203 -290 490q0 169 97.5 311t264 223.5t363.5 81.5q176 0 332.5 -66t262 -182.5t136.5 -260.5zM2048 404q0 -117 -68.5 -223.5t-185.5 -193.5l55 -181l-199 109 q-150 -37 -218 -37q-169 0 -311 70.5t-223.5 191.5t-81.5 264t81.5 264t223.5 191.5t311 70.5q161 0 303 -70.5t227.5 -192t85.5 -263.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1764 1525q33 -24 27 -64l-256 -1536q-5 -29 -32 -45q-14 -8 -31 -8q-11 0 -24 5l-453 185l-242 -295q-18 -23 -49 -23q-13 0 -22 4q-19 7 -30.5 23.5t-11.5 36.5v349l864 1059l-1069 -925l-395 162q-37 14 -40 55q-2 40 32 59l1664 960q15 9 32 9q20 0 36 -11z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1764 1525q33 -24 27 -64l-256 -1536q-5 -29 -32 -45q-14 -8 -31 -8q-11 0 -24 5l-527 215l-298 -327q-18 -21 -47 -21q-14 0 -23 4q-19 7 -30 23.5t-11 36.5v452l-472 193q-37 14 -40 55q-3 39 32 59l1664 960q35 21 68 -2zM1422 26l221 1323l-1434 -827l336 -137 l863 639l-478 -797z" /> +<glyph unicode="" d="M1536 640q0 -156 -61 -298t-164 -245t-245 -164t-298 -61q-172 0 -327 72.5t-264 204.5q-7 10 -6.5 22.5t8.5 20.5l137 138q10 9 25 9q16 -2 23 -12q73 -95 179 -147t225 -52q104 0 198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5t-40.5 198.5t-109.5 163.5 t-163.5 109.5t-198.5 40.5q-98 0 -188 -35.5t-160 -101.5l137 -138q31 -30 14 -69q-17 -40 -59 -40h-448q-26 0 -45 19t-19 45v448q0 42 40 59q39 17 69 -14l130 -129q107 101 244.5 156.5t284.5 55.5q156 0 298 -61t245 -164t164 -245t61 -298zM896 928v-448q0 -14 -9 -23 t-23 -9h-320q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h224v352q0 14 9 23t23 9h64q14 0 23 -9t9 -23z" /> +<glyph unicode="" d="M768 1280q-130 0 -248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5t-51 248.5t-136.5 204t-204 136.5t-248.5 51zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103 t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1682 -128q-44 0 -132.5 3.5t-133.5 3.5q-44 0 -132 -3.5t-132 -3.5q-24 0 -37 20.5t-13 45.5q0 31 17 46t39 17t51 7t45 15q33 21 33 140l-1 391q0 21 -1 31q-13 4 -50 4h-675q-38 0 -51 -4q-1 -10 -1 -31l-1 -371q0 -142 37 -164q16 -10 48 -13t57 -3.5t45 -15 t20 -45.5q0 -26 -12.5 -48t-36.5 -22q-47 0 -139.5 3.5t-138.5 3.5q-43 0 -128 -3.5t-127 -3.5q-23 0 -35.5 21t-12.5 45q0 30 15.5 45t36 17.5t47.5 7.5t42 15q33 23 33 143l-1 57v813q0 3 0.5 26t0 36.5t-1.5 38.5t-3.5 42t-6.5 36.5t-11 31.5t-16 18q-15 10 -45 12t-53 2 t-41 14t-18 45q0 26 12 48t36 22q46 0 138.5 -3.5t138.5 -3.5q42 0 126.5 3.5t126.5 3.5q25 0 37.5 -22t12.5 -48q0 -30 -17 -43.5t-38.5 -14.5t-49.5 -4t-43 -13q-35 -21 -35 -160l1 -320q0 -21 1 -32q13 -3 39 -3h699q25 0 38 3q1 11 1 32l1 320q0 139 -35 160 q-18 11 -58.5 12.5t-66 13t-25.5 49.5q0 26 12.5 48t37.5 22q44 0 132 -3.5t132 -3.5q43 0 129 3.5t129 3.5q25 0 37.5 -22t12.5 -48q0 -30 -17.5 -44t-40 -14.5t-51.5 -3t-44 -12.5q-35 -23 -35 -161l1 -943q0 -119 34 -140q16 -10 46 -13.5t53.5 -4.5t41.5 -15.5t18 -44.5 q0 -26 -12 -48t-36 -22z" /> +<glyph unicode="" horiz-adv-x="1280" d="M1278 1347v-73q0 -29 -18.5 -61t-42.5 -32q-50 0 -54 -1q-26 -6 -32 -31q-3 -11 -3 -64v-1152q0 -25 -18 -43t-43 -18h-108q-25 0 -43 18t-18 43v1218h-143v-1218q0 -25 -17.5 -43t-43.5 -18h-108q-26 0 -43.5 18t-17.5 43v496q-147 12 -245 59q-126 58 -192 179 q-64 117 -64 259q0 166 88 286q88 118 209 159q111 37 417 37h479q25 0 43 -18t18 -43z" /> +<glyph unicode="" d="M352 128v-128h-352v128h352zM704 256q26 0 45 -19t19 -45v-256q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h256zM864 640v-128h-864v128h864zM224 1152v-128h-224v128h224zM1536 128v-128h-736v128h736zM576 1280q26 0 45 -19t19 -45v-256 q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h256zM1216 768q26 0 45 -19t19 -45v-256q0 -26 -19 -45t-45 -19h-256q-26 0 -45 19t-19 45v256q0 26 19 45t45 19h256zM1536 640v-128h-224v128h224zM1536 1152v-128h-864v128h864z" /> +<glyph unicode="" d="M1216 512q133 0 226.5 -93.5t93.5 -226.5t-93.5 -226.5t-226.5 -93.5t-226.5 93.5t-93.5 226.5q0 12 2 34l-360 180q-92 -86 -218 -86q-133 0 -226.5 93.5t-93.5 226.5t93.5 226.5t226.5 93.5q126 0 218 -86l360 180q-2 22 -2 34q0 133 93.5 226.5t226.5 93.5 t226.5 -93.5t93.5 -226.5t-93.5 -226.5t-226.5 -93.5q-126 0 -218 86l-360 -180q2 -22 2 -34t-2 -34l360 -180q92 86 218 86z" /> +<glyph unicode="" d="M1280 341q0 88 -62.5 151t-150.5 63q-84 0 -145 -58l-241 120q2 16 2 23t-2 23l241 120q61 -58 145 -58q88 0 150.5 63t62.5 151t-62.5 150.5t-150.5 62.5t-151 -62.5t-63 -150.5q0 -7 2 -23l-241 -120q-62 57 -145 57q-88 0 -150.5 -62.5t-62.5 -150.5t62.5 -150.5 t150.5 -62.5q83 0 145 57l241 -120q-2 -16 -2 -23q0 -88 63 -150.5t151 -62.5t150.5 62.5t62.5 150.5zM1536 1120v-960q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M571 947q-10 25 -34 35t-49 0q-108 -44 -191 -127t-127 -191q-10 -25 0 -49t35 -34q13 -5 24 -5q42 0 60 40q34 84 98.5 148.5t148.5 98.5q25 11 35 35t0 49zM1513 1303l46 -46l-244 -243l68 -68q19 -19 19 -45.5t-19 -45.5l-64 -64q89 -161 89 -343q0 -143 -55.5 -273.5 t-150 -225t-225 -150t-273.5 -55.5t-273.5 55.5t-225 150t-150 225t-55.5 273.5t55.5 273.5t150 225t225 150t273.5 55.5q182 0 343 -89l64 64q19 19 45.5 19t45.5 -19l68 -68zM1521 1359q-10 -10 -22 -10q-13 0 -23 10l-91 90q-9 10 -9 23t9 23q10 9 23 9t23 -9l90 -91 q10 -9 10 -22.5t-10 -22.5zM1751 1129q-11 -9 -23 -9t-23 9l-90 91q-10 9 -10 22.5t10 22.5q9 10 22.5 10t22.5 -10l91 -90q9 -10 9 -23t-9 -23zM1792 1312q0 -14 -9 -23t-23 -9h-96q-14 0 -23 9t-9 23t9 23t23 9h96q14 0 23 -9t9 -23zM1600 1504v-96q0 -14 -9 -23t-23 -9 t-23 9t-9 23v96q0 14 9 23t23 9t23 -9t9 -23zM1751 1449l-91 -90q-10 -10 -22 -10q-13 0 -23 10q-10 9 -10 22.5t10 22.5l90 91q10 9 23 9t23 -9q9 -10 9 -23t-9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M609 720l287 208l287 -208l-109 -336h-355zM896 1536q182 0 348 -71t286 -191t191 -286t71 -348t-71 -348t-191 -286t-286 -191t-348 -71t-348 71t-286 191t-191 286t-71 348t71 348t191 286t286 191t348 71zM1515 186q149 203 149 454v3l-102 -89l-240 224l63 323 l134 -12q-150 206 -389 282l53 -124l-287 -159l-287 159l53 124q-239 -76 -389 -282l135 12l62 -323l-240 -224l-102 89v-3q0 -251 149 -454l30 132l326 -40l139 -298l-116 -69q117 -39 240 -39t240 39l-116 69l139 298l326 40z" /> +<glyph unicode="" horiz-adv-x="1792" d="M448 224v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM256 608v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM832 224v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23 v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM640 608v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM66 768q-28 0 -47 19t-19 46v129h514v-129q0 -27 -19 -46t-46 -19h-383zM1216 224v-192q0 -14 -9 -23t-23 -9h-192 q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1024 608v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1600 224v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23 zM1408 608v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1792 1016v-13h-514v10q0 104 -382 102q-382 -1 -382 -102v-10h-514v13q0 17 8.5 43t34 64t65.5 75.5t110.5 76t160 67.5t224 47.5t293.5 18.5t293 -18.5t224 -47.5 t160.5 -67.5t110.5 -76t65.5 -75.5t34 -64t8.5 -43zM1792 608v-192q0 -14 -9 -23t-23 -9h-192q-14 0 -23 9t-9 23v192q0 14 9 23t23 9h192q14 0 23 -9t9 -23zM1792 962v-129q0 -27 -19 -46t-46 -19h-384q-27 0 -46 19t-19 46v129h514z" /> +<glyph unicode="" horiz-adv-x="1792" d="M704 1216v-768q0 -26 -19 -45t-45 -19v-576q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v512l249 873q7 23 31 23h424zM1024 1216v-704h-256v704h256zM1792 320v-512q0 -26 -19 -45t-45 -19h-512q-26 0 -45 19t-19 45v576q-26 0 -45 19t-19 45v768h424q24 0 31 -23z M736 1504v-224h-352v224q0 14 9 23t23 9h288q14 0 23 -9t9 -23zM1408 1504v-224h-352v224q0 14 9 23t23 9h288q14 0 23 -9t9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1755 1083q37 -37 37 -90t-37 -91l-401 -400l150 -150l-160 -160q-163 -163 -389.5 -186.5t-411.5 100.5l-362 -362h-181v181l362 362q-124 185 -100.5 411.5t186.5 389.5l160 160l150 -150l400 401q38 37 91 37t90 -37t37 -90.5t-37 -90.5l-400 -401l234 -234l401 400 q38 37 91 37t90 -37z" /> +<glyph unicode="" horiz-adv-x="1792" d="M873 796q0 -83 -63.5 -142.5t-152.5 -59.5t-152.5 59.5t-63.5 142.5q0 84 63.5 143t152.5 59t152.5 -59t63.5 -143zM1375 796q0 -83 -63 -142.5t-153 -59.5q-89 0 -152.5 59.5t-63.5 142.5q0 84 63.5 143t152.5 59q90 0 153 -59t63 -143zM1600 616v667q0 87 -32 123.5 t-111 36.5h-1112q-83 0 -112.5 -34t-29.5 -126v-673q43 -23 88.5 -40t81 -28t81 -18.5t71 -11t70 -4t58.5 -0.5t56.5 2t44.5 2q68 1 95 -27q6 -6 10 -9q26 -25 61 -51q7 91 118 87q5 0 36.5 -1.5t43 -2t45.5 -1t53 1t54.5 4.5t61 8.5t62 13.5t67 19.5t67.5 27t72 34.5z M1763 621q-121 -149 -372 -252q84 -285 -23 -465q-66 -113 -183 -148q-104 -32 -182 15q-86 51 -82 164l-1 326v1q-8 2 -24.5 6t-23.5 5l-1 -338q4 -114 -83 -164q-79 -47 -183 -15q-117 36 -182 150q-105 180 -22 463q-251 103 -372 252q-25 37 -4 63t60 -1q3 -2 11 -7 t11 -8v694q0 72 47 123t114 51h1257q67 0 114 -51t47 -123v-694l21 15q39 27 60 1t-4 -63z" /> +<glyph unicode="" horiz-adv-x="1792" d="M896 1102v-434h-145v434h145zM1294 1102v-434h-145v434h145zM1294 342l253 254v795h-1194v-1049h326v-217l217 217h398zM1692 1536v-1013l-434 -434h-326l-217 -217h-217v217h-398v1158l109 289h1483z" /> +<glyph unicode="" d="M773 217v-127q-1 -292 -6 -305q-12 -32 -51 -40q-54 -9 -181.5 38t-162.5 89q-13 15 -17 36q-1 12 4 26q4 10 34 47t181 216q1 0 60 70q15 19 39.5 24.5t49.5 -3.5q24 -10 37.5 -29t12.5 -42zM624 468q-3 -55 -52 -70l-120 -39q-275 -88 -292 -88q-35 2 -54 36 q-12 25 -17 75q-8 76 1 166.5t30 124.5t56 32q13 0 202 -77q70 -29 115 -47l84 -34q23 -9 35.5 -30.5t11.5 -48.5zM1450 171q-7 -54 -91.5 -161t-135.5 -127q-37 -14 -63 7q-14 10 -184 287l-47 77q-14 21 -11.5 46t19.5 46q35 43 83 26q1 -1 119 -40q203 -66 242 -79.5 t47 -20.5q28 -22 22 -61zM778 803q5 -102 -54 -122q-58 -17 -114 71l-378 598q-8 35 19 62q41 43 207.5 89.5t224.5 31.5q40 -10 49 -45q3 -18 22 -305.5t24 -379.5zM1440 695q3 -39 -26 -59q-15 -10 -329 -86q-67 -15 -91 -23l1 2q-23 -6 -46 4t-37 32q-30 47 0 87 q1 1 75 102q125 171 150 204t34 39q28 19 65 2q48 -23 123 -133.5t81 -167.5v-3z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1024 1024h-384v-384h384v384zM1152 384v-128h-640v128h640zM1152 1152v-640h-640v640h640zM1792 384v-128h-512v128h512zM1792 640v-128h-512v128h512zM1792 896v-128h-512v128h512zM1792 1152v-128h-512v128h512zM256 192v960h-128v-960q0 -26 19 -45t45 -19t45 19 t19 45zM1920 192v1088h-1536v-1088q0 -33 -11 -64h1483q26 0 45 19t19 45zM2048 1408v-1216q0 -80 -56 -136t-136 -56h-1664q-80 0 -136 56t-56 136v1088h256v128h1792z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1024 13q-20 0 -93 73.5t-73 93.5q0 32 62.5 54t103.5 22t103.5 -22t62.5 -54q0 -20 -73 -93.5t-93 -73.5zM1294 284q-2 0 -40 25t-101.5 50t-128.5 25t-128.5 -25t-101 -50t-40.5 -25q-18 0 -93.5 75t-75.5 93q0 13 10 23q78 77 196 121t233 44t233 -44t196 -121 q10 -10 10 -23q0 -18 -75.5 -93t-93.5 -75zM1567 556q-11 0 -23 8q-136 105 -252 154.5t-268 49.5q-85 0 -170.5 -22t-149 -53t-113.5 -62t-79 -53t-31 -22q-17 0 -92 75t-75 93q0 12 10 22q132 132 320 205t380 73t380 -73t320 -205q10 -10 10 -22q0 -18 -75 -93t-92 -75z M1838 827q-11 0 -22 9q-179 157 -371.5 236.5t-420.5 79.5t-420.5 -79.5t-371.5 -236.5q-11 -9 -22 -9q-17 0 -92.5 75t-75.5 93q0 13 10 23q187 186 445 288t527 102t527 -102t445 -288q10 -10 10 -23q0 -18 -75.5 -93t-92.5 -75z" /> +<glyph unicode="" horiz-adv-x="1792" d="M384 0q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM768 0q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM384 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5 t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1152 0q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM768 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5 t37.5 90.5zM384 768q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1152 384q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM768 768q0 53 -37.5 90.5t-90.5 37.5 t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1536 0v384q0 52 -38 90t-90 38t-90 -38t-38 -90v-384q0 -52 38 -90t90 -38t90 38t38 90zM1152 768q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5z M1536 1088v256q0 26 -19 45t-45 19h-1280q-26 0 -45 -19t-19 -45v-256q0 -26 19 -45t45 -19h1280q26 0 45 19t19 45zM1536 768q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1664 1408v-1536q0 -52 -38 -90t-90 -38 h-1408q-52 0 -90 38t-38 90v1536q0 52 38 90t90 38h1408q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1112 1090q0 159 -237 159h-70q-32 0 -59.5 -21.5t-34.5 -52.5l-63 -276q-2 -5 -2 -16q0 -24 17 -39.5t41 -15.5h53q69 0 128.5 13t112.5 41t83.5 81.5t30.5 126.5zM1716 938q0 -265 -220 -428q-219 -161 -612 -161h-61q-32 0 -59 -21.5t-34 -52.5l-73 -316 q-8 -36 -40.5 -61.5t-69.5 -25.5h-213q-31 0 -53 20t-22 51q0 10 13 65h151q34 0 64 23.5t38 56.5l73 316q8 33 37.5 57t63.5 24h61q390 0 607 160t217 421q0 129 -51 207q183 -92 183 -335zM1533 1123q0 -264 -221 -428q-218 -161 -612 -161h-60q-32 0 -59.5 -22t-34.5 -53 l-73 -315q-8 -36 -40 -61.5t-69 -25.5h-214q-31 0 -52.5 19.5t-21.5 51.5q0 8 2 20l300 1301q8 36 40.5 61.5t69.5 25.5h444q68 0 125 -4t120.5 -15t113.5 -30t96.5 -50.5t77.5 -74t49.5 -103.5t18.5 -136z" /> +<glyph unicode="" horiz-adv-x="1792" d="M602 949q19 -61 31 -123.5t17 -141.5t-14 -159t-62 -145q-21 81 -67 157t-95.5 127t-99 90.5t-78.5 57.5t-33 19q-62 34 -81.5 100t14.5 128t101 81.5t129 -14.5q138 -83 238 -177zM927 1236q11 -25 20.5 -46t36.5 -100.5t42.5 -150.5t25.5 -179.5t0 -205.5t-47.5 -209.5 t-105.5 -208.5q-51 -72 -138 -72q-54 0 -98 31q-57 40 -69 109t28 127q60 85 81 195t13 199.5t-32 180.5t-39 128t-22 52q-31 63 -8.5 129.5t85.5 97.5q34 17 75 17q47 0 88.5 -25t63.5 -69zM1248 567q-17 -160 -72 -311q-17 131 -63 246q25 174 -5 361q-27 178 -94 342 q114 -90 212 -211q9 -37 15 -80q26 -179 7 -347zM1520 1440q9 -17 23.5 -49.5t43.5 -117.5t50.5 -178t34 -227.5t5 -269t-47 -300t-112.5 -323.5q-22 -48 -66 -75.5t-95 -27.5q-39 0 -74 16q-67 31 -92.5 100t4.5 136q58 126 90 257.5t37.5 239.5t-3.5 213.5t-26.5 180.5 t-38.5 138.5t-32.5 90t-15.5 32.5q-34 65 -11.5 135.5t87.5 104.5q37 20 81 20q49 0 91.5 -25.5t66.5 -70.5z" /> +<glyph unicode="" horiz-adv-x="2304" d="M1975 546h-138q14 37 66 179l3 9q4 10 10 26t9 26l12 -55zM531 611l-58 295q-11 54 -75 54h-268l-2 -13q311 -79 403 -336zM710 960l-162 -438l-17 89q-26 70 -85 129.5t-131 88.5l135 -510h175l261 641h-176zM849 318h166l104 642h-166zM1617 944q-69 27 -149 27 q-123 0 -201 -59t-79 -153q-1 -102 145 -174q48 -23 67 -41t19 -39q0 -30 -30 -46t-69 -16q-86 0 -156 33l-22 11l-23 -144q74 -34 185 -34q130 -1 208.5 59t80.5 160q0 106 -140 174q-49 25 -71 42t-22 38q0 22 24.5 38.5t70.5 16.5q70 1 124 -24l15 -8zM2042 960h-128 q-65 0 -87 -54l-246 -588h174l35 96h212q5 -22 20 -96h154zM2304 1280v-1280q0 -52 -38 -90t-90 -38h-2048q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h2048q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="2304" d="M671 603h-13q-47 0 -47 -32q0 -22 20 -22q17 0 28 15t12 39zM1066 639h62v3q1 4 0.5 6.5t-1 7t-2 8t-4.5 6.5t-7.5 5t-11.5 2q-28 0 -36 -38zM1606 603h-12q-48 0 -48 -32q0 -22 20 -22q17 0 28 15t12 39zM1925 629q0 41 -30 41q-19 0 -31 -20t-12 -51q0 -42 28 -42 q20 0 32.5 20t12.5 52zM480 770h87l-44 -262h-56l32 201l-71 -201h-39l-4 200l-34 -200h-53l44 262h81l2 -163zM733 663q0 -6 -4 -42q-16 -101 -17 -113h-47l1 22q-20 -26 -58 -26q-23 0 -37.5 16t-14.5 42q0 39 26 60.5t73 21.5q14 0 23 -1q0 3 0.5 5.5t1 4.5t0.5 3 q0 20 -36 20q-29 0 -59 -10q0 4 7 48q38 11 67 11q74 0 74 -62zM889 721l-8 -49q-22 3 -41 3q-27 0 -27 -17q0 -8 4.5 -12t21.5 -11q40 -19 40 -60q0 -72 -87 -71q-34 0 -58 6q0 2 7 49q29 -8 51 -8q32 0 32 19q0 7 -4.5 11.5t-21.5 12.5q-43 20 -43 59q0 72 84 72 q30 0 50 -4zM977 721h28l-7 -52h-29q-2 -17 -6.5 -40.5t-7 -38.5t-2.5 -18q0 -16 19 -16q8 0 16 2l-8 -47q-21 -7 -40 -7q-43 0 -45 47q0 12 8 56q3 20 25 146h55zM1180 648q0 -23 -7 -52h-111q-3 -22 10 -33t38 -11q30 0 58 14l-9 -54q-30 -8 -57 -8q-95 0 -95 95 q0 55 27.5 90.5t69.5 35.5q35 0 55.5 -21t20.5 -56zM1319 722q-13 -23 -22 -62q-22 2 -31 -24t-25 -128h-56l3 14q22 130 29 199h51l-3 -33q14 21 25.5 29.5t28.5 4.5zM1506 763l-9 -57q-28 14 -50 14q-31 0 -51 -27.5t-20 -70.5q0 -30 13.5 -47t38.5 -17q21 0 48 13 l-10 -59q-28 -8 -50 -8q-45 0 -71.5 30.5t-26.5 82.5q0 70 35.5 114.5t91.5 44.5q26 0 61 -13zM1668 663q0 -18 -4 -42q-13 -79 -17 -113h-46l1 22q-20 -26 -59 -26q-23 0 -37 16t-14 42q0 39 25.5 60.5t72.5 21.5q15 0 23 -1q2 7 2 13q0 20 -36 20q-29 0 -59 -10q0 4 8 48 q38 11 67 11q73 0 73 -62zM1809 722q-14 -24 -21 -62q-23 2 -31.5 -23t-25.5 -129h-56l3 14q19 104 29 199h52q0 -11 -4 -33q15 21 26.5 29.5t27.5 4.5zM1950 770h56l-43 -262h-53l3 19q-23 -23 -52 -23q-31 0 -49.5 24t-18.5 64q0 53 27.5 92t64.5 39q31 0 53 -29z M2061 640q0 148 -72.5 273t-198 198t-273.5 73q-181 0 -328 -110q127 -116 171 -284h-50q-44 150 -158 253q-114 -103 -158 -253h-50q44 168 171 284q-147 110 -328 110q-148 0 -273.5 -73t-198 -198t-72.5 -273t72.5 -273t198 -198t273.5 -73q181 0 328 110 q-120 111 -165 264h50q46 -138 152 -233q106 95 152 233h50q-45 -153 -165 -264q147 -110 328 -110q148 0 273.5 73t198 198t72.5 273zM2304 1280v-1280q0 -52 -38 -90t-90 -38h-2048q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h2048q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="2304" d="M313 759q0 -51 -36 -84q-29 -26 -89 -26h-17v220h17q61 0 89 -27q36 -31 36 -83zM2089 824q0 -52 -64 -52h-19v101h20q63 0 63 -49zM380 759q0 74 -50 120.5t-129 46.5h-95v-333h95q74 0 119 38q60 51 60 128zM410 593h65v333h-65v-333zM730 694q0 40 -20.5 62t-75.5 42 q-29 10 -39.5 19t-10.5 23q0 16 13.5 26.5t34.5 10.5q29 0 53 -27l34 44q-41 37 -98 37q-44 0 -74 -27.5t-30 -67.5q0 -35 18 -55.5t64 -36.5q37 -13 45 -19q19 -12 19 -34q0 -20 -14 -33.5t-36 -13.5q-48 0 -71 44l-42 -40q44 -64 115 -64q51 0 83 30.5t32 79.5zM1008 604 v77q-37 -37 -78 -37q-49 0 -80.5 32.5t-31.5 82.5q0 48 31.5 81.5t77.5 33.5q43 0 81 -38v77q-40 20 -80 20q-74 0 -125.5 -50.5t-51.5 -123.5t51 -123.5t125 -50.5q42 0 81 19zM2240 0v527q-65 -40 -144.5 -84t-237.5 -117t-329.5 -137.5t-417.5 -134.5t-504 -118h1569 q26 0 45 19t19 45zM1389 757q0 75 -53 128t-128 53t-128 -53t-53 -128t53 -128t128 -53t128 53t53 128zM1541 584l144 342h-71l-90 -224l-89 224h-71l142 -342h35zM1714 593h184v56h-119v90h115v56h-115v74h119v57h-184v-333zM2105 593h80l-105 140q76 16 76 94q0 47 -31 73 t-87 26h-97v-333h65v133h9zM2304 1274v-1268q0 -56 -38.5 -95t-93.5 -39h-2040q-55 0 -93.5 39t-38.5 95v1268q0 56 38.5 95t93.5 39h2040q55 0 93.5 -39t38.5 -95z" /> +<glyph unicode="" horiz-adv-x="2304" d="M119 854h89l-45 108zM740 328l74 79l-70 79h-163v-49h142v-55h-142v-54h159zM898 406l99 -110v217zM1186 453q0 33 -40 33h-84v-69h83q41 0 41 36zM1475 457q0 29 -42 29h-82v-61h81q43 0 43 32zM1197 923q0 29 -42 29h-82v-60h81q43 0 43 31zM1656 854h89l-44 108z M699 1009v-271h-66v212l-94 -212h-57l-94 212v-212h-132l-25 60h-135l-25 -60h-70l116 271h96l110 -257v257h106l85 -184l77 184h108zM1255 453q0 -20 -5.5 -35t-14 -25t-22.5 -16.5t-26 -10t-31.5 -4.5t-31.5 -1t-32.5 0.5t-29.5 0.5v-91h-126l-80 90l-83 -90h-256v271h260 l80 -89l82 89h207q109 0 109 -89zM964 794v-56h-217v271h217v-57h-152v-49h148v-55h-148v-54h152zM2304 235v-229q0 -55 -38.5 -94.5t-93.5 -39.5h-2040q-55 0 -93.5 39.5t-38.5 94.5v678h111l25 61h55l25 -61h218v46l19 -46h113l20 47v-47h541v99l10 1q10 0 10 -14v-86h279 v23q23 -12 55 -18t52.5 -6.5t63 0.5t51.5 1l25 61h56l25 -61h227v58l34 -58h182v378h-180v-44l-25 44h-185v-44l-23 44h-249q-69 0 -109 -22v22h-172v-22q-24 22 -73 22h-628l-43 -97l-43 97h-198v-44l-22 44h-169l-78 -179v391q0 55 38.5 94.5t93.5 39.5h2040 q55 0 93.5 -39.5t38.5 -94.5v-678h-120q-51 0 -81 -22v22h-177q-55 0 -78 -22v22h-316v-22q-31 22 -87 22h-209v-22q-23 22 -91 22h-234l-54 -58l-50 58h-349v-378h343l55 59l52 -59h211v89h21q59 0 90 13v-102h174v99h8q8 0 10 -2t2 -10v-87h529q57 0 88 24v-24h168 q60 0 95 17zM1546 469q0 -23 -12 -43t-34 -29q25 -9 34 -26t9 -46v-54h-65v45q0 33 -12 43.5t-46 10.5h-69v-99h-65v271h154q48 0 77 -15t29 -58zM1269 936q0 -24 -12.5 -44t-33.5 -29q26 -9 34.5 -25.5t8.5 -46.5v-53h-65q0 9 0.5 26.5t0 25t-3 18.5t-8.5 16t-17.5 8.5 t-29.5 3.5h-70v-98h-64v271l153 -1q49 0 78 -14.5t29 -57.5zM1798 327v-56h-216v271h216v-56h-151v-49h148v-55h-148v-54zM1372 1009v-271h-66v271h66zM2065 357q0 -86 -102 -86h-126v58h126q34 0 34 25q0 16 -17 21t-41.5 5t-49.5 3.5t-42 22.5t-17 55q0 39 26 60t66 21 h130v-57h-119q-36 0 -36 -25q0 -16 17.5 -20.5t42 -4t49 -2.5t42 -21.5t17.5 -54.5zM2304 407v-101q-24 -35 -88 -35h-125v58h125q33 0 33 25q0 13 -12.5 19t-31 5.5t-40 2t-40 8t-31 24t-12.5 48.5q0 39 26.5 60t66.5 21h129v-57h-118q-36 0 -36 -25q0 -20 29 -22t68.5 -5 t56.5 -26zM2139 1008v-270h-92l-122 203v-203h-132l-26 60h-134l-25 -60h-75q-129 0 -129 133q0 138 133 138h63v-59q-7 0 -28 1t-28.5 0.5t-23 -2t-21.5 -6.5t-14.5 -13.5t-11.5 -23t-3 -33.5q0 -38 13.5 -58t49.5 -20h29l92 213h97l109 -256v256h99l114 -188v188h66z" /> +<glyph unicode="" horiz-adv-x="2304" d="M322 689h-15q-19 0 -19 18q0 28 19 85q5 15 15 19.5t28 4.5q77 0 77 -49q0 -41 -30.5 -59.5t-74.5 -18.5zM664 528q-47 0 -47 29q0 62 123 62l3 -3q-5 -88 -79 -88zM1438 687h-15q-19 0 -19 19q0 28 19 85q5 15 14.5 19t28.5 4q77 0 77 -49q0 -41 -30.5 -59.5 t-74.5 -18.5zM1780 527q-47 0 -47 30q0 62 123 62l3 -3q-5 -89 -79 -89zM373 894h-128q-8 0 -14.5 -4t-8.5 -7.5t-7 -12.5q-3 -7 -45 -190t-42 -192q0 -7 5.5 -12.5t13.5 -5.5h62q25 0 32.5 34.5l15 69t32.5 34.5q47 0 87.5 7.5t80.5 24.5t63.5 52.5t23.5 84.5 q0 36 -14.5 61t-41 36.5t-53.5 15.5t-62 4zM719 798q-38 0 -74 -6q-2 0 -8.5 -1t-9 -1.5l-7.5 -1.5t-7.5 -2t-6.5 -3t-6.5 -4t-5 -5t-4.5 -7t-4 -9q-9 -29 -9 -39t9 -10q5 0 21.5 5t19.5 6q30 8 58 8q74 0 74 -36q0 -11 -10 -14q-8 -2 -18 -3t-21.5 -1.5t-17.5 -1.5 q-38 -4 -64.5 -10t-56.5 -19.5t-45.5 -39t-15.5 -62.5q0 -38 26 -59.5t64 -21.5q24 0 45.5 6.5t33 13t38.5 23.5q-3 -7 -3 -15t5.5 -13.5t12.5 -5.5h56q1 1 7 3.5t7.5 3.5t5 3.5t5 5.5t2.5 8l45 194q4 13 4 30q0 81 -145 81zM1247 793h-74q-22 0 -39 -23q-5 -7 -29.5 -51 t-46.5 -81.5t-26 -38.5l-5 4q0 77 -27 166q-1 5 -3.5 8.5t-6 6.5t-6.5 5t-8.5 3t-8.5 1.5t-9.5 1t-9 0.5h-10h-8.5q-38 0 -38 -21l1 -5q5 -53 25 -151t25 -143q2 -16 2 -24q0 -19 -30.5 -61.5t-30.5 -58.5q0 -13 40 -13q61 0 76 25l245 415q10 20 10 26q0 9 -8 9zM1489 892 h-129q-18 0 -29 -23q-6 -13 -46.5 -191.5t-40.5 -190.5q0 -20 43 -20h7.5h9h9t9.5 1t8.5 2t8.5 3t6.5 4.5t5.5 6t3 8.5l21 91q2 10 10.5 17t19.5 7q47 0 87.5 7t80.5 24.5t63.5 52.5t23.5 84q0 36 -14.5 61t-41 36.5t-53.5 15.5t-62 4zM1835 798q-26 0 -74 -6 q-38 -6 -48 -16q-7 -8 -11 -19q-8 -24 -8 -39q0 -10 8 -10q1 0 41 12q30 8 58 8q74 0 74 -36q0 -12 -10 -14q-4 -1 -57 -7q-38 -4 -64.5 -10t-56.5 -19.5t-45.5 -39t-15.5 -62.5t26 -58.5t64 -21.5q24 0 45 6t34 13t38 24q-3 -15 -3 -16q0 -5 2 -8.5t6.5 -5.5t8 -3.5 t10.5 -2t9.5 -0.5h9.5h8q42 0 48 25l45 194q3 15 3 31q0 81 -145 81zM2157 889h-55q-25 0 -33 -40q-10 -44 -36.5 -167t-42.5 -190v-5q0 -16 16 -18h1h57q10 0 18.5 6.5t10.5 16.5l83 374h-1l1 5q0 7 -5.5 12.5t-13.5 5.5zM2304 1280v-1280q0 -52 -38 -90t-90 -38h-2048 q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h2048q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="2304" d="M1597 633q0 -69 -21 -106q-19 -35 -52 -35q-23 0 -41 9v224q29 30 57 30q57 0 57 -122zM2035 669h-110q6 98 56 98q51 0 54 -98zM476 534q0 59 -33 91.5t-101 57.5q-36 13 -52 24t-16 25q0 26 38 26q58 0 124 -33l18 112q-67 32 -149 32q-77 0 -123 -38q-48 -39 -48 -109 q0 -58 32.5 -90.5t99.5 -56.5q39 -14 54.5 -25.5t15.5 -27.5q0 -31 -48 -31q-29 0 -70 12.5t-72 30.5l-18 -113q72 -41 168 -41q81 0 129 37q51 41 51 117zM771 749l19 111h-96v135l-129 -21l-18 -114l-46 -8l-17 -103h62v-219q0 -84 44 -120q38 -30 111 -30q32 0 79 11v118 q-32 -7 -44 -7q-42 0 -42 50v197h77zM1087 724v139q-15 3 -28 3q-32 0 -55.5 -16t-33.5 -46l-10 56h-131v-471h150v306q26 31 82 31q16 0 26 -2zM1124 389h150v471h-150v-471zM1746 638q0 122 -45 179q-40 52 -111 52q-64 0 -117 -56l-8 47h-132v-645l150 25v151 q36 -11 68 -11q83 0 134 56q61 65 61 202zM1278 986q0 33 -23 56t-56 23t-56 -23t-23 -56t23 -56.5t56 -23.5t56 23.5t23 56.5zM2176 629q0 113 -48 176q-50 64 -144 64q-96 0 -151.5 -66t-55.5 -180q0 -128 63 -188q55 -55 161 -55q101 0 160 40l-16 103q-57 -31 -128 -31 q-43 0 -63 19q-23 19 -28 66h248q2 14 2 52zM2304 1280v-1280q0 -52 -38 -90t-90 -38h-2048q-52 0 -90 38t-38 90v1280q0 52 38 90t90 38h2048q52 0 90 -38t38 -90z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1558 684q61 -356 298 -556q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-180.5 74.5t-75.5 180.5zM1024 -176q16 0 16 16t-16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5zM2026 1424q8 -10 7.5 -23.5t-10.5 -22.5 l-1872 -1622q-10 -8 -23.5 -7t-21.5 11l-84 96q-8 10 -7.5 23.5t10.5 21.5l186 161q-19 32 -19 66q50 42 91 88t85 119.5t74.5 158.5t50 206t19.5 260q0 152 117 282.5t307 158.5q-8 19 -8 39q0 40 28 68t68 28t68 -28t28 -68q0 -20 -8 -39q124 -18 219 -82.5t148 -157.5 l418 363q10 8 23.5 7t21.5 -11z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1040 -160q0 16 -16 16q-59 0 -101.5 42.5t-42.5 101.5q0 16 -16 16t-16 -16q0 -73 51.5 -124.5t124.5 -51.5q16 0 16 16zM503 315l877 760q-42 88 -132.5 146.5t-223.5 58.5q-93 0 -169.5 -31.5t-121.5 -80.5t-69 -103t-24 -105q0 -384 -137 -645zM1856 128 q0 -52 -38 -90t-90 -38h-448q0 -106 -75 -181t-181 -75t-180.5 74.5t-75.5 180.5l149 129h757q-166 187 -227 459l111 97q61 -356 298 -556zM1942 1520l84 -96q8 -10 7.5 -23.5t-10.5 -22.5l-1872 -1622q-10 -8 -23.5 -7t-21.5 11l-84 96q-8 10 -7.5 23.5t10.5 21.5l186 161 q-19 32 -19 66q50 42 91 88t85 119.5t74.5 158.5t50 206t19.5 260q0 152 117 282.5t307 158.5q-8 19 -8 39q0 40 28 68t68 28t68 -28t28 -68q0 -20 -8 -39q124 -18 219 -82.5t148 -157.5l418 363q10 8 23.5 7t21.5 -11z" /> +<glyph unicode="" horiz-adv-x="1408" d="M512 160v704q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-704q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM768 160v704q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-704q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM1024 160v704q0 14 -9 23t-23 9h-64q-14 0 -23 -9t-9 -23v-704 q0 -14 9 -23t23 -9h64q14 0 23 9t9 23zM480 1152h448l-48 117q-7 9 -17 11h-317q-10 -2 -17 -11zM1408 1120v-64q0 -14 -9 -23t-23 -9h-96v-948q0 -83 -47 -143.5t-113 -60.5h-832q-66 0 -113 58.5t-47 141.5v952h-96q-14 0 -23 9t-9 23v64q0 14 9 23t23 9h309l70 167 q15 37 54 63t79 26h320q40 0 79 -26t54 -63l70 -167h309q14 0 23 -9t9 -23z" /> +<glyph unicode="" d="M1150 462v-109q0 -50 -36.5 -89t-94 -60.5t-118 -32.5t-117.5 -11q-205 0 -342.5 139t-137.5 346q0 203 136 339t339 136q34 0 75.5 -4.5t93 -18t92.5 -34t69 -56.5t28 -81v-109q0 -16 -16 -16h-118q-16 0 -16 16v70q0 43 -65.5 67.5t-137.5 24.5q-140 0 -228.5 -91.5 t-88.5 -237.5q0 -151 91.5 -249.5t233.5 -98.5q68 0 138 24t70 66v70q0 7 4.5 11.5t10.5 4.5h119q6 0 11 -4.5t5 -11.5zM768 1280q-130 0 -248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51t248.5 51t204 136.5t136.5 204t51 248.5 t-51 248.5t-136.5 204t-204 136.5t-248.5 51zM1536 640q0 -209 -103 -385.5t-279.5 -279.5t-385.5 -103t-385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103t385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" d="M972 761q0 108 -53.5 169t-147.5 61q-63 0 -124 -30.5t-110 -84.5t-79.5 -137t-30.5 -180q0 -112 53.5 -173t150.5 -61q96 0 176 66.5t122.5 166t42.5 203.5zM1536 640q0 -111 -37 -197t-98.5 -135t-131.5 -74.5t-145 -27.5q-6 0 -15.5 -0.5t-16.5 -0.5q-95 0 -142 53 q-28 33 -33 83q-52 -66 -131.5 -110t-173.5 -44q-161 0 -249.5 95.5t-88.5 269.5q0 157 66 290t179 210.5t246 77.5q87 0 155 -35.5t106 -99.5l2 19l11 56q1 6 5.5 12t9.5 6h118q5 0 13 -11q5 -5 3 -16l-120 -614q-5 -24 -5 -48q0 -39 12.5 -52t44.5 -13q28 1 57 5.5t73 24 t77 50t57 89.5t24 137q0 292 -174 466t-466 174q-130 0 -248.5 -51t-204 -136.5t-136.5 -204t-51 -248.5t51 -248.5t136.5 -204t204 -136.5t248.5 -51q228 0 405 144q11 9 24 8t21 -12l41 -49q8 -12 7 -24q-2 -13 -12 -22q-102 -83 -227.5 -128t-258.5 -45q-156 0 -298 61 t-245 164t-164 245t-61 298t61 298t164 245t245 164t298 61q344 0 556 -212t212 -556z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1698 1442q94 -94 94 -226.5t-94 -225.5l-225 -223l104 -104q10 -10 10 -23t-10 -23l-210 -210q-10 -10 -23 -10t-23 10l-105 105l-603 -603q-37 -37 -90 -37h-203l-256 -128l-64 64l128 256v203q0 53 37 90l603 603l-105 105q-10 10 -10 23t10 23l210 210q10 10 23 10 t23 -10l104 -104l223 225q93 94 225.5 94t226.5 -94zM512 64l576 576l-192 192l-576 -576v-192h192z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1615 1536q70 0 122.5 -46.5t52.5 -116.5q0 -63 -45 -151q-332 -629 -465 -752q-97 -91 -218 -91q-126 0 -216.5 92.5t-90.5 219.5q0 128 92 212l638 579q59 54 130 54zM706 502q39 -76 106.5 -130t150.5 -76l1 -71q4 -213 -129.5 -347t-348.5 -134q-123 0 -218 46.5 t-152.5 127.5t-86.5 183t-29 220q7 -5 41 -30t62 -44.5t59 -36.5t46 -17q41 0 55 37q25 66 57.5 112.5t69.5 76t88 47.5t103 25.5t125 10.5z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1792 128v-384h-1792v384q45 0 85 14t59 27.5t47 37.5q30 27 51.5 38t56.5 11t55.5 -11t52.5 -38q29 -25 47 -38t58 -27t86 -14q45 0 85 14.5t58 27t48 37.5q21 19 32.5 27t31 15t43.5 7q35 0 56.5 -11t51.5 -38q28 -24 47 -37.5t59 -27.5t85 -14t85 14t59 27.5t47 37.5 q30 27 51.5 38t56.5 11q34 0 55.5 -11t51.5 -38q28 -24 47 -37.5t59 -27.5t85 -14zM1792 448v-192q-35 0 -55.5 11t-52.5 38q-29 25 -47 38t-58 27t-85 14q-46 0 -86 -14t-58 -27t-47 -38q-22 -19 -33 -27t-31 -15t-44 -7q-35 0 -56.5 11t-51.5 38q-29 25 -47 38t-58 27 t-86 14q-45 0 -85 -14.5t-58 -27t-48 -37.5q-21 -19 -32.5 -27t-31 -15t-43.5 -7q-35 0 -56.5 11t-51.5 38q-28 24 -47 37.5t-59 27.5t-85 14q-46 0 -86 -14t-58 -27t-47 -38q-30 -27 -51.5 -38t-56.5 -11v192q0 80 56 136t136 56h64v448h256v-448h256v448h256v-448h256v448 h256v-448h64q80 0 136 -56t56 -136zM512 1312q0 -77 -36 -118.5t-92 -41.5q-53 0 -90.5 37.5t-37.5 90.5q0 29 9.5 51t23.5 34t31 28t31 31.5t23.5 44.5t9.5 67q38 0 83 -74t45 -150zM1024 1312q0 -77 -36 -118.5t-92 -41.5q-53 0 -90.5 37.5t-37.5 90.5q0 29 9.5 51 t23.5 34t31 28t31 31.5t23.5 44.5t9.5 67q38 0 83 -74t45 -150zM1536 1312q0 -77 -36 -118.5t-92 -41.5q-53 0 -90.5 37.5t-37.5 90.5q0 29 9.5 51t23.5 34t31 28t31 31.5t23.5 44.5t9.5 67q38 0 83 -74t45 -150z" /> +<glyph unicode="" horiz-adv-x="2048" d="M2048 0v-128h-2048v1536h128v-1408h1920zM1664 1024l256 -896h-1664v576l448 576l576 -576z" /> +<glyph unicode="" horiz-adv-x="1792" d="M768 646l546 -546q-106 -108 -247.5 -168t-298.5 -60q-209 0 -385.5 103t-279.5 279.5t-103 385.5t103 385.5t279.5 279.5t385.5 103v-762zM955 640h773q0 -157 -60 -298.5t-168 -247.5zM1664 768h-768v768q209 0 385.5 -103t279.5 -279.5t103 -385.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M2048 0v-128h-2048v1536h128v-1408h1920zM1920 1248v-435q0 -21 -19.5 -29.5t-35.5 7.5l-121 121l-633 -633q-10 -10 -23 -10t-23 10l-233 233l-416 -416l-192 192l585 585q10 10 23 10t23 -10l233 -233l464 464l-121 121q-16 16 -7.5 35.5t29.5 19.5h435q14 0 23 -9 t9 -23z" /> +<glyph unicode="" horiz-adv-x="1792" d="M1292 832q0 -6 10 -41q10 -29 25 -49.5t41 -34t44 -20t55 -16.5q325 -91 325 -332q0 -146 -105.5 -242.5t-254.5 -96.5q-59 0 -111.5 18.5t-91.5 45.5t-77 74.5t-63 87.5t-53.5 103.5t-43.5 103t-39.5 106.5t-35.5 95q-32 81 -61.5 133.5t-73.5 96.5t-104 64t-142 20 q-96 0 -183 -55.5t-138 -144.5t-51 -185q0 -160 106.5 -279.5t263.5 -119.5q177 0 258 95q56 63 83 116l84 -152q-15 -34 -44 -70l1 -1q-131 -152 -388 -152q-147 0 -269.5 79t-190.5 207.5t-68 274.5q0 105 43.5 206t116 176.5t172 121.5t204.5 46q87 0 159 -19t123.5 -50 t95 -80t72.5 -99t58.5 -117t50.5 -124.5t50 -130.5t55 -127q96 -200 233 -200q81 0 138.5 48.5t57.5 128.5q0 42 -19 72t-50.5 46t-72.5 31.5t-84.5 27t-87.5 34t-81 52t-65 82t-39 122.5q-3 16 -3 33q0 110 87.5 192t198.5 78q78 -3 120.5 -14.5t90.5 -53.5h-1 q12 -11 23 -24.5t26 -36t19 -27.5l-129 -99q-26 49 -54 70v1q-23 21 -97 21q-49 0 -84 -33t-35 -83z" /> +<glyph unicode="" d="M1432 484q0 173 -234 239q-35 10 -53 16.5t-38 25t-29 46.5q0 2 -2 8.5t-3 12t-1 7.5q0 36 24.5 59.5t60.5 23.5q54 0 71 -15h-1q20 -15 39 -51l93 71q-39 54 -49 64q-33 29 -67.5 39t-85.5 10q-80 0 -142 -57.5t-62 -137.5q0 -7 2 -23q16 -96 64.5 -140t148.5 -73 q29 -8 49 -15.5t45 -21.5t38.5 -34.5t13.5 -46.5v-5q1 -58 -40.5 -93t-100.5 -35q-97 0 -167 144q-23 47 -51.5 121.5t-48 125.5t-54 110.5t-74 95.5t-103.5 60.5t-147 24.5q-101 0 -192 -56t-144 -148t-50 -192v-1q4 -108 50.5 -199t133.5 -147.5t196 -56.5q186 0 279 110 q20 27 31 51l-60 109q-42 -80 -99 -116t-146 -36q-115 0 -191 87t-76 204q0 105 82 189t186 84q112 0 170 -53.5t104 -172.5q8 -21 25.5 -68.5t28.5 -76.5t31.5 -74.5t38.5 -74t45.5 -62.5t55.5 -53.5t66 -33t80 -13.5q107 0 183 69.5t76 174.5zM1536 1120v-960 q0 -119 -84.5 -203.5t-203.5 -84.5h-960q-119 0 -203.5 84.5t-84.5 203.5v960q0 119 84.5 203.5t203.5 84.5h960q119 0 203.5 -84.5t84.5 -203.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1152 640q0 104 -40.5 198.5t-109.5 163.5t-163.5 109.5t-198.5 40.5t-198.5 -40.5t-163.5 -109.5t-109.5 -163.5t-40.5 -198.5t40.5 -198.5t109.5 -163.5t163.5 -109.5t198.5 -40.5t198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5zM1920 640q0 104 -40.5 198.5 t-109.5 163.5t-163.5 109.5t-198.5 40.5h-386q119 -90 188.5 -224t69.5 -288t-69.5 -288t-188.5 -224h386q104 0 198.5 40.5t163.5 109.5t109.5 163.5t40.5 198.5zM2048 640q0 -130 -51 -248.5t-136.5 -204t-204 -136.5t-248.5 -51h-768q-130 0 -248.5 51t-204 136.5 t-136.5 204t-51 248.5t51 248.5t136.5 204t204 136.5t248.5 51h768q130 0 248.5 -51t204 -136.5t136.5 -204t51 -248.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M0 640q0 130 51 248.5t136.5 204t204 136.5t248.5 51h768q130 0 248.5 -51t204 -136.5t136.5 -204t51 -248.5t-51 -248.5t-136.5 -204t-204 -136.5t-248.5 -51h-768q-130 0 -248.5 51t-204 136.5t-136.5 204t-51 248.5zM1408 128q104 0 198.5 40.5t163.5 109.5 t109.5 163.5t40.5 198.5t-40.5 198.5t-109.5 163.5t-163.5 109.5t-198.5 40.5t-198.5 -40.5t-163.5 -109.5t-109.5 -163.5t-40.5 -198.5t40.5 -198.5t109.5 -163.5t163.5 -109.5t198.5 -40.5z" /> +<glyph unicode="" horiz-adv-x="2304" d="M762 384h-314q-40 0 -57.5 35t6.5 67l188 251q-65 31 -137 31q-132 0 -226 -94t-94 -226t94 -226t226 -94q115 0 203 72.5t111 183.5zM576 512h186q-18 85 -75 148zM1056 512l288 384h-480l-99 -132q105 -103 126 -252h165zM2176 448q0 132 -94 226t-226 94 q-60 0 -121 -24l174 -260q15 -23 10 -49t-27 -40q-15 -11 -36 -11q-35 0 -53 29l-174 260q-93 -95 -93 -225q0 -132 94 -226t226 -94t226 94t94 226zM2304 448q0 -185 -131.5 -316.5t-316.5 -131.5t-316.5 131.5t-131.5 316.5q0 97 39.5 183.5t109.5 149.5l-65 98l-353 -469 q-18 -26 -51 -26h-197q-23 -164 -149 -274t-294 -110q-185 0 -316.5 131.5t-131.5 316.5t131.5 316.5t316.5 131.5q114 0 215 -55l137 183h-224q-26 0 -45 19t-19 45t19 45t45 19h384v-128h435l-85 128h-222q-26 0 -45 19t-19 45t19 45t45 19h256q33 0 53 -28l267 -400 q91 44 192 44q185 0 316.5 -131.5t131.5 -316.5z" /> +<glyph unicode="" d="M384 320q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1408 320q0 53 -37.5 90.5t-90.5 37.5t-90.5 -37.5t-37.5 -90.5t37.5 -90.5t90.5 -37.5t90.5 37.5t37.5 90.5zM1362 716l-72 384q-5 23 -22.5 37.5t-40.5 14.5 h-918q-23 0 -40.5 -14.5t-22.5 -37.5l-72 -384q-5 -30 14 -53t49 -23h1062q30 0 49 23t14 53zM1136 1328q0 20 -14 34t-34 14h-640q-20 0 -34 -14t-14 -34t14 -34t34 -14h640q20 0 34 14t14 34zM1536 603v-603h-128v-128q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5 t-37.5 90.5v128h-768v-128q0 -53 -37.5 -90.5t-90.5 -37.5t-90.5 37.5t-37.5 90.5v128h-128v603q0 112 25 223l103 454q9 78 97.5 137t230 89t312.5 30t312.5 -30t230 -89t97.5 -137l105 -454q23 -102 23 -223z" /> +<glyph unicode="" horiz-adv-x="2048" d="M1463 704q0 -35 -25 -60.5t-61 -25.5h-702q-36 0 -61 25.5t-25 60.5t25 60.5t61 25.5h702q36 0 61 -25.5t25 -60.5zM1677 704q0 86 -23 170h-982q-36 0 -61 25t-25 60q0 36 25 61t61 25h908q-88 143 -235 227t-320 84q-177 0 -327.5 -87.5t-238 -237.5t-87.5 -327 q0 -86 23 -170h982q36 0 61 -25t25 -60q0 -36 -25 -61t-61 -25h-908q88 -143 235.5 -227t320.5 -84q132 0 253 51.5t208 139t139 208t52 253.5zM2048 959q0 -35 -25 -60t-61 -25h-131q17 -85 17 -170q0 -167 -65.5 -319.5t-175.5 -263t-262.5 -176t-319.5 -65.5 q-246 0 -448.5 133t-301.5 350h-189q-36 0 -61 25t-25 61q0 35 25 60t61 25h132q-17 85 -17 170q0 167 65.5 319.5t175.5 263t262.5 176t320.5 65.5q245 0 447.5 -133t301.5 -350h188q36 0 61 -25t25 -61z" /> +<glyph unicode="" horiz-adv-x="1280" d="M953 1158l-114 -328l117 -21q165 451 165 518q0 56 -38 56q-57 0 -130 -225zM654 471l33 -88q37 42 71 67l-33 5.5t-38.5 7t-32.5 8.5zM362 1367q0 -98 159 -521q18 10 49 10q15 0 75 -5l-121 351q-75 220 -123 220q-19 0 -29 -17.5t-10 -37.5zM283 608q0 -36 51.5 -119 t117.5 -153t100 -70q14 0 25.5 13t11.5 27q0 24 -32 102q-13 32 -32 72t-47.5 89t-61.5 81t-62 32q-20 0 -45.5 -27t-25.5 -47zM125 273q0 -41 25 -104q59 -145 183.5 -227t281.5 -82q227 0 382 170q152 169 152 427q0 43 -1 67t-11.5 62t-30.5 56q-56 49 -211.5 75.5 t-270.5 26.5q-37 0 -49 -11q-12 -5 -12 -35q0 -34 21.5 -60t55.5 -40t77.5 -23.5t87.5 -11.5t85 -4t70 0h23q24 0 40 -19q15 -19 19 -55q-28 -28 -96 -54q-61 -22 -93 -46q-64 -46 -108.5 -114t-44.5 -137q0 -31 18.5 -88.5t18.5 -87.5l-3 -12q-4 -12 -4 -14 q-137 10 -146 216q-8 -2 -41 -2q2 -7 2 -21q0 -53 -40.5 -89.5t-94.5 -36.5q-82 0 -166.5 78t-84.5 159q0 34 33 67q52 -64 60 -76q77 -104 133 -104q12 0 26.5 8.5t14.5 20.5q0 34 -87.5 145t-116.5 111q-43 0 -70 -44.5t-27 -90.5zM11 264q0 101 42.5 163t136.5 88 q-28 74 -28 104q0 62 61 123t122 61q29 0 70 -15q-163 462 -163 567q0 80 41 130.5t119 50.5q131 0 325 -581q6 -17 8 -23q6 16 29 79.5t43.5 118.5t54 127.5t64.5 123t70.5 86.5t76.5 36q71 0 112 -49t41 -122q0 -108 -159 -550q61 -15 100.5 -46t58.5 -78t26 -93.5 t7 -110.5q0 -150 -47 -280t-132 -225t-211 -150t-278 -55q-111 0 -223 42q-149 57 -258 191.5t-109 286.5z" /> +<glyph unicode="" horiz-adv-x="2048" d="M785 528h207q-14 -158 -98.5 -248.5t-214.5 -90.5q-162 0 -254.5 116t-92.5 316q0 194 93 311.5t233 117.5q148 0 232 -87t97 -247h-203q-5 64 -35.5 99t-81.5 35q-57 0 -88.5 -60.5t-31.5 -177.5q0 -48 5 -84t18 -69.5t40 -51.5t66 -18q95 0 109 139zM1497 528h206 q-14 -158 -98 -248.5t-214 -90.5q-162 0 -254.5 116t-92.5 316q0 194 93 311.5t233 117.5q148 0 232 -87t97 -247h-204q-4 64 -35 99t-81 35q-57 0 -88.5 -60.5t-31.5 -177.5q0 -48 5 -84t18 -69.5t39.5 -51.5t65.5 -18q49 0 76.5 38t33.5 101zM1856 647q0 207 -15.5 307 t-60.5 161q-6 8 -13.5 14t-21.5 15t-16 11q-86 63 -697 63q-625 0 -710 -63q-5 -4 -17.5 -11.5t-21 -14t-14.5 -14.5q-45 -60 -60 -159.5t-15 -308.5q0 -208 15 -307.5t60 -160.5q6 -8 15 -15t20.5 -14t17.5 -12q44 -33 239.5 -49t470.5 -16q610 0 697 65q5 4 17 11t20.5 14 t13.5 16q46 60 61 159t15 309zM2048 1408v-1536h-2048v1536h2048z" /> +<glyph unicode="" d="M992 912v-496q0 -14 -9 -23t-23 -9h-160q-14 0 -23 9t-9 23v496q0 112 -80 192t-192 80h-272v-1152q0 -14 -9 -23t-23 -9h-160q-14 0 -23 9t-9 23v1344q0 14 9 23t23 9h464q135 0 249 -66.5t180.5 -180.5t66.5 -249zM1376 1376v-880q0 -135 -66.5 -249t-180.5 -180.5 t-249 -66.5h-464q-14 0 -23 9t-9 23v960q0 14 9 23t23 9h160q14 0 23 -9t9 -23v-768h272q112 0 192 80t80 192v880q0 14 9 23t23 9h160q14 0 23 -9t9 -23z" /> +<glyph unicode="" d="M1311 694v-114q0 -24 -13.5 -38t-37.5 -14h-202q-24 0 -38 14t-14 38v114q0 24 14 38t38 14h202q24 0 37.5 -14t13.5 -38zM821 464v250q0 53 -32.5 85.5t-85.5 32.5h-133q-68 0 -96 -52q-28 52 -96 52h-130q-53 0 -85.5 -32.5t-32.5 -85.5v-250q0 -22 21 -22h55 q22 0 22 22v230q0 24 13.5 38t38.5 14h94q24 0 38 -14t14 -38v-230q0 -22 21 -22h54q22 0 22 22v230q0 24 14 38t38 14h97q24 0 37.5 -14t13.5 -38v-230q0 -22 22 -22h55q21 0 21 22zM1410 560v154q0 53 -33 85.5t-86 32.5h-264q-53 0 -86 -32.5t-33 -85.5v-410 q0 -21 22 -21h55q21 0 21 21v180q31 -42 94 -42h191q53 0 86 32.5t33 85.5zM1536 1176v-1072q0 -96 -68 -164t-164 -68h-1072q-96 0 -164 68t-68 164v1072q0 96 68 164t164 68h1072q96 0 164 -68t68 -164z" /> +<glyph unicode="" horiz-adv-x="1792" /> +<glyph unicode="" horiz-adv-x="1792" /> +<glyph unicode="" horiz-adv-x="1792" /> +</font> +</defs></svg> \ No newline at end of file diff --git a/latest/_static/fonts/fontawesome-webfont.ttf b/latest/_static/fonts/fontawesome-webfont.ttf new file mode 100644 index 0000000000000000000000000000000000000000..96a3639cdde5e8ab459c6380e3b9524ee81641dc GIT binary patch literal 112160 zcmd4434B%6xi`Gm+S8fmAvrlo&PmRY0RtpCNq`UzVTOQAPJkFt6hRae1aUelRlymQ zQd>1@rP6DAZLNJ<TfC?3t$jO4ZEJ07y}hxmZEveyuzhWXoXz)t);=dW37~D?`+dJJ z!`^G{z4qE`c-FI?c}q-^B$t$vWT}7l?BxqDd#>>jTzMP+(K$0`&E{uGiX<@$^0Bj* zjc>h+@9aaq0r~!mH?7(H>b_@IA%CYN@h@Js=9<kXPogGC>BfD_WmjBx>B6P4J;=|L z*gaogzi!PXmP@^_OKdN0OC9TR!Og9|M7|68#QIHJcSI9`oyen3edvm-E?&cKe&o2s z9zGv+@J(xWZ06_ksKg${eJOV3noaBa>b7N(zd@4ZuFY3nvvrH}S6d|Z_?ILpuy*^p zwU<8k`DH^A`*H=!Yxt+$N<WzT#1HBG{bh9nbbh7olC#7e7cx{5ok5<llQ^RH$f0_z zirp`%lA_$Lv>|`HdFIzhD?}cbPXDv{x~s2|vQq5-paCaQM3Y!OPNF5nCt@Opaig)5 z&_BA)o<WXMQAxp@C8-~^s8S5S1JWVs^U{~3m!zM^Y_ajNi{f>4HFf>Tp`)&&HAj1n zE;_pU=#@urI(qNXM~{B~=ogP3Ir^)k?;bUdxsKHwYdO|)Y|*jR$F4kf)3JMxJ$mf( z$6h>k<k+u{y?e}f&-H&K%%3FQ@bvH-q)~5>j(U#9k7kc9KH7hD^U>VV`;QJBefDVn z=qpDDj~+cH9rGNE9h-10du;Ks{$rbu<&NEdY~a|l$MVNsIW~Cg=z9{q;pA^lUUKrn zlNX#^esadi)<OG!{{BC|@~ij%<HUcw@OrH$>Z$TndMZ3&PskJW1U!C^&*Swd9@)b^ z%p<u^x(#>1J>)*&KJNa&{Wtet-S4~qkNYp~KfB*^A9Ejd(476h{=)!ErPnZm4*D<u z!A+XV|3CcbT7^Z8SZ$SOYz%?;Kl#G|FC4#{(O(Y+MV53)>Wq8ivN!G>WO*aInGbAM zW5+jZ(sA*Q(y)olL>k5mPfFU8YEG&~CZIEKyfqZi>f?2(_Kvo=m!&f8J*+L>TEny_ zn+tccY$TP64CUy^vV}XF6AfWC7j8(Xv+HrYAf?(<_>(2Rqq#m@WwBI=slq!XyrUTz zZ@|UtT6lX8Z)**E)zR7Zj!xFm)*8~Jnd>iGaoPHrIGuI*d4<v0RE?Z<cpAFY*olGG zMa{ur^P)>|O7qHh3RB82$ls}LvjK^85rm)(IkZ8S;^@3biqStqSL@OYheV2dd>x6H z67mHx3?U_Fd|=#be86;ewXFBGcO;BM&%JS<apLe*R~=?5t6}Qlt8QTDB{>Q(-7IY6 z+WS)M+#5zpTy@wuao-!y8HbVrBv0maAQ34dO_df(QqrsGitggg7!a0DB~xi{AcV2* z@OJYS8FQco1L07(Mw!A}d*sfJ&K}n3H76(IrRl*y<zh+WFORlmH%(w{!lrE7qsCv7 zF~3vIJN-=69G2r*r+?o!UePAkb+!Z;3$%3BP1audM#qJ@)xF2Fy{lLEs`=j4F<DB~ z9NE=8VdBII&AX1&Bnpz#?^hbQ&+4_<RKN4-tp}b`Cq|M!UotXLed<8-1N|rP-0EJ1 z>M-Y+`j!K}loSkUi;_VLTWff@N5+KGn92{g`wI8l>ifFK8-qQ!T(vlnSbWtjJ%h$u zg$HszzQU5Y=#qP9yz#f@dD%oFJFod~Z~Vtwg{RHBKZm&+l<JT{MSfIA^OjU`1b}w> z2~0ba{*KnLU&WY2jEBx;!GJ$#Of#loLWBHV<H5=<_WqmxZvUI?{Vw^sP{erDaOlop zwd3u#9o0e2#s0$9Rt1yRdF(rljmD&TR$3zjH|D#o1ie<4v}5w+q*`jnnVX?(VXelB z!-tI(taTpS$*yDH5$$R`bF+AWHTJNZj9Yt*pBXE^^Bvh%YG&()w36Bg$i~>$N@+k< z5klH~R2u(QT4*(@<k4a&Pe)A6?Y(Yj|8;xyV60>Ix~bOQWgol!W6OH2Q`gPzhy`^c z|EBTHH{WDEx9zy=t{s_m+b+3iMniL^8Gj8kF1lpfI{EkJ{Wm4aPHRf1_qy@s@zONu zZ0REDD(PnFKIt*(UnNP+w5OU`omR~Pp(zYt{SkTQZBGfPFD?T%ru-@Sk0}39?;E?A zSS}S2nC%P)MM^~q5}`gB$06iO1=X@A4Wvg(eN>%Th98K9q+uatOZBDL!>3CYA{;MH zMGQJBBSlV(B<1oV#>n;4SNOtl@orTtVzChk99f!A!q#FhD50B5LYUYaO8JkvFH3#x zhSc8I*UrUpBrWI8bcaiXM*G?s9r+K+GDGE=QFkP<SOxwmwS5E@C7=S)>Z!~`n%*(_ zvG@O{^JCw~rLG1e-_X_7z_N54N%LHJt}rS$`rhc=hm|a^k;TMo>A-$IoGgqa<&k9B z)w1O23zSu6Qu^3t$KZwk@mcu$M^(jm4~dbM(dQGRMt}6Z@^b&=SdAJAiAmQ<F6|EG zi&6-?3HB~ss~gW)s(l*6W@W{pmT7lH3*+vLE{@)5?2kq%!BYHw%FFL97Pq2zvJI4v zMvY(a2T%s}UU~9e)u-&0>cP4N+)S%WTX7hVsynTt>kkEVD^q=<X5)3^b+aaxLaO*S zmMYf%I<AWMoawIl1l3~FGbT+{kG*jw_GYZBX7f;&n#!;@(~6q{w2eb+sG4CT0uv!9 zF9}QXw3L@3`JID)C&-pTkRT(;QS{h?%$evhK6uKLRLSqkh_vT7EI0#^R^BJK6qY8K zeIkrk#2tTM`wMw$I!8<XkyeXN|J^M$X_K4=%35laGDI11O^Jby&9wVEJ3`@*rn@j1 zf&#!snr>mBAHyLZ;cOFw6P>;Di1AzFe;dC&vh(r1&6n54+)ZmYF4=SVmBV|MY+T#q zj@52x+WUAR*SEe8e?0doD!KCri+<|Mtanq))!cM>Z2oK4tw(V@wf?%-=Ep8?YIemo z887nr1%byo9f_6#;VbCha(Y2Z3YaNDN^2;I)`4aaI}8EM*gUnq{QfC<$>++ueB!`z z|5&=e^q}u*LnK)iHN965X-;W&^$?w0GF@Wt9TypuGDTVu^8vi4OIIS_o~qLVp;lTD zSf4s(B!C&I#~Rgi{8BHlT+=!&gjAX+SkU*l)WQhZfFL?cSKELkIza!6WmL;T;ZBg& z;0%bYb}>Cv3wA`2_P@G+|Eqkz$MIEvpnk5+T6KTO;o389yvM0m|H>6)(TR=s*xWAr zO=;cYp6jb}{V%7-V}HR_*)YRqjXV%?I!712*XnjUZb^v35jP6+5WQhP+w?0(h(|k; zt>-%;w&cCmE5hzOTccj*S3JRuR{PZ*HmAcLTv^#Vv5E(sqHIgcq$LiA&6&8*wz0gh zZF`%=Wfq<g<w3D`6lqy=AD<%4kS+skkC}C_jiaDoY~Bz4H&8=-YY$^_jBZ@hRRL*u z&?I1r*r_d!Q72BSmf^qwJz`FAU}s3@hH@^qEN5l6tI*H#6Lg#LEt@W1<#Y9~?i~U> z)lU$@GPB)_Xn$Yip3O2YpByU#Bi9+yg&O%wLw$gGZ&I1R&C0p;Av9#DZ`pO*mdRfc zP5Vr;y*>FE0ypp`5e(R+sx0}%`WIb8$BXn?#>zsS05m`sc7`;;8gbVEr6N8Kdc)vi zL9H6Olc2dGDaNPqY3x6HEKb>JDfAWk91f?Y$HHy=hq3cxe-Vr6mp0C0Mht~>MCh_X zrZD!pk>b<mTe;4s7yiw{xOKj*%EHf!M1Jrs8Vh6nmq`u)kqpTJfUo>$Irc3;ZE$!# zOwuf@d*i7zOF<4nI3Vs-zaDMqYB(-v6*<??AKk@v*c`@p9PDDFzoDxjDZ8Tm4JUF$ zM`>9Ujm|Xgtah+Tj^jQBJ3Si^f)9GPxi$mXf5w>*Rl@62z<7wIC3#v{%*8x4EY=}; zIIt;%0+0#FKqMwc7!;Gh2KF8|etvxK-s7y{IJ^3Y@tCpNc<jg#wuU{y*2sg#Fboka z6bzI?S@8tFsJ!TrBVry~A#Ys-^yme&ODrR|Fk+i@IjDt*Z(@OZ2nEu(j27dv1|dNm z&;=vNts~?jiV@~O!B7~|i}Na2!1;nRz$%!}@fU}Wzu!{GI(;mF%f?Y$4=|szkZp;u z$1RBfTZSucTsep$ZWLk50tpLyJi?<2!!G7`8hORx@qjD#JDEfmPU1MPqelt&qkd<e zW;yRf^2FOcLS_rP0Q0PaGfYC(Atj2quypp1n)Yz0bsDWc7Sf51VJV=ucu~L+gg{C) zrAmw>OR4sQ00&GoruIj7O#am5JJ~A@UB=hEwMN$0;WM(eUT+hV0GZ&CnACJo$fHcD z6pM{e+IMz!-Py&xjnzih?`Qey#x%<d)+#ID)P$7^DIsV8&~3$b4TDP13#kS#0!t6` zq?9svQTlDhH|!O5Bk#6YLV2-pFh)NZhMB#4Pk|cV?{FC3uv%Hx;}0-`8<#QQ<E>?o zcK8&~IZa!E7cscz7HLXHh|*+dZtLo@7TVY}G@E7JKmO3BJ{T|tsDZ5C=W;mMG^^Ff zd)Nmb(p1PO2)P5sonqz3A@GvpGB&SxI8J-KiIgGAF|l#jACgb9ZYHx=3*E2c#JVqH zS>B(D90#JReAkwV$k|B7_HHH5$~KuDH9XwG^G_HxG>PojJyUr@WnEom;pbD!#>g#I zk%WZkaIxuvjqU8f*qmY6D+95@pxf*5#A5MU9{bQm&!3v_GxAo8Kgn}Rzt3;vzyD#Y zo(<z8XftTS(EoI58cWsJxj1OHwpQBjfvao4F(||0$+lJndp}4!0JxED@_K9cJow!b z@wNTcdAi4C-)&`<O~&`086nm7G5^L}0pY4-WFx7Dbj_aKMG|lQMK*5TW2v<5dVq*J z*2SVnc3!pa7A&G+`V#a^LYjkC26QgP>k=SXMg#!hJh07*#tIBtTG-%k(3N32XDaha zanbhHkotR;HP##N?lt~<<1KzH&j_tN|L!?oT66m!X4{(pj!u6i^$%Ckz2e31IQ`Sv z!_2>z1vcJ_$Jn6CjlUSrU3uv(ezS^HyMK4@+*_~qUJ~}petH~N_Utw<ICbV=3(+-y zia?PxYNzt3B)ckdF(VXdW(<WoHc#|jX(u5<g6@A<-akfaRT{EknM%%N1c(JXT}r|I zA#qQ}K%FU#LL~Y%CBdU)y{vz@;y<4zRXE+nk!yuESv)k9N9D@Gav`u-<4R7@zqJ_0 zIJgdou#3=Lr06s4*nf!=3}HDF$tq_{Om~b~*k)#lHFU{Re#8F#8;rq1o)A3;y3c=w zS&YAZB@b04m$F4Z!Yg$OxEw}!Afh_}VaO9z-NNhZOc61ybE26+GPenVDBhkGgPUEj zVS$>jtoqr*Q*T^#*Sx%O)a!|)YJ-#C{_4gTZc4Rw+<f6OXC$Rcb5kc=G@i<Pskxa2 z3$_*1$|~2^aqZ*wT2m4JyI9y&y<_qee^YxC0T|Xd@EwiC0&1a~gYYlH5zVv74x>4p z9hr6x3WEm&wX~fNlV&CgpGrIeN3V*i2`$$h_-bhP`6E>7oNMc5RzC}I@fVGsJzG7q z?%Fvc_s-uP`f8y2_CeOp`dItm?R?L{2PejtZHy7_7W|AWHmBQh(b@-@_Nh-9#~)mK zk)wN#xN8!qv5m{(6CXVIaaQs2&YdqCe=z$MlO<&kG@QU&*shE8W?LK^O-ROG?Khq? zjte}jv4vQw%D@R);cOw+X%4&cLURogyu_58sOzlL*9Iv8O(X`OM{aMCF*?NeobDYg zcg}2^JCdrXtE-^@RK#tYeVP{=z5};K)nrw$I#}5<v!xQ}s-z0)6lx3L<ga4R=Adt9 zN%N$Q|45s#{TEv*^fchN1@k7_TXqi|9stqj;kZpYpMSJR?3~Zu?Q~S7(p`c1%a+X# zbfr@fr}J+1S>q>8fN5H<)mswR@7Z&Gq6JBD^Cy4*D0CV}jKUN(6-fuG-5pPU<;f0r zbs!DspYmm+-MD!r?j*vBQ>l!sWFFSaJS!uW$c7UrvQl!;APPMM=^^c){rr%jR6#dT z5A8skSgXPMj357T{4;PW^h;-k1S?(#@0O|e)_dc@whUdTUzWp<oCE7cYzO^AIgjH> zsgP50xR66eoC~=ER$W0{k|kWr4Ka2z6VEVQFXVX65Z6i0jHft?$P!(qf9isV4nlr; zYCqDDbeVmb0)2<nR_|@||6lx1!%r->y0-Qa{PpzQR9ibu{5>*l8vbq)f2*fWJG^=| z6`M9q%^kl*z4@Q|CtPIi=?|%YLRu${@34%bND+a9C~ZR^i&!4Walr=V+N2Row`Y=t zOezDp{6Hp`;@?jycDlL1$Yzp8AerPpNaiwZpuI1XDs&K$B@xf{kiN0_E=Z_8{B5e) z25^7CiBKT2dcxNq)e4pqjZ3uDu-B5*!dzzX?`R)-gGNVd@ep3dzn99G&6Xt__{8hb z=H=2Q(pF#q@Fc+9z;WqRC)Cp&sm>lwf*MMYL~V2ex3sVh_NBG-oUUQd0s98lI~`Jq zb!#QrP6|~PS-G;jc3DHnc*lRu^r3YN?~7K1G=@EqJAztxoJCf-9F>Dj3ey!Oq4>uu z%)+@Vq*=U9e;}TQ)Y!>Cn7=q=yqlPF;m{|m>~>ql4*8SS9TqlD=cyC#C=M6zcUCGv zBnksatUu+7Qa5St(6!m~HZGdct+co-Rhm6eWlL>L*%~bNIxVre&f20n>($7%l%?Kk z2}CT8WISCNVw!B-Jb&og?X%pTs@b&>`In)3cMa{Af?6<$S}>CsQozN>RbUFz6|+_d zAxH`!#9$CqKwM!0A@*zK?r<=kPRIR~6Y7mQ#+<}>GarP_fz{bncl@t)T~14kJ#CyH zr@U%KUZ{cym*>R(D+4bDq;3dFO=KeEKJgMLk_u3WtWAoIwi>ZL7r9TOzXhkqfPIGW zKLC+KPRW^!C<MzU?K0@}Z#f%u3?G1i;y|<^d-fIv{KRry4Fd&}_skmoPCuT;6|m3) zXK&##5>_05@ZzMjMXZ&ao)bKC9P(UAA~OsaVKC^<(MD>X*|K4Am1N4%J@UMF4;^~< zkUU5v)A1Y~2iyGXGF-~6^S2c)8<Bj={U~?nT|RIBh9OZ-#_`UHbLLFE^F)pe9ZWk0 zyc{%EY5a6)F=k0_1>w}00>CTKwoicw(jW3+=Eyt&2aq<wIuQJd4#K~+2Z~>8Zb=PP zO^w_}QcAk1)oc8xpN;=;l0S9c(D!(_cS2jr@eZq4kg>=w$M-h6&#ex){d?RRn`UJD zj6bH8+gR8Vv^v$ErOfDwtcy-b^~sD+{;$cFq`X-Ek<p{@!qBy6>vo$zUCY<=S6#Xh zTV#CVqPqW>e3rvqt)={mPw}`|bA43B{%mttJdb}<=97(gDnqqCaBFF+FJN(*xC$5& zFc}1fUjr?As4eDgPq%>g($TqqR>NdLJEChKEA@crb3kB#9;KUQJSaP!btHhapyrT+ z0hg=;cyIzxVPtso{9d-Bv1(TDMe`=li!#nETGNcBJJ+^NzGQ1}>tYKl{Fb}#PUv<` zg#ag!X=ziHwd}XIg;$1Vf9!@;UGcM)_hcS^dG@x)o?bQX*>M|;E8Q`6_SL=Py5nBO zmU*?^vVH!A{53r?ZR_&cmrsd0Tff&<wIR|nw0X5s;day{qvM0Es{C5B#c5R)wv78( zWb*PG7qp)@X>zQh{-uX5dF;|zQ7t6aXHKE@IZ2X&0>yQ9L|8i0!qc6^ngZ#OZb3&6 zHI5@mq%|G$i;mJfd$o@zqE5DR1FM+2$nTGT{>I4@*4-0TT{ZV5Ee_4ftFH6%5X1+} z`?Tz|H`}YXM)%BY`^rt{@U*YKSLf~AUSH|7tMX;ss;X9=ZnY)d{_*k2&Ib!`F1M~- zdXC$tRE_JD100f26IPF-y;ahUn7P&vsl!Oz326=5M5;D4kpv?ERWPeGML^I!5OyL( z;Hl{#$9TF$ralnc8V<k=NGkz1>Pry(LJI`s-{EcNB%vo5r|!an2akKTSK_|FO@Yby z_r(`4F3)`MqYlS+FlUMT5-h3J*n=)hlM+z4ny#*_mOW0UIsAGx_g>t(C}w4fs@fW! zPN;HSpYhx2m_^xp!4(yLjd4Y`e>}b;;ID~Cnq0YL<cSFWl8RJH4N1z$D$Ffos?*Nc z=E23)E@j+u>!MlAVwE{#in640b>T~od#;)r4>o%mY%VwB0bd)lR>dN&CU(v`_Taj0 zyeb?GD2@u3bNgjH;$vWnX^dr|+gKw#1OaYw91}`7G-ePp*eHvG2uU-9@Mj#y9^MZ6 zmuP!z_T?kV$ZUv|C0IHw80btq5DH)u21A#IdXo%_YG8;EjJK!o>=JWqXG8cZZI6e` z2i9fts#9xjT6{&5m0`i1c3gF<42vF&m}38U<6k`H*s3*-?#`?di7465ZimyY%0rT@ zLLD;ZszO)Qn=$4ba`0H$kT0CgoEqnfx}@_!d*@3}%su^(d$#`T9nZ*mwMCylcS(op zsIoh@uNPx}{A7AuhaBt*${pj<!9;C6=k>LT;At-k-ertDLul5_UCk7&kCjt=R9=US z=>xE9sR#_JQY7p@AyH1nkp!&AMNY#}+{@8D1;@Nd(Scq15y}6L+HIOE%4m#ew`i1# zqp;KwIgaE1bi2peCwx?X^mvz#cKKN2x@hq~Jko#HSbtO-$KD^?<`H-)hn@2DKQzi8 zDyJK(Ii|Le*xR%@Xbp|cpAO#3%a6T3wy$IJOoHNr$l5a;G~7Qf?x|U)|9DyH(Ra#A zm8S=X>t)xRE;;n);j79>fwHToe@y7%$KZ;yLE#aRNxB!Pm1u+fM@Qq7(aHIpE~_yJ zg+|N@!I_Hu2N(yxQxnZTA&!c;Ql1_uBM*`p1w9_6ga0FYR@Pq$iiT7BSd{w<LK<=; z>;H8h`>BIMD(FHJ)kFVi7x|GW)nJ;6AZ1v^sL-LTGpA2t%8GrIAYq~T6C6~jPbD_K zn$dKIL%NiP+{kBaI<&oz-G1oMcAnpUi0$)LIh<({5H)#KKihY(bm!3ar`TS<3N3&s z7Xxns`bvkdN{!TlYl1iFXa!4^VHim8vfxq#Z;KbF!etx_QCd8=d0_MA0cG>?9Lo-H zP!k`Bj%r!-bYHmzq~f81n+q^q&x@ig=69Z;Von8*#7>Z<Vy{A0i<02+Aj{Y&Y2ffG zp=p%jooPMT7G&+9&>5(9@GM}v(LOI^unfF9SyF`9#+83snd8@nY<l6>I*z<X?_dK% zd81$bQ}UqEe=yOJN&P8_QX6yfK!{4&LR9K|M*mQr4e-HC@*o>{DwX;pBprhO6!fwV zdDkc@hYR=!Yf1>cWz#@|?T;G|dZx{t<~H`l**Nwz8z&d-Dx^)bhmOZnskp4o-t;OP zXS{0GU9>5I#5L)y6YA+v%4z9A(k{ynj!{GRD_K(^$B&(=H$<ChV%0qO9g@9*(~;Au zIziG0VYJebBt1Eqq{v_ZAcv`u!?2DBu<B4$SHR~*Va^qR_y<z7SB>+HSC?p8F1Rvk zZEbI}M6bMHi?)R25^>fX?+kl9;m&w7izgs8fBsbi{d)C*Tdhyt^@|H@;5T#OFYbEM zdb7D+wZ8$zG{D#-sYjZNR++OYr7)MFPUZ)KFY&>EDzbk8VGhEv4ElilLGFiSG37cY zoaQ?q@7Q`^Yd@D_UgHUG%*$3UIkbHU@PBB#oSoJIV-CkemoFS5<Biq5GC<6lbvN|0 zSfSq-R93Ar23Ns8?m(3FqnfUMo*%BK@WU6)TDBjm)IDBQqiLoQ$m-skoT$aaUxpR~ zRq^O57F!iXEnuew%#eNn{C=~vLag4hu1ys7^58<q3ZS&E&@&PpheLi-cM1Etn6CLl zV%3wieUDC-b_C)Ong!Hcsf*G{r$4f=%cgBE_0AWKc>KY4jGS2g1IFQNwx1=3EsDox z3r%XO*Ms#_7G1UH`3(a=84*9r`FXujDD~6ttWqO&N~xEx`EAY$kHyN~Fmk{bP5Ik) z8_$OA-07;jtbbS6#O3{qmrb9X4haN<BJHKV-;B8)FRTVfBa7m+l1<d96HAy3{TKTb zv2{fY%JS|GQL-bZYr#7di1%5yD<BHx2V`)Xjl{hn<-+|MW6@0bv%~BW5skHIo zsWdQ^Hrc{n#j_Rc^WuRD;{!ZOmC$@L@JB$8n9mu=33~w$B5^Vj5E<H7i5-mthD*CF zSwzN(L8UEMOd7GM(3(+3m;5Is=uRM`hU$cpbb!S<h*pvGgZ_XPRNST{<#8MK=9J_Q z|6}F-qu(a_lM^_N{DL}!3<`aKgNmTBOi>hxraC(1pZFsYe_^s!8L@{~tm-v>N91@m z;_&mAthT}m!8r)ZwXni&G3ysHc6e2cuKx_L5rsNBwc)p&`cD3mKXS^OC!e7SDC~$7 zCX2T0EXoSuq;*PLXmUh9wPj{M;m(EL`q3|cM750Rr};L_#z^&|uQ#YStGmc!0uoL^ ze~2}@{`f25cs#652=g_C8fPG)<|6?oQVD`7v9Ac+PquKh!<XR*Q_ER~4o#Z?iN=|n z1ctz`8N)d>OJ)<`-NdmhP46Mt1t!9Jbf5YbvNRYeKdPRQXEi*Fu?r7(Ee!c7^$>^~ zz18%yXz2J$G;|mk8a@miK?pkRK-OaCFNp+34mTYU{*ui)Tz?5pPN|<>L#kAgkeU`R z+G*ctf#OQ^90%2M=C`962Wgnh4)cRHYk6bDIF;7K=(db)#BhJh-#fa$V_t;LlGm%G z!D|a}0)?dCL<(ZgSyB8;#1wVbg;6ZR7_Bk&rI9I0@v}-p94Y(`8dr&WbP`8%JRd&! zuyRoS9VjNr%0s5*xJmVkty0-nc!&G_{)03V5kUFxkT~d9eo}a+@Qz5DmvEiRn02l| zotGBtG(~S^M(6+oWf`iXYW&=fT14fjfbXL>(3?1Z%>q<Vj7141Np~n=W5aF$%F^5s zvEh?X5sbu4$08UCwvIB`Q}WbhG5FMT8U>M|!C=`jgc8r@NHSm!)97bd^BB^pd`)7G z%yyMpb7~vP{D4mTRueo<c}w})Zx(vf_VJ8N1t8R{uX77w8Au<p8PLTs)CLPWlF4CH zET;{X8~x8e@At3pS4AihsY3G9E9|y0Bf=j2u;RrE*pV}iO<34?QENelgRB&71wJ5h z9JX>JhLx(~TZwr$*8dvEl`yH^KyBo;zM(NKlIx;AG~KxT*XWHe3Pxr>fT`9ue@q)l z=UBpJlcm|9m;pHiG$kK22B|HW0}W&$T4Nf8U{8iPyHo=EFSHzqvR0D$XI_{%l2!0k z2haO+&K=&RJ3Q7*ysmx1f`$pxE*B-5<FUHQwUsP4ru74*r+xhM=kH(o(+b}unqy`~ zMSDEe5{hn{k)X=`Q~kc+#PRc|j_Hy#(kJ4*CYSnDG$S&b4Kkv*Bw9OQCNZkZqbw68 zm?@WxS^N8i5g!^?)<J$s;|E+mE>TG&jJ!Dc<a?1ZliwKI-jOvj9{zyRh#v@~yu&gY zs1HCJq47Z6&>&&ZO`90lYl||tKU@~ifl4yvI?z1~m&J3aL;2h$TDqHJk6$5{(-n`$ z#$I68q$2kv|Ma-H|M;Jh_t67mE^re=oaX7_>ex6SiZeW3tdH>F$b1p*nt~A!PCw#6 zjz5rLn<|MScjCs%4RoBz265hATg0||Hx7GkbjE2^{^c^O%TtU>*>_L>&~PP{A7-RD zsxL*mX>u|mV%F?|saXk}(SUNFv4WQO>wf>GIKvJR$4mV?Kdj08CwK-9y`rRegq|fs z>kl!Z9v<_L!4uFY{DfgbfEC`uRbf*JpaNbr{bP!L-fHZ;f@}A{Ro~rv?ocKF^Bqrt zjaFkYbNUVZVSYmfPe2J>tomhs+vB$v+!vg;_xoSx@2%WB^xzXvP`+gRS~$Ygu*s~N zQkZ7grDZ@zEs$c!0D9}=*!zI{gj|j6wL66P0aOvTaZQ@uUdXa!Dz$)25DMF1LU9-A zLl&e`#xHrkeL5^tG7F5?6IUeqaPMwmsIVuMnxEQ$0%TSOT$fSv#rF}dMZP7(O@LaU z)dGtwF;RjeRP)Kgwsd=28uhbeA=^HEdOOb>zr_1f?U@w6E6KARD3VMrzzbM%K?ZMU zDZCvI6t>mV`!c|-3)C!m(33nxbZnUPGB^HWH-YT61*nPqv|blgiH@Kueph{G2fCW% znGb0TwUyQqz4LjzGgtEcE)6E&kGeHX02ap<FQs0>R%IJTiV`f<*A5RPmZI@nkmPyX z+e+g}GM)v=r13h&8t$f;ixm2fx6-)gKy&8FPoT)lWq@E^@E{2by)W4)@H8B)I(_jr zG{NN83}VOz*M9O7Th{i}tE$)Sap(@Wd~@ar{@p=vWn6*>ydR~A9C6fkoU?6UUFS@# z-s%o`tr6^$)d#<GJKIN;2uhXH0AZqms3kxY!#n`UHL?7NFTlK)=q^Gpn0W}@{%kY8 zbU$8Jw1mB%^#OBSEr-#R`;9MA+Gb;YRDuj}**g(Ye%K(F%A@!^VTVf(pnOC;fFfuP z=vC**d(=Ox*Ffq;G};;3ai(?)E56e-<P7cR+0!<J?>lX?sePEoqCFY`uUL=6z&gA_ zh5-m8rovvs=<jOC!=a#Gco+<b41?W<OrEo+TovVu@8XgQ0};VPiFcLOpjq#UELEtW z5>b<=7q+ZSBHokuC-UH{f%An6h7-fhR5jCW=PYPQr-5_|tHbS0cEDu`K7OkDy_Tv- zHgZ{u@xFj`<NcP)kgsZCHYCkk%w{eETk)3hKKmV>xDvNNVZ1E7t=m3<N3O*EhaWE8 zVQqBBczO6v`QAo63M7ZH;Dj}!=_y0ha5=3d``goW0W_-LB-HtMa*#PPOdjzs`k+1u z1aR<ipUvia!)3D}B*<4?eswGza^k;Vbom3$7o7n=yOeKoXcmj+DD1Pj!L>q^i67wJ zEc^>X;FjkTmE?t;A@mX<P!=7mO=y?{A-JFr3EkFe`ix<yO(q%?hAA@_kx#I=NRlR& z8;n{9jC>-Rk0y++Z`~AW#!T{`cQrIeZv18gdlm#$SHlTRY`>tUzH;Ghw_Uh#YA!c* zBc<3^T)r=Lu~+kXV_a8dRh7K%@!GD%UHGeg9JPX?>Ng<`<`7wz@3t3iTlmyd3vu!h z|6kN$1QA(*<jOE3fm9GZ0_jSYXD~K_RlX*fGC&YoE|{i(S|Ur?9-t>-f=cFU3jUxp z=kTP7JY&4^o1Iwn6~U_2f!$31a)hS>EykaI`P$%vd)#}&p7G5+)iq54FSp2Y&-|V! zx1RU$7dLf&>A5dHl(wY<b?J)qw3tVRUDL&f?g&-@TUD&~->{x(7p)yMzPag&@#_3+ zUp5q}R$Q7>uV2_P*{{sBwPmjP@nhQ)KDTU5Cv9nO*t%-hRw3iSx`Eux4GU3;eDr8K z%-suGsDMDa>97!Rs=(mkbd5r~q!G>9NonHQ{rzW8oT0E4ckf=&Y36!mGdCb~2Xs*U zi*{YOZ0_8ZZT&gM8kcXq<(ajmE30oUUZEie{YK-i<lv7LmncY1Dh(qMNyx+D#|dB; zb3qf)3Z@Kj0vxB|K3OMp;2hR+2i}@$#)O&r)`5?)2iU9Zfx`3Az>UvE8=^bU4aipn z?l#he_l)%2fxzAD7qAci#oavn_O|uceU*aFeD%8Z+unZp&wu8V8lunL7>Gs#=k7Fq zJhT3H#-CW|t@@euZ?TZ^$G1psesTb99R%G|2~VpT(m8<qPFT>j!$!w9ww+08r@3*1 z)Ic$_#So?ww3CeA4_*l7M<_>rCjc=xp>~4M=FN-FTZ_JYhVLHf1-pY?Zmilc(dKjP z^o+aj*!h9LC)i8OdBMsKn@^1-YT~jd`RJ{z!ou=_^z8k{wqMPEm0f<_HJ_Pw(Z5dm z?mg4;8>yd$!LJ<Y=6~z_>jlT*3p}$??Skn)-(A~R`zPk{uJJhFSHo?_guC8qW$&N0 zYj$0B$ulqR^1b`@=dRhD{UTTmnmZ5h=}`esae^r9`X7OlWSDpkTX+J;f}@Z|l)Au5 zPWu~nXAvtoWvM>tol<vPs+;0X*2|K&dv^EZKumrY9oR1ReTQzh>n@|y=5)%>9?wmi zR$W(DO{TlGi3IRHe$*?}D<t^*0e!m>%%(UWP*VwoMl&Ome{u%Gl+-df^NVy?#gbS1 z$7TB-A5gtH-J!^C&G;{)kWroeRu^|$4-eTnvmveVZ!+0XTr#)kTps?3fxf)j-=6P# zyfD}A>era;WJ5;bn_gGHmD`67>mH|Ljg@8KWfiu-BRJ<&9~<b)(oRM(lQ5R2+Ch^w zH(5ZREnNe-U);3fPL4T4x-G1`#r0v~O%WgCUa5TNn0saZVBiXe*}eF13WzxeXTCw! z4_BhRF)%jG2gUUq9bqVrk}w(<B}W`;P-gf#Of`{)rm=)97^0ILC%^S}xXwTy#LN?} zh>|RprRv~A!eWST7h`$zjH^7xVx+A!25}tvoG5~Z#!zDT^1>4mRjuOKPdb@?^Vlbu z`zzM7ItVVN6Lz5ze8pQ7?4d>WmoN>{-N-@{*rKI7I%||R8X2O7eZx27*b1<OUEr>V zA0^W@m?saH<_~u-4Ar!?Ef_aQJJ;ZGRf8WN>9b=Sx>mIJwf448u9{LTLf+6NS3fFp zQkt-+yQw19Qr$RX>UkILm}%BA=3?n7rFPZxXLZhPtQKODAs5u%d8obfjLEtyT-P!+ zec_kHeQbzuos_qi3e<E@Yw6k4yJE-UbKBzL;Zax2;utrqE7HFJ9TI5@f&?VGrUHkh z(wS68iuORYlR_i(Fl?HNE*&*4`OEADFB!)tPWM(RvdV1mAJiuV8!Kw;k34_xQP%h6 zzpziqEykyfU;K;ZUuU>1uvlb@M{&z8ZpnnZTIM!fz_k6hzVpnwe=+9`D@Dyg^3^81 zc!L2!6_s`}NIGg{MDZ%+KU$jqZR2rcuJQP{L7qeGFur?fOH<3z?(t@pf)A0)wwa^A zL?bz#&wbZ;@%iUj?{`HBKy50dC?R5m@C3hfq-gnLG;kQl6;e<;sKiJ<oP@}Ne8-Di zWl=}9j|8@-N`qg1swCZg%AfJ`w;<)O@{`d&)p>GIJ1GB2$ehdM2gBMsjRe7_yqPK= zmIm{mqYkPo<45hLU>dcfPLnpuDLH8U!3vu(uUh18giauhn&3jQAjn9UbZR8prifia zb|KIR{L8^B)4D-yJ2?tgpLBI9F#k~2V%HU(kEGlzi+Ex1hD}BCJnOLz=sf2(@-Xp) zV=t~1@^sDbl=G!0u*MY|>|X<HfDM4eg5ydkWaPXcl8l@^Z)f`}yhbh@X5tddIr3Kf z$RkF-m;=xs*u!#wW%8ef{3ubhwor;^@)*?B8dz8B;980VEFim+OpVPRDPiIOb5PJP z*dTvjoW38cJn=Tu)e89l!Of5qNrjU93qKG*BzY>`c135(7b2;Q@aquIERgetRFRZ- z>eUrC&jd1MkGR@qDsm^1PG4;(si$b|f%eV;_5m|v;TkGVic+_0)rst?UAtB>9QnYi zUGhLd<mEhFjqRc;%sD*|_4uVG)P(sm_hp(*_{O0k7KG>@L3Cg>3Py;oi2C*OYK>=` zKiPXCUze$6i;+^Ybs6K(P=581sm8ymtoY&>UOu<B-q_kUCsI>e&+f*VO&+*tuCY~9 zyh>SPNR}h<JoY|l-eBzlAR=y{2th)XOJi*+Zh0PpMJ%myH7#X}YFXv=b_y0&rnSX- z75Z8{fFFz>%j%MxH{V6?0D6xDbVq550js8*LFk1~Tj7Y-x9s&G^^1+ey8u)ta~26> zOnbT$6mF2_4E8bfAB4i%Od-c}7y<mN(%&QiqnRP+DUM%Q8cQc~z<9@Va;|{NSnfnl z$<Z7FcB%deQWiC9I#jkg7#9%BVUU}2N<j(?gK=PJ(3NxwK~4vbCEYO=co3Xv`pnAd zv!<>(?|Su?U!PsQa(w2JdDS6jB)D<r)(0XL4}O00zu&!XB6#B_m^%o&CK+}e@}rg3 zhJ`6-@Ac<Z`}M7BTDz{E$}0JSZ7z#4Z7EwJub#90lZTf3tY<Mk^3)-W59XrSeyCu9 zRcPKj>j_PCW~dj{aN}$%Mc5$t3u@A#?fLK5{8!h^UH!}N{Pf^pVNlo+pcw<(5ApuN z`#L7GA6g%O;NW0k00t+xerP+!9`6x)O^P#Ag<T^J*?tdNKwMrKXVFny^DLf;OP*9r z^MqoQmg4{sz1($PEC+eO=jvVUi~716T<^iVcK@qG`ziLPk}Jmb8+w!c<}gJ=|DG+} zpyd{1j!Q7if!s2)fPXRSTir{vKtq>BgnAkJW{$xx^-X$M!QAJs-IL3m5D%zy6!Se- z+lToMl8-oAFJ_whU@}KExfC>xY`1mcD1r$W6bzhN$yowOjCGb=J8Kj<3-d33W7A?X z1EaJ2t+ifjx~^I7e<Ql6sUcce^X%a#Uw)Cb4m|ntZS3NHxuq_)*6Xxsi<e(8Nq!dQ zV~d*_{dicM4avJUR@XugH#9AZ^2cs_`N;v+`r^w^9)8w%q+f2v2IpOC(-tmW(TnCw zSnwy^uys3%8S-LYZk7&9CyM=|SUzU|!1jS;Elv|jmO#Q&d>{0M%+$vthhHMSu*Vbw z`~ZmoL;oY;eMD_$a38z_HB$W;$y6GMf!-rx27x;OO##Y|Ha&{<7zzVVz{L!vGANH$ zK?L&8KP=}26v_J${s~)xc{Fk^>nH8Ox-MN0Z};16*CZS44n6#W-N(Xpjo0c<yX}76 z*5e5~4%l47MMFENXkBx8QHz6$I=bCqJBsq$Lk?e?vXfi-T!BEq)o0;5l{TN_p@*E_ zHbv>_D&A;o)RY}co7ef!KU%&R!sw(RzyZLpn*t?{gmM2@ZGKi!-#B50&F0W+w(BeW zjw{AjxNV=X1uxJoAFHz3T#G{EQWeZ=A1-RQIxIEU>MMM%D_TYs_4I`%)P=dXFnG7e zT~)cIQjzDZ4ssq`Jx5lMt#W&CqdH7C;QxIgZp~@rv*}*A+ASabXPzSX75G=s!AT)A z@=)-IG=U?*4csNbMJhr(K(TJIF!dTGT%!@(lEZRZtB=u&O#oJbkSRRS*Nw0J+qo-l zcsS82+x>7Mk+~|vNFm{=4%%+G_v>sHyNS)>-S^&L3s!p)DjWgfr-)(!M{DBY8&;fa z9Q*F%n#Wng)*EjR-?Cr6%lPBlyFKSOSiyC|eMnPu85>?Im~5z+`{V6*y}f&PVfT(7 z&8=ui22&ctO-0jm+2vunwc&ivE@j2?RYz}MxM0p}!!$RRtPcOaO(RieuuALWa2vsC zm<z)8jh>Py5dG?by(8U5q7zGmmI?i92*is)7%{4WdYHUD!CR3V3n?sNM*teAT{*a@ z)fni{_D3p`jiF8@RXHxvm`0osXR>;Hc!K(q+pf#2HTAwsz#VJOO|+&!nLcw*;==x~ zUB5MC3=+a+zQnr86Dz{0=5*Wg+h<RBcKv~aRCS8y+7?d!{*<+=BiDYcIXqKsjb-W+ zzCupZ-4-vO_nAnIXWsl+>#WMDUbZT6!Tfk);f!Et-NL&bKdZT6L5Alt3o33~kg2?G zS5tEOo^2Oid;oAkG$oK5@U#vo(dJPY4WmGtFNTB01XxRVse<0AQOUiJhe^nl%8(B$ zZHP2f0{f7~D1PH5!70fkNr|fmhevdHxSC_`K*m>Jqpm$KciT^3@HD<U>5RoZ>Bhvk z%9PR>YD`u{FrKWxby4oX`e!H9*WbRpEnU}OukcTpvMyn~E5<Aq+M0Xu^38XDj&;i^ z>qJFNM#_-tS26F@%2}<k`SUzAk#m;L<6etf*9tjbqCOLARcD5qKXz?o_1Y=lpS-a3 zvI7@ic<szt)06SF%gzn9F1!sMh%{;q<HkL@TV1#=6r8az5uYz;fzQcVm3VQ`NT&oF zma}7n3#)_2zkO;j;qrA!KCkeqgB5}-ICLnIkbt)!@j`$_!J&|_lVGkGJ6X#$&*)#Z ze#g4G6}}!{#oTo}*01WH(fl<&i_iRe4#AUsXNapTKeOb9c`cr{g)^d|P;|z^Hc!jE z8<sr%wZbcW{MVnR;L5(!g<UST7n@-W<YI%AB}ym+(elVlV}i{KMf23jyhaw134(>; zVy0${=iqteMg%D$d?=b!F-wvU76S_MYBoh4@D~Qj+%YTIkvyr(V*N@i7;&1W>ahQ& z%<A3(#4%ja?YtEX;~*)oVkQ&JVj#H-gGGCF0qZjOrzB}sI@`SUz<OfGHnjm{JyEB( zW$HsRG<bmAw$@RRN{F_5=l8#VpUvJnZ_Xq(WiFrh`@K8voX3AJ%fHv%-Q%{hSIbGx zo&3wMwa=W{-ZpF2&}Z1a4?ntXU2oxTwkzeUpZEyBrku(o94#q1tVKK7(nE(yqy$Wv zDAE_i--wEYMVOXp903R3B2Pz*o);Ks5Y!$1IQUCrSsV8{Se4pmToFk<axv{?BHUv8 z#gFg-2I&Y)J+e3&p9ce4?eJEyw^EVozs)5xo}(ds8<UOp5DEnzO;b#Ru|zo8XkhAx z4UtQ>pHvQ{4j|T4I+yg0BbLWpG=L_|w5m2^r{yrW&la|t`bU2EvzS6MSmgaCgvi<L zheW}Wg)yl`eDYEQWyEtr4N1?D8d9_!a}6P+ltnkh3OWS_t;2n4hbRbB+ks91&o?2= zI#8Rq6jDwHg6x_@+sS!dz$_Czfi%yA+2S=2`B3Yg4is4%xmpZEF3+2gYcauE;N+a( zn>BD^^Dy#2vRGJ2_&e&@nczDtWO&$muq6vy8Crruf+SEfkZ(&-phSRD;)dDx=AV=f zE8jXP&A;bxZrMFAZ)wV;s;ACau+8Th!jx=VFk@<UD$}&(<$IPPidt-SFGt5%tf7nF z^Tdz(7d`!c|Bs%ie)>pm&iz}@Ry!K&7PfWFUpb4W!Iho0a(+kK!n(!|_3W+p&&fgS zB_x<oWl~I~BJV_gA|ZH+B%vW}lkNfj&=5TVw(Dt_t0R#vX2WG?+zkinwM=^(QdEfM z4C|nUd~MS`K#A#&bPAL<Y|2_NE@3c9H8T8;g^xuG8;{jp17=11%hO;Ui1DL^G%PA$ zdn^v8)#7lpTCEnJ)tXT)Hd(gWqMFSL-*D?r#f@FV(~S>acqj9i;_=8Y9ojzV@rG>e zlUA;o-gtKMtmuYx>cW>U^klBC9+y13F}r5vqy}qnLhtmje@Y+_^k@!U4>j9t&Yrn5 zD0oFEG+5#WzhZURE%?tkbS<Ll<Dt3LRatG+ZFUG=?b{rh5>iwTOy})fwpl7<E`Nd0 z2Db#g|Gnlct)k=X+s?V}oRwRw4HXrUh&^_eb<0XzxOH(yg_Z!-+T0jxP-Lsi1wYrW za5y#I34h<zt#T+V7x~T-Zp^89EO@uM-b*q0O6Sq>sA@>=($NXn0@D^B)|OJVvZB@c znWFRkOYq{UOqzOeko}7Y(APu;nPiQ5Qlh|RERS$~EMIGG;pP!ic<51!VX^1Vg_^a$ zp|m3)Y#GbL0x(+xP@{E^IH4zjLnk6m2li9)-^L;Ulo0O;Vi(F#*j>Rl8><H#8Z9C0 zsW<}H`#KRTSFloMS@9r{Ezx>H?Q53BV*<uN2H)(mJ8Tx4O|kkH1-kz*rTMZMUAw3E z-#oE0R1vCJQ#t9)NzY$)%TKrG?jHK&4d0ve>n>cIw=Ptfn3p?u(Zk=|+5P*;{=UGH z`8KX7Rs@ygFO9paswR3?1m68gAG1yfSA;qy&ik+bzNKNHF?`;*>QHUste>&KT~8Tb zJJC6=y85bl73YT=9&fzrr$@d#eah5D6Kw02hgXDcUau{rH9SIN!ssAk7(iPL9EILv zAWSL^s!7Br0Eb8)ksvP$qU%V4NaI6E1`i)IG!`Y{ejSE6M8F<gw|Z4oTefzwb?w5O z@!w}psF!Q(KE180weq|wm+q^#r($lo+BIp$B%2;&egD3j*SV^!zOL5pfUCMmshl+1 zKU<SoL)CeetzB)p&t4<fPdJ--a|_p67uROns#dLD7qkc9@#LR9sZwdGb_KdyyL{Fv zR~_H|?|m$&+fcWwT6V`$_Ie-WCMM1o{WR_3NAFFiIG-u~BR(Lje^v5|p>0N$N_!0X z{0x*lg0Nr(e3>yyG-1mM;aF#w`9CyRNe-%@&s=Z;`;6m^QA?x~DYpNdbBqn@iVu%p zBH&xlFtbRbOa58Fa1?ohNN);NFrwwBqzYn2M0*C0BZX`5<p%)r@UB;sm8ue#=VUT! zG-UHl?(*n<M@YW-zE1Ac^u~#ewty^GM5@9z`-Du(OjUL2KHkkHeOjB~YphIoChZG? z`za@R*m-u<(j2Xp1GeeCy5{7a_gyT95Xr#Vm}qv}LQz#at7Rg-s1n>a$&;vT^i9w{ zZG5Mj`*f$O&TPrZlgg<gf?wEMY0I&flg?d;JD?U<OpcUv)wFmiIC3Z~^xGjNEC?h> zJ0N51(3a1*i1mH)HRH$67{}hMZ+`RH%MaGZqs>j5_sv|?yJ*~XY~@Rq!?)kvzo|cY z`Gv~*wX<B&TaCiI|7+6&${v2>8r2^D!Zsx(kGpr-`3oL;&X!8te)!Vhq-&<x#M-*( zWKRA!&`3hY4YUElvy32B6sU?e-&XnG9yzz0CDVp+<fL@+mCx-{|6=@Y?%c!1&kI)m zSJv?Q3ona$q?4Z!^SYGQC@eQ<KmRAUH|(Bp(W3yhK20)y`G=~?e|DdWRQ<vDWifp1 z5uQ6?T(wZG@crbU-*qmPeHH3L_P~iBndUy|x{03zy^}=7+}&w&2K6ff0+M6H2#+Cr zCbe7&rc5b_poEo-8N?ryt%y}4=S#Nz6!RwE)le2K@T(Nc2JZwgLC%`PKH-La1W8$& z@ov+JV)$J_F`FO+L0^M1#4Z<txR>IO#e>=)(KqHNI-GtDmM2dC2RQaKDaTOn>fRBT zR9qe$box&~iNyO6V9AfrVmXquQ$wf?^zEUk$dqKdpoWM*!8Bq$3n?BV>tF@@)Zsf^ zN{rldz(T;sOlMlYnfra!cT^^L$oSe@m9TV*r~@pq<?1`Q6CpjK_eGM-@kJQ3-uSc1 z`hYJYGmZV{3txMUd4z|p@$G0J7_WSb%?j~E<sH>Nuk((pw-|3cQ56W(SN@FM#;U*Q zWXa0=z-%~Q``QaeoW_y_q&N}nP>U!<;1)`KDe0!*k^{negj>KWX)(hVmtmu_D6fiV zeDC=2y$t{Od#v2q_e87msYjFw*U)>e3Pt&XInthQdslVJuFh57Z+qApdZzeyv=pcq zYIgPx`?b^Sbrx<i@`BCGR<`ohncm(^;fYp(+iw%H_ZA7hCV&Rwtne=-UBE3ahV9P< zxowNm(FsCA(A)7C0gddHRIj2zR<Hnp(2R?WZIgSIR6z4h9G|Lw>X{b!IaSFv?@sZ~ zLG~PjX<g2^*4V?YlSvmx-!fq<<Nnnf)A8wTQyOa~w^lWUZ|S~v`Ie5=y=W@g9SkMp z7mOb_8t*{|2H43$Zj%Szu>*dmgMfo;Gq7GA@dPX`c@d2Wf`p()Flhu=a7jpIh+OuO zL>LhnNwS4tHZ`(*zh}xhvCHNau2loZ`x91t;)PGFn4sj*kt`ONk%h*8>G@OBe|*sb z>om)Ye@st3f9bQabEbGa^Dbi(*f<_&yJGFMX=|@&E4*#I+TKU2uCKjm)xOWZch>=? zM*RVz-4GDkIC0>v_ddIC71|F^M9^u5dZXZP;D!zYo{r;*HUo7+X9`VDN3x7JkDU-- z6T?78c;+z-V@F~j=xIE!_V1~&IU2s6anx2fzA(Yo=+J8ecia(eYP3ywp|QHwk@<Rq z!&b9rOsU4|JMO4%99@Rz#yrMD^q9SIr1GZd=&BoSj@rBKs<GQfm7#TB)amGuIjkQm zj}!)Z<a%QMni4k9V&(G4l8nui^@lJ(<>E*L)*|{1mV7j+M3S4*NEOn^LcS(ZbHN<A zraBwu&Z(I-Cl;Ig;<uL^E=nQU0zl%&FF&Njg(UK0hd(`~D29yL!mtE%Rq*Nc&W5`2 z(^5A+8DiI#3nK%QGRvB0OucJdFuP<)<)lI`n=KbY_GK<V&@;)DK+c+CiqfopZ`2)? z=XVB|_GIgC-#N1zLdcQv=>+D0-B1!z89~c%ns}@?Y^y|#l9HF;J5Cf$7^FM#df5D7 zyFr@;1SLftMUe1_Gz_{nMJ^(=5y!<**s?*eO-!-cAB)vb?{28(5KYf*a8)qBFBG)Q zxd0<p$hR&+NW%rDbW&M!-tw1TWa|Yta&SS$7@YFy7jM4zS;nTyaplnEA3w03T^oAx z#?-X&bq&t?>Ab>K6|4x`SS+(3$8!~}O>tS)_>yc0RChcTo;ss>S!PmTA?#>}#gi4W zbCzbaCci^5Co>DC%=+ZrYTu=y;G~`dmtS_Ed*;sD>$5#egPrqb45HU>g@FT&9dNIZ zbqm;1N+Us`4j|dm!SHB0Az#A17*#Qrv{>jD#0r_dK)^_1oYF4aq87OVkT2v)DTEAA zA0gKPQwVbuMoo2l+rlx>zyS?8ns(~RX{P<M5#U%M#M^RrIZU1jaL@faAaod<1)eO8 zPdju0kZ+Tpmr$Y$849gAmtq1DZ=?O4HhLU8A$04c9AZ(KU+V|}H_^J&$p467$}5ft zKuc>+E7=`j7>Ps5W(#84t?KC}y=9UqlBPL_*bCBqmMYG5$8?(Oj``Q!F=noXD0<2) zo&_Y%Eds7ZIRn_%lT2M%BTp4WTbOBrYK{KkpjrfM44cVE3wpFxP)0-q#XCESu6w!$ z4?{-L`RNLfQ@L*;*%BMJ!+!YfA@2Tuc<-%b8<0feFngaoDu>Oy5t<8T-<<p`55v9( zC8#`#8vF4S5{FYC>H{g-CZP!s{y^1=Mgc>R<6B!?G%*Cf!p?G!JyjKTn~gDSLZ<wF zv8imsO6DBfv~?(o))yNS8EGg=8)F>YMtHMgyVBUK&@Rz18mwWjRPkYhQSDMr?fLM_ zm}_jSE`@|-0}U+3>D0ayKB`@i%c5Dp2_Q1D?oCI`Kp0yn8p%e@CHyeOGz>R}d@;oo zu??rT>k_juG|Q)f0qNwJh85RmPQaO+{hU|eO1a+vBsCONkkoA*VSJ^e2L>HlDjk5G zk4Bz0g4rd`H-*)V!Vm=N9jSDixTQnv7Yxx3LAMaI51I)83GFB;o&KpbR9vW**N0Gd zX9t8@Aw**pCA4tL1qPa>>!`{Oq)-hBKq#!A7Sf6DB-tWrLgSFb-YhB!cZR|#;1v|% zco+%DO*%t*2O(TMhKD<WQuHv+2t*+SF0gkAQJ_R2V}TqLn;uI;(Stsa45pp}t&k*! zj)a*yP*taSFAOF(1Rr264U!Ki8jYpKV3ZJgGmT#L$kZBYG~FR|FRro>OankggwU?e z_Ecx6Q@k8lkJ{M-V`J8y!2>irXi;k?90=+==ux~)oH|H70u+G3>qyfW(K#h|5KE36 zO#<R3B6JKads-k@!z`pwz=cnnG94|UzMy4@sfa&5#sfs2$=w=Pp*QxpQgvP)h7dyL z4m;Ce(`>UL=%Jf4SynX*J|L=LbCvC~+hfzLvaT|BK(@5wtTSg+kt4FI>zrvS!X)|? z-5S=^L}gslbO%JKR_4&<dbjFStTw;ulC2J_Dm&a38}oWB%&J-}a@6Lp(yI`C({6Ke z7*RWIc%!OXWIbk6D!i(qFd0VGEfe6c<KcA{)urj^kj@pi%i_`YUZ5ikplq{htl7_D zW9@-)tB%%j+3R%1(Q=<dQ5+T?hIX9Em55}jXguO3s)Sqclx%ZBEQweuAy}?*?sNoX zwaQ|1cvW{)Px!fN*SQ)|Q4k?ZYkjJW@Pby35WxYihE&;!apKIXaXUmXjMV0JI^u3Y zA@4w>Ni-hA$n<8-t*abHfR(C@o~br&x9AqcKV;0U!ynA$Rf6~`EyHkIA)!{SkXEa; zvd(2C#J#fYbJ{$z!zz2ZJLEll<N?_)`=F<{dSq@>?3zwf#aYm;I;;p}%CVSK*==<x zPL8>QVW%SN{wfaHI!p`3pgZH+%*$*Jrdu@4;^!d-um~}a6ClMg^wtVlwNn&V)n<bo z0>%{z7)^mquBKQmT(v5i)h}x<RrfkA9>o&W5PcD2q=wv;s>SL=)Ki8JH)&y-ShquQ zs}&ea8#yQV@B%AFC=9r(WNwR#IoudC-HJ%d%%&hVBuBVTwNgQ>NQLVb3@C=%9YGVU z%%!Uyt0HTfLz7(?$;J2TjCs%nJBxZ1%$W<*$YN=QInI*h2E=o=TQ#*_)1vrbl8c_< zfu>4D4JtC;rUyMCu2ltWmV~A|HGFN!D=X-0o#MAJr_U~HK21?A6<n@%$C(vyqx%#n z3#=Sa3<#)37$2ttE%3{3`0sGV(&Vwly&mp{Q3mt@fJWJ>*`3g5SNUWZpI~NHmko*o z?zQU{Xhviog086+#qY7=O?G_w8<KB}j!>@{Rn@}m3N#dWE#`pRG<E3K#3%3`7-c%B zwH8b>L7I#gU|DfZ1r%3mSh;p?mGL2Q%!#elS?jHIhZMca0*Y3af+vI8O+r2rBu~N; zl`o<}V-o{;548^LK}q(B@a&*dDLkke3=4ZFW|CI?vxRfX$8!TroDZcx&ff@+|I<CD zGtK0i$Km5ezx;;!;PqCw*QCAKZ&5sX1$lw;Lu)_I?oQ9R{WGRuDPCi*vmYAVD6gCY zX&({YB=SJ}Oh1S!P)e}MO~ML~Eb+wu2vIHcaAUudIySFJMEV;!1%{LyawLSI2Q~H4 z(GznhOMgR<3Yd1gII`cJDMS3X3jX_g$ZW{Y6EVq4Vd6m7n%`M!Rj<dlll&q&94t!> zKYc(+m70`a;M+(D0U`p!N&X1?9eW4gkik$W=6HyiBilvH*yu4JB_?T&5TYuG_;3)Y z5nm>lv!cN+Yyu=hQXoB}Z%~sen?cOi54E`T0fh1l9(DB557ytiT9sg5YQ#*D$^dnG z07EcHUjcy3o+J(ftErzQ-6O0Jt=Pz5{ASJxNfgMl2D~CkM(9f*<WxhfBkbo)$vDXs ztU}^I{30F{cU9SVgk5|;It?O6d~D}_;}PSL`)PnkD+P_z{rC#mBlr6w4o3sJfEZWa zT3o_I;ww~ne2{@6Xvx1h{c|<xF;7tdE%L>sn#H?C33|8c7jOt4haAS;3kmroNQ0J1 zE75gf+m-Q<krEgh5JINH9?NF*7odw$$I_ReQ3|d`Wb-2oaPcfJmf%aCxa{_&n{Ut- z?3gm6S5-!TGTPR=`1U(*U)*aeelmK<jB6*KTeL8h<C~Y>e%TXC)ZQ6Wb}Z0tFbxPf zpm50|wx+2$oUFd9;5x(SrPWqpcWTrYzcO8TY|)bI)opiGC&SH6Y=gK-;75L5_iLMB zrx}O0#pM_UVp+fn*MQ5z)V9cEYAk|$fO09`1XWnP)>$&Kk;5I5>B(;5nKYh7iozQR zUwz0~h##(H>a)>TU_x3W$LxN+tHE6van#E3=#i?%hUmU%VS4mPv>{!+FB*NNs&Q;7 z`Q~%>E!%P3vLnmRKmXjFJC?t)d`upn2}JENxz-V>bT@SAeml~zb^T#gWN(!J0f}hU z-e?+ys%l3UD!h4g+1_R6{BYTh>(4#^eAGNTOX~u-D+k<Fg)tJGKU4<7SQKbfp}vtU z316AYz4_RQJkaI6TR9^1J<8aW+5H>#H{S9z%RTlc91?f^vLot7@V;m7?b*L!!L*tm zfp@$H`hF+s4r3M&F<q>%PT_z-3!dbvkaDRkj@aSQlLXbjcFo#wBDY~y7yB#Lk7@S- z0l)FKag_gW<7gmv{slMRe1Tla?lW<;v1O*QjD4;)$?h|@Bt=&wCS+`ckQYg-qz%#z z>2~RE+@iO^QU<ZpNybR48*3cIIcQMIh_5xEw`3U$s+BGg`PxD1UO{b>p>1)}fh<(e zxhWFXVW)v^2edThT)-nRXGXLVR6;f54^O3`r6d9$)(5PU-YOpy{5ZRUorub6P0s1@ zx(bV~v?!p7*Dl-jz@6u=u<L7=?%KO-rq#J~r_(xf+1_1C*Xn9x^Eta8*tKk}j*^xu z`4?SYk26=J%Fz?6T3VN^x@3OZJhd!oZAs6+WR-bhuKu{|?1=1AK_~sJpAQ0K4p>3+ zxs-_9pDX<B3*64lO)_F!9Z1xBvLN|x>s8pq2@CJZEMK(z`o4QJ%WIw1dGoB!+U1#h z`=(rxK6`oly$dHyWJ)i)&7x;L^@+fqrd@4Q5_Bj`Y1`G55C=Xm*`5ek#z$li$RhS% zF`msDOSbe|pz8K05hI^v2lmL=G_VN)e@Vb!wTR}Bgk=c6%D@D^E#hVqLE}>y&`}FS z+|h<u8HnZRr%i;QSL`Lj8BO4S(h3y@>1zs%KBqw5`ZK$8#!p!@wpbkhopl>I^3>;2 zgZy(dso;X?lFwqr?>69J)M0$3;itw=`M(%HH9n2+&kc}!Hohh!HS`btP05)#KpR7( z^<C->>J6j=A@3uAn<;oSosLA_6v0s#5<;@#gJ_Uv3a6w|<<%P=-FC+%Lx0`!#$%6O z!!NW=^*C*XC(gcf!`?pGGHq#g`Lx2<B6ZcNO7<{}svS1t(rH&iQqN~y^6_ntULsqr z`P5^-+ERGJ=I~6l@rxGj-*9=~&|jx5&n}(DXH}%CV^zkbxYuK24@07VH7Z+6dw9`S zN5<NnD9tjzkHKIIhk&Kv0EY=0eBGv~K8Af<Nt9svaFPf8uo4aP6(%YzCrj`L$>jnz z<M*}+Zc{6l!*I)(CIo;S4wp<{FfV@Ba{!;sU=`5@B823eYod)++5#oV_!AP%C?-iN z)A0C*FfUyVD(Y;A8h?oPi#aLv37)HE+9rXD$W3EJ-3*%m=>LbUVuXCPsM{jV7AP8u zE=_$iwLfMw=?}|~j+0jkA*bdD%^ep<O6Nt24(xZQOVZ*vnFp<zl}sI58eX8FXi6Sn zzTyrIx%jBom9%hUub&!~nH(dEf9lb4ZQF5EtvLE(d4X5NW9)u$Dh$9V&YVm6H)F4` zk;v4T7WBzY>t6jUEW)~_K49%Dq#J+^#Hta(*G#*fhV&r=$%yy}6!s&3kOcYU7DR{_ zatN_eLArsDLXGJ>+?FzJ?L=*AdK#9VWAC3b2sdt8vY~g<#7Wi7mq#oU6MoNh&jz;e zqPA{s?AONk_KvTvY^gt|;-bm(E}6M>7Q0#fqd5*f7sVhxo-@9%k#S4YoI5wDZ<pUG zAFbt!SM{EMR&_LM>9Wme^f8_}aQ-!p`8@kr!q>LEy?I=?vTE{_wn@w8v@UDutn4<v zVGgLv=a;X&_~OPV8XVqa-_6Dq#*M=_#*FKTKE(}v(>j4mi^iHJ*e0=uk;#u4E0^3s z+%O_3Zfw9r*xT?c$B6<U2|0cR^&>n=h;Ghwk|2zJL0Dp|1QttagJcKzfv^T---?DO z-2O49v~KIY%4T<|j^(b_%=tU7o;jnp_ouVgPfou5|M2!6fNhm$+pwN9wD-2;Az7B> zc*aAv;}s=whBKX=kdT;6XFxUqG7w2vDTNRqP)1`Y6ey%nHgD6`ZGqCVDRk1-w3Lt1 zGCC+Uu};40evV|zP6E8||NbAuXX%V*-p@U+o86`x<r^KH($(3uYwPT5#@O^EH?FZ2 z+T=)Od3#G|a@vf_>e<BtAjnh?L#s0xsXTAV<Ecws=8{;~u2yFdGUZK8OIn&2bxxSj z?yk!BpVGt=n^rg0M5;zRJ-$-AS#Py$99<ZTRtUvYWBM`C5|1|+Xl?75*I58QB}*4p zlGVutjaLH}eYH-tjXIwP)rMgNequgXPHoj1liv-R44`|Bb<m*kpc>v(bibGIce5== z>O?M5#A8su#Xv1GI_lbn(NVo<3AWZBC|)pUdtp-{6Izq4$OFWz+R8}VqQyN6o61K! zN*o@Y4KlZ@xO|mWnD^53iy-S)#yhn(QE%0Hklk+Tv<>GUzIVsY);6!*ktZ*3T8C1Q z%V9xS#1Kyb8Q+>T81k$aTH@M2EAQ=|*%GeKcZN&yo0>aspS9wK1uYXi5hwx{7@@_8 zS#*9gGihxBU8%{XT>0bkr&o<@9uo>zRZp9~v+E8v<9J@liGA6=fh#=u!)Ul4he|66 z1z@>`a%WzrISR@-qVA3n=Of$ZfBSso_lEm3A}SV<>}oP+?pd63Jp31B*nPu)8-DhA zcjkVJ#N9p;WaT78*FKs@v|-l{9x6kJ;vnRpGv{i~;hAs9c^R9To1K&BaPZV^89WCU z<beqE7<Gh58)qflZ<+)ja_TH%Q6EtX7zxg@m%hoO8-P+)<~(r%c7x}fPFYL)6ECb- zQCNsSw)>f9T3hia{yuXh{q@X&_+9?&n+^0V9&Mm!ozGp*pDSFU4Djb#pGhyvToDR0 z2N-rzCif@t|8|XEGh;|w#0X27L_8jZNWppl5|UyOS~B5LO<OQzs^AAkrX4=Q6t9v| zO9(0M60f|-QeU?ier%9c7kM^a@3Mx?agjVENRmy8adX(}(nH*5a0azJ=NcP?`a;qK zVyaI))HxbFZ%Kc<XF9G(eFGYs&kDsMBYz3{gL=$h^<g%%q`tvh9W2I60)5~KP(R3P z8NO^P&Qu%&5MJo)$^1=ewcr7Wa1oFxZiFBL4`K!i4jM+O>G*mHTIPeIlkg76J4{QK zxYssqXmJ@T-Rs*f{(jHSKVG};iA$H1cg-l&1NT7dsC(`HoA1ARL)%oVK8pCk_62z> z9n#B6Hlz7$ZqW&yJGuBf@iA9_d}QnMdz-uWTrr{N>mhSUHyV2VwsUU&_1*iw_2I&{ z$d1KDwd1$W@2pXlP1>-8?fwh*0n4o$kS+%K{%q}>YGSQS<>)GG2%l3qZkk2iCGKFI zE}!o+RCw04KK|!PyPjCz^Z1@~%4f~6cqF5&b=1Cc?@jk!xxSSu=S|eK&G)bHJDw!| zkH;#26TD<m@k8+@7XRbCJ1*`V)4l8R@oR1m$wq61!{=&WbmYyuF1zn<3tNkKEG()S zw`J~>8fC?*TUG86y+m?Nircn)kZR^~TF7N>SmD9KASBaQs1vD!$Si~2D#XkJKnM5~ zT7#&w$Y???I^=<ib`Vv@Cysoukpx&Gq%^1-$<T^zJ7$lXHKn3<_S|x}NhmXxSn>>p zspDG`U6EvKVs>QxBIVQhx2(Nvnb%_}eP~Ygm}u+F8L`%j*N-o4ZZ0jVs3@weWf!JW zN&I7}T<(~)Pw#ZaIx4C<A~3!b=?ZLx-Xg)#I&1#M`nCn<Y<@YJJh1TGU1C9AMXkB6 zU{PK9#EL?5QCrWrn%VW`l@+66Rh?C>v+5MM2BeVhVFa@+X+mhPnP7ECL+<DXH;C3M z#GvMxu4xISJd088<4L2MPDvot!E8qP)Z%0qQ%4KdUTQX%+H6`9(rEw{3ak#ThPF%8 zCF+DfB$u3%96d#O|LB1~kBKgxx}P~hMV>0}jW0|YJLBh@*<A<sPn}*faZ=6USXUrX zJa&DuY<6C?yS#02L-U3ujaFOSJ;pvkw1*Nso8~r5+OkL7@aCKA-gsl3@J`9Z30<j~ z=ghri+uZKf$+Hhu&2g3`N0rn_KfH0ytqtRoi^g7a&XjGFTaxYJ;FvYdSL~S+54WtY zTDx{m{lLwE`ep5Tqmk6G$~;;StR+q7woKa4QXp>J_}kxZ{58pFTz8{E2E%;##*(zm zQ=>v9MFCAEaNfoc!wAEOVh9r=Dn}tgNQ~7ma@C^<{nXYQXOvk;_gXe%?~%PT%G8}u zw*JV;6wxLrb>w}hp+U=H0Ufq1)y?{@?uxpV{&%lAw0q{v-G|hjQij~kctGJ>F?ljY zk5En`5HZj&mPBT(6rx(-AE?H(skjtCR#KAi0Kg^|Ktd+*9DeMAXMa7BKmIH#E)tF# zp5;PL24#UjP6qG=els?V`;*WaUZ*~r)TD%z#J@|^g=BL6Fpw}1bcBzpACi)}@8QXa zQD!`wRG%G;BI1Y(LXwvm&Kr1|LVdD@2TEg7ga0@mJ{ZRXynNtNhv5Sd#THudkv)O= zkVdM6^O0`08!n=`Jb{!t*$ea?srzKgCA~D{Sh|e!uzkQDr*?rRZ+NRhDkRZ#u$_2$ zhl)9(*?yDL5@%>b$e*xIXui1bSni9c9nglz46T;&3;GWIuC`~k?>LVR8BwDN5W?{g zvGe*6pDeTp+&>`NK=5Q5xbh%U7b@Nu`Nk4Sh4MiMy8#&!D#oz&SB{x{VI5<27fv4Y zEjDFL`HD{Es-?zp<!u0^XTFBE@^Qu`%D0N!FPJ++?i;sUY#w-**fKFt6Z`kdvg(?e z>atzGkFy1{4%I0qle+4H5~s7Ipjwywz+ZO5*qJ@cc%MHEn!gc8Ht<m>F+v0=#~`Oy zaLpr4703}$C`Z_7hx?2tLYeEl>|Esuww$e<C(K#3_M5Au>y#&FFBm)DV^W@kXv8{U z4V=7o>;tcg*A0ZlKd{=)6)QTYo_F5B@6yi;&UHH{))m&Jf61<6ACDe=C^WjM=uerp zÄ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 V*eE<O3LN-DOyYv>M;|ho{trTA6=?tf literal 0 HcmV?d00001 diff --git a/latest/_static/fonts/fontawesome-webfont.woff b/latest/_static/fonts/fontawesome-webfont.woff new file mode 100644 index 0000000000000000000000000000000000000000..628b6a52a87e62c6f22426e17c01f6a303aa194e GIT binary patch literal 65452 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 q%u^)w#YX9ZIvhtu?9Cy6YRi6f6G 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 literal 0 HcmV?d00001 diff --git a/latest/_static/images/datastore-logo.png b/latest/_static/images/datastore-logo.png deleted file mode 100644 index a0fc0a0a0e9a42e12e8e6eca261c11cf0361bbc0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10705 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 diff --git a/latest/_static/images/icon-arrow-bullet.svg b/latest/_static/images/icon-arrow-bullet.svg deleted file mode 100644 index dd9acb566eb8..000000000000 --- a/latest/_static/images/icon-arrow-bullet.svg +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="10px" height="10px" viewBox="1 -0.5 10 10" enable-background="new 1 -0.5 10 10" xml:space="preserve"> -<polygon fill="#020202" points="5.745,4.594 2.708,7.632 4.576,9.5 9.48,4.594 4.387,-0.5 2.52,1.369 "/> -</svg> diff --git a/latest/_static/images/icon-dropdown-faq.svg b/latest/_static/images/icon-dropdown-faq.svg deleted file mode 100644 index 786bcdc7d131..000000000000 --- a/latest/_static/images/icon-dropdown-faq.svg +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="12px" height="9px" viewBox="0 0 12 9" enable-background="new 0 0 12 9" xml:space="preserve"> -<polygon fill="#4285F4" points="5.887,4.194 2.242,0.549 0,2.791 5.887,8.677 12,2.564 9.758,0.323 "/> -</svg> diff --git a/latest/_static/images/icon-dropdown.svg b/latest/_static/images/icon-dropdown.svg deleted file mode 100644 index 3642565ff6b5..000000000000 --- a/latest/_static/images/icon-dropdown.svg +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="12px" height="9px" viewBox="0 0 12 9" enable-background="new 0 0 12 9" xml:space="preserve"> -<polygon fill="#FFFFFF" points="5.887,4.194 2.242,0.549 0,2.791 5.887,8.677 12,2.564 9.758,0.323 "/> -</svg> diff --git a/latest/_static/images/icon-lang-dotnet.svg b/latest/_static/images/icon-lang-dotnet.svg deleted file mode 100644 index 490a7f7101c1..000000000000 --- a/latest/_static/images/icon-lang-dotnet.svg +++ /dev/null @@ -1,18 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<svg version="1.1" id="_x2E_NET_logo" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" - y="0px" width="24px" height="24px" viewBox="0 0 24 24" style="enable-background:new 0 0 24 24;" xml:space="preserve"> -<style type="text/css"> - .st0{fill:#FFFFFF;} -</style> -<g> - <path class="st0" d="M3.8,15.1c-0.2,0-0.3-0.1-0.4-0.2c-0.1-0.1-0.2-0.3-0.2-0.4c0-0.2,0.1-0.3,0.2-0.4s0.3-0.2,0.4-0.2 - c0.2,0,0.3,0.1,0.5,0.2c0.1,0.1,0.2,0.3,0.2,0.4c0,0.2-0.1,0.3-0.2,0.4C4.1,15.1,4,15.1,3.8,15.1z"/> - <path class="st0" d="M10.9,15H9.8l-3-4.6c-0.1-0.1-0.1-0.2-0.2-0.4h0c0,0.1,0,0.4,0,0.9V15h-1V8.7h1.2l2.9,4.5 - c0.1,0.2,0.2,0.3,0.2,0.4h0c0-0.2,0-0.5,0-0.8V8.7h1V15z"/> - <path class="st0" d="M16,15h-3.5V8.7h3.4v0.9h-2.4v1.8h2.2v0.9h-2.2v1.9H16V15z"/> - <path class="st0" d="M21.2,9.6h-1.8V15h-1V9.6h-1.8V8.7h4.7V9.6z"/> -</g> -<g> - <path class="st0" d="M23,1v22H1V1H23 M24,0H0v24h24V0L24,0z"/> -</g> -</svg> diff --git a/latest/_static/images/icon-lang-java-duke.svg b/latest/_static/images/icon-lang-java-duke.svg deleted file mode 100644 index e91633e9cc08..000000000000 --- a/latest/_static/images/icon-lang-java-duke.svg +++ /dev/null @@ -1,49 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 19.1.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="24px" height="24px" viewBox="0 0 24 24" enable-background="new 0 0 24 24;" xml:space="preserve"> -<style type="text/css"> - .st0{fill:#FFFFFF;} - .st1{fill:none;} -</style> -<g> - <g> - <path class="st0" d="M15,0c0.2,0,0.4,0,0.5,0C15.8,0.1,16,0.3,16,0.5c0.1,0.4,0.2,0.8,0.3,1.2c0.1,0.3,0.1,0.6,0.4,0.9 - c0.1-0.4,0.2-0.8,0.4-1.2c0.2-0.4,0.4-0.7,0.9-0.8c0.4-0.1,0.7,0.1,0.7,0.6c0,0.2-0.1,0.5-0.2,0.7c-0.3,0.6-0.4,1.3-0.2,2 - c0.1,0.5,0.2,1,0.2,1.6c-0.1,0.4-0.3,0.7-0.6,1c-0.1,0.1-0.3,0.2-0.4,0.4c-0.2,0.3-0.3,0.6-0.3,0.9c0,0.6,0,1.1,0,1.7 - c0,0.3-0.1,0.6-0.3,0.9c-0.3,0.4-0.4,0.9-0.5,1.4c0,0.5,0.1,1.1,0.3,1.6c0.3,0.6,0.5,1.3,0.7,1.9c0.4,1.1,0.6,2.3,0.7,3.5 - c0.1,0.6,0.1,1.2,0.1,1.8c0,0.4,0,0.8-0.1,1.2c0,0.5-0.1,1-0.3,1.4c-0.1,0.3-0.2,0.5-0.5,0.7c-0.2,0.1-0.4,0.2-0.7,0.3 - c-0.3,0-0.6,0-0.9-0.3c-0.2-0.3-0.4-0.5-0.6-0.8c-0.4-0.5-0.7-1.1-1.2-1.5c-0.5-0.5-1.1-0.7-1.8-0.6c-0.5,0.1-1,0.3-1.4,0.6 - c-0.7,0.5-1.3,1-1.9,1.5c-0.4,0.3-0.8,0.6-1.2,0.7c-0.4,0.1-0.8,0-0.9-0.5c-0.1-0.4-0.1-0.7-0.1-1.1c0-0.3,0-0.7,0-1 - c-0.1,0-0.2,0.1-0.3,0.1c-0.4,0-0.7-0.1-0.9-0.5c0-0.1,0-0.3,0-0.4c0-0.1,0.1-0.1,0.1-0.2c0.2-0.3,0.4-0.6,0.6-0.9 - c0.4-0.5,0.5-1.1,0.4-1.7c-0.1-0.3-0.2-0.7-0.3-1c-0.1-0.4-0.1-0.8,0-1.2s0.3-0.7,0.6-1c0.5-0.6,0.8-1.2,1.1-1.9 - c0.3-0.8,0.3-1.6,0.4-2.5c0-0.4,0.1-0.9,0.1-1.3c0-0.5,0.1-1.1,0.1-1.6c0-1.1,0-2.2,0-3.3c0-0.2,0-0.3-0.1-0.5 - c0-0.2-0.1-0.4-0.1-0.6c0.1,0,0.1,0,0.1,0.1C8.9,3.1,9.5,3.5,10,3.9c0.5,0.4,0.9,0.9,1.4,1.4c0.4,0.4,0.7,0.8,1.1,1.2 - c0.4,0.5,0.8,0.9,1.1,1.4c0.5,0.6,0.9,1.3,1.3,2c0.2,0.3,0.4,0.4,0.7,0.3c0.4-0.1,0.8-0.3,0.9-0.8c0.2-0.7,0.1-1.3-0.1-2 - c-0.1-0.2-0.2-0.3-0.4-0.3c-0.4,0-0.7-0.2-1-0.4c-0.3-0.2-0.6-0.3-1-0.2c-0.1,0-0.3,0.1-0.5,0.1c-0.1,0-0.3,0-0.4,0 - c-0.3-0.2-0.4-0.7-0.1-1c0.2-0.2,0.4-0.3,0.6-0.4c0.2-0.1,0.4-0.1,0.6-0.2c-0.2-0.2-0.3-0.4-0.5-0.6c-0.5-0.6-0.8-1.3-1-2.1 - c-0.1-0.5-0.1-0.9,0.3-1.1C13.5,1,13.8,1,14,1.4c0.2,0.3,0.3,0.7,0.5,1.1c0.1,0.2,0.3,0.4,0.4,0.5c0,0,0,0,0.1,0 - c0-0.2-0.1-0.4-0.1-0.5c-0.1-0.5-0.2-0.9-0.2-1.4c0-0.1,0-0.3,0-0.4C14.7,0.3,14.8,0.1,15,0z M13.6,9.6c0,0.2,0.1,0.5,0.1,0.7 - c0,0.4-0.1,0.9-0.3,1.3c-0.4,0.7-1,1.1-1.7,1.3c-0.4,0.1-0.7,0.1-1.1,0.1c-0.6-0.1-1-0.3-1.4-0.8C9.1,12.1,9,12,8.9,12 - c-0.1,0.1-0.1,0.1-0.2,0.2c-0.2,0.7-0.3,1.4-0.5,2.2c-0.1,0.7-0.3,1.4-0.4,2.2c-0.1,0.5-0.2,1.1-0.3,1.6c-0.1,0.5-0.2,0.9-0.2,1.4 - c-0.1,0.4-0.1,0.8-0.1,1.3c-0.1,0.5-0.1,1.1,0,1.6c0.1,0.4,0.2,0.5,0.6,0.3c0.3-0.2,0.6-0.4,0.9-0.6c0.4-0.3,0.8-0.7,1.1-1 - c0.7-0.5,1.4-1,2.3-1.1c0.4,0,0.8,0,1.2,0.1c0.7,0.3,1.3,0.8,1.7,1.4c0.4,0.5,0.7,1,1,1.5c0.1,0.1,0.2,0.2,0.3,0.2 - c0.4,0.1,0.6,0,0.8-0.4c0.1-0.2,0.1-0.3,0.1-0.5c0.1-0.7,0.1-1.4,0.2-2c0-0.7,0-1.3-0.1-2c-0.1-0.5-0.2-1.1-0.3-1.6 - c-0.2-0.7-0.4-1.3-0.6-2c-0.3-0.9-0.7-1.8-1.1-2.7c-0.4-0.8-0.9-1.6-1.3-2.4c-0.1-0.2-0.2-0.2-0.4-0.1C13.7,9.5,13.6,9.6,13.6,9.6 - z M11.4,8.8c-0.1,0-0.2,0-0.4,0c-0.5,0.1-0.9,0.3-1.3,0.6C9.3,9.8,9,10.3,9.1,10.9c0.1,0.5,0.3,0.9,0.7,1.1c0.5,0.3,1,0.4,1.5,0.3 - c0.4-0.1,0.8-0.2,1.2-0.5c0.5-0.5,0.7-1,0.6-1.7c0-0.4-0.2-0.7-0.4-0.9C12.3,8.9,11.9,8.7,11.4,8.8z M7,17.1c0-0.1,0-0.2,0-0.2 - c0.1-0.6,0.2-1.2,0.3-1.8c0-0.1,0.1-0.3,0-0.4C6.8,15.2,6.4,16,7,17.1z"/> - <path class="st1" d="M13.6,9.6c0.1,0,0.1,0,0.2,0c0.1,0,0.3,0,0.4,0.1c0.4,0.8,0.9,1.6,1.3,2.4c0.4,0.9,0.8,1.8,1.1,2.7 - c0.2,0.6,0.4,1.3,0.6,2c0.1,0.5,0.2,1.1,0.3,1.6c0.1,0.7,0.1,1.3,0.1,2c0,0.7-0.1,1.4-0.2,2c0,0.2-0.1,0.4-0.1,0.5 - c-0.1,0.3-0.4,0.5-0.8,0.4c-0.1,0-0.2-0.1-0.3-0.2c-0.4-0.5-0.7-1-1-1.5c-0.5-0.6-1-1.1-1.7-1.4c-0.4-0.1-0.8-0.2-1.2-0.1 - c-0.9,0.1-1.6,0.5-2.3,1.1c-0.4,0.3-0.8,0.7-1.1,1c-0.3,0.2-0.6,0.4-0.9,0.6c-0.4,0.2-0.5,0.1-0.6-0.3c-0.1-0.5,0-1.1,0-1.6 - c0.1-0.4,0.1-0.8,0.1-1.3c0.1-0.5,0.1-0.9,0.2-1.4c0.1-0.5,0.2-1.1,0.3-1.6c0.1-0.7,0.3-1.4,0.4-2.2s0.3-1.4,0.5-2.2 - c0-0.1,0.1-0.1,0.2-0.2c0.1,0,0.1,0.1,0.2,0.1c0.4,0.4,0.9,0.7,1.4,0.8c0.4,0.1,0.8,0,1.1-0.1c0.7-0.2,1.3-0.6,1.7-1.3 - c0.2-0.4,0.3-0.8,0.3-1.3C13.7,10,13.6,9.8,13.6,9.6z"/> - <path class="st1" d="M9.9,10c0.2,0,0.5-0.2,0.6-0.4c0-0.1,0-0.2-0.1-0.2c-0.2,0-0.5,0.2-0.5,0.4C9.7,9.9,9.7,10,9.9,10z"/> - <path class="st1" d="M7,17.1c-0.6-1.2-0.3-1.9,0.3-2.5c0.1,0.1,0.1,0.3,0,0.4c-0.1,0.6-0.2,1.2-0.3,1.8C7.1,17,7.1,17,7,17.1z"/> - <path class="st0" d="M9.9,10c-0.2,0-0.2-0.1-0.1-0.2c0.1-0.2,0.4-0.4,0.5-0.4c0.1,0,0.2,0.1,0.1,0.2C10.4,9.8,10,10,9.9,10z"/> - </g> -</g> -</svg> diff --git a/latest/_static/images/icon-lang-nodejs.svg b/latest/_static/images/icon-lang-nodejs.svg deleted file mode 100644 index 24a4addc3c57..000000000000 --- a/latest/_static/images/icon-lang-nodejs.svg +++ /dev/null @@ -1,16 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="24px" height="24px" viewBox="0 0 24 24" enable-background="new 0 0 24 24" xml:space="preserve"> -<g> - <polygon fill="#FFFFFF" points="12.518,17.611 17.118,14.957 17.121,9.467 12.425,12.176 "/> - <polygon fill="#FFFFFF" points="12.105,11.517 16.755,8.835 12.004,6.091 7.261,8.828 "/> - <polygon fill="#FFFFFF" points="6.986,14.945 11.785,17.609 11.695,12.245 6.895,9.472 "/> - <polygon fill="#FFFFFF" points="6.895,9.46 6.895,9.472 11.695,12.245 11.693,12.124 "/> - <path fill="#FFFFFF" d="M22.393,6.001L22.393,6.001L12.007,0h-0.001l0,0L1.611,5.996V6L1.604,6.005l0.008,0.439L1.607,17.996 - L11.998,24l0.303-0.175l0.021,0.011l0.139-0.104l9.932-5.729l0.004-12L22.393,6.001z M21.662,17.582l-9.014,5.199l-0.067-4.014 - H11.85l0.067,4.01l-9.388-5.211L2.349,6.847l3.535,2.042l0.497-0.65L2.715,6.203l9.291-5.359l9.293,5.369l-3.592,2.072l0.41,0.607 - l3.549-2.047L21.662,17.582z"/> -</g> -</svg> diff --git a/latest/_static/images/icon-lang-python.svg b/latest/_static/images/icon-lang-python.svg deleted file mode 100644 index bc4737703c35..000000000000 --- a/latest/_static/images/icon-lang-python.svg +++ /dev/null @@ -1,21 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="24px" height="24px" viewBox="0 0 24 24" enable-background="new 0 0 24 24" xml:space="preserve"> -<g id="Layer_7"> - <g> - <path id="path1948_1_" fill="#FFFFFF" d="M11.859,0C10.88,0.005,9.945,0.089,9.123,0.234C6.7,0.662,6.26,1.558,6.26,3.21v2.182 - h5.726V6.12H6.26H4.111c-1.664,0-3.121,1-3.576,2.903c-0.526,2.181-0.549,3.542,0,5.819c0.407,1.695,1.378,2.902,3.043,2.902 - h1.968v-2.616c0-1.89,1.635-3.557,3.577-3.557h5.719c1.592,0,2.862-1.31,2.862-2.909V3.21c0-1.551-1.31-2.717-2.862-2.977 - C13.857,0.07,12.837-0.004,11.859,0z M8.762,1.756c0.591,0,1.075,0.491,1.075,1.094c0,0.601-0.483,1.087-1.075,1.087 - c-0.594,0-1.074-0.486-1.074-1.087C7.688,2.247,8.168,1.756,8.762,1.756z"/> - <path id="path1950_1_" fill="#FFFFFF" d="M18.418,6.12v2.543c0,1.971-1.671,3.629-3.576,3.629H9.123 - c-1.566,0-2.863,1.341-2.863,2.91v5.452c0,1.551,1.349,2.463,2.863,2.908c1.812,0.533,3.55,0.631,5.719,0 - c1.441-0.416,2.862-1.256,2.862-2.908v-2.184h-5.718v-0.728h5.718h2.862c1.664,0,2.285-1.16,2.863-2.902 - c0.598-1.794,0.571-3.519,0-5.819c-0.412-1.657-1.197-2.903-2.863-2.903L18.418,6.12L18.418,6.12z M15.201,19.926 - c0.595,0,1.074,0.486,1.074,1.088c0,0.604-0.479,1.096-1.074,1.096c-0.59,0-1.073-0.491-1.073-1.096 - C14.128,20.412,14.611,19.926,15.201,19.926z"/> - </g> -</g> -</svg> diff --git a/latest/_static/images/icon-lang-ruby.svg b/latest/_static/images/icon-lang-ruby.svg deleted file mode 100644 index 5f4e5a25d893..000000000000 --- a/latest/_static/images/icon-lang-ruby.svg +++ /dev/null @@ -1,15 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 14.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 43363) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Ruby" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="24px" height="24px" viewBox="0 0 24 24" enable-background="new 0 0 24 24" xml:space="preserve"> -<path fill="#FFFFFF" d="M23.512,7.685l-3.188-3.967C20.324,3.718,17.938,0,12,0C6.062,0,3.676,3.718,3.676,3.718L0.488,7.685 - L0,9.503l0.492,1.834L12,24l11.508-12.663L24,9.503L23.512,7.685z M12,1.25c4.479,0,7.229,2.087,7.229,3.373 - c0,1.287-2.75,3.083-7.229,3.083c-4.479,0-7.229-1.796-7.229-3.083C4.771,3.337,7.521,1.25,12,1.25z M1.576,10.8L1.263,9.633 - L1.602,8.37L3.22,6.355l-1.23,4.901L1.576,10.8z M4.086,6.354c0.647,0.942,1.816,1.664,3.226,2.151l-4.464,2.776L4.086,6.354z - M2.978,12.35L7.6,9.475l-1.57,6.25L2.978,12.35z M8.403,9.753l2.878,6.263H6.83L8.403,9.753z M11.453,21.72L7,16.797h4.453V21.72z - M8.977,8.952C9.954,9.146,10.984,9.246,12,9.246c1.016,0,2.046-0.1,3.023-0.294L12,15.53L8.977,8.952z M12.547,21.72v-4.923H17 - L12.547,21.72z M12.719,16.016l2.878-6.263l1.573,6.263H12.719z M17.971,15.725l-1.57-6.25l4.621,2.875L17.971,15.725z - M16.688,8.505c1.41-0.487,2.58-1.209,3.227-2.151l1.238,4.927L16.688,8.505z M22.424,10.8l-0.414,0.456l-1.23-4.901l1.619,2.015 - l0.338,1.263L22.424,10.8z"/> -</svg> diff --git a/latest/_static/images/icon-link-github.svg b/latest/_static/images/icon-link-github.svg deleted file mode 100644 index 2404f8b0be06..000000000000 --- a/latest/_static/images/icon-link-github.svg +++ /dev/null @@ -1,19 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="16px" height="16px" viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> -<path fill="#010101" d="M2.231,7.326c-0.025,0,0.279,0.644,0.287,0.644c0.664,1.185,1.942,1.921,4.101,2.124 - c-0.308,0.23-0.679,0.666-0.729,1.17c-0.387,0.246-1.166,0.326-1.771,0.139C3.271,11.14,2.945,9.489,1.675,9.725 - C1.4,9.775,1.455,9.953,1.692,10.105c0.388,0.246,0.752,0.554,1.033,1.209c0.215,0.504,0.67,1.404,2.104,1.404 - c0.569,0,0.969-0.068,0.969-0.068s0.011,1.285,0.011,1.785c0,0.576-0.791,0.739-0.791,1.016c0,0.109,0.262,0.121,0.472,0.121 - c0.416,0,1.282-0.342,1.282-0.941c0-0.475,0.008-2.074,0.008-2.355c0-0.611,0.334-0.805,0.334-0.805s0.041,3.266-0.08,3.704 - c-0.143,0.515-0.398,0.441-0.398,0.671c0,0.342,1.041,0.085,1.387-0.666c0.268-0.582,0.15-3.788,0.15-3.788l0.285-0.007 - c0,0,0.016,1.468,0.006,2.139c-0.01,0.694-0.059,1.572,0.361,1.986c0.275,0.273,1.17,0.75,1.17,0.314c0-0.254-0.49-0.463-0.49-1.148 - v-3.161c0.391,0,0.332,1.039,0.332,1.039l0.029,1.931c0,0-0.087,0.703,0.773,0.998c0.305,0.104,0.953,0.133,0.984-0.043 - s-0.782-0.437-0.789-0.98c-0.006-0.332,0.015-0.527,0.015-1.971s-0.198-1.978-0.886-2.402c2.121-0.215,3.436-0.73,4.074-2.111 - c0.051,0.002,0.262-0.646,0.234-0.646c0.143-0.521,0.221-1.138,0.236-1.868c-0.004-1.982-0.969-2.683-1.154-3.012 - c0.273-1.5-0.045-2.182-0.193-2.416c-0.547-0.191-1.902,0.492-2.643,0.973c-1.207-0.348-3.758-0.313-4.715,0.09 - C4.038-0.146,3.104,0.043,3.104,0.043s-0.604,1.063-0.16,2.619C2.364,3.39,1.931,3.904,1.931,5.269 - C1.932,6.038,2.024,6.727,2.231,7.326z"/> -</svg> diff --git a/latest/_static/images/icon-link-package-manager.svg b/latest/_static/images/icon-link-package-manager.svg deleted file mode 100644 index 3a12655fe6f9..000000000000 --- a/latest/_static/images/icon-link-package-manager.svg +++ /dev/null @@ -1,19 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="16px" height="16px" viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> -<g> - <g> - <path d="M8,1.759l7,2v8.618l-7,1.869l-7-1.869V3.759L8,1.759 M8,0.719L0,3.005v10.14l8,2.137l8-2.137V3.005L8,0.719L8,0.719z"/> - </g> - <g> - <path d="M9,2.022l6,1.737v8.618l-6,1.603V2 M8,0.719v14.562l8-2.137V3.005L8,0.719L8,0.719z"/> - </g> - <g> - <g> - <path d="M8,1.759l6.051,1.729L8,5.102L1.949,3.488L8,1.759 M8,0.719L0,3.005v0.998l8,2.134l8-2.134V3.005L8,0.719L8,0.719z"/> - </g> - </g> -</g> -</svg> diff --git a/latest/_static/images/icon-link-stackoverflow.svg b/latest/_static/images/icon-link-stackoverflow.svg deleted file mode 100644 index e1a1f789a897..000000000000 --- a/latest/_static/images/icon-link-stackoverflow.svg +++ /dev/null @@ -1,16 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="16px" height="16px" viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> -<g> - <rect x="3.699" y="12.517" width="6.317" height="1.349"/> - <rect x="9.919" y="2.553" transform="matrix(-0.171 -0.9853 0.9853 -0.171 12.134 16.6649)" width="6.318" height="1.35"/> - <polygon points="10.045,12.128 3.754,11.549 3.878,10.205 10.168,10.785 "/> - <rect x="4.199" y="8.182" transform="matrix(-0.9657 -0.2596 0.2596 -0.9657 12.1634 19.3181)" width="6.317" height="1.349"/> - <polygon points="10.693,8.644 5.252,5.434 5.938,4.272 11.379,7.48 "/> - <polygon points="11.598,7.296 8.039,2.077 9.154,1.317 12.713,6.536 "/> - <polygon points="11.076,9.403 11.076,14.967 2.792,14.967 2.792,9.403 1.717,9.403 1.717,15.979 1.735,15.979 2.05,15.979 - 12.15,15.979 12.15,16 12.15,15.685 12.15,9.403 "/> -</g> -</svg> diff --git a/latest/_static/images/icon-menu.svg b/latest/_static/images/icon-menu.svg deleted file mode 100644 index 98d3e7073cde..000000000000 --- a/latest/_static/images/icon-menu.svg +++ /dev/null @@ -1,11 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="24px" height="19.524px" viewBox="0 0 24 19.524" enable-background="new 0 0 24 19.524" xml:space="preserve"> -<g> - <rect y="15.438" fill="#FFFFFF" width="24" height="4.063"/> - <rect fill="#FFFFFF" width="24" height="4.063"/> - <rect y="7.313" fill="#FFFFFF" width="24" height="4.063"/> -</g> -</svg> diff --git a/latest/_static/images/icon-table-check.svg b/latest/_static/images/icon-table-check.svg deleted file mode 100644 index 7934bef97f06..000000000000 --- a/latest/_static/images/icon-table-check.svg +++ /dev/null @@ -1,7 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="16px" height="16px" viewBox="0 0 16 16" enable-background="new 0 0 16 16" xml:space="preserve"> -<polygon fill="#24B25D" points="5.969,10.247 1.846,6.126 0,7.972 5.969,13.938 16,3.907 14.154,2.062 "/> -</svg> diff --git a/latest/_static/images/lang-bg.png b/latest/_static/images/lang-bg.png deleted file mode 100644 index 654e12af3418935fe10e84aac1b3134fdc4c4b4b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 966 zcmaJ=J#W)M7`Dn+s0ggk>EyyhVxR3KPOO+Hu@f2zM^PHoY}BzYiIv)C>`UWhg8_-( zfY_Ls7%DNqfRNY_5(_&UDwR-o&S{)7kXkz5d#C4l-p_m4ZaqwIZf!CQlWy+l9lD>; zbt|<&|BwHCzfQM1q~0UDctECRfS9U{`v^2$bBH>~v}aGhpfbZ;0#3I_dd4Hg!Y*gV z7%p;s%4V2yCGt&cj0otXq2sCS@An^A;Mgj=mp7o{YiQ)`%mcJLZ*{Ht*ecm<<pC&1 z3Keh>F+t=Wc%c%h>_S(ec6`mVU;!axl|2ipXS9Ka0|fFM%v!JjK|$aIDJRQv28d9A zJQR6B%nGt1i3)^Z`LWbnU=Ngz-dOsgCzTx$;wwBqold!_#NlAb3#C#i))2)kMP$R7 zN6aYeh1-dOjzTMNeBxja#ENDgPl(FWNY7Gm{gtd2F3Us<#z&^l3mlA7N`QuOG1PTe z=#X^KdA$D>4!biS@f{T6Nnp{&4Yp%fzM=)lBsl0|e2`SJJ;DTsBkTihHxKq4&&Jbm zfi?`K>4n7fEY#Fhmhw5rv6Y<M$QQMmBnkO~Ak=e3N!Lp-UoT1xSrFw?!qu@gagj$7 zu6@qUt>wmp;QG|FjsoWp*^L0ZV3DxmtdB)ltGDFZ>thkua(NmIAGh_NHYZnfc4Bii zwDhnVd*sns59m-IonHGHKZvGY?M6R-eXFJ!CiMx{PVi|4JgYeOGOzAldGhY^?X4T> n7gsfF1ak}X^Vj`_dGr29=J55#@$u1{RQ$4<^_Kp&w*UMu#(pT3 diff --git a/latest/_static/images/logo-full.svg b/latest/_static/images/logo-full.svg deleted file mode 100644 index 3b84037fccc6..000000000000 --- a/latest/_static/images/logo-full.svg +++ /dev/null @@ -1,112 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="300px" height="40px" viewBox="0 0 300 40" enable-background="new 0 0 300 40" xml:space="preserve"> -<g> - <path fill="#FFFFFF" d="M26.963,19.866c0-3.138-2.543-5.681-5.681-5.681c-3.138,0-5.681,2.543-5.681,5.681 - c0,3.136,2.543,5.681,5.681,5.681C24.419,25.547,26.963,23.002,26.963,19.866"/> - <path fill="#FFFFFF" d="M42.057,17.958l-4.921-8.522c-0.018-0.031-0.04-0.059-0.06-0.088L33.31,2.822 - c-0.701-1.214-1.972-1.893-3.28-1.895H12.535c-1.402,0-2.625,0.762-3.28,1.894l-4.919,8.523l0,0l4.372,7.572L14.722,8.5 - l20.773,0.001c0.654,0,1.289,0.339,1.64,0.946h-8.738l6.007,10.404l-6.57,11.377h-0.001l-3.818,6.614 - c-0.328,0.564-0.938,0.945-1.639,0.945l4.365-7.562H14.722l-6.05-10.479l0,0L8.16,19.864l0.001-0.001l-3.826-6.626 - c-0.325-0.564-0.35-1.28-0.004-1.884l-3.824,6.619c-0.701,1.214-0.653,2.654,0,3.789l8.747,15.15 - c0.701,1.213,1.972,1.894,3.28,1.894h9.841c0.072,0,0.142-0.007,0.211-0.015h7.441c1.402,0,2.626-0.763,3.281-1.894l8.747-15.149 - C42.757,20.532,42.709,19.091,42.057,17.958 M12.535,6.043c-0.628,0-1.137-0.509-1.137-1.138c0-0.628,0.509-1.137,1.137-1.137 - s1.138,0.509,1.138,1.137C13.673,5.534,13.164,6.043,12.535,6.043 M30.598,5.891c-0.544,0.314-1.24,0.127-1.553-0.416 - c-0.314-0.544-0.128-1.24,0.416-1.554s1.239-0.128,1.554,0.416C31.329,4.881,31.143,5.577,30.598,5.891 M4.772,20.625 - c-0.313,0.543-1.009,0.73-1.553,0.417c-0.544-0.313-0.729-1.01-0.417-1.554c0.314-0.544,1.009-0.73,1.554-0.417 - C4.9,19.385,5.087,20.081,4.772,20.625 M13.103,36.191c-0.544,0.313-1.24,0.127-1.554-0.416c-0.314-0.545-0.127-1.24,0.417-1.555 - c0.544-0.316,1.239-0.128,1.554,0.418C13.833,35.182,13.647,35.877,13.103,36.191 M30.028,36.344c-0.628,0-1.137-0.508-1.137-1.137 - c0-0.627,0.509-1.137,1.137-1.137c0.628,0,1.138,0.51,1.138,1.137C31.166,35.836,30.656,36.344,30.028,36.344 M39.761,20.625 - c-0.314,0.544-1.01,0.73-1.554,0.416s-0.73-1.009-0.416-1.553c0.313-0.544,1.009-0.73,1.553-0.417 - C39.889,19.386,40.075,20.082,39.761,20.625"/> - <path fill="#FFFFFF" d="M159.484,13.827c-2.064,0-3.689,0.661-4.877,1.982c-1.187,1.322-1.778,3.131-1.778,5.427 - c0,2.351,0.56,4.175,1.678,5.474c1.119,1.299,2.718,1.949,4.798,1.949c1.381,0,2.65-0.179,3.807-0.529v1.015 - c-1.088,0.383-2.447,0.573-4.076,0.573c-2.313,0-4.133-0.747-5.463-2.241c-1.327-1.494-1.992-3.58-1.992-6.261 - c0-1.675,0.316-3.15,0.952-4.426c0.634-1.276,1.546-2.262,2.735-2.956s2.573-1.042,4.149-1.042c1.606,0,3.044,0.301,4.313,0.901 - l-0.463,1.036C162.066,14.127,160.807,13.827,159.484,13.827"/> - <rect x="166.27" y="11.968" fill="#FFFFFF" width="1.115" height="17.524"/> - <path fill="#FFFFFF" d="M171.715,23.354c0,1.683,0.37,2.994,1.109,3.937c0.738,0.942,1.785,1.414,3.137,1.414 - s2.396-0.472,3.137-1.414c0.738-0.94,1.108-2.254,1.108-3.937c0-1.688-0.374-2.999-1.121-3.93 - c-0.747-0.931-1.796-1.396-3.147-1.396c-1.351,0-2.393,0.463-3.125,1.391C172.081,20.346,171.715,21.656,171.715,23.354 - M181.377,23.354c0,1.998-0.484,3.558-1.453,4.681c-0.968,1.123-2.304,1.684-4.009,1.684c-1.074,0-2.021-0.26-2.838-0.776 - c-0.818-0.518-1.444-1.262-1.88-2.23c-0.437-0.967-0.653-2.086-0.653-3.355c0-1.998,0.483-3.551,1.452-4.667 - c0.969-1.115,2.298-1.672,3.986-1.672c1.683,0,3.002,0.565,3.959,1.695S181.377,21.387,181.377,23.354"/> - <path fill="#FFFFFF" d="M185.505,17.25v7.928c0,1.232,0.259,2.127,0.776,2.688c0.518,0.559,1.32,0.838,2.41,0.838 - c1.455,0,2.527-0.367,3.215-1.104c0.688-0.735,1.029-1.934,1.029-3.592V17.25h1.104v12.24h-0.944l-0.203-1.688h-0.067 - c-0.796,1.275-2.212,1.914-4.245,1.914c-2.786,0-4.178-1.489-4.178-4.471V17.25H185.505z"/> - <path fill="#FFFFFF" d="M202.393,18.027c-1.338,0-2.342,0.47-3.014,1.408s-1.009,2.301-1.009,4.088 - c0,3.467,1.348,5.201,4.043,5.201c1.382,0,2.396-0.4,3.041-1.203c0.646-0.806,0.969-2.129,0.969-3.978v-0.19 - c0-1.894-0.317-3.252-0.952-4.083C204.836,18.442,203.811,18.027,202.393,18.027 M202.393,17.014c0.885,0,1.65,0.162,2.297,0.484 - c0.646,0.323,1.223,0.875,1.733,1.656h0.067c-0.045-0.946-0.067-1.874-0.067-2.782v-4.403h1.103v17.523h-0.73l-0.281-1.871h-0.09 - c-0.932,1.396-2.268,2.096-4.01,2.096c-1.688,0-2.98-0.525-3.873-1.576c-0.895-1.053-1.341-2.584-1.341-4.596 - c0-2.117,0.442-3.735,1.329-4.853C199.414,17.573,200.702,17.014,202.393,17.014"/> - <path fill="#FFFFFF" d="M218.598,21.697h2.262c1.854,0,3.195-0.305,4.021-0.918c0.825-0.611,1.238-1.604,1.238-2.979 - c0-1.269-0.391-2.209-1.171-2.821s-1.989-0.917-3.626-0.917h-2.725V21.697L218.598,21.697z M227.357,17.757 - c0,1.592-0.541,2.812-1.623,3.659c-1.08,0.85-2.611,1.273-4.594,1.273h-2.545v6.803h-1.147V13.027h4.03 - C225.396,13.027,227.357,14.604,227.357,17.757"/> - <rect x="230.426" y="11.968" fill="#FFFFFF" width="1.115" height="17.524"/> - <path fill="#FFFFFF" d="M238.338,28.703c1.307,0,2.337-0.373,3.092-1.121c0.754-0.746,1.131-1.785,1.131-3.113v-1.205l-2.14,0.09 - c-1.72,0.082-2.944,0.353-3.677,0.806c-0.732,0.455-1.098,1.161-1.098,2.123c0,0.766,0.233,1.36,0.703,1.784 - C236.818,28.49,237.48,28.703,238.338,28.703 M242.842,29.49l-0.281-1.936h-0.09c-0.615,0.788-1.248,1.346-1.896,1.672 - c-0.649,0.325-1.417,0.489-2.303,0.489c-1.203,0-2.138-0.309-2.806-0.924s-1.002-1.467-1.002-2.558c0-1.192,0.497-2.12,1.492-2.78 - c0.994-0.66,2.435-1.011,4.317-1.047l2.332-0.068v-0.812c0-1.163-0.236-2.042-0.709-2.634c-0.475-0.593-1.235-0.889-2.287-0.889 - c-1.133,0-2.309,0.315-3.524,0.946l-0.416-0.968c1.345-0.63,2.672-0.947,3.985-0.947c1.345,0,2.349,0.35,3.014,1.048 - c0.664,0.698,0.996,1.787,0.996,3.267v8.141H242.842z"/> - <path fill="#FFFFFF" d="M250.63,28.725c0.705,0,1.321-0.059,1.847-0.18v0.9c-0.541,0.182-1.164,0.271-1.869,0.271 - c-1.082,0-1.879-0.289-2.394-0.866c-0.515-0.578-0.771-1.486-0.771-2.728v-7.904h-1.813v-0.653l1.813-0.507l0.563-2.77h0.574v2.962 - h3.593v0.968h-3.593v7.748c0,0.938,0.165,1.634,0.495,2.082C249.404,28.5,249.924,28.725,250.63,28.725"/> - <path fill="#FFFFFF" d="M259.441,18.219h-2.883V29.49h-1.115V18.219h-2.274v-0.653l2.274-0.417v-0.946 - c0-1.501,0.275-2.603,0.828-3.305c0.552-0.702,1.453-1.053,2.709-1.053c0.675,0,1.351,0.102,2.025,0.304l-0.259,0.968 - c-0.601-0.188-1.198-0.281-1.791-0.281c-0.87,0-1.487,0.257-1.853,0.771c-0.364,0.515-0.547,1.35-0.547,2.506v1.138h2.883v0.968 - H259.441z"/> - <path fill="#FFFFFF" d="M262.037,23.354c0,1.683,0.37,2.994,1.109,3.937c0.738,0.942,1.785,1.414,3.137,1.414 - c1.351,0,2.396-0.472,3.136-1.414c0.739-0.94,1.108-2.254,1.108-3.937c0-1.688-0.373-2.999-1.119-3.93 - c-0.747-0.931-1.797-1.396-3.147-1.396c-1.352,0-2.394,0.463-3.125,1.391C262.402,20.346,262.037,21.656,262.037,23.354 - M271.699,23.354c0,1.998-0.483,3.558-1.452,4.681c-0.97,1.123-2.306,1.684-4.009,1.684c-1.074,0-2.021-0.26-2.838-0.776 - c-0.818-0.518-1.445-1.262-1.881-2.23c-0.437-0.967-0.653-2.086-0.653-3.355c0-1.998,0.483-3.551,1.452-4.667 - c0.97-1.115,2.298-1.672,3.986-1.672c1.682,0,3.002,0.565,3.959,1.695C271.22,19.842,271.699,21.387,271.699,23.354"/> - <path fill="#FFFFFF" d="M279.68,17.014c0.518,0,1.072,0.053,1.665,0.158l-0.214,1.07c-0.511-0.127-1.039-0.192-1.587-0.192 - c-1.044,0-1.899,0.443-2.567,1.329c-0.668,0.886-1.002,2.004-1.002,3.355v6.759h-1.115V17.25h0.945l0.113,2.207h0.078 - c0.503-0.901,1.04-1.534,1.609-1.897C278.177,17.196,278.868,17.014,279.68,17.014"/> - <path fill="#FFFFFF" d="M298.896,29.49v-8.029c0-1.192-0.232-2.063-0.697-2.612c-0.467-0.548-1.18-0.822-2.141-0.822 - c-1.254,0-2.182,0.345-2.781,1.036c-0.602,0.69-0.9,1.775-0.9,3.253v7.174h-1.138v-8.367c0-2.063-0.945-3.096-2.839-3.096 - c-1.282,0-2.219,0.374-2.803,1.121c-0.586,0.747-0.88,1.942-0.88,3.586v6.756h-1.114V17.25h0.924l0.236,1.678h0.067 - c0.338-0.608,0.817-1.079,1.44-1.414c0.623-0.333,1.311-0.501,2.062-0.501c1.929,0,3.168,0.725,3.716,2.174h0.047 - c0.396-0.698,0.932-1.235,1.604-1.61c0.671-0.375,1.436-0.563,2.292-0.563c1.336,0,2.338,0.357,3.006,1.07s1.003,1.847,1.003,3.4 - v8.007L298.896,29.49L298.896,29.49z"/> - <path fill="#FFFFFF" d="M117.465,24.746c0.694-0.701,0.757-1.672,0.757-2.219c0-2.181-1.305-5.579-3.809-5.579 - c-0.79,0-1.634,0.391-2.119,0.999c-0.514,0.638-0.667,1.453-0.667,2.246c0,2.032,1.181,5.407,3.784,5.407 - C116.16,25.6,116.979,25.234,117.465,24.746 M116.585,30.512c-0.239-0.027-0.392-0.027-0.69-0.027c-0.275,0-1.91,0.056-3.178,0.48 - c-0.666,0.246-2.602,0.979-2.602,3.129c0,2.152,2.093,3.707,5.327,3.707c2.895,0,4.44-1.402,4.44-3.281 - C119.882,32.971,118.886,32.158,116.585,30.512 M118.735,17.034c0.692,0.582,2.146,1.792,2.146,4.099 - c0,2.248-1.276,3.309-2.544,4.314c-0.388,0.396-0.843,0.816-0.843,1.488c0,0.666,0.455,1.026,0.786,1.301l1.089,0.85 - c1.329,1.123,2.541,2.15,2.541,4.252c0,2.848-2.754,5.734-7.955,5.734c-4.381,0-6.497-2.094-6.497-4.344 - c0-1.088,0.54-2.633,2.33-3.701c1.87-1.15,4.412-1.305,5.771-1.396c-0.419-0.545-0.911-1.123-0.911-2.063 - c0-0.514,0.156-0.82,0.307-1.182c-0.336,0.03-0.666,0.059-0.97,0.059c-3.205,0-5.016-2.4-5.016-4.766 - c0-1.401,0.639-2.943,1.935-4.064c1.72-1.432,3.777-1.674,5.411-1.674h6.228l-1.937,1.092L118.735,17.034L118.735,17.034z"/> - <path fill="#FFFFFF" d="M103.471,27.572c0.726-0.971,0.912-2.176,0.912-3.367c0-2.666-1.27-7.753-5.011-7.753 - c-1,0-1.996,0.39-2.722,1.029c-1.175,1.058-1.391,2.39-1.391,3.697c0,3.002,1.484,7.939,5.137,7.939 - C101.568,29.117,102.779,28.545,103.471,27.572 M99.699,30.025c-4.799,0-7.364-3.76-7.364-7.15c0-3.971,3.227-7.365,7.818-7.365 - c4.435,0,7.212,3.486,7.212,7.15C107.365,26.236,104.621,30.025,99.699,30.025"/> - <path fill="#FFFFFF" d="M87.112,27.572c0.729-0.971,0.904-2.176,0.904-3.367c0-2.666-1.264-7.753-5.011-7.753 - c-0.996,0-1.987,0.39-2.714,1.029c-1.177,1.058-1.389,2.39-1.389,3.697c0,3.002,1.478,7.939,5.128,7.939 - C85.21,29.117,86.419,28.545,87.112,27.572 M83.338,30.025c-4.802,0-7.364-3.76-7.364-7.15c0-3.971,3.227-7.365,7.817-7.365 - c4.438,0,7.217,3.486,7.217,7.15C91.009,26.236,88.26,30.025,83.338,30.025"/> - <path fill="#FFFFFF" d="M128.327,28.68c-1.004-0.098-1.214-0.281-1.214-1.465v-0.34V9.969c0.009-0.068,0.012-0.131,0.02-0.197 - c0.122-1.071,0.428-1.248,1.365-1.802h-4.34l-2.279,1.097h2.324v0.016L124.2,9.078v17.797v1.01c0,0.609-0.122,0.697-0.822,1.607 - h5.372l1.131-0.67C129.361,28.77,128.843,28.732,128.327,28.68"/> - <path fill="#FFFFFF" d="M137.846,19.938c0.573-0.213,0.874-0.392,0.874-0.813c0-1.216-1.356-2.61-2.985-2.61 - c-1.207,0-3.469,0.945-3.469,4.211c0,0.515,0.066,1.058,0.091,1.597L137.846,19.938z M140.677,28.955 - c-0.332,0.184-0.666,0.398-0.997,0.545c-0.991,0.459-2.016,0.574-2.921,0.574c-0.964,0-2.468-0.057-4.015-1.186 - c-2.129-1.503-3.074-4.111-3.074-6.382c0-4.689,3.804-6.987,6.907-6.987c1.086,0,2.208,0.276,3.103,0.845 - c1.507,0.996,1.904,2.297,2.109,2.995l-7.076,2.875l-2.327,0.184c0.752,3.846,3.348,6.084,6.214,6.084 - c1.533,0,2.646-0.545,3.673-1.055L140.677,28.955z"/> - <path fill="#FFFFFF" d="M73.664,29.551l-4.337,1.006c-1.762,0.273-3.337,0.523-5.006,0.523c-8.376,0-11.56-6.191-11.56-11.035 - c0-5.911,4.521-11.392,12.254-11.392c1.64,0,3.223,0.242,4.647,0.637c2.271,0.641,3.339,1.439,4.002,1.888l-2.513,2.405 - l-1.063,0.245l0.756-1.218c-1.035-1.004-2.913-2.856-6.492-2.856c-4.796,0-8.406,3.653-8.406,8.984 - c0,5.728,4.128,11.118,10.741,11.118c1.945,0,2.945-0.397,3.856-0.764v-4.902l-4.583,0.238l2.423-1.305h6.433l-0.785,0.764 - c-0.213,0.178-0.246,0.238-0.304,0.48c-0.031,0.279-0.062,1.166-0.062,1.471L73.664,29.551L73.664,29.551z"/> -</g> -</svg> diff --git a/latest/_static/images/logo.svg b/latest/_static/images/logo.svg deleted file mode 100644 index 6c515095c5ad..000000000000 --- a/latest/_static/images/logo.svg +++ /dev/null @@ -1,25 +0,0 @@ -<?xml version="1.0" encoding="utf-8"?> -<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> -<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> -<svg version="1.1" id="Camada_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" - width="43.176px" height="40px" viewBox="0 0 43.176 40" enable-background="new 0 0 43.176 40" xml:space="preserve"> -<g> - <path fill="#FFFFFF" d="M27.27,20.001c0-3.138-2.543-5.682-5.682-5.682c-3.138,0-5.681,2.544-5.681,5.682 - c0,3.136,2.543,5.681,5.681,5.681C24.727,25.682,27.27,23.137,27.27,20.001"/> - <path fill="#FFFFFF" d="M42.363,18.093l-4.922-8.521c-0.018-0.031-0.039-0.059-0.06-0.089l-3.766-6.525 - c-0.701-1.214-1.972-1.894-3.28-1.895H12.841c-1.402,0-2.625,0.762-3.28,1.894L4.642,11.48l0,0l4.372,7.572l6.015-10.417 - l20.773,0.001c0.654,0.001,1.289,0.34,1.64,0.946h-8.737l6.007,10.404l-6.57,11.377l0,0l-3.818,6.615 - c-0.328,0.563-0.938,0.944-1.639,0.944l4.364-7.562h-12.02l-6.05-10.479l0,0l-0.511-0.885l0.001-0.001l-3.826-6.626 - c-0.325-0.564-0.35-1.28-0.004-1.885l-3.824,6.619c-0.701,1.214-0.653,2.654,0,3.788l8.747,15.15 - c0.701,1.213,1.972,1.893,3.28,1.893h9.841c0.072,0,0.143-0.006,0.211-0.014h7.441c1.402,0,2.626-0.762,3.281-1.893l8.746-15.15 - C43.063,20.667,43.016,19.227,42.363,18.093 M12.841,6.178c-0.628,0-1.137-0.509-1.137-1.138c0-0.628,0.509-1.137,1.137-1.137 - s1.138,0.509,1.138,1.137C13.979,5.669,13.47,6.178,12.841,6.178 M30.904,6.026c-0.545,0.313-1.24,0.127-1.553-0.416 - c-0.314-0.545-0.129-1.24,0.416-1.554c0.543-0.314,1.238-0.128,1.553,0.416C31.635,5.017,31.449,5.712,30.904,6.026 M5.079,20.76 - c-0.313,0.543-1.009,0.73-1.553,0.416c-0.544-0.313-0.73-1.01-0.417-1.554s1.009-0.73,1.554-0.416 - C5.207,19.52,5.393,20.216,5.079,20.76 M13.409,36.326c-0.544,0.314-1.24,0.127-1.554-0.416c-0.314-0.545-0.127-1.24,0.417-1.555 - c0.544-0.315,1.239-0.127,1.554,0.418C14.139,35.316,13.953,36.012,13.409,36.326 M30.334,36.479c-0.628,0-1.137-0.508-1.137-1.137 - c0-0.627,0.509-1.137,1.137-1.137s1.139,0.51,1.139,1.137C31.473,35.971,30.962,36.479,30.334,36.479 M40.066,20.761 - c-0.313,0.544-1.01,0.729-1.553,0.415c-0.545-0.313-0.73-1.009-0.416-1.553c0.313-0.544,1.008-0.73,1.553-0.416 - S40.381,20.217,40.066,20.761"/> -</g> -</svg> diff --git a/latest/_static/images/storage-logo.png b/latest/_static/images/storage-logo.png deleted file mode 100644 index f5c80042dee4db5a33fd6ff28d7348e433ce9484..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 9757 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 HyV(B&mdS=Q diff --git a/latest/_static/js/main.js b/latest/_static/js/main.js deleted file mode 100644 index dcd61f346e86..000000000000 --- a/latest/_static/js/main.js +++ /dev/null @@ -1,59 +0,0 @@ -$('.nav-current').click(function(){ - $('.main-nav').toggleClass('open'); -}); - -$('.faq-btn').click(function(){ - $(this).toggleClass('open'); -}); - -$('.headerlink').parent().each(function() { - $(this).hover( - function() { $(this).children('.headerlink').show(); }, - function() { $(this).children('.headerlink').hide(); } - ); -}); - -var apiQsSection; -// don't even ask me why -if ($('#cloud-datastore-in-10-seconds').length) - apiQsSection = $('#cloud-datastore-in-10-seconds'); -else if ($('#cloud-storage-in-10-seconds').length) - apiQsSection = $('#cloud-storage-in-10-seconds'); -else if ($('#cloud-pubsub-in-10-seconds').length) - apiQsSection = $('#cloud-pubsub-in-10-seconds'); -else if ($('#cloud-bigquery-in-10-seconds').length) - apiQsSection = $('#cloud-bigquery-in-10-seconds'); - -if(apiQsSection) { - var apiQsSubSections = apiQsSection.children('div'); - var showToggle = $('<span></span>') - .text('▹') - .addClass('toggle'); - var hideToggle = $('<span></span>') - .text('▿') - .addClass('toggle') - .hide(); - showToggle.click(function() { - showToggle.hide(); - hideToggle.show(); - apiQsSubSections.each(function() { - $(this).show(); - }) - }); - hideToggle.click(function() { - hideToggle.hide(); - showToggle.show(); - apiQsSubSections.each(function() { - $(this).hide(); - }) - }); - var toggler = $('<div></div>') - .addClass('toggler') - .append(showToggle) - .append(hideToggle); - - apiQsSubSections.each(function() { - $(this).hide(); - }); - $(apiQsSection).children('h2').first().prepend(toggler); -} diff --git a/latest/_static/js/vendor/modernizr-2.6.2.min.js b/latest/_static/js/modernizr.min.js similarity index 100% rename from latest/_static/js/vendor/modernizr-2.6.2.min.js rename to latest/_static/js/modernizr.min.js diff --git a/latest/_static/js/plugins.js b/latest/_static/js/plugins.js deleted file mode 100644 index 728680b08d18..000000000000 --- a/latest/_static/js/plugins.js +++ /dev/null @@ -1,24 +0,0 @@ -// Avoid `console` errors in browsers that lack a console. -(function() { - var method; - var noop = function () {}; - var methods = [ - 'assert', 'clear', 'count', 'debug', 'dir', 'dirxml', 'error', - 'exception', 'group', 'groupCollapsed', 'groupEnd', 'info', 'log', - 'markTimeline', 'profile', 'profileEnd', 'table', 'time', 'timeEnd', - 'timeStamp', 'trace', 'warn' - ]; - var length = methods.length; - var console = (window.console = window.console || {}); - - while (length--) { - method = methods[length]; - - // Only stub undefined methods. - if (!console[method]) { - console[method] = noop; - } - } -}()); - -// Place any jQuery/helper plugins in here. diff --git a/latest/_static/js/theme.js b/latest/_static/js/theme.js new file mode 100644 index 000000000000..48a9f06b5b89 --- /dev/null +++ b/latest/_static/js/theme.js @@ -0,0 +1,153 @@ +require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({"sphinx-rtd-theme":[function(require,module,exports){ +var jQuery = (typeof(window) != 'undefined') ? window.jQuery : require('jquery'); + +// Sphinx theme nav state +function ThemeNav () { + + var nav = { + navBar: null, + win: null, + winScroll: false, + winResize: false, + linkScroll: false, + winPosition: 0, + winHeight: null, + docHeight: null, + isRunning: null + }; + + nav.enable = function () { + var self = this; + + jQuery(function ($) { + self.init($); + + self.reset(); + self.win.on('hashchange', self.reset); + + // Set scroll monitor + self.win.on('scroll', function () { + if (!self.linkScroll) { + self.winScroll = true; + } + }); + setInterval(function () { if (self.winScroll) self.onScroll(); }, 25); + + // Set resize monitor + self.win.on('resize', function () { + self.winResize = true; + }); + setInterval(function () { if (self.winResize) self.onResize(); }, 25); + self.onResize(); + }); + }; + + nav.init = function ($) { + var doc = $(document), + self = this; + + this.navBar = $('div.wy-side-scroll:first'); + this.win = $(window); + + // Set up javascript UX bits + $(document) + // Shift nav in mobile when clicking the menu. + .on('click', "[data-toggle='wy-nav-top']", function() { + $("[data-toggle='wy-nav-shift']").toggleClass("shift"); + $("[data-toggle='rst-versions']").toggleClass("shift"); + }) + + // Nav menu link click operations + .on('click', ".wy-menu-vertical .current ul li a", function() { + var target = $(this); + // Close menu when you click a link. + $("[data-toggle='wy-nav-shift']").removeClass("shift"); + $("[data-toggle='rst-versions']").toggleClass("shift"); + // Handle dynamic display of l3 and l4 nav lists + self.toggleCurrent(target); + self.hashChange(); + }) + .on('click', "[data-toggle='rst-current-version']", function() { + $("[data-toggle='rst-versions']").toggleClass("shift-up"); + }) + + // Make tables responsive + $("table.docutils:not(.field-list)") + .wrap("<div class='wy-table-responsive'></div>"); + + // Add expand links to all parents of nested ul + $('.wy-menu-vertical ul').not('.simple').siblings('a').each(function () { + var link = $(this); + expand = $('<span class="toctree-expand"></span>'); + expand.on('click', function (ev) { + self.toggleCurrent(link); + ev.stopPropagation(); + return false; + }); + link.prepend(expand); + }); + }; + + nav.reset = function () { + // Get anchor from URL and open up nested nav + var anchor = encodeURI(window.location.hash); + if (anchor) { + try { + var link = $('.wy-menu-vertical') + .find('[href="' + anchor + '"]'); + $('.wy-menu-vertical li.toctree-l1 li.current') + .removeClass('current'); + link.closest('li.toctree-l2').addClass('current'); + link.closest('li.toctree-l3').addClass('current'); + link.closest('li.toctree-l4').addClass('current'); + } + catch (err) { + console.log("Error expanding nav for anchor", err); + } + } + }; + + nav.onScroll = function () { + this.winScroll = false; + var newWinPosition = this.win.scrollTop(), + winBottom = newWinPosition + this.winHeight, + navPosition = this.navBar.scrollTop(), + newNavPosition = navPosition + (newWinPosition - this.winPosition); + if (newWinPosition < 0 || winBottom > this.docHeight) { + return; + } + this.navBar.scrollTop(newNavPosition); + this.winPosition = newWinPosition; + }; + + nav.onResize = function () { + this.winResize = false; + this.winHeight = this.win.height(); + this.docHeight = $(document).height(); + }; + + nav.hashChange = function () { + this.linkScroll = true; + this.win.one('hashchange', function () { + this.linkScroll = false; + }); + }; + + nav.toggleCurrent = function (elem) { + var parent_li = elem.closest('li'); + parent_li.siblings('li.current').removeClass('current'); + parent_li.siblings().find('li.current').removeClass('current'); + parent_li.find('> ul li.current').removeClass('current'); + parent_li.toggleClass('current'); + } + + return nav; +}; + +module.exports.ThemeNav = ThemeNav(); + +if (typeof(window) != 'undefined') { + window.SphinxRtdTheme = { StickyNav: module.exports.ThemeNav }; +} + +},{"jquery":"jquery"}]},{},["sphinx-rtd-theme"]); diff --git a/latest/_static/js/vendor/jquery-1.10.2.min.js b/latest/_static/js/vendor/jquery-1.10.2.min.js deleted file mode 100644 index da4170647dd1..000000000000 --- a/latest/_static/js/vendor/jquery-1.10.2.min.js +++ /dev/null @@ -1,6 +0,0 @@ -/*! jQuery v1.10.2 | (c) 2005, 2013 jQuery Foundation, Inc. | jquery.org/license -//@ sourceMappingURL=jquery-1.10.2.min.map -*/ -(function(e,t){var n,r,i=typeof t,o=e.location,a=e.document,s=a.documentElement,l=e.jQuery,u=e.$,c={},p=[],f="1.10.2",d=p.concat,h=p.push,g=p.slice,m=p.indexOf,y=c.toString,v=c.hasOwnProperty,b=f.trim,x=function(e,t){return new x.fn.init(e,t,r)},w=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=/\S+/g,C=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,N=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,k=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,E=/^[\],:{}\s]*$/,S=/(?:^|:|,)(?:\s*\[)+/g,A=/\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,j=/"[^"\\\r\n]*"|true|false|null|-?(?:\d+\.|)\d+(?:[eE][+-]?\d+|)/g,D=/^-ms-/,L=/-([\da-z])/gi,H=function(e,t){return t.toUpperCase()},q=function(e){(a.addEventListener||"load"===e.type||"complete"===a.readyState)&&(_(),x.ready())},_=function(){a.addEventListener?(a.removeEventListener("DOMContentLoaded",q,!1),e.removeEventListener("load",q,!1)):(a.detachEvent("onreadystatechange",q),e.detachEvent("onload",q))};x.fn=x.prototype={jquery:f,constructor:x,init:function(e,n,r){var i,o;if(!e)return this;if("string"==typeof e){if(i="<"===e.charAt(0)&&">"===e.charAt(e.length-1)&&e.length>=3?[null,e,null]:N.exec(e),!i||!i[1]&&n)return!n||n.jquery?(n||r).find(e):this.constructor(n).find(e);if(i[1]){if(n=n instanceof x?n[0]:n,x.merge(this,x.parseHTML(i[1],n&&n.nodeType?n.ownerDocument||n:a,!0)),k.test(i[1])&&x.isPlainObject(n))for(i in n)x.isFunction(this[i])?this[i](n[i]):this.attr(i,n[i]);return this}if(o=a.getElementById(i[2]),o&&o.parentNode){if(o.id!==i[2])return r.find(e);this.length=1,this[0]=o}return this.context=a,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):x.isFunction(e)?r.ready(e):(e.selector!==t&&(this.selector=e.selector,this.context=e.context),x.makeArray(e,this))},selector:"",length:0,toArray:function(){return g.call(this)},get:function(e){return null==e?this.toArray():0>e?this[this.length+e]:this[e]},pushStack:function(e){var t=x.merge(this.constructor(),e);return t.prevObject=this,t.context=this.context,t},each:function(e,t){return x.each(this,e,t)},ready:function(e){return x.ready.promise().done(e),this},slice:function(){return this.pushStack(g.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(0>e?t:0);return this.pushStack(n>=0&&t>n?[this[n]]:[])},map:function(e){return this.pushStack(x.map(this,function(t,n){return e.call(t,n,t)}))},end:function(){return this.prevObject||this.constructor(null)},push:h,sort:[].sort,splice:[].splice},x.fn.init.prototype=x.fn,x.extend=x.fn.extend=function(){var e,n,r,i,o,a,s=arguments[0]||{},l=1,u=arguments.length,c=!1;for("boolean"==typeof s&&(c=s,s=arguments[1]||{},l=2),"object"==typeof s||x.isFunction(s)||(s={}),u===l&&(s=this,--l);u>l;l++)if(null!=(o=arguments[l]))for(i in o)e=s[i],r=o[i],s!==r&&(c&&r&&(x.isPlainObject(r)||(n=x.isArray(r)))?(n?(n=!1,a=e&&x.isArray(e)?e:[]):a=e&&x.isPlainObject(e)?e:{},s[i]=x.extend(c,a,r)):r!==t&&(s[i]=r));return s},x.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),noConflict:function(t){return e.$===x&&(e.$=u),t&&e.jQuery===x&&(e.jQuery=l),x},isReady:!1,readyWait:1,holdReady:function(e){e?x.readyWait++:x.ready(!0)},ready:function(e){if(e===!0?!--x.readyWait:!x.isReady){if(!a.body)return setTimeout(x.ready);x.isReady=!0,e!==!0&&--x.readyWait>0||(n.resolveWith(a,[x]),x.fn.trigger&&x(a).trigger("ready").off("ready"))}},isFunction:function(e){return"function"===x.type(e)},isArray:Array.isArray||function(e){return"array"===x.type(e)},isWindow:function(e){return null!=e&&e==e.window},isNumeric:function(e){return!isNaN(parseFloat(e))&&isFinite(e)},type:function(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?c[y.call(e)]||"object":typeof e},isPlainObject:function(e){var n;if(!e||"object"!==x.type(e)||e.nodeType||x.isWindow(e))return!1;try{if(e.constructor&&!v.call(e,"constructor")&&!v.call(e.constructor.prototype,"isPrototypeOf"))return!1}catch(r){return!1}if(x.support.ownLast)for(n in e)return v.call(e,n);for(n in e);return n===t||v.call(e,n)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},error:function(e){throw Error(e)},parseHTML:function(e,t,n){if(!e||"string"!=typeof e)return null;"boolean"==typeof t&&(n=t,t=!1),t=t||a;var r=k.exec(e),i=!n&&[];return r?[t.createElement(r[1])]:(r=x.buildFragment([e],t,i),i&&x(i).remove(),x.merge([],r.childNodes))},parseJSON:function(n){return e.JSON&&e.JSON.parse?e.JSON.parse(n):null===n?n:"string"==typeof n&&(n=x.trim(n),n&&E.test(n.replace(A,"@").replace(j,"]").replace(S,"")))?Function("return "+n)():(x.error("Invalid JSON: "+n),t)},parseXML:function(n){var r,i;if(!n||"string"!=typeof n)return null;try{e.DOMParser?(i=new DOMParser,r=i.parseFromString(n,"text/xml")):(r=new ActiveXObject("Microsoft.XMLDOM"),r.async="false",r.loadXML(n))}catch(o){r=t}return r&&r.documentElement&&!r.getElementsByTagName("parsererror").length||x.error("Invalid XML: "+n),r},noop:function(){},globalEval:function(t){t&&x.trim(t)&&(e.execScript||function(t){e.eval.call(e,t)})(t)},camelCase:function(e){return e.replace(D,"ms-").replace(L,H)},nodeName:function(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()},each:function(e,t,n){var r,i=0,o=e.length,a=M(e);if(n){if(a){for(;o>i;i++)if(r=t.apply(e[i],n),r===!1)break}else for(i in e)if(r=t.apply(e[i],n),r===!1)break}else if(a){for(;o>i;i++)if(r=t.call(e[i],i,e[i]),r===!1)break}else for(i in e)if(r=t.call(e[i],i,e[i]),r===!1)break;return e},trim:b&&!b.call("\ufeff\u00a0")?function(e){return null==e?"":b.call(e)}:function(e){return null==e?"":(e+"").replace(C,"")},makeArray:function(e,t){var n=t||[];return null!=e&&(M(Object(e))?x.merge(n,"string"==typeof e?[e]:e):h.call(n,e)),n},inArray:function(e,t,n){var r;if(t){if(m)return m.call(t,e,n);for(r=t.length,n=n?0>n?Math.max(0,r+n):n:0;r>n;n++)if(n in t&&t[n]===e)return n}return-1},merge:function(e,n){var r=n.length,i=e.length,o=0;if("number"==typeof r)for(;r>o;o++)e[i++]=n[o];else while(n[o]!==t)e[i++]=n[o++];return e.length=i,e},grep:function(e,t,n){var r,i=[],o=0,a=e.length;for(n=!!n;a>o;o++)r=!!t(e[o],o),n!==r&&i.push(e[o]);return i},map:function(e,t,n){var r,i=0,o=e.length,a=M(e),s=[];if(a)for(;o>i;i++)r=t(e[i],i,n),null!=r&&(s[s.length]=r);else for(i in e)r=t(e[i],i,n),null!=r&&(s[s.length]=r);return d.apply([],s)},guid:1,proxy:function(e,n){var r,i,o;return"string"==typeof n&&(o=e[n],n=e,e=o),x.isFunction(e)?(r=g.call(arguments,2),i=function(){return e.apply(n||this,r.concat(g.call(arguments)))},i.guid=e.guid=e.guid||x.guid++,i):t},access:function(e,n,r,i,o,a,s){var l=0,u=e.length,c=null==r;if("object"===x.type(r)){o=!0;for(l in r)x.access(e,n,l,r[l],!0,a,s)}else if(i!==t&&(o=!0,x.isFunction(i)||(s=!0),c&&(s?(n.call(e,i),n=null):(c=n,n=function(e,t,n){return c.call(x(e),n)})),n))for(;u>l;l++)n(e[l],r,s?i:i.call(e[l],l,n(e[l],r)));return o?e:c?n.call(e):u?n(e[0],r):a},now:function(){return(new Date).getTime()},swap:function(e,t,n,r){var i,o,a={};for(o in t)a[o]=e.style[o],e.style[o]=t[o];i=n.apply(e,r||[]);for(o in t)e.style[o]=a[o];return i}}),x.ready.promise=function(t){if(!n)if(n=x.Deferred(),"complete"===a.readyState)setTimeout(x.ready);else if(a.addEventListener)a.addEventListener("DOMContentLoaded",q,!1),e.addEventListener("load",q,!1);else{a.attachEvent("onreadystatechange",q),e.attachEvent("onload",q);var r=!1;try{r=null==e.frameElement&&a.documentElement}catch(i){}r&&r.doScroll&&function o(){if(!x.isReady){try{r.doScroll("left")}catch(e){return setTimeout(o,50)}_(),x.ready()}}()}return n.promise(t)},x.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(e,t){c["[object "+t+"]"]=t.toLowerCase()});function M(e){var t=e.length,n=x.type(e);return x.isWindow(e)?!1:1===e.nodeType&&t?!0:"array"===n||"function"!==n&&(0===t||"number"==typeof t&&t>0&&t-1 in e)}r=x(a),function(e,t){var n,r,i,o,a,s,l,u,c,p,f,d,h,g,m,y,v,b="sizzle"+-new Date,w=e.document,T=0,C=0,N=st(),k=st(),E=st(),S=!1,A=function(e,t){return e===t?(S=!0,0):0},j=typeof t,D=1<<31,L={}.hasOwnProperty,H=[],q=H.pop,_=H.push,M=H.push,O=H.slice,F=H.indexOf||function(e){var t=0,n=this.length;for(;n>t;t++)if(this[t]===e)return t;return-1},B="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",P="[\\x20\\t\\r\\n\\f]",R="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",W=R.replace("w","w#"),$="\\["+P+"*("+R+")"+P+"*(?:([*^$|!~]?=)"+P+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+W+")|)|)"+P+"*\\]",I=":("+R+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+$.replace(3,8)+")*)|.*)\\)|)",z=RegExp("^"+P+"+|((?:^|[^\\\\])(?:\\\\.)*)"+P+"+$","g"),X=RegExp("^"+P+"*,"+P+"*"),U=RegExp("^"+P+"*([>+~]|"+P+")"+P+"*"),V=RegExp(P+"*[+~]"),Y=RegExp("="+P+"*([^\\]'\"]*)"+P+"*\\]","g"),J=RegExp(I),G=RegExp("^"+W+"$"),Q={ID:RegExp("^#("+R+")"),CLASS:RegExp("^\\.("+R+")"),TAG:RegExp("^("+R.replace("w","w*")+")"),ATTR:RegExp("^"+$),PSEUDO:RegExp("^"+I),CHILD:RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+P+"*(even|odd|(([+-]|)(\\d*)n|)"+P+"*(?:([+-]|)"+P+"*(\\d+)|))"+P+"*\\)|)","i"),bool:RegExp("^(?:"+B+")$","i"),needsContext:RegExp("^"+P+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+P+"*((?:-\\d)?\\d*)"+P+"*\\)|)(?=[^-]|$)","i")},K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,et=/^(?:input|select|textarea|button)$/i,tt=/^h\d$/i,nt=/'|\\/g,rt=RegExp("\\\\([\\da-f]{1,6}"+P+"?|("+P+")|.)","ig"),it=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:0>r?String.fromCharCode(r+65536):String.fromCharCode(55296|r>>10,56320|1023&r)};try{M.apply(H=O.call(w.childNodes),w.childNodes),H[w.childNodes.length].nodeType}catch(ot){M={apply:H.length?function(e,t){_.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function at(e,t,n,i){var o,a,s,l,u,c,d,m,y,x;if((t?t.ownerDocument||t:w)!==f&&p(t),t=t||f,n=n||[],!e||"string"!=typeof e)return n;if(1!==(l=t.nodeType)&&9!==l)return[];if(h&&!i){if(o=Z.exec(e))if(s=o[1]){if(9===l){if(a=t.getElementById(s),!a||!a.parentNode)return n;if(a.id===s)return n.push(a),n}else if(t.ownerDocument&&(a=t.ownerDocument.getElementById(s))&&v(t,a)&&a.id===s)return n.push(a),n}else{if(o[2])return M.apply(n,t.getElementsByTagName(e)),n;if((s=o[3])&&r.getElementsByClassName&&t.getElementsByClassName)return M.apply(n,t.getElementsByClassName(s)),n}if(r.qsa&&(!g||!g.test(e))){if(m=d=b,y=t,x=9===l&&e,1===l&&"object"!==t.nodeName.toLowerCase()){c=mt(e),(d=t.getAttribute("id"))?m=d.replace(nt,"\\$&"):t.setAttribute("id",m),m="[id='"+m+"'] ",u=c.length;while(u--)c[u]=m+yt(c[u]);y=V.test(e)&&t.parentNode||t,x=c.join(",")}if(x)try{return M.apply(n,y.querySelectorAll(x)),n}catch(T){}finally{d||t.removeAttribute("id")}}}return kt(e.replace(z,"$1"),t,n,i)}function st(){var e=[];function t(n,r){return e.push(n+=" ")>o.cacheLength&&delete t[e.shift()],t[n]=r}return t}function lt(e){return e[b]=!0,e}function ut(e){var t=f.createElement("div");try{return!!e(t)}catch(n){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function ct(e,t){var n=e.split("|"),r=e.length;while(r--)o.attrHandle[n[r]]=t}function pt(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||D)-(~e.sourceIndex||D);if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function ft(e){return function(t){var n=t.nodeName.toLowerCase();return"input"===n&&t.type===e}}function dt(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function ht(e){return lt(function(t){return t=+t,lt(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}s=at.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return t?"HTML"!==t.nodeName:!1},r=at.support={},p=at.setDocument=function(e){var n=e?e.ownerDocument||e:w,i=n.defaultView;return n!==f&&9===n.nodeType&&n.documentElement?(f=n,d=n.documentElement,h=!s(n),i&&i.attachEvent&&i!==i.top&&i.attachEvent("onbeforeunload",function(){p()}),r.attributes=ut(function(e){return e.className="i",!e.getAttribute("className")}),r.getElementsByTagName=ut(function(e){return e.appendChild(n.createComment("")),!e.getElementsByTagName("*").length}),r.getElementsByClassName=ut(function(e){return e.innerHTML="<div class='a'></div><div class='a i'></div>",e.firstChild.className="i",2===e.getElementsByClassName("i").length}),r.getById=ut(function(e){return d.appendChild(e).id=b,!n.getElementsByName||!n.getElementsByName(b).length}),r.getById?(o.find.ID=function(e,t){if(typeof t.getElementById!==j&&h){var n=t.getElementById(e);return n&&n.parentNode?[n]:[]}},o.filter.ID=function(e){var t=e.replace(rt,it);return function(e){return e.getAttribute("id")===t}}):(delete o.find.ID,o.filter.ID=function(e){var t=e.replace(rt,it);return function(e){var n=typeof e.getAttributeNode!==j&&e.getAttributeNode("id");return n&&n.value===t}}),o.find.TAG=r.getElementsByTagName?function(e,n){return typeof n.getElementsByTagName!==j?n.getElementsByTagName(e):t}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},o.find.CLASS=r.getElementsByClassName&&function(e,n){return typeof n.getElementsByClassName!==j&&h?n.getElementsByClassName(e):t},m=[],g=[],(r.qsa=K.test(n.querySelectorAll))&&(ut(function(e){e.innerHTML="<select><option selected=''></option></select>",e.querySelectorAll("[selected]").length||g.push("\\["+P+"*(?:value|"+B+")"),e.querySelectorAll(":checked").length||g.push(":checked")}),ut(function(e){var t=n.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("t",""),e.querySelectorAll("[t^='']").length&&g.push("[*^$]="+P+"*(?:''|\"\")"),e.querySelectorAll(":enabled").length||g.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),g.push(",.*:")})),(r.matchesSelector=K.test(y=d.webkitMatchesSelector||d.mozMatchesSelector||d.oMatchesSelector||d.msMatchesSelector))&&ut(function(e){r.disconnectedMatch=y.call(e,"div"),y.call(e,"[s!='']:x"),m.push("!=",I)}),g=g.length&&RegExp(g.join("|")),m=m.length&&RegExp(m.join("|")),v=K.test(d.contains)||d.compareDocumentPosition?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},A=d.compareDocumentPosition?function(e,t){if(e===t)return S=!0,0;var i=t.compareDocumentPosition&&e.compareDocumentPosition&&e.compareDocumentPosition(t);return i?1&i||!r.sortDetached&&t.compareDocumentPosition(e)===i?e===n||v(w,e)?-1:t===n||v(w,t)?1:c?F.call(c,e)-F.call(c,t):0:4&i?-1:1:e.compareDocumentPosition?-1:1}:function(e,t){var r,i=0,o=e.parentNode,a=t.parentNode,s=[e],l=[t];if(e===t)return S=!0,0;if(!o||!a)return e===n?-1:t===n?1:o?-1:a?1:c?F.call(c,e)-F.call(c,t):0;if(o===a)return pt(e,t);r=e;while(r=r.parentNode)s.unshift(r);r=t;while(r=r.parentNode)l.unshift(r);while(s[i]===l[i])i++;return i?pt(s[i],l[i]):s[i]===w?-1:l[i]===w?1:0},n):f},at.matches=function(e,t){return at(e,null,null,t)},at.matchesSelector=function(e,t){if((e.ownerDocument||e)!==f&&p(e),t=t.replace(Y,"='$1']"),!(!r.matchesSelector||!h||m&&m.test(t)||g&&g.test(t)))try{var n=y.call(e,t);if(n||r.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(i){}return at(t,f,null,[e]).length>0},at.contains=function(e,t){return(e.ownerDocument||e)!==f&&p(e),v(e,t)},at.attr=function(e,n){(e.ownerDocument||e)!==f&&p(e);var i=o.attrHandle[n.toLowerCase()],a=i&&L.call(o.attrHandle,n.toLowerCase())?i(e,n,!h):t;return a===t?r.attributes||!h?e.getAttribute(n):(a=e.getAttributeNode(n))&&a.specified?a.value:null:a},at.error=function(e){throw Error("Syntax error, unrecognized expression: "+e)},at.uniqueSort=function(e){var t,n=[],i=0,o=0;if(S=!r.detectDuplicates,c=!r.sortStable&&e.slice(0),e.sort(A),S){while(t=e[o++])t===e[o]&&(i=n.push(o));while(i--)e.splice(n[i],1)}return e},a=at.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=a(e)}else if(3===i||4===i)return e.nodeValue}else for(;t=e[r];r++)n+=a(t);return n},o=at.selectors={cacheLength:50,createPseudo:lt,match:Q,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(rt,it),e[3]=(e[4]||e[5]||"").replace(rt,it),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||at.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&at.error(e[0]),e},PSEUDO:function(e){var n,r=!e[5]&&e[2];return Q.CHILD.test(e[0])?null:(e[3]&&e[4]!==t?e[2]=e[4]:r&&J.test(r)&&(n=mt(r,!0))&&(n=r.indexOf(")",r.length-n)-r.length)&&(e[0]=e[0].slice(0,n),e[2]=r.slice(0,n)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(rt,it).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=N[e+" "];return t||(t=RegExp("(^|"+P+")"+e+"("+P+"|$)"))&&N(e,function(e){return t.test("string"==typeof e.className&&e.className||typeof e.getAttribute!==j&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=at.attr(r,e);return null==i?"!="===t:t?(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i+" ").indexOf(n)>-1:"|="===t?i===n||i.slice(0,n.length+1)===n+"-":!1):!0}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,l){var u,c,p,f,d,h,g=o!==a?"nextSibling":"previousSibling",m=t.parentNode,y=s&&t.nodeName.toLowerCase(),v=!l&&!s;if(m){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===y:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?m.firstChild:m.lastChild],a&&v){c=m[b]||(m[b]={}),u=c[e]||[],d=u[0]===T&&u[1],f=u[0]===T&&u[2],p=d&&m.childNodes[d];while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if(1===p.nodeType&&++f&&p===t){c[e]=[T,d,f];break}}else if(v&&(u=(t[b]||(t[b]={}))[e])&&u[0]===T)f=u[1];else while(p=++d&&p&&p[g]||(f=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===y:1===p.nodeType)&&++f&&(v&&((p[b]||(p[b]={}))[e]=[T,f]),p===t))break;return f-=i,f===r||0===f%r&&f/r>=0}}},PSEUDO:function(e,t){var n,r=o.pseudos[e]||o.setFilters[e.toLowerCase()]||at.error("unsupported pseudo: "+e);return r[b]?r(t):r.length>1?(n=[e,e,"",t],o.setFilters.hasOwnProperty(e.toLowerCase())?lt(function(e,n){var i,o=r(e,t),a=o.length;while(a--)i=F.call(e,o[a]),e[i]=!(n[i]=o[a])}):function(e){return r(e,0,n)}):r}},pseudos:{not:lt(function(e){var t=[],n=[],r=l(e.replace(z,"$1"));return r[b]?lt(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),!n.pop()}}),has:lt(function(e){return function(t){return at(e,t).length>0}}),contains:lt(function(e){return function(t){return(t.textContent||t.innerText||a(t)).indexOf(e)>-1}}),lang:lt(function(e){return G.test(e||"")||at.error("unsupported lang: "+e),e=e.replace(rt,it).toLowerCase(),function(t){var n;do if(n=h?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return n=n.toLowerCase(),n===e||0===n.indexOf(e+"-");while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===d},focus:function(e){return e===f.activeElement&&(!f.hasFocus||f.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return e.disabled===!1},disabled:function(e){return e.disabled===!0},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,e.selected===!0},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeName>"@"||3===e.nodeType||4===e.nodeType)return!1;return!0},parent:function(e){return!o.pseudos.empty(e)},header:function(e){return tt.test(e.nodeName)},input:function(e){return et.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||t.toLowerCase()===e.type)},first:ht(function(){return[0]}),last:ht(function(e,t){return[t-1]}),eq:ht(function(e,t,n){return[0>n?n+t:n]}),even:ht(function(e,t){var n=0;for(;t>n;n+=2)e.push(n);return e}),odd:ht(function(e,t){var n=1;for(;t>n;n+=2)e.push(n);return e}),lt:ht(function(e,t,n){var r=0>n?n+t:n;for(;--r>=0;)e.push(r);return e}),gt:ht(function(e,t,n){var r=0>n?n+t:n;for(;t>++r;)e.push(r);return e})}},o.pseudos.nth=o.pseudos.eq;for(n in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})o.pseudos[n]=ft(n);for(n in{submit:!0,reset:!0})o.pseudos[n]=dt(n);function gt(){}gt.prototype=o.filters=o.pseudos,o.setFilters=new gt;function mt(e,t){var n,r,i,a,s,l,u,c=k[e+" "];if(c)return t?0:c.slice(0);s=e,l=[],u=o.preFilter;while(s){(!n||(r=X.exec(s)))&&(r&&(s=s.slice(r[0].length)||s),l.push(i=[])),n=!1,(r=U.exec(s))&&(n=r.shift(),i.push({value:n,type:r[0].replace(z," ")}),s=s.slice(n.length));for(a in o.filter)!(r=Q[a].exec(s))||u[a]&&!(r=u[a](r))||(n=r.shift(),i.push({value:n,type:a,matches:r}),s=s.slice(n.length));if(!n)break}return t?s.length:s?at.error(e):k(e,l).slice(0)}function yt(e){var t=0,n=e.length,r="";for(;n>t;t++)r+=e[t].value;return r}function vt(e,t,n){var r=t.dir,o=n&&"parentNode"===r,a=C++;return t.first?function(t,n,i){while(t=t[r])if(1===t.nodeType||o)return e(t,n,i)}:function(t,n,s){var l,u,c,p=T+" "+a;if(s){while(t=t[r])if((1===t.nodeType||o)&&e(t,n,s))return!0}else while(t=t[r])if(1===t.nodeType||o)if(c=t[b]||(t[b]={}),(u=c[r])&&u[0]===p){if((l=u[1])===!0||l===i)return l===!0}else if(u=c[r]=[p],u[1]=e(t,n,s)||i,u[1]===!0)return!0}}function bt(e){return e.length>1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function xt(e,t,n,r,i){var o,a=[],s=0,l=e.length,u=null!=t;for(;l>s;s++)(o=e[s])&&(!n||n(o,r,i))&&(a.push(o),u&&t.push(s));return a}function wt(e,t,n,r,i,o){return r&&!r[b]&&(r=wt(r)),i&&!i[b]&&(i=wt(i,o)),lt(function(o,a,s,l){var u,c,p,f=[],d=[],h=a.length,g=o||Nt(t||"*",s.nodeType?[s]:s,[]),m=!e||!o&&t?g:xt(g,f,e,s,l),y=n?i||(o?e:h||r)?[]:a:m;if(n&&n(m,y,s,l),r){u=xt(y,d),r(u,[],s,l),c=u.length;while(c--)(p=u[c])&&(y[d[c]]=!(m[d[c]]=p))}if(o){if(i||e){if(i){u=[],c=y.length;while(c--)(p=y[c])&&u.push(m[c]=p);i(null,y=[],u,l)}c=y.length;while(c--)(p=y[c])&&(u=i?F.call(o,p):f[c])>-1&&(o[u]=!(a[u]=p))}}else y=xt(y===a?y.splice(h,y.length):y),i?i(null,a,y,l):M.apply(a,y)})}function Tt(e){var t,n,r,i=e.length,a=o.relative[e[0].type],s=a||o.relative[" "],l=a?1:0,c=vt(function(e){return e===t},s,!0),p=vt(function(e){return F.call(t,e)>-1},s,!0),f=[function(e,n,r){return!a&&(r||n!==u)||((t=n).nodeType?c(e,n,r):p(e,n,r))}];for(;i>l;l++)if(n=o.relative[e[l].type])f=[vt(bt(f),n)];else{if(n=o.filter[e[l].type].apply(null,e[l].matches),n[b]){for(r=++l;i>r;r++)if(o.relative[e[r].type])break;return wt(l>1&&bt(f),l>1&&yt(e.slice(0,l-1).concat({value:" "===e[l-2].type?"*":""})).replace(z,"$1"),n,r>l&&Tt(e.slice(l,r)),i>r&&Tt(e=e.slice(r)),i>r&&yt(e))}f.push(n)}return bt(f)}function Ct(e,t){var n=0,r=t.length>0,a=e.length>0,s=function(s,l,c,p,d){var h,g,m,y=[],v=0,b="0",x=s&&[],w=null!=d,C=u,N=s||a&&o.find.TAG("*",d&&l.parentNode||l),k=T+=null==C?1:Math.random()||.1;for(w&&(u=l!==f&&l,i=n);null!=(h=N[b]);b++){if(a&&h){g=0;while(m=e[g++])if(m(h,l,c)){p.push(h);break}w&&(T=k,i=++n)}r&&((h=!m&&h)&&v--,s&&x.push(h))}if(v+=b,r&&b!==v){g=0;while(m=t[g++])m(x,y,l,c);if(s){if(v>0)while(b--)x[b]||y[b]||(y[b]=q.call(p));y=xt(y)}M.apply(p,y),w&&!s&&y.length>0&&v+t.length>1&&at.uniqueSort(p)}return w&&(T=k,u=C),x};return r?lt(s):s}l=at.compile=function(e,t){var n,r=[],i=[],o=E[e+" "];if(!o){t||(t=mt(e)),n=t.length;while(n--)o=Tt(t[n]),o[b]?r.push(o):i.push(o);o=E(e,Ct(i,r))}return o};function Nt(e,t,n){var r=0,i=t.length;for(;i>r;r++)at(e,t[r],n);return n}function kt(e,t,n,i){var a,s,u,c,p,f=mt(e);if(!i&&1===f.length){if(s=f[0]=f[0].slice(0),s.length>2&&"ID"===(u=s[0]).type&&r.getById&&9===t.nodeType&&h&&o.relative[s[1].type]){if(t=(o.find.ID(u.matches[0].replace(rt,it),t)||[])[0],!t)return n;e=e.slice(s.shift().value.length)}a=Q.needsContext.test(e)?0:s.length;while(a--){if(u=s[a],o.relative[c=u.type])break;if((p=o.find[c])&&(i=p(u.matches[0].replace(rt,it),V.test(s[0].type)&&t.parentNode||t))){if(s.splice(a,1),e=i.length&&yt(s),!e)return M.apply(n,i),n;break}}}return l(e,f)(i,t,!h,n,V.test(e)),n}r.sortStable=b.split("").sort(A).join("")===b,r.detectDuplicates=S,p(),r.sortDetached=ut(function(e){return 1&e.compareDocumentPosition(f.createElement("div"))}),ut(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||ct("type|href|height|width",function(e,n,r){return r?t:e.getAttribute(n,"type"===n.toLowerCase()?1:2)}),r.attributes&&ut(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||ct("value",function(e,n,r){return r||"input"!==e.nodeName.toLowerCase()?t:e.defaultValue}),ut(function(e){return null==e.getAttribute("disabled")})||ct(B,function(e,n,r){var i;return r?t:(i=e.getAttributeNode(n))&&i.specified?i.value:e[n]===!0?n.toLowerCase():null}),x.find=at,x.expr=at.selectors,x.expr[":"]=x.expr.pseudos,x.unique=at.uniqueSort,x.text=at.getText,x.isXMLDoc=at.isXML,x.contains=at.contains}(e);var O={};function F(e){var t=O[e]={};return x.each(e.match(T)||[],function(e,n){t[n]=!0}),t}x.Callbacks=function(e){e="string"==typeof e?O[e]||F(e):x.extend({},e);var n,r,i,o,a,s,l=[],u=!e.once&&[],c=function(t){for(r=e.memory&&t,i=!0,a=s||0,s=0,o=l.length,n=!0;l&&o>a;a++)if(l[a].apply(t[0],t[1])===!1&&e.stopOnFalse){r=!1;break}n=!1,l&&(u?u.length&&c(u.shift()):r?l=[]:p.disable())},p={add:function(){if(l){var t=l.length;(function i(t){x.each(t,function(t,n){var r=x.type(n);"function"===r?e.unique&&p.has(n)||l.push(n):n&&n.length&&"string"!==r&&i(n)})})(arguments),n?o=l.length:r&&(s=t,c(r))}return this},remove:function(){return l&&x.each(arguments,function(e,t){var r;while((r=x.inArray(t,l,r))>-1)l.splice(r,1),n&&(o>=r&&o--,a>=r&&a--)}),this},has:function(e){return e?x.inArray(e,l)>-1:!(!l||!l.length)},empty:function(){return l=[],o=0,this},disable:function(){return l=u=r=t,this},disabled:function(){return!l},lock:function(){return u=t,r||p.disable(),this},locked:function(){return!u},fireWith:function(e,t){return!l||i&&!u||(t=t||[],t=[e,t.slice?t.slice():t],n?u.push(t):c(t)),this},fire:function(){return p.fireWith(this,arguments),this},fired:function(){return!!i}};return p},x.extend({Deferred:function(e){var t=[["resolve","done",x.Callbacks("once memory"),"resolved"],["reject","fail",x.Callbacks("once memory"),"rejected"],["notify","progress",x.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return x.Deferred(function(n){x.each(t,function(t,o){var a=o[0],s=x.isFunction(e[t])&&e[t];i[o[1]](function(){var e=s&&s.apply(this,arguments);e&&x.isFunction(e.promise)?e.promise().done(n.resolve).fail(n.reject).progress(n.notify):n[a+"With"](this===r?n.promise():this,s?[e]:arguments)})}),e=null}).promise()},promise:function(e){return null!=e?x.extend(e,r):r}},i={};return r.pipe=r.then,x.each(t,function(e,o){var a=o[2],s=o[3];r[o[1]]=a.add,s&&a.add(function(){n=s},t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=a.fireWith}),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=g.call(arguments),r=n.length,i=1!==r||e&&x.isFunction(e.promise)?r:0,o=1===i?e:x.Deferred(),a=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?g.call(arguments):r,n===s?o.notifyWith(t,n):--i||o.resolveWith(t,n)}},s,l,u;if(r>1)for(s=Array(r),l=Array(r),u=Array(r);r>t;t++)n[t]&&x.isFunction(n[t].promise)?n[t].promise().done(a(t,u,n)).fail(o.reject).progress(a(t,l,s)):--i;return i||o.resolveWith(u,n),o.promise()}}),x.support=function(t){var n,r,o,s,l,u,c,p,f,d=a.createElement("div");if(d.setAttribute("className","t"),d.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",n=d.getElementsByTagName("*")||[],r=d.getElementsByTagName("a")[0],!r||!r.style||!n.length)return t;s=a.createElement("select"),u=s.appendChild(a.createElement("option")),o=d.getElementsByTagName("input")[0],r.style.cssText="top:1px;float:left;opacity:.5",t.getSetAttribute="t"!==d.className,t.leadingWhitespace=3===d.firstChild.nodeType,t.tbody=!d.getElementsByTagName("tbody").length,t.htmlSerialize=!!d.getElementsByTagName("link").length,t.style=/top/.test(r.getAttribute("style")),t.hrefNormalized="/a"===r.getAttribute("href"),t.opacity=/^0.5/.test(r.style.opacity),t.cssFloat=!!r.style.cssFloat,t.checkOn=!!o.value,t.optSelected=u.selected,t.enctype=!!a.createElement("form").enctype,t.html5Clone="<:nav></:nav>"!==a.createElement("nav").cloneNode(!0).outerHTML,t.inlineBlockNeedsLayout=!1,t.shrinkWrapBlocks=!1,t.pixelPosition=!1,t.deleteExpando=!0,t.noCloneEvent=!0,t.reliableMarginRight=!0,t.boxSizingReliable=!0,o.checked=!0,t.noCloneChecked=o.cloneNode(!0).checked,s.disabled=!0,t.optDisabled=!u.disabled;try{delete d.test}catch(h){t.deleteExpando=!1}o=a.createElement("input"),o.setAttribute("value",""),t.input=""===o.getAttribute("value"),o.value="t",o.setAttribute("type","radio"),t.radioValue="t"===o.value,o.setAttribute("checked","t"),o.setAttribute("name","t"),l=a.createDocumentFragment(),l.appendChild(o),t.appendChecked=o.checked,t.checkClone=l.cloneNode(!0).cloneNode(!0).lastChild.checked,d.attachEvent&&(d.attachEvent("onclick",function(){t.noCloneEvent=!1}),d.cloneNode(!0).click());for(f in{submit:!0,change:!0,focusin:!0})d.setAttribute(c="on"+f,"t"),t[f+"Bubbles"]=c in e||d.attributes[c].expando===!1;d.style.backgroundClip="content-box",d.cloneNode(!0).style.backgroundClip="",t.clearCloneStyle="content-box"===d.style.backgroundClip;for(f in x(t))break;return t.ownLast="0"!==f,x(function(){var n,r,o,s="padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",l=a.getElementsByTagName("body")[0];l&&(n=a.createElement("div"),n.style.cssText="border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px",l.appendChild(n).appendChild(d),d.innerHTML="<table><tr><td></td><td>t</td></tr></table>",o=d.getElementsByTagName("td"),o[0].style.cssText="padding:0;margin:0;border:0;display:none",p=0===o[0].offsetHeight,o[0].style.display="",o[1].style.display="none",t.reliableHiddenOffsets=p&&0===o[0].offsetHeight,d.innerHTML="",d.style.cssText="box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;",x.swap(l,null!=l.style.zoom?{zoom:1}:{},function(){t.boxSizing=4===d.offsetWidth}),e.getComputedStyle&&(t.pixelPosition="1%"!==(e.getComputedStyle(d,null)||{}).top,t.boxSizingReliable="4px"===(e.getComputedStyle(d,null)||{width:"4px"}).width,r=d.appendChild(a.createElement("div")),r.style.cssText=d.style.cssText=s,r.style.marginRight=r.style.width="0",d.style.width="1px",t.reliableMarginRight=!parseFloat((e.getComputedStyle(r,null)||{}).marginRight)),typeof d.style.zoom!==i&&(d.innerHTML="",d.style.cssText=s+"width:1px;padding:1px;display:inline;zoom:1",t.inlineBlockNeedsLayout=3===d.offsetWidth,d.style.display="block",d.innerHTML="<div></div>",d.firstChild.style.width="5px",t.shrinkWrapBlocks=3!==d.offsetWidth,t.inlineBlockNeedsLayout&&(l.style.zoom=1)),l.removeChild(n),n=d=o=r=null)}),n=s=l=u=r=o=null,t -}({});var B=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,P=/([A-Z])/g;function R(e,n,r,i){if(x.acceptData(e)){var o,a,s=x.expando,l=e.nodeType,u=l?x.cache:e,c=l?e[s]:e[s]&&s;if(c&&u[c]&&(i||u[c].data)||r!==t||"string"!=typeof n)return c||(c=l?e[s]=p.pop()||x.guid++:s),u[c]||(u[c]=l?{}:{toJSON:x.noop}),("object"==typeof n||"function"==typeof n)&&(i?u[c]=x.extend(u[c],n):u[c].data=x.extend(u[c].data,n)),a=u[c],i||(a.data||(a.data={}),a=a.data),r!==t&&(a[x.camelCase(n)]=r),"string"==typeof n?(o=a[n],null==o&&(o=a[x.camelCase(n)])):o=a,o}}function W(e,t,n){if(x.acceptData(e)){var r,i,o=e.nodeType,a=o?x.cache:e,s=o?e[x.expando]:x.expando;if(a[s]){if(t&&(r=n?a[s]:a[s].data)){x.isArray(t)?t=t.concat(x.map(t,x.camelCase)):t in r?t=[t]:(t=x.camelCase(t),t=t in r?[t]:t.split(" ")),i=t.length;while(i--)delete r[t[i]];if(n?!I(r):!x.isEmptyObject(r))return}(n||(delete a[s].data,I(a[s])))&&(o?x.cleanData([e],!0):x.support.deleteExpando||a!=a.window?delete a[s]:a[s]=null)}}}x.extend({cache:{},noData:{applet:!0,embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(e){return e=e.nodeType?x.cache[e[x.expando]]:e[x.expando],!!e&&!I(e)},data:function(e,t,n){return R(e,t,n)},removeData:function(e,t){return W(e,t)},_data:function(e,t,n){return R(e,t,n,!0)},_removeData:function(e,t){return W(e,t,!0)},acceptData:function(e){if(e.nodeType&&1!==e.nodeType&&9!==e.nodeType)return!1;var t=e.nodeName&&x.noData[e.nodeName.toLowerCase()];return!t||t!==!0&&e.getAttribute("classid")===t}}),x.fn.extend({data:function(e,n){var r,i,o=null,a=0,s=this[0];if(e===t){if(this.length&&(o=x.data(s),1===s.nodeType&&!x._data(s,"parsedAttrs"))){for(r=s.attributes;r.length>a;a++)i=r[a].name,0===i.indexOf("data-")&&(i=x.camelCase(i.slice(5)),$(s,i,o[i]));x._data(s,"parsedAttrs",!0)}return o}return"object"==typeof e?this.each(function(){x.data(this,e)}):arguments.length>1?this.each(function(){x.data(this,e,n)}):s?$(s,e,x.data(s,e)):null},removeData:function(e){return this.each(function(){x.removeData(this,e)})}});function $(e,n,r){if(r===t&&1===e.nodeType){var i="data-"+n.replace(P,"-$1").toLowerCase();if(r=e.getAttribute(i),"string"==typeof r){try{r="true"===r?!0:"false"===r?!1:"null"===r?null:+r+""===r?+r:B.test(r)?x.parseJSON(r):r}catch(o){}x.data(e,n,r)}else r=t}return r}function I(e){var t;for(t in e)if(("data"!==t||!x.isEmptyObject(e[t]))&&"toJSON"!==t)return!1;return!0}x.extend({queue:function(e,n,r){var i;return e?(n=(n||"fx")+"queue",i=x._data(e,n),r&&(!i||x.isArray(r)?i=x._data(e,n,x.makeArray(r)):i.push(r)),i||[]):t},dequeue:function(e,t){t=t||"fx";var n=x.queue(e,t),r=n.length,i=n.shift(),o=x._queueHooks(e,t),a=function(){x.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return x._data(e,n)||x._data(e,n,{empty:x.Callbacks("once memory").add(function(){x._removeData(e,t+"queue"),x._removeData(e,n)})})}}),x.fn.extend({queue:function(e,n){var r=2;return"string"!=typeof e&&(n=e,e="fx",r--),r>arguments.length?x.queue(this[0],e):n===t?this:this.each(function(){var t=x.queue(this,e,n);x._queueHooks(this,e),"fx"===e&&"inprogress"!==t[0]&&x.dequeue(this,e)})},dequeue:function(e){return this.each(function(){x.dequeue(this,e)})},delay:function(e,t){return e=x.fx?x.fx.speeds[e]||e:e,t=t||"fx",this.queue(t,function(t,n){var r=setTimeout(t,e);n.stop=function(){clearTimeout(r)}})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,n){var r,i=1,o=x.Deferred(),a=this,s=this.length,l=function(){--i||o.resolveWith(a,[a])};"string"!=typeof e&&(n=e,e=t),e=e||"fx";while(s--)r=x._data(a[s],e+"queueHooks"),r&&r.empty&&(i++,r.empty.add(l));return l(),o.promise(n)}});var z,X,U=/[\t\r\n\f]/g,V=/\r/g,Y=/^(?:input|select|textarea|button|object)$/i,J=/^(?:a|area)$/i,G=/^(?:checked|selected)$/i,Q=x.support.getSetAttribute,K=x.support.input;x.fn.extend({attr:function(e,t){return x.access(this,x.attr,e,t,arguments.length>1)},removeAttr:function(e){return this.each(function(){x.removeAttr(this,e)})},prop:function(e,t){return x.access(this,x.prop,e,t,arguments.length>1)},removeProp:function(e){return e=x.propFix[e]||e,this.each(function(){try{this[e]=t,delete this[e]}catch(n){}})},addClass:function(e){var t,n,r,i,o,a=0,s=this.length,l="string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).addClass(e.call(this,t,this.className))});if(l)for(t=(e||"").match(T)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(U," "):" ")){o=0;while(i=t[o++])0>r.indexOf(" "+i+" ")&&(r+=i+" ");n.className=x.trim(r)}return this},removeClass:function(e){var t,n,r,i,o,a=0,s=this.length,l=0===arguments.length||"string"==typeof e&&e;if(x.isFunction(e))return this.each(function(t){x(this).removeClass(e.call(this,t,this.className))});if(l)for(t=(e||"").match(T)||[];s>a;a++)if(n=this[a],r=1===n.nodeType&&(n.className?(" "+n.className+" ").replace(U," "):"")){o=0;while(i=t[o++])while(r.indexOf(" "+i+" ")>=0)r=r.replace(" "+i+" "," ");n.className=e?x.trim(r):""}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):x.isFunction(e)?this.each(function(n){x(this).toggleClass(e.call(this,n,this.className,t),t)}):this.each(function(){if("string"===n){var t,r=0,o=x(this),a=e.match(T)||[];while(t=a[r++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else(n===i||"boolean"===n)&&(this.className&&x._data(this,"__className__",this.className),this.className=this.className||e===!1?"":x._data(this,"__className__")||"")})},hasClass:function(e){var t=" "+e+" ",n=0,r=this.length;for(;r>n;n++)if(1===this[n].nodeType&&(" "+this[n].className+" ").replace(U," ").indexOf(t)>=0)return!0;return!1},val:function(e){var n,r,i,o=this[0];{if(arguments.length)return i=x.isFunction(e),this.each(function(n){var o;1===this.nodeType&&(o=i?e.call(this,n,x(this).val()):e,null==o?o="":"number"==typeof o?o+="":x.isArray(o)&&(o=x.map(o,function(e){return null==e?"":e+""})),r=x.valHooks[this.type]||x.valHooks[this.nodeName.toLowerCase()],r&&"set"in r&&r.set(this,o,"value")!==t||(this.value=o))});if(o)return r=x.valHooks[o.type]||x.valHooks[o.nodeName.toLowerCase()],r&&"get"in r&&(n=r.get(o,"value"))!==t?n:(n=o.value,"string"==typeof n?n.replace(V,""):null==n?"":n)}}}),x.extend({valHooks:{option:{get:function(e){var t=x.find.attr(e,"value");return null!=t?t:e.text}},select:{get:function(e){var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||0>i,a=o?null:[],s=o?i+1:r.length,l=0>i?s:o?i:0;for(;s>l;l++)if(n=r[l],!(!n.selected&&l!==i||(x.support.optDisabled?n.disabled:null!==n.getAttribute("disabled"))||n.parentNode.disabled&&x.nodeName(n.parentNode,"optgroup"))){if(t=x(n).val(),o)return t;a.push(t)}return a},set:function(e,t){var n,r,i=e.options,o=x.makeArray(t),a=i.length;while(a--)r=i[a],(r.selected=x.inArray(x(r).val(),o)>=0)&&(n=!0);return n||(e.selectedIndex=-1),o}}},attr:function(e,n,r){var o,a,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return typeof e.getAttribute===i?x.prop(e,n,r):(1===s&&x.isXMLDoc(e)||(n=n.toLowerCase(),o=x.attrHooks[n]||(x.expr.match.bool.test(n)?X:z)),r===t?o&&"get"in o&&null!==(a=o.get(e,n))?a:(a=x.find.attr(e,n),null==a?t:a):null!==r?o&&"set"in o&&(a=o.set(e,r,n))!==t?a:(e.setAttribute(n,r+""),r):(x.removeAttr(e,n),t))},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(T);if(o&&1===e.nodeType)while(n=o[i++])r=x.propFix[n]||n,x.expr.match.bool.test(n)?K&&Q||!G.test(n)?e[r]=!1:e[x.camelCase("default-"+n)]=e[r]=!1:x.attr(e,n,""),e.removeAttribute(Q?n:r)},attrHooks:{type:{set:function(e,t){if(!x.support.radioValue&&"radio"===t&&x.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},propFix:{"for":"htmlFor","class":"className"},prop:function(e,n,r){var i,o,a,s=e.nodeType;if(e&&3!==s&&8!==s&&2!==s)return a=1!==s||!x.isXMLDoc(e),a&&(n=x.propFix[n]||n,o=x.propHooks[n]),r!==t?o&&"set"in o&&(i=o.set(e,r,n))!==t?i:e[n]=r:o&&"get"in o&&null!==(i=o.get(e,n))?i:e[n]},propHooks:{tabIndex:{get:function(e){var t=x.find.attr(e,"tabindex");return t?parseInt(t,10):Y.test(e.nodeName)||J.test(e.nodeName)&&e.href?0:-1}}}}),X={set:function(e,t,n){return t===!1?x.removeAttr(e,n):K&&Q||!G.test(n)?e.setAttribute(!Q&&x.propFix[n]||n,n):e[x.camelCase("default-"+n)]=e[n]=!0,n}},x.each(x.expr.match.bool.source.match(/\w+/g),function(e,n){var r=x.expr.attrHandle[n]||x.find.attr;x.expr.attrHandle[n]=K&&Q||!G.test(n)?function(e,n,i){var o=x.expr.attrHandle[n],a=i?t:(x.expr.attrHandle[n]=t)!=r(e,n,i)?n.toLowerCase():null;return x.expr.attrHandle[n]=o,a}:function(e,n,r){return r?t:e[x.camelCase("default-"+n)]?n.toLowerCase():null}}),K&&Q||(x.attrHooks.value={set:function(e,n,r){return x.nodeName(e,"input")?(e.defaultValue=n,t):z&&z.set(e,n,r)}}),Q||(z={set:function(e,n,r){var i=e.getAttributeNode(r);return i||e.setAttributeNode(i=e.ownerDocument.createAttribute(r)),i.value=n+="","value"===r||n===e.getAttribute(r)?n:t}},x.expr.attrHandle.id=x.expr.attrHandle.name=x.expr.attrHandle.coords=function(e,n,r){var i;return r?t:(i=e.getAttributeNode(n))&&""!==i.value?i.value:null},x.valHooks.button={get:function(e,n){var r=e.getAttributeNode(n);return r&&r.specified?r.value:t},set:z.set},x.attrHooks.contenteditable={set:function(e,t,n){z.set(e,""===t?!1:t,n)}},x.each(["width","height"],function(e,n){x.attrHooks[n]={set:function(e,r){return""===r?(e.setAttribute(n,"auto"),r):t}}})),x.support.hrefNormalized||x.each(["href","src"],function(e,t){x.propHooks[t]={get:function(e){return e.getAttribute(t,4)}}}),x.support.style||(x.attrHooks.style={get:function(e){return e.style.cssText||t},set:function(e,t){return e.style.cssText=t+""}}),x.support.optSelected||(x.propHooks.selected={get:function(e){var t=e.parentNode;return t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex),null}}),x.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){x.propFix[this.toLowerCase()]=this}),x.support.enctype||(x.propFix.enctype="encoding"),x.each(["radio","checkbox"],function(){x.valHooks[this]={set:function(e,n){return x.isArray(n)?e.checked=x.inArray(x(e).val(),n)>=0:t}},x.support.checkOn||(x.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})});var Z=/^(?:input|select|textarea)$/i,et=/^key/,tt=/^(?:mouse|contextmenu)|click/,nt=/^(?:focusinfocus|focusoutblur)$/,rt=/^([^.]*)(?:\.(.+)|)$/;function it(){return!0}function ot(){return!1}function at(){try{return a.activeElement}catch(e){}}x.event={global:{},add:function(e,n,r,o,a){var s,l,u,c,p,f,d,h,g,m,y,v=x._data(e);if(v){r.handler&&(c=r,r=c.handler,a=c.selector),r.guid||(r.guid=x.guid++),(l=v.events)||(l=v.events={}),(f=v.handle)||(f=v.handle=function(e){return typeof x===i||e&&x.event.triggered===e.type?t:x.event.dispatch.apply(f.elem,arguments)},f.elem=e),n=(n||"").match(T)||[""],u=n.length;while(u--)s=rt.exec(n[u])||[],g=y=s[1],m=(s[2]||"").split(".").sort(),g&&(p=x.event.special[g]||{},g=(a?p.delegateType:p.bindType)||g,p=x.event.special[g]||{},d=x.extend({type:g,origType:y,data:o,handler:r,guid:r.guid,selector:a,needsContext:a&&x.expr.match.needsContext.test(a),namespace:m.join(".")},c),(h=l[g])||(h=l[g]=[],h.delegateCount=0,p.setup&&p.setup.call(e,o,m,f)!==!1||(e.addEventListener?e.addEventListener(g,f,!1):e.attachEvent&&e.attachEvent("on"+g,f))),p.add&&(p.add.call(e,d),d.handler.guid||(d.handler.guid=r.guid)),a?h.splice(h.delegateCount++,0,d):h.push(d),x.event.global[g]=!0);e=null}},remove:function(e,t,n,r,i){var o,a,s,l,u,c,p,f,d,h,g,m=x.hasData(e)&&x._data(e);if(m&&(c=m.events)){t=(t||"").match(T)||[""],u=t.length;while(u--)if(s=rt.exec(t[u])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){p=x.event.special[d]||{},d=(r?p.delegateType:p.bindType)||d,f=c[d]||[],s=s[2]&&RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),l=o=f.length;while(o--)a=f[o],!i&&g!==a.origType||n&&n.guid!==a.guid||s&&!s.test(a.namespace)||r&&r!==a.selector&&("**"!==r||!a.selector)||(f.splice(o,1),a.selector&&f.delegateCount--,p.remove&&p.remove.call(e,a));l&&!f.length&&(p.teardown&&p.teardown.call(e,h,m.handle)!==!1||x.removeEvent(e,d,m.handle),delete c[d])}else for(d in c)x.event.remove(e,d+t[u],n,r,!0);x.isEmptyObject(c)&&(delete m.handle,x._removeData(e,"events"))}},trigger:function(n,r,i,o){var s,l,u,c,p,f,d,h=[i||a],g=v.call(n,"type")?n.type:n,m=v.call(n,"namespace")?n.namespace.split("."):[];if(u=f=i=i||a,3!==i.nodeType&&8!==i.nodeType&&!nt.test(g+x.event.triggered)&&(g.indexOf(".")>=0&&(m=g.split("."),g=m.shift(),m.sort()),l=0>g.indexOf(":")&&"on"+g,n=n[x.expando]?n:new x.Event(g,"object"==typeof n&&n),n.isTrigger=o?2:3,n.namespace=m.join("."),n.namespace_re=n.namespace?RegExp("(^|\\.)"+m.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,n.result=t,n.target||(n.target=i),r=null==r?[n]:x.makeArray(r,[n]),p=x.event.special[g]||{},o||!p.trigger||p.trigger.apply(i,r)!==!1)){if(!o&&!p.noBubble&&!x.isWindow(i)){for(c=p.delegateType||g,nt.test(c+g)||(u=u.parentNode);u;u=u.parentNode)h.push(u),f=u;f===(i.ownerDocument||a)&&h.push(f.defaultView||f.parentWindow||e)}d=0;while((u=h[d++])&&!n.isPropagationStopped())n.type=d>1?c:p.bindType||g,s=(x._data(u,"events")||{})[n.type]&&x._data(u,"handle"),s&&s.apply(u,r),s=l&&u[l],s&&x.acceptData(u)&&s.apply&&s.apply(u,r)===!1&&n.preventDefault();if(n.type=g,!o&&!n.isDefaultPrevented()&&(!p._default||p._default.apply(h.pop(),r)===!1)&&x.acceptData(i)&&l&&i[g]&&!x.isWindow(i)){f=i[l],f&&(i[l]=null),x.event.triggered=g;try{i[g]()}catch(y){}x.event.triggered=t,f&&(i[l]=f)}return n.result}},dispatch:function(e){e=x.event.fix(e);var n,r,i,o,a,s=[],l=g.call(arguments),u=(x._data(this,"events")||{})[e.type]||[],c=x.event.special[e.type]||{};if(l[0]=e,e.delegateTarget=this,!c.preDispatch||c.preDispatch.call(this,e)!==!1){s=x.event.handlers.call(this,e,u),n=0;while((o=s[n++])&&!e.isPropagationStopped()){e.currentTarget=o.elem,a=0;while((i=o.handlers[a++])&&!e.isImmediatePropagationStopped())(!e.namespace_re||e.namespace_re.test(i.namespace))&&(e.handleObj=i,e.data=i.data,r=((x.event.special[i.origType]||{}).handle||i.handler).apply(o.elem,l),r!==t&&(e.result=r)===!1&&(e.preventDefault(),e.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,e),e.result}},handlers:function(e,n){var r,i,o,a,s=[],l=n.delegateCount,u=e.target;if(l&&u.nodeType&&(!e.button||"click"!==e.type))for(;u!=this;u=u.parentNode||this)if(1===u.nodeType&&(u.disabled!==!0||"click"!==e.type)){for(o=[],a=0;l>a;a++)i=n[a],r=i.selector+" ",o[r]===t&&(o[r]=i.needsContext?x(r,this).index(u)>=0:x.find(r,this,null,[u]).length),o[r]&&o.push(i);o.length&&s.push({elem:u,handlers:o})}return n.length>l&&s.push({elem:this,handlers:n.slice(l)}),s},fix:function(e){if(e[x.expando])return e;var t,n,r,i=e.type,o=e,s=this.fixHooks[i];s||(this.fixHooks[i]=s=tt.test(i)?this.mouseHooks:et.test(i)?this.keyHooks:{}),r=s.props?this.props.concat(s.props):this.props,e=new x.Event(o),t=r.length;while(t--)n=r[t],e[n]=o[n];return e.target||(e.target=o.srcElement||a),3===e.target.nodeType&&(e.target=e.target.parentNode),e.metaKey=!!e.metaKey,s.filter?s.filter(e,o):e},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(e,t){return null==e.which&&(e.which=null!=t.charCode?t.charCode:t.keyCode),e}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(e,n){var r,i,o,s=n.button,l=n.fromElement;return null==e.pageX&&null!=n.clientX&&(i=e.target.ownerDocument||a,o=i.documentElement,r=i.body,e.pageX=n.clientX+(o&&o.scrollLeft||r&&r.scrollLeft||0)-(o&&o.clientLeft||r&&r.clientLeft||0),e.pageY=n.clientY+(o&&o.scrollTop||r&&r.scrollTop||0)-(o&&o.clientTop||r&&r.clientTop||0)),!e.relatedTarget&&l&&(e.relatedTarget=l===e.target?n.toElement:l),e.which||s===t||(e.which=1&s?1:2&s?3:4&s?2:0),e}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==at()&&this.focus)try{return this.focus(),!1}catch(e){}},delegateType:"focusin"},blur:{trigger:function(){return this===at()&&this.blur?(this.blur(),!1):t},delegateType:"focusout"},click:{trigger:function(){return x.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):t},_default:function(e){return x.nodeName(e.target,"a")}},beforeunload:{postDispatch:function(e){e.result!==t&&(e.originalEvent.returnValue=e.result)}}},simulate:function(e,t,n,r){var i=x.extend(new x.Event,n,{type:e,isSimulated:!0,originalEvent:{}});r?x.event.trigger(i,null,t):x.event.dispatch.call(t,i),i.isDefaultPrevented()&&n.preventDefault()}},x.removeEvent=a.removeEventListener?function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n,!1)}:function(e,t,n){var r="on"+t;e.detachEvent&&(typeof e[r]===i&&(e[r]=null),e.detachEvent(r,n))},x.Event=function(e,n){return this instanceof x.Event?(e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||e.returnValue===!1||e.getPreventDefault&&e.getPreventDefault()?it:ot):this.type=e,n&&x.extend(this,n),this.timeStamp=e&&e.timeStamp||x.now(),this[x.expando]=!0,t):new x.Event(e,n)},x.Event.prototype={isDefaultPrevented:ot,isPropagationStopped:ot,isImmediatePropagationStopped:ot,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=it,e&&(e.preventDefault?e.preventDefault():e.returnValue=!1)},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=it,e&&(e.stopPropagation&&e.stopPropagation(),e.cancelBubble=!0)},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=it,this.stopPropagation()}},x.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(e,t){x.event.special[e]={delegateType:t,bindType:t,handle:function(e){var n,r=this,i=e.relatedTarget,o=e.handleObj;return(!i||i!==r&&!x.contains(r,i))&&(e.type=o.origType,n=o.handler.apply(this,arguments),e.type=t),n}}}),x.support.submitBubbles||(x.event.special.submit={setup:function(){return x.nodeName(this,"form")?!1:(x.event.add(this,"click._submit keypress._submit",function(e){var n=e.target,r=x.nodeName(n,"input")||x.nodeName(n,"button")?n.form:t;r&&!x._data(r,"submitBubbles")&&(x.event.add(r,"submit._submit",function(e){e._submit_bubble=!0}),x._data(r,"submitBubbles",!0))}),t)},postDispatch:function(e){e._submit_bubble&&(delete e._submit_bubble,this.parentNode&&!e.isTrigger&&x.event.simulate("submit",this.parentNode,e,!0))},teardown:function(){return x.nodeName(this,"form")?!1:(x.event.remove(this,"._submit"),t)}}),x.support.changeBubbles||(x.event.special.change={setup:function(){return Z.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(x.event.add(this,"propertychange._change",function(e){"checked"===e.originalEvent.propertyName&&(this._just_changed=!0)}),x.event.add(this,"click._change",function(e){this._just_changed&&!e.isTrigger&&(this._just_changed=!1),x.event.simulate("change",this,e,!0)})),!1):(x.event.add(this,"beforeactivate._change",function(e){var t=e.target;Z.test(t.nodeName)&&!x._data(t,"changeBubbles")&&(x.event.add(t,"change._change",function(e){!this.parentNode||e.isSimulated||e.isTrigger||x.event.simulate("change",this.parentNode,e,!0)}),x._data(t,"changeBubbles",!0))}),t)},handle:function(e){var n=e.target;return this!==n||e.isSimulated||e.isTrigger||"radio"!==n.type&&"checkbox"!==n.type?e.handleObj.handler.apply(this,arguments):t},teardown:function(){return x.event.remove(this,"._change"),!Z.test(this.nodeName)}}),x.support.focusinBubbles||x.each({focus:"focusin",blur:"focusout"},function(e,t){var n=0,r=function(e){x.event.simulate(t,e.target,x.event.fix(e),!0)};x.event.special[t]={setup:function(){0===n++&&a.addEventListener(e,r,!0)},teardown:function(){0===--n&&a.removeEventListener(e,r,!0)}}}),x.fn.extend({on:function(e,n,r,i,o){var a,s;if("object"==typeof e){"string"!=typeof n&&(r=r||n,n=t);for(a in e)this.on(a,n,r,e[a],o);return this}if(null==r&&null==i?(i=n,r=n=t):null==i&&("string"==typeof n?(i=r,r=t):(i=r,r=n,n=t)),i===!1)i=ot;else if(!i)return this;return 1===o&&(s=i,i=function(e){return x().off(e),s.apply(this,arguments)},i.guid=s.guid||(s.guid=x.guid++)),this.each(function(){x.event.add(this,e,i,r,n)})},one:function(e,t,n,r){return this.on(e,t,n,r,1)},off:function(e,n,r){var i,o;if(e&&e.preventDefault&&e.handleObj)return i=e.handleObj,x(e.delegateTarget).off(i.namespace?i.origType+"."+i.namespace:i.origType,i.selector,i.handler),this;if("object"==typeof e){for(o in e)this.off(o,n,e[o]);return this}return(n===!1||"function"==typeof n)&&(r=n,n=t),r===!1&&(r=ot),this.each(function(){x.event.remove(this,e,r,n)})},trigger:function(e,t){return this.each(function(){x.event.trigger(e,t,this)})},triggerHandler:function(e,n){var r=this[0];return r?x.event.trigger(e,n,r,!0):t}});var st=/^.[^:#\[\.,]*$/,lt=/^(?:parents|prev(?:Until|All))/,ut=x.expr.match.needsContext,ct={children:!0,contents:!0,next:!0,prev:!0};x.fn.extend({find:function(e){var t,n=[],r=this,i=r.length;if("string"!=typeof e)return this.pushStack(x(e).filter(function(){for(t=0;i>t;t++)if(x.contains(r[t],this))return!0}));for(t=0;i>t;t++)x.find(e,r[t],n);return n=this.pushStack(i>1?x.unique(n):n),n.selector=this.selector?this.selector+" "+e:e,n},has:function(e){var t,n=x(e,this),r=n.length;return this.filter(function(){for(t=0;r>t;t++)if(x.contains(this,n[t]))return!0})},not:function(e){return this.pushStack(ft(this,e||[],!0))},filter:function(e){return this.pushStack(ft(this,e||[],!1))},is:function(e){return!!ft(this,"string"==typeof e&&ut.test(e)?x(e):e||[],!1).length},closest:function(e,t){var n,r=0,i=this.length,o=[],a=ut.test(e)||"string"!=typeof e?x(e,t||this.context):0;for(;i>r;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(11>n.nodeType&&(a?a.index(n)>-1:1===n.nodeType&&x.find.matchesSelector(n,e))){n=o.push(n);break}return this.pushStack(o.length>1?x.unique(o):o)},index:function(e){return e?"string"==typeof e?x.inArray(this[0],x(e)):x.inArray(e.jquery?e[0]:e,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){var n="string"==typeof e?x(e,t):x.makeArray(e&&e.nodeType?[e]:e),r=x.merge(this.get(),n);return this.pushStack(x.unique(r))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function pt(e,t){do e=e[t];while(e&&1!==e.nodeType);return e}x.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return x.dir(e,"parentNode")},parentsUntil:function(e,t,n){return x.dir(e,"parentNode",n)},next:function(e){return pt(e,"nextSibling")},prev:function(e){return pt(e,"previousSibling")},nextAll:function(e){return x.dir(e,"nextSibling")},prevAll:function(e){return x.dir(e,"previousSibling")},nextUntil:function(e,t,n){return x.dir(e,"nextSibling",n)},prevUntil:function(e,t,n){return x.dir(e,"previousSibling",n)},siblings:function(e){return x.sibling((e.parentNode||{}).firstChild,e)},children:function(e){return x.sibling(e.firstChild)},contents:function(e){return x.nodeName(e,"iframe")?e.contentDocument||e.contentWindow.document:x.merge([],e.childNodes)}},function(e,t){x.fn[e]=function(n,r){var i=x.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=x.filter(r,i)),this.length>1&&(ct[e]||(i=x.unique(i)),lt.test(e)&&(i=i.reverse())),this.pushStack(i)}}),x.extend({filter:function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?x.find.matchesSelector(r,e)?[r]:[]:x.find.matches(e,x.grep(t,function(e){return 1===e.nodeType}))},dir:function(e,n,r){var i=[],o=e[n];while(o&&9!==o.nodeType&&(r===t||1!==o.nodeType||!x(o).is(r)))1===o.nodeType&&i.push(o),o=o[n];return i},sibling:function(e,t){var n=[];for(;e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n}});function ft(e,t,n){if(x.isFunction(t))return x.grep(e,function(e,r){return!!t.call(e,r,e)!==n});if(t.nodeType)return x.grep(e,function(e){return e===t!==n});if("string"==typeof t){if(st.test(t))return x.filter(t,e,n);t=x.filter(t,e)}return x.grep(e,function(e){return x.inArray(e,t)>=0!==n})}function dt(e){var t=ht.split("|"),n=e.createDocumentFragment();if(n.createElement)while(t.length)n.createElement(t.pop());return n}var ht="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",gt=/ jQuery\d+="(?:null|\d+)"/g,mt=RegExp("<(?:"+ht+")[\\s/>]","i"),yt=/^\s+/,vt=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,bt=/<([\w:]+)/,xt=/<tbody/i,wt=/<|&#?\w+;/,Tt=/<(?:script|style|link)/i,Ct=/^(?:checkbox|radio)$/i,Nt=/checked\s*(?:[^=]|=\s*.checked.)/i,kt=/^$|\/(?:java|ecma)script/i,Et=/^true\/(.*)/,St=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,At={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:x.support.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},jt=dt(a),Dt=jt.appendChild(a.createElement("div"));At.optgroup=At.option,At.tbody=At.tfoot=At.colgroup=At.caption=At.thead,At.th=At.td,x.fn.extend({text:function(e){return x.access(this,function(e){return e===t?x.text(this):this.empty().append((this[0]&&this[0].ownerDocument||a).createTextNode(e))},null,e,arguments.length)},append:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Lt(this,e);t.appendChild(e)}})},prepend:function(){return this.domManip(arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Lt(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return this.domManip(arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},remove:function(e,t){var n,r=e?x.filter(e,this):this,i=0;for(;null!=(n=r[i]);i++)t||1!==n.nodeType||x.cleanData(Ft(n)),n.parentNode&&(t&&x.contains(n.ownerDocument,n)&&_t(Ft(n,"script")),n.parentNode.removeChild(n));return this},empty:function(){var e,t=0;for(;null!=(e=this[t]);t++){1===e.nodeType&&x.cleanData(Ft(e,!1));while(e.firstChild)e.removeChild(e.firstChild);e.options&&x.nodeName(e,"select")&&(e.options.length=0)}return this},clone:function(e,t){return e=null==e?!1:e,t=null==t?e:t,this.map(function(){return x.clone(this,e,t)})},html:function(e){return x.access(this,function(e){var n=this[0]||{},r=0,i=this.length;if(e===t)return 1===n.nodeType?n.innerHTML.replace(gt,""):t;if(!("string"!=typeof e||Tt.test(e)||!x.support.htmlSerialize&&mt.test(e)||!x.support.leadingWhitespace&&yt.test(e)||At[(bt.exec(e)||["",""])[1].toLowerCase()])){e=e.replace(vt,"<$1></$2>");try{for(;i>r;r++)n=this[r]||{},1===n.nodeType&&(x.cleanData(Ft(n,!1)),n.innerHTML=e);n=0}catch(o){}}n&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var e=x.map(this,function(e){return[e.nextSibling,e.parentNode]}),t=0;return this.domManip(arguments,function(n){var r=e[t++],i=e[t++];i&&(r&&r.parentNode!==i&&(r=this.nextSibling),x(this).remove(),i.insertBefore(n,r))},!0),t?this:this.remove()},detach:function(e){return this.remove(e,!0)},domManip:function(e,t,n){e=d.apply([],e);var r,i,o,a,s,l,u=0,c=this.length,p=this,f=c-1,h=e[0],g=x.isFunction(h);if(g||!(1>=c||"string"!=typeof h||x.support.checkClone)&&Nt.test(h))return this.each(function(r){var i=p.eq(r);g&&(e[0]=h.call(this,r,i.html())),i.domManip(e,t,n)});if(c&&(l=x.buildFragment(e,this[0].ownerDocument,!1,!n&&this),r=l.firstChild,1===l.childNodes.length&&(l=r),r)){for(a=x.map(Ft(l,"script"),Ht),o=a.length;c>u;u++)i=l,u!==f&&(i=x.clone(i,!0,!0),o&&x.merge(a,Ft(i,"script"))),t.call(this[u],i,u);if(o)for(s=a[a.length-1].ownerDocument,x.map(a,qt),u=0;o>u;u++)i=a[u],kt.test(i.type||"")&&!x._data(i,"globalEval")&&x.contains(s,i)&&(i.src?x._evalUrl(i.src):x.globalEval((i.text||i.textContent||i.innerHTML||"").replace(St,"")));l=r=null}return this}});function Lt(e,t){return x.nodeName(e,"table")&&x.nodeName(1===t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function Ht(e){return e.type=(null!==x.find.attr(e,"type"))+"/"+e.type,e}function qt(e){var t=Et.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function _t(e,t){var n,r=0;for(;null!=(n=e[r]);r++)x._data(n,"globalEval",!t||x._data(t[r],"globalEval"))}function Mt(e,t){if(1===t.nodeType&&x.hasData(e)){var n,r,i,o=x._data(e),a=x._data(t,o),s=o.events;if(s){delete a.handle,a.events={};for(n in s)for(r=0,i=s[n].length;i>r;r++)x.event.add(t,n,s[n][r])}a.data&&(a.data=x.extend({},a.data))}}function Ot(e,t){var n,r,i;if(1===t.nodeType){if(n=t.nodeName.toLowerCase(),!x.support.noCloneEvent&&t[x.expando]){i=x._data(t);for(r in i.events)x.removeEvent(t,r,i.handle);t.removeAttribute(x.expando)}"script"===n&&t.text!==e.text?(Ht(t).text=e.text,qt(t)):"object"===n?(t.parentNode&&(t.outerHTML=e.outerHTML),x.support.html5Clone&&e.innerHTML&&!x.trim(t.innerHTML)&&(t.innerHTML=e.innerHTML)):"input"===n&&Ct.test(e.type)?(t.defaultChecked=t.checked=e.checked,t.value!==e.value&&(t.value=e.value)):"option"===n?t.defaultSelected=t.selected=e.defaultSelected:("input"===n||"textarea"===n)&&(t.defaultValue=e.defaultValue)}}x.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,t){x.fn[e]=function(e){var n,r=0,i=[],o=x(e),a=o.length-1;for(;a>=r;r++)n=r===a?this:this.clone(!0),x(o[r])[t](n),h.apply(i,n.get());return this.pushStack(i)}});function Ft(e,n){var r,o,a=0,s=typeof e.getElementsByTagName!==i?e.getElementsByTagName(n||"*"):typeof e.querySelectorAll!==i?e.querySelectorAll(n||"*"):t;if(!s)for(s=[],r=e.childNodes||e;null!=(o=r[a]);a++)!n||x.nodeName(o,n)?s.push(o):x.merge(s,Ft(o,n));return n===t||n&&x.nodeName(e,n)?x.merge([e],s):s}function Bt(e){Ct.test(e.type)&&(e.defaultChecked=e.checked)}x.extend({clone:function(e,t,n){var r,i,o,a,s,l=x.contains(e.ownerDocument,e);if(x.support.html5Clone||x.isXMLDoc(e)||!mt.test("<"+e.nodeName+">")?o=e.cloneNode(!0):(Dt.innerHTML=e.outerHTML,Dt.removeChild(o=Dt.firstChild)),!(x.support.noCloneEvent&&x.support.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||x.isXMLDoc(e)))for(r=Ft(o),s=Ft(e),a=0;null!=(i=s[a]);++a)r[a]&&Ot(i,r[a]);if(t)if(n)for(s=s||Ft(e),r=r||Ft(o),a=0;null!=(i=s[a]);a++)Mt(i,r[a]);else Mt(e,o);return r=Ft(o,"script"),r.length>0&&_t(r,!l&&Ft(e,"script")),r=s=i=null,o},buildFragment:function(e,t,n,r){var i,o,a,s,l,u,c,p=e.length,f=dt(t),d=[],h=0;for(;p>h;h++)if(o=e[h],o||0===o)if("object"===x.type(o))x.merge(d,o.nodeType?[o]:o);else if(wt.test(o)){s=s||f.appendChild(t.createElement("div")),l=(bt.exec(o)||["",""])[1].toLowerCase(),c=At[l]||At._default,s.innerHTML=c[1]+o.replace(vt,"<$1></$2>")+c[2],i=c[0];while(i--)s=s.lastChild;if(!x.support.leadingWhitespace&&yt.test(o)&&d.push(t.createTextNode(yt.exec(o)[0])),!x.support.tbody){o="table"!==l||xt.test(o)?"<table>"!==c[1]||xt.test(o)?0:s:s.firstChild,i=o&&o.childNodes.length;while(i--)x.nodeName(u=o.childNodes[i],"tbody")&&!u.childNodes.length&&o.removeChild(u)}x.merge(d,s.childNodes),s.textContent="";while(s.firstChild)s.removeChild(s.firstChild);s=f.lastChild}else d.push(t.createTextNode(o));s&&f.removeChild(s),x.support.appendChecked||x.grep(Ft(d,"input"),Bt),h=0;while(o=d[h++])if((!r||-1===x.inArray(o,r))&&(a=x.contains(o.ownerDocument,o),s=Ft(f.appendChild(o),"script"),a&&_t(s),n)){i=0;while(o=s[i++])kt.test(o.type||"")&&n.push(o)}return s=null,f},cleanData:function(e,t){var n,r,o,a,s=0,l=x.expando,u=x.cache,c=x.support.deleteExpando,f=x.event.special;for(;null!=(n=e[s]);s++)if((t||x.acceptData(n))&&(o=n[l],a=o&&u[o])){if(a.events)for(r in a.events)f[r]?x.event.remove(n,r):x.removeEvent(n,r,a.handle); -u[o]&&(delete u[o],c?delete n[l]:typeof n.removeAttribute!==i?n.removeAttribute(l):n[l]=null,p.push(o))}},_evalUrl:function(e){return x.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})}}),x.fn.extend({wrapAll:function(e){if(x.isFunction(e))return this.each(function(t){x(this).wrapAll(e.call(this,t))});if(this[0]){var t=x(e,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstChild&&1===e.firstChild.nodeType)e=e.firstChild;return e}).append(this)}return this},wrapInner:function(e){return x.isFunction(e)?this.each(function(t){x(this).wrapInner(e.call(this,t))}):this.each(function(){var t=x(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=x.isFunction(e);return this.each(function(n){x(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(){return this.parent().each(function(){x.nodeName(this,"body")||x(this).replaceWith(this.childNodes)}).end()}});var Pt,Rt,Wt,$t=/alpha\([^)]*\)/i,It=/opacity\s*=\s*([^)]*)/,zt=/^(top|right|bottom|left)$/,Xt=/^(none|table(?!-c[ea]).+)/,Ut=/^margin/,Vt=RegExp("^("+w+")(.*)$","i"),Yt=RegExp("^("+w+")(?!px)[a-z%]+$","i"),Jt=RegExp("^([+-])=("+w+")","i"),Gt={BODY:"block"},Qt={position:"absolute",visibility:"hidden",display:"block"},Kt={letterSpacing:0,fontWeight:400},Zt=["Top","Right","Bottom","Left"],en=["Webkit","O","Moz","ms"];function tn(e,t){if(t in e)return t;var n=t.charAt(0).toUpperCase()+t.slice(1),r=t,i=en.length;while(i--)if(t=en[i]+n,t in e)return t;return r}function nn(e,t){return e=t||e,"none"===x.css(e,"display")||!x.contains(e.ownerDocument,e)}function rn(e,t){var n,r,i,o=[],a=0,s=e.length;for(;s>a;a++)r=e[a],r.style&&(o[a]=x._data(r,"olddisplay"),n=r.style.display,t?(o[a]||"none"!==n||(r.style.display=""),""===r.style.display&&nn(r)&&(o[a]=x._data(r,"olddisplay",ln(r.nodeName)))):o[a]||(i=nn(r),(n&&"none"!==n||!i)&&x._data(r,"olddisplay",i?n:x.css(r,"display"))));for(a=0;s>a;a++)r=e[a],r.style&&(t&&"none"!==r.style.display&&""!==r.style.display||(r.style.display=t?o[a]||"":"none"));return e}x.fn.extend({css:function(e,n){return x.access(this,function(e,n,r){var i,o,a={},s=0;if(x.isArray(n)){for(o=Rt(e),i=n.length;i>s;s++)a[n[s]]=x.css(e,n[s],!1,o);return a}return r!==t?x.style(e,n,r):x.css(e,n)},e,n,arguments.length>1)},show:function(){return rn(this,!0)},hide:function(){return rn(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){nn(this)?x(this).show():x(this).hide()})}}),x.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Wt(e,"opacity");return""===n?"1":n}}}},cssNumber:{columnCount:!0,fillOpacity:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":x.support.cssFloat?"cssFloat":"styleFloat"},style:function(e,n,r,i){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var o,a,s,l=x.camelCase(n),u=e.style;if(n=x.cssProps[l]||(x.cssProps[l]=tn(u,l)),s=x.cssHooks[n]||x.cssHooks[l],r===t)return s&&"get"in s&&(o=s.get(e,!1,i))!==t?o:u[n];if(a=typeof r,"string"===a&&(o=Jt.exec(r))&&(r=(o[1]+1)*o[2]+parseFloat(x.css(e,n)),a="number"),!(null==r||"number"===a&&isNaN(r)||("number"!==a||x.cssNumber[l]||(r+="px"),x.support.clearCloneStyle||""!==r||0!==n.indexOf("background")||(u[n]="inherit"),s&&"set"in s&&(r=s.set(e,r,i))===t)))try{u[n]=r}catch(c){}}},css:function(e,n,r,i){var o,a,s,l=x.camelCase(n);return n=x.cssProps[l]||(x.cssProps[l]=tn(e.style,l)),s=x.cssHooks[n]||x.cssHooks[l],s&&"get"in s&&(a=s.get(e,!0,r)),a===t&&(a=Wt(e,n,i)),"normal"===a&&n in Kt&&(a=Kt[n]),""===r||r?(o=parseFloat(a),r===!0||x.isNumeric(o)?o||0:a):a}}),e.getComputedStyle?(Rt=function(t){return e.getComputedStyle(t,null)},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),l=s?s.getPropertyValue(n)||s[n]:t,u=e.style;return s&&(""!==l||x.contains(e.ownerDocument,e)||(l=x.style(e,n)),Yt.test(l)&&Ut.test(n)&&(i=u.width,o=u.minWidth,a=u.maxWidth,u.minWidth=u.maxWidth=u.width=l,l=s.width,u.width=i,u.minWidth=o,u.maxWidth=a)),l}):a.documentElement.currentStyle&&(Rt=function(e){return e.currentStyle},Wt=function(e,n,r){var i,o,a,s=r||Rt(e),l=s?s[n]:t,u=e.style;return null==l&&u&&u[n]&&(l=u[n]),Yt.test(l)&&!zt.test(n)&&(i=u.left,o=e.runtimeStyle,a=o&&o.left,a&&(o.left=e.currentStyle.left),u.left="fontSize"===n?"1em":l,l=u.pixelLeft+"px",u.left=i,a&&(o.left=a)),""===l?"auto":l});function on(e,t,n){var r=Vt.exec(t);return r?Math.max(0,r[1]-(n||0))+(r[2]||"px"):t}function an(e,t,n,r,i){var o=n===(r?"border":"content")?4:"width"===t?1:0,a=0;for(;4>o;o+=2)"margin"===n&&(a+=x.css(e,n+Zt[o],!0,i)),r?("content"===n&&(a-=x.css(e,"padding"+Zt[o],!0,i)),"margin"!==n&&(a-=x.css(e,"border"+Zt[o]+"Width",!0,i))):(a+=x.css(e,"padding"+Zt[o],!0,i),"padding"!==n&&(a+=x.css(e,"border"+Zt[o]+"Width",!0,i)));return a}function sn(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=Rt(e),a=x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,o);if(0>=i||null==i){if(i=Wt(e,t,o),(0>i||null==i)&&(i=e.style[t]),Yt.test(i))return i;r=a&&(x.support.boxSizingReliable||i===e.style[t]),i=parseFloat(i)||0}return i+an(e,t,n||(a?"border":"content"),r,o)+"px"}function ln(e){var t=a,n=Gt[e];return n||(n=un(e,t),"none"!==n&&n||(Pt=(Pt||x("<iframe frameborder='0' width='0' height='0'/>").css("cssText","display:block !important")).appendTo(t.documentElement),t=(Pt[0].contentWindow||Pt[0].contentDocument).document,t.write("<!doctype html><html><body>"),t.close(),n=un(e,t),Pt.detach()),Gt[e]=n),n}function un(e,t){var n=x(t.createElement(e)).appendTo(t.body),r=x.css(n[0],"display");return n.remove(),r}x.each(["height","width"],function(e,n){x.cssHooks[n]={get:function(e,r,i){return r?0===e.offsetWidth&&Xt.test(x.css(e,"display"))?x.swap(e,Qt,function(){return sn(e,n,i)}):sn(e,n,i):t},set:function(e,t,r){var i=r&&Rt(e);return on(e,t,r?an(e,n,r,x.support.boxSizing&&"border-box"===x.css(e,"boxSizing",!1,i),i):0)}}}),x.support.opacity||(x.cssHooks.opacity={get:function(e,t){return It.test((t&&e.currentStyle?e.currentStyle.filter:e.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":t?"1":""},set:function(e,t){var n=e.style,r=e.currentStyle,i=x.isNumeric(t)?"alpha(opacity="+100*t+")":"",o=r&&r.filter||n.filter||"";n.zoom=1,(t>=1||""===t)&&""===x.trim(o.replace($t,""))&&n.removeAttribute&&(n.removeAttribute("filter"),""===t||r&&!r.filter)||(n.filter=$t.test(o)?o.replace($t,i):o+" "+i)}}),x(function(){x.support.reliableMarginRight||(x.cssHooks.marginRight={get:function(e,n){return n?x.swap(e,{display:"inline-block"},Wt,[e,"marginRight"]):t}}),!x.support.pixelPosition&&x.fn.position&&x.each(["top","left"],function(e,n){x.cssHooks[n]={get:function(e,r){return r?(r=Wt(e,n),Yt.test(r)?x(e).position()[n]+"px":r):t}}})}),x.expr&&x.expr.filters&&(x.expr.filters.hidden=function(e){return 0>=e.offsetWidth&&0>=e.offsetHeight||!x.support.reliableHiddenOffsets&&"none"===(e.style&&e.style.display||x.css(e,"display"))},x.expr.filters.visible=function(e){return!x.expr.filters.hidden(e)}),x.each({margin:"",padding:"",border:"Width"},function(e,t){x.cssHooks[e+t]={expand:function(n){var r=0,i={},o="string"==typeof n?n.split(" "):[n];for(;4>r;r++)i[e+Zt[r]+t]=o[r]||o[r-2]||o[0];return i}},Ut.test(e)||(x.cssHooks[e+t].set=on)});var cn=/%20/g,pn=/\[\]$/,fn=/\r?\n/g,dn=/^(?:submit|button|image|reset|file)$/i,hn=/^(?:input|select|textarea|keygen)/i;x.fn.extend({serialize:function(){return x.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=x.prop(this,"elements");return e?x.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!x(this).is(":disabled")&&hn.test(this.nodeName)&&!dn.test(e)&&(this.checked||!Ct.test(e))}).map(function(e,t){var n=x(this).val();return null==n?null:x.isArray(n)?x.map(n,function(e){return{name:t.name,value:e.replace(fn,"\r\n")}}):{name:t.name,value:n.replace(fn,"\r\n")}}).get()}}),x.param=function(e,n){var r,i=[],o=function(e,t){t=x.isFunction(t)?t():null==t?"":t,i[i.length]=encodeURIComponent(e)+"="+encodeURIComponent(t)};if(n===t&&(n=x.ajaxSettings&&x.ajaxSettings.traditional),x.isArray(e)||e.jquery&&!x.isPlainObject(e))x.each(e,function(){o(this.name,this.value)});else for(r in e)gn(r,e[r],n,o);return i.join("&").replace(cn,"+")};function gn(e,t,n,r){var i;if(x.isArray(t))x.each(t,function(t,i){n||pn.test(e)?r(e,i):gn(e+"["+("object"==typeof i?t:"")+"]",i,n,r)});else if(n||"object"!==x.type(t))r(e,t);else for(i in t)gn(e+"["+i+"]",t[i],n,r)}x.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(e,t){x.fn[t]=function(e,n){return arguments.length>0?this.on(t,null,e,n):this.trigger(t)}}),x.fn.extend({hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)},bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)}});var mn,yn,vn=x.now(),bn=/\?/,xn=/#.*$/,wn=/([?&])_=[^&]*/,Tn=/^(.*?):[ \t]*([^\r\n]*)\r?$/gm,Cn=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Nn=/^(?:GET|HEAD)$/,kn=/^\/\//,En=/^([\w.+-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,Sn=x.fn.load,An={},jn={},Dn="*/".concat("*");try{yn=o.href}catch(Ln){yn=a.createElement("a"),yn.href="",yn=yn.href}mn=En.exec(yn.toLowerCase())||[];function Hn(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(T)||[];if(x.isFunction(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function qn(e,n,r,i){var o={},a=e===jn;function s(l){var u;return o[l]=!0,x.each(e[l]||[],function(e,l){var c=l(n,r,i);return"string"!=typeof c||a||o[c]?a?!(u=c):t:(n.dataTypes.unshift(c),s(c),!1)}),u}return s(n.dataTypes[0])||!o["*"]&&s("*")}function _n(e,n){var r,i,o=x.ajaxSettings.flatOptions||{};for(i in n)n[i]!==t&&((o[i]?e:r||(r={}))[i]=n[i]);return r&&x.extend(!0,e,r),e}x.fn.load=function(e,n,r){if("string"!=typeof e&&Sn)return Sn.apply(this,arguments);var i,o,a,s=this,l=e.indexOf(" ");return l>=0&&(i=e.slice(l,e.length),e=e.slice(0,l)),x.isFunction(n)?(r=n,n=t):n&&"object"==typeof n&&(a="POST"),s.length>0&&x.ajax({url:e,type:a,dataType:"html",data:n}).done(function(e){o=arguments,s.html(i?x("<div>").append(x.parseHTML(e)).find(i):e)}).complete(r&&function(e,t){s.each(r,o||[e.responseText,t,e])}),this},x.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){x.fn[t]=function(e){return this.on(t,e)}}),x.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:yn,type:"GET",isLocal:Cn.test(mn[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Dn,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":x.parseJSON,"text xml":x.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?_n(_n(e,x.ajaxSettings),t):_n(x.ajaxSettings,e)},ajaxPrefilter:Hn(An),ajaxTransport:Hn(jn),ajax:function(e,n){"object"==typeof e&&(n=e,e=t),n=n||{};var r,i,o,a,s,l,u,c,p=x.ajaxSetup({},n),f=p.context||p,d=p.context&&(f.nodeType||f.jquery)?x(f):x.event,h=x.Deferred(),g=x.Callbacks("once memory"),m=p.statusCode||{},y={},v={},b=0,w="canceled",C={readyState:0,getResponseHeader:function(e){var t;if(2===b){if(!c){c={};while(t=Tn.exec(a))c[t[1].toLowerCase()]=t[2]}t=c[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===b?a:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return b||(e=v[n]=v[n]||e,y[e]=t),this},overrideMimeType:function(e){return b||(p.mimeType=e),this},statusCode:function(e){var t;if(e)if(2>b)for(t in e)m[t]=[m[t],e[t]];else C.always(e[C.status]);return this},abort:function(e){var t=e||w;return u&&u.abort(t),k(0,t),this}};if(h.promise(C).complete=g.add,C.success=C.done,C.error=C.fail,p.url=((e||p.url||yn)+"").replace(xn,"").replace(kn,mn[1]+"//"),p.type=n.method||n.type||p.method||p.type,p.dataTypes=x.trim(p.dataType||"*").toLowerCase().match(T)||[""],null==p.crossDomain&&(r=En.exec(p.url.toLowerCase()),p.crossDomain=!(!r||r[1]===mn[1]&&r[2]===mn[2]&&(r[3]||("http:"===r[1]?"80":"443"))===(mn[3]||("http:"===mn[1]?"80":"443")))),p.data&&p.processData&&"string"!=typeof p.data&&(p.data=x.param(p.data,p.traditional)),qn(An,p,n,C),2===b)return C;l=p.global,l&&0===x.active++&&x.event.trigger("ajaxStart"),p.type=p.type.toUpperCase(),p.hasContent=!Nn.test(p.type),o=p.url,p.hasContent||(p.data&&(o=p.url+=(bn.test(o)?"&":"?")+p.data,delete p.data),p.cache===!1&&(p.url=wn.test(o)?o.replace(wn,"$1_="+vn++):o+(bn.test(o)?"&":"?")+"_="+vn++)),p.ifModified&&(x.lastModified[o]&&C.setRequestHeader("If-Modified-Since",x.lastModified[o]),x.etag[o]&&C.setRequestHeader("If-None-Match",x.etag[o])),(p.data&&p.hasContent&&p.contentType!==!1||n.contentType)&&C.setRequestHeader("Content-Type",p.contentType),C.setRequestHeader("Accept",p.dataTypes[0]&&p.accepts[p.dataTypes[0]]?p.accepts[p.dataTypes[0]]+("*"!==p.dataTypes[0]?", "+Dn+"; q=0.01":""):p.accepts["*"]);for(i in p.headers)C.setRequestHeader(i,p.headers[i]);if(p.beforeSend&&(p.beforeSend.call(f,C,p)===!1||2===b))return C.abort();w="abort";for(i in{success:1,error:1,complete:1})C[i](p[i]);if(u=qn(jn,p,n,C)){C.readyState=1,l&&d.trigger("ajaxSend",[C,p]),p.async&&p.timeout>0&&(s=setTimeout(function(){C.abort("timeout")},p.timeout));try{b=1,u.send(y,k)}catch(N){if(!(2>b))throw N;k(-1,N)}}else k(-1,"No Transport");function k(e,n,r,i){var c,y,v,w,T,N=n;2!==b&&(b=2,s&&clearTimeout(s),u=t,a=i||"",C.readyState=e>0?4:0,c=e>=200&&300>e||304===e,r&&(w=Mn(p,C,r)),w=On(p,w,C,c),c?(p.ifModified&&(T=C.getResponseHeader("Last-Modified"),T&&(x.lastModified[o]=T),T=C.getResponseHeader("etag"),T&&(x.etag[o]=T)),204===e||"HEAD"===p.type?N="nocontent":304===e?N="notmodified":(N=w.state,y=w.data,v=w.error,c=!v)):(v=N,(e||!N)&&(N="error",0>e&&(e=0))),C.status=e,C.statusText=(n||N)+"",c?h.resolveWith(f,[y,N,C]):h.rejectWith(f,[C,N,v]),C.statusCode(m),m=t,l&&d.trigger(c?"ajaxSuccess":"ajaxError",[C,p,c?y:v]),g.fireWith(f,[C,N]),l&&(d.trigger("ajaxComplete",[C,p]),--x.active||x.event.trigger("ajaxStop")))}return C},getJSON:function(e,t,n){return x.get(e,t,n,"json")},getScript:function(e,n){return x.get(e,t,n,"script")}}),x.each(["get","post"],function(e,n){x[n]=function(e,r,i,o){return x.isFunction(r)&&(o=o||i,i=r,r=t),x.ajax({url:e,type:n,dataType:o,data:r,success:i})}});function Mn(e,n,r){var i,o,a,s,l=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),o===t&&(o=e.mimeType||n.getResponseHeader("Content-Type"));if(o)for(s in l)if(l[s]&&l[s].test(o)){u.unshift(s);break}if(u[0]in r)a=u[0];else{for(s in r){if(!u[0]||e.converters[s+" "+u[0]]){a=s;break}i||(i=s)}a=a||i}return a?(a!==u[0]&&u.unshift(a),r[a]):t}function On(e,t,n,r){var i,o,a,s,l,u={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)u[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!l&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),l=o,o=c.shift())if("*"===o)o=l;else if("*"!==l&&l!==o){if(a=u[l+" "+o]||u["* "+o],!a)for(i in u)if(s=i.split(" "),s[1]===o&&(a=u[l+" "+s[0]]||u["* "+s[0]])){a===!0?a=u[i]:u[i]!==!0&&(o=s[0],c.unshift(s[1]));break}if(a!==!0)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(p){return{state:"parsererror",error:a?p:"No conversion from "+l+" to "+o}}}return{state:"success",data:t}}x.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(e){return x.globalEval(e),e}}}),x.ajaxPrefilter("script",function(e){e.cache===t&&(e.cache=!1),e.crossDomain&&(e.type="GET",e.global=!1)}),x.ajaxTransport("script",function(e){if(e.crossDomain){var n,r=a.head||x("head")[0]||a.documentElement;return{send:function(t,i){n=a.createElement("script"),n.async=!0,e.scriptCharset&&(n.charset=e.scriptCharset),n.src=e.url,n.onload=n.onreadystatechange=function(e,t){(t||!n.readyState||/loaded|complete/.test(n.readyState))&&(n.onload=n.onreadystatechange=null,n.parentNode&&n.parentNode.removeChild(n),n=null,t||i(200,"success"))},r.insertBefore(n,r.firstChild)},abort:function(){n&&n.onload(t,!0)}}}});var Fn=[],Bn=/(=)\?(?=&|$)|\?\?/;x.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Fn.pop()||x.expando+"_"+vn++;return this[e]=!0,e}}),x.ajaxPrefilter("json jsonp",function(n,r,i){var o,a,s,l=n.jsonp!==!1&&(Bn.test(n.url)?"url":"string"==typeof n.data&&!(n.contentType||"").indexOf("application/x-www-form-urlencoded")&&Bn.test(n.data)&&"data");return l||"jsonp"===n.dataTypes[0]?(o=n.jsonpCallback=x.isFunction(n.jsonpCallback)?n.jsonpCallback():n.jsonpCallback,l?n[l]=n[l].replace(Bn,"$1"+o):n.jsonp!==!1&&(n.url+=(bn.test(n.url)?"&":"?")+n.jsonp+"="+o),n.converters["script json"]=function(){return s||x.error(o+" was not called"),s[0]},n.dataTypes[0]="json",a=e[o],e[o]=function(){s=arguments},i.always(function(){e[o]=a,n[o]&&(n.jsonpCallback=r.jsonpCallback,Fn.push(o)),s&&x.isFunction(a)&&a(s[0]),s=a=t}),"script"):t});var Pn,Rn,Wn=0,$n=e.ActiveXObject&&function(){var e;for(e in Pn)Pn[e](t,!0)};function In(){try{return new e.XMLHttpRequest}catch(t){}}function zn(){try{return new e.ActiveXObject("Microsoft.XMLHTTP")}catch(t){}}x.ajaxSettings.xhr=e.ActiveXObject?function(){return!this.isLocal&&In()||zn()}:In,Rn=x.ajaxSettings.xhr(),x.support.cors=!!Rn&&"withCredentials"in Rn,Rn=x.support.ajax=!!Rn,Rn&&x.ajaxTransport(function(n){if(!n.crossDomain||x.support.cors){var r;return{send:function(i,o){var a,s,l=n.xhr();if(n.username?l.open(n.type,n.url,n.async,n.username,n.password):l.open(n.type,n.url,n.async),n.xhrFields)for(s in n.xhrFields)l[s]=n.xhrFields[s];n.mimeType&&l.overrideMimeType&&l.overrideMimeType(n.mimeType),n.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");try{for(s in i)l.setRequestHeader(s,i[s])}catch(u){}l.send(n.hasContent&&n.data||null),r=function(e,i){var s,u,c,p;try{if(r&&(i||4===l.readyState))if(r=t,a&&(l.onreadystatechange=x.noop,$n&&delete Pn[a]),i)4!==l.readyState&&l.abort();else{p={},s=l.status,u=l.getAllResponseHeaders(),"string"==typeof l.responseText&&(p.text=l.responseText);try{c=l.statusText}catch(f){c=""}s||!n.isLocal||n.crossDomain?1223===s&&(s=204):s=p.text?200:404}}catch(d){i||o(-1,d)}p&&o(s,c,p,u)},n.async?4===l.readyState?setTimeout(r):(a=++Wn,$n&&(Pn||(Pn={},x(e).unload($n)),Pn[a]=r),l.onreadystatechange=r):r()},abort:function(){r&&r(t,!0)}}}});var Xn,Un,Vn=/^(?:toggle|show|hide)$/,Yn=RegExp("^(?:([+-])=|)("+w+")([a-z%]*)$","i"),Jn=/queueHooks$/,Gn=[nr],Qn={"*":[function(e,t){var n=this.createTween(e,t),r=n.cur(),i=Yn.exec(t),o=i&&i[3]||(x.cssNumber[e]?"":"px"),a=(x.cssNumber[e]||"px"!==o&&+r)&&Yn.exec(x.css(n.elem,e)),s=1,l=20;if(a&&a[3]!==o){o=o||a[3],i=i||[],a=+r||1;do s=s||".5",a/=s,x.style(n.elem,e,a+o);while(s!==(s=n.cur()/r)&&1!==s&&--l)}return i&&(a=n.start=+a||+r||0,n.unit=o,n.end=i[1]?a+(i[1]+1)*i[2]:+i[2]),n}]};function Kn(){return setTimeout(function(){Xn=t}),Xn=x.now()}function Zn(e,t,n){var r,i=(Qn[t]||[]).concat(Qn["*"]),o=0,a=i.length;for(;a>o;o++)if(r=i[o].call(n,t,e))return r}function er(e,t,n){var r,i,o=0,a=Gn.length,s=x.Deferred().always(function(){delete l.elem}),l=function(){if(i)return!1;var t=Xn||Kn(),n=Math.max(0,u.startTime+u.duration-t),r=n/u.duration||0,o=1-r,a=0,l=u.tweens.length;for(;l>a;a++)u.tweens[a].run(o);return s.notifyWith(e,[u,o,n]),1>o&&l?n:(s.resolveWith(e,[u]),!1)},u=s.promise({elem:e,props:x.extend({},t),opts:x.extend(!0,{specialEasing:{}},n),originalProperties:t,originalOptions:n,startTime:Xn||Kn(),duration:n.duration,tweens:[],createTween:function(t,n){var r=x.Tween(e,u.opts,t,n,u.opts.specialEasing[t]||u.opts.easing);return u.tweens.push(r),r},stop:function(t){var n=0,r=t?u.tweens.length:0;if(i)return this;for(i=!0;r>n;n++)u.tweens[n].run(1);return t?s.resolveWith(e,[u,t]):s.rejectWith(e,[u,t]),this}}),c=u.props;for(tr(c,u.opts.specialEasing);a>o;o++)if(r=Gn[o].call(u,e,c,u.opts))return r;return x.map(c,Zn,u),x.isFunction(u.opts.start)&&u.opts.start.call(e,u),x.fx.timer(x.extend(l,{elem:e,anim:u,queue:u.opts.queue})),u.progress(u.opts.progress).done(u.opts.done,u.opts.complete).fail(u.opts.fail).always(u.opts.always)}function tr(e,t){var n,r,i,o,a;for(n in e)if(r=x.camelCase(n),i=t[r],o=e[n],x.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),a=x.cssHooks[r],a&&"expand"in a){o=a.expand(o),delete e[r];for(n in o)n in e||(e[n]=o[n],t[n]=i)}else t[r]=i}x.Animation=x.extend(er,{tweener:function(e,t){x.isFunction(e)?(t=e,e=["*"]):e=e.split(" ");var n,r=0,i=e.length;for(;i>r;r++)n=e[r],Qn[n]=Qn[n]||[],Qn[n].unshift(t)},prefilter:function(e,t){t?Gn.unshift(e):Gn.push(e)}});function nr(e,t,n){var r,i,o,a,s,l,u=this,c={},p=e.style,f=e.nodeType&&nn(e),d=x._data(e,"fxshow");n.queue||(s=x._queueHooks(e,"fx"),null==s.unqueued&&(s.unqueued=0,l=s.empty.fire,s.empty.fire=function(){s.unqueued||l()}),s.unqueued++,u.always(function(){u.always(function(){s.unqueued--,x.queue(e,"fx").length||s.empty.fire()})})),1===e.nodeType&&("height"in t||"width"in t)&&(n.overflow=[p.overflow,p.overflowX,p.overflowY],"inline"===x.css(e,"display")&&"none"===x.css(e,"float")&&(x.support.inlineBlockNeedsLayout&&"inline"!==ln(e.nodeName)?p.zoom=1:p.display="inline-block")),n.overflow&&(p.overflow="hidden",x.support.shrinkWrapBlocks||u.always(function(){p.overflow=n.overflow[0],p.overflowX=n.overflow[1],p.overflowY=n.overflow[2]}));for(r in t)if(i=t[r],Vn.exec(i)){if(delete t[r],o=o||"toggle"===i,i===(f?"hide":"show"))continue;c[r]=d&&d[r]||x.style(e,r)}if(!x.isEmptyObject(c)){d?"hidden"in d&&(f=d.hidden):d=x._data(e,"fxshow",{}),o&&(d.hidden=!f),f?x(e).show():u.done(function(){x(e).hide()}),u.done(function(){var t;x._removeData(e,"fxshow");for(t in c)x.style(e,t,c[t])});for(r in c)a=Zn(f?d[r]:0,r,u),r in d||(d[r]=a.start,f&&(a.end=a.start,a.start="width"===r||"height"===r?1:0))}}function rr(e,t,n,r,i){return new rr.prototype.init(e,t,n,r,i)}x.Tween=rr,rr.prototype={constructor:rr,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||"swing",this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(x.cssNumber[n]?"":"px")},cur:function(){var e=rr.propHooks[this.prop];return e&&e.get?e.get(this):rr.propHooks._default.get(this)},run:function(e){var t,n=rr.propHooks[this.prop];return this.pos=t=this.options.duration?x.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):rr.propHooks._default.set(this),this}},rr.prototype.init.prototype=rr.prototype,rr.propHooks={_default:{get:function(e){var t;return null==e.elem[e.prop]||e.elem.style&&null!=e.elem.style[e.prop]?(t=x.css(e.elem,e.prop,""),t&&"auto"!==t?t:0):e.elem[e.prop]},set:function(e){x.fx.step[e.prop]?x.fx.step[e.prop](e):e.elem.style&&(null!=e.elem.style[x.cssProps[e.prop]]||x.cssHooks[e.prop])?x.style(e.elem,e.prop,e.now+e.unit):e.elem[e.prop]=e.now}}},rr.propHooks.scrollTop=rr.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},x.each(["toggle","show","hide"],function(e,t){var n=x.fn[t];x.fn[t]=function(e,r,i){return null==e||"boolean"==typeof e?n.apply(this,arguments):this.animate(ir(t,!0),e,r,i)}}),x.fn.extend({fadeTo:function(e,t,n,r){return this.filter(nn).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(e,t,n,r){var i=x.isEmptyObject(e),o=x.speed(t,n,r),a=function(){var t=er(this,x.extend({},e),o);(i||x._data(this,"finish"))&&t.stop(!0)};return a.finish=a,i||o.queue===!1?this.each(a):this.queue(o.queue,a)},stop:function(e,n,r){var i=function(e){var t=e.stop;delete e.stop,t(r)};return"string"!=typeof e&&(r=n,n=e,e=t),n&&e!==!1&&this.queue(e||"fx",[]),this.each(function(){var t=!0,n=null!=e&&e+"queueHooks",o=x.timers,a=x._data(this);if(n)a[n]&&a[n].stop&&i(a[n]);else for(n in a)a[n]&&a[n].stop&&Jn.test(n)&&i(a[n]);for(n=o.length;n--;)o[n].elem!==this||null!=e&&o[n].queue!==e||(o[n].anim.stop(r),t=!1,o.splice(n,1));(t||!r)&&x.dequeue(this,e)})},finish:function(e){return e!==!1&&(e=e||"fx"),this.each(function(){var t,n=x._data(this),r=n[e+"queue"],i=n[e+"queueHooks"],o=x.timers,a=r?r.length:0;for(n.finish=!0,x.queue(this,e,[]),i&&i.stop&&i.stop.call(this,!0),t=o.length;t--;)o[t].elem===this&&o[t].queue===e&&(o[t].anim.stop(!0),o.splice(t,1));for(t=0;a>t;t++)r[t]&&r[t].finish&&r[t].finish.call(this);delete n.finish})}});function ir(e,t){var n,r={height:e},i=0;for(t=t?1:0;4>i;i+=2-t)n=Zt[i],r["margin"+n]=r["padding"+n]=e;return t&&(r.opacity=r.width=e),r}x.each({slideDown:ir("show"),slideUp:ir("hide"),slideToggle:ir("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,t){x.fn[e]=function(e,n,r){return this.animate(t,e,n,r)}}),x.speed=function(e,t,n){var r=e&&"object"==typeof e?x.extend({},e):{complete:n||!n&&t||x.isFunction(e)&&e,duration:e,easing:n&&t||t&&!x.isFunction(t)&&t};return r.duration=x.fx.off?0:"number"==typeof r.duration?r.duration:r.duration in x.fx.speeds?x.fx.speeds[r.duration]:x.fx.speeds._default,(null==r.queue||r.queue===!0)&&(r.queue="fx"),r.old=r.complete,r.complete=function(){x.isFunction(r.old)&&r.old.call(this),r.queue&&x.dequeue(this,r.queue)},r},x.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2}},x.timers=[],x.fx=rr.prototype.init,x.fx.tick=function(){var e,n=x.timers,r=0;for(Xn=x.now();n.length>r;r++)e=n[r],e()||n[r]!==e||n.splice(r--,1);n.length||x.fx.stop(),Xn=t},x.fx.timer=function(e){e()&&x.timers.push(e)&&x.fx.start()},x.fx.interval=13,x.fx.start=function(){Un||(Un=setInterval(x.fx.tick,x.fx.interval))},x.fx.stop=function(){clearInterval(Un),Un=null},x.fx.speeds={slow:600,fast:200,_default:400},x.fx.step={},x.expr&&x.expr.filters&&(x.expr.filters.animated=function(e){return x.grep(x.timers,function(t){return e===t.elem}).length}),x.fn.offset=function(e){if(arguments.length)return e===t?this:this.each(function(t){x.offset.setOffset(this,e,t)});var n,r,o={top:0,left:0},a=this[0],s=a&&a.ownerDocument;if(s)return n=s.documentElement,x.contains(n,a)?(typeof a.getBoundingClientRect!==i&&(o=a.getBoundingClientRect()),r=or(s),{top:o.top+(r.pageYOffset||n.scrollTop)-(n.clientTop||0),left:o.left+(r.pageXOffset||n.scrollLeft)-(n.clientLeft||0)}):o},x.offset={setOffset:function(e,t,n){var r=x.css(e,"position");"static"===r&&(e.style.position="relative");var i=x(e),o=i.offset(),a=x.css(e,"top"),s=x.css(e,"left"),l=("absolute"===r||"fixed"===r)&&x.inArray("auto",[a,s])>-1,u={},c={},p,f;l?(c=i.position(),p=c.top,f=c.left):(p=parseFloat(a)||0,f=parseFloat(s)||0),x.isFunction(t)&&(t=t.call(e,n,o)),null!=t.top&&(u.top=t.top-o.top+p),null!=t.left&&(u.left=t.left-o.left+f),"using"in t?t.using.call(e,u):i.css(u)}},x.fn.extend({position:function(){if(this[0]){var e,t,n={top:0,left:0},r=this[0];return"fixed"===x.css(r,"position")?t=r.getBoundingClientRect():(e=this.offsetParent(),t=this.offset(),x.nodeName(e[0],"html")||(n=e.offset()),n.top+=x.css(e[0],"borderTopWidth",!0),n.left+=x.css(e[0],"borderLeftWidth",!0)),{top:t.top-n.top-x.css(r,"marginTop",!0),left:t.left-n.left-x.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent||s;while(e&&!x.nodeName(e,"html")&&"static"===x.css(e,"position"))e=e.offsetParent;return e||s})}}),x.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(e,n){var r=/Y/.test(n);x.fn[e]=function(i){return x.access(this,function(e,i,o){var a=or(e);return o===t?a?n in a?a[n]:a.document.documentElement[i]:e[i]:(a?a.scrollTo(r?x(a).scrollLeft():o,r?o:x(a).scrollTop()):e[i]=o,t)},e,i,arguments.length,null)}});function or(e){return x.isWindow(e)?e:9===e.nodeType?e.defaultView||e.parentWindow:!1}x.each({Height:"height",Width:"width"},function(e,n){x.each({padding:"inner"+e,content:n,"":"outer"+e},function(r,i){x.fn[i]=function(i,o){var a=arguments.length&&(r||"boolean"!=typeof i),s=r||(i===!0||o===!0?"margin":"border");return x.access(this,function(n,r,i){var o;return x.isWindow(n)?n.document.documentElement["client"+e]:9===n.nodeType?(o=n.documentElement,Math.max(n.body["scroll"+e],o["scroll"+e],n.body["offset"+e],o["offset"+e],o["client"+e])):i===t?x.css(n,r,s):x.style(n,r,i,s)},n,a?i:t,a,null)}})}),x.fn.size=function(){return this.length},x.fn.andSelf=x.fn.addBack,"object"==typeof module&&module&&"object"==typeof module.exports?module.exports=x:(e.jQuery=e.$=x,"function"==typeof define&&define.amd&&define("jquery",[],function(){return x}))})(window); diff --git a/latest/_static/js/vendor/prettify.js b/latest/_static/js/vendor/prettify.js deleted file mode 100644 index 7b990496dd2b..000000000000 --- a/latest/_static/js/vendor/prettify.js +++ /dev/null @@ -1,30 +0,0 @@ -!function(){var q=null;window.PR_SHOULD_USE_CONTINUATION=!0; -(function(){function S(a){function d(e){var b=e.charCodeAt(0);if(b!==92)return b;var a=e.charAt(1);return(b=r[a])?b:"0"<=a&&a<="7"?parseInt(e.substring(1),8):a==="u"||a==="x"?parseInt(e.substring(2),16):e.charCodeAt(1)}function g(e){if(e<32)return(e<16?"\\x0":"\\x")+e.toString(16);e=String.fromCharCode(e);return e==="\\"||e==="-"||e==="]"||e==="^"?"\\"+e:e}function b(e){var b=e.substring(1,e.length-1).match(/\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\[0-3][0-7]{0,2}|\\[0-7]{1,2}|\\[\S\s]|[^\\]/g),e=[],a= -b[0]==="^",c=["["];a&&c.push("^");for(var a=a?1:0,f=b.length;a<f;++a){var h=b[a];if(/\\[bdsw]/i.test(h))c.push(h);else{var h=d(h),l;a+2<f&&"-"===b[a+1]?(l=d(b[a+2]),a+=2):l=h;e.push([h,l]);l<65||h>122||(l<65||h>90||e.push([Math.max(65,h)|32,Math.min(l,90)|32]),l<97||h>122||e.push([Math.max(97,h)&-33,Math.min(l,122)&-33]))}}e.sort(function(e,a){return e[0]-a[0]||a[1]-e[1]});b=[];f=[];for(a=0;a<e.length;++a)h=e[a],h[0]<=f[1]+1?f[1]=Math.max(f[1],h[1]):b.push(f=h);for(a=0;a<b.length;++a)h=b[a],c.push(g(h[0])), -h[1]>h[0]&&(h[1]+1>h[0]&&c.push("-"),c.push(g(h[1])));c.push("]");return c.join("")}function s(e){for(var a=e.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),c=a.length,d=[],f=0,h=0;f<c;++f){var l=a[f];l==="("?++h:"\\"===l.charAt(0)&&(l=+l.substring(1))&&(l<=h?d[l]=-1:a[f]=g(l))}for(f=1;f<d.length;++f)-1===d[f]&&(d[f]=++x);for(h=f=0;f<c;++f)l=a[f],l==="("?(++h,d[h]||(a[f]="(?:")):"\\"===l.charAt(0)&&(l=+l.substring(1))&&l<=h&& -(a[f]="\\"+d[l]);for(f=0;f<c;++f)"^"===a[f]&&"^"!==a[f+1]&&(a[f]="");if(e.ignoreCase&&m)for(f=0;f<c;++f)l=a[f],e=l.charAt(0),l.length>=2&&e==="["?a[f]=b(l):e!=="\\"&&(a[f]=l.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return a.join("")}for(var x=0,m=!1,j=!1,k=0,c=a.length;k<c;++k){var i=a[k];if(i.ignoreCase)j=!0;else if(/[a-z]/i.test(i.source.replace(/\\u[\da-f]{4}|\\x[\da-f]{2}|\\[^UXux]/gi,""))){m=!0;j=!1;break}}for(var r={b:8,t:9,n:10,v:11, -f:12,r:13},n=[],k=0,c=a.length;k<c;++k){i=a[k];if(i.global||i.multiline)throw Error(""+i);n.push("(?:"+s(i)+")")}return RegExp(n.join("|"),j?"gi":"g")}function T(a,d){function g(a){var c=a.nodeType;if(c==1){if(!b.test(a.className)){for(c=a.firstChild;c;c=c.nextSibling)g(c);c=a.nodeName.toLowerCase();if("br"===c||"li"===c)s[j]="\n",m[j<<1]=x++,m[j++<<1|1]=a}}else if(c==3||c==4)c=a.nodeValue,c.length&&(c=d?c.replace(/\r\n?/g,"\n"):c.replace(/[\t\n\r ]+/g," "),s[j]=c,m[j<<1]=x,x+=c.length,m[j++<<1|1]= -a)}var b=/(?:^|\s)nocode(?:\s|$)/,s=[],x=0,m=[],j=0;g(a);return{a:s.join("").replace(/\n$/,""),d:m}}function H(a,d,g,b){d&&(a={a:d,e:a},g(a),b.push.apply(b,a.g))}function U(a){for(var d=void 0,g=a.firstChild;g;g=g.nextSibling)var b=g.nodeType,d=b===1?d?a:g:b===3?V.test(g.nodeValue)?a:d:d;return d===a?void 0:d}function C(a,d){function g(a){for(var j=a.e,k=[j,"pln"],c=0,i=a.a.match(s)||[],r={},n=0,e=i.length;n<e;++n){var z=i[n],w=r[z],t=void 0,f;if(typeof w==="string")f=!1;else{var h=b[z.charAt(0)]; -if(h)t=z.match(h[1]),w=h[0];else{for(f=0;f<x;++f)if(h=d[f],t=z.match(h[1])){w=h[0];break}t||(w="pln")}if((f=w.length>=5&&"lang-"===w.substring(0,5))&&!(t&&typeof t[1]==="string"))f=!1,w="src";f||(r[z]=w)}h=c;c+=z.length;if(f){f=t[1];var l=z.indexOf(f),B=l+f.length;t[2]&&(B=z.length-t[2].length,l=B-f.length);w=w.substring(5);H(j+h,z.substring(0,l),g,k);H(j+h+l,f,I(w,f),k);H(j+h+B,z.substring(B),g,k)}else k.push(j+h,w)}a.g=k}var b={},s;(function(){for(var g=a.concat(d),j=[],k={},c=0,i=g.length;c<i;++c){var r= -g[c],n=r[3];if(n)for(var e=n.length;--e>=0;)b[n.charAt(e)]=r;r=r[1];n=""+r;k.hasOwnProperty(n)||(j.push(r),k[n]=q)}j.push(/[\S\s]/);s=S(j)})();var x=d.length;return g}function v(a){var d=[],g=[];a.tripleQuotedStrings?d.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,q,"'\""]):a.multiLineStrings?d.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/, -q,"'\"`"]):d.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,q,"\"'"]);a.verbatimStrings&&g.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,q]);var b=a.hashComments;b&&(a.cStyleComments?(b>1?d.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,q,"#"]):d.push(["com",/^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)\b|[^\n\r]*)/,q,"#"]),g.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h(?:h|pp|\+\+)?|[a-z]\w*)>/,q])):d.push(["com", -/^#[^\n\r]*/,q,"#"]));a.cStyleComments&&(g.push(["com",/^\/\/[^\n\r]*/,q]),g.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/,q]));if(b=a.regexLiterals){var s=(b=b>1?"":"\n\r")?".":"[\\S\\s]";g.push(["lang-regex",RegExp("^(?:^^\\.?|[+-]|[!=]=?=?|\\#|%=?|&&?=?|\\(|\\*=?|[+\\-]=|->|\\/=?|::?|<<?=?|>>?>?=?|,|;|\\?|@|\\[|~|{|\\^\\^?=?|\\|\\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\\s*("+("/(?=[^/*"+b+"])(?:[^/\\x5B\\x5C"+b+"]|\\x5C"+s+"|\\x5B(?:[^\\x5C\\x5D"+b+"]|\\x5C"+ -s+")*(?:\\x5D|$))+/")+")")])}(b=a.types)&&g.push(["typ",b]);b=(""+a.keywords).replace(/^ | $/g,"");b.length&&g.push(["kwd",RegExp("^(?:"+b.replace(/[\s,]+/g,"|")+")\\b"),q]);d.push(["pln",/^\s+/,q," \r\n\t\u00a0"]);b="^.[^\\s\\w.$@'\"`/\\\\]*";a.regexLiterals&&(b+="(?!s*/)");g.push(["lit",/^@[$_a-z][\w$@]*/i,q],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,q],["pln",/^[$_a-z][\w$@]*/i,q],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,q,"0123456789"],["pln",/^\\[\S\s]?/, -q],["pun",RegExp(b),q]);return C(d,g)}function J(a,d,g){function b(a){var c=a.nodeType;if(c==1&&!x.test(a.className))if("br"===a.nodeName)s(a),a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)b(a);else if((c==3||c==4)&&g){var d=a.nodeValue,i=d.match(m);if(i)c=d.substring(0,i.index),a.nodeValue=c,(d=d.substring(i.index+i[0].length))&&a.parentNode.insertBefore(j.createTextNode(d),a.nextSibling),s(a),c||a.parentNode.removeChild(a)}}function s(a){function b(a,c){var d= -c?a.cloneNode(!1):a,e=a.parentNode;if(e){var e=b(e,1),g=a.nextSibling;e.appendChild(d);for(var i=g;i;i=g)g=i.nextSibling,e.appendChild(i)}return d}for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),d;(d=a.parentNode)&&d.nodeType===1;)a=d;c.push(a)}for(var x=/(?:^|\s)nocode(?:\s|$)/,m=/\r\n?|\n/,j=a.ownerDocument,k=j.createElement("li");a.firstChild;)k.appendChild(a.firstChild);for(var c=[k],i=0;i<c.length;++i)b(c[i]);d===(d|0)&&c[0].setAttribute("value",d);var r=j.createElement("ol"); -r.className="linenums";for(var d=Math.max(0,d-1|0)||0,i=0,n=c.length;i<n;++i)k=c[i],k.className="L"+(i+d)%10,k.firstChild||k.appendChild(j.createTextNode("\u00a0")),r.appendChild(k);a.appendChild(r)}function p(a,d){for(var g=d.length;--g>=0;){var b=d[g];F.hasOwnProperty(b)?D.console&&console.warn("cannot override language handler %s",b):F[b]=a}}function I(a,d){if(!a||!F.hasOwnProperty(a))a=/^\s*</.test(d)?"default-markup":"default-code";return F[a]}function K(a){var d=a.h;try{var g=T(a.c,a.i),b=g.a; -a.a=b;a.d=g.d;a.e=0;I(d,b)(a);var s=/\bMSIE\s(\d+)/.exec(navigator.userAgent),s=s&&+s[1]<=8,d=/\n/g,x=a.a,m=x.length,g=0,j=a.d,k=j.length,b=0,c=a.g,i=c.length,r=0;c[i]=m;var n,e;for(e=n=0;e<i;)c[e]!==c[e+2]?(c[n++]=c[e++],c[n++]=c[e++]):e+=2;i=n;for(e=n=0;e<i;){for(var p=c[e],w=c[e+1],t=e+2;t+2<=i&&c[t+1]===w;)t+=2;c[n++]=p;c[n++]=w;e=t}c.length=n;var f=a.c,h;if(f)h=f.style.display,f.style.display="none";try{for(;b<k;){var l=j[b+2]||m,B=c[r+2]||m,t=Math.min(l,B),A=j[b+1],G;if(A.nodeType!==1&&(G=x.substring(g, -t))){s&&(G=G.replace(d,"\r"));A.nodeValue=G;var L=A.ownerDocument,o=L.createElement("span");o.className=c[r+1];var v=A.parentNode;v.replaceChild(o,A);o.appendChild(A);g<l&&(j[b+1]=A=L.createTextNode(x.substring(t,l)),v.insertBefore(A,o.nextSibling))}g=t;g>=l&&(b+=2);g>=B&&(r+=2)}}finally{if(f)f.style.display=h}}catch(u){D.console&&console.log(u&&u.stack||u)}}var D=window,y=["break,continue,do,else,for,if,return,while"],E=[[y,"auto,case,char,const,default,double,enum,extern,float,goto,inline,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"], -"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],M=[E,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,delegate,dynamic_cast,explicit,export,friend,generic,late_check,mutable,namespace,nullptr,property,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],N=[E,"abstract,assert,boolean,byte,extends,final,finally,implements,import,instanceof,interface,null,native,package,strictfp,super,synchronized,throws,transient"], -O=[N,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],E=[E,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],P=[y,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"], -Q=[y,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],W=[y,"as,assert,const,copy,drop,enum,extern,fail,false,fn,impl,let,log,loop,match,mod,move,mut,priv,pub,pure,ref,self,static,struct,true,trait,type,unsafe,use"],y=[y,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],R=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)\b/, -V=/\S/,X=v({keywords:[M,O,E,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",P,Q,y],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),F={};p(X,["default-code"]);p(C([],[["pln",/^[^<?]+/],["dec",/^<!\w[^>]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-", -/^<xmp\b[^>]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\S\s]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\S\s]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),["default-markup","htm","html","mxml","xhtml","xml","xsl"]);p(C([["pln",/^\s+/,q," \t\r\n"],["atv",/^(?:"[^"]*"?|'[^']*'?)/,q,"\"'"]],[["tag",/^^<\/?[a-z](?:[\w-.:]*\w)?|\/?>$/i],["atn",/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^\s"'>]*(?:[^\s"'/>]|\/(?=\s)))/],["pun",/^[/<->]+/], -["lang-js",/^on\w+\s*=\s*"([^"]+)"/i],["lang-js",/^on\w+\s*=\s*'([^']+)'/i],["lang-js",/^on\w+\s*=\s*([^\s"'>]+)/i],["lang-css",/^style\s*=\s*"([^"]+)"/i],["lang-css",/^style\s*=\s*'([^']+)'/i],["lang-css",/^style\s*=\s*([^\s"'>]+)/i]]),["in.tag"]);p(C([],[["atv",/^[\S\s]+/]]),["uq.val"]);p(v({keywords:M,hashComments:!0,cStyleComments:!0,types:R}),["c","cc","cpp","cxx","cyc","m"]);p(v({keywords:"null,true,false"}),["json"]);p(v({keywords:O,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:R}), -["cs"]);p(v({keywords:N,cStyleComments:!0}),["java"]);p(v({keywords:y,hashComments:!0,multiLineStrings:!0}),["bash","bsh","csh","sh"]);p(v({keywords:P,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),["cv","py","python"]);p(v({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:2}),["perl","pl","pm"]);p(v({keywords:Q, -hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb","ruby"]);p(v({keywords:E,cStyleComments:!0,regexLiterals:!0}),["javascript","js"]);p(v({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,throw,true,try,unless,until,when,while,yes",hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);p(v({keywords:W,cStyleComments:!0,multilineStrings:!0}),["rc","rs","rust"]); -p(C([],[["str",/^[\S\s]+/]]),["regex"]);var Y=D.PR={createSimpleLexer:C,registerLangHandler:p,sourceDecorator:v,PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ",prettyPrintOne:D.prettyPrintOne=function(a,d,g){var b=document.createElement("div");b.innerHTML="<pre>"+a+"</pre>";b=b.firstChild;g&&J(b,g,!0);K({h:d,j:g,c:b,i:1}); -return b.innerHTML},prettyPrint:D.prettyPrint=function(a,d){function g(){for(var b=D.PR_SHOULD_USE_CONTINUATION?c.now()+250:Infinity;i<p.length&&c.now()<b;i++){for(var d=p[i],j=h,k=d;k=k.previousSibling;){var m=k.nodeType,o=(m===7||m===8)&&k.nodeValue;if(o?!/^\??prettify\b/.test(o):m!==3||/\S/.test(k.nodeValue))break;if(o){j={};o.replace(/\b(\w+)=([\w%+\-.:]+)/g,function(a,b,c){j[b]=c});break}}k=d.className;if((j!==h||e.test(k))&&!v.test(k)){m=!1;for(o=d.parentNode;o;o=o.parentNode)if(f.test(o.tagName)&& -o.className&&e.test(o.className)){m=!0;break}if(!m){d.className+=" prettyprinted";m=j.lang;if(!m){var m=k.match(n),y;if(!m&&(y=U(d))&&t.test(y.tagName))m=y.className.match(n);m&&(m=m[1])}if(w.test(d.tagName))o=1;else var o=d.currentStyle,u=s.defaultView,o=(o=o?o.whiteSpace:u&&u.getComputedStyle?u.getComputedStyle(d,q).getPropertyValue("white-space"):0)&&"pre"===o.substring(0,3);u=j.linenums;if(!(u=u==="true"||+u))u=(u=k.match(/\blinenums\b(?::(\d+))?/))?u[1]&&u[1].length?+u[1]:!0:!1;u&&J(d,u,o);r= -{h:m,c:d,j:u,i:o};K(r)}}}i<p.length?setTimeout(g,250):"function"===typeof a&&a()}for(var b=d||document.body,s=b.ownerDocument||document,b=[b.getElementsByTagName("pre"),b.getElementsByTagName("code"),b.getElementsByTagName("xmp")],p=[],m=0;m<b.length;++m)for(var j=0,k=b[m].length;j<k;++j)p.push(b[m][j]);var b=q,c=Date;c.now||(c={now:function(){return+new Date}});var i=0,r,n=/\blang(?:uage)?-([\w.]+)(?!\S)/,e=/\bprettyprint\b/,v=/\bprettyprinted\b/,w=/pre|xmp/i,t=/^code$/i,f=/^(?:pre|code|xmp)$/i, -h={};g()}};typeof define==="function"&&define.amd&&define("google-code-prettify",[],function(){return Y})})();}() diff --git a/latest/bigquery-client.html b/latest/bigquery-client.html index 0da7fc264cac..6b7379ae7395 100644 --- a/latest/bigquery-client.html +++ b/latest/bigquery-client.html @@ -1,109 +1,267 @@ + + <!DOCTYPE html> +<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]--> +<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]--> +<head> + <meta charset="utf-8"> + + <meta name="viewport" content="width=device-width, initial-scale=1.0"> + + <title>BigQuery Client — google-cloud 92219b8 documentation + + + + + - - - - - BigQuery Client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    BigQuery Client#

    Client for interacting with the Google BigQuery API.

    -
    -class gcloud.bigquery.client.Client(project=None, credentials=None, http=None)[source]#
    -

    Bases: gcloud.client.JSONClient

    +
    +class google.cloud.bigquery.client.Client(project=None, credentials=None, http=None)[source]#
    +

    Bases: google.cloud.client.JSONClient

    Client to bundle configuration needed for API requests.

    @@ -113,7 +271,7 @@

  • project (str) – the project which the client acts on behalf of. Will be passed when creating a dataset / job. If not passed, falls back to the default inferred from the environment.
  • -
  • credentials (oauth2client.client.OAuth2Credentials or +
  • credentials (oauth2client.client.OAuth2Credentials or NoneType) – The OAuth2 Credentials to use for the connection owned by this client. If not passed (and if no http object is passed), falls back to the default inferred @@ -127,8 +285,8 @@

  • -
    -copy_table(job_name, destination, *sources)[source]#
    +
    +copy_table(job_name, destination, *sources)[source]#

    Construct a job for copying one or more tables into another table.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.copy

    @@ -138,12 +296,12 @@

    Parameters: -Return type:

    gcloud.bigquery.job.CopyJob

    +Return type:

    google.cloud.bigquery.job.CopyJob

    Returns:

    a new CopyJob instance

    @@ -154,8 +312,8 @@

    -
    -dataset(dataset_name)[source]#
    +
    +dataset(dataset_name)[source]#

    Construct a dataset bound to this client.

    @@ -163,7 +321,7 @@

    - + @@ -172,8 +330,8 @@

    -
    -extract_table_to_storage(job_name, source, *destination_uris)[source]#
    +
    +extract_table_to_storage(job_name, source, *destination_uris)[source]#

    Construct a job for extracting a table into Cloud Storage files.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.extract

    @@ -183,14 +341,14 @@

    - - -
    Parameters:dataset_name (str) – Name of the dataset.
    Return type:gcloud.bigquery.dataset.Dataset
    Return type:google.cloud.bigquery.dataset.Dataset
    Returns:a new Dataset instance
    Parameters:
    • job_name (str) – Name of the job.
    • -
    • source (gcloud.bigquery.table.Table) – table to be extracted.
    • +
    • source (google.cloud.bigquery.table.Table) – table to be extracted.
    • destination_uris (sequence of string) – URIs of CloudStorage file(s) into which table data is to be extracted; in format gs://<bucket_name>/<object_name_or_glob>.
    Return type:

    gcloud.bigquery.job.ExtractTableToStorageJob

    +
    Return type:

    google.cloud.bigquery.job.ExtractTableToStorageJob

    Returns:

    a new ExtractTableToStorageJob instance

    @@ -201,8 +359,8 @@

    -
    -job_from_resource(resource)[source]#
    +
    +job_from_resource(resource)[source]#

    Detect correct job type from resource and instantiate.

    @@ -211,11 +369,11 @@

    +google.cloud.bigquery.job.LoadTableFromStorageJob, +google.cloud.bigquery.job.CopyJob, +google.cloud.bigquery.job.ExtractTableToStorageJob, +google.cloud.bigquery.job.QueryJob, +google.cloud.bigquery.job.RunSyncQueryJob @@ -224,8 +382,8 @@

    -
    -list_datasets(include_all=False, max_results=None, page_token=None)[source]#
    +
    +list_datasets(include_all=False, max_results=None, page_token=None)[source]#

    List datasets for the project associated with this client.

    See: https://cloud.google.com/bigquery/docs/reference/v2/datasets/list

    @@ -246,8 +404,8 @@

    - @@ -257,8 +415,8 @@

    -
    -list_jobs(max_results=None, page_token=None, all_users=None, state_filter=None)[source]#
    +
    +list_jobs(max_results=None, page_token=None, all_users=None, state_filter=None)[source]#

    List jobs for the project associated with this client.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/list

    @@ -299,8 +457,40 @@

    -
    -load_table_from_storage(job_name, destination, *source_uris)[source]#
    +
    +list_projects(max_results=None, page_token=None)[source]#
    +

    List projects for the project associated with this client.

    +

    See: +https://cloud.google.com/bigquery/docs/reference/v2/projects/list

    +

    Parameters:resource (dict) – one job resource from API response
    Return type:One of: -gcloud.bigquery.job.LoadTableFromStorageJob, -gcloud.bigquery.job.CopyJob, -gcloud.bigquery.job.ExtractTableToStorageJob, -gcloud.bigquery.job.QueryJob, -gcloud.bigquery.job.RunSyncQueryJob
    Returns:the job instance, constructed via the resource
    Return type:

    tuple, (list, str)

    Returns:

    list of gcloud.bigquery.dataset.Dataset, plus a -“next page token” string: if the token is not None, +

    Returns:

    list of Dataset, +plus a “next page token” string: if the token is not None, indicates that more datasets can be retrieved with another call (pass that value as page_token).

    +++ + + + + + + + +
    Parameters:
      +
    • max_results (int) – maximum number of projects to return, If not +passed, defaults to a value set by the API.
    • +
    • page_token (str) – opaque marker for the next “page” of projects. If +not passed, the API will return the first page of +projects.
    • +
    +
    Return type:

    tuple, (list, str)

    +
    Returns:

    list of gcloud.bigquery.client.Project, plus a +“next page token” string: if the token is not None, +indicates that more projects can be retrieved with another +call (pass that value as page_token).

    +
    +
    + +
    +
    +load_table_from_storage(job_name, destination, *source_uris)[source]#

    Construct a job for loading data into a table from CloudStorage.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load

    @@ -310,13 +500,13 @@

    Parameters:
    • job_name (str) – Name of the job.
    • -
    • destination (gcloud.bigquery.table.Table) – Table into which data is to be loaded.
    • +
    • destination (google.cloud.bigquery.table.Table) – Table into which data is to be loaded.
    • source_uris (sequence of string) – URIs of data files to be loaded; in format gs://<bucket_name>/<object_name_or_glob>.
    Return type:

    gcloud.bigquery.job.LoadTableFromStorageJob

    +
    Return type:

    google.cloud.bigquery.job.LoadTableFromStorageJob

    Returns:

    a new LoadTableFromStorageJob instance

    @@ -327,8 +517,8 @@

    -
    -run_async_query(job_name, query)[source]#
    +
    +run_async_query(job_name, query)[source]#

    Construct a job for running a SQL query asynchronously.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query

    @@ -342,7 +532,7 @@

    Return type:

    gcloud.bigquery.job.QueryJob

    +
    Return type:

    google.cloud.bigquery.job.QueryJob

    Returns:

    a new QueryJob instance

    @@ -353,8 +543,8 @@

    -
    -run_sync_query(query)[source]#
    +
    +run_sync_query(query)[source]#

    Run a SQL query synchronously.

    @@ -362,7 +552,7 @@

    - + @@ -372,35 +562,61 @@

    -
    -

    Connection#

    -

    Create / interact with gcloud bigquery connections.

    -
    -class gcloud.bigquery.connection.Connection(credentials=None, http=None)[source]#
    -

    Bases: gcloud.connection.JSONConnection

    +
    +class google.cloud.bigquery.client.Project(project_id, numeric_id, friendly_name)[source]#
    +

    Bases: object

    +

    Wrapper for resource describing a BigQuery project.

    +

    Parameters:query (str) – SQL query to be executed
    Return type:gcloud.bigquery.query.QueryResults
    Return type:google.cloud.bigquery.query.QueryResults
    Returns:a new QueryResults instance
    +++ + + + +
    Parameters:
      +
    • project_id (str) – Opaque ID of the project
    • +
    • numeric_id (int) – Numeric ID of the project
    • +
    • friendly_name (str) – Display name of the project
    • +
    +
    +
    +
    +classmethod from_api_repr(resource)[source]#
    +

    Factory: construct an instance from a resource dict.

    +
    + +
    + +
    +

    Connection#

    +

    Create / interact with Google Cloud BigQuery connections.

    +
    +
    +class google.cloud.bigquery.connection.Connection(credentials=None, http=None)[source]#
    +

    Bases: google.cloud.connection.JSONConnection

    A connection to Google Cloud BigQuery via the JSON REST API.

    -
    -API_BASE_URL = 'https://www.googleapis.com'#
    +
    +API_BASE_URL = 'https://www.googleapis.com'#

    The base of the API call URL.

    -
    -API_URL_TEMPLATE = '{api_base_url}/bigquery/{api_version}{path}'#
    +
    +API_URL_TEMPLATE = '{api_base_url}/bigquery/{api_version}{path}'#

    A template for the URL of a particular API call.

    -
    -API_VERSION = 'v2'#
    +
    +API_VERSION = 'v2'#

    The version of the API, used in building the API call’s URL.

    -
    -SCOPE = ('https://www.googleapis.com/auth/bigquery', 'https://www.googleapis.com/auth/cloud-platform')#
    +
    +SCOPE = ('https://www.googleapis.com/auth/bigquery', 'https://www.googleapis.com/auth/cloud-platform')#

    The scopes required for authenticating as a Cloud BigQuery consumer.

    @@ -410,123 +626,71 @@

    - - - - - - - + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigquery-dataset.html b/latest/bigquery-dataset.html index 3ce6053925b3..9d9cee600807 100644 --- a/latest/bigquery-dataset.html +++ b/latest/bigquery-dataset.html @@ -1,108 +1,263 @@ + + + + + + + + + + Datasets — google-cloud 92219b8 documentation + + + + + + + - - - - - Datasets — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Datasets#

    Define API Datasets.

    -
    -class gcloud.bigquery.dataset.AccessGrant(role, entity_type, entity_id)[source]#
    +
    +class google.cloud.bigquery.dataset.AccessGrant(role, entity_type, entity_id)[source]#

    Bases: object

    Represent grant of an access role to an entity.

    Every entry in the access list will have exactly one of @@ -125,29 +280,29 @@

    May also be None if the entity_type is view.

  • entity_type (string) – Type of entity being granted the role. One of -ENTITY_TYPES.
  • +ENTITY_TYPES.
  • entity_id (string) – ID of entity being granted the role.
  • Raises:

    ValueError if the entity_type is not among -ENTITY_TYPES, or if a view has role set or +ENTITY_TYPES, or if a view has role set or a non view does not have a role set.

    -
    -ENTITY_TYPES = frozenset(['userByEmail', 'groupByEmail', 'domain', 'view', 'specialGroup'])#
    +
    +ENTITY_TYPES = frozenset(['specialGroup', 'groupByEmail', 'userByEmail', 'view', 'domain'])#

    Allowed entity types.

    -
    -class gcloud.bigquery.dataset.Dataset(name, client, access_grants=())[source]#
    +
    +class google.cloud.bigquery.dataset.Dataset(name, client, access_grants=())[source]#

    Bases: object

    Datasets are containers for tables.

    See: @@ -158,23 +313,23 @@

    Parameters:
    • name (string) – the name of the dataset
    • -
    • client (gcloud.bigquery.client.Client) – A client which holds credentials and project configuration +
    • client (google.cloud.bigquery.client.Client) – A client which holds credentials and project configuration for the dataset (which requires a project).
    • -
    • access_grants (list of AccessGrant) – roles granted to entities for this dataset
    • +
    • access_grants (list of AccessGrant) – roles granted to entities for this dataset
    -
    -access_grants#
    +
    +access_grants#

    Dataset’s access grants.

    - + @@ -183,16 +338,17 @@

    -
    -create(client=None)[source]#
    -

    API call: create the dataset via a PUT request

    +
    +create(client=None)[source]#
    +

    API call: create the dataset via a PUT request.

    See: https://cloud.google.com/bigquery/docs/reference/v2/tables/insert

    Return type:list of AccessGrant
    Return type:list of AccessGrant
    Returns:roles granted to entities for this dataset
    - @@ -200,8 +356,8 @@

    -
    -created#
    +
    +created#

    Datetime at which the dataset was created.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -216,8 +372,8 @@

    -
    -dataset_id#
    +
    +dataset_id#

    ID for the dataset resource.

    @@ -232,8 +388,8 @@

    -
    -default_table_expiration_ms#
    +
    +default_table_expiration_ms#

    Default expiration time for tables in the dataset.

    @@ -248,16 +404,17 @@

    -
    -delete(client=None)[source]#
    -

    API call: delete the dataset via a DELETE request

    +
    +delete(client=None)[source]#
    +

    API call: delete the dataset via a DELETE request.

    See: https://cloud.google.com/bigquery/docs/reference/v2/tables/delete

    - @@ -265,8 +422,8 @@

    -
    -description#
    +
    +description#

    Description of the dataset.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -281,8 +438,8 @@

    -
    -etag#
    +
    +etag#

    ETag for the dataset resource.

    @@ -297,8 +454,8 @@

    -
    -exists(client=None)[source]#
    +
    +exists(client=None)[source]#

    API call: test for the existence of the dataset via a GET request

    See https://cloud.google.com/bigquery/docs/reference/v2/datasets/get

    @@ -306,7 +463,8 @@

    - @@ -318,8 +476,8 @@

    -
    -friendly_name#
    +
    +friendly_name#

    Title of the dataset.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    Return type:bool
    @@ -334,8 +492,8 @@

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a dataset given its API representation

    @@ -343,12 +501,12 @@

    - -
    Parameters:
    Return type:

    gcloud.bigquery.dataset.Dataset

    +
    Return type:

    google.cloud.bigquery.dataset.Dataset

    Returns:

    Dataset parsed from resource.

    @@ -359,8 +517,8 @@

    -
    -list_tables(max_results=None, page_token=None)[source]#
    +
    +list_tables(max_results=None, page_token=None)[source]#

    List tables for the project associated with this client.

    See: https://cloud.google.com/bigquery/docs/reference/v2/tables/list

    @@ -380,7 +538,7 @@

    Return type:

    tuple, (list, str)

    Returns:

    list of gcloud.bigquery.table.Table, plus a +

    Returns:

    list of google.cloud.bigquery.table.Table, plus a “next page token” string: if not None, indicates that more tables can be retrieved with another call (pass that value as page_token).

    @@ -391,8 +549,8 @@

    -
    -location#
    +
    +location#

    Location in which the dataset is hosted.

    @@ -407,8 +565,8 @@

    -
    -modified#
    +
    +modified#

    Datetime at which the dataset was last modified.

    @@ -423,9 +581,9 @@

    -
    -patch(client=None, **kw)[source]#
    -

    API call: update individual dataset properties via a PATCH request

    +
    +patch(client=None, **kw)[source]#
    +

    API call: update individual dataset properties via a PATCH request.

    See https://cloud.google.com/bigquery/docs/reference/v2/datasets/patch

    @@ -433,7 +591,8 @@

    Parameters:
      -
    • client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    • client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    • kw (dict) – properties to be patched.
    @@ -447,8 +606,8 @@

    -
    -path#
    +
    +path#

    URL path for the dataset’s APIs.

    @@ -463,8 +622,8 @@

    -
    -project#
    +
    +project#

    Project bound to the dataset.

    @@ -479,16 +638,17 @@

    -
    -reload(client=None)[source]#
    -

    API call: refresh dataset properties via a GET request

    +
    +reload(client=None)[source]#
    +

    API call: refresh dataset properties via a GET request.

    See https://cloud.google.com/bigquery/docs/reference/v2/datasets/get

    - @@ -496,8 +656,8 @@

    - +

    URL for the dataset resource.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -512,8 +672,8 @@

    -
    -table(name, schema=())[source]#
    +
    +table(name, schema=())[source]#

    Construct a table bound to this dataset.

    @@ -521,11 +681,11 @@

    -
    Parameters:
    • name (string) – Name of the table.
    • -
    • schema (list of gcloud.bigquery.table.SchemaField) – The table’s schema
    • +
    • schema (list of google.cloud.bigquery.table.SchemaField) – The table’s schema
    Return type:

    gcloud.bigquery.table.Table

    +
    Return type:

    google.cloud.bigquery.table.Table

    Returns:

    a new Table instance

    @@ -536,16 +696,17 @@

    -
    -update(client=None)[source]#
    -

    API call: update dataset properties via a PUT request

    +
    +update(client=None)[source]#
    +

    API call: update dataset properties via a PUT request.

    See https://cloud.google.com/bigquery/docs/reference/v2/datasets/update

    - @@ -557,123 +718,71 @@

    - - - + - - - + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/bigquery-job.html b/latest/bigquery-job.html index 91d6fab0e0d1..094070f5f375 100644 --- a/latest/bigquery-job.html +++ b/latest/bigquery-job.html @@ -1,116 +1,271 @@ + + + + + + + + + + Jobs — google-cloud 92219b8 documentation + + + + + + + - - - - - Jobs — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + -
    +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Jobs#

    Define API Jobs.

    -
    -class gcloud.bigquery.job.Compression(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.Compression(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for compression properties.

    -
    -class gcloud.bigquery.job.CopyJob(name, destination, sources, client)[source]#
    -

    Bases: gcloud.bigquery.job._AsyncJob

    +
    +class google.cloud.bigquery.job.CopyJob(name, destination, sources, client)[source]#
    +

    Bases: google.cloud.bigquery.job._AsyncJob

    Asynchronous job: copy data into a table from other tables.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -118,9 +273,9 @@

    @@ -128,15 +283,15 @@

    Parameters:
    -
    -create_disposition#
    +
    +create_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.copy.createDisposition

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a job given its API representation

    @@ -144,12 +299,12 @@

    - @@ -495,8 +668,8 @@

    -
    -path#
    +
    +path#

    URL path for the table’s APIs.

    Parameters:
    Return type:

    gcloud.bigquery.job.CopyJob

    +
    Return type:

    google.cloud.bigquery.job.CopyJob

    Returns:

    Job parsed from resource.

    @@ -160,8 +315,8 @@

    -
    -write_disposition#
    +
    +write_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.copy.writeDisposition

    @@ -169,30 +324,30 @@

    -
    -class gcloud.bigquery.job.CreateDisposition(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.CreateDisposition(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for create_disposition properties.

    -
    -class gcloud.bigquery.job.DestinationFormat(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.DestinationFormat(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for destination_format properties.

    -
    -class gcloud.bigquery.job.Encoding(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.Encoding(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for encoding properties.

    -
    -class gcloud.bigquery.job.ExtractTableToStorageJob(name, source, destination_uris, client)[source]#
    -

    Bases: gcloud.bigquery.job._AsyncJob

    +
    +class google.cloud.bigquery.job.ExtractTableToStorageJob(name, source, destination_uris, client)[source]#
    +

    Bases: google.cloud.bigquery.job._AsyncJob

    Asynchronous job: extract data from a table into Cloud Storage.

    @@ -200,11 +355,11 @@

    @@ -212,29 +367,29 @@

    Parameters:
    -
    -compression#
    +
    +compression#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.extracted.compression

    -
    -destination_format#
    +
    +destination_format#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.extracted.destinationFormat

    -
    -field_delimiter#
    +
    +field_delimiter#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.extracted.fieldDelimiter

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a job given its API representation

    @@ -242,12 +397,12 @@

    - - @@ -162,8 +294,8 @@

    -
    -created#
    +
    +created#

    Datetime at which the table was created.

    Parameters:
    Return type:

    gcloud.bigquery.job.ExtractTableToStorageJob

    +
    Return type:

    google.cloud.bigquery.job.ExtractTableToStorageJob

    Returns:

    Job parsed from resource.

    @@ -258,8 +413,8 @@

    -
    -print_header#
    +
    +print_header#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.extracted.printHeader

    @@ -267,9 +422,9 @@

    -
    -class gcloud.bigquery.job.LoadTableFromStorageJob(name, destination, source_uris, client, schema=())[source]#
    -

    Bases: gcloud.bigquery.job._AsyncJob

    +
    +class google.cloud.bigquery.job.LoadTableFromStorageJob(name, destination, source_uris, client, schema=())[source]#
    +

    Bases: google.cloud.bigquery.job._AsyncJob

    Asynchronous job for loading data into a table from CloudStorage.

    @@ -277,55 +432,55 @@

    Parameters:
    -
    -allow_jagged_rows#
    +
    +allow_jagged_rows#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.allowJaggedRows

    -
    -allow_quoted_newlines#
    +
    +allow_quoted_newlines#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.allowQuotedNewlines

    -
    -create_disposition#
    +
    +create_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.createDisposition

    -
    -encoding#
    +
    +encoding#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.encoding

    -
    -field_delimiter#
    +
    +field_delimiter#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.fieldDelimiter

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a job given its API representation

    @@ -333,12 +488,12 @@

    -
    Parameters:
    Return type:

    gcloud.bigquery.job.LoadTableFromStorageJob

    +
    Return type:

    google.cloud.bigquery.job.LoadTableFromStorageJob

    Returns:

    Job parsed from resource.

    @@ -349,15 +504,15 @@

    -
    -ignore_unknown_values#
    +
    +ignore_unknown_values#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.ignoreUnknownValues

    -
    -input_file_bytes#
    +
    +input_file_bytes#

    Count of bytes loaded from source files.

    @@ -372,8 +527,8 @@

    -
    -input_files#
    +
    +input_files#

    Count of source files.

    @@ -388,15 +543,15 @@

    -
    -max_bad_records#
    +
    +max_bad_records#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.maxBadRecords

    -
    -output_bytes#
    +
    +output_bytes#

    Count of bytes saved to destination table.

    @@ -411,8 +566,8 @@

    -
    -output_rows#
    +
    +output_rows#

    Count of rows saved to destination table.

    @@ -427,15 +582,15 @@

    -
    -quote_character#
    +
    +quote_character#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.quote

    -
    -schema#
    +
    +schema#

    Table’s schema.

    @@ -450,22 +605,22 @@

    -
    -skip_leading_rows#
    +
    +skip_leading_rows#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.skipLeadingRows

    -
    -source_format#
    +
    +source_format#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.sourceFormat

    -
    -write_disposition#
    +
    +write_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.load.writeDisposition

    @@ -473,9 +628,9 @@

    -
    -class gcloud.bigquery.job.QueryJob(name, query, client)[source]#
    -

    Bases: gcloud.bigquery.job._AsyncJob

    +
    +class google.cloud.bigquery.job.QueryJob(name, query, client, udf_resources=())[source]#
    +

    Bases: google.cloud.bigquery.job._AsyncJob

    Asynchronous job: query tables.

    @@ -484,51 +639,54 @@

    Parameters:
    -
    -allow_large_results#
    +
    +allow_large_results#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.allowLargeResults

    -
    -create_disposition#
    +
    +create_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.createDisposition

    -
    -default_dataset#
    +
    +default_dataset#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.defaultDataset

    -
    -destination#
    +
    +destination#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.destinationTable

    -
    -flatten_results#
    +
    +flatten_results#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.flattenResults

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a job given its API representation

    @@ -536,12 +694,12 @@

    - @@ -229,14 +388,14 @@

    -
    -job#
    +
    +job#

    Job instance used to run the query.

    Parameters:
    Return type:

    gcloud.bigquery.job.RunAsyncQueryJob

    +
    Return type:

    google.cloud.bigquery.job.RunAsyncQueryJob

    Returns:

    Job parsed from resource.

    @@ -552,29 +710,29 @@

    -
    -priority#
    +
    +priority#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.priority

    -
    -use_legacy_sql#
    +
    +use_legacy_sql#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.useLegacySql

    -
    -use_query_cache#
    +
    +use_query_cache#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.useQueryCache

    -
    -write_disposition#
    +
    +write_disposition#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs#configuration.query.writeDisposition

    @@ -582,146 +740,121 @@

    -
    -class gcloud.bigquery.job.QueryPriority(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.QueryPriority(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for QueryJob.priority property.

    -
    -class gcloud.bigquery.job.SourceFormat(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.SourceFormat(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for source_format properties.

    -
    -class gcloud.bigquery.job.WriteDisposition(name)[source]#
    -

    Bases: gcloud.bigquery._helpers._EnumProperty

    +
    +class google.cloud.bigquery.job.UDFResource(udf_type, value)[source]#
    +

    Bases: object

    +

    Describe a single user-defined function (UDF) resource. +:type udf_type: str +:param udf_type: the type of the resource (‘inlineCode’ or ‘resourceUri’)

    + +++ + + + +
    Parameters:value (str) – the inline code or resource URI.
    +

    See +https://cloud.google.com/bigquery/user-defined-functions#api

    +
    + +
    +
    +class google.cloud.bigquery.job.UDFResourcesProperty[source]#
    +

    Bases: object

    +

    Custom property type for QueryJob.

    +

    Also used by Query.

    +
    + +
    +
    +class google.cloud.bigquery.job.WriteDisposition(name)[source]#
    +

    Bases: google.cloud.bigquery._helpers._EnumProperty

    Pseudo-enum for write_disposition properties.

    - - - + - - - + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/bigquery-query.html b/latest/bigquery-query.html index 50e1cdedc0b6..461a98d88954 100644 --- a/latest/bigquery-query.html +++ b/latest/bigquery-query.html @@ -1,108 +1,263 @@ + + + + + + + + + + Query — google-cloud 92219b8 documentation + + + + + + + - - - - - Query — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    -
    + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Query#

    Define API Queries.

    -
    -class gcloud.bigquery.query.QueryResults(query, client)[source]#
    +
    +class google.cloud.bigquery.query.QueryResults(query, client, udf_resources=())[source]#

    Bases: object

    Synchronous job: query tables.

    @@ -111,16 +266,19 @@

    Parameters:
    -
    -cache_hit#
    +
    +cache_hit#

    Query results served from cache.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#cacheHit

    @@ -138,8 +296,8 @@

    -
    -complete#
    +
    +complete#

    Server completed query.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#jobComplete

    @@ -157,22 +315,22 @@

    -
    -default_dataset#
    +
    +default_dataset#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#defaultDataset

    -
    -dry_run#
    +
    +dry_run#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#dryRun

    -
    -errors#
    +
    +errors#

    Errors generated by the query.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#errors

    @@ -190,8 +348,8 @@

    -
    -fetch_data(max_results=None, page_token=None, start_index=None, timeout_ms=None, client=None)[source]#
    +
    +fetch_data(max_results=None, page_token=None, start_index=None, timeout_ms=None, client=None)[source]#

    API call: fetch a page of query result data via a GET request

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/getQueryResults

    @@ -205,7 +363,8 @@

  • start_index (integer or NoneType) – zero-based index of starting row
  • timeout_ms (integer or NoneType) – timeout, in milliseconds, to wait for query to complete
  • -
  • client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
  • client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
  • - + @@ -246,15 +405,15 @@

    -
    -max_results#
    +
    +max_results#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#maxResults

    -
    -name#
    +
    +name#

    Job name, generated by the back-end.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#jobReference

    @@ -272,8 +431,8 @@

    -
    -page_token#
    +
    +page_token#

    Token for fetching next bach of results.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#pageToken

    @@ -290,15 +449,15 @@

    -
    -preserve_nulls#
    +
    +preserve_nulls#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#preserveNulls

    -
    -project#
    +
    +project#

    Project bound to the job.

    Return type:gcloud.bigquery.job.QueryJob, or NoneType
    Return type:google.cloud.bigquery.job.QueryJob, or NoneType
    Returns:Job instance used to run the query (None until jobReference property is set by the server).
    @@ -313,8 +472,8 @@

    -
    -rows#
    +
    +rows#

    Query results.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#rows

    @@ -331,8 +490,8 @@

    -
    -run(client=None)[source]#
    +
    +run(client=None)[source]#

    API call: run the query via a POST request

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query

    @@ -340,7 +499,8 @@

    - @@ -348,8 +508,8 @@

    -
    -schema#
    +
    +schema#

    Schema for query results.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#schema

    @@ -366,16 +526,16 @@

    -
    -timeout_ms#
    +
    +timeout_ms#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#timeoutMs

    -
    -total_bytes_processed#
    -

    Total number of bytes processed by the query

    +
    +total_bytes_processed#
    +

    Total number of bytes processed by the query.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#totalBytesProcessed

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -391,9 +551,9 @@

    -
    -total_rows#
    -

    Total number of rows returned by the query

    +
    +total_rows#
    +

    Total number of rows returned by the query.

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#totalRows

    @@ -409,15 +569,15 @@

    -
    -use_legacy_sql#
    +
    +use_legacy_sql#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#useLegacySql

    -
    -use_query_cache#
    +
    +use_query_cache#

    See: https://cloud.google.com/bigquery/docs/reference/v2/jobs/query#useQueryCache

    @@ -427,123 +587,71 @@

    - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigquery-schema.html b/latest/bigquery-schema.html new file mode 100644 index 000000000000..7f297a5f9abc --- /dev/null +++ b/latest/bigquery-schema.html @@ -0,0 +1,352 @@ + + + + + + + + + + + Schemas — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Schemas#

    +

    Scheamas for BigQuery tables / queries.

    +
    +
    +class google.cloud.bigquery.schema.SchemaField(name, field_type, mode='NULLABLE', description=None, fields=None)[source]#
    +

    Bases: object

    +

    Describe a single field within a table schema.

    +

    +++ + + + +
    Parameters:
      +
    • name (str) – the name of the field.
    • +
    • field_type (str) – the type of the field (one of ‘STRING’, ‘INTEGER’, +‘FLOAT’, ‘BOOLEAN’, ‘TIMESTAMP’ or ‘RECORD’).
    • +
    • mode (str) – the type of the field (one of ‘NULLABLE’, ‘REQUIRED’, +or ‘REPEATED’).
    • +
    • description (str) – optional description for the field.
    • +
    • fields (list of SchemaField, or None) – subfields (requires field_type of ‘RECORD’).
    • +
    +
    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigquery-table.html b/latest/bigquery-table.html index fbdab0de7161..3ccff1308684 100644 --- a/latest/bigquery-table.html +++ b/latest/bigquery-table.html @@ -1,132 +1,263 @@ + + + + + + + + + + Tables — google-cloud 92219b8 documentation + + + + + - - - - - Tables — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Tables#

    +

    Define API Datasets.

    -
    -class gcloud.bigquery.table.Table(name, dataset, schema=())[source]#
    +
    +class google.cloud.bigquery.table.Table(name, dataset, schema=())[source]#

    Bases: object

    Tables represent a set of rows whose values correspond to a schema.

    See: @@ -137,16 +268,16 @@

    Parameters:
    -
    -create(client=None)[source]#
    +
    +create(client=None)[source]#

    API call: create the dataset via a PUT request

    See: https://cloud.google.com/bigquery/docs/reference/v2/tables/insert

    @@ -154,7 +285,8 @@

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -178,8 +310,8 @@

    -
    -dataset_name#
    +
    +dataset_name#

    Name of dataset containing the table.

    @@ -194,8 +326,8 @@

    -
    -delete(client=None)[source]#
    +
    +delete(client=None)[source]#

    API call: delete the table via a DELETE request

    See: https://cloud.google.com/bigquery/docs/reference/v2/tables/delete

    @@ -203,7 +335,8 @@

    - @@ -211,8 +344,8 @@

    -
    -description#
    +
    +description#

    Description of the table.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -227,8 +360,8 @@

    -
    -etag#
    +
    +etag#

    ETag for the table resource.

    @@ -243,8 +376,8 @@

    -
    -exists(client=None)[source]#
    +
    +exists(client=None)[source]#

    API call: test for the existence of the table via a GET request

    See https://cloud.google.com/bigquery/docs/reference/v2/tables/get

    @@ -252,7 +385,8 @@

    - @@ -264,8 +398,8 @@

    -
    -expires#
    +
    +expires#

    Datetime at which the table will be removed.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    Return type:bool
    @@ -280,8 +414,8 @@

    -
    -fetch_data(max_results=None, page_token=None, client=None)[source]#
    +
    +fetch_data(max_results=None, page_token=None, client=None)[source]#

    API call: fetch the table data via a GET request

    See: https://cloud.google.com/bigquery/docs/reference/v2/tabledata/list

    @@ -300,7 +434,8 @@

    @@ -321,8 +456,8 @@

    -
    -friendly_name#
    +
    +friendly_name#

    Title of the table.

    Parameters:
    • max_results (integer or NoneType) – maximum number of rows to return.
    • page_token (str or NoneType) – token representing a cursor into the table’s rows.
    • -
    • client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    • client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    @@ -337,8 +472,8 @@

    -
    -classmethod from_api_repr(resource, dataset)[source]#
    +
    +classmethod from_api_repr(resource, dataset)[source]#

    Factory: construct a table given its API representation

    @@ -346,11 +481,11 @@

    - @@ -401,9 +537,29 @@

    Parameters:
    Return type:

    gcloud.bigquery.table.Table

    +
    Return type:

    google.cloud.bigquery.table.Table

    Returns:

    Table parsed from resource.

    @@ -361,8 +496,8 @@

    -
    -insert_data(rows, row_ids=None, skip_invalid_rows=None, ignore_unknown_values=None, template_suffix=None, client=None)[source]#
    +
    +insert_data(rows, row_ids=None, skip_invalid_rows=None, ignore_unknown_values=None, template_suffix=None, client=None)[source]#

    API call: insert table data via a POST request

    See: https://cloud.google.com/bigquery/docs/reference/v2/tabledata/insertAll

    @@ -383,7 +518,8 @@

    <name> + <template_suffix> based on the schema of the template table. See: https://cloud.google.com/bigquery/streaming-data-into-bigquery#template-tables -
  • client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
  • client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
  • +
    +
    +list_partitions(client=None)[source]#
    +

    List the partitions in a table.

    + +++ + + + + + + + +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the +client stored on the current dataset.
    Return type:list
    Returns:a list of time partitions
    +
    +
    -
    -location#
    +
    +location#

    Location in which the table is hosted.

    @@ -418,8 +574,8 @@

    -
    -modified#
    +
    +modified#

    Datetime at which the table was last modified.

    @@ -434,8 +590,8 @@

    -
    -num_bytes#
    +
    +num_bytes#

    The size of the table in bytes.

    @@ -450,8 +606,8 @@

    -
    -num_rows#
    +
    +num_rows#

    The number of rows in the table.

    @@ -465,9 +621,25 @@

    +
    +
    +partition_expiration#
    +

    Expiration time in ms for a partition +:rtype: int, or NoneType +:returns: Returns the time in ms for partition expiration

    +
    + +
    +
    +partitioning_type#
    +

    Time partitioning of the table. +:rtype: str, or NoneType +:returns: Returns type if the table is partitioned, None otherwise.

    +
    +
    -
    -patch(client=None, friendly_name=<object object>, description=<object object>, location=<object object>, expires=<object object>, view_query=<object object>, schema=<object object>)[source]#
    +
    +patch(client=None, friendly_name=<object object>, description=<object object>, location=<object object>, expires=<object object>, view_query=<object object>, schema=<object object>)[source]#

    API call: update individual table properties via a PATCH request

    See https://cloud.google.com/bigquery/docs/reference/v2/tables/patch

    @@ -476,14 +648,15 @@

    Parameters:
      -
    • client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    • client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    • friendly_name (str or NoneType) – point in time at which the table expires.
    • description (str or NoneType) – point in time at which the table expires.
    • location (str or NoneType) – point in time at which the table expires.
    • expires (datetime.datetime or NoneType) – point in time at which the table expires.
    • view_query (str) – SQL query defining the table as a view
    • -
    • schema (list of SchemaField) – fields describing the schema
    • +
    • schema (list of SchemaField) – fields describing the schema
    @@ -511,8 +684,8 @@

    -
    -project#
    +
    +project#

    Project bound to the table.

    @@ -527,8 +700,8 @@

    -
    -reload(client=None)[source]#
    +
    +reload(client=None)[source]#

    API call: refresh table properties via a GET request

    See https://cloud.google.com/bigquery/docs/reference/v2/tables/get

    @@ -536,7 +709,8 @@

    - @@ -544,14 +718,14 @@

    -
    -schema#
    +
    +schema#

    Table’s schema.

    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    - + @@ -560,8 +734,8 @@

    - +

    URL for the table resource.

    Return type:list of SchemaField
    Return type:list of SchemaField
    Returns:fields describing the schema
    @@ -576,8 +750,8 @@

    -
    -table_id#
    +
    +table_id#

    ID for the table resource.

    @@ -592,8 +766,8 @@

    -
    -table_type#
    +
    +table_type#

    The type of the table.

    Possible values are “TABLE” or “VIEW”.

    @@ -609,8 +783,8 @@

    -
    -update(client=None)[source]#
    +
    +update(client=None)[source]#

    API call: update table properties via a PUT request

    See https://cloud.google.com/bigquery/docs/reference/v2/tables/update

    @@ -618,7 +792,8 @@

    - @@ -626,8 +801,8 @@

    -
    -upload_from_file(file_obj, source_format, rewind=False, size=None, num_retries=6, allow_jagged_rows=None, allow_quoted_newlines=None, create_disposition=None, encoding=None, field_delimiter=None, ignore_unknown_values=None, max_bad_records=None, quote_character=None, skip_leading_rows=None, write_disposition=None, client=None)[source]#
    +
    +upload_from_file(file_obj, source_format, rewind=False, size=None, num_retries=6, allow_jagged_rows=None, allow_quoted_newlines=None, create_disposition=None, encoding=None, field_delimiter=None, ignore_unknown_values=None, max_bad_records=None, quote_character=None, skip_leading_rows=None, write_disposition=None, client=None)[source]#

    Upload the contents of this table from a file-like object.

    The content type of the upload will either be - The value passed in to the function (if any) @@ -640,7 +815,7 @@

  • file_obj (file) – A file handle opened in binary mode for reading.
  • source_format (str) – one of ‘CSV’ or ‘NEWLINE_DELIMITED_JSON’. job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob()
  • rewind (boolean) – If True, seek to the beginning of the file handle before writing the file to Cloud Storage.
  • size (int) – The number of bytes to read from the file handle. @@ -649,35 +824,36 @@

    filesystem this won’t be possible.)

  • num_retries (integer) – Number of upload retries. Defaults to 6.
  • allow_jagged_rows (boolean) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • allow_quoted_newlines (boolean) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • create_disposition (str) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • encoding (str) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • field_delimiter (str) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • ignore_unknown_values (boolean) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • max_bad_records (integer) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • quote_character (str) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • skip_leading_rows (integer) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • +google.cloud.bigquery.job.LoadJob().
  • write_disposition (str) – job configuration option; see -gcloud.bigquery.job.LoadJob()
  • -
  • client (gcloud.storage.client.Client or NoneType) – Optional. The client to use. If not passed, falls back +google.cloud.bigquery.job.LoadJob().
  • +
  • client (Client or +NoneType) – Optional. The client to use. If not passed, falls back to the client stored on the current dataset.
  • -

    +mutations exceeds the MAX_MUTATIONS.
    Parameters:client (gcloud.bigquery.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (Client or +NoneType) – the client to use. If not passed, falls back to the client stored on the current dataset.
    Return type:

    gcloud.bigquery.jobs.LoadTableFromStorageJob

    +
    Return type:

    google.cloud.bigquery.jobs.LoadTableFromStorageJob

    Returns:

    the job instance used to load the data (e.g., for -querying status)

    +querying status).

    Raises:

    ValueError if size is not passed in and can not @@ -690,8 +866,8 @@

    -
    -view_query#
    +
    +view_query#

    SQL query defining the table as a view.

    @@ -710,123 +886,71 @@

    - - - +
    +

    + © Copyright 2014, Google. - - - +

    +
    + Built with Sphinx using a theme provided by Read the Docs. + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + \ No newline at end of file diff --git a/latest/bigquery-usage.html b/latest/bigquery-usage.html index 0e6aa62164f6..aac76433d405 100644 --- a/latest/bigquery-usage.html +++ b/latest/bigquery-usage.html @@ -1,111 +1,286 @@ + + + + + + + + + + Using the API — google-cloud 92219b8 documentation + + + + + + + - - - - - Using the API — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + -
    + +
    + +
    +
    +
    +
    +

    Using the API#

    Authentication / Configuration#

    +
    + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-client-intro.html b/latest/bigtable-client-intro.html index 54f77c59136f..884870131c7b 100644 --- a/latest/bigtable-client-intro.html +++ b/latest/bigtable-client-intro.html @@ -1,196 +1,90 @@ + + + + + + + + + + Base for Everything — google-cloud 92219b8 documentation + + + + + + + - - - - - Base for Everything — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Base for Everything#

    +

    To use the API, the Client +class defines a high-level interface which handles authorization +and creating other objects:

    +
    from google.cloud.bigtable.client import Client
    +client = Client()
    +
    +
    +
    +

    Long-lived Defaults#

    +

    When creating a Client, the +user_agent argument has sensible a default +(DEFAULT_USER_AGENT). +However, you may over-ride it and the value will be used throughout all API +requests made with the client you create.

    +
    +
    +

    Configuration#

    +
      +
    • For an overview of authentication in google-cloud-python, +see Authentication.

      +
    • +
    • In addition to any authentication configuration, you can also set the +GOOGLE_CLOUD_PROJECT environment variable for the Google Cloud Console +project you’d like to interact with. If your code is running in Google App +Engine or Google Compute Engine the project will be detected automatically. +(Setting this environment variable is not required, you may instead pass the +project explicitly when constructing a +Client).

      +
    • +
    • After configuring your environment, create a +Client

      +
      >>> from google.cloud import bigtable
      +>>> client = bigtable.Client()
      +
      +
      +

      or pass in credentials and project explicitly

      +
      >>> from google.cloud import bigtable
      +>>> client = bigtable.Client(project='my-project', credentials=creds)
      +
      +
      +
    +
    +

    Tip

    +

    Be sure to use the Project ID, not the Project Number.

    +
    +
    +
    +

    Admin API Access#

    +

    If you’ll be using your client to make Instance Admin and Table Admin +API requests, you’ll need to pass the admin argument:

    +
    client = bigtable.Client(admin=True)
    +
    +
    +
    +
    +

    Read-Only Mode#

    +

    If on the other hand, you only have (or want) read access to the data, +you can pass the read_only argument:

    +
    client = bigtable.Client(read_only=True)
    +
    +
    +

    This will ensure that the +READ_ONLY_SCOPE is used +for API requests (so any accidental requests that would modify data will +fail).

    +
    +
    +

    Next Step#

    +

    After a Client, the next highest-level +object is a Instance. You’ll need +one before you can interact with tables or data.

    +

    Head next to learn about the Instance Admin API.

    +
    +
    + + +
    +
    + + +
    +
    + +
    + +
    + - - - - - - + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-client.html b/latest/bigtable-client.html index 59a253dc90f8..e4215cadaa49 100644 --- a/latest/bigtable-client.html +++ b/latest/bigtable-client.html @@ -1,131 +1,280 @@ + + + + + + + + + + Client — google-cloud 92219b8 documentation + + + + + - - - - - Client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + -
    + +
    +
      +
    • Docs »
    • + +
    • Client
    • +
    • + + + View page source + -
      -

      Client#

      -
      -

      Warning

      -

      gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

      +
    • +
    +
    -

    Parent client for calling the Google Cloud Bigtable API.

    +
    +
    + +
    +

    Client#

    +

    Parent client for calling the Google Cloud Bigtable API.

    This is the base from which all interactions with the API occur.

    In the hierarchy of API concepts

    -
    -gcloud.bigtable.client.ADMIN_SCOPE = 'https://www.googleapis.com/auth/bigtable.admin'#
    +
    +google.cloud.bigtable.client.ADMIN_SCOPE = 'https://www.googleapis.com/auth/bigtable.admin'#

    Scope for interacting with the Cluster Admin and Table Admin APIs.

    -
    -class gcloud.bigtable.client.Client(project=None, credentials=None, read_only=False, admin=False, user_agent='gcloud-python/0.17.0', timeout_seconds=10)[source]#
    -

    Bases: gcloud.client._ClientFactoryMixin, gcloud.client._ClientProjectMixin

    +
    +class google.cloud.bigtable.client.Client(project=None, credentials=None, read_only=False, admin=False, user_agent='google-cloud-python/0.18.0')[source]#
    +

    Bases: google.cloud.client._ClientFactoryMixin, google.cloud.client._ClientProjectMixin

    Client for interacting with Google Cloud Bigtable API.

    Note

    @@ -140,7 +289,7 @@

    Clientstr or unicode) – (Optional) The ID of the project which owns the instances, tables and data. If not provided, will attempt to determine from the environment. -
  • credentials (OAuth2Credentials or +
  • credentials (OAuth2Credentials or NoneType) – (Optional) The OAuth2 Credentials to use for this client. If not provided, defaults to the Google Application Default Credentials.
  • @@ -149,12 +298,9 @@

    ClientFalse.
  • admin (bool) – (Optional) Boolean indicating if the client will be used to interact with the Instance Admin or Table Admin APIs. This -requires the ADMIN_SCOPE. Defaults to False.
  • +requires the ADMIN_SCOPE. Defaults to False.
  • user_agent (str) – (Optional) The user agent to be used with API request. -Defaults to DEFAULT_USER_AGENT.
  • -
  • timeout_seconds (int) – Number of seconds for request time-out. If not -passed, defaults to -DEFAULT_TIMEOUT_SECONDS.
  • +Defaults to DEFAULT_USER_AGENT. @@ -165,8 +311,8 @@

    Client -
    -copy()[source]#
    +
    +copy()[source]#

    Make a copy of this client.

    Copies the local data stored as simple types but does not copy the current state of any open connections with the Cloud Bigtable API.

    @@ -174,7 +320,7 @@

    Client

    - + @@ -183,14 +329,14 @@

    Client -
    -credentials#
    +
    +credentials#

    Getter for client’s credentials.

    Return type:Client
    Return type:Client
    Returns:A copy of the current client.
    - + @@ -199,8 +345,8 @@

    Client -
    -instance(instance_id, location='see-existing-cluster', display_name=None, serve_nodes=3)[source]#
    +
    +instance(instance_id, location='see-existing-cluster', display_name=None, serve_nodes=3)[source]#

    Factory to create a instance associated with this client.

    Return type:OAuth2Credentials
    Return type:OAuth2Credentials
    Returns:The credentials stored on the client.
    @@ -220,7 +366,7 @@

    Client

    - + @@ -157,25 +305,25 @@

    Cluster -
    -create()[source]#
    +
    +create()[source]#

    Create this cluster.

    Note

    Uses the project, instance and cluster_id on the -current Cluster in addition to the serve_nodes. +current Cluster in addition to the serve_nodes. To change them before creating, reset the values via

    cluster.serve_nodes = 8
     cluster.cluster_id = 'i-changed-my-mind'
     
    -

    before calling create().

    +

    before calling create().

    Return type:

    Instance

    +
    Return type:

    Instance

    Returns:

    an instance owned by this client.

    @@ -231,24 +377,8 @@

    Client -
    -is_started()[source]#
    -

    Check if the client has been started.

    - --- - - - - - -
    Return type:bool
    Returns:Boolean indicating if the client has been started.
    -
    - -
    -
    -list_instances()[source]#
    +
    +list_instances()[source]#

    List instances owned by the project.

    @@ -257,7 +387,7 @@

    Client

    @@ -265,8 +395,8 @@

    Client -
    -project_name#
    +
    +project_name#

    Project name to be used with Instance Admin API.

    Note

    @@ -289,202 +419,112 @@

    Client -
    -start()[source]#
    -

    Prepare the client to make requests.

    -

    Activates gRPC contexts for making requests to the Bigtable -Service(s).

    -
    - -
    -
    -stop()[source]#
    -

    Closes all the open gRPC clients.

    -
    -

    -
    -gcloud.bigtable.client.DATA_API_HOST_V2 = 'bigtable.googleapis.com'#
    +
    +google.cloud.bigtable.client.DATA_API_HOST = 'bigtable.googleapis.com'#

    Data API request host.

    -
    -gcloud.bigtable.client.DATA_API_PORT_V2 = 443#
    -

    Data API request port.

    -
    - -
    -
    -gcloud.bigtable.client.DATA_SCOPE = 'https://www.googleapis.com/auth/bigtable.data'#
    +
    +google.cloud.bigtable.client.DATA_SCOPE = 'https://www.googleapis.com/auth/bigtable.data'#

    Scope for reading and writing table data.

    -
    -gcloud.bigtable.client.DEFAULT_TIMEOUT_SECONDS = 10#
    -

    The default timeout to use for API requests.

    -
    - -
    -
    -gcloud.bigtable.client.DEFAULT_USER_AGENT = 'gcloud-python/0.17.0'#
    +
    +google.cloud.bigtable.client.DEFAULT_USER_AGENT = 'google-cloud-python/0.18.0'#

    The default user agent for API requests.

    -
    -gcloud.bigtable.client.INSTANCE_ADMIN_HOST_V2 = 'bigtableadmin.googleapis.com'#
    +
    +google.cloud.bigtable.client.INSTANCE_ADMIN_HOST = 'bigtableadmin.googleapis.com'#

    Cluster Admin API request host.

    -
    -gcloud.bigtable.client.INSTANCE_ADMIN_PORT_V2 = 443#
    -

    Cluster Admin API request port.

    -
    - -
    -
    -gcloud.bigtable.client.READ_ONLY_SCOPE = 'https://www.googleapis.com/auth/bigtable.data.readonly'#
    +
    +google.cloud.bigtable.client.READ_ONLY_SCOPE = 'https://www.googleapis.com/auth/bigtable.data.readonly'#

    Scope for reading table data.

    -
    -gcloud.bigtable.client.TABLE_ADMIN_HOST_V2 = 'bigtableadmin.googleapis.com'#
    +
    +google.cloud.bigtable.client.TABLE_ADMIN_HOST = 'bigtableadmin.googleapis.com'#

    Table Admin API request host.

    -
    -
    -gcloud.bigtable.client.TABLE_ADMIN_PORT_V2 = 443#
    -

    Table Admin API request port.

    -
    - - - - - - - - + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-cluster.html b/latest/bigtable-cluster.html index 6fe096a499ef..b649036bdca3 100644 --- a/latest/bigtable-cluster.html +++ b/latest/bigtable-cluster.html @@ -1,123 +1,271 @@ + + + + + + + + + + Cluster — google-cloud 92219b8 documentation + + + + + - - - - - Cluster — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + -
    + + +
    +
      +
    • Docs »
    • + +
    • Cluster
    • +
    • + + + View page source + -
      -

      Cluster#

      -
      -

      Warning

      -

      gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

      +
    • +
    +
    -

    User friendly container for Google Cloud Bigtable Cluster.

    +
    +
    + +
    +

    Cluster#

    +

    User friendly container for Google Cloud Bigtable Cluster.

    -
    -class gcloud.bigtable.cluster.Cluster(cluster_id, instance, serve_nodes=3)[source]#
    +
    +class google.cloud.bigtable.cluster.Cluster(cluster_id, instance, serve_nodes=3)[source]#

    Bases: object

    Representation of a Google Cloud Bigtable Cluster.

    -

    We can use a Cluster to:

    +

    We can use a Cluster to:

    Note

    @@ -130,17 +278,17 @@

    Cluster

    Return type:tuple
    Returns:A pair of results, the first is a list of -Instance objects returned and the second is a +Instance objects returned and the second is a list of strings (the failed locations in the request).
    Parameters:
    -
    -copy()[source]#
    +
    +copy()[source]#

    Make a copy of this cluster.

    Copies the local data stored as simple types and copies the client attached to this instance.

    @@ -148,7 +296,7 @@

    Cluster

    Return type:Cluster
    Return type:Cluster
    Returns:A copy of the current cluster.
    - + @@ -185,8 +333,8 @@

    Cluster -
    -delete()[source]#
    +
    +delete()[source]#

    Delete this cluster.

    Marks a cluster and all of its tables for permanent deletion in 7 days.

    Immediately upon completion of the request:

    @@ -198,11 +346,6 @@

    Cluster
  • All tables within the cluster will become unavailable.
  • -

    Prior to the cluster’s delete_time:

    -
      -
    • The cluster can be recovered with a call to UndeleteCluster.
    • -
    • All other attempts to modify or delete the cluster will be rejected.
    • -

    At the cluster’s delete_time:

    Return type:Operation
    Return type:Operation
    Returns:The long-running operation corresponding to the create operation.
    @@ -225,7 +368,7 @@

    Cluster

    +mutations exceeds the MAX_MUTATIONS.
    Return type:

    Cluster

    +
    Return type:

    Cluster

    Returns:

    The cluster parsed from the protobuf response.

    @@ -243,8 +386,8 @@

    Cluster -
    -name#
    +
    +name#

    Cluster name used in requests.

    Note

    @@ -267,14 +410,14 @@

    Cluster -
    -reload()[source]#
    +
    +reload()[source]#

    Reload the metadata for this cluster.

    -
    -update()[source]#
    +
    +update()[source]#

    Update this cluster.

    Note

    @@ -283,13 +426,13 @@

    Cluster
    cluster.serve_nodes = 8
     

    -

    before calling update().

    +

    before calling update().

    - + @@ -301,173 +444,79 @@

    Cluster -
    -gcloud.bigtable.cluster.DEFAULT_SERVE_NODES = 3#
    +
    +google.cloud.bigtable.cluster.DEFAULT_SERVE_NODES = 3#

    Default number of nodes to use when creating a cluster.

    -
    -
    -class gcloud.bigtable.cluster.Operation(op_type, op_id, cluster=None)[source]#
    -

    Bases: object

    -

    Representation of a Google API Long-Running Operation.

    -

    In particular, these will be the result of operations on -clusters using the Cloud Bigtable API.

    -

    Return type:Operation
    Return type:Operation
    Returns:The long-running operation corresponding to the update operation.
    --- - - - -
    Parameters:
      -
    • op_type (str) – The type of operation being performed. Expect -create, update or undelete.
    • -
    • op_id (int) – The ID of the operation.
    • -
    • cluster (Cluster) – The cluster that created the operation.
    • -
    -
    -
    -
    -finished()[source]#
    -

    Check if the operation has finished.

    - --- - - - - - - - -
    Return type:bool
    Returns:A boolean indicating if the current operation has completed.
    Raises:ValueError if the operation -has already completed.
    -
    + -
    - + + + - - - + + + + + + + + + + + + + + + + + + + + + - + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-column-family.html b/latest/bigtable-column-family.html index f6d838e63620..e808e57e93b0 100644 --- a/latest/bigtable-column-family.html +++ b/latest/bigtable-column-family.html @@ -1,129 +1,278 @@ + + + + + + + + + + Column Families — google-cloud 92219b8 documentation + + + + + + + - - - - - Column Families — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    +

    Column Families#

    -
    -

    Warning

    -

    gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

    -

    When creating a -ColumnFamily, it is +ColumnFamily, it is possible to set garbage collection rules for expired data.

    By setting a rule, cells in the table matching the rule will be deleted during periodic garbage collection (which executes opportunistically in the background).

    The types -MaxAgeGCRule, -MaxVersionsGCRule, +MaxAgeGCRule, +MaxVersionsGCRule, GarbageCollectionRuleUnion and GarbageCollectionRuleIntersection can all be used as the optional gc_rule argument in the -ColumnFamily +ColumnFamily constructor. This value is then used in the -create() and -update() methods.

    +create() and +update() methods.

    These rules can be nested arbitrarily, with a -MaxAgeGCRule or -MaxVersionsGCRule +MaxAgeGCRule or +MaxVersionsGCRule at the lowest level of the nesting:

    import datetime
     
    @@ -142,17 +291,17 @@ 

    Column Families -

    User friendly container for Google Cloud Bigtable Column Family.

    +

    User friendly container for Google Cloud Bigtable Column Family.

    -
    -class gcloud.bigtable.column_family.ColumnFamily(column_family_id, table, gc_rule=None)[source]#
    +
    +class google.cloud.bigtable.column_family.ColumnFamily(column_family_id, table, gc_rule=None)[source]#

    Bases: object

    Representation of a Google Cloud Bigtable Column Family.

    -

    We can use a ColumnFamily to:

    +

    We can use a ColumnFamily to:

    @@ -161,8 +310,8 @@

    Column Families

    @@ -170,20 +319,20 @@

    Column Families -
    -create()[source]#
    +
    +create()[source]#

    Create this column family.

    -
    -delete()[source]#
    +
    +delete()[source]#

    Delete this column family.

    -
    -name#
    +
    +name#

    Column family name used in requests.

    Note

    @@ -206,8 +355,8 @@

    Column Families -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the column family to a protobuf.

    Parameters:
    • column_family_id (str) – The ID of the column family. Must be of the form [_a-zA-Z0-9][-_.a-zA-Z0-9]*.
    • -
    • table (Table) – The table that owns the column family.
    • -
    • gc_rule (GarbageCollectionRule) – (Optional) The garbage collection settings for this +
    • table (Table) – The table that owns the column family.
    • +
    • gc_rule (GarbageCollectionRule) – (Optional) The garbage collection settings for this column family.
    @@ -222,8 +371,8 @@

    Column Families -
    -update()[source]#
    +
    +update()[source]#

    Update this column family.

    Note

    @@ -235,21 +384,21 @@

    Column Families -
    -class gcloud.bigtable.column_family.GCRuleIntersection(rules)[source]#
    -

    Bases: gcloud.bigtable.column_family.GarbageCollectionRule

    +
    +class google.cloud.bigtable.column_family.GCRuleIntersection(rules)[source]#
    +

    Bases: google.cloud.bigtable.column_family.GarbageCollectionRule

    Intersection of garbage collection rules.

    - +
    Parameters:rules (list) – List of GarbageCollectionRule.
    Parameters:rules (list) – List of GarbageCollectionRule.
    -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the intersection into a single GC rule as a protobuf.

    @@ -266,21 +415,21 @@

    Column Families -
    -class gcloud.bigtable.column_family.GCRuleUnion(rules)[source]#
    -

    Bases: gcloud.bigtable.column_family.GarbageCollectionRule

    +
    +class google.cloud.bigtable.column_family.GCRuleUnion(rules)[source]#
    +

    Bases: google.cloud.bigtable.column_family.GarbageCollectionRule

    Union of garbage collection rules.

    - +
    Parameters:rules (list) – List of GarbageCollectionRule.
    Parameters:rules (list) – List of GarbageCollectionRule.
    -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the union into a single GC rule as a protobuf.

    @@ -297,8 +446,8 @@

    Column Families -
    -class gcloud.bigtable.column_family.GarbageCollectionRule[source]#
    +
    +class google.cloud.bigtable.column_family.GarbageCollectionRule[source]#

    Bases: object

    Garbage collection rule for column families within a table.

    Cells in the column family (within a table) fitting the rule will be @@ -316,9 +465,9 @@

    Column Families -
    -class gcloud.bigtable.column_family.MaxAgeGCRule(max_age)[source]#
    -

    Bases: gcloud.bigtable.column_family.GarbageCollectionRule

    +
    +class google.cloud.bigtable.column_family.MaxAgeGCRule(max_age)[source]#
    +

    Bases: google.cloud.bigtable.column_family.GarbageCollectionRule

    Garbage collection limiting the age of a cell.

    @@ -329,8 +478,8 @@

    Column Families -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the garbage collection rule to a protobuf.

    @@ -347,9 +496,9 @@

    Column Families -
    -class gcloud.bigtable.column_family.MaxVersionsGCRule(max_num_versions)[source]#
    -

    Bases: gcloud.bigtable.column_family.GarbageCollectionRule

    +
    +class google.cloud.bigtable.column_family.MaxVersionsGCRule(max_num_versions)[source]#
    +

    Bases: google.cloud.bigtable.column_family.GarbageCollectionRule

    Garbage collection limiting the number of versions of a cell.

    @@ -360,8 +509,8 @@

    Column Families -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the garbage collection rule to a protobuf.

    @@ -380,123 +529,71 @@

    Column Families -

    gcloud

    -
    -

    Datastore

    - -

    Storage

    - -

    Pub/Sub

    - -

    BigQuery

    - -

    Cloud Bigtable

    - -

    Resource Manager

    - -

    DNS

    - -

    Stackdriver Logging

    - -

    Stackdriver Monitoring

    - -

    Translate

    - -

    External Links

    - + + + - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-data-api.html b/latest/bigtable-data-api.html index 2832b4074887..86701f0a2099 100644 --- a/latest/bigtable-data-api.html +++ b/latest/bigtable-data-api.html @@ -1,111 +1,279 @@ + + + + + + + + + + Data API — google-cloud 92219b8 documentation + + + + + + + - - - - - Data API — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    +

    Data API#

    -
    -

    Warning

    -

    gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

    -
    -

    After creating a Table and some +

    After creating a Table and some column families, you are ready to store and retrieve data.

    Cells vs. Columns vs. Column Families#

    @@ -130,7 +298,7 @@

    Modifying DataTable.

    +Table.

    Direct vs. Conditional vs. Append#

    There are three ways to modify data in a table, described by the @@ -139,38 +307,38 @@

    Direct vs. Conditional vs. Append
  • The direct way is via MutateRow which involves simply adding, overwriting or deleting cells. The -DirectRow class +DirectRow class handles direct mutations.
  • The conditional way is via CheckAndMutateRow. This method first checks if some filter is matched in a a given row, then applies one of two sets of mutations, depending on if a match occurred or not. (These mutation sets are called the “true mutations” and “false mutations”.) The -ConditionalRow class +ConditionalRow class handles conditional mutations.
  • The append way is via ReadModifyWriteRow. This simply appends (as bytes) or increments (as an integer) data in a presumed existing cell in a row. The -AppendRow class +AppendRow class handles append mutations.
  • Row Factory#

    A single factory can be used to create any of the three row types. -To create a DirectRow:

    +To create a DirectRow:

    row = table.row(row_key)
     

    Unlike the previous string values we’ve used before, the row key must be bytes.

    -

    To create a ConditionalRow, +

    To create a ConditionalRow, first create a RowFilter and then

    cond_row = table.row(row_key, filter_=filter_)
     
    -

    To create an AppendRow

    +

    To create an AppendRow

    append_row = table.row(row_key, append=True)
     
    @@ -187,7 +355,7 @@

    Building Up MutationsDirect Mutations#

    Direct mutations can be added via one of four methods

      -
    • set_cell() allows a +

    • set_cell() allows a single value to be written to a column

      row.set_cell(column_family_id, column, value,
                    timestamp=timestamp)
      @@ -198,7 +366,7 @@ 

      Direct Mutationsdelete_cell() deletes +
    • delete_cell() deletes all cells (i.e. for all timestamps) in a given column

      row.delete_cell(column_family_id, column)
       
      @@ -212,9 +380,9 @@

      Direct Mutationsdelete_cells() does +
    • delete_cells() does the same thing as -delete_cell() +delete_cell() but accepts a list of columns in a column family rather than a single one.

      row.delete_cells(column_family_id, [column1, column2],
                        time_range=time_range)
      @@ -228,7 +396,7 @@ 

      Direct Mutationsdelete() will delete the +
    • delete() will delete the entire row

      row.delete()
       
      @@ -254,13 +422,13 @@

      Conditional MutationsAppend Mutations#

      Append mutations can be added via one of two methods

        -
      • append_cell_value() +

      • append_cell_value() appends a bytes value to an existing cell:

        append_row.append_cell_value(column_family_id, column, bytes_value)
         
      • -
      • increment_cell_value() +

      • increment_cell_value() increments an integer value in an existing cell:

        append_row.increment_cell_value(column_family_id, column, int_value)
         
        @@ -288,83 +456,83 @@

        Reading Data

        Read Single Row from a Table#

        To make a ReadRows API request for a single row key, use -Table.read_row():

        +Table.read_row():

        >>> row_data = table.read_row(row_key)
         >>> row_data.cells
         {
             u'fam1': {
                 b'col1': [
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
                 ],
                 b'col2': [
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
                 ],
             },
             u'fam2': {
                 b'col3': [
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        -            <gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
        +            <google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>,
                 ],
             },
         }
         >>> cell = row_data.cells[u'fam1'][b'col1'][0]
         >>> cell
        -<gcloud.bigtable.row_data.Cell at 0x7f80d150ef10>
        +<google.cloud.bigtable.row_data.Cell at 0x7f80d150ef10>
         >>> cell.value
         b'val1'
         >>> cell.timestamp
         datetime.datetime(2016, 2, 27, 3, 41, 18, 122823, tzinfo=<UTC>)
         
        -

        Rather than returning a DirectRow +

        Rather than returning a DirectRow or similar class, this method returns a -PartialRowData +PartialRowData instance. This class is used for reading and parsing data rather than for -modifying data (as DirectRow is).

        +modifying data (as DirectRow is).

        A filter can also be applied to the results:

        row_data = table.read_row(row_key, filter_=filter_val)
         

        The allowable filter_ values are the same as those used for a -ConditionalRow. For +ConditionalRow. For more information, see the -Table.read_row() documentation.

        +Table.read_row() documentation.

        Stream Many Rows from a Table#

        To make a ReadRows API request for a stream of rows, use -Table.read_rows():

        +Table.read_rows():

        row_data = table.read_rows()
         

        Using gRPC over HTTP/2, a continual stream of responses will be delivered. In particular

        -

        See the PartialRowsData +

        See the PartialRowsData documentation for more information.

        As with -Table.read_row(), an optional +Table.read_row(), an optional filter_ can be applied. In addition a start_key and / or end_key can be supplied for the stream, a limit can be set and a boolean allow_row_interleaving can be specified to allow faster streamed results at the potential cost of non-sequential reads.

        -

        See the Table.read_rows() +

        See the Table.read_rows() documentation for more information on the optional arguments.

        Sample Keys in a Table#

        Make a SampleRowKeys API request with -Table.sample_row_keys():

        +Table.sample_row_keys():

        keys_iterator = table.sample_row_keys()
         
        @@ -372,7 +540,7 @@

        Sample Keys in a Table

        As with -Table.read_rows(), the +Table.read_rows(), the returned keys_iterator is connected to a cancellable HTTP/2 stream.

        The next key in the result can be accessed via

        next_key = keys_iterator.next()
        @@ -392,123 +560,71 @@ 

        Sample Keys in a Table -

    -
    + + - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-instance-api.html b/latest/bigtable-instance-api.html index 131179017de1..b54b807899a2 100644 --- a/latest/bigtable-instance-api.html +++ b/latest/bigtable-instance-api.html @@ -1,224 +1,90 @@ + + + + + + + + + + Instance Admin API — google-cloud 92219b8 documentation + + + + + - - - - - Instance Admin API — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    +
    + + +
    + + + +
    + + + + + + +
    +
    + + + - - - + + +
    + +
    +
    +
    +
    + +
    +

    Instance Admin API#

    +

    After creating a Client, you can +interact with individual instances for a project.

    +
    +

    List Instances#

    +

    If you want a comprehensive list of all existing instances, make a +ListInstances API request with +Client.list_instances():

    +
    instances = client.list_instances()
    +
    +
    +
    +
    +

    Instance Factory#

    +

    To create a Instance object:

    +
    instance = client.instance(instance_id, location_id,
    +                           display_name=display_name)
    +
    +
    +
      +
    • location_id is the ID of the location in which the instance’s cluster +will be hosted, e.g. 'us-central1-c'. location_id is required for +instances which do not already exist.
    • +
    • display_name is optional. When not provided, display_name defaults +to the instance_id value.
    • +
    +

    You can also use Client.instance() to create a local wrapper for +instances that have already been created with the API, or through the web +conole:

    +
    instance = client.instance(existing_instance_id)
    +instance.reload()
    +
    +
    +
    +
    +

    Create a new Instance#

    +

    After creating the instance object, make a CreateInstance API request +with create():

    +
    instance.display_name = 'My very own instance'
    +instance.create()
    +
    +
    +
    +
    +

    Check on Current Operation#

    +
    +

    Note

    +

    When modifying a instance (via a CreateInstance request), the Bigtable +API will return a long-running operation and a corresponding +Operation object +will be returned by +create().

    +
    +

    You can check if a long-running operation (for a +create() has finished +by making a GetOperation request with +Operation.finished():

    +
    >>> operation = instance.create()
    +>>> operation.finished()
    +True
    +
    +
    +
    +

    Note

    +

    Once an Operation object +has returned True from +finished(), the +object should not be re-used. Subsequent calls to +finished() +will result in a ValueError.

    +
    +
    +
    +

    Get metadata for an existing Instance#

    +

    After creating the instance object, make a GetInstance API request +with reload():

    +
    instance.reload()
    +
    +
    +

    This will load display_name for the existing instance object.

    +
    +
    +

    Update an existing Instance#

    +

    After creating the instance object, make an UpdateInstance API request +with update():

    +
    client.display_name = 'New display_name'
    +instance.update()
    +
    +
    +
    +
    +

    Delete an existing Instance#

    +

    Make a DeleteInstance API request with +delete():

    +
    instance.delete()
    +
    +
    +
    +
    +

    Next Step#

    +

    Now we go down the hierarchy from +Instance to a +Table.

    +

    Head next to learn about the Table Admin API.

    +
    +
    + + +
    +
    + + +
    +
    + +
    + + - + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-instance.html b/latest/bigtable-instance.html index 9d8d83991e5f..3f075f545931 100644 --- a/latest/bigtable-instance.html +++ b/latest/bigtable-instance.html @@ -1,123 +1,271 @@ + + + + + + + + + + Instance — google-cloud 92219b8 documentation + + + + + - - - - - Instance — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + -
    + + +
    +
      +
    • Docs »
    • + +
    • Instance
    • +
    • + + + View page source + -
      -

      Instance#

      -
      -

      Warning

      -

      gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

      +
    • +
    +
    -

    User friendly container for Google Cloud Bigtable Instance.

    +
    +
    + +
    +

    Instance#

    +

    User friendly container for Google Cloud Bigtable Instance.

    -
    -class gcloud.bigtable.instance.Instance(instance_id, client, location_id='see-existing-cluster', display_name=None, serve_nodes=3)[source]#
    +
    +class google.cloud.bigtable.instance.Instance(instance_id, client, location_id='see-existing-cluster', display_name=None, serve_nodes=3)[source]#

    Bases: object

    Representation of a Google Cloud Bigtable Instance.

    -

    We can use a Instance to:

    +

    We can use a Instance to:

    Note

    @@ -130,7 +278,7 @@

    Instance

    Parameters:
    -
    -to_pb()[source]#
    +
    +to_pb()[source]#

    Converts the row filter to a protobuf.

    @@ -947,123 +1096,71 @@

    Bigtable Row Filters - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-row.html b/latest/bigtable-row.html index 4764ae65eb8c..e9ac30d09670 100644 --- a/latest/bigtable-row.html +++ b/latest/bigtable-row.html @@ -1,121 +1,270 @@ + + + + + + + + + + Bigtable Row — google-cloud 92219b8 documentation + + + + + + + - - - - - Bigtable Row — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Bigtable Row
    • +
    • + + + View page source + -
      -

      Bigtable Row#

      -
      -

      Warning

      -

      gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

      +
    • +
    +
    -

    User friendly container for Google Cloud Bigtable Row.

    +
    +
    + +
    +

    Bigtable Row#

    +

    User friendly container for Google Cloud Bigtable Row.

    -
    -class gcloud.bigtable.row.AppendRow(row_key, table)[source]#
    -

    Bases: gcloud.bigtable.row.Row

    +
    +class google.cloud.bigtable.row.AppendRow(row_key, table)[source]#
    +

    Bases: google.cloud.bigtable.row.Row

    Google Cloud Bigtable Row for sending append mutations.

    These mutations are intended to augment the value of an existing cell and uses the methods:

    The first works by appending bytes and the second by incrementing an integer (stored in the cell as 8 bytes). In either case, if the @@ -127,22 +276,22 @@

    Bigtable Row

    Parameters:
    • row_key (bytes) – The key for the current row.
    • -
    • table (Table) – The table that owns the row.
    • +
    • table (Table) – The table that owns the row.
    -
    -append_cell_value(column_family_id, column, value)[source]#
    +
    +append_cell_value(column_family_id, column, value)[source]#

    Appends a value to an existing cell.

    Note

    This method adds a read-modify rule protobuf to the accumulated read-modify rules on this row, but does not make an API request. To actually send an API request (with the rules) to the -Google Cloud Bigtable API, call commit().

    +Google Cloud Bigtable API, call commit().

    @@ -165,17 +314,17 @@

    Bigtable Row -
    -clear()[source]#
    +
    +clear()[source]#

    Removes all currently accumulated modifications on current row.

    -
    -commit()[source]#
    +
    +commit()[source]#

    Makes a ReadModifyWriteRow API request.

    -

    This commits modifications made by append_cell_value() and -increment_cell_value(). If no modifications were made, makes +

    This commits modifications made by append_cell_value() and +increment_cell_value(). If no modifications were made, makes no API request and just returns {}.

    Modifies a row atomically, reading the latest existing timestamp / value from the specified columns and writing a new value by @@ -215,15 +364,15 @@

    Bigtable Row

    +mutations exceeds the MAX_MUTATIONS.
    Raises:ValueError if the number of -mutations exceeds the MAX_MUTATIONS.
    -
    -increment_cell_value(column_family_id, column, int_value)[source]#
    +
    +increment_cell_value(column_family_id, column, int_value)[source]#

    Increments a value in an existing cell.

    Assumes the value in the cell is stored as a 64 bit integer serialized to bytes.

    @@ -232,7 +381,7 @@

    Bigtable RowThis method adds a read-modify rule protobuf to the accumulated read-modify rules on this row, but does not make an API request. To actually send an API request (with the rules) to the -Google Cloud Bigtable API, call commit().

    +Google Cloud Bigtable API, call commit().

    @@ -260,21 +409,21 @@

    Bigtable Row -
    -class gcloud.bigtable.row.ConditionalRow(row_key, table, filter_)[source]#
    -

    Bases: gcloud.bigtable.row._SetDeleteRow

    +
    +class google.cloud.bigtable.row.ConditionalRow(row_key, table, filter_)[source]#
    +

    Bases: google.cloud.bigtable.row._SetDeleteRow

    Google Cloud Bigtable Row for sending mutations conditionally.

    Each mutation has an associated state: True or False. -When commit()-ed, the mutations for the True +When commit()-ed, the mutations for the True state will be applied if the filter matches any cells in the row, otherwise the False state will be applied.

    -

    A ConditionalRow accumulates mutations in the same way a -DirectRow does:

    +

    A ConditionalRow accumulates mutations in the same way a +DirectRow does:

    with the only change the extra state parameter:

    >>> row_cond = table.row(b'row-key2', filter_=row_filter)
    @@ -284,8 +433,8 @@ 

    Bigtable Row

    Note

    -

    As with DirectRow, to actually send these mutations to the -Google Cloud Bigtable API, you must call commit().

    +

    As with DirectRow, to actually send these mutations to the +Google Cloud Bigtable API, you must call commit().

    @@ -293,26 +442,26 @@

    Bigtable Row

    Parameters:
    • row_key (bytes) – The key for the current row.
    • -
    • table (Table) – The table that owns the row.
    • -
    • filter (RowFilter) – Filter to be used for conditional mutations.
    • +
    • table (Table) – The table that owns the row.
    • +
    • filter (RowFilter) – Filter to be used for conditional mutations.
    -
    -clear()[source]#
    +
    +clear()[source]#

    Removes all currently accumulated mutations on the current row.

    -
    -commit()[source]#
    +
    +commit()[source]#

    Makes a CheckAndMutateRow API request.

    If no mutations have been created in the row, no request is made.

    The mutations will be applied conditionally, based on whether the -filter matches any cells in the ConditionalRow or not. (Each +filter matches any cells in the ConditionalRow or not. (Each method which adds a mutation has a state parameter for this purpose.)

    Mutations are applied atomically and in order, meaning that earlier @@ -330,22 +479,22 @@

    Bigtable Row

    Raises:ValueError if the number of -mutations exceeds the MAX_MUTATIONS.
    -
    -delete(state=True)[source]#
    +
    +delete(state=True)[source]#

    Deletes this row from the table.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -359,15 +508,15 @@

    Bigtable Row -
    -delete_cell(column_family_id, column, time_range=None, state=True)[source]#
    +
    +delete_cell(column_family_id, column, time_range=None, state=True)[source]#

    Deletes cell in this row.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -391,15 +540,15 @@

    Bigtable Row -
    -delete_cells(column_family_id, columns, time_range=None, state=True)[source]#
    +
    +delete_cells(column_family_id, columns, time_range=None, state=True)[source]#

    Deletes cells in this row.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -425,19 +574,19 @@

    Bigtable Row -
    -set_cell(column_family_id, column, value, timestamp=None, state=True)[source]#
    +
    +set_cell(column_family_id, column, value, timestamp=None, state=True)[source]#

    Sets a value in this row.

    The cell is determined by the row_key of this -ConditionalRow and the column. The column must be in -an existing ColumnFamily (as determined by +ConditionalRow and the column. The column must be in +an existing ColumnFamily (as determined by column_family_id).

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -465,16 +614,16 @@

    Bigtable Row -
    -class gcloud.bigtable.row.DirectRow(row_key, table)[source]#
    -

    Bases: gcloud.bigtable.row._SetDeleteRow

    +
    +class google.cloud.bigtable.row.DirectRow(row_key, table)[source]#
    +

    Bases: google.cloud.bigtable.row._SetDeleteRow

    Google Cloud Bigtable Row for sending “direct” mutations.

    These mutations directly set or delete cell contents:

    These methods can be used directly:

    >>> row = table.row(b'row-key1')
    @@ -484,10 +633,10 @@ 

    Bigtable Row

    Note

    -

    A DirectRow accumulates mutations locally via the -set_cell(), delete(), delete_cell() and -delete_cells() methods. To actually send these mutations to the -Google Cloud Bigtable API, you must call commit().

    +

    A DirectRow accumulates mutations locally via the +set_cell(), delete(), delete_cell() and +delete_cells() methods. To actually send these mutations to the +Google Cloud Bigtable API, you must call commit().

    @@ -495,21 +644,21 @@

    Bigtable Row

    Parameters:
    • row_key (bytes) – The key for the current row.
    • -
    • table (Table) – The table that owns the row.
    • +
    • table (Table) – The table that owns the row.
    -
    -clear()[source]#
    +
    +clear()[source]#

    Removes all currently accumulated mutations on the current row.

    -
    -commit()[source]#
    +
    +commit()[source]#

    Makes a MutateRow API request.

    If no mutations have been created in the row, no request is made.

    Mutations are applied atomically and in order, meaning that earlier @@ -522,35 +671,35 @@

    Bigtable Row

    Raises:ValueError if the number of -mutations exceeds the MAX_MUTATIONS.
    -
    -delete()[source]#
    +
    +delete()[source]#

    Deletes this row from the table.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    -
    -delete_cell(column_family_id, column, time_range=None)[source]#
    +
    +delete_cell(column_family_id, column, time_range=None)[source]#

    Deletes cell in this row.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -572,15 +721,15 @@

    Bigtable Row -
    -delete_cells(column_family_id, columns, time_range=None)[source]#
    +
    +delete_cells(column_family_id, columns, time_range=None)[source]#

    Deletes cells in this row.

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -604,18 +753,18 @@

    Bigtable Row -
    -set_cell(column_family_id, column, value, timestamp=None)[source]#
    +
    +set_cell(column_family_id, column, value, timestamp=None)[source]#

    Sets a value in this row.

    -

    The cell is determined by the row_key of this DirectRow +

    The cell is determined by the row_key of this DirectRow and the column. The column must be in an existing -ColumnFamily (as determined by column_family_id).

    +ColumnFamily (as determined by column_family_id).

    Note

    This method adds a mutation to the accumulated mutations on this row, but does not make an API request. To actually send an API request (with the mutations) to the Google Cloud -Bigtable API, call commit().

    +Bigtable API, call commit().

    @@ -641,22 +790,22 @@

    Bigtable Row -
    -gcloud.bigtable.row.MAX_MUTATIONS = 100000#
    +
    +google.cloud.bigtable.row.MAX_MUTATIONS = 100000#

    The maximum number of mutations that a row can accumulate.

    -
    -class gcloud.bigtable.row.Row(row_key, table)[source]#
    +
    +class google.cloud.bigtable.row.Row(row_key, table)[source]#

    Bases: object

    Base representation of a Google Cloud Bigtable Row.

    This class has three subclasses corresponding to the three RPC methods for sending row mutations:

    @@ -664,7 +813,7 @@

    Bigtable Row

    @@ -675,123 +824,71 @@

    Bigtable Row -

    gcloud

    -
    -

    Datastore

    - -

    Storage

    - -

    Pub/Sub

    - -

    BigQuery

    - -

    Cloud Bigtable

    - -

    Resource Manager

    - -

    DNS

    - -

    Stackdriver Logging

    - -

    Stackdriver Monitoring

    - -

    Translate

    - -

    External Links

    - + + + - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-table-api.html b/latest/bigtable-table-api.html index 904dcfa247b1..88714a338015 100644 --- a/latest/bigtable-table-api.html +++ b/latest/bigtable-table-api.html @@ -1,232 +1,90 @@ + + + + + + + + + + Table Admin API — google-cloud 92219b8 documentation + + + + + + + - - - - - Table Admin API — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    +
    + + +
    + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Table Admin API#

    +

    After creating a Instance, you can +interact with individual tables, groups of tables or column families within +a table.

    +
    +

    List Tables#

    +

    If you want a comprehensive list of all existing tables in a instance, make a +ListTables API request with +Instance.list_tables():

    +
    >>> instance.list_tables()
    +[<google.cloud.bigtable.table.Table at 0x7ff6a1de8f50>,
    + <google.cloud.bigtable.table.Table at 0x7ff6a1de8350>]
    +
    +
    +
    +
    +

    Table Factory#

    +

    To create a Table object:

    +
    table = instance.table(table_id)
    +
    +
    +

    Even if this Table already +has been created with the API, you’ll want this object to use as a +parent of a ColumnFamily +or Row.

    +
    +
    +

    Create a new Table#

    +

    After creating the table object, make a CreateTable API request +with create():

    +
    table.create()
    +
    +
    +

    If you would to initially split the table into several tablets (Tablets are +similar to HBase regions):

    +
    table.create(initial_split_keys=['s1', 's2'])
    +
    +
    +
    +
    +

    Delete an existing Table#

    +

    Make a DeleteTable API request with +delete():

    +
    table.delete()
    +
    +
    +
    +
    +

    List Column Families in a Table#

    +

    Though there is no official method for retrieving column families +associated with a table, the GetTable API method returns a +table object with the names of the column families.

    +

    To retrieve the list of column families use +list_column_families():

    +
    column_families = table.list_column_families()
    +
    +
    +
    +
    +

    Column Family Factory#

    +

    To create a +ColumnFamily object:

    +
    column_family = table.column_family(column_family_id)
    +
    +
    +

    There is no real reason to use this factory unless you intend to +create or delete a column family.

    +

    In addition, you can specify an optional gc_rule (a +GarbageCollectionRule +or similar):

    +
    column_family = table.column_family(column_family_id,
    +                                    gc_rule=gc_rule)
    +
    +
    +

    This rule helps the backend determine when and how to clean up old cells +in the column family.

    +

    See Column Families for more information about +GarbageCollectionRule +and related classes.

    +
    +
    +

    Create a new Column Family#

    +

    After creating the column family object, make a CreateColumnFamily API +request with +ColumnFamily.create()

    +
    column_family.create()
    +
    +
    +
    +
    +

    Delete an existing Column Family#

    +

    Make a DeleteColumnFamily API request with +ColumnFamily.delete()

    +
    column_family.delete()
    +
    +
    +
    +
    +

    Update an existing Column Family#

    +

    Make an UpdateColumnFamily API request with +ColumnFamily.delete()

    +
    column_family.update()
    +
    +
    +
    +
    +

    Next Step#

    +

    Now we go down the final step of the hierarchy from +Table to +Row as well as streaming +data directly via a Table.

    +

    Head next to learn about the Data API.

    +
    +
    + + +
    +
    + + +
    +
    + +
    + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-table.html b/latest/bigtable-table.html index b511b75339da..a20492e974f0 100644 --- a/latest/bigtable-table.html +++ b/latest/bigtable-table.html @@ -1,114 +1,263 @@ + + + + + + + + + + Table — google-cloud 92219b8 documentation + + + + + + + - - - - - Table — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Table
    • +
    • -
      -

      Table#

      -
      -

      Warning

      -

      gRPC is required for using the Cloud Bigtable API. As of May 2016, -grpcio is only supported in Python 2.7, so importing -gcloud.bigtable in other versions of Python will fail.

      + + View page source + + +
    • +
    +
    -

    User friendly container for Google Cloud Bigtable Table.

    +
    +
    + +
    +

    Table#

    +

    User friendly container for Google Cloud Bigtable Table.

    -
    -class gcloud.bigtable.table.Table(table_id, instance)[source]#
    +
    +class google.cloud.bigtable.table.Table(table_id, instance)[source]#

    Bases: object

    Representation of a Google Cloud Bigtable Table.

    -

    We can use a Table to:

    +

    We can use a Table to:

    Parameters:
    • row_key (bytes) – The key for the current row.
    • -
    • table (Table) – The table that owns the row.
    • +
    • table (Table) – The table that owns the row.
    @@ -131,15 +280,15 @@

    Table

    Parameters:
    • table_id (str) – The ID of the table.
    • -
    • instance (Instance) – The instance that owns the table.
    • +
    • instance (Instance) – The instance that owns the table.
    -
    -column_family(column_family_id, gc_rule=None)[source]#
    +
    +column_family(column_family_id, gc_rule=None)[source]#

    Factory to create a column family associated with this table.

    @@ -148,12 +297,12 @@

    Table

    -
    Parameters:
    • column_family_id (str) – The ID of the column family. Must be of the form [_a-zA-Z0-9][-_.a-zA-Z0-9]*.
    • -
    • gc_rule (GarbageCollectionRule) – (Optional) The garbage collection settings for this +
    • gc_rule (GarbageCollectionRule) – (Optional) The garbage collection settings for this column family.
    Return type:

    ColumnFamily

    +
    Return type:

    ColumnFamily

    Returns:

    A column family owned by this table.

    @@ -164,13 +313,13 @@

    Table
    -
    -create(initial_split_keys=None, column_families=())[source]#
    +
    +create(initial_split_keys=None, column_families=())[source]#

    Creates this table.

    Note

    A create request returns a -_generated_v2.table_pb2.Table but we don’t use +_generated.table_pb2.Table but we don’t use this response.

    @@ -186,7 +335,7 @@

    Table created, spanning the key ranges: [, s1), [s1, s2), [s2, ).
  • column_families (list) – (Optional) List or other iterable of -ColumnFamily instances.
  • +ColumnFamily instances. @@ -195,14 +344,14 @@

    Table
    -
    -delete()[source]#
    +
    +delete()[source]#

    Delete this table.

    -
    -list_column_families()[source]#
    +
    +list_column_families()[source]#

    List the column families owned by this table.

    @@ -212,7 +361,7 @@

    Table

    +ColumnFamily instances.
    Returns:Dictionary of column families attached to this table. Keys are strings (column family names) and values are -ColumnFamily instances.
    Raises:ValueError if the column family name from the response does not agree with the computed @@ -223,8 +372,8 @@

    Table
    -
    -name#
    +
    +name#

    Table name used in requests.

    Note

    @@ -247,8 +396,8 @@

    Table

    -
    -read_row(row_key, filter_=None)[source]#
    +
    +read_row(row_key, filter_=None)[source]#

    Read a single row from this table.

    @@ -256,12 +405,12 @@

    Table

    -
    Parameters:
    • row_key (bytes) – The key of the row to read from.
    • -
    • filter (RowFilter) – (Optional) The filter to apply to the contents of the +
    • filter (RowFilter) – (Optional) The filter to apply to the contents of the row. If unset, returns the entire row.
    Return type:

    PartialRowData, NoneType

    +
    Return type:

    PartialRowData, NoneType

    Returns:

    The contents of the row if any chunks were returned in @@ -277,8 +426,8 @@

    Table
    -
    -read_rows(start_key=None, end_key=None, limit=None, filter_=None)[source]#
    +
    +read_rows(start_key=None, end_key=None, limit=None, filter_=None)[source]#

    Read rows from this table.

    @@ -294,16 +443,16 @@

    Table
  • limit (int) – (Optional) The read will terminate after committing to N rows’ worth of results. The default (zero) is to return all results.
  • -
  • filter (RowFilter) – (Optional) The filter to apply to the contents of the +
  • filter (RowFilter) – (Optional) The filter to apply to the contents of the specified row(s). If unset, reads every column in each row.
  • -

    - @@ -312,8 +461,8 @@

    Table
    -
    -row(row_key, filter_=None, append=False)[source]#
    +
    +row(row_key, filter_=None, append=False)[source]#

    Factory to create a row associated with this table.

    Warning

    @@ -326,14 +475,14 @@

    Table

    - - + - +
    Return type:

    PartialRowsData

    +
    Return type:

    PartialRowsData

    Returns:

    A PartialRowsData convenience wrapper for consuming +

    Returns:

    A PartialRowsData convenience wrapper for consuming the streamed results.

    Parameters:
    • row_key (bytes) – The key for the row being created.
    • -
    • filter (RowFilter) – (Optional) Filter to be used for conditional mutations. -See DirectRow for more details.
    • +
    • filter (RowFilter) – (Optional) Filter to be used for conditional mutations. +See DirectRow for more details.
    • append (bool) – (Optional) Flag to determine if the row should be used for append mutations.
    Return type:

    DirectRow

    +
    Return type:

    DirectRow

    Returns:

    A row owned by this table.

    @@ -348,8 +497,8 @@

    Table
    -
    -sample_row_keys()[source]#
    +
    +sample_row_keys()[source]#

    Read a sample of row keys in the table.

    The returned row keys will delimit contiguous sections of the table of approximately equal size, which can be used to break up the data for @@ -375,7 +524,7 @@

    Table

    Return type:grpc.framework.alpha._reexport._CancellableIterator
    Return type:grpc._channel._Rendezvous
    Returns:A cancel-able iterator. Can be consumed by calling next() or by casting to a list and can be cancelled by @@ -390,123 +539,71 @@

    Table - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/bigtable-usage.html b/latest/bigtable-usage.html index f117b719c498..2239b55116b1 100644 --- a/latest/bigtable-usage.html +++ b/latest/bigtable-usage.html @@ -1,138 +1,90 @@ + + + + + + + + + + Using the API — google-cloud 92219b8 documentation + + + + + + + - - - - - Using the API — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    +
    + + +
    + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Using the API#

    +

    API requests are sent to the Google Cloud Bigtable API via RPC over HTTP/2. +In order to support this, we’ll rely on gRPC. We are working with the gRPC +team to rapidly make the install story more user-friendly.

    +

    Get started by learning about the +Client on the +Base for Everything page.

    +

    In the hierarchy of API concepts

    +
      +
    • a Client owns a +Cluster <google.cloud.bigtable.instance.Instance
    • +
    • a Cluster <google.cloud.bigtable.instance.Instance owns a +Table
    • +
    • a Table owns a +ColumnFamily
    • +
    • a Table owns a +Row +(and all the cells in the row)
    • +
    +
    + + +
    +
    + + +
    +
    + +
    + + + + - - - - + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/datastore-batches.html b/latest/datastore-batches.html index 33d0d7af4c5d..13aeee63b018 100644 --- a/latest/datastore-batches.html +++ b/latest/datastore-batches.html @@ -1,119 +1,274 @@ + + + + + + + + + + Batches — google-cloud 92219b8 documentation + + + + + + + - - - - - Batches — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    -
    + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Batches#

    Create / interact with a batch of updates / deletes.

    Batches provide the ability to execute multiple operations in a single request to the Cloud Datastore API.

    See https://cloud.google.com/datastore/docs/concepts/entities#Datastore_Batch_operations

    -
    -class gcloud.datastore.batch.Batch(client)[source]#
    +
    +class google.cloud.datastore.batch.Batch(client)[source]#

    Bases: object

    An abstraction representing a collected group of updates / deletes.

    -

    Used to build up a bulk mutuation.

    +

    Used to build up a bulk mutation.

    For example, the following snippet of code will put the two save operations and the delete operation into the same mutation, and send them to the server in a single API request:

    -
    >>> from gcloud import datastore
    +
    >>> from google.cloud import datastore
     >>> client = datastore.Client()
     >>> batch = client.batch()
     >>> batch.put(entity1)
    @@ -123,7 +278,7 @@ 

    You can also use a batch as a context manager, in which case -commit() will be called automatically if its block exits without +commit() will be called automatically if its block exits without raising an exception:

    >>> with batch:
     ...     batch.put(entity1)
    @@ -141,18 +296,18 @@ 

    Parameters:client (gcloud.datastore.client.Client) – The client used to connect to datastore.
    Parameters:client (google.cloud.datastore.client.Client) – The client used to connect to datastore.
    -
    -begin()[source]#
    +
    +begin()[source]#

    Begins a batch.

    This method is called automatically when entering a with statement, however it can be called explicitly if you don’t want to use a context manager.

    -

    Overridden by gcloud.datastore.transaction.Transaction.

    +

    Overridden by google.cloud.datastore.transaction.Transaction.

    @@ -164,8 +319,8 @@

    -
    -commit()[source]#
    +
    +commit()[source]#

    Commits the batch.

    This is called automatically upon exiting a with statement, however it can be called explicitly if you don’t want to use a @@ -173,14 +328,14 @@

    -
    -connection#
    +
    +connection#

    Getter for connection over which the batch will run.

    - + @@ -189,20 +344,20 @@

    -
    -current()[source]#
    +
    +current()[source]#

    Return the topmost batch / transaction, or None.

    -
    -delete(key)[source]#
    -

    Remember a key to be deleted during commit().

    +
    +delete(key)[source]#
    +

    Remember a key to be deleted during commit().

    Return type:gcloud.datastore.connection.Connection
    Return type:google.cloud.datastore.connection.Connection
    Returns:The connection over which the batch will run.
    - + @@ -212,12 +367,12 @@

    -
    -mutations#
    +
    +mutations#

    Getter for the changes accumulated by this batch.

    Every batch is committed with a single commit request containing all -the work to be done as mutations. Inside a batch, calling put() -with an entity, or delete() with a key, builds up the request by +the work to be done as mutations. Inside a batch, calling put() +with an entity, or delete() with a key, builds up the request by adding a new mutation. This getter returns the protobuf that has been built-up so far.

    Parameters:key (gcloud.datastore.key.Key) – the key to be deleted.
    Parameters:key (google.cloud.datastore.key.Key) – the key to be deleted.
    Raises:ValueError if key is not complete, or if the key’s project does not match ours.
    @@ -234,8 +389,8 @@

    -
    -namespace#
    +
    +namespace#

    Getter for namespace in which the batch will run.

    @@ -250,8 +405,8 @@

    -
    -project#
    +
    +project#

    Getter for project in which the batch will run.

    @@ -266,9 +421,9 @@

    -
    -put(entity)[source]#
    -

    Remember an entity’s state to be saved during commit().

    +
    +put(entity)[source]#
    +

    Remember an entity’s state to be saved during commit().

    Note

    Any existing properties for the entity will be replaced by those @@ -282,7 +437,7 @@

    Python3) map to ‘string_value’ in the datastore; values which are “bytes” (‘str’ in Python2, ‘bytes’ in Python3) map to ‘blob_value’.

    -

    When an entity has a partial key, calling commit() sends it as +

    When an entity has a partial key, calling commit() sends it as an insert mutation and the key is completed. On return, the key for the entity passed in is updated to match the key ID assigned by the server.

    @@ -290,7 +445,7 @@

    - + @@ -300,11 +455,11 @@

    -
    -rollback()[source]#
    +
    +rollback()[source]#

    Rolls back the current batch.

    Marks the batch as aborted (can’t be used again).

    -

    Overridden by gcloud.datastore.transaction.Transaction.

    +

    Overridden by google.cloud.datastore.transaction.Transaction.

    @@ -312,123 +467,71 @@

    - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/datastore-client.html b/latest/datastore-client.html index 0fe43e19242c..51e37a7db4e4 100644 --- a/latest/datastore-client.html +++ b/latest/datastore-client.html @@ -1,109 +1,267 @@ + + + + + + + + + + Datastore Client — google-cloud 92219b8 documentation + + + + + - - - - - Datastore Client — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Datastore Client#

    Convenience wrapper for invoking APIs/factories w/ a project.

    -
    -class gcloud.datastore.client.Client(project=None, namespace=None, credentials=None, http=None)[source]#
    -

    Bases: gcloud.client.Client, gcloud.client._ClientProjectMixin

    +
    +class google.cloud.datastore.client.Client(project=None, namespace=None, credentials=None, http=None)[source]#
    +

    Bases: google.cloud.client.Client, google.cloud.client._ClientProjectMixin

    Convenience wrapper for invoking APIs/factories w/ a project.

    Parameters:entity (gcloud.datastore.entity.Entity) – the entity to be saved.
    Parameters:entity (google.cloud.datastore.entity.Entity) – the entity to be saved.
    Raises:ValueError if entity has no key assigned, or if the key’s project does not match ours.
    @@ -112,7 +270,7 @@

    Parameters:
    • project (string) – (optional) The project to pass to proxied API methods.
    • namespace (string) – (optional) namespace to pass to proxied API methods.
    • -
    • credentials (oauth2client.client.OAuth2Credentials or +
    • credentials (oauth2client.client.OAuth2Credentials or NoneType) – The OAuth2 Credentials to use for the connection owned by this client. If not passed (and if no http object is passed), falls back to the default inferred @@ -126,20 +284,20 @@

    -
    -allocate_ids(incomplete_key, num_ids)[source]#
    +
    +allocate_ids(incomplete_key, num_ids)[source]#

    Allocate a list of IDs from a partial key.

    - -
    Parameters:
    Return type:

    list of gcloud.datastore.key.Key

    +
    Return type:

    list of google.cloud.datastore.key.Key

    Returns:

    The (complete) keys allocated with incomplete_key as @@ -155,20 +313,20 @@

    -
    -batch()[source]#
    -

    Proxy to gcloud.datastore.batch.Batch.

    +
    +batch()[source]#
    +

    Proxy to google.cloud.datastore.batch.Batch.

    -
    -current_batch#
    +
    +current_batch#

    Currently-active batch.

    - @@ -178,16 +336,16 @@

    -
    -current_transaction#
    +
    +current_transaction#

    Currently-active transaction.

    Return type:gcloud.datastore.batch.Batch, or an object +
    Return type:google.cloud.datastore.batch.Batch, or an object implementing its API, or NoneType (if no batch is active).
    Returns:The batch/transaction at the top of the batch stack.
    - + @@ -196,12 +354,12 @@

    -
    -delete(key)[source]#
    +
    +delete(key)[source]#

    Delete the key in the Cloud Datastore.

    Note

    -

    This is just a thin wrapper over delete_multi(). +

    This is just a thin wrapper over delete_multi(). The backend API does not make a distinction between a single key or multiple keys in a commit request.

    @@ -209,33 +367,33 @@

    - +
    Return type:gcloud.datastore.transaction.Transaction, or an object -implementing its API, or NoneType (if no transaction is -active).
    Return type:google.cloud.datastore.transaction.Transaction, or an +object implementing its API, or NoneType (if no transaction +is active).
    Returns:The transaction at the top of the batch stack.
    Parameters:key (gcloud.datastore.key.Key) – The key to be deleted from the datastore.
    Parameters:key (google.cloud.datastore.key.Key) – The key to be deleted from the datastore.
    -
    -delete_multi(keys)[source]#
    +
    +delete_multi(keys)[source]#

    Delete keys from the Cloud Datastore.

    - +
    Parameters:keys (list of gcloud.datastore.key.Key) – The keys to be deleted from the datastore.
    Parameters:keys (list of google.cloud.datastore.key.Key) – The keys to be deleted from the Datastore.
    -
    -get(key, missing=None, deferred=None, transaction=None)[source]#
    +
    +get(key, missing=None, deferred=None, transaction=None)[source]#

    Retrieve an entity from a single key (if it exists).

    Note

    -

    This is just a thin wrapper over get_multi(). +

    This is just a thin wrapper over get_multi(). The backend API does not make a distinction between a single key or multiple keys in a lookup request.

    @@ -244,18 +402,18 @@

    Parameters:
      -
    • key (gcloud.datastore.key.Key) – The key to be retrieved from the datastore.
    • +
    • key (google.cloud.datastore.key.Key) – The key to be retrieved from the datastore.
    • missing (list) – (Optional) If a list is passed, the key-only entities returned by the backend as “missing” will be copied into it.
    • deferred (list) – (Optional) If a list is passed, the keys returned by the backend as “deferred” will be copied into it.
    • -
    • transaction (gcloud.datastore.transaction.Transaction) – (Optional) Transaction to use for read consistency. +
    • transaction (Transaction) – (Optional) Transaction to use for read consistency. If not passed, uses current transaction, if set.
    Return type:

    gcloud.datastore.entity.Entity or NoneType

    +
    Return type:

    google.cloud.datastore.entity.Entity or NoneType

    Returns:

    The requested entity if it exists.

    @@ -266,27 +424,27 @@

    -
    -get_multi(keys, missing=None, deferred=None, transaction=None)[source]#
    +
    +get_multi(keys, missing=None, deferred=None, transaction=None)[source]#

    Retrieve entities, along with their attributes.

    - - +
    Parameters:
      -
    • keys (list of gcloud.datastore.key.Key) – The keys to be retrieved from the datastore.
    • +
    • keys (list of google.cloud.datastore.key.Key) – The keys to be retrieved from the datastore.
    • missing (list) – (Optional) If a list is passed, the key-only entities returned by the backend as “missing” will be copied into it. If the list is not empty, an error will occur.
    • deferred (list) – (Optional) If a list is passed, the keys returned by the backend as “deferred” will be copied into it. If the list is not empty, an error will occur.
    • -
    • transaction (gcloud.datastore.transaction.Transaction) – (Optional) Transaction to use for read consistency. +
    • transaction (Transaction) – (Optional) Transaction to use for read consistency. If not passed, uses current transaction, if set.
    Return type:

    list of gcloud.datastore.entity.Entity

    +
    Return type:

    list of google.cloud.datastore.entity.Entity

    Returns:

    The requested entities.

    @@ -301,19 +459,19 @@

    -
    -key(*path_args, **kwargs)[source]#
    -

    Proxy to gcloud.datastore.key.Key.

    +
    +key(*path_args, **kwargs)[source]#
    +

    Proxy to google.cloud.datastore.key.Key.

    Passes our project.

    -
    -put(entity)[source]#
    +
    +put(entity)[source]#

    Save an entity in the Cloud Datastore.

    Note

    -

    This is just a thin wrapper over put_multi(). +

    This is just a thin wrapper over put_multi(). The backend API does not make a distinction between a single entity or multiple entities in a commit request.

    @@ -321,21 +479,21 @@

    Parameters:entity (gcloud.datastore.entity.Entity) – The entity to be saved to the datastore.
    Parameters:entity (google.cloud.datastore.entity.Entity) – The entity to be saved to the datastore.
    -
    -put_multi(entities)[source]#
    +
    +put_multi(entities)[source]#

    Save entities in the Cloud Datastore.

    - + @@ -344,71 +502,107 @@

    -
    -query(**kwargs)[source]#
    -

    Proxy to gcloud.datastore.query.Query.

    +
    +query(**kwargs)[source]#
    +

    Proxy to google.cloud.datastore.query.Query.

    Passes our project.

    +

    Using query to search a datastore:

    +
    >>> from google.cloud import datastore
    +>>> client = datastore.Client()
    +>>> query = client.query(kind='MyKind')
    +>>> query.add_filter('property', '=', 'val')
    +
    +
    +

    Using the query iterator’s +next_page() method:

    +
    >>> query_iter = query.fetch()
    +>>> entities, more_results, cursor = query_iter.next_page()
    +>>> entities
    +[<list of Entity unmarshalled from protobuf>]
    +>>> more_results
    +<boolean of more results>
    +>>> cursor
    +<string containing cursor where fetch stopped>
    +
    +
    +

    Under the hood this is doing:

    +
    >>> connection.run_query('project', query.to_protobuf())
    +[<list of Entity Protobufs>], cursor, more_results, skipped_results
    +
    +
    +

    Parameters:entities (list of gcloud.datastore.entity.Entity) – The entities to be saved to the datastore.
    Parameters:entities (list of google.cloud.datastore.entity.Entity) – The entities to be saved to the datastore.
    Raises:ValueError if entities is a single entity.
    +++ + + + + + + + +
    Parameters:kwargs (dict) – Parameters for initializing and instance of +google.cloud.datastore.query.Query.
    Return type:google.cloud.datastore.query.Query
    Returns:An instance of google.cloud.datastore.query.Query
    -
    -transaction()[source]#
    -

    Proxy to gcloud.datastore.transaction.Transaction.

    +
    +transaction()[source]#
    +

    Proxy to google.cloud.datastore.transaction.Transaction.

    -
    -

    Connection#

    -

    Connections to gcloud datastore API servers.

    +
    +

    Connection#

    +

    Connections to Google Cloud Datastore API servers.

    -
    -class gcloud.datastore.connection.Connection(credentials=None, http=None, api_base_url=None)[source]#
    -

    Bases: gcloud.connection.Connection

    +
    +class google.cloud.datastore.connection.Connection(credentials=None, http=None)[source]#
    +

    Bases: google.cloud.connection.Connection

    A connection to the Google Cloud Datastore via the Protobuf API.

    This class should understand only the basic types (and protobufs) -in method arguments, however should be capable of returning advanced types.

    +in method arguments, however it should be capable of returning advanced +types.

    Parameters:
    -
    -API_BASE_URL = 'https://datastore.googleapis.com'#
    +
    +API_BASE_URL = 'https://datastore.googleapis.com'#

    The base of the API call URL.

    -
    -API_URL_TEMPLATE = '{api_base}/{api_version}/projects/{project}:{method}'#
    +
    +API_URL_TEMPLATE = '{api_base}/{api_version}/projects/{project}:{method}'#

    A template for the URL of a particular API call.

    -
    -API_VERSION = 'v1beta3'#
    +
    +API_VERSION = 'v1'#

    The version of the API, used in building the API call’s URL.

    -
    -SCOPE = ('https://www.googleapis.com/auth/datastore',)#
    +
    +SCOPE = ('https://www.googleapis.com/auth/datastore',)#

    The scopes required for authenticating as a Cloud Datastore consumer.

    -
    -allocate_ids(project, key_pbs)[source]#
    +
    +allocate_ids(project, key_pbs)[source]#

    Obtain backend-generated IDs for a set of keys.

    Maps the DatastoreService.AllocateIds protobuf RPC.

    @@ -418,11 +612,11 @@

    -
    Parameters:
    • project (string) – The project to which the transaction belongs.
    • key_pbs (list of -gcloud.datastore._generated.entity_pb2.Key) – The keys for which the backend should allocate IDs.
    • +google.cloud.datastore._generated.entity_pb2.Key) – The keys for which the backend should allocate IDs.
    Return type:

    list of gcloud.datastore._generated.entity_pb2.Key

    +
    Return type:

    list of datastore._generated.entity_pb2.Key

    Returns:

    An equal number of keys, with IDs filled in by the backend.

    @@ -433,8 +627,8 @@

    -
    -begin_transaction(project)[source]#
    +
    +begin_transaction(project)[source]#

    Begin a transaction.

    Maps the DatastoreService.BeginTransaction protobuf RPC.

    @@ -452,8 +646,8 @@

    -
    -build_api_url(project, method, base_url=None, api_version=None)[source]#
    +
    +build_api_url(project, method, base_url=None, api_version=None)[source]#

    Construct the URL for a particular API call.

    This method is used internally to come up with the URL to use when making RPCs to the Cloud Datastore API.

    @@ -483,9 +677,9 @@

    -
    -commit(project, request, transaction_id)[source]#
    -

    Commit mutations in context of current transation (if any).

    +
    +commit(project, request, transaction_id)[source]#
    +

    Commit mutations in context of current transaction (if any).

    Maps the DatastoreService.Commit protobuf RPC.

    @@ -495,7 +689,7 @@

  • project (string) – The project to which the transaction applies.
  • request (_generated.datastore_pb2.CommitRequest) – The protobuf with the mutations being committed.
  • transaction_id (string or None) – The transaction ID returned from -begin_transaction(). Non-transactional +begin_transaction(). Non-transactional batches must pass None.
  • @@ -521,23 +715,23 @@

    -
    -lookup(project, key_pbs, eventual=False, transaction_id=None)[source]#
    +
    +lookup(project, key_pbs, eventual=False, transaction_id=None)[source]#

    Lookup keys from a project in the Cloud Datastore.

    Maps the DatastoreService.Lookup protobuf RPC.

    This uses mostly protobufs -(gcloud.datastore._generated.entity_pb2.Key as input and -gcloud.datastore._generated.entity_pb2.Entity as output). It -is used under the hood in -Client.get():

    -
    >>> from gcloud import datastore
    +(google.cloud.datastore._generated.entity_pb2.Key as input
    +and google.cloud.datastore._generated.entity_pb2.Entity
    +as output). It is used under the hood in
    +Client.get():

    +
    >>> from google.cloud import datastore
     >>> client = datastore.Client(project='project')
     >>> key = client.key('MyKind', 1234)
     >>> client.get(key)
     [<Entity object>]
     
    -

    Using a Connection directly:

    +

    Using a Connection directly:

    >>> connection.lookup('project', [key.to_protobuf()])
     [<Entity protobuf>]
     
    @@ -549,7 +743,7 @@

    @@ -574,8 +768,8 @@

    -
    -rollback(project, transaction_id)[source]#
    +
    +rollback(project, transaction_id)[source]#

    Rollback the connection’s existing transaction.

    Maps the DatastoreService.Rollback protobuf RPC.

    Parameters:
    • project (string) – The project to look up the keys in.
    • key_pbs (list of -gcloud.datastore._generated.entity_pb2.Key) – The keys to retrieve from the datastore.
    • +google.cloud.datastore._generated.entity_pb2.Key) – The keys to retrieve from the datastore.
    • eventual (bool) – If False (the default), request STRONG read consistency. If True, request EVENTUAL read consistency.
    • @@ -564,9 +758,9 @@

    Returns:

    A triple of (results, missing, deferred) where both results and missing are lists of -gcloud.datastore._generated.entity_pb2.Entity and -deferred is a list of -gcloud.datastore._generated.entity_pb2.Key.

    +google.cloud.datastore._generated.entity_pb2.Entity +and deferred is a list of +google.cloud.datastore._generated.entity_pb2.Key.

    @@ -585,7 +779,7 @@

    @@ -594,47 +788,24 @@

    -
    -run_query(project, query_pb, namespace=None, eventual=False, transaction_id=None)[source]#
    +
    +run_query(project, query_pb, namespace=None, eventual=False, transaction_id=None)[source]#

    Run a query on the Cloud Datastore.

    Maps the DatastoreService.RunQuery protobuf RPC.

    Given a Query protobuf, sends a runQuery request to the Cloud Datastore API and returns a list of entity protobufs matching the query.

    You typically wouldn’t use this method directly, in favor of the -gcloud.datastore.query.Query.fetch() method.

    -

    Under the hood, the gcloud.datastore.query.Query class -uses this method to fetch data:

    -
    >>> from gcloud import datastore
    ->>> client = datastore.Client()
    ->>> query = client.query(kind='MyKind')
    ->>> query.add_filter('property', '=', 'val')
    -
    -
    -

    Using the query iterator’s -next_page() method:

    -
    >>> query_iter = query.fetch()
    ->>> entities, more_results, cursor = query_iter.next_page()
    ->>> entities
    -[<list of Entity unmarshalled from protobuf>]
    ->>> more_results
    -<boolean of more results>
    ->>> cursor
    -<string containing cursor where fetch stopped>
    -
    -
    -

    Under the hood this is doing:

    -
    >>> connection.run_query('project', query.to_protobuf())
    -[<list of Entity Protobufs>], cursor, more_results, skipped_results
    -
    -
    +google.cloud.datastore.query.Query.fetch() method.

    +

    Under the hood, the google.cloud.datastore.query.Query class +uses this method to fetch data.

    Parameters:
    @@ -227,8 +382,8 @@

    -
    -ancestor#
    +
    +ancestor#

    The ancestor key for the query.

    Parameters:
    @@ -243,8 +398,8 @@

    -
    -distinct_on#
    +
    +distinct_on#

    Names of fields used to group query results.

    @@ -259,11 +414,11 @@

    -
    -fetch(limit=None, offset=0, start_cursor=None, end_cursor=None, client=None)[source]#
    +
    +fetch(limit=None, offset=0, start_cursor=None, end_cursor=None, client=None)[source]#

    Execute the Query; return an iterator for the matching entities.

    For example:

    -
    >>> from gcloud import datastore
    +
    >>> from google.cloud import datastore
     >>> client = datastore.Client()
     >>> query = client.query(kind='Person')
     >>> query.add_filter('name', '=', 'Sally')
    @@ -282,12 +437,12 @@ 

  • offset (integer) – An optional offset passed through to the iterator.
  • start_cursor (bytes) – An optional cursor passed through to the iterator.
  • end_cursor (bytes) – An optional cursor passed through to the iterator.
  • -
  • client (gcloud.datastore.client.Client) – client used to connect to datastore. +
  • client (google.cloud.datastore.client.Client) – client used to connect to datastore. If not supplied, uses the query’s value.
  • -

    Return type:

    Iterator

    +
    Return type:

    Iterator

    Returns:

    The iterator for the query.

    @@ -302,8 +457,8 @@

    -
    -filters#
    +
    +filters#

    Filters set on the query.

    @@ -318,15 +473,15 @@

    -
    -key_filter(key, operator='=')[source]#
    +
    +key_filter(key, operator='=')[source]#

    Filter on a key.

    Parameters: @@ -337,14 +492,14 @@

    -
    -keys_only()[source]#
    +
    +keys_only()[source]#

    Set the projection to include only keys.

    -
    -kind#
    +
    +kind#

    Get the Kind of the Query.

    @@ -359,8 +514,8 @@

    -
    -namespace#
    +
    +namespace#

    This query’s namespace

    @@ -375,8 +530,8 @@

    -
    -order#
    +
    +order#

    Names of fields used to sort query results.

    @@ -391,8 +546,8 @@

    -
    -project#
    +
    +project#

    Get the project for this Query.

    @@ -407,8 +562,8 @@

    -
    -projection#
    +
    +projection#

    Fields names returned by the query.

    @@ -427,123 +582,71 @@

    - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/datastore-transactions.html b/latest/datastore-transactions.html index 2b6be75d73f3..1fb90fd176d4 100644 --- a/latest/datastore-transactions.html +++ b/latest/datastore-transactions.html @@ -1,123 +1,278 @@ + + + + + + + + + + Transactions — google-cloud 92219b8 documentation + + + + + + + - - - - - Transactions — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    -
    + + + + + +
    +
    + + + + + + +
    +
      +
    • Docs »
    • + +
    • Transactions
    • +
    • + + + View page source + -
      -

      Transactions#

      -

      Create / interact with gcloud datastore transactions.

      +
    • +
    +
    +
    +
    +
    + +
    +

    Transactions#

    +

    Create / interact with Google Cloud Datastore transactions.

    -
    -class gcloud.datastore.transaction.Transaction(client)[source]#
    -

    Bases: gcloud.datastore.batch.Batch

    +
    +class google.cloud.datastore.transaction.Transaction(client)[source]#
    +

    Bases: google.cloud.datastore.batch.Batch

    An abstraction representing datastore Transactions.

    Transactions can be used to build up a bulk mutation and ensure all or none succeed (transactionally).

    For example, the following snippet of code will put the two save operations (either insert or upsert) into the same mutation, and execute those within a transaction:

    -
    >>> from gcloud import datastore
    +
    >>> from google.cloud import datastore
     >>> client = datastore.Client()
     >>> with client.transaction():
     ...     client.put_multi([entity1, entity2])
     
    -

    Because it derives from Batch, -Transaction also provides put() and delete() methods:

    +

    Because it derives from Batch, +Transaction also provides put() and delete() methods:

    >>> with client.transaction() as xact:
     ...     xact.put(entity1)
     ...     xact.delete(entity2.key)
    @@ -144,7 +299,7 @@ 

    entity won’t have a complete key until the transaction is committed.

    -

    Once you exit the transaction (or call commit()), the +

    Once you exit the transaction (or call commit()), the automatically generated ID will be assigned to the entity:

    >>> with client.transaction():
     ...     entity = datastore.Entity(key=client.key('Thing'))
    @@ -175,13 +330,13 @@ 

    - +
    Parameters:client (gcloud.datastore.client.Client) – the client used to connect to datastore.
    Parameters:client (google.cloud.datastore.client.Client) – the client used to connect to datastore.
    -
    -begin()[source]#
    +
    +begin()[source]#

    Begins a transaction.

    This method is called automatically when entering a with statement, however it can be called explicitly if you don’t want @@ -197,8 +352,8 @@

    -
    -commit()[source]#
    +
    +commit()[source]#

    Commits the transaction.

    This is called automatically upon exiting a with statement, however it can be called explicitly if you don’t want to use a @@ -210,14 +365,14 @@

    -
    -connection#
    +
    +connection#

    Getter for connection over which the batch will run.

    - + @@ -226,8 +381,8 @@

    -
    -current()[source]#
    +
    +current()[source]#

    Return the topmost transaction.

    Note

    @@ -238,7 +393,7 @@

    - + @@ -247,14 +402,14 @@

    -
    -delete(key)#
    -

    Remember a key to be deleted during commit().

    +
    +delete(key)#
    +

    Remember a key to be deleted during commit().

    Return type:gcloud.datastore.connection.Connection
    Return type:google.cloud.datastore.connection.Connection
    Returns:The connection over which the batch will run.
    Return type:gcloud.datastore.transaction.Transaction or None
    Return type:google.cloud.datastore.transaction.Transaction or None
    Returns:The current transaction (if any are active).
    - + @@ -264,8 +419,8 @@

    -
    -id#
    +
    +id#

    Getter for the transaction ID.

    Parameters:key (gcloud.datastore.key.Key) – the key to be deleted.
    Parameters:key (google.cloud.datastore.key.Key) – the key to be deleted.
    Raises:ValueError if key is not complete, or if the key’s project does not match ours.
    @@ -280,12 +435,12 @@

    -
    -mutations#
    +
    +mutations#

    Getter for the changes accumulated by this batch.

    Every batch is committed with a single commit request containing all -the work to be done as mutations. Inside a batch, calling put() -with an entity, or delete() with a key, builds up the request by +the work to be done as mutations. Inside a batch, calling put() +with an entity, or delete() with a key, builds up the request by adding a new mutation. This getter returns the protobuf that has been built-up so far.

    @@ -302,8 +457,8 @@

    -
    -namespace#
    +
    +namespace#

    Getter for namespace in which the batch will run.

    @@ -318,8 +473,8 @@

    -
    -project#
    +
    +project#

    Getter for project in which the batch will run.

    @@ -334,9 +489,9 @@

    -
    -put(entity)#
    -

    Remember an entity’s state to be saved during commit().

    +
    +put(entity)#
    +

    Remember an entity’s state to be saved during commit().

    Note

    Any existing properties for the entity will be replaced by those @@ -350,7 +505,7 @@

    Python3) map to ‘string_value’ in the datastore; values which are “bytes” (‘str’ in Python2, ‘bytes’ in Python3) map to ‘blob_value’.

    -

    When an entity has a partial key, calling commit() sends it as +

    When an entity has a partial key, calling commit() sends it as an insert mutation and the key is completed. On return, the key for the entity passed in is updated to match the key ID assigned by the server.

    @@ -358,7 +513,7 @@

    - + @@ -368,8 +523,8 @@

    -
    -rollback()[source]#
    +
    +rollback()[source]#

    Rolls back the current transaction.

    This method has necessary side-effects:

    Parameters:entity (gcloud.datastore.entity.Entity) – the entity to be saved.
    Parameters:entity (google.cloud.datastore.entity.Entity) – the entity to be saved.
    Raises:ValueError if entity has no key assigned, or if the key’s project does not match ours.
    - +
    Parameters:zone (gcloud.dns.zone.ManagedZone) – A zone which holds one or more record sets.
    Parameters:zone (google.cloud.dns.zone.ManagedZone) – A zone which holds one or more record sets.
    -
    -add_record_set(record_set)[source]#
    +
    +add_record_set(record_set)[source]#

    Append a record set to the ‘additions’ for the change set.

    - + @@ -133,33 +288,33 @@

    -
    -additions#
    +
    +additions#

    Resource record sets to be added to the zone.

    Parameters:record_set (gcloud.dns.resource_record_set.ResourceRecordSet) – the record set to append
    Parameters:record_set (google.cloud.dns.resource_record_set.ResourceRecordSet) – the record set to append.
    Raises:ValueError if record_set is not of the required type.
    +google.cloud.dns.resource_record_set.ResourceRecordSet. - +
    Return type:sequence of -gcloud.dns.resource_record_set.ResourceRecordSet.
    Returns:record sets appended via add_record_set()
    Returns:record sets appended via add_record_set().
    -
    -create(client=None)[source]#
    -

    API call: create the change set via a POST request

    +
    +create(client=None)[source]#
    +

    API call: create the change set via a POST request.

    See: https://cloud.google.com/dns/api/v1/changes/create

    - @@ -167,14 +322,14 @@

    -
    -delete_record_set(record_set)[source]#
    +
    +delete_record_set(record_set)[source]#

    Append a record set to the ‘deletions’ for the change set.

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    - + @@ -183,33 +338,33 @@

    -
    -deletions#
    +
    +deletions#

    Resource record sets to be deleted from the zone.

    Parameters:record_set (gcloud.dns.resource_record_set.ResourceRecordSet) – the record set to append
    Parameters:record_set (google.cloud.dns.resource_record_set.ResourceRecordSet) – the record set to append.
    Raises:ValueError if record_set is not of the required type.
    +google.cloud.dns.resource_record_set.ResourceRecordSet. - +
    Return type:sequence of -gcloud.dns.resource_record_set.ResourceRecordSet.
    Returns:record sets appended via delete_record_set()
    Returns:record sets appended via delete_record_set().
    -
    -exists(client=None)[source]#
    -

    API call: test for the existence of the change set via a GET request

    +
    +exists(client=None)[source]#
    +

    API call: test for the existence of the change set via a GET request.

    See https://cloud.google.com/dns/api/v1/changes/get

    - @@ -221,20 +376,20 @@

    -
    -classmethod from_api_repr(resource, zone)[source]#
    +
    +classmethod from_api_repr(resource, zone)[source]#

    Factory: construct a change set given its API representation

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    Return type:bool
    - -
    Parameters:
    Return type:

    gcloud.dns.changes.Changes

    +
    Return type:

    google.cloud.dns.changes.Changes

    Returns:

    RRS parsed from resource.

    @@ -245,8 +400,8 @@

    -
    -name#
    +
    +name#

    Name of the change set.

    @@ -261,8 +416,8 @@

    -
    -path#
    +
    +path#

    URL path for change set APIs.

    @@ -277,16 +432,16 @@

    -
    -reload(client=None)[source]#
    -

    API call: refresh zone properties via a GET request

    +
    +reload(client=None)[source]#
    +

    API call: refresh zone properties via a GET request.

    See https://cloud.google.com/dns/api/v1/changes/get

    - @@ -294,8 +449,8 @@

    -
    -started#
    +
    +started#

    Time when the change set was started.

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    @@ -310,8 +465,8 @@

    -
    -status#
    +
    +status#

    Status of the change set.

    @@ -330,123 +485,71 @@

    - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/dns-client.html b/latest/dns-client.html index 7b8f193c609a..48a48460d3d1 100644 --- a/latest/dns-client.html +++ b/latest/dns-client.html @@ -1,109 +1,267 @@ + + + + + + + + + + DNS Client — google-cloud 92219b8 documentation + + + + + + + - - - - - DNS Client — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    DNS Client#

    Client for interacting with the Google Cloud DNS API.

    -
    -class gcloud.dns.client.Client(project=None, credentials=None, http=None)[source]#
    -

    Bases: gcloud.client.JSONClient

    +
    +class google.cloud.dns.client.Client(project=None, credentials=None, http=None)[source]#
    +

    Bases: google.cloud.client.JSONClient

    Client to bundle configuration needed for API requests.

    @@ -113,7 +271,7 @@

  • project (string) – the project which the client acts on behalf of. Will be passed when creating a zone. If not passed, falls back to the default inferred from the environment.
  • -
  • credentials (oauth2client.client.OAuth2Credentials or +
  • credentials (oauth2client.client.OAuth2Credentials or NoneType) – The OAuth2 Credentials to use for the connection owned by this client. If not passed (and if no http object is passed), falls back to the default inferred @@ -127,8 +285,8 @@

  • -
    -list_zones(max_results=None, page_token=None)[source]#
    +
    +list_zones(max_results=None, page_token=None)[source]#

    List zones for the project associated with this client.

    See: https://cloud.google.com/dns/api/v1/managedZones/list

    @@ -148,7 +306,7 @@

    Return type:

    tuple, (list, str)

    Returns:

    list of gcloud.dns.zone.ManagedZone, plus a +

    Returns:

    list of google.cloud.dns.zone.ManagedZone, plus a “next page token” string: if the token is not None, indicates that more zones can be retrieved with another call (pass that value as page_token).

    @@ -159,9 +317,9 @@

    -
    -quotas()[source]#
    -

    Return DNS quots for the project associated with this client.

    +
    +quotas()[source]#
    +

    Return DNS quotas for the project associated with this client.

    See: https://cloud.google.com/dns/api/v1/projects/get

    @@ -178,8 +336,8 @@

    -
    -zone(name, dns_name=None, description=None)[source]#
    +
    +zone(name, dns_name=None, description=None)[source]#

    Construct a zone bound to this client.

    @@ -194,10 +352,10 @@

    -

    - @@ -206,35 +364,35 @@

    -
    -

    Connection#

    -

    Create / interact with gcloud dns connections.

    +
    +

    Connection#

    +

    Create / interact with Google Cloud DNS connections.

    -
    -class gcloud.dns.connection.Connection(credentials=None, http=None)[source]#
    -

    Bases: gcloud.connection.JSONConnection

    +
    +class google.cloud.dns.connection.Connection(credentials=None, http=None)[source]#
    +

    Bases: google.cloud.connection.JSONConnection

    A connection to Google Cloud DNS via the JSON REST API.

    -
    -API_BASE_URL = 'https://www.googleapis.com'#
    +
    +API_BASE_URL = 'https://www.googleapis.com'#

    The base of the API call URL.

    -
    -API_URL_TEMPLATE = '{api_base_url}/dns/{api_version}{path}'#
    +
    +API_URL_TEMPLATE = '{api_base_url}/dns/{api_version}{path}'#

    A template for the URL of a particular API call.

    -
    -API_VERSION = 'v1'#
    +
    +API_VERSION = 'v1'#

    The version of the API, used in building the API call’s URL.

    -
    -SCOPE = ('https://www.googleapis.com/auth/ndev.clouddns.readwrite',)#
    +
    +SCOPE = ('https://www.googleapis.com/auth/ndev.clouddns.readwrite',)#

    The scopes required for authenticating as a Cloud DNS consumer.

    @@ -244,123 +402,71 @@

    - -
    + + - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/dns-resource-record-set.html b/latest/dns-resource-record-set.html index 42a3943b3531..a0123b322e8c 100644 --- a/latest/dns-resource-record-set.html +++ b/latest/dns-resource-record-set.html @@ -1,164 +1,90 @@ + + + + + + + + + + Resource Record Sets — google-cloud 92219b8 documentation + + + + + - - - - - Resource Record Sets — gcloud 47bfd0a documentation - - - - + + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -

    Return type:

    gcloud.dns.zone.ManagedZone

    +
    Return type:

    google.cloud.dns.zone.ManagedZone

    Returns:

    a new ManagedZone instance

    +
    Returns:

    a new ManagedZone instance.

    --- - - - -
    Parameters:
      -
    • name (string) – the name of the record set
    • -
    • record_type (string) – the RR type of the zone
    • -
    • ttl (integer) – TTL (in seconds) for caching the record sets
    • -
    • rrdatas (list of string) – one or more lines containing the resource data
    • -
    • zone (gcloud.dns.zone.ManagedZone) – A zone which holds one or more record sets.
    • -
    -
    -
    -
    -classmethod from_api_repr(resource, zone)[source]#
    -

    Factory: construct a record set given its API representation

    - --- - - - - - - - -
    Parameters:
      -
    • resource (dict) – record sets representation returned from the API
    • -
    • zone (gcloud.dns.zone.ManagedZone) – A zone which holds one or more record sets.
    • -
    -
    Return type:

    gcloud.dns.zone.ResourceRecordSet

    -
    Returns:

    RRS parsed from resource.

    -
    -
    + + google-cloud + -
    + + + + + + + + +
    +
    + + + +
    + + - - - + + + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Resource Record Sets#

    +

    Define API ResourceRecordSets.

    +
    +
    +class google.cloud.dns.resource_record_set.ResourceRecordSet(name, record_type, ttl, rrdatas, zone)[source]#
    +

    Bases: object

    +

    ResourceRecordSets are DNS resource records.

    +

    RRS are owned by a google.cloud.dns.zone.ManagedZone instance.

    +

    See: +https://cloud.google.com/dns/api/v1/resourceRecordSets

    + +++ + + + +
    Parameters:
      +
    • name (string) – the name of the record set.
    • +
    • record_type (string) – the RR type of the zone.
    • +
    • ttl (integer) – TTL (in seconds) for caching the record sets.
    • +
    • rrdatas (list of string) – one or more lines containing the resource data.
    • +
    • zone (google.cloud.dns.zone.ManagedZone) – A zone which holds one or more record sets.
    • +
    +
    +
    +
    +classmethod from_api_repr(resource, zone)[source]#
    +

    Factory: construct a record set given its API representation

    + +++ + + + + + + + +
    Parameters: +
    Return type:

    google.cloud.dns.zone.ResourceRecordSet

    +
    Returns:

    RRS parsed from resource.

    +
    +
    + +
    + +
    + - - - +
    +
    + + +
    +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/dns-usage.html b/latest/dns-usage.html index c765e5dfe47c..99bfad847fda 100644 --- a/latest/dns-usage.html +++ b/latest/dns-usage.html @@ -1,114 +1,280 @@ + + + + + + + + + + Using the API — google-cloud 92219b8 documentation + + + + + + + - - - - - Using the API — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + -
    +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    +

    Using the API#

    Client#

    -

    Client objects provide a means to -configure your DNS applications. Eash instance holds both a project +

    Client objects provide a means to +configure your DNS applications. Each instance holds both a project and an authenticated connection to the DNS service.

    -

    For an overview of authentication in gcloud-python, see Authentication.

    +

    For an overview of authentication in google-cloud-python, see Authentication.

    Assuming your environment is set up as described in that document, -create an instance of Client.

    +create an instance of Client.

    -
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client()
     
    @@ -125,7 +291,7 @@

    Projectsproject to the constructor, or to either of the alternative classmethod factories:

    -
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     
    @@ -135,7 +301,7 @@

    Projects#

    Query the quotas for a given project:

    -
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     >>> quotas = client.quotas()  # API request
     >>> for key, value in sorted(quotas.items()):
    @@ -161,7 +327,7 @@ 

    Managed Zones
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     >>> zone = client.zone('acme-co', 'example.com',
     ...                    description='Acme Company zone')
    @@ -176,7 +342,7 @@ 

    Managed Zones
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     >>> zones = client.list_zones()  # API request
     >>> [zone.name for zone in zones]
    @@ -189,7 +355,7 @@ 

    Managed Zones#

    Each managed zone exposes a read-only set of resource records:

    -
    >>> from gcloud import dns
    +
    >>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     >>> zone = client.zone('acme-co', 'example.com')
     >>> records, page_token = zone.list_resource_record_sets()  # API request
    @@ -221,7 +387,7 @@ 

    Change requests
    >>> import time
    ->>> from gcloud import dns
    +>>> from google.cloud import dns
     >>> client = dns.Client(project='PROJECT_ID')
     >>> zone = client.zone('acme-co', 'example.com')
     >>> TWO_HOURS = 2 * 60 * 60  # seconds
    @@ -239,7 +405,7 @@ 

    Change requests

    +
    + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/dns-zone.html b/latest/dns-zone.html index 1100f949a89e..585ee82add8e 100644 --- a/latest/dns-zone.html +++ b/latest/dns-zone.html @@ -1,108 +1,263 @@ + + + + + + + + + + Managed Zones — google-cloud 92219b8 documentation + + + + + + + - - - - - Managed Zones — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    -
    + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Managed Zones#

    Define API ManagedZones.

    -
    -class gcloud.dns.zone.ManagedZone(name, dns_name=None, client=None, description=None)[source]#
    +
    +class google.cloud.dns.zone.ManagedZone(name, dns_name=None, client=None, description=None)[source]#

    Bases: object

    ManagedZones are containers for DNS resource records.

    See: @@ -114,8 +269,8 @@

    Parameters:
    • name (string) – the name of the zone
    • dns_name (string or NoneType) – the DNS name of the zone. If not passed, then calls -to create() will fail.
    • -
    • client (gcloud.dns.client.Client) – A client which holds credentials and project configuration +to create() will fail.
    • +
    • client (google.cloud.dns.client.Client) – A client which holds credentials and project configuration for the zone (which requires a project).
    • description (string or NoneType) – the description for the zone. If not passed, defaults to the value of ‘dns_name’.
    • @@ -125,14 +280,14 @@

    -
    -changes()[source]#
    +
    +changes()[source]#

    Construct a change set bound to this zone.

    - + @@ -141,8 +296,8 @@

    -
    -create(client=None)[source]#
    +
    +create(client=None)[source]#

    API call: create the zone via a PUT request

    See: https://cloud.google.com/dns/api/v1/managedZones/create

    @@ -150,7 +305,7 @@

    - @@ -158,8 +313,8 @@

    -
    -created#
    +
    +created#

    Datetime at which the zone was created.

    Return type:gcloud.dns.changes.Changes
    Return type:google.cloud.dns.changes.Changes
    Returns:a new Changes instance
    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    @@ -174,8 +329,8 @@

    -
    -delete(client=None)[source]#
    +
    +delete(client=None)[source]#

    API call: delete the zone via a DELETE request

    See: https://cloud.google.com/dns/api/v1/managedZones/delete

    @@ -183,7 +338,7 @@

    - @@ -191,8 +346,8 @@

    -
    -description#
    +
    +description#

    Description of the zone.

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    @@ -207,8 +362,8 @@

    -
    -exists(client=None)[source]#
    +
    +exists(client=None)[source]#

    API call: test for the existence of the zone via a GET request

    See https://cloud.google.com/dns/api/v1/managedZones/get

    @@ -216,7 +371,7 @@

    - @@ -228,8 +383,8 @@

    -
    -classmethod from_api_repr(resource, client)[source]#
    +
    +classmethod from_api_repr(resource, client)[source]#

    Factory: construct a zone given its API representation

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    Return type:bool
    @@ -237,12 +392,12 @@

    - @@ -277,7 +432,7 @@

    @@ -312,7 +467,7 @@

    Parameters:
    Return type:

    gcloud.dns.zone.ManagedZone

    +
    Return type:

    google.cloud.dns.zone.ManagedZone

    Returns:

    Zone parsed from resource.

    @@ -253,8 +408,8 @@

    -
    -list_changes(max_results=None, page_token=None, client=None)[source]#
    +
    +list_changes(max_results=None, page_token=None, client=None)[source]#

    List change sets for this zone.

    See: https://cloud.google.com/dns/api/v1/resourceRecordSets/list

    @@ -268,7 +423,7 @@

  • page_token (string) – opaque marker for the next “page” of zones. If not passed, the API will return the first page of zones.
  • -
  • client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
  • client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
  • Returns:

    list of -gcloud.dns.resource_record_set.ResourceRecordSet, +google.cloud.dns.resource_record_set.ResourceRecordSet, plus a “next page token” string: if the token is not None, indicates that more zones can be retrieved with another call (pass that value as page_token).

    @@ -288,8 +443,8 @@

    -
    -list_resource_record_sets(max_results=None, page_token=None, client=None)[source]#
    +
    +list_resource_record_sets(max_results=None, page_token=None, client=None)[source]#

    List resource record sets for this zone.

    See: https://cloud.google.com/dns/api/v1/resourceRecordSets/list

    @@ -303,7 +458,7 @@

  • page_token (string) – opaque marker for the next “page” of zones. If not passed, the API will return the first page of zones.
  • -
  • client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
  • client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
  • Returns:

    list of -gcloud.dns.resource_record_set.ResourceRecordSet, +google.cloud.dns.resource_record_set.ResourceRecordSet, plus a “next page token” string: if the token is not None, indicates that more zones can be retrieved with another call (pass that value as page_token).

    @@ -323,8 +478,8 @@

    -
    -name_server_set#
    +
    +name_server_set#

    Named set of DNS name servers that all host the same ManagedZones.

    Most users will leave this blank.

    See: @@ -342,8 +497,8 @@

    -
    -name_servers#
    +
    +name_servers#

    Datetime at which the zone was created.

    @@ -358,8 +513,8 @@

    -
    -path#
    +
    +path#

    URL path for the zone’s APIs.

    @@ -374,8 +529,8 @@

    -
    -project#
    +
    +project#

    Project bound to the zone.

    @@ -390,8 +545,8 @@

    -
    -reload(client=None)[source]#
    +
    +reload(client=None)[source]#

    API call: refresh zone properties via a GET request

    See https://cloud.google.com/dns/api/v1/managedZones/get

    @@ -399,7 +554,7 @@

    - @@ -407,8 +562,8 @@

    -
    -resource_record_set(name, record_type, ttl, rrdatas)[source]#
    +
    +resource_record_set(name, record_type, ttl, rrdatas)[source]#

    Construct a resource record set bound to this zone.

    Parameters:client (gcloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the +
    Parameters:client (google.cloud.dns.client.Client or NoneType) – the client to use. If not passed, falls back to the client stored on the current zone.
    @@ -422,7 +577,7 @@

    -

    Return type:

    gcloud.dns.resource_record_set.ResourceRecordSet

    +
    Return type:

    google.cloud.dns.resource_record_set.ResourceRecordSet

    Returns:

    a new ResourceRecordSet instance

    @@ -433,8 +588,8 @@

    -
    -zone_id#
    +
    +zone_id#

    ID for the zone resource.

    @@ -453,123 +608,71 @@

    - - - + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/error-reporting-client.html b/latest/error-reporting-client.html new file mode 100644 index 000000000000..d739560127ac --- /dev/null +++ b/latest/error-reporting-client.html @@ -0,0 +1,493 @@ + + + + + + + + + + + Error Reporting Client — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Error Reporting Client#

    +

    Client for interacting with the Stackdriver Logging API

    +
    +
    +class google.cloud.error_reporting.client.Client(project=None, credentials=None, http=None, service=None, version=None)[source]#
    +

    Bases: object

    +

    Error Reporting client. Currently Error Reporting is done by creating +a Logging client.

    +

    +++ + + + + + +
    Parameters:
      +
    • project (string) – the project which the client acts on behalf of. If not +passed falls back to the default inferred from the +environment.
    • +
    • credentials (oauth2client.client.OAuth2Credentials or +NoneType) – The OAuth2 Credentials to use for the connection +owned by this client. If not passed (and if no http +object is passed), falls back to the default inferred +from the environment.
    • +
    • http (httplib2.Http or class that defines request().) – An optional HTTP object to make requests. If not passed, an +http object is created that is bound to the +credentials for the current object.
    • +
    • service (str) – An identifier of the service, such as the name of the +executable, job, or Google App Engine service name. This +field is expected to have a low number of values that are +relatively stable over time, as opposed to version, +which can be changed whenever new code is deployed.
    • +
    • version (str) – Represents the source code version that the developer +provided, which could represent a version label or a Git +SHA-1 hash, for example. If the developer did not provide +a version, the value is set to default.
    • +
    +
    Raises:

    ValueError if the project is neither passed in nor +set in the environment.

    +
    +
    +
    +report(message, http_context=None, user=None)[source]#
    +

    Reports a message to Stackdriver Error Reporting +https://cloud.google.com/error-reporting/docs/formatting-error-messages

    +
    +
    +
    +++ + + + + + +
    type message:str
    param message:A user-supplied message to report
    +
    + +++ + + + + + + + + + + + +
    type http_context:
     

    :class`google.cloud.error_reporting.HTTPContext`

    +
    param http_context:
     

    The HTTP request which was processed when the +error was triggered.

    +
    type user:

    string

    +
    param user:
    +
    The user who caused or was affected by the crash. This
    +

    can be a user ID, an email address, or an arbitrary +token that uniquely identifies the user. When sending +an error report, leave this field empty if the user +was not logged in. In this case the Error Reporting +system will use other data, such as remote IP address, +to distinguish affected users.

    +
    +
    Example::
    +
    >>>  client.report("Something went wrong!")
    +
    +
    +
    +
    +
    +
    +
    + +
    +
    +report_exception(http_context=None, user=None)[source]#
    +
    +
    Reports the details of the latest exceptions to Stackdriver Error
    +
    Reporting.
    +
    + +++ + + + +
    Parameters:
      +
    • http_context (:class`google.cloud.error_reporting.HTTPContext`) – The HTTP request which was processed when the +error was triggered.
    • +
    • user (string) –
      +
      The user who caused or was affected by the crash. This
      +
      can be a user ID, an email address, or an arbitrary +token that uniquely identifies the user. When sending an +error report, leave this field empty if the user was +not logged in. In this case the Error Reporting system +will use other data, such as remote IP address, +to distinguish affected users.
      +
      +

      Example:

      +
      >>>     try:
      +>>>         raise NameError
      +>>>     except Exception:
      +>>>         client.report_exception()
      +
      +
      +
    • +
    +
    +
    + +
    + +
    +
    +class google.cloud.error_reporting.client.HTTPContext(method=None, url=None, user_agent=None, referrer=None, response_status_code=None, remote_ip=None)[source]#
    +

    Bases: object

    +

    HTTPContext defines an object that captures the parameter for the +httpRequest part of Error Reporting API

    + +++ + + + +
    Parameters:
      +
    • method (string) – The type of HTTP request, such as GET, POST, etc.
    • +
    • url (string) – The URL of the request
    • +
    • user_agent (string) – The user agent information that is provided with the +request.
    • +
    • referrer (string) – The referrer information that is provided with the +request.
    • +
    • response_status_code (int) – The HTTP response status code for the request.
    • +
    • remote_ip (string) – The IP address from which the request originated. This +can be IPv4, IPv6, or a token which is derived from +the IP address, depending on the data that has been +provided in the error report.
    • +
    +
    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/error-reporting-usage.html b/latest/error-reporting-usage.html new file mode 100644 index 000000000000..ce8abbdfa14a --- /dev/null +++ b/latest/error-reporting-usage.html @@ -0,0 +1,419 @@ + + + + + + + + + + + Using the API — google-cloud 92219b8 documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + + + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    + +
    +

    Using the API#

    +
    +

    Authentication and Configuration#

    +
      +
    • For an overview of authentication in google-cloud-python, +see Authentication.

      +
    • +
    • In addition to any authentication configuration, you should also set the +GOOGLE_CLOUD_PROJECT environment variable for the project you’d like +to interact with. If you are Google App Engine or Google Compute Engine +this will be detected automatically.

      +
    • +
    • After configuring your environment, create a +Client

      +
      >>> from google.cloud import error_reporting
      +>>> client = error_reporting.Client()
      +
      +
      +

      or pass in credentials and project explicitly

      +
      >>> from google.cloud import error_reporting
      +>>> client = error_reporting.Client(project='my-project', credentials=creds)
      +
      +
      +

      Error Reporting associates errors with a service, which is an identifier for an executable, +App Engine service, or job. The default service is “python”, but a default can be specified +for the client on construction time. You can also optionally specify a version for that service, +which defaults to “default.”

      +
      +
      >>> from google.cloud import error_reporting
      +>>> client = error_reporting.Client(project='my-project',
      +...                                 service="login_service",
      +...                                 version="0.1.0")
      +
      +
      +
      +
    • +
    +
    +
    +

    Reporting an exception#

    +

    Report a stacktrace to Stackdriver Error Reporting after an exception

    +
    >>> from google.cloud import error_reporting
    +>>> client = error_reporting.Client()
    +>>> try:
    +>>>     raise NameError
    +>>> except Exception:
    +>>>     client.report_exception()
    +
    +
    +

    By default, the client will report the error using the service specified in the client’s +constructor, or the default service of “python”.

    +

    The user and HTTP context can also be included in the exception. The HTTP context +can be constructed using google.cloud.error_reporting.HTTPContext. This will +be used by Stackdriver Error Reporting to help group exceptions.

    +
    >>> from google.cloud import error_reporting
    +>>> client = error_reporting.Client()
    +>>> user = 'example@gmail.com'
    +>>> http_context = HTTPContext(method='GET', url='/', userAgent='test agent',
    +...                            referrer='example.com', responseStatusCode=500,
    +...                            remote_ip='1.2.3.4')
    +>>> try:
    +>>>     raise NameError
    +>>> except Exception:
    +>>>     client.report_exception(http_context=http_context, user=user))
    +
    +
    +
    +
    +

    Reporting an error without an exception#

    +

    Errors can also be reported to Stackdriver Error Reporting outside the context of an exception. +The library will include the file path, function name, and line number of the location where the +error was reported.

    +
    >>> from google.cloud import error_reporting
    +>>> client = error_reporting.Client()
    +>>> error_reporting.report("Found an error!")
    +
    +
    +

    Similarly to reporting an exception, the user and HTTP context can be provided:

    +
    >>> from google.cloud import error_reporting
    +>>> client = error_reporting.Client()
    +>>> user = 'example@gmail.com'
    +>>> http_context = HTTPContext(method='GET', url='/', userAgent='test agent',
    +...                            referrer='example.com', responseStatusCode=500,
    +...                            remote_ip='1.2.3.4')
    +>>> error_reporting.report("Found an error!", http_context=http_context, user=user))
    +
    +
    +
    +
    + + +
    +
    + + +
    +
    + +
    + +
    + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/latest/gcloud-api.html b/latest/gcloud-api.html index 4fad1bdd6138..aa028742861c 100644 --- a/latest/gcloud-api.html +++ b/latest/gcloud-api.html @@ -1,111 +1,273 @@ + + + + + + + + + + Shared Core Modules — google-cloud 92219b8 documentation + + + + + + + - - - - - Shared Core Modules — gcloud 47bfd0a documentation - - - - + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + +
    + -
    - -
    - - -
    + + +
    + + + + + + +
    +
    + + + + + + +
    + +
    +
    +
    +
    +

    Shared Core Modules#

    -
    -

    Base Client#

    +
    +

    Base Client#

    Base classes for client used to interact with Google Cloud APIs.

    -
    -class gcloud.client.Client(credentials=None, http=None)[source]#
    -

    Bases: gcloud.client._ClientFactoryMixin

    +
    +class google.cloud.client.Client(credentials=None, http=None)[source]#
    +

    Bases: google.cloud.client._ClientFactoryMixin

    Client to bundle configuration needed for API requests.

    Assumes that the associated _connection_class only accepts http and credentials in its constructor.

    @@ -114,7 +276,7 @@

    Shared Core Modules

    Parameters: