diff --git a/saved_models/cocosoda/save_tokenizer.log b/saved_models/cocosoda/save_tokenizer.log
new file mode 100644
index 0000000000000000000000000000000000000000..2b2b75a3fa4cd767449caf07bb7fea6e0209db44
--- /dev/null
+++ b/saved_models/cocosoda/save_tokenizer.log
@@ -0,0 +1,347 @@
+02/17/2024 15:12:04 - INFO - __main__ - device: cuda, n_gpu: 2
+02/17/2024 15:12:08 - INFO - __main__ - new token {'additional_special_tokens': ['global_variable', 'heredoc_end', 'decimal_floating_point_literal', 'rune_literal', 'int_literal', 'ERROR', 'class', 'heredoc_content', 'field_identifier', 'name', 'string', 'hash_key_symbol', 'hex_integer_literal', 'statement_identifier', 'boolean', 'separators', 'escape_sequence', 'boolean_type', 'regex_flags', 'string_fragment', 'identifier', 'instance_variable', 'regex_pattern', 'decimal_integer_literal', 'raw_string_literal', 'property_identifier', 'operator', 'label_name', 'namespace', 'string_literal', 'package_identifier', 'float_literal', 'integer', 'php_tag', 'shorthand_property_identifier', 'shorthand_property_identifier_pattern', 'extends', 'none', 'text', 'void_type', 'null_literal', 'heredoc_beginning', 'keyword', 'simple_symbol', 'type_identifier', 'character_literal', 'string_content', 'comment', 'number', '"', 'constant', 'class_variable']}
+02/17/2024 15:12:09 - INFO - __main__ - +-------------------------------------------------------------------+--------------+----------+
+| Layer Name | Output Shape | Param # |
++-------------------------------------------------------------------+--------------+----------+
+| code_encoder_q.embeddings.word_embeddings.weight | [51451, 768] | 39514368 |
+| code_encoder_q.embeddings.position_embeddings.weight | [1026, 768] | 787968 |
+| code_encoder_q.embeddings.token_type_embeddings.weight | [10, 768] | 7680 |
+| code_encoder_q.embeddings.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.embeddings.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.0.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.0.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.0.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.0.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.0.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.0.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.0.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.0.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.0.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.0.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.1.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.1.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.1.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.1.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.1.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.1.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.1.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.1.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.1.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.1.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.2.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.2.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.2.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.2.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.2.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.2.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.2.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.2.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.2.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.2.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.3.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.3.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.3.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.3.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.3.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.3.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.3.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.3.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.3.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.3.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.4.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.4.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.4.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.4.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.4.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.4.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.4.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.4.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.4.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.4.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.5.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.5.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.5.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.5.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.5.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.5.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.5.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.5.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.5.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.5.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.6.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.6.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.6.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.6.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.6.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.6.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.6.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.6.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.6.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.6.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.7.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.7.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.7.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.7.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.7.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.7.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.7.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.7.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.7.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.7.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.8.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.8.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.8.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.8.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.8.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.8.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.8.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.8.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.8.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.8.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.9.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.9.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.9.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.9.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.9.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.9.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.9.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.9.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.9.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.9.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.10.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.10.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.10.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.10.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.10.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.10.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.10.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.10.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.10.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.10.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.self.query.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.11.attention.self.query.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.self.key.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.11.attention.self.key.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.self.value.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.11.attention.self.value.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.output.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.encoder.layer.11.attention.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.11.attention.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.intermediate.dense.weight | [3072, 768] | 2359296 |
+| code_encoder_q.encoder.layer.11.intermediate.dense.bias | [3072] | 3072 |
+| code_encoder_q.encoder.layer.11.output.dense.weight | [768, 3072] | 2359296 |
+| code_encoder_q.encoder.layer.11.output.dense.bias | [768] | 768 |
+| code_encoder_q.encoder.layer.11.output.LayerNorm.weight | [768] | 768 |
+| code_encoder_q.encoder.layer.11.output.LayerNorm.bias | [768] | 768 |
+| code_encoder_q.pooler.dense.weight | [768, 768] | 589824 |
+| code_encoder_q.pooler.dense.bias | [768] | 768 |
++-------------------------------------------------------------------+--------------+----------+
+02/17/2024 15:12:09 - INFO - __main__ - Training/evaluation parameters Namespace(agg_way='cls_pooler', aug_type_way='random_replace_type', code_length=64, codebase_file='dataset/ruby/codebase.jsonl', config_name='microsoft/unixcoder-base', couninue_pre_train_data_files=['dataset/java/train.jsonl', 'dataset/javascript/train.jsonl', 'dataset/python/train.jsonl', 'dataset/php/train.jsonl', 'dataset/go/train.jsonl', 'dataset/ruby/train.jsonl'], data_aug_type='other', data_flow_length=0, debug=False, device=device(type='cuda'), do_avg=False, do_continue_pre_trained=False, do_eval=False, do_fine_tune=False, do_ineer_loss=False, do_multi_lang_continue_pre_train=True, do_single_lang_continue_pre_train=False, do_test=True, do_train=False, do_whitening=False, do_zero_short=False, epoch=50, eval_batch_size=64, eval_data_file='dataset/ruby/valid.jsonl', eval_frequency=100, fp16=False, gradient_accumulation_steps=1, hidden_size=768, lang='ruby', learning_rate=2e-05, loaded_codebert_model_filename=None, loaded_model_filename=None, local_rank=-1, logging_steps=50, max_codeblock_num=10, max_grad_norm=1.0, max_steps=100000, mlm_probability=0.1, mlp=False, moco_dim=768, moco_k=1024, moco_m=0.999, moco_t=0.07, moco_type='encoder_queue', model_name_or_path='microsoft/unixcoder-base', model_type='multi-loss-cocosoda', n_debug_samples=100, n_gpu=2, nl_length=64, num_train_epochs=10, num_warmup_steps=0, only_save_the_nl_code_vec=False, output_dir='./saved_models/cocosoda/', print_align_unif_loss=False, save_evaluation_reuslt=False, save_evaluation_reuslt_dir=None, save_steps=1000, seed=123456, test_data_file='dataset/ruby/test.jsonl', time_score=1, tokenizer_name='microsoft/unixcoder-base', train_batch_size=128, train_data_file='dataset/ruby/train.jsonl', use_best_mrr_model=False, weight_decay=0.01)
+02/17/2024 15:15:03 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:03 - INFO - __main__ - idx: 0
+02/17/2024 15:15:03 - INFO - __main__ - code_tokens: ['', '', ' ', '@', '_Override', '_public', '_Image', 'Source', '_apply', '_(', '_Image', 'Source', '_input', '_)', '_{', '_final', '_int', '_[', '_]', '_[', '_]', '_pixel', 'Matrix', '_=', '_new', '_int', '_[', '_3', '_]', '_[', '_3', '_]', '_;', '_int', '_w', '_=', '_input', '_.', '_getWidth', '_(', '_)', '_;', '_int', '_h', '_=', '_input', '_.', '_getHeight', '_(', '_)', '_;', '_int', '_[', '_]', '_[', '_]', '_output', '_=', '_new', '_int', '_[', '_h', '_]', '']
+02/17/2024 15:15:03 - INFO - __main__ - code_ids: 0 6 2 150 19505 1240 6085 1768 5230 400 6085 1768 1586 743 399 1920 554 626 2406 626 2406 5578 3679 385 579 554 626 995 2406 626 995 2406 2476 554 477 385 1586 746 32671 400 743 2476 554 566 385 1586 746 32720 400 743 2476 554 626 2406 626 2406 1721 385 579 554 626 566 2406 2
+02/17/2024 15:15:03 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Expect', 's', '_a', '_height', '_mat', '_as', '_input', '']
+02/17/2024 15:15:03 - INFO - __main__ - nl_ids: 0 6 2 7871 201 434 3082 5772 880 1586 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:03 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:03 - INFO - __main__ - idx: 1
+02/17/2024 15:15:03 - INFO - __main__ - code_tokens: ['', '', ' ', 'public', '_<', '_L', 'extends', 'Listener', '_>', '_void', '_pop', 'Event', '_(', '_Event', '_<', '_?', '_,', '_L', '_>', '_expected', '_)', '_{', '_synchronized', '_(', '_this', '_.', '_stack', '_)', '_{', '_final', '_Event', '_<', '_?', '_,', '_?', '_>', '_actual', '_=', '_this', '_.', '_stack', '_.', '_pop', '_(', '_)', '_;', '_if', '_(', '_actual', '_!=', '_expected', '_)', '_{', '_throw', '_new', '_IllegalStateException', '_(', '_String', '_.', '_format', '_(', '"', 'Un', '']
+02/17/2024 15:15:03 - INFO - __main__ - code_ids: 0 6 2 653 517 747 13125 2486 711 723 5012 1089 400 3916 517 999 2019 747 711 2048 743 399 9401 400 547 746 3325 743 399 1920 3916 517 999 2019 999 711 3780 385 547 746 3325 746 5012 400 743 2476 462 400 3780 620 2048 743 399 1185 579 16219 400 1167 746 2021 400 120 965 2
+02/17/2024 15:15:03 - INFO - __main__ - nl_tokens: ['', '', ' ', 'P', 'ops', '_the', '_top', '_event', '_off', '_the', '_current', '_event', '_stack', '_.', '_This', '_action', '_has', '_to', '_be', '_performed', '_immediately', '_after', '_the', '_event', '_has', '_been', '_dispatched', '_to', '_all', '_listeners', '_.', '']
+02/17/2024 15:15:03 - INFO - __main__ - nl_ids: 0 6 2 166 2489 448 3194 1488 3413 448 1434 1488 3325 746 1600 2657 1559 508 661 13181 10086 2493 448 1488 1559 3022 43340 508 1345 11839 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:03 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:03 - INFO - __main__ - idx: 2
+02/17/2024 15:15:03 - INFO - __main__ - code_tokens: ['', '', ' ', 'protected', '_void', '_modify', '_(', '_Transaction', '_t', '_)', '_{', '_try', '_{', '_this', '_.', '_lock', '_.', '_write', 'Lock', '_(', '_)', '_.', '_lock', '_(', '_)', '_;', '_t', '_.', '_perform', '_(', '_)', '_;', '_}', '_finally', '_{', '_this', '_.', '_lock', '_.', '_write', 'Lock', '_(', '_)', '_.', '_unlock', '_(', '_)', '_;', '_}', '_}', '']
+02/17/2024 15:15:03 - INFO - __main__ - code_ids: 0 6 2 1933 723 8660 400 13081 422 743 399 1568 399 547 746 3505 746 2250 2896 400 743 746 3505 400 743 2476 422 746 4729 400 743 2476 425 6110 399 547 746 3505 746 2250 2896 400 743 746 14552 400 743 2476 425 425 2 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:03 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Executes', '_the', '_given', '_transaction', '_within', '_the', '_con', 'text', 'of', '_a', '_write', '_lock', '_.', '']
+02/17/2024 15:15:03 - INFO - __main__ - nl_ids: 0 6 2 40551 448 2076 4993 5289 448 549 625 757 434 2250 3505 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:59 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:59 - INFO - __main__ - idx: 0
+02/17/2024 15:15:59 - INFO - __main__ - code_tokens: ['', '', ' ', 'function', '_(', '_state', '_,', '_action', '_)', '_{', '_return', '__', '_.', '_defaults', '_(', '_{', '_isValid', 'ating', '_:', '_action', '_.', '_isValid', 'ating', '_,', '_last', 'Action', '_:', '_IS', '_', 'VALID', 'ATING', '_}', '_,', '_state', '_)', '_}', '']
+02/17/2024 15:15:59 - INFO - __main__ - code_ids: 0 6 2 618 400 1404 2019 2657 743 399 483 623 746 7470 400 399 17002 2335 545 2657 746 17002 2335 2019 2023 1888 545 1947 181 7477 40173 425 2019 1404 743 425 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:59 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Update', '_is', '_validating', '_result', '']
+02/17/2024 15:15:59 - INFO - __main__ - nl_ids: 0 6 2 2056 555 38924 1046 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:59 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:59 - INFO - __main__ - idx: 1
+02/17/2024 15:15:59 - INFO - __main__ - code_tokens: ['', '', ' ', 'function', '_add', 'Widget', 'For', 'Filter', '_(', '_view', '_,', '_filter', '_,', '_edit', 'Mode', 'Hint', '_)', '_{', '_var', '_grid', 'ster', '_=', '_view', '_.', '__', 'widgets', 'Grid', 'ster', '_;', '_var', '_row', '_=', '_filter', '_.', '_row', '_||', '_1', '_;', '_var', '_col', '_=', '_filter', '_.', '_col', '_||', '_1', '_;', '_var', '_size', 'X', '_=', '_filter', '_.', '_size', '_', 'x', '_||', '_3', '_;', '_var', '_size', 'Y', '_=', '']
+02/17/2024 15:15:59 - INFO - __main__ - code_ids: 0 6 2 618 1103 3104 1459 2274 400 2859 2019 2866 2019 7277 1649 7641 743 399 660 6335 7400 385 2859 746 623 14718 3981 7400 2476 660 2562 385 2866 746 2562 853 524 2476 660 1253 385 2866 746 1253 853 524 2476 660 1014 174 385 2866 746 1014 181 206 853 995 2476 660 1014 175 385 2
+02/17/2024 15:15:59 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Add', '_a', '_widget', '_to', '_the', '_analyze', '_page', '_for', '_the', '_given', '_filter', '']
+02/17/2024 15:15:59 - INFO - __main__ - nl_ids: 0 6 2 972 434 6949 508 448 25087 2303 563 448 2076 2866 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:15:59 - INFO - __main__ - *** Example ***
+02/17/2024 15:15:59 - INFO - __main__ - idx: 2
+02/17/2024 15:15:59 - INFO - __main__ - code_tokens: ['', '', ' ', 'function', '_in', 'Range', '_(', '_value', '_,', '_min', '_,', '_max', '_)', '_{', '_const', '_int', '_=', '_parseInt', '_(', '_value', '_,', '_10', '_)', '_return', '_(', '_`', '_${', '_int', '_}', '_`', '_===', '_`', '_${', '_value', '_.', '_replace', '_(', '_/', '_^', '0', '_/', '_,', "_''", '_)', '_}', '_`', '_&&', '_int', '_>=', '_min', '_&&', '_int', '_<=', '_max', '_)', '_}', '']
+02/17/2024 15:15:59 - INFO - __main__ - code_ids: 0 6 2 618 488 2228 400 767 2019 2069 2019 1621 743 399 925 554 385 9998 400 767 2019 1865 743 483 400 1222 5593 554 425 1222 1246 1222 5593 767 746 4126 400 1017 3855 134 1017 2019 3606 743 425 1222 698 554 1451 2069 698 554 1826 1621 743 425 2 1 1 1 1 1 1 1
+02/17/2024 15:15:59 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Determine', '_if', '_value', '_is', '_within', '_a', '_numeric', '_range', '']
+02/17/2024 15:15:59 - INFO - __main__ - nl_ids: 0 6 2 17591 462 767 555 5289 434 10397 1780 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:19:33 - INFO - __main__ - *** Example ***
+02/17/2024 15:19:33 - INFO - __main__ - idx: 0
+02/17/2024 15:19:33 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_split', '_', 'phy', 'log', 'en', 'y', '_(', '_p', '_,', '_level', '_=', '"', 's', '"', ')', '_:', '_level', '_=', '_level', '_+', '"', '__', '"', 'result', '_=', '_p', '_.', '_split', '_(', '_level', '_)', '_return', '_result', '_[', '_0', '_]', '_+', '_level', '_+', '_result', '_[', '_1', '_]', '_.', '_split', '_(', '"', ';', '"', ')', '_[', '_0', '_]', '']
+02/17/2024 15:19:33 - INFO - __main__ - code_ids: 0 6 2 729 5192 181 3258 896 386 207 400 428 2019 3144 385 120 201 120 127 545 3144 385 3144 513 120 876 120 1125 385 428 746 5192 400 3144 743 483 1046 626 461 2406 513 3144 513 1046 626 524 2406 746 5192 400 120 145 120 127 626 461 2406 2 1 1 1 1 1 1
+02/17/2024 15:19:33 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Return', '_either', '_the', '_full', '_or', '_truncated', '_version', '_of', '_a', '_Q', 'II', 'ME', '_-', '_formatted', '_taxonomy', 'string', '.', '']
+02/17/2024 15:19:33 - INFO - __main__ - nl_ids: 0 6 2 1675 4759 448 3662 872 19307 2229 595 434 1152 4300 1098 581 10440 29021 571 132 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:19:33 - INFO - __main__ - *** Example ***
+02/17/2024 15:19:33 - INFO - __main__ - idx: 1
+02/17/2024 15:19:33 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_ensure', '_', 'dir', '_(', '_d', '_)', '_:', '_if', '_not', '_os', '_.', '_path', '_.', '_exists', '_(', '_d', '_)', '_:', '_try', '_:', '_os', '_.', '_m', 'akedirs', '_(', '_d', '_)', '_except', '_OSError', '_as', '_oe', '_:', '_#', '_should', '_not', '_happen', '_with', '_os', '.', 'makedirs', '_#', '_ENOENT', ':', '_No', '_such', '_file', '_or', '_directory', '_if', '_os', '_.', '_errno', '_==', '_errno', '_.', '_ENOENT', '_:', '_msg', '_=', '']
+02/17/2024 15:19:33 - INFO - __main__ - code_ids: 0 6 2 729 6229 181 1282 400 480 743 545 462 800 2215 746 1391 746 4534 400 480 743 545 1568 545 2215 746 446 23328 400 480 743 3552 22934 880 44902 545 830 1570 800 7564 918 2215 132 24429 830 41059 144 4038 5632 1012 872 3456 462 2215 746 2341 550 2341 746 41059 545 2345 385 2
+02/17/2024 15:19:33 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Check', '_to', '_make', '_sure', '_the', '_supplied', '_directory', '_path', '_does', '_not', '_exist', '_if', '_so', '_create', '_it', '_.', '_The', '_method', '_catch', 'es', '_OSError', '_exceptions', '_and', '_returns', '_a', '_desc', 'riptive', '_message', '_instead', '_of', '_re', '_-', '_raising', '_the', '_error', '_.', '']
+02/17/2024 15:19:33 - INFO - __main__ - nl_ids: 0 6 2 1749 508 2002 3984 448 8813 3456 1391 2129 800 3040 462 1769 1738 835 746 1044 1454 2092 482 22934 12300 706 2060 434 2162 44105 1841 4488 595 479 581 47183 448 843 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:19:33 - INFO - __main__ - *** Example ***
+02/17/2024 15:19:33 - INFO - __main__ - idx: 2
+02/17/2024 15:19:33 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_file', '_', 'handle', '_(', '_fn', 'h', '_,', '_mode', '_=', '"', 'r', 'U', '"', ')', '_:', '_handle', '_=', '_None', '_if', '_isinstance', '_(', '_fn', 'h', '_,', '_file', '_)', '_:', '_if', '_fn', 'h', '_.', '_closed', '_:', '_raise', '_ValueError', '_(', '"', 'Input', '_file', '_is', '_closed', '.', '"', ')', '_handle', '_=', '_fn', 'h', '_elif', '_isinstance', '_(', '_fn', 'h', '_,', '_str', '_)', '_:', '_handle', '_=', '']
+02/17/2024 15:19:33 - INFO - __main__ - code_ids: 0 6 2 729 1012 181 2133 400 4065 190 2019 2119 385 120 200 171 120 127 545 2384 385 1938 462 5408 400 4065 190 2019 1012 743 545 462 4065 190 746 8264 545 3085 6052 400 120 1834 1012 555 8264 132 120 127 2384 385 4065 190 3625 5408 400 4065 190 2019 1113 743 545 2384 385 2
+02/17/2024 15:19:33 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Takes', '_either', '_a', '_file', '_path', '_or', '_an', '_open', '_file', '_handle', '_checks', '_validity', '_and', '_returns', '_an', '_open', '_file', '_handle', '_or', '_raises', '_an', '_appropriate', '_Exception', '_.', '']
+02/17/2024 15:19:33 - INFO - __main__ - nl_ids: 0 6 2 27408 4759 434 1012 1391 872 817 2717 1012 2384 7825 25911 706 2060 817 2717 1012 2384 872 23154 817 7900 2654 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:23:02 - INFO - __main__ - *** Example ***
+02/17/2024 15:23:02 - INFO - __main__ - idx: 0
+02/17/2024 15:23:02 - INFO - __main__ - code_tokens: ['', '', ' ', 'public', '_function', '_on', 'Channel', 'Pre', 'Delete', '_(', '_Resource', 'Controller', 'Event', '_$', '_event', '_)', '_:', '_void', '_{', '_$', '_channel', '_=', '_$', '_event', '_->', '_get', 'Subject', '_(', '_)', '_;', '_if', '_(', '_!', '_$', '_channel', '_instanceof', '_Channel', 'Interface', '_)', '_{', '_throw', '_new', '_Unexpected', 'TypeException', '_(', '_$', '_channel', '_,', '_Channel', 'Interface', '_::', 'class', ')', '_;', '_}', '_$', '_results', '_=', '_$', '_this', '_->', '_channel', 'Repository', '']
+02/17/2024 15:23:02 - INFO - __main__ - code_ids: 0 6 2 653 603 854 3267 1782 2843 400 7606 3357 1089 440 1488 743 545 723 399 440 3225 385 440 1488 1703 744 7562 400 743 2476 462 400 552 440 3225 3052 11322 2285 743 399 1185 579 23297 48098 400 440 3225 2019 11322 2285 5431 1149 127 2476 425 440 3286 385 440 547 1703 3225 5674 2
+02/17/2024 15:23:02 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Prevent', '_channel', '_deletion', '_if', '_no', '_more', '_channels', '_enabled', '_.', '']
+02/17/2024 15:23:02 - INFO - __main__ - nl_ids: 0 6 2 42669 3225 19744 462 1375 2726 8630 5334 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:23:02 - INFO - __main__ - *** Example ***
+02/17/2024 15:23:02 - INFO - __main__ - idx: 1
+02/17/2024 15:23:02 - INFO - __main__ - code_tokens: ['', '', ' ', 'public', '_function', '_get', 'Tax', 'Total', '_(', '_)', '_:', '_int', '_{', '_$', '_tax', 'Total', '_=', '_0', '_;', '_foreach', '_(', '_$', '_this', '_->', '_get', 'Adjustments', '_(', '_Adjust', 'ment', 'Interface', '_::', '_T', 'AX', '_', 'ADJUST', 'MENT', '_)', '_as', '_$', '_tax', 'Adjustment', '_)', '_{', '_$', '_tax', 'Total', '_+=', '_$', '_tax', 'Adjustment', '_->', '_get', 'Amount', '_(', '_)', '_;', '_}', '_foreach', '_(', '_$', '_this', '_->', '_units', '']
+02/17/2024 15:23:02 - INFO - __main__ - code_ids: 0 6 2 653 603 744 11266 4703 400 743 545 554 399 440 14990 4703 385 461 2476 2315 400 440 547 1703 744 39930 400 16203 564 2285 5431 515 3383 181 44094 4332 743 880 440 14990 21585 743 399 440 14990 4703 1054 440 14990 21585 1703 744 6933 400 743 2476 425 2315 400 440 547 1703 10931 2
+02/17/2024 15:23:02 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Returns', '_sum', '_of', '_ne', 'utral', '_and', '_non', '_ne', 'utral', '_tax', '_adjust', 'ments', '_on', '_order', '_item', '_and', '_total', '_tax', '_of', '_units', '_.', '']
+02/17/2024 15:23:02 - INFO - __main__ - nl_ids: 0 6 2 2853 3863 595 1472 22943 706 2514 1472 22943 14990 7780 2067 854 2991 1573 706 3704 14990 595 10931 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:23:02 - INFO - __main__ - *** Example ***
+02/17/2024 15:23:02 - INFO - __main__ - idx: 2
+02/17/2024 15:23:02 - INFO - __main__ - code_tokens: ['', '', ' ', 'private', '_function', '_is', 'Last', 'Enabled', 'Entity', '_(', '_$', '_result', '_,', '_$', '_entity', '_)', '_:', '_bool', '_{', '_return', '_!', '_$', '_result', '_||', '_0', '_===', '_count', '_(', '_$', '_result', '_)', '_||', '_(', '_1', '_===', '_count', '_(', '_$', '_result', '_)', '_&&', '_$', '_entity', '_===', '_(', '_$', '_result', '_instanceof', '_\\', '_Iterator', '_?', '_$', '_result', '_->', '_current', '_(', '_)', '_:', '_current', '_(', '_$', '_result', '_)', '']
+02/17/2024 15:23:02 - INFO - __main__ - code_ids: 0 6 2 1335 603 555 2954 3060 2268 400 440 1046 2019 440 4498 743 545 1223 399 483 552 440 1046 853 461 1246 1752 400 440 1046 743 853 400 524 1246 1752 400 440 1046 743 698 440 4498 1246 400 440 1046 3052 1216 13119 999 440 1046 1703 1434 400 743 545 1434 400 440 1046 743 2
+02/17/2024 15:23:02 - INFO - __main__ - nl_tokens: ['', '', ' ', 'If', '_no', '_entity', '_matched', '_the', '_query', '_criteria', '_or', '_a', '_single', '_entity', '_matched', '_which', '_is', '_the', '_same', '_as', '_the', '_entity', '_being', '_validated', '_the', '_entity', '_is', '_the', '_last', '_enabled', '_entity', '_available', '_.', '']
+02/17/2024 15:23:02 - INFO - __main__ - nl_ids: 0 6 2 2815 1375 4498 5865 448 2616 14677 872 434 3501 4498 5865 1839 555 448 2641 880 448 4498 4251 20709 448 4498 555 448 2023 5334 4498 3777 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:32 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:32 - INFO - __main__ - idx: 0
+02/17/2024 15:25:32 - INFO - __main__ - code_tokens: ['', '', ' ', 'func', '_getAll', 'Dep', 'Types', '_(', '_)', '_[', '_]', 'string', '{', '_dep', 'Types', '_:=', '_make', '_(', '_[', '_]', 'string', ',', '_0', '_,', '_len', '_(', '_cmds', '_)', '_)', '_Ċ', '_for', '_dep', 'Type', '_:=', '_range', '_cmds', '_{', '_dep', 'Types', '_=', '_append', '_(', '_dep', 'Types', '_,', '_dep', 'Type', '_)', '_Ċ', '_}', '_Ċ', '_sort', '_.', '_Strings', '_(', '_dep', 'Types', '_)', '_Ċ', '_return', '_dep', 'Types', '_Ċ', '']
+02/17/2024 15:25:32 - INFO - __main__ - code_ids: 0 6 2 763 21556 15010 2531 400 743 626 2406 571 209 13994 2531 716 2002 400 626 2406 571 130 461 2019 1015 400 22803 743 743 1022 563 13994 641 716 1780 22803 399 13994 2531 385 2746 400 13994 2531 2019 13994 641 743 1022 425 1022 4821 746 23012 400 13994 2531 743 1022 483 13994 2531 1022 2
+02/17/2024 15:25:32 - INFO - __main__ - nl_tokens: ['', '', ' ', 'getAll', 'Dep', 'Types', '_returns', '_a', '_sorted', '_list', '_of', 'name', 's', '_of', '_all', '_dep', '_type', '_commands', '_.', '']
+02/17/2024 15:25:32 - INFO - __main__ - nl_ids: 0 6 2 12199 15010 2531 2060 434 6977 1182 595 616 201 595 1345 13994 889 7997 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:32 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:32 - INFO - __main__ - idx: 1
+02/17/2024 15:25:32 - INFO - __main__ - code_tokens: ['', '', ' ', 'func', '_get', 'Io', 'Progress', 'Reader', '_(', '_label', 'string', ',', '_res', '_*', '_http', '_.', '_Response', '_)', '_io', '_.', '_Reader', '_{', '_prefix', '_:=', '"', '"', '+', '_label', '_Ċ', '_fmt', 'Bytes', 'Size', '_:=', '_18', '_Ċ', '_bar', 'Size', '_:=', '_int', '64', '_(', '_80', '_-', '_len', '_(', '_prefix', '_)', '_-', '_fmt', 'Bytes', 'Size', '_)', '_Ċ', '_bar', '_:=', '_i', 'opro', 'gress', '_.', '_Draw', 'Text', 'Format', 'Bar', '']
+02/17/2024 15:25:32 - INFO - __main__ - code_ids: 0 6 2 763 744 8499 4909 2692 400 2649 571 130 705 426 2014 746 6397 743 3095 746 15471 399 3603 716 120 120 129 2649 1022 2771 2240 939 716 7837 1022 5252 939 716 554 848 400 8967 581 1015 400 3603 743 581 2771 2240 939 743 1022 5252 716 548 31375 2639 746 8548 1072 1660 3238 2
+02/17/2024 15:25:32 - INFO - __main__ - nl_tokens: ['', '', ' ', 'get', 'Io', 'Progress', 'Reader', '_returns', '_a', '_reader', '_that', '_wraps', '_the', '_HTTP', '_response', '_body', '_so', '_it', '_prints', '_a', '_pretty', '_progress', '_bar', '_when', '_reading', '_data', '_from', '_it', '_.', '']
+02/17/2024 15:25:32 - INFO - __main__ - nl_ids: 0 6 2 459 8499 4909 2692 2060 434 4636 922 28232 448 4383 1925 3444 1769 835 22199 434 15344 6687 5252 1672 8267 869 1029 835 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:32 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:32 - INFO - __main__ - idx: 2
+02/17/2024 15:25:32 - INFO - __main__ - code_tokens: ['', '', ' ', 'func', '_(', '_f', '_*', '_remove', 'OnClose', '_)', '_Close', '_(', '_)', '_error', '_{', '_if', '_f', '_==', '_nil', '_||', '_f', '_.', '_File', '_==', '_nil', '_{', '_return', '_nil', '_Ċ', '_}', 'name', ':', '=', '_f', '_.', '_File', '_.', '_Name', '_(', '_)', '_Ċ', '_if', '_err', '_:=', '_f', '_.', '_File', '_.', '_Close', '_(', '_)', '_;', '_err', '_!=', '_nil', '_{', '_return', '_err', '_Ċ', '_}', '_Ċ', '_if', '_err', '']
+02/17/2024 15:25:32 - INFO - __main__ - code_ids: 0 6 2 763 400 412 426 3033 45359 743 5832 400 743 843 399 462 412 550 845 853 412 746 2536 550 845 399 483 845 1022 425 616 144 147 412 746 2536 746 3725 400 743 1022 462 573 716 412 746 2536 746 5832 400 743 2476 573 620 845 399 483 573 1022 425 1022 462 573 2
+02/17/2024 15:25:32 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Close', '_closes', '_the', '_file', '_and', '_then', '_removes', '_it', '_from', '_disk', '_.', '_No', '_error', '_is', '_returned', '_if', '_the', '_file', '_did', '_not', '_exist', '_at', '_the', '_point', '_of', '_removal', '_.', '']
+02/17/2024 15:25:32 - INFO - __main__ - nl_ids: 0 6 2 3108 19735 448 1012 706 2270 15719 835 1029 8236 746 4038 843 555 2862 462 448 1012 6088 800 3040 1035 448 1704 595 23066 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:48 - INFO - __main__ - idx: 0
+02/17/2024 15:25:48 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_render', '_', 'body', '_(', '_con', 'text', ',', '_options', '_)', '_if', '_options', '_.', '_key', '?', '_(', '_:', 'partial', '_)', '_[', '_render', '_', 'partial', '_(', '_con', 'text', ',', '_options', '_)', '_]', '_else', '_Streaming', 'Template', 'Renderer', '_.', '_new', '_(', '_@', 'lookup', '_', 'con', 'text', ')', '_.', '_render', '_(', '_con', 'text', ',', '_options', '_)', '_end', '_end', '']
+02/17/2024 15:25:48 - INFO - __main__ - code_ids: 0 6 2 729 4342 181 1995 400 549 625 130 1466 743 462 1466 746 1129 149 400 545 7609 743 626 4342 181 7609 400 549 625 130 1466 743 2406 669 47128 3057 6412 746 579 400 890 4961 181 525 625 127 746 4342 400 549 625 130 1466 743 1013 1013 2 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Render', '_but', '_returns', '_a', '_valid', '_R', 'ack', '_body', '_.', '_If', '_fib', 'ers', '_are', '_defined', '_we', '_return', '_a', '_streaming', '_body', '_that', '_renders', '_the', '_template', '_piece', '_by', '_piece', '_.', '']
+02/17/2024 15:25:48 - INFO - __main__ - nl_ids: 0 6 2 3726 2107 2060 434 1976 821 598 3444 746 1359 24766 560 1147 3474 937 483 434 22676 3444 922 40840 448 3636 18781 1243 18781 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:48 - INFO - __main__ - idx: 1
+02/17/2024 15:25:48 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_attribute', '_', 'missing', '_(', '_match', '_,', '_*', '_args', '_,', '_&', '_block', '_)', '___', 'send', '__', '_(', '_match', '_.', '_target', '_,', '_match', '_.', '_attr', '_', 'name', ',', '_args', '_,', '_block', '_)', '_end', '']
+02/17/2024 15:25:48 - INFO - __main__ - code_ids: 0 6 2 729 2416 181 8487 400 1655 2019 426 1822 2019 519 1818 743 1267 2414 876 400 1655 746 1744 2019 1655 746 3526 181 616 130 1822 2019 1818 743 1013 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - nl_tokens: ['', '', ' ', '+', '_attribute', '_', 'missing', '_+', '_is', '_like', '_+', '_method', '_', 'missing', '_+', '_but', '_for', '_attributes', '_.', '_When', '_+', '_method', '_', 'missing', '_+', '_is', '_called', '_we', '_check', '_to', '_see', '_if', '_there', '_is', '_a', '_matching', '_attribute', '_method', '_.', '_If', '_so', '_we', '_tell', '_+', '_attribute', '_', 'missing', '_+', '_to', '_dispatch', '_the', '_attribute', '_.', '_This', '_method', '_can', '_be', '_overloaded', '_to', '_customize', '_the', '_behavior', '_.', '']
+02/17/2024 15:25:48 - INFO - __main__ - nl_ids: 0 6 2 129 2416 181 8487 513 555 4401 513 1454 181 8487 513 2107 563 4402 746 5919 513 1454 181 8487 513 555 2953 937 1382 508 3986 462 2550 555 434 6506 2416 1454 746 1359 1769 937 11931 513 2416 181 8487 513 508 9363 448 2416 746 1600 1454 1347 661 45869 508 36145 448 9050 746 2
+02/17/2024 15:25:48 - INFO - __main__ - *** Example ***
+02/17/2024 15:25:48 - INFO - __main__ - idx: 2
+02/17/2024 15:25:48 - INFO - __main__ - code_tokens: ['', '', ' ', 'def', '_matched', '_', 'attribute', '_', 'method', '_(', '_method', '_', 'name', ')', '_matches', '_=', '_self', '_.', 'class', '.', '_send', '_(', '_:', 'attribute', '_', 'method', '_', 'matchers', '_', 'matching', '_,', '_method', '_', 'name', ')', '_matches', '_.', '_detect', '_{', '_|', '_match', '_|', '_attribute', '_', 'method', '?', '_(', '_match', '_.', '_attr', '_', 'name', ')', '_}', '_end', '']
+02/17/2024 15:25:48 - INFO - __main__ - code_ids: 0 6 2 729 5865 181 2163 181 1521 400 1454 181 616 127 5288 385 1358 746 1149 132 2904 400 545 2163 181 1521 181 38734 181 13575 2019 1454 181 616 127 5288 746 10241 399 649 1655 649 2416 181 1521 149 400 1655 746 3526 181 616 127 425 1013 2 1 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Returns', '_a', '_struct', '_representing', '_the', '_matching', '_attribute', '_method', '_.', '_The', '_struct', '_s', '_attributes', '_are', '_prefix', '_base', '_and', '_suffix', '_.', '']
+02/17/2024 15:25:48 - INFO - __main__ - nl_ids: 0 6 2 2853 434 1277 8466 448 6506 2416 1454 746 1044 1277 431 4402 1147 3603 1712 706 8436 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 15:25:48 - INFO - __main__ - ***** Running training *****
+02/17/2024 15:25:48 - INFO - __main__ - Num examples = 908224
+02/17/2024 15:25:48 - INFO - __main__ - Num Epochs = 10
+02/17/2024 15:25:48 - INFO - __main__ - Num quene = 1024
+02/17/2024 15:25:48 - INFO - __main__ - Instantaneous batch size per GPU = 64
+02/17/2024 15:25:48 - INFO - __main__ - Total train batch size = 128
+Traceback (most recent call last):
+ File "run.py", line 1200, in
+ main()
+ File "run.py", line 1160, in main
+ multi_lang_continue_pre_train(args, model, tokenizer, pool)
+ File "run.py", line 756, in multi_lang_continue_pre_train
+ nl_q=nl_inputs , nl_k=nl_transformations_ids )
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/parallel/data_parallel.py", line 168, in forward
+ outputs = self.parallel_apply(replicas, inputs, kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/parallel/data_parallel.py", line 178, in parallel_apply
+ return parallel_apply(replicas, inputs, kwargs, self.device_ids[:len(replicas)])
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/parallel/parallel_apply.py", line 86, in parallel_apply
+ output.reraise()
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/_utils.py", line 434, in reraise
+ raise exception
+UnboundLocalError: Caught UnboundLocalError in replica 0 on device 0.
+Original Traceback (most recent call last):
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/parallel/parallel_apply.py", line 61, in _worker
+ output = module(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/cocosoda/CoCoSoDa/model.py", line 235, in forward
+ code_q = torch.nn.functional.normalize(code_q, p=2, dim=1)
+UnboundLocalError: local variable 'code_q' referenced before assignment
+
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/base_dvi.pth b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/base_dvi.pth
new file mode 100644
index 0000000000000000000000000000000000000000..336cf2f9bec8c9bd70c48bb4c878a6c770ffc494
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/base_dvi.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:1396d58628aa89cf55b533e8c813f633582c8f2b77c210189bfcf355005fcc28
+size 9506759
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/bgimg.png b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/bgimg.png
new file mode 100644
index 0000000000000000000000000000000000000000..041c94fec760772a8884a5962161e2121b721562
Binary files /dev/null and b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/bgimg.png differ
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/embedding.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/embedding.npy
new file mode 100644
index 0000000000000000000000000000000000000000..7fd10ef5fd033a283386689b688e68f4b0a91364
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/embedding.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:085bb5f7efe704f484da4f7603c28b58486e62822fbd89e145a2084e3d86f437
+size 199544
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/index.json b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/index.json
new file mode 100644
index 0000000000000000000000000000000000000000..9c13769254bdbcb6392dc4eb5ee76e59d645fb69
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/index.json
@@ -0,0 +1,24929 @@
+[
+ 0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6,
+ 7,
+ 8,
+ 9,
+ 10,
+ 11,
+ 12,
+ 13,
+ 14,
+ 15,
+ 16,
+ 17,
+ 18,
+ 19,
+ 20,
+ 21,
+ 22,
+ 23,
+ 24,
+ 25,
+ 26,
+ 27,
+ 28,
+ 29,
+ 30,
+ 31,
+ 32,
+ 33,
+ 34,
+ 35,
+ 36,
+ 37,
+ 38,
+ 39,
+ 40,
+ 41,
+ 42,
+ 43,
+ 44,
+ 45,
+ 46,
+ 47,
+ 48,
+ 49,
+ 50,
+ 51,
+ 52,
+ 53,
+ 54,
+ 55,
+ 56,
+ 57,
+ 58,
+ 59,
+ 60,
+ 61,
+ 62,
+ 63,
+ 64,
+ 65,
+ 66,
+ 67,
+ 68,
+ 69,
+ 70,
+ 71,
+ 72,
+ 73,
+ 74,
+ 75,
+ 76,
+ 77,
+ 78,
+ 79,
+ 80,
+ 81,
+ 82,
+ 83,
+ 84,
+ 85,
+ 86,
+ 87,
+ 88,
+ 89,
+ 90,
+ 91,
+ 92,
+ 93,
+ 94,
+ 95,
+ 96,
+ 97,
+ 98,
+ 99,
+ 100,
+ 101,
+ 102,
+ 103,
+ 104,
+ 105,
+ 106,
+ 107,
+ 108,
+ 109,
+ 110,
+ 111,
+ 112,
+ 113,
+ 114,
+ 115,
+ 116,
+ 117,
+ 118,
+ 119,
+ 120,
+ 121,
+ 122,
+ 123,
+ 124,
+ 125,
+ 126,
+ 127,
+ 128,
+ 129,
+ 130,
+ 131,
+ 132,
+ 133,
+ 134,
+ 135,
+ 136,
+ 137,
+ 138,
+ 139,
+ 140,
+ 141,
+ 142,
+ 143,
+ 144,
+ 145,
+ 146,
+ 147,
+ 148,
+ 149,
+ 150,
+ 151,
+ 152,
+ 153,
+ 154,
+ 155,
+ 156,
+ 157,
+ 158,
+ 159,
+ 160,
+ 161,
+ 162,
+ 163,
+ 164,
+ 165,
+ 166,
+ 167,
+ 168,
+ 169,
+ 170,
+ 171,
+ 172,
+ 173,
+ 174,
+ 175,
+ 176,
+ 177,
+ 178,
+ 179,
+ 180,
+ 181,
+ 182,
+ 183,
+ 184,
+ 185,
+ 186,
+ 187,
+ 188,
+ 189,
+ 190,
+ 191,
+ 192,
+ 193,
+ 194,
+ 195,
+ 196,
+ 197,
+ 198,
+ 199,
+ 200,
+ 201,
+ 202,
+ 203,
+ 204,
+ 205,
+ 206,
+ 207,
+ 208,
+ 209,
+ 210,
+ 211,
+ 212,
+ 213,
+ 214,
+ 215,
+ 216,
+ 217,
+ 218,
+ 219,
+ 220,
+ 221,
+ 222,
+ 223,
+ 224,
+ 225,
+ 226,
+ 227,
+ 228,
+ 229,
+ 230,
+ 231,
+ 232,
+ 233,
+ 234,
+ 235,
+ 236,
+ 237,
+ 238,
+ 239,
+ 240,
+ 241,
+ 242,
+ 243,
+ 244,
+ 245,
+ 246,
+ 247,
+ 248,
+ 249,
+ 250,
+ 251,
+ 252,
+ 253,
+ 254,
+ 255,
+ 256,
+ 257,
+ 258,
+ 259,
+ 260,
+ 261,
+ 262,
+ 263,
+ 264,
+ 265,
+ 266,
+ 267,
+ 268,
+ 269,
+ 270,
+ 271,
+ 272,
+ 273,
+ 274,
+ 275,
+ 276,
+ 277,
+ 278,
+ 279,
+ 280,
+ 281,
+ 282,
+ 283,
+ 284,
+ 285,
+ 286,
+ 287,
+ 288,
+ 289,
+ 290,
+ 291,
+ 292,
+ 293,
+ 294,
+ 295,
+ 296,
+ 297,
+ 298,
+ 299,
+ 300,
+ 301,
+ 302,
+ 303,
+ 304,
+ 305,
+ 306,
+ 307,
+ 308,
+ 309,
+ 310,
+ 311,
+ 312,
+ 313,
+ 314,
+ 315,
+ 316,
+ 317,
+ 318,
+ 319,
+ 320,
+ 321,
+ 322,
+ 323,
+ 324,
+ 325,
+ 326,
+ 327,
+ 328,
+ 329,
+ 330,
+ 331,
+ 332,
+ 333,
+ 334,
+ 335,
+ 336,
+ 337,
+ 338,
+ 339,
+ 340,
+ 341,
+ 342,
+ 343,
+ 344,
+ 345,
+ 346,
+ 347,
+ 348,
+ 349,
+ 350,
+ 351,
+ 352,
+ 353,
+ 354,
+ 355,
+ 356,
+ 357,
+ 358,
+ 359,
+ 360,
+ 361,
+ 362,
+ 363,
+ 364,
+ 365,
+ 366,
+ 367,
+ 368,
+ 369,
+ 370,
+ 371,
+ 372,
+ 373,
+ 374,
+ 375,
+ 376,
+ 377,
+ 378,
+ 379,
+ 380,
+ 381,
+ 382,
+ 383,
+ 384,
+ 385,
+ 386,
+ 387,
+ 388,
+ 389,
+ 390,
+ 391,
+ 392,
+ 393,
+ 394,
+ 395,
+ 396,
+ 397,
+ 398,
+ 399,
+ 400,
+ 401,
+ 402,
+ 403,
+ 404,
+ 405,
+ 406,
+ 407,
+ 408,
+ 409,
+ 410,
+ 411,
+ 412,
+ 413,
+ 414,
+ 415,
+ 416,
+ 417,
+ 418,
+ 419,
+ 420,
+ 421,
+ 422,
+ 423,
+ 424,
+ 425,
+ 426,
+ 427,
+ 428,
+ 429,
+ 430,
+ 431,
+ 432,
+ 433,
+ 434,
+ 435,
+ 436,
+ 437,
+ 438,
+ 439,
+ 440,
+ 441,
+ 442,
+ 443,
+ 444,
+ 445,
+ 446,
+ 447,
+ 448,
+ 449,
+ 450,
+ 451,
+ 452,
+ 453,
+ 454,
+ 455,
+ 456,
+ 457,
+ 458,
+ 459,
+ 460,
+ 461,
+ 462,
+ 463,
+ 464,
+ 465,
+ 466,
+ 467,
+ 468,
+ 469,
+ 470,
+ 471,
+ 472,
+ 473,
+ 474,
+ 475,
+ 476,
+ 477,
+ 478,
+ 479,
+ 480,
+ 481,
+ 482,
+ 483,
+ 484,
+ 485,
+ 486,
+ 487,
+ 488,
+ 489,
+ 490,
+ 491,
+ 492,
+ 493,
+ 494,
+ 495,
+ 496,
+ 497,
+ 498,
+ 499,
+ 500,
+ 501,
+ 502,
+ 503,
+ 504,
+ 505,
+ 506,
+ 507,
+ 508,
+ 509,
+ 510,
+ 511,
+ 512,
+ 513,
+ 514,
+ 515,
+ 516,
+ 517,
+ 518,
+ 519,
+ 520,
+ 521,
+ 522,
+ 523,
+ 524,
+ 525,
+ 526,
+ 527,
+ 528,
+ 529,
+ 530,
+ 531,
+ 532,
+ 533,
+ 534,
+ 535,
+ 536,
+ 537,
+ 538,
+ 539,
+ 540,
+ 541,
+ 542,
+ 543,
+ 544,
+ 545,
+ 546,
+ 547,
+ 548,
+ 549,
+ 550,
+ 551,
+ 552,
+ 553,
+ 554,
+ 555,
+ 556,
+ 557,
+ 558,
+ 559,
+ 560,
+ 561,
+ 562,
+ 563,
+ 564,
+ 565,
+ 566,
+ 567,
+ 568,
+ 569,
+ 570,
+ 571,
+ 572,
+ 573,
+ 574,
+ 575,
+ 576,
+ 577,
+ 578,
+ 579,
+ 580,
+ 581,
+ 582,
+ 583,
+ 584,
+ 585,
+ 586,
+ 587,
+ 588,
+ 589,
+ 590,
+ 591,
+ 592,
+ 593,
+ 594,
+ 595,
+ 596,
+ 597,
+ 598,
+ 599,
+ 600,
+ 601,
+ 602,
+ 603,
+ 604,
+ 605,
+ 606,
+ 607,
+ 608,
+ 609,
+ 610,
+ 611,
+ 612,
+ 613,
+ 614,
+ 615,
+ 616,
+ 617,
+ 618,
+ 619,
+ 620,
+ 621,
+ 622,
+ 623,
+ 624,
+ 625,
+ 626,
+ 627,
+ 628,
+ 629,
+ 630,
+ 631,
+ 632,
+ 633,
+ 634,
+ 635,
+ 636,
+ 637,
+ 638,
+ 639,
+ 640,
+ 641,
+ 642,
+ 643,
+ 644,
+ 645,
+ 646,
+ 647,
+ 648,
+ 649,
+ 650,
+ 651,
+ 652,
+ 653,
+ 654,
+ 655,
+ 656,
+ 657,
+ 658,
+ 659,
+ 660,
+ 661,
+ 662,
+ 663,
+ 664,
+ 665,
+ 666,
+ 667,
+ 668,
+ 669,
+ 670,
+ 671,
+ 672,
+ 673,
+ 674,
+ 675,
+ 676,
+ 677,
+ 678,
+ 679,
+ 680,
+ 681,
+ 682,
+ 683,
+ 684,
+ 685,
+ 686,
+ 687,
+ 688,
+ 689,
+ 690,
+ 691,
+ 692,
+ 693,
+ 694,
+ 695,
+ 696,
+ 697,
+ 698,
+ 699,
+ 700,
+ 701,
+ 702,
+ 703,
+ 704,
+ 705,
+ 706,
+ 707,
+ 708,
+ 709,
+ 710,
+ 711,
+ 712,
+ 713,
+ 714,
+ 715,
+ 716,
+ 717,
+ 718,
+ 719,
+ 720,
+ 721,
+ 722,
+ 723,
+ 724,
+ 725,
+ 726,
+ 727,
+ 728,
+ 729,
+ 730,
+ 731,
+ 732,
+ 733,
+ 734,
+ 735,
+ 736,
+ 737,
+ 738,
+ 739,
+ 740,
+ 741,
+ 742,
+ 743,
+ 744,
+ 745,
+ 746,
+ 747,
+ 748,
+ 749,
+ 750,
+ 751,
+ 752,
+ 753,
+ 754,
+ 755,
+ 756,
+ 757,
+ 758,
+ 759,
+ 760,
+ 761,
+ 762,
+ 763,
+ 764,
+ 765,
+ 766,
+ 767,
+ 768,
+ 769,
+ 770,
+ 771,
+ 772,
+ 773,
+ 774,
+ 775,
+ 776,
+ 777,
+ 778,
+ 779,
+ 780,
+ 781,
+ 782,
+ 783,
+ 784,
+ 785,
+ 786,
+ 787,
+ 788,
+ 789,
+ 790,
+ 791,
+ 792,
+ 793,
+ 794,
+ 795,
+ 796,
+ 797,
+ 798,
+ 799,
+ 800,
+ 801,
+ 802,
+ 803,
+ 804,
+ 805,
+ 806,
+ 807,
+ 808,
+ 809,
+ 810,
+ 811,
+ 812,
+ 813,
+ 814,
+ 815,
+ 816,
+ 817,
+ 818,
+ 819,
+ 820,
+ 821,
+ 822,
+ 823,
+ 824,
+ 825,
+ 826,
+ 827,
+ 828,
+ 829,
+ 830,
+ 831,
+ 832,
+ 833,
+ 834,
+ 835,
+ 836,
+ 837,
+ 838,
+ 839,
+ 840,
+ 841,
+ 842,
+ 843,
+ 844,
+ 845,
+ 846,
+ 847,
+ 848,
+ 849,
+ 850,
+ 851,
+ 852,
+ 853,
+ 854,
+ 855,
+ 856,
+ 857,
+ 858,
+ 859,
+ 860,
+ 861,
+ 862,
+ 863,
+ 864,
+ 865,
+ 866,
+ 867,
+ 868,
+ 869,
+ 870,
+ 871,
+ 872,
+ 873,
+ 874,
+ 875,
+ 876,
+ 877,
+ 878,
+ 879,
+ 880,
+ 881,
+ 882,
+ 883,
+ 884,
+ 885,
+ 886,
+ 887,
+ 888,
+ 889,
+ 890,
+ 891,
+ 892,
+ 893,
+ 894,
+ 895,
+ 896,
+ 897,
+ 898,
+ 899,
+ 900,
+ 901,
+ 902,
+ 903,
+ 904,
+ 905,
+ 906,
+ 907,
+ 908,
+ 909,
+ 910,
+ 911,
+ 912,
+ 913,
+ 914,
+ 915,
+ 916,
+ 917,
+ 918,
+ 919,
+ 920,
+ 921,
+ 922,
+ 923,
+ 924,
+ 925,
+ 926,
+ 927,
+ 928,
+ 929,
+ 930,
+ 931,
+ 932,
+ 933,
+ 934,
+ 935,
+ 936,
+ 937,
+ 938,
+ 939,
+ 940,
+ 941,
+ 942,
+ 943,
+ 944,
+ 945,
+ 946,
+ 947,
+ 948,
+ 949,
+ 950,
+ 951,
+ 952,
+ 953,
+ 954,
+ 955,
+ 956,
+ 957,
+ 958,
+ 959,
+ 960,
+ 961,
+ 962,
+ 963,
+ 964,
+ 965,
+ 966,
+ 967,
+ 968,
+ 969,
+ 970,
+ 971,
+ 972,
+ 973,
+ 974,
+ 975,
+ 976,
+ 977,
+ 978,
+ 979,
+ 980,
+ 981,
+ 982,
+ 983,
+ 984,
+ 985,
+ 986,
+ 987,
+ 988,
+ 989,
+ 990,
+ 991,
+ 992,
+ 993,
+ 994,
+ 995,
+ 996,
+ 997,
+ 998,
+ 999,
+ 1000,
+ 1001,
+ 1002,
+ 1003,
+ 1004,
+ 1005,
+ 1006,
+ 1007,
+ 1008,
+ 1009,
+ 1010,
+ 1011,
+ 1012,
+ 1013,
+ 1014,
+ 1015,
+ 1016,
+ 1017,
+ 1018,
+ 1019,
+ 1020,
+ 1021,
+ 1022,
+ 1023,
+ 1024,
+ 1025,
+ 1026,
+ 1027,
+ 1028,
+ 1029,
+ 1030,
+ 1031,
+ 1032,
+ 1033,
+ 1034,
+ 1035,
+ 1036,
+ 1037,
+ 1038,
+ 1039,
+ 1040,
+ 1041,
+ 1042,
+ 1043,
+ 1044,
+ 1045,
+ 1046,
+ 1047,
+ 1048,
+ 1049,
+ 1050,
+ 1051,
+ 1052,
+ 1053,
+ 1054,
+ 1055,
+ 1056,
+ 1057,
+ 1058,
+ 1059,
+ 1060,
+ 1061,
+ 1062,
+ 1063,
+ 1064,
+ 1065,
+ 1066,
+ 1067,
+ 1068,
+ 1069,
+ 1070,
+ 1071,
+ 1072,
+ 1073,
+ 1074,
+ 1075,
+ 1076,
+ 1077,
+ 1078,
+ 1079,
+ 1080,
+ 1081,
+ 1082,
+ 1083,
+ 1084,
+ 1085,
+ 1086,
+ 1087,
+ 1088,
+ 1089,
+ 1090,
+ 1091,
+ 1092,
+ 1093,
+ 1094,
+ 1095,
+ 1096,
+ 1097,
+ 1098,
+ 1099,
+ 1100,
+ 1101,
+ 1102,
+ 1103,
+ 1104,
+ 1105,
+ 1106,
+ 1107,
+ 1108,
+ 1109,
+ 1110,
+ 1111,
+ 1112,
+ 1113,
+ 1114,
+ 1115,
+ 1116,
+ 1117,
+ 1118,
+ 1119,
+ 1120,
+ 1121,
+ 1122,
+ 1123,
+ 1124,
+ 1125,
+ 1126,
+ 1127,
+ 1128,
+ 1129,
+ 1130,
+ 1131,
+ 1132,
+ 1133,
+ 1134,
+ 1135,
+ 1136,
+ 1137,
+ 1138,
+ 1139,
+ 1140,
+ 1141,
+ 1142,
+ 1143,
+ 1144,
+ 1145,
+ 1146,
+ 1147,
+ 1148,
+ 1149,
+ 1150,
+ 1151,
+ 1152,
+ 1153,
+ 1154,
+ 1155,
+ 1156,
+ 1157,
+ 1158,
+ 1159,
+ 1160,
+ 1161,
+ 1162,
+ 1163,
+ 1164,
+ 1165,
+ 1166,
+ 1167,
+ 1168,
+ 1169,
+ 1170,
+ 1171,
+ 1172,
+ 1173,
+ 1174,
+ 1175,
+ 1176,
+ 1177,
+ 1178,
+ 1179,
+ 1180,
+ 1181,
+ 1182,
+ 1183,
+ 1184,
+ 1185,
+ 1186,
+ 1187,
+ 1188,
+ 1189,
+ 1190,
+ 1191,
+ 1192,
+ 1193,
+ 1194,
+ 1195,
+ 1196,
+ 1197,
+ 1198,
+ 1199,
+ 1200,
+ 1201,
+ 1202,
+ 1203,
+ 1204,
+ 1205,
+ 1206,
+ 1207,
+ 1208,
+ 1209,
+ 1210,
+ 1211,
+ 1212,
+ 1213,
+ 1214,
+ 1215,
+ 1216,
+ 1217,
+ 1218,
+ 1219,
+ 1220,
+ 1221,
+ 1222,
+ 1223,
+ 1224,
+ 1225,
+ 1226,
+ 1227,
+ 1228,
+ 1229,
+ 1230,
+ 1231,
+ 1232,
+ 1233,
+ 1234,
+ 1235,
+ 1236,
+ 1237,
+ 1238,
+ 1239,
+ 1240,
+ 1241,
+ 1242,
+ 1243,
+ 1244,
+ 1245,
+ 1246,
+ 1247,
+ 1248,
+ 1249,
+ 1250,
+ 1251,
+ 1252,
+ 1253,
+ 1254,
+ 1255,
+ 1256,
+ 1257,
+ 1258,
+ 1259,
+ 1260,
+ 1261,
+ 1262,
+ 1263,
+ 1264,
+ 1265,
+ 1266,
+ 1267,
+ 1268,
+ 1269,
+ 1270,
+ 1271,
+ 1272,
+ 1273,
+ 1274,
+ 1275,
+ 1276,
+ 1277,
+ 1278,
+ 1279,
+ 1280,
+ 1281,
+ 1282,
+ 1283,
+ 1284,
+ 1285,
+ 1286,
+ 1287,
+ 1288,
+ 1289,
+ 1290,
+ 1291,
+ 1292,
+ 1293,
+ 1294,
+ 1295,
+ 1296,
+ 1297,
+ 1298,
+ 1299,
+ 1300,
+ 1301,
+ 1302,
+ 1303,
+ 1304,
+ 1305,
+ 1306,
+ 1307,
+ 1308,
+ 1309,
+ 1310,
+ 1311,
+ 1312,
+ 1313,
+ 1314,
+ 1315,
+ 1316,
+ 1317,
+ 1318,
+ 1319,
+ 1320,
+ 1321,
+ 1322,
+ 1323,
+ 1324,
+ 1325,
+ 1326,
+ 1327,
+ 1328,
+ 1329,
+ 1330,
+ 1331,
+ 1332,
+ 1333,
+ 1334,
+ 1335,
+ 1336,
+ 1337,
+ 1338,
+ 1339,
+ 1340,
+ 1341,
+ 1342,
+ 1343,
+ 1344,
+ 1345,
+ 1346,
+ 1347,
+ 1348,
+ 1349,
+ 1350,
+ 1351,
+ 1352,
+ 1353,
+ 1354,
+ 1355,
+ 1356,
+ 1357,
+ 1358,
+ 1359,
+ 1360,
+ 1361,
+ 1362,
+ 1363,
+ 1364,
+ 1365,
+ 1366,
+ 1367,
+ 1368,
+ 1369,
+ 1370,
+ 1371,
+ 1372,
+ 1373,
+ 1374,
+ 1375,
+ 1376,
+ 1377,
+ 1378,
+ 1379,
+ 1380,
+ 1381,
+ 1382,
+ 1383,
+ 1384,
+ 1385,
+ 1386,
+ 1387,
+ 1388,
+ 1389,
+ 1390,
+ 1391,
+ 1392,
+ 1393,
+ 1394,
+ 1395,
+ 1396,
+ 1397,
+ 1398,
+ 1399,
+ 1400,
+ 1401,
+ 1402,
+ 1403,
+ 1404,
+ 1405,
+ 1406,
+ 1407,
+ 1408,
+ 1409,
+ 1410,
+ 1411,
+ 1412,
+ 1413,
+ 1414,
+ 1415,
+ 1416,
+ 1417,
+ 1418,
+ 1419,
+ 1420,
+ 1421,
+ 1422,
+ 1423,
+ 1424,
+ 1425,
+ 1426,
+ 1427,
+ 1428,
+ 1429,
+ 1430,
+ 1431,
+ 1432,
+ 1433,
+ 1434,
+ 1435,
+ 1436,
+ 1437,
+ 1438,
+ 1439,
+ 1440,
+ 1441,
+ 1442,
+ 1443,
+ 1444,
+ 1445,
+ 1446,
+ 1447,
+ 1448,
+ 1449,
+ 1450,
+ 1451,
+ 1452,
+ 1453,
+ 1454,
+ 1455,
+ 1456,
+ 1457,
+ 1458,
+ 1459,
+ 1460,
+ 1461,
+ 1462,
+ 1463,
+ 1464,
+ 1465,
+ 1466,
+ 1467,
+ 1468,
+ 1469,
+ 1470,
+ 1471,
+ 1472,
+ 1473,
+ 1474,
+ 1475,
+ 1476,
+ 1477,
+ 1478,
+ 1479,
+ 1480,
+ 1481,
+ 1482,
+ 1483,
+ 1484,
+ 1485,
+ 1486,
+ 1487,
+ 1488,
+ 1489,
+ 1490,
+ 1491,
+ 1492,
+ 1493,
+ 1494,
+ 1495,
+ 1496,
+ 1497,
+ 1498,
+ 1499,
+ 1500,
+ 1501,
+ 1502,
+ 1503,
+ 1504,
+ 1505,
+ 1506,
+ 1507,
+ 1508,
+ 1509,
+ 1510,
+ 1511,
+ 1512,
+ 1513,
+ 1514,
+ 1515,
+ 1516,
+ 1517,
+ 1518,
+ 1519,
+ 1520,
+ 1521,
+ 1522,
+ 1523,
+ 1524,
+ 1525,
+ 1526,
+ 1527,
+ 1528,
+ 1529,
+ 1530,
+ 1531,
+ 1532,
+ 1533,
+ 1534,
+ 1535,
+ 1536,
+ 1537,
+ 1538,
+ 1539,
+ 1540,
+ 1541,
+ 1542,
+ 1543,
+ 1544,
+ 1545,
+ 1546,
+ 1547,
+ 1548,
+ 1549,
+ 1550,
+ 1551,
+ 1552,
+ 1553,
+ 1554,
+ 1555,
+ 1556,
+ 1557,
+ 1558,
+ 1559,
+ 1560,
+ 1561,
+ 1562,
+ 1563,
+ 1564,
+ 1565,
+ 1566,
+ 1567,
+ 1568,
+ 1569,
+ 1570,
+ 1571,
+ 1572,
+ 1573,
+ 1574,
+ 1575,
+ 1576,
+ 1577,
+ 1578,
+ 1579,
+ 1580,
+ 1581,
+ 1582,
+ 1583,
+ 1584,
+ 1585,
+ 1586,
+ 1587,
+ 1588,
+ 1589,
+ 1590,
+ 1591,
+ 1592,
+ 1593,
+ 1594,
+ 1595,
+ 1596,
+ 1597,
+ 1598,
+ 1599,
+ 1600,
+ 1601,
+ 1602,
+ 1603,
+ 1604,
+ 1605,
+ 1606,
+ 1607,
+ 1608,
+ 1609,
+ 1610,
+ 1611,
+ 1612,
+ 1613,
+ 1614,
+ 1615,
+ 1616,
+ 1617,
+ 1618,
+ 1619,
+ 1620,
+ 1621,
+ 1622,
+ 1623,
+ 1624,
+ 1625,
+ 1626,
+ 1627,
+ 1628,
+ 1629,
+ 1630,
+ 1631,
+ 1632,
+ 1633,
+ 1634,
+ 1635,
+ 1636,
+ 1637,
+ 1638,
+ 1639,
+ 1640,
+ 1641,
+ 1642,
+ 1643,
+ 1644,
+ 1645,
+ 1646,
+ 1647,
+ 1648,
+ 1649,
+ 1650,
+ 1651,
+ 1652,
+ 1653,
+ 1654,
+ 1655,
+ 1656,
+ 1657,
+ 1658,
+ 1659,
+ 1660,
+ 1661,
+ 1662,
+ 1663,
+ 1664,
+ 1665,
+ 1666,
+ 1667,
+ 1668,
+ 1669,
+ 1670,
+ 1671,
+ 1672,
+ 1673,
+ 1674,
+ 1675,
+ 1676,
+ 1677,
+ 1678,
+ 1679,
+ 1680,
+ 1681,
+ 1682,
+ 1683,
+ 1684,
+ 1685,
+ 1686,
+ 1687,
+ 1688,
+ 1689,
+ 1690,
+ 1691,
+ 1692,
+ 1693,
+ 1694,
+ 1695,
+ 1696,
+ 1697,
+ 1698,
+ 1699,
+ 1700,
+ 1701,
+ 1702,
+ 1703,
+ 1704,
+ 1705,
+ 1706,
+ 1707,
+ 1708,
+ 1709,
+ 1710,
+ 1711,
+ 1712,
+ 1713,
+ 1714,
+ 1715,
+ 1716,
+ 1717,
+ 1718,
+ 1719,
+ 1720,
+ 1721,
+ 1722,
+ 1723,
+ 1724,
+ 1725,
+ 1726,
+ 1727,
+ 1728,
+ 1729,
+ 1730,
+ 1731,
+ 1732,
+ 1733,
+ 1734,
+ 1735,
+ 1736,
+ 1737,
+ 1738,
+ 1739,
+ 1740,
+ 1741,
+ 1742,
+ 1743,
+ 1744,
+ 1745,
+ 1746,
+ 1747,
+ 1748,
+ 1749,
+ 1750,
+ 1751,
+ 1752,
+ 1753,
+ 1754,
+ 1755,
+ 1756,
+ 1757,
+ 1758,
+ 1759,
+ 1760,
+ 1761,
+ 1762,
+ 1763,
+ 1764,
+ 1765,
+ 1766,
+ 1767,
+ 1768,
+ 1769,
+ 1770,
+ 1771,
+ 1772,
+ 1773,
+ 1774,
+ 1775,
+ 1776,
+ 1777,
+ 1778,
+ 1779,
+ 1780,
+ 1781,
+ 1782,
+ 1783,
+ 1784,
+ 1785,
+ 1786,
+ 1787,
+ 1788,
+ 1789,
+ 1790,
+ 1791,
+ 1792,
+ 1793,
+ 1794,
+ 1795,
+ 1796,
+ 1797,
+ 1798,
+ 1799,
+ 1800,
+ 1801,
+ 1802,
+ 1803,
+ 1804,
+ 1805,
+ 1806,
+ 1807,
+ 1808,
+ 1809,
+ 1810,
+ 1811,
+ 1812,
+ 1813,
+ 1814,
+ 1815,
+ 1816,
+ 1817,
+ 1818,
+ 1819,
+ 1820,
+ 1821,
+ 1822,
+ 1823,
+ 1824,
+ 1825,
+ 1826,
+ 1827,
+ 1828,
+ 1829,
+ 1830,
+ 1831,
+ 1832,
+ 1833,
+ 1834,
+ 1835,
+ 1836,
+ 1837,
+ 1838,
+ 1839,
+ 1840,
+ 1841,
+ 1842,
+ 1843,
+ 1844,
+ 1845,
+ 1846,
+ 1847,
+ 1848,
+ 1849,
+ 1850,
+ 1851,
+ 1852,
+ 1853,
+ 1854,
+ 1855,
+ 1856,
+ 1857,
+ 1858,
+ 1859,
+ 1860,
+ 1861,
+ 1862,
+ 1863,
+ 1864,
+ 1865,
+ 1866,
+ 1867,
+ 1868,
+ 1869,
+ 1870,
+ 1871,
+ 1872,
+ 1873,
+ 1874,
+ 1875,
+ 1876,
+ 1877,
+ 1878,
+ 1879,
+ 1880,
+ 1881,
+ 1882,
+ 1883,
+ 1884,
+ 1885,
+ 1886,
+ 1887,
+ 1888,
+ 1889,
+ 1890,
+ 1891,
+ 1892,
+ 1893,
+ 1894,
+ 1895,
+ 1896,
+ 1897,
+ 1898,
+ 1899,
+ 1900,
+ 1901,
+ 1902,
+ 1903,
+ 1904,
+ 1905,
+ 1906,
+ 1907,
+ 1908,
+ 1909,
+ 1910,
+ 1911,
+ 1912,
+ 1913,
+ 1914,
+ 1915,
+ 1916,
+ 1917,
+ 1918,
+ 1919,
+ 1920,
+ 1921,
+ 1922,
+ 1923,
+ 1924,
+ 1925,
+ 1926,
+ 1927,
+ 1928,
+ 1929,
+ 1930,
+ 1931,
+ 1932,
+ 1933,
+ 1934,
+ 1935,
+ 1936,
+ 1937,
+ 1938,
+ 1939,
+ 1940,
+ 1941,
+ 1942,
+ 1943,
+ 1944,
+ 1945,
+ 1946,
+ 1947,
+ 1948,
+ 1949,
+ 1950,
+ 1951,
+ 1952,
+ 1953,
+ 1954,
+ 1955,
+ 1956,
+ 1957,
+ 1958,
+ 1959,
+ 1960,
+ 1961,
+ 1962,
+ 1963,
+ 1964,
+ 1965,
+ 1966,
+ 1967,
+ 1968,
+ 1969,
+ 1970,
+ 1971,
+ 1972,
+ 1973,
+ 1974,
+ 1975,
+ 1976,
+ 1977,
+ 1978,
+ 1979,
+ 1980,
+ 1981,
+ 1982,
+ 1983,
+ 1984,
+ 1985,
+ 1986,
+ 1987,
+ 1988,
+ 1989,
+ 1990,
+ 1991,
+ 1992,
+ 1993,
+ 1994,
+ 1995,
+ 1996,
+ 1997,
+ 1998,
+ 1999,
+ 2000,
+ 2001,
+ 2002,
+ 2003,
+ 2004,
+ 2005,
+ 2006,
+ 2007,
+ 2008,
+ 2009,
+ 2010,
+ 2011,
+ 2012,
+ 2013,
+ 2014,
+ 2015,
+ 2016,
+ 2017,
+ 2018,
+ 2019,
+ 2020,
+ 2021,
+ 2022,
+ 2023,
+ 2024,
+ 2025,
+ 2026,
+ 2027,
+ 2028,
+ 2029,
+ 2030,
+ 2031,
+ 2032,
+ 2033,
+ 2034,
+ 2035,
+ 2036,
+ 2037,
+ 2038,
+ 2039,
+ 2040,
+ 2041,
+ 2042,
+ 2043,
+ 2044,
+ 2045,
+ 2046,
+ 2047,
+ 2048,
+ 2049,
+ 2050,
+ 2051,
+ 2052,
+ 2053,
+ 2054,
+ 2055,
+ 2056,
+ 2057,
+ 2058,
+ 2059,
+ 2060,
+ 2061,
+ 2062,
+ 2063,
+ 2064,
+ 2065,
+ 2066,
+ 2067,
+ 2068,
+ 2069,
+ 2070,
+ 2071,
+ 2072,
+ 2073,
+ 2074,
+ 2075,
+ 2076,
+ 2077,
+ 2078,
+ 2079,
+ 2080,
+ 2081,
+ 2082,
+ 2083,
+ 2084,
+ 2085,
+ 2086,
+ 2087,
+ 2088,
+ 2089,
+ 2090,
+ 2091,
+ 2092,
+ 2093,
+ 2094,
+ 2095,
+ 2096,
+ 2097,
+ 2098,
+ 2099,
+ 2100,
+ 2101,
+ 2102,
+ 2103,
+ 2104,
+ 2105,
+ 2106,
+ 2107,
+ 2108,
+ 2109,
+ 2110,
+ 2111,
+ 2112,
+ 2113,
+ 2114,
+ 2115,
+ 2116,
+ 2117,
+ 2118,
+ 2119,
+ 2120,
+ 2121,
+ 2122,
+ 2123,
+ 2124,
+ 2125,
+ 2126,
+ 2127,
+ 2128,
+ 2129,
+ 2130,
+ 2131,
+ 2132,
+ 2133,
+ 2134,
+ 2135,
+ 2136,
+ 2137,
+ 2138,
+ 2139,
+ 2140,
+ 2141,
+ 2142,
+ 2143,
+ 2144,
+ 2145,
+ 2146,
+ 2147,
+ 2148,
+ 2149,
+ 2150,
+ 2151,
+ 2152,
+ 2153,
+ 2154,
+ 2155,
+ 2156,
+ 2157,
+ 2158,
+ 2159,
+ 2160,
+ 2161,
+ 2162,
+ 2163,
+ 2164,
+ 2165,
+ 2166,
+ 2167,
+ 2168,
+ 2169,
+ 2170,
+ 2171,
+ 2172,
+ 2173,
+ 2174,
+ 2175,
+ 2176,
+ 2177,
+ 2178,
+ 2179,
+ 2180,
+ 2181,
+ 2182,
+ 2183,
+ 2184,
+ 2185,
+ 2186,
+ 2187,
+ 2188,
+ 2189,
+ 2190,
+ 2191,
+ 2192,
+ 2193,
+ 2194,
+ 2195,
+ 2196,
+ 2197,
+ 2198,
+ 2199,
+ 2200,
+ 2201,
+ 2202,
+ 2203,
+ 2204,
+ 2205,
+ 2206,
+ 2207,
+ 2208,
+ 2209,
+ 2210,
+ 2211,
+ 2212,
+ 2213,
+ 2214,
+ 2215,
+ 2216,
+ 2217,
+ 2218,
+ 2219,
+ 2220,
+ 2221,
+ 2222,
+ 2223,
+ 2224,
+ 2225,
+ 2226,
+ 2227,
+ 2228,
+ 2229,
+ 2230,
+ 2231,
+ 2232,
+ 2233,
+ 2234,
+ 2235,
+ 2236,
+ 2237,
+ 2238,
+ 2239,
+ 2240,
+ 2241,
+ 2242,
+ 2243,
+ 2244,
+ 2245,
+ 2246,
+ 2247,
+ 2248,
+ 2249,
+ 2250,
+ 2251,
+ 2252,
+ 2253,
+ 2254,
+ 2255,
+ 2256,
+ 2257,
+ 2258,
+ 2259,
+ 2260,
+ 2261,
+ 2262,
+ 2263,
+ 2264,
+ 2265,
+ 2266,
+ 2267,
+ 2268,
+ 2269,
+ 2270,
+ 2271,
+ 2272,
+ 2273,
+ 2274,
+ 2275,
+ 2276,
+ 2277,
+ 2278,
+ 2279,
+ 2280,
+ 2281,
+ 2282,
+ 2283,
+ 2284,
+ 2285,
+ 2286,
+ 2287,
+ 2288,
+ 2289,
+ 2290,
+ 2291,
+ 2292,
+ 2293,
+ 2294,
+ 2295,
+ 2296,
+ 2297,
+ 2298,
+ 2299,
+ 2300,
+ 2301,
+ 2302,
+ 2303,
+ 2304,
+ 2305,
+ 2306,
+ 2307,
+ 2308,
+ 2309,
+ 2310,
+ 2311,
+ 2312,
+ 2313,
+ 2314,
+ 2315,
+ 2316,
+ 2317,
+ 2318,
+ 2319,
+ 2320,
+ 2321,
+ 2322,
+ 2323,
+ 2324,
+ 2325,
+ 2326,
+ 2327,
+ 2328,
+ 2329,
+ 2330,
+ 2331,
+ 2332,
+ 2333,
+ 2334,
+ 2335,
+ 2336,
+ 2337,
+ 2338,
+ 2339,
+ 2340,
+ 2341,
+ 2342,
+ 2343,
+ 2344,
+ 2345,
+ 2346,
+ 2347,
+ 2348,
+ 2349,
+ 2350,
+ 2351,
+ 2352,
+ 2353,
+ 2354,
+ 2355,
+ 2356,
+ 2357,
+ 2358,
+ 2359,
+ 2360,
+ 2361,
+ 2362,
+ 2363,
+ 2364,
+ 2365,
+ 2366,
+ 2367,
+ 2368,
+ 2369,
+ 2370,
+ 2371,
+ 2372,
+ 2373,
+ 2374,
+ 2375,
+ 2376,
+ 2377,
+ 2378,
+ 2379,
+ 2380,
+ 2381,
+ 2382,
+ 2383,
+ 2384,
+ 2385,
+ 2386,
+ 2387,
+ 2388,
+ 2389,
+ 2390,
+ 2391,
+ 2392,
+ 2393,
+ 2394,
+ 2395,
+ 2396,
+ 2397,
+ 2398,
+ 2399,
+ 2400,
+ 2401,
+ 2402,
+ 2403,
+ 2404,
+ 2405,
+ 2406,
+ 2407,
+ 2408,
+ 2409,
+ 2410,
+ 2411,
+ 2412,
+ 2413,
+ 2414,
+ 2415,
+ 2416,
+ 2417,
+ 2418,
+ 2419,
+ 2420,
+ 2421,
+ 2422,
+ 2423,
+ 2424,
+ 2425,
+ 2426,
+ 2427,
+ 2428,
+ 2429,
+ 2430,
+ 2431,
+ 2432,
+ 2433,
+ 2434,
+ 2435,
+ 2436,
+ 2437,
+ 2438,
+ 2439,
+ 2440,
+ 2441,
+ 2442,
+ 2443,
+ 2444,
+ 2445,
+ 2446,
+ 2447,
+ 2448,
+ 2449,
+ 2450,
+ 2451,
+ 2452,
+ 2453,
+ 2454,
+ 2455,
+ 2456,
+ 2457,
+ 2458,
+ 2459,
+ 2460,
+ 2461,
+ 2462,
+ 2463,
+ 2464,
+ 2465,
+ 2466,
+ 2467,
+ 2468,
+ 2469,
+ 2470,
+ 2471,
+ 2472,
+ 2473,
+ 2474,
+ 2475,
+ 2476,
+ 2477,
+ 2478,
+ 2479,
+ 2480,
+ 2481,
+ 2482,
+ 2483,
+ 2484,
+ 2485,
+ 2486,
+ 2487,
+ 2488,
+ 2489,
+ 2490,
+ 2491,
+ 2492,
+ 2493,
+ 2494,
+ 2495,
+ 2496,
+ 2497,
+ 2498,
+ 2499,
+ 2500,
+ 2501,
+ 2502,
+ 2503,
+ 2504,
+ 2505,
+ 2506,
+ 2507,
+ 2508,
+ 2509,
+ 2510,
+ 2511,
+ 2512,
+ 2513,
+ 2514,
+ 2515,
+ 2516,
+ 2517,
+ 2518,
+ 2519,
+ 2520,
+ 2521,
+ 2522,
+ 2523,
+ 2524,
+ 2525,
+ 2526,
+ 2527,
+ 2528,
+ 2529,
+ 2530,
+ 2531,
+ 2532,
+ 2533,
+ 2534,
+ 2535,
+ 2536,
+ 2537,
+ 2538,
+ 2539,
+ 2540,
+ 2541,
+ 2542,
+ 2543,
+ 2544,
+ 2545,
+ 2546,
+ 2547,
+ 2548,
+ 2549,
+ 2550,
+ 2551,
+ 2552,
+ 2553,
+ 2554,
+ 2555,
+ 2556,
+ 2557,
+ 2558,
+ 2559,
+ 2560,
+ 2561,
+ 2562,
+ 2563,
+ 2564,
+ 2565,
+ 2566,
+ 2567,
+ 2568,
+ 2569,
+ 2570,
+ 2571,
+ 2572,
+ 2573,
+ 2574,
+ 2575,
+ 2576,
+ 2577,
+ 2578,
+ 2579,
+ 2580,
+ 2581,
+ 2582,
+ 2583,
+ 2584,
+ 2585,
+ 2586,
+ 2587,
+ 2588,
+ 2589,
+ 2590,
+ 2591,
+ 2592,
+ 2593,
+ 2594,
+ 2595,
+ 2596,
+ 2597,
+ 2598,
+ 2599,
+ 2600,
+ 2601,
+ 2602,
+ 2603,
+ 2604,
+ 2605,
+ 2606,
+ 2607,
+ 2608,
+ 2609,
+ 2610,
+ 2611,
+ 2612,
+ 2613,
+ 2614,
+ 2615,
+ 2616,
+ 2617,
+ 2618,
+ 2619,
+ 2620,
+ 2621,
+ 2622,
+ 2623,
+ 2624,
+ 2625,
+ 2626,
+ 2627,
+ 2628,
+ 2629,
+ 2630,
+ 2631,
+ 2632,
+ 2633,
+ 2634,
+ 2635,
+ 2636,
+ 2637,
+ 2638,
+ 2639,
+ 2640,
+ 2641,
+ 2642,
+ 2643,
+ 2644,
+ 2645,
+ 2646,
+ 2647,
+ 2648,
+ 2649,
+ 2650,
+ 2651,
+ 2652,
+ 2653,
+ 2654,
+ 2655,
+ 2656,
+ 2657,
+ 2658,
+ 2659,
+ 2660,
+ 2661,
+ 2662,
+ 2663,
+ 2664,
+ 2665,
+ 2666,
+ 2667,
+ 2668,
+ 2669,
+ 2670,
+ 2671,
+ 2672,
+ 2673,
+ 2674,
+ 2675,
+ 2676,
+ 2677,
+ 2678,
+ 2679,
+ 2680,
+ 2681,
+ 2682,
+ 2683,
+ 2684,
+ 2685,
+ 2686,
+ 2687,
+ 2688,
+ 2689,
+ 2690,
+ 2691,
+ 2692,
+ 2693,
+ 2694,
+ 2695,
+ 2696,
+ 2697,
+ 2698,
+ 2699,
+ 2700,
+ 2701,
+ 2702,
+ 2703,
+ 2704,
+ 2705,
+ 2706,
+ 2707,
+ 2708,
+ 2709,
+ 2710,
+ 2711,
+ 2712,
+ 2713,
+ 2714,
+ 2715,
+ 2716,
+ 2717,
+ 2718,
+ 2719,
+ 2720,
+ 2721,
+ 2722,
+ 2723,
+ 2724,
+ 2725,
+ 2726,
+ 2727,
+ 2728,
+ 2729,
+ 2730,
+ 2731,
+ 2732,
+ 2733,
+ 2734,
+ 2735,
+ 2736,
+ 2737,
+ 2738,
+ 2739,
+ 2740,
+ 2741,
+ 2742,
+ 2743,
+ 2744,
+ 2745,
+ 2746,
+ 2747,
+ 2748,
+ 2749,
+ 2750,
+ 2751,
+ 2752,
+ 2753,
+ 2754,
+ 2755,
+ 2756,
+ 2757,
+ 2758,
+ 2759,
+ 2760,
+ 2761,
+ 2762,
+ 2763,
+ 2764,
+ 2765,
+ 2766,
+ 2767,
+ 2768,
+ 2769,
+ 2770,
+ 2771,
+ 2772,
+ 2773,
+ 2774,
+ 2775,
+ 2776,
+ 2777,
+ 2778,
+ 2779,
+ 2780,
+ 2781,
+ 2782,
+ 2783,
+ 2784,
+ 2785,
+ 2786,
+ 2787,
+ 2788,
+ 2789,
+ 2790,
+ 2791,
+ 2792,
+ 2793,
+ 2794,
+ 2795,
+ 2796,
+ 2797,
+ 2798,
+ 2799,
+ 2800,
+ 2801,
+ 2802,
+ 2803,
+ 2804,
+ 2805,
+ 2806,
+ 2807,
+ 2808,
+ 2809,
+ 2810,
+ 2811,
+ 2812,
+ 2813,
+ 2814,
+ 2815,
+ 2816,
+ 2817,
+ 2818,
+ 2819,
+ 2820,
+ 2821,
+ 2822,
+ 2823,
+ 2824,
+ 2825,
+ 2826,
+ 2827,
+ 2828,
+ 2829,
+ 2830,
+ 2831,
+ 2832,
+ 2833,
+ 2834,
+ 2835,
+ 2836,
+ 2837,
+ 2838,
+ 2839,
+ 2840,
+ 2841,
+ 2842,
+ 2843,
+ 2844,
+ 2845,
+ 2846,
+ 2847,
+ 2848,
+ 2849,
+ 2850,
+ 2851,
+ 2852,
+ 2853,
+ 2854,
+ 2855,
+ 2856,
+ 2857,
+ 2858,
+ 2859,
+ 2860,
+ 2861,
+ 2862,
+ 2863,
+ 2864,
+ 2865,
+ 2866,
+ 2867,
+ 2868,
+ 2869,
+ 2870,
+ 2871,
+ 2872,
+ 2873,
+ 2874,
+ 2875,
+ 2876,
+ 2877,
+ 2878,
+ 2879,
+ 2880,
+ 2881,
+ 2882,
+ 2883,
+ 2884,
+ 2885,
+ 2886,
+ 2887,
+ 2888,
+ 2889,
+ 2890,
+ 2891,
+ 2892,
+ 2893,
+ 2894,
+ 2895,
+ 2896,
+ 2897,
+ 2898,
+ 2899,
+ 2900,
+ 2901,
+ 2902,
+ 2903,
+ 2904,
+ 2905,
+ 2906,
+ 2907,
+ 2908,
+ 2909,
+ 2910,
+ 2911,
+ 2912,
+ 2913,
+ 2914,
+ 2915,
+ 2916,
+ 2917,
+ 2918,
+ 2919,
+ 2920,
+ 2921,
+ 2922,
+ 2923,
+ 2924,
+ 2925,
+ 2926,
+ 2927,
+ 2928,
+ 2929,
+ 2930,
+ 2931,
+ 2932,
+ 2933,
+ 2934,
+ 2935,
+ 2936,
+ 2937,
+ 2938,
+ 2939,
+ 2940,
+ 2941,
+ 2942,
+ 2943,
+ 2944,
+ 2945,
+ 2946,
+ 2947,
+ 2948,
+ 2949,
+ 2950,
+ 2951,
+ 2952,
+ 2953,
+ 2954,
+ 2955,
+ 2956,
+ 2957,
+ 2958,
+ 2959,
+ 2960,
+ 2961,
+ 2962,
+ 2963,
+ 2964,
+ 2965,
+ 2966,
+ 2967,
+ 2968,
+ 2969,
+ 2970,
+ 2971,
+ 2972,
+ 2973,
+ 2974,
+ 2975,
+ 2976,
+ 2977,
+ 2978,
+ 2979,
+ 2980,
+ 2981,
+ 2982,
+ 2983,
+ 2984,
+ 2985,
+ 2986,
+ 2987,
+ 2988,
+ 2989,
+ 2990,
+ 2991,
+ 2992,
+ 2993,
+ 2994,
+ 2995,
+ 2996,
+ 2997,
+ 2998,
+ 2999,
+ 3000,
+ 3001,
+ 3002,
+ 3003,
+ 3004,
+ 3005,
+ 3006,
+ 3007,
+ 3008,
+ 3009,
+ 3010,
+ 3011,
+ 3012,
+ 3013,
+ 3014,
+ 3015,
+ 3016,
+ 3017,
+ 3018,
+ 3019,
+ 3020,
+ 3021,
+ 3022,
+ 3023,
+ 3024,
+ 3025,
+ 3026,
+ 3027,
+ 3028,
+ 3029,
+ 3030,
+ 3031,
+ 3032,
+ 3033,
+ 3034,
+ 3035,
+ 3036,
+ 3037,
+ 3038,
+ 3039,
+ 3040,
+ 3041,
+ 3042,
+ 3043,
+ 3044,
+ 3045,
+ 3046,
+ 3047,
+ 3048,
+ 3049,
+ 3050,
+ 3051,
+ 3052,
+ 3053,
+ 3054,
+ 3055,
+ 3056,
+ 3057,
+ 3058,
+ 3059,
+ 3060,
+ 3061,
+ 3062,
+ 3063,
+ 3064,
+ 3065,
+ 3066,
+ 3067,
+ 3068,
+ 3069,
+ 3070,
+ 3071,
+ 3072,
+ 3073,
+ 3074,
+ 3075,
+ 3076,
+ 3077,
+ 3078,
+ 3079,
+ 3080,
+ 3081,
+ 3082,
+ 3083,
+ 3084,
+ 3085,
+ 3086,
+ 3087,
+ 3088,
+ 3089,
+ 3090,
+ 3091,
+ 3092,
+ 3093,
+ 3094,
+ 3095,
+ 3096,
+ 3097,
+ 3098,
+ 3099,
+ 3100,
+ 3101,
+ 3102,
+ 3103,
+ 3104,
+ 3105,
+ 3106,
+ 3107,
+ 3108,
+ 3109,
+ 3110,
+ 3111,
+ 3112,
+ 3113,
+ 3114,
+ 3115,
+ 3116,
+ 3117,
+ 3118,
+ 3119,
+ 3120,
+ 3121,
+ 3122,
+ 3123,
+ 3124,
+ 3125,
+ 3126,
+ 3127,
+ 3128,
+ 3129,
+ 3130,
+ 3131,
+ 3132,
+ 3133,
+ 3134,
+ 3135,
+ 3136,
+ 3137,
+ 3138,
+ 3139,
+ 3140,
+ 3141,
+ 3142,
+ 3143,
+ 3144,
+ 3145,
+ 3146,
+ 3147,
+ 3148,
+ 3149,
+ 3150,
+ 3151,
+ 3152,
+ 3153,
+ 3154,
+ 3155,
+ 3156,
+ 3157,
+ 3158,
+ 3159,
+ 3160,
+ 3161,
+ 3162,
+ 3163,
+ 3164,
+ 3165,
+ 3166,
+ 3167,
+ 3168,
+ 3169,
+ 3170,
+ 3171,
+ 3172,
+ 3173,
+ 3174,
+ 3175,
+ 3176,
+ 3177,
+ 3178,
+ 3179,
+ 3180,
+ 3181,
+ 3182,
+ 3183,
+ 3184,
+ 3185,
+ 3186,
+ 3187,
+ 3188,
+ 3189,
+ 3190,
+ 3191,
+ 3192,
+ 3193,
+ 3194,
+ 3195,
+ 3196,
+ 3197,
+ 3198,
+ 3199,
+ 3200,
+ 3201,
+ 3202,
+ 3203,
+ 3204,
+ 3205,
+ 3206,
+ 3207,
+ 3208,
+ 3209,
+ 3210,
+ 3211,
+ 3212,
+ 3213,
+ 3214,
+ 3215,
+ 3216,
+ 3217,
+ 3218,
+ 3219,
+ 3220,
+ 3221,
+ 3222,
+ 3223,
+ 3224,
+ 3225,
+ 3226,
+ 3227,
+ 3228,
+ 3229,
+ 3230,
+ 3231,
+ 3232,
+ 3233,
+ 3234,
+ 3235,
+ 3236,
+ 3237,
+ 3238,
+ 3239,
+ 3240,
+ 3241,
+ 3242,
+ 3243,
+ 3244,
+ 3245,
+ 3246,
+ 3247,
+ 3248,
+ 3249,
+ 3250,
+ 3251,
+ 3252,
+ 3253,
+ 3254,
+ 3255,
+ 3256,
+ 3257,
+ 3258,
+ 3259,
+ 3260,
+ 3261,
+ 3262,
+ 3263,
+ 3264,
+ 3265,
+ 3266,
+ 3267,
+ 3268,
+ 3269,
+ 3270,
+ 3271,
+ 3272,
+ 3273,
+ 3274,
+ 3275,
+ 3276,
+ 3277,
+ 3278,
+ 3279,
+ 3280,
+ 3281,
+ 3282,
+ 3283,
+ 3284,
+ 3285,
+ 3286,
+ 3287,
+ 3288,
+ 3289,
+ 3290,
+ 3291,
+ 3292,
+ 3293,
+ 3294,
+ 3295,
+ 3296,
+ 3297,
+ 3298,
+ 3299,
+ 3300,
+ 3301,
+ 3302,
+ 3303,
+ 3304,
+ 3305,
+ 3306,
+ 3307,
+ 3308,
+ 3309,
+ 3310,
+ 3311,
+ 3312,
+ 3313,
+ 3314,
+ 3315,
+ 3316,
+ 3317,
+ 3318,
+ 3319,
+ 3320,
+ 3321,
+ 3322,
+ 3323,
+ 3324,
+ 3325,
+ 3326,
+ 3327,
+ 3328,
+ 3329,
+ 3330,
+ 3331,
+ 3332,
+ 3333,
+ 3334,
+ 3335,
+ 3336,
+ 3337,
+ 3338,
+ 3339,
+ 3340,
+ 3341,
+ 3342,
+ 3343,
+ 3344,
+ 3345,
+ 3346,
+ 3347,
+ 3348,
+ 3349,
+ 3350,
+ 3351,
+ 3352,
+ 3353,
+ 3354,
+ 3355,
+ 3356,
+ 3357,
+ 3358,
+ 3359,
+ 3360,
+ 3361,
+ 3362,
+ 3363,
+ 3364,
+ 3365,
+ 3366,
+ 3367,
+ 3368,
+ 3369,
+ 3370,
+ 3371,
+ 3372,
+ 3373,
+ 3374,
+ 3375,
+ 3376,
+ 3377,
+ 3378,
+ 3379,
+ 3380,
+ 3381,
+ 3382,
+ 3383,
+ 3384,
+ 3385,
+ 3386,
+ 3387,
+ 3388,
+ 3389,
+ 3390,
+ 3391,
+ 3392,
+ 3393,
+ 3394,
+ 3395,
+ 3396,
+ 3397,
+ 3398,
+ 3399,
+ 3400,
+ 3401,
+ 3402,
+ 3403,
+ 3404,
+ 3405,
+ 3406,
+ 3407,
+ 3408,
+ 3409,
+ 3410,
+ 3411,
+ 3412,
+ 3413,
+ 3414,
+ 3415,
+ 3416,
+ 3417,
+ 3418,
+ 3419,
+ 3420,
+ 3421,
+ 3422,
+ 3423,
+ 3424,
+ 3425,
+ 3426,
+ 3427,
+ 3428,
+ 3429,
+ 3430,
+ 3431,
+ 3432,
+ 3433,
+ 3434,
+ 3435,
+ 3436,
+ 3437,
+ 3438,
+ 3439,
+ 3440,
+ 3441,
+ 3442,
+ 3443,
+ 3444,
+ 3445,
+ 3446,
+ 3447,
+ 3448,
+ 3449,
+ 3450,
+ 3451,
+ 3452,
+ 3453,
+ 3454,
+ 3455,
+ 3456,
+ 3457,
+ 3458,
+ 3459,
+ 3460,
+ 3461,
+ 3462,
+ 3463,
+ 3464,
+ 3465,
+ 3466,
+ 3467,
+ 3468,
+ 3469,
+ 3470,
+ 3471,
+ 3472,
+ 3473,
+ 3474,
+ 3475,
+ 3476,
+ 3477,
+ 3478,
+ 3479,
+ 3480,
+ 3481,
+ 3482,
+ 3483,
+ 3484,
+ 3485,
+ 3486,
+ 3487,
+ 3488,
+ 3489,
+ 3490,
+ 3491,
+ 3492,
+ 3493,
+ 3494,
+ 3495,
+ 3496,
+ 3497,
+ 3498,
+ 3499,
+ 3500,
+ 3501,
+ 3502,
+ 3503,
+ 3504,
+ 3505,
+ 3506,
+ 3507,
+ 3508,
+ 3509,
+ 3510,
+ 3511,
+ 3512,
+ 3513,
+ 3514,
+ 3515,
+ 3516,
+ 3517,
+ 3518,
+ 3519,
+ 3520,
+ 3521,
+ 3522,
+ 3523,
+ 3524,
+ 3525,
+ 3526,
+ 3527,
+ 3528,
+ 3529,
+ 3530,
+ 3531,
+ 3532,
+ 3533,
+ 3534,
+ 3535,
+ 3536,
+ 3537,
+ 3538,
+ 3539,
+ 3540,
+ 3541,
+ 3542,
+ 3543,
+ 3544,
+ 3545,
+ 3546,
+ 3547,
+ 3548,
+ 3549,
+ 3550,
+ 3551,
+ 3552,
+ 3553,
+ 3554,
+ 3555,
+ 3556,
+ 3557,
+ 3558,
+ 3559,
+ 3560,
+ 3561,
+ 3562,
+ 3563,
+ 3564,
+ 3565,
+ 3566,
+ 3567,
+ 3568,
+ 3569,
+ 3570,
+ 3571,
+ 3572,
+ 3573,
+ 3574,
+ 3575,
+ 3576,
+ 3577,
+ 3578,
+ 3579,
+ 3580,
+ 3581,
+ 3582,
+ 3583,
+ 3584,
+ 3585,
+ 3586,
+ 3587,
+ 3588,
+ 3589,
+ 3590,
+ 3591,
+ 3592,
+ 3593,
+ 3594,
+ 3595,
+ 3596,
+ 3597,
+ 3598,
+ 3599,
+ 3600,
+ 3601,
+ 3602,
+ 3603,
+ 3604,
+ 3605,
+ 3606,
+ 3607,
+ 3608,
+ 3609,
+ 3610,
+ 3611,
+ 3612,
+ 3613,
+ 3614,
+ 3615,
+ 3616,
+ 3617,
+ 3618,
+ 3619,
+ 3620,
+ 3621,
+ 3622,
+ 3623,
+ 3624,
+ 3625,
+ 3626,
+ 3627,
+ 3628,
+ 3629,
+ 3630,
+ 3631,
+ 3632,
+ 3633,
+ 3634,
+ 3635,
+ 3636,
+ 3637,
+ 3638,
+ 3639,
+ 3640,
+ 3641,
+ 3642,
+ 3643,
+ 3644,
+ 3645,
+ 3646,
+ 3647,
+ 3648,
+ 3649,
+ 3650,
+ 3651,
+ 3652,
+ 3653,
+ 3654,
+ 3655,
+ 3656,
+ 3657,
+ 3658,
+ 3659,
+ 3660,
+ 3661,
+ 3662,
+ 3663,
+ 3664,
+ 3665,
+ 3666,
+ 3667,
+ 3668,
+ 3669,
+ 3670,
+ 3671,
+ 3672,
+ 3673,
+ 3674,
+ 3675,
+ 3676,
+ 3677,
+ 3678,
+ 3679,
+ 3680,
+ 3681,
+ 3682,
+ 3683,
+ 3684,
+ 3685,
+ 3686,
+ 3687,
+ 3688,
+ 3689,
+ 3690,
+ 3691,
+ 3692,
+ 3693,
+ 3694,
+ 3695,
+ 3696,
+ 3697,
+ 3698,
+ 3699,
+ 3700,
+ 3701,
+ 3702,
+ 3703,
+ 3704,
+ 3705,
+ 3706,
+ 3707,
+ 3708,
+ 3709,
+ 3710,
+ 3711,
+ 3712,
+ 3713,
+ 3714,
+ 3715,
+ 3716,
+ 3717,
+ 3718,
+ 3719,
+ 3720,
+ 3721,
+ 3722,
+ 3723,
+ 3724,
+ 3725,
+ 3726,
+ 3727,
+ 3728,
+ 3729,
+ 3730,
+ 3731,
+ 3732,
+ 3733,
+ 3734,
+ 3735,
+ 3736,
+ 3737,
+ 3738,
+ 3739,
+ 3740,
+ 3741,
+ 3742,
+ 3743,
+ 3744,
+ 3745,
+ 3746,
+ 3747,
+ 3748,
+ 3749,
+ 3750,
+ 3751,
+ 3752,
+ 3753,
+ 3754,
+ 3755,
+ 3756,
+ 3757,
+ 3758,
+ 3759,
+ 3760,
+ 3761,
+ 3762,
+ 3763,
+ 3764,
+ 3765,
+ 3766,
+ 3767,
+ 3768,
+ 3769,
+ 3770,
+ 3771,
+ 3772,
+ 3773,
+ 3774,
+ 3775,
+ 3776,
+ 3777,
+ 3778,
+ 3779,
+ 3780,
+ 3781,
+ 3782,
+ 3783,
+ 3784,
+ 3785,
+ 3786,
+ 3787,
+ 3788,
+ 3789,
+ 3790,
+ 3791,
+ 3792,
+ 3793,
+ 3794,
+ 3795,
+ 3796,
+ 3797,
+ 3798,
+ 3799,
+ 3800,
+ 3801,
+ 3802,
+ 3803,
+ 3804,
+ 3805,
+ 3806,
+ 3807,
+ 3808,
+ 3809,
+ 3810,
+ 3811,
+ 3812,
+ 3813,
+ 3814,
+ 3815,
+ 3816,
+ 3817,
+ 3818,
+ 3819,
+ 3820,
+ 3821,
+ 3822,
+ 3823,
+ 3824,
+ 3825,
+ 3826,
+ 3827,
+ 3828,
+ 3829,
+ 3830,
+ 3831,
+ 3832,
+ 3833,
+ 3834,
+ 3835,
+ 3836,
+ 3837,
+ 3838,
+ 3839,
+ 3840,
+ 3841,
+ 3842,
+ 3843,
+ 3844,
+ 3845,
+ 3846,
+ 3847,
+ 3848,
+ 3849,
+ 3850,
+ 3851,
+ 3852,
+ 3853,
+ 3854,
+ 3855,
+ 3856,
+ 3857,
+ 3858,
+ 3859,
+ 3860,
+ 3861,
+ 3862,
+ 3863,
+ 3864,
+ 3865,
+ 3866,
+ 3867,
+ 3868,
+ 3869,
+ 3870,
+ 3871,
+ 3872,
+ 3873,
+ 3874,
+ 3875,
+ 3876,
+ 3877,
+ 3878,
+ 3879,
+ 3880,
+ 3881,
+ 3882,
+ 3883,
+ 3884,
+ 3885,
+ 3886,
+ 3887,
+ 3888,
+ 3889,
+ 3890,
+ 3891,
+ 3892,
+ 3893,
+ 3894,
+ 3895,
+ 3896,
+ 3897,
+ 3898,
+ 3899,
+ 3900,
+ 3901,
+ 3902,
+ 3903,
+ 3904,
+ 3905,
+ 3906,
+ 3907,
+ 3908,
+ 3909,
+ 3910,
+ 3911,
+ 3912,
+ 3913,
+ 3914,
+ 3915,
+ 3916,
+ 3917,
+ 3918,
+ 3919,
+ 3920,
+ 3921,
+ 3922,
+ 3923,
+ 3924,
+ 3925,
+ 3926,
+ 3927,
+ 3928,
+ 3929,
+ 3930,
+ 3931,
+ 3932,
+ 3933,
+ 3934,
+ 3935,
+ 3936,
+ 3937,
+ 3938,
+ 3939,
+ 3940,
+ 3941,
+ 3942,
+ 3943,
+ 3944,
+ 3945,
+ 3946,
+ 3947,
+ 3948,
+ 3949,
+ 3950,
+ 3951,
+ 3952,
+ 3953,
+ 3954,
+ 3955,
+ 3956,
+ 3957,
+ 3958,
+ 3959,
+ 3960,
+ 3961,
+ 3962,
+ 3963,
+ 3964,
+ 3965,
+ 3966,
+ 3967,
+ 3968,
+ 3969,
+ 3970,
+ 3971,
+ 3972,
+ 3973,
+ 3974,
+ 3975,
+ 3976,
+ 3977,
+ 3978,
+ 3979,
+ 3980,
+ 3981,
+ 3982,
+ 3983,
+ 3984,
+ 3985,
+ 3986,
+ 3987,
+ 3988,
+ 3989,
+ 3990,
+ 3991,
+ 3992,
+ 3993,
+ 3994,
+ 3995,
+ 3996,
+ 3997,
+ 3998,
+ 3999,
+ 4000,
+ 4001,
+ 4002,
+ 4003,
+ 4004,
+ 4005,
+ 4006,
+ 4007,
+ 4008,
+ 4009,
+ 4010,
+ 4011,
+ 4012,
+ 4013,
+ 4014,
+ 4015,
+ 4016,
+ 4017,
+ 4018,
+ 4019,
+ 4020,
+ 4021,
+ 4022,
+ 4023,
+ 4024,
+ 4025,
+ 4026,
+ 4027,
+ 4028,
+ 4029,
+ 4030,
+ 4031,
+ 4032,
+ 4033,
+ 4034,
+ 4035,
+ 4036,
+ 4037,
+ 4038,
+ 4039,
+ 4040,
+ 4041,
+ 4042,
+ 4043,
+ 4044,
+ 4045,
+ 4046,
+ 4047,
+ 4048,
+ 4049,
+ 4050,
+ 4051,
+ 4052,
+ 4053,
+ 4054,
+ 4055,
+ 4056,
+ 4057,
+ 4058,
+ 4059,
+ 4060,
+ 4061,
+ 4062,
+ 4063,
+ 4064,
+ 4065,
+ 4066,
+ 4067,
+ 4068,
+ 4069,
+ 4070,
+ 4071,
+ 4072,
+ 4073,
+ 4074,
+ 4075,
+ 4076,
+ 4077,
+ 4078,
+ 4079,
+ 4080,
+ 4081,
+ 4082,
+ 4083,
+ 4084,
+ 4085,
+ 4086,
+ 4087,
+ 4088,
+ 4089,
+ 4090,
+ 4091,
+ 4092,
+ 4093,
+ 4094,
+ 4095,
+ 4096,
+ 4097,
+ 4098,
+ 4099,
+ 4100,
+ 4101,
+ 4102,
+ 4103,
+ 4104,
+ 4105,
+ 4106,
+ 4107,
+ 4108,
+ 4109,
+ 4110,
+ 4111,
+ 4112,
+ 4113,
+ 4114,
+ 4115,
+ 4116,
+ 4117,
+ 4118,
+ 4119,
+ 4120,
+ 4121,
+ 4122,
+ 4123,
+ 4124,
+ 4125,
+ 4126,
+ 4127,
+ 4128,
+ 4129,
+ 4130,
+ 4131,
+ 4132,
+ 4133,
+ 4134,
+ 4135,
+ 4136,
+ 4137,
+ 4138,
+ 4139,
+ 4140,
+ 4141,
+ 4142,
+ 4143,
+ 4144,
+ 4145,
+ 4146,
+ 4147,
+ 4148,
+ 4149,
+ 4150,
+ 4151,
+ 4152,
+ 4153,
+ 4154,
+ 4155,
+ 4156,
+ 4157,
+ 4158,
+ 4159,
+ 4160,
+ 4161,
+ 4162,
+ 4163,
+ 4164,
+ 4165,
+ 4166,
+ 4167,
+ 4168,
+ 4169,
+ 4170,
+ 4171,
+ 4172,
+ 4173,
+ 4174,
+ 4175,
+ 4176,
+ 4177,
+ 4178,
+ 4179,
+ 4180,
+ 4181,
+ 4182,
+ 4183,
+ 4184,
+ 4185,
+ 4186,
+ 4187,
+ 4188,
+ 4189,
+ 4190,
+ 4191,
+ 4192,
+ 4193,
+ 4194,
+ 4195,
+ 4196,
+ 4197,
+ 4198,
+ 4199,
+ 4200,
+ 4201,
+ 4202,
+ 4203,
+ 4204,
+ 4205,
+ 4206,
+ 4207,
+ 4208,
+ 4209,
+ 4210,
+ 4211,
+ 4212,
+ 4213,
+ 4214,
+ 4215,
+ 4216,
+ 4217,
+ 4218,
+ 4219,
+ 4220,
+ 4221,
+ 4222,
+ 4223,
+ 4224,
+ 4225,
+ 4226,
+ 4227,
+ 4228,
+ 4229,
+ 4230,
+ 4231,
+ 4232,
+ 4233,
+ 4234,
+ 4235,
+ 4236,
+ 4237,
+ 4238,
+ 4239,
+ 4240,
+ 4241,
+ 4242,
+ 4243,
+ 4244,
+ 4245,
+ 4246,
+ 4247,
+ 4248,
+ 4249,
+ 4250,
+ 4251,
+ 4252,
+ 4253,
+ 4254,
+ 4255,
+ 4256,
+ 4257,
+ 4258,
+ 4259,
+ 4260,
+ 4261,
+ 4262,
+ 4263,
+ 4264,
+ 4265,
+ 4266,
+ 4267,
+ 4268,
+ 4269,
+ 4270,
+ 4271,
+ 4272,
+ 4273,
+ 4274,
+ 4275,
+ 4276,
+ 4277,
+ 4278,
+ 4279,
+ 4280,
+ 4281,
+ 4282,
+ 4283,
+ 4284,
+ 4285,
+ 4286,
+ 4287,
+ 4288,
+ 4289,
+ 4290,
+ 4291,
+ 4292,
+ 4293,
+ 4294,
+ 4295,
+ 4296,
+ 4297,
+ 4298,
+ 4299,
+ 4300,
+ 4301,
+ 4302,
+ 4303,
+ 4304,
+ 4305,
+ 4306,
+ 4307,
+ 4308,
+ 4309,
+ 4310,
+ 4311,
+ 4312,
+ 4313,
+ 4314,
+ 4315,
+ 4316,
+ 4317,
+ 4318,
+ 4319,
+ 4320,
+ 4321,
+ 4322,
+ 4323,
+ 4324,
+ 4325,
+ 4326,
+ 4327,
+ 4328,
+ 4329,
+ 4330,
+ 4331,
+ 4332,
+ 4333,
+ 4334,
+ 4335,
+ 4336,
+ 4337,
+ 4338,
+ 4339,
+ 4340,
+ 4341,
+ 4342,
+ 4343,
+ 4344,
+ 4345,
+ 4346,
+ 4347,
+ 4348,
+ 4349,
+ 4350,
+ 4351,
+ 4352,
+ 4353,
+ 4354,
+ 4355,
+ 4356,
+ 4357,
+ 4358,
+ 4359,
+ 4360,
+ 4361,
+ 4362,
+ 4363,
+ 4364,
+ 4365,
+ 4366,
+ 4367,
+ 4368,
+ 4369,
+ 4370,
+ 4371,
+ 4372,
+ 4373,
+ 4374,
+ 4375,
+ 4376,
+ 4377,
+ 4378,
+ 4379,
+ 4380,
+ 4381,
+ 4382,
+ 4383,
+ 4384,
+ 4385,
+ 4386,
+ 4387,
+ 4388,
+ 4389,
+ 4390,
+ 4391,
+ 4392,
+ 4393,
+ 4394,
+ 4395,
+ 4396,
+ 4397,
+ 4398,
+ 4399,
+ 4400,
+ 4401,
+ 4402,
+ 4403,
+ 4404,
+ 4405,
+ 4406,
+ 4407,
+ 4408,
+ 4409,
+ 4410,
+ 4411,
+ 4412,
+ 4413,
+ 4414,
+ 4415,
+ 4416,
+ 4417,
+ 4418,
+ 4419,
+ 4420,
+ 4421,
+ 4422,
+ 4423,
+ 4424,
+ 4425,
+ 4426,
+ 4427,
+ 4428,
+ 4429,
+ 4430,
+ 4431,
+ 4432,
+ 4433,
+ 4434,
+ 4435,
+ 4436,
+ 4437,
+ 4438,
+ 4439,
+ 4440,
+ 4441,
+ 4442,
+ 4443,
+ 4444,
+ 4445,
+ 4446,
+ 4447,
+ 4448,
+ 4449,
+ 4450,
+ 4451,
+ 4452,
+ 4453,
+ 4454,
+ 4455,
+ 4456,
+ 4457,
+ 4458,
+ 4459,
+ 4460,
+ 4461,
+ 4462,
+ 4463,
+ 4464,
+ 4465,
+ 4466,
+ 4467,
+ 4468,
+ 4469,
+ 4470,
+ 4471,
+ 4472,
+ 4473,
+ 4474,
+ 4475,
+ 4476,
+ 4477,
+ 4478,
+ 4479,
+ 4480,
+ 4481,
+ 4482,
+ 4483,
+ 4484,
+ 4485,
+ 4486,
+ 4487,
+ 4488,
+ 4489,
+ 4490,
+ 4491,
+ 4492,
+ 4493,
+ 4494,
+ 4495,
+ 4496,
+ 4497,
+ 4498,
+ 4499,
+ 4500,
+ 4501,
+ 4502,
+ 4503,
+ 4504,
+ 4505,
+ 4506,
+ 4507,
+ 4508,
+ 4509,
+ 4510,
+ 4511,
+ 4512,
+ 4513,
+ 4514,
+ 4515,
+ 4516,
+ 4517,
+ 4518,
+ 4519,
+ 4520,
+ 4521,
+ 4522,
+ 4523,
+ 4524,
+ 4525,
+ 4526,
+ 4527,
+ 4528,
+ 4529,
+ 4530,
+ 4531,
+ 4532,
+ 4533,
+ 4534,
+ 4535,
+ 4536,
+ 4537,
+ 4538,
+ 4539,
+ 4540,
+ 4541,
+ 4542,
+ 4543,
+ 4544,
+ 4545,
+ 4546,
+ 4547,
+ 4548,
+ 4549,
+ 4550,
+ 4551,
+ 4552,
+ 4553,
+ 4554,
+ 4555,
+ 4556,
+ 4557,
+ 4558,
+ 4559,
+ 4560,
+ 4561,
+ 4562,
+ 4563,
+ 4564,
+ 4565,
+ 4566,
+ 4567,
+ 4568,
+ 4569,
+ 4570,
+ 4571,
+ 4572,
+ 4573,
+ 4574,
+ 4575,
+ 4576,
+ 4577,
+ 4578,
+ 4579,
+ 4580,
+ 4581,
+ 4582,
+ 4583,
+ 4584,
+ 4585,
+ 4586,
+ 4587,
+ 4588,
+ 4589,
+ 4590,
+ 4591,
+ 4592,
+ 4593,
+ 4594,
+ 4595,
+ 4596,
+ 4597,
+ 4598,
+ 4599,
+ 4600,
+ 4601,
+ 4602,
+ 4603,
+ 4604,
+ 4605,
+ 4606,
+ 4607,
+ 4608,
+ 4609,
+ 4610,
+ 4611,
+ 4612,
+ 4613,
+ 4614,
+ 4615,
+ 4616,
+ 4617,
+ 4618,
+ 4619,
+ 4620,
+ 4621,
+ 4622,
+ 4623,
+ 4624,
+ 4625,
+ 4626,
+ 4627,
+ 4628,
+ 4629,
+ 4630,
+ 4631,
+ 4632,
+ 4633,
+ 4634,
+ 4635,
+ 4636,
+ 4637,
+ 4638,
+ 4639,
+ 4640,
+ 4641,
+ 4642,
+ 4643,
+ 4644,
+ 4645,
+ 4646,
+ 4647,
+ 4648,
+ 4649,
+ 4650,
+ 4651,
+ 4652,
+ 4653,
+ 4654,
+ 4655,
+ 4656,
+ 4657,
+ 4658,
+ 4659,
+ 4660,
+ 4661,
+ 4662,
+ 4663,
+ 4664,
+ 4665,
+ 4666,
+ 4667,
+ 4668,
+ 4669,
+ 4670,
+ 4671,
+ 4672,
+ 4673,
+ 4674,
+ 4675,
+ 4676,
+ 4677,
+ 4678,
+ 4679,
+ 4680,
+ 4681,
+ 4682,
+ 4683,
+ 4684,
+ 4685,
+ 4686,
+ 4687,
+ 4688,
+ 4689,
+ 4690,
+ 4691,
+ 4692,
+ 4693,
+ 4694,
+ 4695,
+ 4696,
+ 4697,
+ 4698,
+ 4699,
+ 4700,
+ 4701,
+ 4702,
+ 4703,
+ 4704,
+ 4705,
+ 4706,
+ 4707,
+ 4708,
+ 4709,
+ 4710,
+ 4711,
+ 4712,
+ 4713,
+ 4714,
+ 4715,
+ 4716,
+ 4717,
+ 4718,
+ 4719,
+ 4720,
+ 4721,
+ 4722,
+ 4723,
+ 4724,
+ 4725,
+ 4726,
+ 4727,
+ 4728,
+ 4729,
+ 4730,
+ 4731,
+ 4732,
+ 4733,
+ 4734,
+ 4735,
+ 4736,
+ 4737,
+ 4738,
+ 4739,
+ 4740,
+ 4741,
+ 4742,
+ 4743,
+ 4744,
+ 4745,
+ 4746,
+ 4747,
+ 4748,
+ 4749,
+ 4750,
+ 4751,
+ 4752,
+ 4753,
+ 4754,
+ 4755,
+ 4756,
+ 4757,
+ 4758,
+ 4759,
+ 4760,
+ 4761,
+ 4762,
+ 4763,
+ 4764,
+ 4765,
+ 4766,
+ 4767,
+ 4768,
+ 4769,
+ 4770,
+ 4771,
+ 4772,
+ 4773,
+ 4774,
+ 4775,
+ 4776,
+ 4777,
+ 4778,
+ 4779,
+ 4780,
+ 4781,
+ 4782,
+ 4783,
+ 4784,
+ 4785,
+ 4786,
+ 4787,
+ 4788,
+ 4789,
+ 4790,
+ 4791,
+ 4792,
+ 4793,
+ 4794,
+ 4795,
+ 4796,
+ 4797,
+ 4798,
+ 4799,
+ 4800,
+ 4801,
+ 4802,
+ 4803,
+ 4804,
+ 4805,
+ 4806,
+ 4807,
+ 4808,
+ 4809,
+ 4810,
+ 4811,
+ 4812,
+ 4813,
+ 4814,
+ 4815,
+ 4816,
+ 4817,
+ 4818,
+ 4819,
+ 4820,
+ 4821,
+ 4822,
+ 4823,
+ 4824,
+ 4825,
+ 4826,
+ 4827,
+ 4828,
+ 4829,
+ 4830,
+ 4831,
+ 4832,
+ 4833,
+ 4834,
+ 4835,
+ 4836,
+ 4837,
+ 4838,
+ 4839,
+ 4840,
+ 4841,
+ 4842,
+ 4843,
+ 4844,
+ 4845,
+ 4846,
+ 4847,
+ 4848,
+ 4849,
+ 4850,
+ 4851,
+ 4852,
+ 4853,
+ 4854,
+ 4855,
+ 4856,
+ 4857,
+ 4858,
+ 4859,
+ 4860,
+ 4861,
+ 4862,
+ 4863,
+ 4864,
+ 4865,
+ 4866,
+ 4867,
+ 4868,
+ 4869,
+ 4870,
+ 4871,
+ 4872,
+ 4873,
+ 4874,
+ 4875,
+ 4876,
+ 4877,
+ 4878,
+ 4879,
+ 4880,
+ 4881,
+ 4882,
+ 4883,
+ 4884,
+ 4885,
+ 4886,
+ 4887,
+ 4888,
+ 4889,
+ 4890,
+ 4891,
+ 4892,
+ 4893,
+ 4894,
+ 4895,
+ 4896,
+ 4897,
+ 4898,
+ 4899,
+ 4900,
+ 4901,
+ 4902,
+ 4903,
+ 4904,
+ 4905,
+ 4906,
+ 4907,
+ 4908,
+ 4909,
+ 4910,
+ 4911,
+ 4912,
+ 4913,
+ 4914,
+ 4915,
+ 4916,
+ 4917,
+ 4918,
+ 4919,
+ 4920,
+ 4921,
+ 4922,
+ 4923,
+ 4924,
+ 4925,
+ 4926,
+ 4927,
+ 4928,
+ 4929,
+ 4930,
+ 4931,
+ 4932,
+ 4933,
+ 4934,
+ 4935,
+ 4936,
+ 4937,
+ 4938,
+ 4939,
+ 4940,
+ 4941,
+ 4942,
+ 4943,
+ 4944,
+ 4945,
+ 4946,
+ 4947,
+ 4948,
+ 4949,
+ 4950,
+ 4951,
+ 4952,
+ 4953,
+ 4954,
+ 4955,
+ 4956,
+ 4957,
+ 4958,
+ 4959,
+ 4960,
+ 4961,
+ 4962,
+ 4963,
+ 4964,
+ 4965,
+ 4966,
+ 4967,
+ 4968,
+ 4969,
+ 4970,
+ 4971,
+ 4972,
+ 4973,
+ 4974,
+ 4975,
+ 4976,
+ 4977,
+ 4978,
+ 4979,
+ 4980,
+ 4981,
+ 4982,
+ 4983,
+ 4984,
+ 4985,
+ 4986,
+ 4987,
+ 4988,
+ 4989,
+ 4990,
+ 4991,
+ 4992,
+ 4993,
+ 4994,
+ 4995,
+ 4996,
+ 4997,
+ 4998,
+ 4999,
+ 5000,
+ 5001,
+ 5002,
+ 5003,
+ 5004,
+ 5005,
+ 5006,
+ 5007,
+ 5008,
+ 5009,
+ 5010,
+ 5011,
+ 5012,
+ 5013,
+ 5014,
+ 5015,
+ 5016,
+ 5017,
+ 5018,
+ 5019,
+ 5020,
+ 5021,
+ 5022,
+ 5023,
+ 5024,
+ 5025,
+ 5026,
+ 5027,
+ 5028,
+ 5029,
+ 5030,
+ 5031,
+ 5032,
+ 5033,
+ 5034,
+ 5035,
+ 5036,
+ 5037,
+ 5038,
+ 5039,
+ 5040,
+ 5041,
+ 5042,
+ 5043,
+ 5044,
+ 5045,
+ 5046,
+ 5047,
+ 5048,
+ 5049,
+ 5050,
+ 5051,
+ 5052,
+ 5053,
+ 5054,
+ 5055,
+ 5056,
+ 5057,
+ 5058,
+ 5059,
+ 5060,
+ 5061,
+ 5062,
+ 5063,
+ 5064,
+ 5065,
+ 5066,
+ 5067,
+ 5068,
+ 5069,
+ 5070,
+ 5071,
+ 5072,
+ 5073,
+ 5074,
+ 5075,
+ 5076,
+ 5077,
+ 5078,
+ 5079,
+ 5080,
+ 5081,
+ 5082,
+ 5083,
+ 5084,
+ 5085,
+ 5086,
+ 5087,
+ 5088,
+ 5089,
+ 5090,
+ 5091,
+ 5092,
+ 5093,
+ 5094,
+ 5095,
+ 5096,
+ 5097,
+ 5098,
+ 5099,
+ 5100,
+ 5101,
+ 5102,
+ 5103,
+ 5104,
+ 5105,
+ 5106,
+ 5107,
+ 5108,
+ 5109,
+ 5110,
+ 5111,
+ 5112,
+ 5113,
+ 5114,
+ 5115,
+ 5116,
+ 5117,
+ 5118,
+ 5119,
+ 5120,
+ 5121,
+ 5122,
+ 5123,
+ 5124,
+ 5125,
+ 5126,
+ 5127,
+ 5128,
+ 5129,
+ 5130,
+ 5131,
+ 5132,
+ 5133,
+ 5134,
+ 5135,
+ 5136,
+ 5137,
+ 5138,
+ 5139,
+ 5140,
+ 5141,
+ 5142,
+ 5143,
+ 5144,
+ 5145,
+ 5146,
+ 5147,
+ 5148,
+ 5149,
+ 5150,
+ 5151,
+ 5152,
+ 5153,
+ 5154,
+ 5155,
+ 5156,
+ 5157,
+ 5158,
+ 5159,
+ 5160,
+ 5161,
+ 5162,
+ 5163,
+ 5164,
+ 5165,
+ 5166,
+ 5167,
+ 5168,
+ 5169,
+ 5170,
+ 5171,
+ 5172,
+ 5173,
+ 5174,
+ 5175,
+ 5176,
+ 5177,
+ 5178,
+ 5179,
+ 5180,
+ 5181,
+ 5182,
+ 5183,
+ 5184,
+ 5185,
+ 5186,
+ 5187,
+ 5188,
+ 5189,
+ 5190,
+ 5191,
+ 5192,
+ 5193,
+ 5194,
+ 5195,
+ 5196,
+ 5197,
+ 5198,
+ 5199,
+ 5200,
+ 5201,
+ 5202,
+ 5203,
+ 5204,
+ 5205,
+ 5206,
+ 5207,
+ 5208,
+ 5209,
+ 5210,
+ 5211,
+ 5212,
+ 5213,
+ 5214,
+ 5215,
+ 5216,
+ 5217,
+ 5218,
+ 5219,
+ 5220,
+ 5221,
+ 5222,
+ 5223,
+ 5224,
+ 5225,
+ 5226,
+ 5227,
+ 5228,
+ 5229,
+ 5230,
+ 5231,
+ 5232,
+ 5233,
+ 5234,
+ 5235,
+ 5236,
+ 5237,
+ 5238,
+ 5239,
+ 5240,
+ 5241,
+ 5242,
+ 5243,
+ 5244,
+ 5245,
+ 5246,
+ 5247,
+ 5248,
+ 5249,
+ 5250,
+ 5251,
+ 5252,
+ 5253,
+ 5254,
+ 5255,
+ 5256,
+ 5257,
+ 5258,
+ 5259,
+ 5260,
+ 5261,
+ 5262,
+ 5263,
+ 5264,
+ 5265,
+ 5266,
+ 5267,
+ 5268,
+ 5269,
+ 5270,
+ 5271,
+ 5272,
+ 5273,
+ 5274,
+ 5275,
+ 5276,
+ 5277,
+ 5278,
+ 5279,
+ 5280,
+ 5281,
+ 5282,
+ 5283,
+ 5284,
+ 5285,
+ 5286,
+ 5287,
+ 5288,
+ 5289,
+ 5290,
+ 5291,
+ 5292,
+ 5293,
+ 5294,
+ 5295,
+ 5296,
+ 5297,
+ 5298,
+ 5299,
+ 5300,
+ 5301,
+ 5302,
+ 5303,
+ 5304,
+ 5305,
+ 5306,
+ 5307,
+ 5308,
+ 5309,
+ 5310,
+ 5311,
+ 5312,
+ 5313,
+ 5314,
+ 5315,
+ 5316,
+ 5317,
+ 5318,
+ 5319,
+ 5320,
+ 5321,
+ 5322,
+ 5323,
+ 5324,
+ 5325,
+ 5326,
+ 5327,
+ 5328,
+ 5329,
+ 5330,
+ 5331,
+ 5332,
+ 5333,
+ 5334,
+ 5335,
+ 5336,
+ 5337,
+ 5338,
+ 5339,
+ 5340,
+ 5341,
+ 5342,
+ 5343,
+ 5344,
+ 5345,
+ 5346,
+ 5347,
+ 5348,
+ 5349,
+ 5350,
+ 5351,
+ 5352,
+ 5353,
+ 5354,
+ 5355,
+ 5356,
+ 5357,
+ 5358,
+ 5359,
+ 5360,
+ 5361,
+ 5362,
+ 5363,
+ 5364,
+ 5365,
+ 5366,
+ 5367,
+ 5368,
+ 5369,
+ 5370,
+ 5371,
+ 5372,
+ 5373,
+ 5374,
+ 5375,
+ 5376,
+ 5377,
+ 5378,
+ 5379,
+ 5380,
+ 5381,
+ 5382,
+ 5383,
+ 5384,
+ 5385,
+ 5386,
+ 5387,
+ 5388,
+ 5389,
+ 5390,
+ 5391,
+ 5392,
+ 5393,
+ 5394,
+ 5395,
+ 5396,
+ 5397,
+ 5398,
+ 5399,
+ 5400,
+ 5401,
+ 5402,
+ 5403,
+ 5404,
+ 5405,
+ 5406,
+ 5407,
+ 5408,
+ 5409,
+ 5410,
+ 5411,
+ 5412,
+ 5413,
+ 5414,
+ 5415,
+ 5416,
+ 5417,
+ 5418,
+ 5419,
+ 5420,
+ 5421,
+ 5422,
+ 5423,
+ 5424,
+ 5425,
+ 5426,
+ 5427,
+ 5428,
+ 5429,
+ 5430,
+ 5431,
+ 5432,
+ 5433,
+ 5434,
+ 5435,
+ 5436,
+ 5437,
+ 5438,
+ 5439,
+ 5440,
+ 5441,
+ 5442,
+ 5443,
+ 5444,
+ 5445,
+ 5446,
+ 5447,
+ 5448,
+ 5449,
+ 5450,
+ 5451,
+ 5452,
+ 5453,
+ 5454,
+ 5455,
+ 5456,
+ 5457,
+ 5458,
+ 5459,
+ 5460,
+ 5461,
+ 5462,
+ 5463,
+ 5464,
+ 5465,
+ 5466,
+ 5467,
+ 5468,
+ 5469,
+ 5470,
+ 5471,
+ 5472,
+ 5473,
+ 5474,
+ 5475,
+ 5476,
+ 5477,
+ 5478,
+ 5479,
+ 5480,
+ 5481,
+ 5482,
+ 5483,
+ 5484,
+ 5485,
+ 5486,
+ 5487,
+ 5488,
+ 5489,
+ 5490,
+ 5491,
+ 5492,
+ 5493,
+ 5494,
+ 5495,
+ 5496,
+ 5497,
+ 5498,
+ 5499,
+ 5500,
+ 5501,
+ 5502,
+ 5503,
+ 5504,
+ 5505,
+ 5506,
+ 5507,
+ 5508,
+ 5509,
+ 5510,
+ 5511,
+ 5512,
+ 5513,
+ 5514,
+ 5515,
+ 5516,
+ 5517,
+ 5518,
+ 5519,
+ 5520,
+ 5521,
+ 5522,
+ 5523,
+ 5524,
+ 5525,
+ 5526,
+ 5527,
+ 5528,
+ 5529,
+ 5530,
+ 5531,
+ 5532,
+ 5533,
+ 5534,
+ 5535,
+ 5536,
+ 5537,
+ 5538,
+ 5539,
+ 5540,
+ 5541,
+ 5542,
+ 5543,
+ 5544,
+ 5545,
+ 5546,
+ 5547,
+ 5548,
+ 5549,
+ 5550,
+ 5551,
+ 5552,
+ 5553,
+ 5554,
+ 5555,
+ 5556,
+ 5557,
+ 5558,
+ 5559,
+ 5560,
+ 5561,
+ 5562,
+ 5563,
+ 5564,
+ 5565,
+ 5566,
+ 5567,
+ 5568,
+ 5569,
+ 5570,
+ 5571,
+ 5572,
+ 5573,
+ 5574,
+ 5575,
+ 5576,
+ 5577,
+ 5578,
+ 5579,
+ 5580,
+ 5581,
+ 5582,
+ 5583,
+ 5584,
+ 5585,
+ 5586,
+ 5587,
+ 5588,
+ 5589,
+ 5590,
+ 5591,
+ 5592,
+ 5593,
+ 5594,
+ 5595,
+ 5596,
+ 5597,
+ 5598,
+ 5599,
+ 5600,
+ 5601,
+ 5602,
+ 5603,
+ 5604,
+ 5605,
+ 5606,
+ 5607,
+ 5608,
+ 5609,
+ 5610,
+ 5611,
+ 5612,
+ 5613,
+ 5614,
+ 5615,
+ 5616,
+ 5617,
+ 5618,
+ 5619,
+ 5620,
+ 5621,
+ 5622,
+ 5623,
+ 5624,
+ 5625,
+ 5626,
+ 5627,
+ 5628,
+ 5629,
+ 5630,
+ 5631,
+ 5632,
+ 5633,
+ 5634,
+ 5635,
+ 5636,
+ 5637,
+ 5638,
+ 5639,
+ 5640,
+ 5641,
+ 5642,
+ 5643,
+ 5644,
+ 5645,
+ 5646,
+ 5647,
+ 5648,
+ 5649,
+ 5650,
+ 5651,
+ 5652,
+ 5653,
+ 5654,
+ 5655,
+ 5656,
+ 5657,
+ 5658,
+ 5659,
+ 5660,
+ 5661,
+ 5662,
+ 5663,
+ 5664,
+ 5665,
+ 5666,
+ 5667,
+ 5668,
+ 5669,
+ 5670,
+ 5671,
+ 5672,
+ 5673,
+ 5674,
+ 5675,
+ 5676,
+ 5677,
+ 5678,
+ 5679,
+ 5680,
+ 5681,
+ 5682,
+ 5683,
+ 5684,
+ 5685,
+ 5686,
+ 5687,
+ 5688,
+ 5689,
+ 5690,
+ 5691,
+ 5692,
+ 5693,
+ 5694,
+ 5695,
+ 5696,
+ 5697,
+ 5698,
+ 5699,
+ 5700,
+ 5701,
+ 5702,
+ 5703,
+ 5704,
+ 5705,
+ 5706,
+ 5707,
+ 5708,
+ 5709,
+ 5710,
+ 5711,
+ 5712,
+ 5713,
+ 5714,
+ 5715,
+ 5716,
+ 5717,
+ 5718,
+ 5719,
+ 5720,
+ 5721,
+ 5722,
+ 5723,
+ 5724,
+ 5725,
+ 5726,
+ 5727,
+ 5728,
+ 5729,
+ 5730,
+ 5731,
+ 5732,
+ 5733,
+ 5734,
+ 5735,
+ 5736,
+ 5737,
+ 5738,
+ 5739,
+ 5740,
+ 5741,
+ 5742,
+ 5743,
+ 5744,
+ 5745,
+ 5746,
+ 5747,
+ 5748,
+ 5749,
+ 5750,
+ 5751,
+ 5752,
+ 5753,
+ 5754,
+ 5755,
+ 5756,
+ 5757,
+ 5758,
+ 5759,
+ 5760,
+ 5761,
+ 5762,
+ 5763,
+ 5764,
+ 5765,
+ 5766,
+ 5767,
+ 5768,
+ 5769,
+ 5770,
+ 5771,
+ 5772,
+ 5773,
+ 5774,
+ 5775,
+ 5776,
+ 5777,
+ 5778,
+ 5779,
+ 5780,
+ 5781,
+ 5782,
+ 5783,
+ 5784,
+ 5785,
+ 5786,
+ 5787,
+ 5788,
+ 5789,
+ 5790,
+ 5791,
+ 5792,
+ 5793,
+ 5794,
+ 5795,
+ 5796,
+ 5797,
+ 5798,
+ 5799,
+ 5800,
+ 5801,
+ 5802,
+ 5803,
+ 5804,
+ 5805,
+ 5806,
+ 5807,
+ 5808,
+ 5809,
+ 5810,
+ 5811,
+ 5812,
+ 5813,
+ 5814,
+ 5815,
+ 5816,
+ 5817,
+ 5818,
+ 5819,
+ 5820,
+ 5821,
+ 5822,
+ 5823,
+ 5824,
+ 5825,
+ 5826,
+ 5827,
+ 5828,
+ 5829,
+ 5830,
+ 5831,
+ 5832,
+ 5833,
+ 5834,
+ 5835,
+ 5836,
+ 5837,
+ 5838,
+ 5839,
+ 5840,
+ 5841,
+ 5842,
+ 5843,
+ 5844,
+ 5845,
+ 5846,
+ 5847,
+ 5848,
+ 5849,
+ 5850,
+ 5851,
+ 5852,
+ 5853,
+ 5854,
+ 5855,
+ 5856,
+ 5857,
+ 5858,
+ 5859,
+ 5860,
+ 5861,
+ 5862,
+ 5863,
+ 5864,
+ 5865,
+ 5866,
+ 5867,
+ 5868,
+ 5869,
+ 5870,
+ 5871,
+ 5872,
+ 5873,
+ 5874,
+ 5875,
+ 5876,
+ 5877,
+ 5878,
+ 5879,
+ 5880,
+ 5881,
+ 5882,
+ 5883,
+ 5884,
+ 5885,
+ 5886,
+ 5887,
+ 5888,
+ 5889,
+ 5890,
+ 5891,
+ 5892,
+ 5893,
+ 5894,
+ 5895,
+ 5896,
+ 5897,
+ 5898,
+ 5899,
+ 5900,
+ 5901,
+ 5902,
+ 5903,
+ 5904,
+ 5905,
+ 5906,
+ 5907,
+ 5908,
+ 5909,
+ 5910,
+ 5911,
+ 5912,
+ 5913,
+ 5914,
+ 5915,
+ 5916,
+ 5917,
+ 5918,
+ 5919,
+ 5920,
+ 5921,
+ 5922,
+ 5923,
+ 5924,
+ 5925,
+ 5926,
+ 5927,
+ 5928,
+ 5929,
+ 5930,
+ 5931,
+ 5932,
+ 5933,
+ 5934,
+ 5935,
+ 5936,
+ 5937,
+ 5938,
+ 5939,
+ 5940,
+ 5941,
+ 5942,
+ 5943,
+ 5944,
+ 5945,
+ 5946,
+ 5947,
+ 5948,
+ 5949,
+ 5950,
+ 5951,
+ 5952,
+ 5953,
+ 5954,
+ 5955,
+ 5956,
+ 5957,
+ 5958,
+ 5959,
+ 5960,
+ 5961,
+ 5962,
+ 5963,
+ 5964,
+ 5965,
+ 5966,
+ 5967,
+ 5968,
+ 5969,
+ 5970,
+ 5971,
+ 5972,
+ 5973,
+ 5974,
+ 5975,
+ 5976,
+ 5977,
+ 5978,
+ 5979,
+ 5980,
+ 5981,
+ 5982,
+ 5983,
+ 5984,
+ 5985,
+ 5986,
+ 5987,
+ 5988,
+ 5989,
+ 5990,
+ 5991,
+ 5992,
+ 5993,
+ 5994,
+ 5995,
+ 5996,
+ 5997,
+ 5998,
+ 5999,
+ 6000,
+ 6001,
+ 6002,
+ 6003,
+ 6004,
+ 6005,
+ 6006,
+ 6007,
+ 6008,
+ 6009,
+ 6010,
+ 6011,
+ 6012,
+ 6013,
+ 6014,
+ 6015,
+ 6016,
+ 6017,
+ 6018,
+ 6019,
+ 6020,
+ 6021,
+ 6022,
+ 6023,
+ 6024,
+ 6025,
+ 6026,
+ 6027,
+ 6028,
+ 6029,
+ 6030,
+ 6031,
+ 6032,
+ 6033,
+ 6034,
+ 6035,
+ 6036,
+ 6037,
+ 6038,
+ 6039,
+ 6040,
+ 6041,
+ 6042,
+ 6043,
+ 6044,
+ 6045,
+ 6046,
+ 6047,
+ 6048,
+ 6049,
+ 6050,
+ 6051,
+ 6052,
+ 6053,
+ 6054,
+ 6055,
+ 6056,
+ 6057,
+ 6058,
+ 6059,
+ 6060,
+ 6061,
+ 6062,
+ 6063,
+ 6064,
+ 6065,
+ 6066,
+ 6067,
+ 6068,
+ 6069,
+ 6070,
+ 6071,
+ 6072,
+ 6073,
+ 6074,
+ 6075,
+ 6076,
+ 6077,
+ 6078,
+ 6079,
+ 6080,
+ 6081,
+ 6082,
+ 6083,
+ 6084,
+ 6085,
+ 6086,
+ 6087,
+ 6088,
+ 6089,
+ 6090,
+ 6091,
+ 6092,
+ 6093,
+ 6094,
+ 6095,
+ 6096,
+ 6097,
+ 6098,
+ 6099,
+ 6100,
+ 6101,
+ 6102,
+ 6103,
+ 6104,
+ 6105,
+ 6106,
+ 6107,
+ 6108,
+ 6109,
+ 6110,
+ 6111,
+ 6112,
+ 6113,
+ 6114,
+ 6115,
+ 6116,
+ 6117,
+ 6118,
+ 6119,
+ 6120,
+ 6121,
+ 6122,
+ 6123,
+ 6124,
+ 6125,
+ 6126,
+ 6127,
+ 6128,
+ 6129,
+ 6130,
+ 6131,
+ 6132,
+ 6133,
+ 6134,
+ 6135,
+ 6136,
+ 6137,
+ 6138,
+ 6139,
+ 6140,
+ 6141,
+ 6142,
+ 6143,
+ 6144,
+ 6145,
+ 6146,
+ 6147,
+ 6148,
+ 6149,
+ 6150,
+ 6151,
+ 6152,
+ 6153,
+ 6154,
+ 6155,
+ 6156,
+ 6157,
+ 6158,
+ 6159,
+ 6160,
+ 6161,
+ 6162,
+ 6163,
+ 6164,
+ 6165,
+ 6166,
+ 6167,
+ 6168,
+ 6169,
+ 6170,
+ 6171,
+ 6172,
+ 6173,
+ 6174,
+ 6175,
+ 6176,
+ 6177,
+ 6178,
+ 6179,
+ 6180,
+ 6181,
+ 6182,
+ 6183,
+ 6184,
+ 6185,
+ 6186,
+ 6187,
+ 6188,
+ 6189,
+ 6190,
+ 6191,
+ 6192,
+ 6193,
+ 6194,
+ 6195,
+ 6196,
+ 6197,
+ 6198,
+ 6199,
+ 6200,
+ 6201,
+ 6202,
+ 6203,
+ 6204,
+ 6205,
+ 6206,
+ 6207,
+ 6208,
+ 6209,
+ 6210,
+ 6211,
+ 6212,
+ 6213,
+ 6214,
+ 6215,
+ 6216,
+ 6217,
+ 6218,
+ 6219,
+ 6220,
+ 6221,
+ 6222,
+ 6223,
+ 6224,
+ 6225,
+ 6226,
+ 6227,
+ 6228,
+ 6229,
+ 6230,
+ 6231,
+ 6232,
+ 6233,
+ 6234,
+ 6235,
+ 6236,
+ 6237,
+ 6238,
+ 6239,
+ 6240,
+ 6241,
+ 6242,
+ 6243,
+ 6244,
+ 6245,
+ 6246,
+ 6247,
+ 6248,
+ 6249,
+ 6250,
+ 6251,
+ 6252,
+ 6253,
+ 6254,
+ 6255,
+ 6256,
+ 6257,
+ 6258,
+ 6259,
+ 6260,
+ 6261,
+ 6262,
+ 6263,
+ 6264,
+ 6265,
+ 6266,
+ 6267,
+ 6268,
+ 6269,
+ 6270,
+ 6271,
+ 6272,
+ 6273,
+ 6274,
+ 6275,
+ 6276,
+ 6277,
+ 6278,
+ 6279,
+ 6280,
+ 6281,
+ 6282,
+ 6283,
+ 6284,
+ 6285,
+ 6286,
+ 6287,
+ 6288,
+ 6289,
+ 6290,
+ 6291,
+ 6292,
+ 6293,
+ 6294,
+ 6295,
+ 6296,
+ 6297,
+ 6298,
+ 6299,
+ 6300,
+ 6301,
+ 6302,
+ 6303,
+ 6304,
+ 6305,
+ 6306,
+ 6307,
+ 6308,
+ 6309,
+ 6310,
+ 6311,
+ 6312,
+ 6313,
+ 6314,
+ 6315,
+ 6316,
+ 6317,
+ 6318,
+ 6319,
+ 6320,
+ 6321,
+ 6322,
+ 6323,
+ 6324,
+ 6325,
+ 6326,
+ 6327,
+ 6328,
+ 6329,
+ 6330,
+ 6331,
+ 6332,
+ 6333,
+ 6334,
+ 6335,
+ 6336,
+ 6337,
+ 6338,
+ 6339,
+ 6340,
+ 6341,
+ 6342,
+ 6343,
+ 6344,
+ 6345,
+ 6346,
+ 6347,
+ 6348,
+ 6349,
+ 6350,
+ 6351,
+ 6352,
+ 6353,
+ 6354,
+ 6355,
+ 6356,
+ 6357,
+ 6358,
+ 6359,
+ 6360,
+ 6361,
+ 6362,
+ 6363,
+ 6364,
+ 6365,
+ 6366,
+ 6367,
+ 6368,
+ 6369,
+ 6370,
+ 6371,
+ 6372,
+ 6373,
+ 6374,
+ 6375,
+ 6376,
+ 6377,
+ 6378,
+ 6379,
+ 6380,
+ 6381,
+ 6382,
+ 6383,
+ 6384,
+ 6385,
+ 6386,
+ 6387,
+ 6388,
+ 6389,
+ 6390,
+ 6391,
+ 6392,
+ 6393,
+ 6394,
+ 6395,
+ 6396,
+ 6397,
+ 6398,
+ 6399,
+ 6400,
+ 6401,
+ 6402,
+ 6403,
+ 6404,
+ 6405,
+ 6406,
+ 6407,
+ 6408,
+ 6409,
+ 6410,
+ 6411,
+ 6412,
+ 6413,
+ 6414,
+ 6415,
+ 6416,
+ 6417,
+ 6418,
+ 6419,
+ 6420,
+ 6421,
+ 6422,
+ 6423,
+ 6424,
+ 6425,
+ 6426,
+ 6427,
+ 6428,
+ 6429,
+ 6430,
+ 6431,
+ 6432,
+ 6433,
+ 6434,
+ 6435,
+ 6436,
+ 6437,
+ 6438,
+ 6439,
+ 6440,
+ 6441,
+ 6442,
+ 6443,
+ 6444,
+ 6445,
+ 6446,
+ 6447,
+ 6448,
+ 6449,
+ 6450,
+ 6451,
+ 6452,
+ 6453,
+ 6454,
+ 6455,
+ 6456,
+ 6457,
+ 6458,
+ 6459,
+ 6460,
+ 6461,
+ 6462,
+ 6463,
+ 6464,
+ 6465,
+ 6466,
+ 6467,
+ 6468,
+ 6469,
+ 6470,
+ 6471,
+ 6472,
+ 6473,
+ 6474,
+ 6475,
+ 6476,
+ 6477,
+ 6478,
+ 6479,
+ 6480,
+ 6481,
+ 6482,
+ 6483,
+ 6484,
+ 6485,
+ 6486,
+ 6487,
+ 6488,
+ 6489,
+ 6490,
+ 6491,
+ 6492,
+ 6493,
+ 6494,
+ 6495,
+ 6496,
+ 6497,
+ 6498,
+ 6499,
+ 6500,
+ 6501,
+ 6502,
+ 6503,
+ 6504,
+ 6505,
+ 6506,
+ 6507,
+ 6508,
+ 6509,
+ 6510,
+ 6511,
+ 6512,
+ 6513,
+ 6514,
+ 6515,
+ 6516,
+ 6517,
+ 6518,
+ 6519,
+ 6520,
+ 6521,
+ 6522,
+ 6523,
+ 6524,
+ 6525,
+ 6526,
+ 6527,
+ 6528,
+ 6529,
+ 6530,
+ 6531,
+ 6532,
+ 6533,
+ 6534,
+ 6535,
+ 6536,
+ 6537,
+ 6538,
+ 6539,
+ 6540,
+ 6541,
+ 6542,
+ 6543,
+ 6544,
+ 6545,
+ 6546,
+ 6547,
+ 6548,
+ 6549,
+ 6550,
+ 6551,
+ 6552,
+ 6553,
+ 6554,
+ 6555,
+ 6556,
+ 6557,
+ 6558,
+ 6559,
+ 6560,
+ 6561,
+ 6562,
+ 6563,
+ 6564,
+ 6565,
+ 6566,
+ 6567,
+ 6568,
+ 6569,
+ 6570,
+ 6571,
+ 6572,
+ 6573,
+ 6574,
+ 6575,
+ 6576,
+ 6577,
+ 6578,
+ 6579,
+ 6580,
+ 6581,
+ 6582,
+ 6583,
+ 6584,
+ 6585,
+ 6586,
+ 6587,
+ 6588,
+ 6589,
+ 6590,
+ 6591,
+ 6592,
+ 6593,
+ 6594,
+ 6595,
+ 6596,
+ 6597,
+ 6598,
+ 6599,
+ 6600,
+ 6601,
+ 6602,
+ 6603,
+ 6604,
+ 6605,
+ 6606,
+ 6607,
+ 6608,
+ 6609,
+ 6610,
+ 6611,
+ 6612,
+ 6613,
+ 6614,
+ 6615,
+ 6616,
+ 6617,
+ 6618,
+ 6619,
+ 6620,
+ 6621,
+ 6622,
+ 6623,
+ 6624,
+ 6625,
+ 6626,
+ 6627,
+ 6628,
+ 6629,
+ 6630,
+ 6631,
+ 6632,
+ 6633,
+ 6634,
+ 6635,
+ 6636,
+ 6637,
+ 6638,
+ 6639,
+ 6640,
+ 6641,
+ 6642,
+ 6643,
+ 6644,
+ 6645,
+ 6646,
+ 6647,
+ 6648,
+ 6649,
+ 6650,
+ 6651,
+ 6652,
+ 6653,
+ 6654,
+ 6655,
+ 6656,
+ 6657,
+ 6658,
+ 6659,
+ 6660,
+ 6661,
+ 6662,
+ 6663,
+ 6664,
+ 6665,
+ 6666,
+ 6667,
+ 6668,
+ 6669,
+ 6670,
+ 6671,
+ 6672,
+ 6673,
+ 6674,
+ 6675,
+ 6676,
+ 6677,
+ 6678,
+ 6679,
+ 6680,
+ 6681,
+ 6682,
+ 6683,
+ 6684,
+ 6685,
+ 6686,
+ 6687,
+ 6688,
+ 6689,
+ 6690,
+ 6691,
+ 6692,
+ 6693,
+ 6694,
+ 6695,
+ 6696,
+ 6697,
+ 6698,
+ 6699,
+ 6700,
+ 6701,
+ 6702,
+ 6703,
+ 6704,
+ 6705,
+ 6706,
+ 6707,
+ 6708,
+ 6709,
+ 6710,
+ 6711,
+ 6712,
+ 6713,
+ 6714,
+ 6715,
+ 6716,
+ 6717,
+ 6718,
+ 6719,
+ 6720,
+ 6721,
+ 6722,
+ 6723,
+ 6724,
+ 6725,
+ 6726,
+ 6727,
+ 6728,
+ 6729,
+ 6730,
+ 6731,
+ 6732,
+ 6733,
+ 6734,
+ 6735,
+ 6736,
+ 6737,
+ 6738,
+ 6739,
+ 6740,
+ 6741,
+ 6742,
+ 6743,
+ 6744,
+ 6745,
+ 6746,
+ 6747,
+ 6748,
+ 6749,
+ 6750,
+ 6751,
+ 6752,
+ 6753,
+ 6754,
+ 6755,
+ 6756,
+ 6757,
+ 6758,
+ 6759,
+ 6760,
+ 6761,
+ 6762,
+ 6763,
+ 6764,
+ 6765,
+ 6766,
+ 6767,
+ 6768,
+ 6769,
+ 6770,
+ 6771,
+ 6772,
+ 6773,
+ 6774,
+ 6775,
+ 6776,
+ 6777,
+ 6778,
+ 6779,
+ 6780,
+ 6781,
+ 6782,
+ 6783,
+ 6784,
+ 6785,
+ 6786,
+ 6787,
+ 6788,
+ 6789,
+ 6790,
+ 6791,
+ 6792,
+ 6793,
+ 6794,
+ 6795,
+ 6796,
+ 6797,
+ 6798,
+ 6799,
+ 6800,
+ 6801,
+ 6802,
+ 6803,
+ 6804,
+ 6805,
+ 6806,
+ 6807,
+ 6808,
+ 6809,
+ 6810,
+ 6811,
+ 6812,
+ 6813,
+ 6814,
+ 6815,
+ 6816,
+ 6817,
+ 6818,
+ 6819,
+ 6820,
+ 6821,
+ 6822,
+ 6823,
+ 6824,
+ 6825,
+ 6826,
+ 6827,
+ 6828,
+ 6829,
+ 6830,
+ 6831,
+ 6832,
+ 6833,
+ 6834,
+ 6835,
+ 6836,
+ 6837,
+ 6838,
+ 6839,
+ 6840,
+ 6841,
+ 6842,
+ 6843,
+ 6844,
+ 6845,
+ 6846,
+ 6847,
+ 6848,
+ 6849,
+ 6850,
+ 6851,
+ 6852,
+ 6853,
+ 6854,
+ 6855,
+ 6856,
+ 6857,
+ 6858,
+ 6859,
+ 6860,
+ 6861,
+ 6862,
+ 6863,
+ 6864,
+ 6865,
+ 6866,
+ 6867,
+ 6868,
+ 6869,
+ 6870,
+ 6871,
+ 6872,
+ 6873,
+ 6874,
+ 6875,
+ 6876,
+ 6877,
+ 6878,
+ 6879,
+ 6880,
+ 6881,
+ 6882,
+ 6883,
+ 6884,
+ 6885,
+ 6886,
+ 6887,
+ 6888,
+ 6889,
+ 6890,
+ 6891,
+ 6892,
+ 6893,
+ 6894,
+ 6895,
+ 6896,
+ 6897,
+ 6898,
+ 6899,
+ 6900,
+ 6901,
+ 6902,
+ 6903,
+ 6904,
+ 6905,
+ 6906,
+ 6907,
+ 6908,
+ 6909,
+ 6910,
+ 6911,
+ 6912,
+ 6913,
+ 6914,
+ 6915,
+ 6916,
+ 6917,
+ 6918,
+ 6919,
+ 6920,
+ 6921,
+ 6922,
+ 6923,
+ 6924,
+ 6925,
+ 6926,
+ 6927,
+ 6928,
+ 6929,
+ 6930,
+ 6931,
+ 6932,
+ 6933,
+ 6934,
+ 6935,
+ 6936,
+ 6937,
+ 6938,
+ 6939,
+ 6940,
+ 6941,
+ 6942,
+ 6943,
+ 6944,
+ 6945,
+ 6946,
+ 6947,
+ 6948,
+ 6949,
+ 6950,
+ 6951,
+ 6952,
+ 6953,
+ 6954,
+ 6955,
+ 6956,
+ 6957,
+ 6958,
+ 6959,
+ 6960,
+ 6961,
+ 6962,
+ 6963,
+ 6964,
+ 6965,
+ 6966,
+ 6967,
+ 6968,
+ 6969,
+ 6970,
+ 6971,
+ 6972,
+ 6973,
+ 6974,
+ 6975,
+ 6976,
+ 6977,
+ 6978,
+ 6979,
+ 6980,
+ 6981,
+ 6982,
+ 6983,
+ 6984,
+ 6985,
+ 6986,
+ 6987,
+ 6988,
+ 6989,
+ 6990,
+ 6991,
+ 6992,
+ 6993,
+ 6994,
+ 6995,
+ 6996,
+ 6997,
+ 6998,
+ 6999,
+ 7000,
+ 7001,
+ 7002,
+ 7003,
+ 7004,
+ 7005,
+ 7006,
+ 7007,
+ 7008,
+ 7009,
+ 7010,
+ 7011,
+ 7012,
+ 7013,
+ 7014,
+ 7015,
+ 7016,
+ 7017,
+ 7018,
+ 7019,
+ 7020,
+ 7021,
+ 7022,
+ 7023,
+ 7024,
+ 7025,
+ 7026,
+ 7027,
+ 7028,
+ 7029,
+ 7030,
+ 7031,
+ 7032,
+ 7033,
+ 7034,
+ 7035,
+ 7036,
+ 7037,
+ 7038,
+ 7039,
+ 7040,
+ 7041,
+ 7042,
+ 7043,
+ 7044,
+ 7045,
+ 7046,
+ 7047,
+ 7048,
+ 7049,
+ 7050,
+ 7051,
+ 7052,
+ 7053,
+ 7054,
+ 7055,
+ 7056,
+ 7057,
+ 7058,
+ 7059,
+ 7060,
+ 7061,
+ 7062,
+ 7063,
+ 7064,
+ 7065,
+ 7066,
+ 7067,
+ 7068,
+ 7069,
+ 7070,
+ 7071,
+ 7072,
+ 7073,
+ 7074,
+ 7075,
+ 7076,
+ 7077,
+ 7078,
+ 7079,
+ 7080,
+ 7081,
+ 7082,
+ 7083,
+ 7084,
+ 7085,
+ 7086,
+ 7087,
+ 7088,
+ 7089,
+ 7090,
+ 7091,
+ 7092,
+ 7093,
+ 7094,
+ 7095,
+ 7096,
+ 7097,
+ 7098,
+ 7099,
+ 7100,
+ 7101,
+ 7102,
+ 7103,
+ 7104,
+ 7105,
+ 7106,
+ 7107,
+ 7108,
+ 7109,
+ 7110,
+ 7111,
+ 7112,
+ 7113,
+ 7114,
+ 7115,
+ 7116,
+ 7117,
+ 7118,
+ 7119,
+ 7120,
+ 7121,
+ 7122,
+ 7123,
+ 7124,
+ 7125,
+ 7126,
+ 7127,
+ 7128,
+ 7129,
+ 7130,
+ 7131,
+ 7132,
+ 7133,
+ 7134,
+ 7135,
+ 7136,
+ 7137,
+ 7138,
+ 7139,
+ 7140,
+ 7141,
+ 7142,
+ 7143,
+ 7144,
+ 7145,
+ 7146,
+ 7147,
+ 7148,
+ 7149,
+ 7150,
+ 7151,
+ 7152,
+ 7153,
+ 7154,
+ 7155,
+ 7156,
+ 7157,
+ 7158,
+ 7159,
+ 7160,
+ 7161,
+ 7162,
+ 7163,
+ 7164,
+ 7165,
+ 7166,
+ 7167,
+ 7168,
+ 7169,
+ 7170,
+ 7171,
+ 7172,
+ 7173,
+ 7174,
+ 7175,
+ 7176,
+ 7177,
+ 7178,
+ 7179,
+ 7180,
+ 7181,
+ 7182,
+ 7183,
+ 7184,
+ 7185,
+ 7186,
+ 7187,
+ 7188,
+ 7189,
+ 7190,
+ 7191,
+ 7192,
+ 7193,
+ 7194,
+ 7195,
+ 7196,
+ 7197,
+ 7198,
+ 7199,
+ 7200,
+ 7201,
+ 7202,
+ 7203,
+ 7204,
+ 7205,
+ 7206,
+ 7207,
+ 7208,
+ 7209,
+ 7210,
+ 7211,
+ 7212,
+ 7213,
+ 7214,
+ 7215,
+ 7216,
+ 7217,
+ 7218,
+ 7219,
+ 7220,
+ 7221,
+ 7222,
+ 7223,
+ 7224,
+ 7225,
+ 7226,
+ 7227,
+ 7228,
+ 7229,
+ 7230,
+ 7231,
+ 7232,
+ 7233,
+ 7234,
+ 7235,
+ 7236,
+ 7237,
+ 7238,
+ 7239,
+ 7240,
+ 7241,
+ 7242,
+ 7243,
+ 7244,
+ 7245,
+ 7246,
+ 7247,
+ 7248,
+ 7249,
+ 7250,
+ 7251,
+ 7252,
+ 7253,
+ 7254,
+ 7255,
+ 7256,
+ 7257,
+ 7258,
+ 7259,
+ 7260,
+ 7261,
+ 7262,
+ 7263,
+ 7264,
+ 7265,
+ 7266,
+ 7267,
+ 7268,
+ 7269,
+ 7270,
+ 7271,
+ 7272,
+ 7273,
+ 7274,
+ 7275,
+ 7276,
+ 7277,
+ 7278,
+ 7279,
+ 7280,
+ 7281,
+ 7282,
+ 7283,
+ 7284,
+ 7285,
+ 7286,
+ 7287,
+ 7288,
+ 7289,
+ 7290,
+ 7291,
+ 7292,
+ 7293,
+ 7294,
+ 7295,
+ 7296,
+ 7297,
+ 7298,
+ 7299,
+ 7300,
+ 7301,
+ 7302,
+ 7303,
+ 7304,
+ 7305,
+ 7306,
+ 7307,
+ 7308,
+ 7309,
+ 7310,
+ 7311,
+ 7312,
+ 7313,
+ 7314,
+ 7315,
+ 7316,
+ 7317,
+ 7318,
+ 7319,
+ 7320,
+ 7321,
+ 7322,
+ 7323,
+ 7324,
+ 7325,
+ 7326,
+ 7327,
+ 7328,
+ 7329,
+ 7330,
+ 7331,
+ 7332,
+ 7333,
+ 7334,
+ 7335,
+ 7336,
+ 7337,
+ 7338,
+ 7339,
+ 7340,
+ 7341,
+ 7342,
+ 7343,
+ 7344,
+ 7345,
+ 7346,
+ 7347,
+ 7348,
+ 7349,
+ 7350,
+ 7351,
+ 7352,
+ 7353,
+ 7354,
+ 7355,
+ 7356,
+ 7357,
+ 7358,
+ 7359,
+ 7360,
+ 7361,
+ 7362,
+ 7363,
+ 7364,
+ 7365,
+ 7366,
+ 7367,
+ 7368,
+ 7369,
+ 7370,
+ 7371,
+ 7372,
+ 7373,
+ 7374,
+ 7375,
+ 7376,
+ 7377,
+ 7378,
+ 7379,
+ 7380,
+ 7381,
+ 7382,
+ 7383,
+ 7384,
+ 7385,
+ 7386,
+ 7387,
+ 7388,
+ 7389,
+ 7390,
+ 7391,
+ 7392,
+ 7393,
+ 7394,
+ 7395,
+ 7396,
+ 7397,
+ 7398,
+ 7399,
+ 7400,
+ 7401,
+ 7402,
+ 7403,
+ 7404,
+ 7405,
+ 7406,
+ 7407,
+ 7408,
+ 7409,
+ 7410,
+ 7411,
+ 7412,
+ 7413,
+ 7414,
+ 7415,
+ 7416,
+ 7417,
+ 7418,
+ 7419,
+ 7420,
+ 7421,
+ 7422,
+ 7423,
+ 7424,
+ 7425,
+ 7426,
+ 7427,
+ 7428,
+ 7429,
+ 7430,
+ 7431,
+ 7432,
+ 7433,
+ 7434,
+ 7435,
+ 7436,
+ 7437,
+ 7438,
+ 7439,
+ 7440,
+ 7441,
+ 7442,
+ 7443,
+ 7444,
+ 7445,
+ 7446,
+ 7447,
+ 7448,
+ 7449,
+ 7450,
+ 7451,
+ 7452,
+ 7453,
+ 7454,
+ 7455,
+ 7456,
+ 7457,
+ 7458,
+ 7459,
+ 7460,
+ 7461,
+ 7462,
+ 7463,
+ 7464,
+ 7465,
+ 7466,
+ 7467,
+ 7468,
+ 7469,
+ 7470,
+ 7471,
+ 7472,
+ 7473,
+ 7474,
+ 7475,
+ 7476,
+ 7477,
+ 7478,
+ 7479,
+ 7480,
+ 7481,
+ 7482,
+ 7483,
+ 7484,
+ 7485,
+ 7486,
+ 7487,
+ 7488,
+ 7489,
+ 7490,
+ 7491,
+ 7492,
+ 7493,
+ 7494,
+ 7495,
+ 7496,
+ 7497,
+ 7498,
+ 7499,
+ 7500,
+ 7501,
+ 7502,
+ 7503,
+ 7504,
+ 7505,
+ 7506,
+ 7507,
+ 7508,
+ 7509,
+ 7510,
+ 7511,
+ 7512,
+ 7513,
+ 7514,
+ 7515,
+ 7516,
+ 7517,
+ 7518,
+ 7519,
+ 7520,
+ 7521,
+ 7522,
+ 7523,
+ 7524,
+ 7525,
+ 7526,
+ 7527,
+ 7528,
+ 7529,
+ 7530,
+ 7531,
+ 7532,
+ 7533,
+ 7534,
+ 7535,
+ 7536,
+ 7537,
+ 7538,
+ 7539,
+ 7540,
+ 7541,
+ 7542,
+ 7543,
+ 7544,
+ 7545,
+ 7546,
+ 7547,
+ 7548,
+ 7549,
+ 7550,
+ 7551,
+ 7552,
+ 7553,
+ 7554,
+ 7555,
+ 7556,
+ 7557,
+ 7558,
+ 7559,
+ 7560,
+ 7561,
+ 7562,
+ 7563,
+ 7564,
+ 7565,
+ 7566,
+ 7567,
+ 7568,
+ 7569,
+ 7570,
+ 7571,
+ 7572,
+ 7573,
+ 7574,
+ 7575,
+ 7576,
+ 7577,
+ 7578,
+ 7579,
+ 7580,
+ 7581,
+ 7582,
+ 7583,
+ 7584,
+ 7585,
+ 7586,
+ 7587,
+ 7588,
+ 7589,
+ 7590,
+ 7591,
+ 7592,
+ 7593,
+ 7594,
+ 7595,
+ 7596,
+ 7597,
+ 7598,
+ 7599,
+ 7600,
+ 7601,
+ 7602,
+ 7603,
+ 7604,
+ 7605,
+ 7606,
+ 7607,
+ 7608,
+ 7609,
+ 7610,
+ 7611,
+ 7612,
+ 7613,
+ 7614,
+ 7615,
+ 7616,
+ 7617,
+ 7618,
+ 7619,
+ 7620,
+ 7621,
+ 7622,
+ 7623,
+ 7624,
+ 7625,
+ 7626,
+ 7627,
+ 7628,
+ 7629,
+ 7630,
+ 7631,
+ 7632,
+ 7633,
+ 7634,
+ 7635,
+ 7636,
+ 7637,
+ 7638,
+ 7639,
+ 7640,
+ 7641,
+ 7642,
+ 7643,
+ 7644,
+ 7645,
+ 7646,
+ 7647,
+ 7648,
+ 7649,
+ 7650,
+ 7651,
+ 7652,
+ 7653,
+ 7654,
+ 7655,
+ 7656,
+ 7657,
+ 7658,
+ 7659,
+ 7660,
+ 7661,
+ 7662,
+ 7663,
+ 7664,
+ 7665,
+ 7666,
+ 7667,
+ 7668,
+ 7669,
+ 7670,
+ 7671,
+ 7672,
+ 7673,
+ 7674,
+ 7675,
+ 7676,
+ 7677,
+ 7678,
+ 7679,
+ 7680,
+ 7681,
+ 7682,
+ 7683,
+ 7684,
+ 7685,
+ 7686,
+ 7687,
+ 7688,
+ 7689,
+ 7690,
+ 7691,
+ 7692,
+ 7693,
+ 7694,
+ 7695,
+ 7696,
+ 7697,
+ 7698,
+ 7699,
+ 7700,
+ 7701,
+ 7702,
+ 7703,
+ 7704,
+ 7705,
+ 7706,
+ 7707,
+ 7708,
+ 7709,
+ 7710,
+ 7711,
+ 7712,
+ 7713,
+ 7714,
+ 7715,
+ 7716,
+ 7717,
+ 7718,
+ 7719,
+ 7720,
+ 7721,
+ 7722,
+ 7723,
+ 7724,
+ 7725,
+ 7726,
+ 7727,
+ 7728,
+ 7729,
+ 7730,
+ 7731,
+ 7732,
+ 7733,
+ 7734,
+ 7735,
+ 7736,
+ 7737,
+ 7738,
+ 7739,
+ 7740,
+ 7741,
+ 7742,
+ 7743,
+ 7744,
+ 7745,
+ 7746,
+ 7747,
+ 7748,
+ 7749,
+ 7750,
+ 7751,
+ 7752,
+ 7753,
+ 7754,
+ 7755,
+ 7756,
+ 7757,
+ 7758,
+ 7759,
+ 7760,
+ 7761,
+ 7762,
+ 7763,
+ 7764,
+ 7765,
+ 7766,
+ 7767,
+ 7768,
+ 7769,
+ 7770,
+ 7771,
+ 7772,
+ 7773,
+ 7774,
+ 7775,
+ 7776,
+ 7777,
+ 7778,
+ 7779,
+ 7780,
+ 7781,
+ 7782,
+ 7783,
+ 7784,
+ 7785,
+ 7786,
+ 7787,
+ 7788,
+ 7789,
+ 7790,
+ 7791,
+ 7792,
+ 7793,
+ 7794,
+ 7795,
+ 7796,
+ 7797,
+ 7798,
+ 7799,
+ 7800,
+ 7801,
+ 7802,
+ 7803,
+ 7804,
+ 7805,
+ 7806,
+ 7807,
+ 7808,
+ 7809,
+ 7810,
+ 7811,
+ 7812,
+ 7813,
+ 7814,
+ 7815,
+ 7816,
+ 7817,
+ 7818,
+ 7819,
+ 7820,
+ 7821,
+ 7822,
+ 7823,
+ 7824,
+ 7825,
+ 7826,
+ 7827,
+ 7828,
+ 7829,
+ 7830,
+ 7831,
+ 7832,
+ 7833,
+ 7834,
+ 7835,
+ 7836,
+ 7837,
+ 7838,
+ 7839,
+ 7840,
+ 7841,
+ 7842,
+ 7843,
+ 7844,
+ 7845,
+ 7846,
+ 7847,
+ 7848,
+ 7849,
+ 7850,
+ 7851,
+ 7852,
+ 7853,
+ 7854,
+ 7855,
+ 7856,
+ 7857,
+ 7858,
+ 7859,
+ 7860,
+ 7861,
+ 7862,
+ 7863,
+ 7864,
+ 7865,
+ 7866,
+ 7867,
+ 7868,
+ 7869,
+ 7870,
+ 7871,
+ 7872,
+ 7873,
+ 7874,
+ 7875,
+ 7876,
+ 7877,
+ 7878,
+ 7879,
+ 7880,
+ 7881,
+ 7882,
+ 7883,
+ 7884,
+ 7885,
+ 7886,
+ 7887,
+ 7888,
+ 7889,
+ 7890,
+ 7891,
+ 7892,
+ 7893,
+ 7894,
+ 7895,
+ 7896,
+ 7897,
+ 7898,
+ 7899,
+ 7900,
+ 7901,
+ 7902,
+ 7903,
+ 7904,
+ 7905,
+ 7906,
+ 7907,
+ 7908,
+ 7909,
+ 7910,
+ 7911,
+ 7912,
+ 7913,
+ 7914,
+ 7915,
+ 7916,
+ 7917,
+ 7918,
+ 7919,
+ 7920,
+ 7921,
+ 7922,
+ 7923,
+ 7924,
+ 7925,
+ 7926,
+ 7927,
+ 7928,
+ 7929,
+ 7930,
+ 7931,
+ 7932,
+ 7933,
+ 7934,
+ 7935,
+ 7936,
+ 7937,
+ 7938,
+ 7939,
+ 7940,
+ 7941,
+ 7942,
+ 7943,
+ 7944,
+ 7945,
+ 7946,
+ 7947,
+ 7948,
+ 7949,
+ 7950,
+ 7951,
+ 7952,
+ 7953,
+ 7954,
+ 7955,
+ 7956,
+ 7957,
+ 7958,
+ 7959,
+ 7960,
+ 7961,
+ 7962,
+ 7963,
+ 7964,
+ 7965,
+ 7966,
+ 7967,
+ 7968,
+ 7969,
+ 7970,
+ 7971,
+ 7972,
+ 7973,
+ 7974,
+ 7975,
+ 7976,
+ 7977,
+ 7978,
+ 7979,
+ 7980,
+ 7981,
+ 7982,
+ 7983,
+ 7984,
+ 7985,
+ 7986,
+ 7987,
+ 7988,
+ 7989,
+ 7990,
+ 7991,
+ 7992,
+ 7993,
+ 7994,
+ 7995,
+ 7996,
+ 7997,
+ 7998,
+ 7999,
+ 8000,
+ 8001,
+ 8002,
+ 8003,
+ 8004,
+ 8005,
+ 8006,
+ 8007,
+ 8008,
+ 8009,
+ 8010,
+ 8011,
+ 8012,
+ 8013,
+ 8014,
+ 8015,
+ 8016,
+ 8017,
+ 8018,
+ 8019,
+ 8020,
+ 8021,
+ 8022,
+ 8023,
+ 8024,
+ 8025,
+ 8026,
+ 8027,
+ 8028,
+ 8029,
+ 8030,
+ 8031,
+ 8032,
+ 8033,
+ 8034,
+ 8035,
+ 8036,
+ 8037,
+ 8038,
+ 8039,
+ 8040,
+ 8041,
+ 8042,
+ 8043,
+ 8044,
+ 8045,
+ 8046,
+ 8047,
+ 8048,
+ 8049,
+ 8050,
+ 8051,
+ 8052,
+ 8053,
+ 8054,
+ 8055,
+ 8056,
+ 8057,
+ 8058,
+ 8059,
+ 8060,
+ 8061,
+ 8062,
+ 8063,
+ 8064,
+ 8065,
+ 8066,
+ 8067,
+ 8068,
+ 8069,
+ 8070,
+ 8071,
+ 8072,
+ 8073,
+ 8074,
+ 8075,
+ 8076,
+ 8077,
+ 8078,
+ 8079,
+ 8080,
+ 8081,
+ 8082,
+ 8083,
+ 8084,
+ 8085,
+ 8086,
+ 8087,
+ 8088,
+ 8089,
+ 8090,
+ 8091,
+ 8092,
+ 8093,
+ 8094,
+ 8095,
+ 8096,
+ 8097,
+ 8098,
+ 8099,
+ 8100,
+ 8101,
+ 8102,
+ 8103,
+ 8104,
+ 8105,
+ 8106,
+ 8107,
+ 8108,
+ 8109,
+ 8110,
+ 8111,
+ 8112,
+ 8113,
+ 8114,
+ 8115,
+ 8116,
+ 8117,
+ 8118,
+ 8119,
+ 8120,
+ 8121,
+ 8122,
+ 8123,
+ 8124,
+ 8125,
+ 8126,
+ 8127,
+ 8128,
+ 8129,
+ 8130,
+ 8131,
+ 8132,
+ 8133,
+ 8134,
+ 8135,
+ 8136,
+ 8137,
+ 8138,
+ 8139,
+ 8140,
+ 8141,
+ 8142,
+ 8143,
+ 8144,
+ 8145,
+ 8146,
+ 8147,
+ 8148,
+ 8149,
+ 8150,
+ 8151,
+ 8152,
+ 8153,
+ 8154,
+ 8155,
+ 8156,
+ 8157,
+ 8158,
+ 8159,
+ 8160,
+ 8161,
+ 8162,
+ 8163,
+ 8164,
+ 8165,
+ 8166,
+ 8167,
+ 8168,
+ 8169,
+ 8170,
+ 8171,
+ 8172,
+ 8173,
+ 8174,
+ 8175,
+ 8176,
+ 8177,
+ 8178,
+ 8179,
+ 8180,
+ 8181,
+ 8182,
+ 8183,
+ 8184,
+ 8185,
+ 8186,
+ 8187,
+ 8188,
+ 8189,
+ 8190,
+ 8191,
+ 8192,
+ 8193,
+ 8194,
+ 8195,
+ 8196,
+ 8197,
+ 8198,
+ 8199,
+ 8200,
+ 8201,
+ 8202,
+ 8203,
+ 8204,
+ 8205,
+ 8206,
+ 8207,
+ 8208,
+ 8209,
+ 8210,
+ 8211,
+ 8212,
+ 8213,
+ 8214,
+ 8215,
+ 8216,
+ 8217,
+ 8218,
+ 8219,
+ 8220,
+ 8221,
+ 8222,
+ 8223,
+ 8224,
+ 8225,
+ 8226,
+ 8227,
+ 8228,
+ 8229,
+ 8230,
+ 8231,
+ 8232,
+ 8233,
+ 8234,
+ 8235,
+ 8236,
+ 8237,
+ 8238,
+ 8239,
+ 8240,
+ 8241,
+ 8242,
+ 8243,
+ 8244,
+ 8245,
+ 8246,
+ 8247,
+ 8248,
+ 8249,
+ 8250,
+ 8251,
+ 8252,
+ 8253,
+ 8254,
+ 8255,
+ 8256,
+ 8257,
+ 8258,
+ 8259,
+ 8260,
+ 8261,
+ 8262,
+ 8263,
+ 8264,
+ 8265,
+ 8266,
+ 8267,
+ 8268,
+ 8269,
+ 8270,
+ 8271,
+ 8272,
+ 8273,
+ 8274,
+ 8275,
+ 8276,
+ 8277,
+ 8278,
+ 8279,
+ 8280,
+ 8281,
+ 8282,
+ 8283,
+ 8284,
+ 8285,
+ 8286,
+ 8287,
+ 8288,
+ 8289,
+ 8290,
+ 8291,
+ 8292,
+ 8293,
+ 8294,
+ 8295,
+ 8296,
+ 8297,
+ 8298,
+ 8299,
+ 8300,
+ 8301,
+ 8302,
+ 8303,
+ 8304,
+ 8305,
+ 8306,
+ 8307,
+ 8308,
+ 8309,
+ 8310,
+ 8311,
+ 8312,
+ 8313,
+ 8314,
+ 8315,
+ 8316,
+ 8317,
+ 8318,
+ 8319,
+ 8320,
+ 8321,
+ 8322,
+ 8323,
+ 8324,
+ 8325,
+ 8326,
+ 8327,
+ 8328,
+ 8329,
+ 8330,
+ 8331,
+ 8332,
+ 8333,
+ 8334,
+ 8335,
+ 8336,
+ 8337,
+ 8338,
+ 8339,
+ 8340,
+ 8341,
+ 8342,
+ 8343,
+ 8344,
+ 8345,
+ 8346,
+ 8347,
+ 8348,
+ 8349,
+ 8350,
+ 8351,
+ 8352,
+ 8353,
+ 8354,
+ 8355,
+ 8356,
+ 8357,
+ 8358,
+ 8359,
+ 8360,
+ 8361,
+ 8362,
+ 8363,
+ 8364,
+ 8365,
+ 8366,
+ 8367,
+ 8368,
+ 8369,
+ 8370,
+ 8371,
+ 8372,
+ 8373,
+ 8374,
+ 8375,
+ 8376,
+ 8377,
+ 8378,
+ 8379,
+ 8380,
+ 8381,
+ 8382,
+ 8383,
+ 8384,
+ 8385,
+ 8386,
+ 8387,
+ 8388,
+ 8389,
+ 8390,
+ 8391,
+ 8392,
+ 8393,
+ 8394,
+ 8395,
+ 8396,
+ 8397,
+ 8398,
+ 8399,
+ 8400,
+ 8401,
+ 8402,
+ 8403,
+ 8404,
+ 8405,
+ 8406,
+ 8407,
+ 8408,
+ 8409,
+ 8410,
+ 8411,
+ 8412,
+ 8413,
+ 8414,
+ 8415,
+ 8416,
+ 8417,
+ 8418,
+ 8419,
+ 8420,
+ 8421,
+ 8422,
+ 8423,
+ 8424,
+ 8425,
+ 8426,
+ 8427,
+ 8428,
+ 8429,
+ 8430,
+ 8431,
+ 8432,
+ 8433,
+ 8434,
+ 8435,
+ 8436,
+ 8437,
+ 8438,
+ 8439,
+ 8440,
+ 8441,
+ 8442,
+ 8443,
+ 8444,
+ 8445,
+ 8446,
+ 8447,
+ 8448,
+ 8449,
+ 8450,
+ 8451,
+ 8452,
+ 8453,
+ 8454,
+ 8455,
+ 8456,
+ 8457,
+ 8458,
+ 8459,
+ 8460,
+ 8461,
+ 8462,
+ 8463,
+ 8464,
+ 8465,
+ 8466,
+ 8467,
+ 8468,
+ 8469,
+ 8470,
+ 8471,
+ 8472,
+ 8473,
+ 8474,
+ 8475,
+ 8476,
+ 8477,
+ 8478,
+ 8479,
+ 8480,
+ 8481,
+ 8482,
+ 8483,
+ 8484,
+ 8485,
+ 8486,
+ 8487,
+ 8488,
+ 8489,
+ 8490,
+ 8491,
+ 8492,
+ 8493,
+ 8494,
+ 8495,
+ 8496,
+ 8497,
+ 8498,
+ 8499,
+ 8500,
+ 8501,
+ 8502,
+ 8503,
+ 8504,
+ 8505,
+ 8506,
+ 8507,
+ 8508,
+ 8509,
+ 8510,
+ 8511,
+ 8512,
+ 8513,
+ 8514,
+ 8515,
+ 8516,
+ 8517,
+ 8518,
+ 8519,
+ 8520,
+ 8521,
+ 8522,
+ 8523,
+ 8524,
+ 8525,
+ 8526,
+ 8527,
+ 8528,
+ 8529,
+ 8530,
+ 8531,
+ 8532,
+ 8533,
+ 8534,
+ 8535,
+ 8536,
+ 8537,
+ 8538,
+ 8539,
+ 8540,
+ 8541,
+ 8542,
+ 8543,
+ 8544,
+ 8545,
+ 8546,
+ 8547,
+ 8548,
+ 8549,
+ 8550,
+ 8551,
+ 8552,
+ 8553,
+ 8554,
+ 8555,
+ 8556,
+ 8557,
+ 8558,
+ 8559,
+ 8560,
+ 8561,
+ 8562,
+ 8563,
+ 8564,
+ 8565,
+ 8566,
+ 8567,
+ 8568,
+ 8569,
+ 8570,
+ 8571,
+ 8572,
+ 8573,
+ 8574,
+ 8575,
+ 8576,
+ 8577,
+ 8578,
+ 8579,
+ 8580,
+ 8581,
+ 8582,
+ 8583,
+ 8584,
+ 8585,
+ 8586,
+ 8587,
+ 8588,
+ 8589,
+ 8590,
+ 8591,
+ 8592,
+ 8593,
+ 8594,
+ 8595,
+ 8596,
+ 8597,
+ 8598,
+ 8599,
+ 8600,
+ 8601,
+ 8602,
+ 8603,
+ 8604,
+ 8605,
+ 8606,
+ 8607,
+ 8608,
+ 8609,
+ 8610,
+ 8611,
+ 8612,
+ 8613,
+ 8614,
+ 8615,
+ 8616,
+ 8617,
+ 8618,
+ 8619,
+ 8620,
+ 8621,
+ 8622,
+ 8623,
+ 8624,
+ 8625,
+ 8626,
+ 8627,
+ 8628,
+ 8629,
+ 8630,
+ 8631,
+ 8632,
+ 8633,
+ 8634,
+ 8635,
+ 8636,
+ 8637,
+ 8638,
+ 8639,
+ 8640,
+ 8641,
+ 8642,
+ 8643,
+ 8644,
+ 8645,
+ 8646,
+ 8647,
+ 8648,
+ 8649,
+ 8650,
+ 8651,
+ 8652,
+ 8653,
+ 8654,
+ 8655,
+ 8656,
+ 8657,
+ 8658,
+ 8659,
+ 8660,
+ 8661,
+ 8662,
+ 8663,
+ 8664,
+ 8665,
+ 8666,
+ 8667,
+ 8668,
+ 8669,
+ 8670,
+ 8671,
+ 8672,
+ 8673,
+ 8674,
+ 8675,
+ 8676,
+ 8677,
+ 8678,
+ 8679,
+ 8680,
+ 8681,
+ 8682,
+ 8683,
+ 8684,
+ 8685,
+ 8686,
+ 8687,
+ 8688,
+ 8689,
+ 8690,
+ 8691,
+ 8692,
+ 8693,
+ 8694,
+ 8695,
+ 8696,
+ 8697,
+ 8698,
+ 8699,
+ 8700,
+ 8701,
+ 8702,
+ 8703,
+ 8704,
+ 8705,
+ 8706,
+ 8707,
+ 8708,
+ 8709,
+ 8710,
+ 8711,
+ 8712,
+ 8713,
+ 8714,
+ 8715,
+ 8716,
+ 8717,
+ 8718,
+ 8719,
+ 8720,
+ 8721,
+ 8722,
+ 8723,
+ 8724,
+ 8725,
+ 8726,
+ 8727,
+ 8728,
+ 8729,
+ 8730,
+ 8731,
+ 8732,
+ 8733,
+ 8734,
+ 8735,
+ 8736,
+ 8737,
+ 8738,
+ 8739,
+ 8740,
+ 8741,
+ 8742,
+ 8743,
+ 8744,
+ 8745,
+ 8746,
+ 8747,
+ 8748,
+ 8749,
+ 8750,
+ 8751,
+ 8752,
+ 8753,
+ 8754,
+ 8755,
+ 8756,
+ 8757,
+ 8758,
+ 8759,
+ 8760,
+ 8761,
+ 8762,
+ 8763,
+ 8764,
+ 8765,
+ 8766,
+ 8767,
+ 8768,
+ 8769,
+ 8770,
+ 8771,
+ 8772,
+ 8773,
+ 8774,
+ 8775,
+ 8776,
+ 8777,
+ 8778,
+ 8779,
+ 8780,
+ 8781,
+ 8782,
+ 8783,
+ 8784,
+ 8785,
+ 8786,
+ 8787,
+ 8788,
+ 8789,
+ 8790,
+ 8791,
+ 8792,
+ 8793,
+ 8794,
+ 8795,
+ 8796,
+ 8797,
+ 8798,
+ 8799,
+ 8800,
+ 8801,
+ 8802,
+ 8803,
+ 8804,
+ 8805,
+ 8806,
+ 8807,
+ 8808,
+ 8809,
+ 8810,
+ 8811,
+ 8812,
+ 8813,
+ 8814,
+ 8815,
+ 8816,
+ 8817,
+ 8818,
+ 8819,
+ 8820,
+ 8821,
+ 8822,
+ 8823,
+ 8824,
+ 8825,
+ 8826,
+ 8827,
+ 8828,
+ 8829,
+ 8830,
+ 8831,
+ 8832,
+ 8833,
+ 8834,
+ 8835,
+ 8836,
+ 8837,
+ 8838,
+ 8839,
+ 8840,
+ 8841,
+ 8842,
+ 8843,
+ 8844,
+ 8845,
+ 8846,
+ 8847,
+ 8848,
+ 8849,
+ 8850,
+ 8851,
+ 8852,
+ 8853,
+ 8854,
+ 8855,
+ 8856,
+ 8857,
+ 8858,
+ 8859,
+ 8860,
+ 8861,
+ 8862,
+ 8863,
+ 8864,
+ 8865,
+ 8866,
+ 8867,
+ 8868,
+ 8869,
+ 8870,
+ 8871,
+ 8872,
+ 8873,
+ 8874,
+ 8875,
+ 8876,
+ 8877,
+ 8878,
+ 8879,
+ 8880,
+ 8881,
+ 8882,
+ 8883,
+ 8884,
+ 8885,
+ 8886,
+ 8887,
+ 8888,
+ 8889,
+ 8890,
+ 8891,
+ 8892,
+ 8893,
+ 8894,
+ 8895,
+ 8896,
+ 8897,
+ 8898,
+ 8899,
+ 8900,
+ 8901,
+ 8902,
+ 8903,
+ 8904,
+ 8905,
+ 8906,
+ 8907,
+ 8908,
+ 8909,
+ 8910,
+ 8911,
+ 8912,
+ 8913,
+ 8914,
+ 8915,
+ 8916,
+ 8917,
+ 8918,
+ 8919,
+ 8920,
+ 8921,
+ 8922,
+ 8923,
+ 8924,
+ 8925,
+ 8926,
+ 8927,
+ 8928,
+ 8929,
+ 8930,
+ 8931,
+ 8932,
+ 8933,
+ 8934,
+ 8935,
+ 8936,
+ 8937,
+ 8938,
+ 8939,
+ 8940,
+ 8941,
+ 8942,
+ 8943,
+ 8944,
+ 8945,
+ 8946,
+ 8947,
+ 8948,
+ 8949,
+ 8950,
+ 8951,
+ 8952,
+ 8953,
+ 8954,
+ 8955,
+ 8956,
+ 8957,
+ 8958,
+ 8959,
+ 8960,
+ 8961,
+ 8962,
+ 8963,
+ 8964,
+ 8965,
+ 8966,
+ 8967,
+ 8968,
+ 8969,
+ 8970,
+ 8971,
+ 8972,
+ 8973,
+ 8974,
+ 8975,
+ 8976,
+ 8977,
+ 8978,
+ 8979,
+ 8980,
+ 8981,
+ 8982,
+ 8983,
+ 8984,
+ 8985,
+ 8986,
+ 8987,
+ 8988,
+ 8989,
+ 8990,
+ 8991,
+ 8992,
+ 8993,
+ 8994,
+ 8995,
+ 8996,
+ 8997,
+ 8998,
+ 8999,
+ 9000,
+ 9001,
+ 9002,
+ 9003,
+ 9004,
+ 9005,
+ 9006,
+ 9007,
+ 9008,
+ 9009,
+ 9010,
+ 9011,
+ 9012,
+ 9013,
+ 9014,
+ 9015,
+ 9016,
+ 9017,
+ 9018,
+ 9019,
+ 9020,
+ 9021,
+ 9022,
+ 9023,
+ 9024,
+ 9025,
+ 9026,
+ 9027,
+ 9028,
+ 9029,
+ 9030,
+ 9031,
+ 9032,
+ 9033,
+ 9034,
+ 9035,
+ 9036,
+ 9037,
+ 9038,
+ 9039,
+ 9040,
+ 9041,
+ 9042,
+ 9043,
+ 9044,
+ 9045,
+ 9046,
+ 9047,
+ 9048,
+ 9049,
+ 9050,
+ 9051,
+ 9052,
+ 9053,
+ 9054,
+ 9055,
+ 9056,
+ 9057,
+ 9058,
+ 9059,
+ 9060,
+ 9061,
+ 9062,
+ 9063,
+ 9064,
+ 9065,
+ 9066,
+ 9067,
+ 9068,
+ 9069,
+ 9070,
+ 9071,
+ 9072,
+ 9073,
+ 9074,
+ 9075,
+ 9076,
+ 9077,
+ 9078,
+ 9079,
+ 9080,
+ 9081,
+ 9082,
+ 9083,
+ 9084,
+ 9085,
+ 9086,
+ 9087,
+ 9088,
+ 9089,
+ 9090,
+ 9091,
+ 9092,
+ 9093,
+ 9094,
+ 9095,
+ 9096,
+ 9097,
+ 9098,
+ 9099,
+ 9100,
+ 9101,
+ 9102,
+ 9103,
+ 9104,
+ 9105,
+ 9106,
+ 9107,
+ 9108,
+ 9109,
+ 9110,
+ 9111,
+ 9112,
+ 9113,
+ 9114,
+ 9115,
+ 9116,
+ 9117,
+ 9118,
+ 9119,
+ 9120,
+ 9121,
+ 9122,
+ 9123,
+ 9124,
+ 9125,
+ 9126,
+ 9127,
+ 9128,
+ 9129,
+ 9130,
+ 9131,
+ 9132,
+ 9133,
+ 9134,
+ 9135,
+ 9136,
+ 9137,
+ 9138,
+ 9139,
+ 9140,
+ 9141,
+ 9142,
+ 9143,
+ 9144,
+ 9145,
+ 9146,
+ 9147,
+ 9148,
+ 9149,
+ 9150,
+ 9151,
+ 9152,
+ 9153,
+ 9154,
+ 9155,
+ 9156,
+ 9157,
+ 9158,
+ 9159,
+ 9160,
+ 9161,
+ 9162,
+ 9163,
+ 9164,
+ 9165,
+ 9166,
+ 9167,
+ 9168,
+ 9169,
+ 9170,
+ 9171,
+ 9172,
+ 9173,
+ 9174,
+ 9175,
+ 9176,
+ 9177,
+ 9178,
+ 9179,
+ 9180,
+ 9181,
+ 9182,
+ 9183,
+ 9184,
+ 9185,
+ 9186,
+ 9187,
+ 9188,
+ 9189,
+ 9190,
+ 9191,
+ 9192,
+ 9193,
+ 9194,
+ 9195,
+ 9196,
+ 9197,
+ 9198,
+ 9199,
+ 9200,
+ 9201,
+ 9202,
+ 9203,
+ 9204,
+ 9205,
+ 9206,
+ 9207,
+ 9208,
+ 9209,
+ 9210,
+ 9211,
+ 9212,
+ 9213,
+ 9214,
+ 9215,
+ 9216,
+ 9217,
+ 9218,
+ 9219,
+ 9220,
+ 9221,
+ 9222,
+ 9223,
+ 9224,
+ 9225,
+ 9226,
+ 9227,
+ 9228,
+ 9229,
+ 9230,
+ 9231,
+ 9232,
+ 9233,
+ 9234,
+ 9235,
+ 9236,
+ 9237,
+ 9238,
+ 9239,
+ 9240,
+ 9241,
+ 9242,
+ 9243,
+ 9244,
+ 9245,
+ 9246,
+ 9247,
+ 9248,
+ 9249,
+ 9250,
+ 9251,
+ 9252,
+ 9253,
+ 9254,
+ 9255,
+ 9256,
+ 9257,
+ 9258,
+ 9259,
+ 9260,
+ 9261,
+ 9262,
+ 9263,
+ 9264,
+ 9265,
+ 9266,
+ 9267,
+ 9268,
+ 9269,
+ 9270,
+ 9271,
+ 9272,
+ 9273,
+ 9274,
+ 9275,
+ 9276,
+ 9277,
+ 9278,
+ 9279,
+ 9280,
+ 9281,
+ 9282,
+ 9283,
+ 9284,
+ 9285,
+ 9286,
+ 9287,
+ 9288,
+ 9289,
+ 9290,
+ 9291,
+ 9292,
+ 9293,
+ 9294,
+ 9295,
+ 9296,
+ 9297,
+ 9298,
+ 9299,
+ 9300,
+ 9301,
+ 9302,
+ 9303,
+ 9304,
+ 9305,
+ 9306,
+ 9307,
+ 9308,
+ 9309,
+ 9310,
+ 9311,
+ 9312,
+ 9313,
+ 9314,
+ 9315,
+ 9316,
+ 9317,
+ 9318,
+ 9319,
+ 9320,
+ 9321,
+ 9322,
+ 9323,
+ 9324,
+ 9325,
+ 9326,
+ 9327,
+ 9328,
+ 9329,
+ 9330,
+ 9331,
+ 9332,
+ 9333,
+ 9334,
+ 9335,
+ 9336,
+ 9337,
+ 9338,
+ 9339,
+ 9340,
+ 9341,
+ 9342,
+ 9343,
+ 9344,
+ 9345,
+ 9346,
+ 9347,
+ 9348,
+ 9349,
+ 9350,
+ 9351,
+ 9352,
+ 9353,
+ 9354,
+ 9355,
+ 9356,
+ 9357,
+ 9358,
+ 9359,
+ 9360,
+ 9361,
+ 9362,
+ 9363,
+ 9364,
+ 9365,
+ 9366,
+ 9367,
+ 9368,
+ 9369,
+ 9370,
+ 9371,
+ 9372,
+ 9373,
+ 9374,
+ 9375,
+ 9376,
+ 9377,
+ 9378,
+ 9379,
+ 9380,
+ 9381,
+ 9382,
+ 9383,
+ 9384,
+ 9385,
+ 9386,
+ 9387,
+ 9388,
+ 9389,
+ 9390,
+ 9391,
+ 9392,
+ 9393,
+ 9394,
+ 9395,
+ 9396,
+ 9397,
+ 9398,
+ 9399,
+ 9400,
+ 9401,
+ 9402,
+ 9403,
+ 9404,
+ 9405,
+ 9406,
+ 9407,
+ 9408,
+ 9409,
+ 9410,
+ 9411,
+ 9412,
+ 9413,
+ 9414,
+ 9415,
+ 9416,
+ 9417,
+ 9418,
+ 9419,
+ 9420,
+ 9421,
+ 9422,
+ 9423,
+ 9424,
+ 9425,
+ 9426,
+ 9427,
+ 9428,
+ 9429,
+ 9430,
+ 9431,
+ 9432,
+ 9433,
+ 9434,
+ 9435,
+ 9436,
+ 9437,
+ 9438,
+ 9439,
+ 9440,
+ 9441,
+ 9442,
+ 9443,
+ 9444,
+ 9445,
+ 9446,
+ 9447,
+ 9448,
+ 9449,
+ 9450,
+ 9451,
+ 9452,
+ 9453,
+ 9454,
+ 9455,
+ 9456,
+ 9457,
+ 9458,
+ 9459,
+ 9460,
+ 9461,
+ 9462,
+ 9463,
+ 9464,
+ 9465,
+ 9466,
+ 9467,
+ 9468,
+ 9469,
+ 9470,
+ 9471,
+ 9472,
+ 9473,
+ 9474,
+ 9475,
+ 9476,
+ 9477,
+ 9478,
+ 9479,
+ 9480,
+ 9481,
+ 9482,
+ 9483,
+ 9484,
+ 9485,
+ 9486,
+ 9487,
+ 9488,
+ 9489,
+ 9490,
+ 9491,
+ 9492,
+ 9493,
+ 9494,
+ 9495,
+ 9496,
+ 9497,
+ 9498,
+ 9499,
+ 9500,
+ 9501,
+ 9502,
+ 9503,
+ 9504,
+ 9505,
+ 9506,
+ 9507,
+ 9508,
+ 9509,
+ 9510,
+ 9511,
+ 9512,
+ 9513,
+ 9514,
+ 9515,
+ 9516,
+ 9517,
+ 9518,
+ 9519,
+ 9520,
+ 9521,
+ 9522,
+ 9523,
+ 9524,
+ 9525,
+ 9526,
+ 9527,
+ 9528,
+ 9529,
+ 9530,
+ 9531,
+ 9532,
+ 9533,
+ 9534,
+ 9535,
+ 9536,
+ 9537,
+ 9538,
+ 9539,
+ 9540,
+ 9541,
+ 9542,
+ 9543,
+ 9544,
+ 9545,
+ 9546,
+ 9547,
+ 9548,
+ 9549,
+ 9550,
+ 9551,
+ 9552,
+ 9553,
+ 9554,
+ 9555,
+ 9556,
+ 9557,
+ 9558,
+ 9559,
+ 9560,
+ 9561,
+ 9562,
+ 9563,
+ 9564,
+ 9565,
+ 9566,
+ 9567,
+ 9568,
+ 9569,
+ 9570,
+ 9571,
+ 9572,
+ 9573,
+ 9574,
+ 9575,
+ 9576,
+ 9577,
+ 9578,
+ 9579,
+ 9580,
+ 9581,
+ 9582,
+ 9583,
+ 9584,
+ 9585,
+ 9586,
+ 9587,
+ 9588,
+ 9589,
+ 9590,
+ 9591,
+ 9592,
+ 9593,
+ 9594,
+ 9595,
+ 9596,
+ 9597,
+ 9598,
+ 9599,
+ 9600,
+ 9601,
+ 9602,
+ 9603,
+ 9604,
+ 9605,
+ 9606,
+ 9607,
+ 9608,
+ 9609,
+ 9610,
+ 9611,
+ 9612,
+ 9613,
+ 9614,
+ 9615,
+ 9616,
+ 9617,
+ 9618,
+ 9619,
+ 9620,
+ 9621,
+ 9622,
+ 9623,
+ 9624,
+ 9625,
+ 9626,
+ 9627,
+ 9628,
+ 9629,
+ 9630,
+ 9631,
+ 9632,
+ 9633,
+ 9634,
+ 9635,
+ 9636,
+ 9637,
+ 9638,
+ 9639,
+ 9640,
+ 9641,
+ 9642,
+ 9643,
+ 9644,
+ 9645,
+ 9646,
+ 9647,
+ 9648,
+ 9649,
+ 9650,
+ 9651,
+ 9652,
+ 9653,
+ 9654,
+ 9655,
+ 9656,
+ 9657,
+ 9658,
+ 9659,
+ 9660,
+ 9661,
+ 9662,
+ 9663,
+ 9664,
+ 9665,
+ 9666,
+ 9667,
+ 9668,
+ 9669,
+ 9670,
+ 9671,
+ 9672,
+ 9673,
+ 9674,
+ 9675,
+ 9676,
+ 9677,
+ 9678,
+ 9679,
+ 9680,
+ 9681,
+ 9682,
+ 9683,
+ 9684,
+ 9685,
+ 9686,
+ 9687,
+ 9688,
+ 9689,
+ 9690,
+ 9691,
+ 9692,
+ 9693,
+ 9694,
+ 9695,
+ 9696,
+ 9697,
+ 9698,
+ 9699,
+ 9700,
+ 9701,
+ 9702,
+ 9703,
+ 9704,
+ 9705,
+ 9706,
+ 9707,
+ 9708,
+ 9709,
+ 9710,
+ 9711,
+ 9712,
+ 9713,
+ 9714,
+ 9715,
+ 9716,
+ 9717,
+ 9718,
+ 9719,
+ 9720,
+ 9721,
+ 9722,
+ 9723,
+ 9724,
+ 9725,
+ 9726,
+ 9727,
+ 9728,
+ 9729,
+ 9730,
+ 9731,
+ 9732,
+ 9733,
+ 9734,
+ 9735,
+ 9736,
+ 9737,
+ 9738,
+ 9739,
+ 9740,
+ 9741,
+ 9742,
+ 9743,
+ 9744,
+ 9745,
+ 9746,
+ 9747,
+ 9748,
+ 9749,
+ 9750,
+ 9751,
+ 9752,
+ 9753,
+ 9754,
+ 9755,
+ 9756,
+ 9757,
+ 9758,
+ 9759,
+ 9760,
+ 9761,
+ 9762,
+ 9763,
+ 9764,
+ 9765,
+ 9766,
+ 9767,
+ 9768,
+ 9769,
+ 9770,
+ 9771,
+ 9772,
+ 9773,
+ 9774,
+ 9775,
+ 9776,
+ 9777,
+ 9778,
+ 9779,
+ 9780,
+ 9781,
+ 9782,
+ 9783,
+ 9784,
+ 9785,
+ 9786,
+ 9787,
+ 9788,
+ 9789,
+ 9790,
+ 9791,
+ 9792,
+ 9793,
+ 9794,
+ 9795,
+ 9796,
+ 9797,
+ 9798,
+ 9799,
+ 9800,
+ 9801,
+ 9802,
+ 9803,
+ 9804,
+ 9805,
+ 9806,
+ 9807,
+ 9808,
+ 9809,
+ 9810,
+ 9811,
+ 9812,
+ 9813,
+ 9814,
+ 9815,
+ 9816,
+ 9817,
+ 9818,
+ 9819,
+ 9820,
+ 9821,
+ 9822,
+ 9823,
+ 9824,
+ 9825,
+ 9826,
+ 9827,
+ 9828,
+ 9829,
+ 9830,
+ 9831,
+ 9832,
+ 9833,
+ 9834,
+ 9835,
+ 9836,
+ 9837,
+ 9838,
+ 9839,
+ 9840,
+ 9841,
+ 9842,
+ 9843,
+ 9844,
+ 9845,
+ 9846,
+ 9847,
+ 9848,
+ 9849,
+ 9850,
+ 9851,
+ 9852,
+ 9853,
+ 9854,
+ 9855,
+ 9856,
+ 9857,
+ 9858,
+ 9859,
+ 9860,
+ 9861,
+ 9862,
+ 9863,
+ 9864,
+ 9865,
+ 9866,
+ 9867,
+ 9868,
+ 9869,
+ 9870,
+ 9871,
+ 9872,
+ 9873,
+ 9874,
+ 9875,
+ 9876,
+ 9877,
+ 9878,
+ 9879,
+ 9880,
+ 9881,
+ 9882,
+ 9883,
+ 9884,
+ 9885,
+ 9886,
+ 9887,
+ 9888,
+ 9889,
+ 9890,
+ 9891,
+ 9892,
+ 9893,
+ 9894,
+ 9895,
+ 9896,
+ 9897,
+ 9898,
+ 9899,
+ 9900,
+ 9901,
+ 9902,
+ 9903,
+ 9904,
+ 9905,
+ 9906,
+ 9907,
+ 9908,
+ 9909,
+ 9910,
+ 9911,
+ 9912,
+ 9913,
+ 9914,
+ 9915,
+ 9916,
+ 9917,
+ 9918,
+ 9919,
+ 9920,
+ 9921,
+ 9922,
+ 9923,
+ 9924,
+ 9925,
+ 9926,
+ 9927,
+ 9928,
+ 9929,
+ 9930,
+ 9931,
+ 9932,
+ 9933,
+ 9934,
+ 9935,
+ 9936,
+ 9937,
+ 9938,
+ 9939,
+ 9940,
+ 9941,
+ 9942,
+ 9943,
+ 9944,
+ 9945,
+ 9946,
+ 9947,
+ 9948,
+ 9949,
+ 9950,
+ 9951,
+ 9952,
+ 9953,
+ 9954,
+ 9955,
+ 9956,
+ 9957,
+ 9958,
+ 9959,
+ 9960,
+ 9961,
+ 9962,
+ 9963,
+ 9964,
+ 9965,
+ 9966,
+ 9967,
+ 9968,
+ 9969,
+ 9970,
+ 9971,
+ 9972,
+ 9973,
+ 9974,
+ 9975,
+ 9976,
+ 9977,
+ 9978,
+ 9979,
+ 9980,
+ 9981,
+ 9982,
+ 9983,
+ 9984,
+ 9985,
+ 9986,
+ 9987,
+ 9988,
+ 9989,
+ 9990,
+ 9991,
+ 9992,
+ 9993,
+ 9994,
+ 9995,
+ 9996,
+ 9997,
+ 9998,
+ 9999,
+ 10000,
+ 10001,
+ 10002,
+ 10003,
+ 10004,
+ 10005,
+ 10006,
+ 10007,
+ 10008,
+ 10009,
+ 10010,
+ 10011,
+ 10012,
+ 10013,
+ 10014,
+ 10015,
+ 10016,
+ 10017,
+ 10018,
+ 10019,
+ 10020,
+ 10021,
+ 10022,
+ 10023,
+ 10024,
+ 10025,
+ 10026,
+ 10027,
+ 10028,
+ 10029,
+ 10030,
+ 10031,
+ 10032,
+ 10033,
+ 10034,
+ 10035,
+ 10036,
+ 10037,
+ 10038,
+ 10039,
+ 10040,
+ 10041,
+ 10042,
+ 10043,
+ 10044,
+ 10045,
+ 10046,
+ 10047,
+ 10048,
+ 10049,
+ 10050,
+ 10051,
+ 10052,
+ 10053,
+ 10054,
+ 10055,
+ 10056,
+ 10057,
+ 10058,
+ 10059,
+ 10060,
+ 10061,
+ 10062,
+ 10063,
+ 10064,
+ 10065,
+ 10066,
+ 10067,
+ 10068,
+ 10069,
+ 10070,
+ 10071,
+ 10072,
+ 10073,
+ 10074,
+ 10075,
+ 10076,
+ 10077,
+ 10078,
+ 10079,
+ 10080,
+ 10081,
+ 10082,
+ 10083,
+ 10084,
+ 10085,
+ 10086,
+ 10087,
+ 10088,
+ 10089,
+ 10090,
+ 10091,
+ 10092,
+ 10093,
+ 10094,
+ 10095,
+ 10096,
+ 10097,
+ 10098,
+ 10099,
+ 10100,
+ 10101,
+ 10102,
+ 10103,
+ 10104,
+ 10105,
+ 10106,
+ 10107,
+ 10108,
+ 10109,
+ 10110,
+ 10111,
+ 10112,
+ 10113,
+ 10114,
+ 10115,
+ 10116,
+ 10117,
+ 10118,
+ 10119,
+ 10120,
+ 10121,
+ 10122,
+ 10123,
+ 10124,
+ 10125,
+ 10126,
+ 10127,
+ 10128,
+ 10129,
+ 10130,
+ 10131,
+ 10132,
+ 10133,
+ 10134,
+ 10135,
+ 10136,
+ 10137,
+ 10138,
+ 10139,
+ 10140,
+ 10141,
+ 10142,
+ 10143,
+ 10144,
+ 10145,
+ 10146,
+ 10147,
+ 10148,
+ 10149,
+ 10150,
+ 10151,
+ 10152,
+ 10153,
+ 10154,
+ 10155,
+ 10156,
+ 10157,
+ 10158,
+ 10159,
+ 10160,
+ 10161,
+ 10162,
+ 10163,
+ 10164,
+ 10165,
+ 10166,
+ 10167,
+ 10168,
+ 10169,
+ 10170,
+ 10171,
+ 10172,
+ 10173,
+ 10174,
+ 10175,
+ 10176,
+ 10177,
+ 10178,
+ 10179,
+ 10180,
+ 10181,
+ 10182,
+ 10183,
+ 10184,
+ 10185,
+ 10186,
+ 10187,
+ 10188,
+ 10189,
+ 10190,
+ 10191,
+ 10192,
+ 10193,
+ 10194,
+ 10195,
+ 10196,
+ 10197,
+ 10198,
+ 10199,
+ 10200,
+ 10201,
+ 10202,
+ 10203,
+ 10204,
+ 10205,
+ 10206,
+ 10207,
+ 10208,
+ 10209,
+ 10210,
+ 10211,
+ 10212,
+ 10213,
+ 10214,
+ 10215,
+ 10216,
+ 10217,
+ 10218,
+ 10219,
+ 10220,
+ 10221,
+ 10222,
+ 10223,
+ 10224,
+ 10225,
+ 10226,
+ 10227,
+ 10228,
+ 10229,
+ 10230,
+ 10231,
+ 10232,
+ 10233,
+ 10234,
+ 10235,
+ 10236,
+ 10237,
+ 10238,
+ 10239,
+ 10240,
+ 10241,
+ 10242,
+ 10243,
+ 10244,
+ 10245,
+ 10246,
+ 10247,
+ 10248,
+ 10249,
+ 10250,
+ 10251,
+ 10252,
+ 10253,
+ 10254,
+ 10255,
+ 10256,
+ 10257,
+ 10258,
+ 10259,
+ 10260,
+ 10261,
+ 10262,
+ 10263,
+ 10264,
+ 10265,
+ 10266,
+ 10267,
+ 10268,
+ 10269,
+ 10270,
+ 10271,
+ 10272,
+ 10273,
+ 10274,
+ 10275,
+ 10276,
+ 10277,
+ 10278,
+ 10279,
+ 10280,
+ 10281,
+ 10282,
+ 10283,
+ 10284,
+ 10285,
+ 10286,
+ 10287,
+ 10288,
+ 10289,
+ 10290,
+ 10291,
+ 10292,
+ 10293,
+ 10294,
+ 10295,
+ 10296,
+ 10297,
+ 10298,
+ 10299,
+ 10300,
+ 10301,
+ 10302,
+ 10303,
+ 10304,
+ 10305,
+ 10306,
+ 10307,
+ 10308,
+ 10309,
+ 10310,
+ 10311,
+ 10312,
+ 10313,
+ 10314,
+ 10315,
+ 10316,
+ 10317,
+ 10318,
+ 10319,
+ 10320,
+ 10321,
+ 10322,
+ 10323,
+ 10324,
+ 10325,
+ 10326,
+ 10327,
+ 10328,
+ 10329,
+ 10330,
+ 10331,
+ 10332,
+ 10333,
+ 10334,
+ 10335,
+ 10336,
+ 10337,
+ 10338,
+ 10339,
+ 10340,
+ 10341,
+ 10342,
+ 10343,
+ 10344,
+ 10345,
+ 10346,
+ 10347,
+ 10348,
+ 10349,
+ 10350,
+ 10351,
+ 10352,
+ 10353,
+ 10354,
+ 10355,
+ 10356,
+ 10357,
+ 10358,
+ 10359,
+ 10360,
+ 10361,
+ 10362,
+ 10363,
+ 10364,
+ 10365,
+ 10366,
+ 10367,
+ 10368,
+ 10369,
+ 10370,
+ 10371,
+ 10372,
+ 10373,
+ 10374,
+ 10375,
+ 10376,
+ 10377,
+ 10378,
+ 10379,
+ 10380,
+ 10381,
+ 10382,
+ 10383,
+ 10384,
+ 10385,
+ 10386,
+ 10387,
+ 10388,
+ 10389,
+ 10390,
+ 10391,
+ 10392,
+ 10393,
+ 10394,
+ 10395,
+ 10396,
+ 10397,
+ 10398,
+ 10399,
+ 10400,
+ 10401,
+ 10402,
+ 10403,
+ 10404,
+ 10405,
+ 10406,
+ 10407,
+ 10408,
+ 10409,
+ 10410,
+ 10411,
+ 10412,
+ 10413,
+ 10414,
+ 10415,
+ 10416,
+ 10417,
+ 10418,
+ 10419,
+ 10420,
+ 10421,
+ 10422,
+ 10423,
+ 10424,
+ 10425,
+ 10426,
+ 10427,
+ 10428,
+ 10429,
+ 10430,
+ 10431,
+ 10432,
+ 10433,
+ 10434,
+ 10435,
+ 10436,
+ 10437,
+ 10438,
+ 10439,
+ 10440,
+ 10441,
+ 10442,
+ 10443,
+ 10444,
+ 10445,
+ 10446,
+ 10447,
+ 10448,
+ 10449,
+ 10450,
+ 10451,
+ 10452,
+ 10453,
+ 10454,
+ 10455,
+ 10456,
+ 10457,
+ 10458,
+ 10459,
+ 10460,
+ 10461,
+ 10462,
+ 10463,
+ 10464,
+ 10465,
+ 10466,
+ 10467,
+ 10468,
+ 10469,
+ 10470,
+ 10471,
+ 10472,
+ 10473,
+ 10474,
+ 10475,
+ 10476,
+ 10477,
+ 10478,
+ 10479,
+ 10480,
+ 10481,
+ 10482,
+ 10483,
+ 10484,
+ 10485,
+ 10486,
+ 10487,
+ 10488,
+ 10489,
+ 10490,
+ 10491,
+ 10492,
+ 10493,
+ 10494,
+ 10495,
+ 10496,
+ 10497,
+ 10498,
+ 10499,
+ 10500,
+ 10501,
+ 10502,
+ 10503,
+ 10504,
+ 10505,
+ 10506,
+ 10507,
+ 10508,
+ 10509,
+ 10510,
+ 10511,
+ 10512,
+ 10513,
+ 10514,
+ 10515,
+ 10516,
+ 10517,
+ 10518,
+ 10519,
+ 10520,
+ 10521,
+ 10522,
+ 10523,
+ 10524,
+ 10525,
+ 10526,
+ 10527,
+ 10528,
+ 10529,
+ 10530,
+ 10531,
+ 10532,
+ 10533,
+ 10534,
+ 10535,
+ 10536,
+ 10537,
+ 10538,
+ 10539,
+ 10540,
+ 10541,
+ 10542,
+ 10543,
+ 10544,
+ 10545,
+ 10546,
+ 10547,
+ 10548,
+ 10549,
+ 10550,
+ 10551,
+ 10552,
+ 10553,
+ 10554,
+ 10555,
+ 10556,
+ 10557,
+ 10558,
+ 10559,
+ 10560,
+ 10561,
+ 10562,
+ 10563,
+ 10564,
+ 10565,
+ 10566,
+ 10567,
+ 10568,
+ 10569,
+ 10570,
+ 10571,
+ 10572,
+ 10573,
+ 10574,
+ 10575,
+ 10576,
+ 10577,
+ 10578,
+ 10579,
+ 10580,
+ 10581,
+ 10582,
+ 10583,
+ 10584,
+ 10585,
+ 10586,
+ 10587,
+ 10588,
+ 10589,
+ 10590,
+ 10591,
+ 10592,
+ 10593,
+ 10594,
+ 10595,
+ 10596,
+ 10597,
+ 10598,
+ 10599,
+ 10600,
+ 10601,
+ 10602,
+ 10603,
+ 10604,
+ 10605,
+ 10606,
+ 10607,
+ 10608,
+ 10609,
+ 10610,
+ 10611,
+ 10612,
+ 10613,
+ 10614,
+ 10615,
+ 10616,
+ 10617,
+ 10618,
+ 10619,
+ 10620,
+ 10621,
+ 10622,
+ 10623,
+ 10624,
+ 10625,
+ 10626,
+ 10627,
+ 10628,
+ 10629,
+ 10630,
+ 10631,
+ 10632,
+ 10633,
+ 10634,
+ 10635,
+ 10636,
+ 10637,
+ 10638,
+ 10639,
+ 10640,
+ 10641,
+ 10642,
+ 10643,
+ 10644,
+ 10645,
+ 10646,
+ 10647,
+ 10648,
+ 10649,
+ 10650,
+ 10651,
+ 10652,
+ 10653,
+ 10654,
+ 10655,
+ 10656,
+ 10657,
+ 10658,
+ 10659,
+ 10660,
+ 10661,
+ 10662,
+ 10663,
+ 10664,
+ 10665,
+ 10666,
+ 10667,
+ 10668,
+ 10669,
+ 10670,
+ 10671,
+ 10672,
+ 10673,
+ 10674,
+ 10675,
+ 10676,
+ 10677,
+ 10678,
+ 10679,
+ 10680,
+ 10681,
+ 10682,
+ 10683,
+ 10684,
+ 10685,
+ 10686,
+ 10687,
+ 10688,
+ 10689,
+ 10690,
+ 10691,
+ 10692,
+ 10693,
+ 10694,
+ 10695,
+ 10696,
+ 10697,
+ 10698,
+ 10699,
+ 10700,
+ 10701,
+ 10702,
+ 10703,
+ 10704,
+ 10705,
+ 10706,
+ 10707,
+ 10708,
+ 10709,
+ 10710,
+ 10711,
+ 10712,
+ 10713,
+ 10714,
+ 10715,
+ 10716,
+ 10717,
+ 10718,
+ 10719,
+ 10720,
+ 10721,
+ 10722,
+ 10723,
+ 10724,
+ 10725,
+ 10726,
+ 10727,
+ 10728,
+ 10729,
+ 10730,
+ 10731,
+ 10732,
+ 10733,
+ 10734,
+ 10735,
+ 10736,
+ 10737,
+ 10738,
+ 10739,
+ 10740,
+ 10741,
+ 10742,
+ 10743,
+ 10744,
+ 10745,
+ 10746,
+ 10747,
+ 10748,
+ 10749,
+ 10750,
+ 10751,
+ 10752,
+ 10753,
+ 10754,
+ 10755,
+ 10756,
+ 10757,
+ 10758,
+ 10759,
+ 10760,
+ 10761,
+ 10762,
+ 10763,
+ 10764,
+ 10765,
+ 10766,
+ 10767,
+ 10768,
+ 10769,
+ 10770,
+ 10771,
+ 10772,
+ 10773,
+ 10774,
+ 10775,
+ 10776,
+ 10777,
+ 10778,
+ 10779,
+ 10780,
+ 10781,
+ 10782,
+ 10783,
+ 10784,
+ 10785,
+ 10786,
+ 10787,
+ 10788,
+ 10789,
+ 10790,
+ 10791,
+ 10792,
+ 10793,
+ 10794,
+ 10795,
+ 10796,
+ 10797,
+ 10798,
+ 10799,
+ 10800,
+ 10801,
+ 10802,
+ 10803,
+ 10804,
+ 10805,
+ 10806,
+ 10807,
+ 10808,
+ 10809,
+ 10810,
+ 10811,
+ 10812,
+ 10813,
+ 10814,
+ 10815,
+ 10816,
+ 10817,
+ 10818,
+ 10819,
+ 10820,
+ 10821,
+ 10822,
+ 10823,
+ 10824,
+ 10825,
+ 10826,
+ 10827,
+ 10828,
+ 10829,
+ 10830,
+ 10831,
+ 10832,
+ 10833,
+ 10834,
+ 10835,
+ 10836,
+ 10837,
+ 10838,
+ 10839,
+ 10840,
+ 10841,
+ 10842,
+ 10843,
+ 10844,
+ 10845,
+ 10846,
+ 10847,
+ 10848,
+ 10849,
+ 10850,
+ 10851,
+ 10852,
+ 10853,
+ 10854,
+ 10855,
+ 10856,
+ 10857,
+ 10858,
+ 10859,
+ 10860,
+ 10861,
+ 10862,
+ 10863,
+ 10864,
+ 10865,
+ 10866,
+ 10867,
+ 10868,
+ 10869,
+ 10870,
+ 10871,
+ 10872,
+ 10873,
+ 10874,
+ 10875,
+ 10876,
+ 10877,
+ 10878,
+ 10879,
+ 10880,
+ 10881,
+ 10882,
+ 10883,
+ 10884,
+ 10885,
+ 10886,
+ 10887,
+ 10888,
+ 10889,
+ 10890,
+ 10891,
+ 10892,
+ 10893,
+ 10894,
+ 10895,
+ 10896,
+ 10897,
+ 10898,
+ 10899,
+ 10900,
+ 10901,
+ 10902,
+ 10903,
+ 10904,
+ 10905,
+ 10906,
+ 10907,
+ 10908,
+ 10909,
+ 10910,
+ 10911,
+ 10912,
+ 10913,
+ 10914,
+ 10915,
+ 10916,
+ 10917,
+ 10918,
+ 10919,
+ 10920,
+ 10921,
+ 10922,
+ 10923,
+ 10924,
+ 10925,
+ 10926,
+ 10927,
+ 10928,
+ 10929,
+ 10930,
+ 10931,
+ 10932,
+ 10933,
+ 10934,
+ 10935,
+ 10936,
+ 10937,
+ 10938,
+ 10939,
+ 10940,
+ 10941,
+ 10942,
+ 10943,
+ 10944,
+ 10945,
+ 10946,
+ 10947,
+ 10948,
+ 10949,
+ 10950,
+ 10951,
+ 10952,
+ 10953,
+ 10954,
+ 10955,
+ 10956,
+ 10957,
+ 10958,
+ 10959,
+ 10960,
+ 10961,
+ 10962,
+ 10963,
+ 10964,
+ 10965,
+ 10966,
+ 10967,
+ 10968,
+ 10969,
+ 10970,
+ 10971,
+ 10972,
+ 10973,
+ 10974,
+ 10975,
+ 10976,
+ 10977,
+ 10978,
+ 10979,
+ 10980,
+ 10981,
+ 10982,
+ 10983,
+ 10984,
+ 10985,
+ 10986,
+ 10987,
+ 10988,
+ 10989,
+ 10990,
+ 10991,
+ 10992,
+ 10993,
+ 10994,
+ 10995,
+ 10996,
+ 10997,
+ 10998,
+ 10999,
+ 11000,
+ 11001,
+ 11002,
+ 11003,
+ 11004,
+ 11005,
+ 11006,
+ 11007,
+ 11008,
+ 11009,
+ 11010,
+ 11011,
+ 11012,
+ 11013,
+ 11014,
+ 11015,
+ 11016,
+ 11017,
+ 11018,
+ 11019,
+ 11020,
+ 11021,
+ 11022,
+ 11023,
+ 11024,
+ 11025,
+ 11026,
+ 11027,
+ 11028,
+ 11029,
+ 11030,
+ 11031,
+ 11032,
+ 11033,
+ 11034,
+ 11035,
+ 11036,
+ 11037,
+ 11038,
+ 11039,
+ 11040,
+ 11041,
+ 11042,
+ 11043,
+ 11044,
+ 11045,
+ 11046,
+ 11047,
+ 11048,
+ 11049,
+ 11050,
+ 11051,
+ 11052,
+ 11053,
+ 11054,
+ 11055,
+ 11056,
+ 11057,
+ 11058,
+ 11059,
+ 11060,
+ 11061,
+ 11062,
+ 11063,
+ 11064,
+ 11065,
+ 11066,
+ 11067,
+ 11068,
+ 11069,
+ 11070,
+ 11071,
+ 11072,
+ 11073,
+ 11074,
+ 11075,
+ 11076,
+ 11077,
+ 11078,
+ 11079,
+ 11080,
+ 11081,
+ 11082,
+ 11083,
+ 11084,
+ 11085,
+ 11086,
+ 11087,
+ 11088,
+ 11089,
+ 11090,
+ 11091,
+ 11092,
+ 11093,
+ 11094,
+ 11095,
+ 11096,
+ 11097,
+ 11098,
+ 11099,
+ 11100,
+ 11101,
+ 11102,
+ 11103,
+ 11104,
+ 11105,
+ 11106,
+ 11107,
+ 11108,
+ 11109,
+ 11110,
+ 11111,
+ 11112,
+ 11113,
+ 11114,
+ 11115,
+ 11116,
+ 11117,
+ 11118,
+ 11119,
+ 11120,
+ 11121,
+ 11122,
+ 11123,
+ 11124,
+ 11125,
+ 11126,
+ 11127,
+ 11128,
+ 11129,
+ 11130,
+ 11131,
+ 11132,
+ 11133,
+ 11134,
+ 11135,
+ 11136,
+ 11137,
+ 11138,
+ 11139,
+ 11140,
+ 11141,
+ 11142,
+ 11143,
+ 11144,
+ 11145,
+ 11146,
+ 11147,
+ 11148,
+ 11149,
+ 11150,
+ 11151,
+ 11152,
+ 11153,
+ 11154,
+ 11155,
+ 11156,
+ 11157,
+ 11158,
+ 11159,
+ 11160,
+ 11161,
+ 11162,
+ 11163,
+ 11164,
+ 11165,
+ 11166,
+ 11167,
+ 11168,
+ 11169,
+ 11170,
+ 11171,
+ 11172,
+ 11173,
+ 11174,
+ 11175,
+ 11176,
+ 11177,
+ 11178,
+ 11179,
+ 11180,
+ 11181,
+ 11182,
+ 11183,
+ 11184,
+ 11185,
+ 11186,
+ 11187,
+ 11188,
+ 11189,
+ 11190,
+ 11191,
+ 11192,
+ 11193,
+ 11194,
+ 11195,
+ 11196,
+ 11197,
+ 11198,
+ 11199,
+ 11200,
+ 11201,
+ 11202,
+ 11203,
+ 11204,
+ 11205,
+ 11206,
+ 11207,
+ 11208,
+ 11209,
+ 11210,
+ 11211,
+ 11212,
+ 11213,
+ 11214,
+ 11215,
+ 11216,
+ 11217,
+ 11218,
+ 11219,
+ 11220,
+ 11221,
+ 11222,
+ 11223,
+ 11224,
+ 11225,
+ 11226,
+ 11227,
+ 11228,
+ 11229,
+ 11230,
+ 11231,
+ 11232,
+ 11233,
+ 11234,
+ 11235,
+ 11236,
+ 11237,
+ 11238,
+ 11239,
+ 11240,
+ 11241,
+ 11242,
+ 11243,
+ 11244,
+ 11245,
+ 11246,
+ 11247,
+ 11248,
+ 11249,
+ 11250,
+ 11251,
+ 11252,
+ 11253,
+ 11254,
+ 11255,
+ 11256,
+ 11257,
+ 11258,
+ 11259,
+ 11260,
+ 11261,
+ 11262,
+ 11263,
+ 11264,
+ 11265,
+ 11266,
+ 11267,
+ 11268,
+ 11269,
+ 11270,
+ 11271,
+ 11272,
+ 11273,
+ 11274,
+ 11275,
+ 11276,
+ 11277,
+ 11278,
+ 11279,
+ 11280,
+ 11281,
+ 11282,
+ 11283,
+ 11284,
+ 11285,
+ 11286,
+ 11287,
+ 11288,
+ 11289,
+ 11290,
+ 11291,
+ 11292,
+ 11293,
+ 11294,
+ 11295,
+ 11296,
+ 11297,
+ 11298,
+ 11299,
+ 11300,
+ 11301,
+ 11302,
+ 11303,
+ 11304,
+ 11305,
+ 11306,
+ 11307,
+ 11308,
+ 11309,
+ 11310,
+ 11311,
+ 11312,
+ 11313,
+ 11314,
+ 11315,
+ 11316,
+ 11317,
+ 11318,
+ 11319,
+ 11320,
+ 11321,
+ 11322,
+ 11323,
+ 11324,
+ 11325,
+ 11326,
+ 11327,
+ 11328,
+ 11329,
+ 11330,
+ 11331,
+ 11332,
+ 11333,
+ 11334,
+ 11335,
+ 11336,
+ 11337,
+ 11338,
+ 11339,
+ 11340,
+ 11341,
+ 11342,
+ 11343,
+ 11344,
+ 11345,
+ 11346,
+ 11347,
+ 11348,
+ 11349,
+ 11350,
+ 11351,
+ 11352,
+ 11353,
+ 11354,
+ 11355,
+ 11356,
+ 11357,
+ 11358,
+ 11359,
+ 11360,
+ 11361,
+ 11362,
+ 11363,
+ 11364,
+ 11365,
+ 11366,
+ 11367,
+ 11368,
+ 11369,
+ 11370,
+ 11371,
+ 11372,
+ 11373,
+ 11374,
+ 11375,
+ 11376,
+ 11377,
+ 11378,
+ 11379,
+ 11380,
+ 11381,
+ 11382,
+ 11383,
+ 11384,
+ 11385,
+ 11386,
+ 11387,
+ 11388,
+ 11389,
+ 11390,
+ 11391,
+ 11392,
+ 11393,
+ 11394,
+ 11395,
+ 11396,
+ 11397,
+ 11398,
+ 11399,
+ 11400,
+ 11401,
+ 11402,
+ 11403,
+ 11404,
+ 11405,
+ 11406,
+ 11407,
+ 11408,
+ 11409,
+ 11410,
+ 11411,
+ 11412,
+ 11413,
+ 11414,
+ 11415,
+ 11416,
+ 11417,
+ 11418,
+ 11419,
+ 11420,
+ 11421,
+ 11422,
+ 11423,
+ 11424,
+ 11425,
+ 11426,
+ 11427,
+ 11428,
+ 11429,
+ 11430,
+ 11431,
+ 11432,
+ 11433,
+ 11434,
+ 11435,
+ 11436,
+ 11437,
+ 11438,
+ 11439,
+ 11440,
+ 11441,
+ 11442,
+ 11443,
+ 11444,
+ 11445,
+ 11446,
+ 11447,
+ 11448,
+ 11449,
+ 11450,
+ 11451,
+ 11452,
+ 11453,
+ 11454,
+ 11455,
+ 11456,
+ 11457,
+ 11458,
+ 11459,
+ 11460,
+ 11461,
+ 11462,
+ 11463,
+ 11464,
+ 11465,
+ 11466,
+ 11467,
+ 11468,
+ 11469,
+ 11470,
+ 11471,
+ 11472,
+ 11473,
+ 11474,
+ 11475,
+ 11476,
+ 11477,
+ 11478,
+ 11479,
+ 11480,
+ 11481,
+ 11482,
+ 11483,
+ 11484,
+ 11485,
+ 11486,
+ 11487,
+ 11488,
+ 11489,
+ 11490,
+ 11491,
+ 11492,
+ 11493,
+ 11494,
+ 11495,
+ 11496,
+ 11497,
+ 11498,
+ 11499,
+ 11500,
+ 11501,
+ 11502,
+ 11503,
+ 11504,
+ 11505,
+ 11506,
+ 11507,
+ 11508,
+ 11509,
+ 11510,
+ 11511,
+ 11512,
+ 11513,
+ 11514,
+ 11515,
+ 11516,
+ 11517,
+ 11518,
+ 11519,
+ 11520,
+ 11521,
+ 11522,
+ 11523,
+ 11524,
+ 11525,
+ 11526,
+ 11527,
+ 11528,
+ 11529,
+ 11530,
+ 11531,
+ 11532,
+ 11533,
+ 11534,
+ 11535,
+ 11536,
+ 11537,
+ 11538,
+ 11539,
+ 11540,
+ 11541,
+ 11542,
+ 11543,
+ 11544,
+ 11545,
+ 11546,
+ 11547,
+ 11548,
+ 11549,
+ 11550,
+ 11551,
+ 11552,
+ 11553,
+ 11554,
+ 11555,
+ 11556,
+ 11557,
+ 11558,
+ 11559,
+ 11560,
+ 11561,
+ 11562,
+ 11563,
+ 11564,
+ 11565,
+ 11566,
+ 11567,
+ 11568,
+ 11569,
+ 11570,
+ 11571,
+ 11572,
+ 11573,
+ 11574,
+ 11575,
+ 11576,
+ 11577,
+ 11578,
+ 11579,
+ 11580,
+ 11581,
+ 11582,
+ 11583,
+ 11584,
+ 11585,
+ 11586,
+ 11587,
+ 11588,
+ 11589,
+ 11590,
+ 11591,
+ 11592,
+ 11593,
+ 11594,
+ 11595,
+ 11596,
+ 11597,
+ 11598,
+ 11599,
+ 11600,
+ 11601,
+ 11602,
+ 11603,
+ 11604,
+ 11605,
+ 11606,
+ 11607,
+ 11608,
+ 11609,
+ 11610,
+ 11611,
+ 11612,
+ 11613,
+ 11614,
+ 11615,
+ 11616,
+ 11617,
+ 11618,
+ 11619,
+ 11620,
+ 11621,
+ 11622,
+ 11623,
+ 11624,
+ 11625,
+ 11626,
+ 11627,
+ 11628,
+ 11629,
+ 11630,
+ 11631,
+ 11632,
+ 11633,
+ 11634,
+ 11635,
+ 11636,
+ 11637,
+ 11638,
+ 11639,
+ 11640,
+ 11641,
+ 11642,
+ 11643,
+ 11644,
+ 11645,
+ 11646,
+ 11647,
+ 11648,
+ 11649,
+ 11650,
+ 11651,
+ 11652,
+ 11653,
+ 11654,
+ 11655,
+ 11656,
+ 11657,
+ 11658,
+ 11659,
+ 11660,
+ 11661,
+ 11662,
+ 11663,
+ 11664,
+ 11665,
+ 11666,
+ 11667,
+ 11668,
+ 11669,
+ 11670,
+ 11671,
+ 11672,
+ 11673,
+ 11674,
+ 11675,
+ 11676,
+ 11677,
+ 11678,
+ 11679,
+ 11680,
+ 11681,
+ 11682,
+ 11683,
+ 11684,
+ 11685,
+ 11686,
+ 11687,
+ 11688,
+ 11689,
+ 11690,
+ 11691,
+ 11692,
+ 11693,
+ 11694,
+ 11695,
+ 11696,
+ 11697,
+ 11698,
+ 11699,
+ 11700,
+ 11701,
+ 11702,
+ 11703,
+ 11704,
+ 11705,
+ 11706,
+ 11707,
+ 11708,
+ 11709,
+ 11710,
+ 11711,
+ 11712,
+ 11713,
+ 11714,
+ 11715,
+ 11716,
+ 11717,
+ 11718,
+ 11719,
+ 11720,
+ 11721,
+ 11722,
+ 11723,
+ 11724,
+ 11725,
+ 11726,
+ 11727,
+ 11728,
+ 11729,
+ 11730,
+ 11731,
+ 11732,
+ 11733,
+ 11734,
+ 11735,
+ 11736,
+ 11737,
+ 11738,
+ 11739,
+ 11740,
+ 11741,
+ 11742,
+ 11743,
+ 11744,
+ 11745,
+ 11746,
+ 11747,
+ 11748,
+ 11749,
+ 11750,
+ 11751,
+ 11752,
+ 11753,
+ 11754,
+ 11755,
+ 11756,
+ 11757,
+ 11758,
+ 11759,
+ 11760,
+ 11761,
+ 11762,
+ 11763,
+ 11764,
+ 11765,
+ 11766,
+ 11767,
+ 11768,
+ 11769,
+ 11770,
+ 11771,
+ 11772,
+ 11773,
+ 11774,
+ 11775,
+ 11776,
+ 11777,
+ 11778,
+ 11779,
+ 11780,
+ 11781,
+ 11782,
+ 11783,
+ 11784,
+ 11785,
+ 11786,
+ 11787,
+ 11788,
+ 11789,
+ 11790,
+ 11791,
+ 11792,
+ 11793,
+ 11794,
+ 11795,
+ 11796,
+ 11797,
+ 11798,
+ 11799,
+ 11800,
+ 11801,
+ 11802,
+ 11803,
+ 11804,
+ 11805,
+ 11806,
+ 11807,
+ 11808,
+ 11809,
+ 11810,
+ 11811,
+ 11812,
+ 11813,
+ 11814,
+ 11815,
+ 11816,
+ 11817,
+ 11818,
+ 11819,
+ 11820,
+ 11821,
+ 11822,
+ 11823,
+ 11824,
+ 11825,
+ 11826,
+ 11827,
+ 11828,
+ 11829,
+ 11830,
+ 11831,
+ 11832,
+ 11833,
+ 11834,
+ 11835,
+ 11836,
+ 11837,
+ 11838,
+ 11839,
+ 11840,
+ 11841,
+ 11842,
+ 11843,
+ 11844,
+ 11845,
+ 11846,
+ 11847,
+ 11848,
+ 11849,
+ 11850,
+ 11851,
+ 11852,
+ 11853,
+ 11854,
+ 11855,
+ 11856,
+ 11857,
+ 11858,
+ 11859,
+ 11860,
+ 11861,
+ 11862,
+ 11863,
+ 11864,
+ 11865,
+ 11866,
+ 11867,
+ 11868,
+ 11869,
+ 11870,
+ 11871,
+ 11872,
+ 11873,
+ 11874,
+ 11875,
+ 11876,
+ 11877,
+ 11878,
+ 11879,
+ 11880,
+ 11881,
+ 11882,
+ 11883,
+ 11884,
+ 11885,
+ 11886,
+ 11887,
+ 11888,
+ 11889,
+ 11890,
+ 11891,
+ 11892,
+ 11893,
+ 11894,
+ 11895,
+ 11896,
+ 11897,
+ 11898,
+ 11899,
+ 11900,
+ 11901,
+ 11902,
+ 11903,
+ 11904,
+ 11905,
+ 11906,
+ 11907,
+ 11908,
+ 11909,
+ 11910,
+ 11911,
+ 11912,
+ 11913,
+ 11914,
+ 11915,
+ 11916,
+ 11917,
+ 11918,
+ 11919,
+ 11920,
+ 11921,
+ 11922,
+ 11923,
+ 11924,
+ 11925,
+ 11926,
+ 11927,
+ 11928,
+ 11929,
+ 11930,
+ 11931,
+ 11932,
+ 11933,
+ 11934,
+ 11935,
+ 11936,
+ 11937,
+ 11938,
+ 11939,
+ 11940,
+ 11941,
+ 11942,
+ 11943,
+ 11944,
+ 11945,
+ 11946,
+ 11947,
+ 11948,
+ 11949,
+ 11950,
+ 11951,
+ 11952,
+ 11953,
+ 11954,
+ 11955,
+ 11956,
+ 11957,
+ 11958,
+ 11959,
+ 11960,
+ 11961,
+ 11962,
+ 11963,
+ 11964,
+ 11965,
+ 11966,
+ 11967,
+ 11968,
+ 11969,
+ 11970,
+ 11971,
+ 11972,
+ 11973,
+ 11974,
+ 11975,
+ 11976,
+ 11977,
+ 11978,
+ 11979,
+ 11980,
+ 11981,
+ 11982,
+ 11983,
+ 11984,
+ 11985,
+ 11986,
+ 11987,
+ 11988,
+ 11989,
+ 11990,
+ 11991,
+ 11992,
+ 11993,
+ 11994,
+ 11995,
+ 11996,
+ 11997,
+ 11998,
+ 11999,
+ 12000,
+ 12001,
+ 12002,
+ 12003,
+ 12004,
+ 12005,
+ 12006,
+ 12007,
+ 12008,
+ 12009,
+ 12010,
+ 12011,
+ 12012,
+ 12013,
+ 12014,
+ 12015,
+ 12016,
+ 12017,
+ 12018,
+ 12019,
+ 12020,
+ 12021,
+ 12022,
+ 12023,
+ 12024,
+ 12025,
+ 12026,
+ 12027,
+ 12028,
+ 12029,
+ 12030,
+ 12031,
+ 12032,
+ 12033,
+ 12034,
+ 12035,
+ 12036,
+ 12037,
+ 12038,
+ 12039,
+ 12040,
+ 12041,
+ 12042,
+ 12043,
+ 12044,
+ 12045,
+ 12046,
+ 12047,
+ 12048,
+ 12049,
+ 12050,
+ 12051,
+ 12052,
+ 12053,
+ 12054,
+ 12055,
+ 12056,
+ 12057,
+ 12058,
+ 12059,
+ 12060,
+ 12061,
+ 12062,
+ 12063,
+ 12064,
+ 12065,
+ 12066,
+ 12067,
+ 12068,
+ 12069,
+ 12070,
+ 12071,
+ 12072,
+ 12073,
+ 12074,
+ 12075,
+ 12076,
+ 12077,
+ 12078,
+ 12079,
+ 12080,
+ 12081,
+ 12082,
+ 12083,
+ 12084,
+ 12085,
+ 12086,
+ 12087,
+ 12088,
+ 12089,
+ 12090,
+ 12091,
+ 12092,
+ 12093,
+ 12094,
+ 12095,
+ 12096,
+ 12097,
+ 12098,
+ 12099,
+ 12100,
+ 12101,
+ 12102,
+ 12103,
+ 12104,
+ 12105,
+ 12106,
+ 12107,
+ 12108,
+ 12109,
+ 12110,
+ 12111,
+ 12112,
+ 12113,
+ 12114,
+ 12115,
+ 12116,
+ 12117,
+ 12118,
+ 12119,
+ 12120,
+ 12121,
+ 12122,
+ 12123,
+ 12124,
+ 12125,
+ 12126,
+ 12127,
+ 12128,
+ 12129,
+ 12130,
+ 12131,
+ 12132,
+ 12133,
+ 12134,
+ 12135,
+ 12136,
+ 12137,
+ 12138,
+ 12139,
+ 12140,
+ 12141,
+ 12142,
+ 12143,
+ 12144,
+ 12145,
+ 12146,
+ 12147,
+ 12148,
+ 12149,
+ 12150,
+ 12151,
+ 12152,
+ 12153,
+ 12154,
+ 12155,
+ 12156,
+ 12157,
+ 12158,
+ 12159,
+ 12160,
+ 12161,
+ 12162,
+ 12163,
+ 12164,
+ 12165,
+ 12166,
+ 12167,
+ 12168,
+ 12169,
+ 12170,
+ 12171,
+ 12172,
+ 12173,
+ 12174,
+ 12175,
+ 12176,
+ 12177,
+ 12178,
+ 12179,
+ 12180,
+ 12181,
+ 12182,
+ 12183,
+ 12184,
+ 12185,
+ 12186,
+ 12187,
+ 12188,
+ 12189,
+ 12190,
+ 12191,
+ 12192,
+ 12193,
+ 12194,
+ 12195,
+ 12196,
+ 12197,
+ 12198,
+ 12199,
+ 12200,
+ 12201,
+ 12202,
+ 12203,
+ 12204,
+ 12205,
+ 12206,
+ 12207,
+ 12208,
+ 12209,
+ 12210,
+ 12211,
+ 12212,
+ 12213,
+ 12214,
+ 12215,
+ 12216,
+ 12217,
+ 12218,
+ 12219,
+ 12220,
+ 12221,
+ 12222,
+ 12223,
+ 12224,
+ 12225,
+ 12226,
+ 12227,
+ 12228,
+ 12229,
+ 12230,
+ 12231,
+ 12232,
+ 12233,
+ 12234,
+ 12235,
+ 12236,
+ 12237,
+ 12238,
+ 12239,
+ 12240,
+ 12241,
+ 12242,
+ 12243,
+ 12244,
+ 12245,
+ 12246,
+ 12247,
+ 12248,
+ 12249,
+ 12250,
+ 12251,
+ 12252,
+ 12253,
+ 12254,
+ 12255,
+ 12256,
+ 12257,
+ 12258,
+ 12259,
+ 12260,
+ 12261,
+ 12262,
+ 12263,
+ 12264,
+ 12265,
+ 12266,
+ 12267,
+ 12268,
+ 12269,
+ 12270,
+ 12271,
+ 12272,
+ 12273,
+ 12274,
+ 12275,
+ 12276,
+ 12277,
+ 12278,
+ 12279,
+ 12280,
+ 12281,
+ 12282,
+ 12283,
+ 12284,
+ 12285,
+ 12286,
+ 12287,
+ 12288,
+ 12289,
+ 12290,
+ 12291,
+ 12292,
+ 12293,
+ 12294,
+ 12295,
+ 12296,
+ 12297,
+ 12298,
+ 12299,
+ 12300,
+ 12301,
+ 12302,
+ 12303,
+ 12304,
+ 12305,
+ 12306,
+ 12307,
+ 12308,
+ 12309,
+ 12310,
+ 12311,
+ 12312,
+ 12313,
+ 12314,
+ 12315,
+ 12316,
+ 12317,
+ 12318,
+ 12319,
+ 12320,
+ 12321,
+ 12322,
+ 12323,
+ 12324,
+ 12325,
+ 12326,
+ 12327,
+ 12328,
+ 12329,
+ 12330,
+ 12331,
+ 12332,
+ 12333,
+ 12334,
+ 12335,
+ 12336,
+ 12337,
+ 12338,
+ 12339,
+ 12340,
+ 12341,
+ 12342,
+ 12343,
+ 12344,
+ 12345,
+ 12346,
+ 12347,
+ 12348,
+ 12349,
+ 12350,
+ 12351,
+ 12352,
+ 12353,
+ 12354,
+ 12355,
+ 12356,
+ 12357,
+ 12358,
+ 12359,
+ 12360,
+ 12361,
+ 12362,
+ 12363,
+ 12364,
+ 12365,
+ 12366,
+ 12367,
+ 12368,
+ 12369,
+ 12370,
+ 12371,
+ 12372,
+ 12373,
+ 12374,
+ 12375,
+ 12376,
+ 12377,
+ 12378,
+ 12379,
+ 12380,
+ 12381,
+ 12382,
+ 12383,
+ 12384,
+ 12385,
+ 12386,
+ 12387,
+ 12388,
+ 12389,
+ 12390,
+ 12391,
+ 12392,
+ 12393,
+ 12394,
+ 12395,
+ 12396,
+ 12397,
+ 12398,
+ 12399,
+ 12400,
+ 12401,
+ 12402,
+ 12403,
+ 12404,
+ 12405,
+ 12406,
+ 12407,
+ 12408,
+ 12409,
+ 12410,
+ 12411,
+ 12412,
+ 12413,
+ 12414,
+ 12415,
+ 12416,
+ 12417,
+ 12418,
+ 12419,
+ 12420,
+ 12421,
+ 12422,
+ 12423,
+ 12424,
+ 12425,
+ 12426,
+ 12427,
+ 12428,
+ 12429,
+ 12430,
+ 12431,
+ 12432,
+ 12433,
+ 12434,
+ 12435,
+ 12436,
+ 12437,
+ 12438,
+ 12439,
+ 12440,
+ 12441,
+ 12442,
+ 12443,
+ 12444,
+ 12445,
+ 12446,
+ 12447,
+ 12448,
+ 12449,
+ 12450,
+ 12451,
+ 12452,
+ 12453,
+ 12454,
+ 12455,
+ 12456,
+ 12457,
+ 12458,
+ 12459,
+ 12460,
+ 12461,
+ 12462,
+ 12463,
+ 12464,
+ 12465,
+ 12466,
+ 12467,
+ 12468,
+ 12469,
+ 12470,
+ 12471,
+ 12472,
+ 12473,
+ 12474,
+ 12475,
+ 12476,
+ 12477,
+ 12478,
+ 12479,
+ 12480,
+ 12481,
+ 12482,
+ 12483,
+ 12484,
+ 12485,
+ 12486,
+ 12487,
+ 12488,
+ 12489,
+ 12490,
+ 12491,
+ 12492,
+ 12493,
+ 12494,
+ 12495,
+ 12496,
+ 12497,
+ 12498,
+ 12499,
+ 12500,
+ 12501,
+ 12502,
+ 12503,
+ 12504,
+ 12505,
+ 12506,
+ 12507,
+ 12508,
+ 12509,
+ 12510,
+ 12511,
+ 12512,
+ 12513,
+ 12514,
+ 12515,
+ 12516,
+ 12517,
+ 12518,
+ 12519,
+ 12520,
+ 12521,
+ 12522,
+ 12523,
+ 12524,
+ 12525,
+ 12526,
+ 12527,
+ 12528,
+ 12529,
+ 12530,
+ 12531,
+ 12532,
+ 12533,
+ 12534,
+ 12535,
+ 12536,
+ 12537,
+ 12538,
+ 12539,
+ 12540,
+ 12541,
+ 12542,
+ 12543,
+ 12544,
+ 12545,
+ 12546,
+ 12547,
+ 12548,
+ 12549,
+ 12550,
+ 12551,
+ 12552,
+ 12553,
+ 12554,
+ 12555,
+ 12556,
+ 12557,
+ 12558,
+ 12559,
+ 12560,
+ 12561,
+ 12562,
+ 12563,
+ 12564,
+ 12565,
+ 12566,
+ 12567,
+ 12568,
+ 12569,
+ 12570,
+ 12571,
+ 12572,
+ 12573,
+ 12574,
+ 12575,
+ 12576,
+ 12577,
+ 12578,
+ 12579,
+ 12580,
+ 12581,
+ 12582,
+ 12583,
+ 12584,
+ 12585,
+ 12586,
+ 12587,
+ 12588,
+ 12589,
+ 12590,
+ 12591,
+ 12592,
+ 12593,
+ 12594,
+ 12595,
+ 12596,
+ 12597,
+ 12598,
+ 12599,
+ 12600,
+ 12601,
+ 12602,
+ 12603,
+ 12604,
+ 12605,
+ 12606,
+ 12607,
+ 12608,
+ 12609,
+ 12610,
+ 12611,
+ 12612,
+ 12613,
+ 12614,
+ 12615,
+ 12616,
+ 12617,
+ 12618,
+ 12619,
+ 12620,
+ 12621,
+ 12622,
+ 12623,
+ 12624,
+ 12625,
+ 12626,
+ 12627,
+ 12628,
+ 12629,
+ 12630,
+ 12631,
+ 12632,
+ 12633,
+ 12634,
+ 12635,
+ 12636,
+ 12637,
+ 12638,
+ 12639,
+ 12640,
+ 12641,
+ 12642,
+ 12643,
+ 12644,
+ 12645,
+ 12646,
+ 12647,
+ 12648,
+ 12649,
+ 12650,
+ 12651,
+ 12652,
+ 12653,
+ 12654,
+ 12655,
+ 12656,
+ 12657,
+ 12658,
+ 12659,
+ 12660,
+ 12661,
+ 12662,
+ 12663,
+ 12664,
+ 12665,
+ 12666,
+ 12667,
+ 12668,
+ 12669,
+ 12670,
+ 12671,
+ 12672,
+ 12673,
+ 12674,
+ 12675,
+ 12676,
+ 12677,
+ 12678,
+ 12679,
+ 12680,
+ 12681,
+ 12682,
+ 12683,
+ 12684,
+ 12685,
+ 12686,
+ 12687,
+ 12688,
+ 12689,
+ 12690,
+ 12691,
+ 12692,
+ 12693,
+ 12694,
+ 12695,
+ 12696,
+ 12697,
+ 12698,
+ 12699,
+ 12700,
+ 12701,
+ 12702,
+ 12703,
+ 12704,
+ 12705,
+ 12706,
+ 12707,
+ 12708,
+ 12709,
+ 12710,
+ 12711,
+ 12712,
+ 12713,
+ 12714,
+ 12715,
+ 12716,
+ 12717,
+ 12718,
+ 12719,
+ 12720,
+ 12721,
+ 12722,
+ 12723,
+ 12724,
+ 12725,
+ 12726,
+ 12727,
+ 12728,
+ 12729,
+ 12730,
+ 12731,
+ 12732,
+ 12733,
+ 12734,
+ 12735,
+ 12736,
+ 12737,
+ 12738,
+ 12739,
+ 12740,
+ 12741,
+ 12742,
+ 12743,
+ 12744,
+ 12745,
+ 12746,
+ 12747,
+ 12748,
+ 12749,
+ 12750,
+ 12751,
+ 12752,
+ 12753,
+ 12754,
+ 12755,
+ 12756,
+ 12757,
+ 12758,
+ 12759,
+ 12760,
+ 12761,
+ 12762,
+ 12763,
+ 12764,
+ 12765,
+ 12766,
+ 12767,
+ 12768,
+ 12769,
+ 12770,
+ 12771,
+ 12772,
+ 12773,
+ 12774,
+ 12775,
+ 12776,
+ 12777,
+ 12778,
+ 12779,
+ 12780,
+ 12781,
+ 12782,
+ 12783,
+ 12784,
+ 12785,
+ 12786,
+ 12787,
+ 12788,
+ 12789,
+ 12790,
+ 12791,
+ 12792,
+ 12793,
+ 12794,
+ 12795,
+ 12796,
+ 12797,
+ 12798,
+ 12799,
+ 12800,
+ 12801,
+ 12802,
+ 12803,
+ 12804,
+ 12805,
+ 12806,
+ 12807,
+ 12808,
+ 12809,
+ 12810,
+ 12811,
+ 12812,
+ 12813,
+ 12814,
+ 12815,
+ 12816,
+ 12817,
+ 12818,
+ 12819,
+ 12820,
+ 12821,
+ 12822,
+ 12823,
+ 12824,
+ 12825,
+ 12826,
+ 12827,
+ 12828,
+ 12829,
+ 12830,
+ 12831,
+ 12832,
+ 12833,
+ 12834,
+ 12835,
+ 12836,
+ 12837,
+ 12838,
+ 12839,
+ 12840,
+ 12841,
+ 12842,
+ 12843,
+ 12844,
+ 12845,
+ 12846,
+ 12847,
+ 12848,
+ 12849,
+ 12850,
+ 12851,
+ 12852,
+ 12853,
+ 12854,
+ 12855,
+ 12856,
+ 12857,
+ 12858,
+ 12859,
+ 12860,
+ 12861,
+ 12862,
+ 12863,
+ 12864,
+ 12865,
+ 12866,
+ 12867,
+ 12868,
+ 12869,
+ 12870,
+ 12871,
+ 12872,
+ 12873,
+ 12874,
+ 12875,
+ 12876,
+ 12877,
+ 12878,
+ 12879,
+ 12880,
+ 12881,
+ 12882,
+ 12883,
+ 12884,
+ 12885,
+ 12886,
+ 12887,
+ 12888,
+ 12889,
+ 12890,
+ 12891,
+ 12892,
+ 12893,
+ 12894,
+ 12895,
+ 12896,
+ 12897,
+ 12898,
+ 12899,
+ 12900,
+ 12901,
+ 12902,
+ 12903,
+ 12904,
+ 12905,
+ 12906,
+ 12907,
+ 12908,
+ 12909,
+ 12910,
+ 12911,
+ 12912,
+ 12913,
+ 12914,
+ 12915,
+ 12916,
+ 12917,
+ 12918,
+ 12919,
+ 12920,
+ 12921,
+ 12922,
+ 12923,
+ 12924,
+ 12925,
+ 12926,
+ 12927,
+ 12928,
+ 12929,
+ 12930,
+ 12931,
+ 12932,
+ 12933,
+ 12934,
+ 12935,
+ 12936,
+ 12937,
+ 12938,
+ 12939,
+ 12940,
+ 12941,
+ 12942,
+ 12943,
+ 12944,
+ 12945,
+ 12946,
+ 12947,
+ 12948,
+ 12949,
+ 12950,
+ 12951,
+ 12952,
+ 12953,
+ 12954,
+ 12955,
+ 12956,
+ 12957,
+ 12958,
+ 12959,
+ 12960,
+ 12961,
+ 12962,
+ 12963,
+ 12964,
+ 12965,
+ 12966,
+ 12967,
+ 12968,
+ 12969,
+ 12970,
+ 12971,
+ 12972,
+ 12973,
+ 12974,
+ 12975,
+ 12976,
+ 12977,
+ 12978,
+ 12979,
+ 12980,
+ 12981,
+ 12982,
+ 12983,
+ 12984,
+ 12985,
+ 12986,
+ 12987,
+ 12988,
+ 12989,
+ 12990,
+ 12991,
+ 12992,
+ 12993,
+ 12994,
+ 12995,
+ 12996,
+ 12997,
+ 12998,
+ 12999,
+ 13000,
+ 13001,
+ 13002,
+ 13003,
+ 13004,
+ 13005,
+ 13006,
+ 13007,
+ 13008,
+ 13009,
+ 13010,
+ 13011,
+ 13012,
+ 13013,
+ 13014,
+ 13015,
+ 13016,
+ 13017,
+ 13018,
+ 13019,
+ 13020,
+ 13021,
+ 13022,
+ 13023,
+ 13024,
+ 13025,
+ 13026,
+ 13027,
+ 13028,
+ 13029,
+ 13030,
+ 13031,
+ 13032,
+ 13033,
+ 13034,
+ 13035,
+ 13036,
+ 13037,
+ 13038,
+ 13039,
+ 13040,
+ 13041,
+ 13042,
+ 13043,
+ 13044,
+ 13045,
+ 13046,
+ 13047,
+ 13048,
+ 13049,
+ 13050,
+ 13051,
+ 13052,
+ 13053,
+ 13054,
+ 13055,
+ 13056,
+ 13057,
+ 13058,
+ 13059,
+ 13060,
+ 13061,
+ 13062,
+ 13063,
+ 13064,
+ 13065,
+ 13066,
+ 13067,
+ 13068,
+ 13069,
+ 13070,
+ 13071,
+ 13072,
+ 13073,
+ 13074,
+ 13075,
+ 13076,
+ 13077,
+ 13078,
+ 13079,
+ 13080,
+ 13081,
+ 13082,
+ 13083,
+ 13084,
+ 13085,
+ 13086,
+ 13087,
+ 13088,
+ 13089,
+ 13090,
+ 13091,
+ 13092,
+ 13093,
+ 13094,
+ 13095,
+ 13096,
+ 13097,
+ 13098,
+ 13099,
+ 13100,
+ 13101,
+ 13102,
+ 13103,
+ 13104,
+ 13105,
+ 13106,
+ 13107,
+ 13108,
+ 13109,
+ 13110,
+ 13111,
+ 13112,
+ 13113,
+ 13114,
+ 13115,
+ 13116,
+ 13117,
+ 13118,
+ 13119,
+ 13120,
+ 13121,
+ 13122,
+ 13123,
+ 13124,
+ 13125,
+ 13126,
+ 13127,
+ 13128,
+ 13129,
+ 13130,
+ 13131,
+ 13132,
+ 13133,
+ 13134,
+ 13135,
+ 13136,
+ 13137,
+ 13138,
+ 13139,
+ 13140,
+ 13141,
+ 13142,
+ 13143,
+ 13144,
+ 13145,
+ 13146,
+ 13147,
+ 13148,
+ 13149,
+ 13150,
+ 13151,
+ 13152,
+ 13153,
+ 13154,
+ 13155,
+ 13156,
+ 13157,
+ 13158,
+ 13159,
+ 13160,
+ 13161,
+ 13162,
+ 13163,
+ 13164,
+ 13165,
+ 13166,
+ 13167,
+ 13168,
+ 13169,
+ 13170,
+ 13171,
+ 13172,
+ 13173,
+ 13174,
+ 13175,
+ 13176,
+ 13177,
+ 13178,
+ 13179,
+ 13180,
+ 13181,
+ 13182,
+ 13183,
+ 13184,
+ 13185,
+ 13186,
+ 13187,
+ 13188,
+ 13189,
+ 13190,
+ 13191,
+ 13192,
+ 13193,
+ 13194,
+ 13195,
+ 13196,
+ 13197,
+ 13198,
+ 13199,
+ 13200,
+ 13201,
+ 13202,
+ 13203,
+ 13204,
+ 13205,
+ 13206,
+ 13207,
+ 13208,
+ 13209,
+ 13210,
+ 13211,
+ 13212,
+ 13213,
+ 13214,
+ 13215,
+ 13216,
+ 13217,
+ 13218,
+ 13219,
+ 13220,
+ 13221,
+ 13222,
+ 13223,
+ 13224,
+ 13225,
+ 13226,
+ 13227,
+ 13228,
+ 13229,
+ 13230,
+ 13231,
+ 13232,
+ 13233,
+ 13234,
+ 13235,
+ 13236,
+ 13237,
+ 13238,
+ 13239,
+ 13240,
+ 13241,
+ 13242,
+ 13243,
+ 13244,
+ 13245,
+ 13246,
+ 13247,
+ 13248,
+ 13249,
+ 13250,
+ 13251,
+ 13252,
+ 13253,
+ 13254,
+ 13255,
+ 13256,
+ 13257,
+ 13258,
+ 13259,
+ 13260,
+ 13261,
+ 13262,
+ 13263,
+ 13264,
+ 13265,
+ 13266,
+ 13267,
+ 13268,
+ 13269,
+ 13270,
+ 13271,
+ 13272,
+ 13273,
+ 13274,
+ 13275,
+ 13276,
+ 13277,
+ 13278,
+ 13279,
+ 13280,
+ 13281,
+ 13282,
+ 13283,
+ 13284,
+ 13285,
+ 13286,
+ 13287,
+ 13288,
+ 13289,
+ 13290,
+ 13291,
+ 13292,
+ 13293,
+ 13294,
+ 13295,
+ 13296,
+ 13297,
+ 13298,
+ 13299,
+ 13300,
+ 13301,
+ 13302,
+ 13303,
+ 13304,
+ 13305,
+ 13306,
+ 13307,
+ 13308,
+ 13309,
+ 13310,
+ 13311,
+ 13312,
+ 13313,
+ 13314,
+ 13315,
+ 13316,
+ 13317,
+ 13318,
+ 13319,
+ 13320,
+ 13321,
+ 13322,
+ 13323,
+ 13324,
+ 13325,
+ 13326,
+ 13327,
+ 13328,
+ 13329,
+ 13330,
+ 13331,
+ 13332,
+ 13333,
+ 13334,
+ 13335,
+ 13336,
+ 13337,
+ 13338,
+ 13339,
+ 13340,
+ 13341,
+ 13342,
+ 13343,
+ 13344,
+ 13345,
+ 13346,
+ 13347,
+ 13348,
+ 13349,
+ 13350,
+ 13351,
+ 13352,
+ 13353,
+ 13354,
+ 13355,
+ 13356,
+ 13357,
+ 13358,
+ 13359,
+ 13360,
+ 13361,
+ 13362,
+ 13363,
+ 13364,
+ 13365,
+ 13366,
+ 13367,
+ 13368,
+ 13369,
+ 13370,
+ 13371,
+ 13372,
+ 13373,
+ 13374,
+ 13375,
+ 13376,
+ 13377,
+ 13378,
+ 13379,
+ 13380,
+ 13381,
+ 13382,
+ 13383,
+ 13384,
+ 13385,
+ 13386,
+ 13387,
+ 13388,
+ 13389,
+ 13390,
+ 13391,
+ 13392,
+ 13393,
+ 13394,
+ 13395,
+ 13396,
+ 13397,
+ 13398,
+ 13399,
+ 13400,
+ 13401,
+ 13402,
+ 13403,
+ 13404,
+ 13405,
+ 13406,
+ 13407,
+ 13408,
+ 13409,
+ 13410,
+ 13411,
+ 13412,
+ 13413,
+ 13414,
+ 13415,
+ 13416,
+ 13417,
+ 13418,
+ 13419,
+ 13420,
+ 13421,
+ 13422,
+ 13423,
+ 13424,
+ 13425,
+ 13426,
+ 13427,
+ 13428,
+ 13429,
+ 13430,
+ 13431,
+ 13432,
+ 13433,
+ 13434,
+ 13435,
+ 13436,
+ 13437,
+ 13438,
+ 13439,
+ 13440,
+ 13441,
+ 13442,
+ 13443,
+ 13444,
+ 13445,
+ 13446,
+ 13447,
+ 13448,
+ 13449,
+ 13450,
+ 13451,
+ 13452,
+ 13453,
+ 13454,
+ 13455,
+ 13456,
+ 13457,
+ 13458,
+ 13459,
+ 13460,
+ 13461,
+ 13462,
+ 13463,
+ 13464,
+ 13465,
+ 13466,
+ 13467,
+ 13468,
+ 13469,
+ 13470,
+ 13471,
+ 13472,
+ 13473,
+ 13474,
+ 13475,
+ 13476,
+ 13477,
+ 13478,
+ 13479,
+ 13480,
+ 13481,
+ 13482,
+ 13483,
+ 13484,
+ 13485,
+ 13486,
+ 13487,
+ 13488,
+ 13489,
+ 13490,
+ 13491,
+ 13492,
+ 13493,
+ 13494,
+ 13495,
+ 13496,
+ 13497,
+ 13498,
+ 13499,
+ 13500,
+ 13501,
+ 13502,
+ 13503,
+ 13504,
+ 13505,
+ 13506,
+ 13507,
+ 13508,
+ 13509,
+ 13510,
+ 13511,
+ 13512,
+ 13513,
+ 13514,
+ 13515,
+ 13516,
+ 13517,
+ 13518,
+ 13519,
+ 13520,
+ 13521,
+ 13522,
+ 13523,
+ 13524,
+ 13525,
+ 13526,
+ 13527,
+ 13528,
+ 13529,
+ 13530,
+ 13531,
+ 13532,
+ 13533,
+ 13534,
+ 13535,
+ 13536,
+ 13537,
+ 13538,
+ 13539,
+ 13540,
+ 13541,
+ 13542,
+ 13543,
+ 13544,
+ 13545,
+ 13546,
+ 13547,
+ 13548,
+ 13549,
+ 13550,
+ 13551,
+ 13552,
+ 13553,
+ 13554,
+ 13555,
+ 13556,
+ 13557,
+ 13558,
+ 13559,
+ 13560,
+ 13561,
+ 13562,
+ 13563,
+ 13564,
+ 13565,
+ 13566,
+ 13567,
+ 13568,
+ 13569,
+ 13570,
+ 13571,
+ 13572,
+ 13573,
+ 13574,
+ 13575,
+ 13576,
+ 13577,
+ 13578,
+ 13579,
+ 13580,
+ 13581,
+ 13582,
+ 13583,
+ 13584,
+ 13585,
+ 13586,
+ 13587,
+ 13588,
+ 13589,
+ 13590,
+ 13591,
+ 13592,
+ 13593,
+ 13594,
+ 13595,
+ 13596,
+ 13597,
+ 13598,
+ 13599,
+ 13600,
+ 13601,
+ 13602,
+ 13603,
+ 13604,
+ 13605,
+ 13606,
+ 13607,
+ 13608,
+ 13609,
+ 13610,
+ 13611,
+ 13612,
+ 13613,
+ 13614,
+ 13615,
+ 13616,
+ 13617,
+ 13618,
+ 13619,
+ 13620,
+ 13621,
+ 13622,
+ 13623,
+ 13624,
+ 13625,
+ 13626,
+ 13627,
+ 13628,
+ 13629,
+ 13630,
+ 13631,
+ 13632,
+ 13633,
+ 13634,
+ 13635,
+ 13636,
+ 13637,
+ 13638,
+ 13639,
+ 13640,
+ 13641,
+ 13642,
+ 13643,
+ 13644,
+ 13645,
+ 13646,
+ 13647,
+ 13648,
+ 13649,
+ 13650,
+ 13651,
+ 13652,
+ 13653,
+ 13654,
+ 13655,
+ 13656,
+ 13657,
+ 13658,
+ 13659,
+ 13660,
+ 13661,
+ 13662,
+ 13663,
+ 13664,
+ 13665,
+ 13666,
+ 13667,
+ 13668,
+ 13669,
+ 13670,
+ 13671,
+ 13672,
+ 13673,
+ 13674,
+ 13675,
+ 13676,
+ 13677,
+ 13678,
+ 13679,
+ 13680,
+ 13681,
+ 13682,
+ 13683,
+ 13684,
+ 13685,
+ 13686,
+ 13687,
+ 13688,
+ 13689,
+ 13690,
+ 13691,
+ 13692,
+ 13693,
+ 13694,
+ 13695,
+ 13696,
+ 13697,
+ 13698,
+ 13699,
+ 13700,
+ 13701,
+ 13702,
+ 13703,
+ 13704,
+ 13705,
+ 13706,
+ 13707,
+ 13708,
+ 13709,
+ 13710,
+ 13711,
+ 13712,
+ 13713,
+ 13714,
+ 13715,
+ 13716,
+ 13717,
+ 13718,
+ 13719,
+ 13720,
+ 13721,
+ 13722,
+ 13723,
+ 13724,
+ 13725,
+ 13726,
+ 13727,
+ 13728,
+ 13729,
+ 13730,
+ 13731,
+ 13732,
+ 13733,
+ 13734,
+ 13735,
+ 13736,
+ 13737,
+ 13738,
+ 13739,
+ 13740,
+ 13741,
+ 13742,
+ 13743,
+ 13744,
+ 13745,
+ 13746,
+ 13747,
+ 13748,
+ 13749,
+ 13750,
+ 13751,
+ 13752,
+ 13753,
+ 13754,
+ 13755,
+ 13756,
+ 13757,
+ 13758,
+ 13759,
+ 13760,
+ 13761,
+ 13762,
+ 13763,
+ 13764,
+ 13765,
+ 13766,
+ 13767,
+ 13768,
+ 13769,
+ 13770,
+ 13771,
+ 13772,
+ 13773,
+ 13774,
+ 13775,
+ 13776,
+ 13777,
+ 13778,
+ 13779,
+ 13780,
+ 13781,
+ 13782,
+ 13783,
+ 13784,
+ 13785,
+ 13786,
+ 13787,
+ 13788,
+ 13789,
+ 13790,
+ 13791,
+ 13792,
+ 13793,
+ 13794,
+ 13795,
+ 13796,
+ 13797,
+ 13798,
+ 13799,
+ 13800,
+ 13801,
+ 13802,
+ 13803,
+ 13804,
+ 13805,
+ 13806,
+ 13807,
+ 13808,
+ 13809,
+ 13810,
+ 13811,
+ 13812,
+ 13813,
+ 13814,
+ 13815,
+ 13816,
+ 13817,
+ 13818,
+ 13819,
+ 13820,
+ 13821,
+ 13822,
+ 13823,
+ 13824,
+ 13825,
+ 13826,
+ 13827,
+ 13828,
+ 13829,
+ 13830,
+ 13831,
+ 13832,
+ 13833,
+ 13834,
+ 13835,
+ 13836,
+ 13837,
+ 13838,
+ 13839,
+ 13840,
+ 13841,
+ 13842,
+ 13843,
+ 13844,
+ 13845,
+ 13846,
+ 13847,
+ 13848,
+ 13849,
+ 13850,
+ 13851,
+ 13852,
+ 13853,
+ 13854,
+ 13855,
+ 13856,
+ 13857,
+ 13858,
+ 13859,
+ 13860,
+ 13861,
+ 13862,
+ 13863,
+ 13864,
+ 13865,
+ 13866,
+ 13867,
+ 13868,
+ 13869,
+ 13870,
+ 13871,
+ 13872,
+ 13873,
+ 13874,
+ 13875,
+ 13876,
+ 13877,
+ 13878,
+ 13879,
+ 13880,
+ 13881,
+ 13882,
+ 13883,
+ 13884,
+ 13885,
+ 13886,
+ 13887,
+ 13888,
+ 13889,
+ 13890,
+ 13891,
+ 13892,
+ 13893,
+ 13894,
+ 13895,
+ 13896,
+ 13897,
+ 13898,
+ 13899,
+ 13900,
+ 13901,
+ 13902,
+ 13903,
+ 13904,
+ 13905,
+ 13906,
+ 13907,
+ 13908,
+ 13909,
+ 13910,
+ 13911,
+ 13912,
+ 13913,
+ 13914,
+ 13915,
+ 13916,
+ 13917,
+ 13918,
+ 13919,
+ 13920,
+ 13921,
+ 13922,
+ 13923,
+ 13924,
+ 13925,
+ 13926,
+ 13927,
+ 13928,
+ 13929,
+ 13930,
+ 13931,
+ 13932,
+ 13933,
+ 13934,
+ 13935,
+ 13936,
+ 13937,
+ 13938,
+ 13939,
+ 13940,
+ 13941,
+ 13942,
+ 13943,
+ 13944,
+ 13945,
+ 13946,
+ 13947,
+ 13948,
+ 13949,
+ 13950,
+ 13951,
+ 13952,
+ 13953,
+ 13954,
+ 13955,
+ 13956,
+ 13957,
+ 13958,
+ 13959,
+ 13960,
+ 13961,
+ 13962,
+ 13963,
+ 13964,
+ 13965,
+ 13966,
+ 13967,
+ 13968,
+ 13969,
+ 13970,
+ 13971,
+ 13972,
+ 13973,
+ 13974,
+ 13975,
+ 13976,
+ 13977,
+ 13978,
+ 13979,
+ 13980,
+ 13981,
+ 13982,
+ 13983,
+ 13984,
+ 13985,
+ 13986,
+ 13987,
+ 13988,
+ 13989,
+ 13990,
+ 13991,
+ 13992,
+ 13993,
+ 13994,
+ 13995,
+ 13996,
+ 13997,
+ 13998,
+ 13999,
+ 14000,
+ 14001,
+ 14002,
+ 14003,
+ 14004,
+ 14005,
+ 14006,
+ 14007,
+ 14008,
+ 14009,
+ 14010,
+ 14011,
+ 14012,
+ 14013,
+ 14014,
+ 14015,
+ 14016,
+ 14017,
+ 14018,
+ 14019,
+ 14020,
+ 14021,
+ 14022,
+ 14023,
+ 14024,
+ 14025,
+ 14026,
+ 14027,
+ 14028,
+ 14029,
+ 14030,
+ 14031,
+ 14032,
+ 14033,
+ 14034,
+ 14035,
+ 14036,
+ 14037,
+ 14038,
+ 14039,
+ 14040,
+ 14041,
+ 14042,
+ 14043,
+ 14044,
+ 14045,
+ 14046,
+ 14047,
+ 14048,
+ 14049,
+ 14050,
+ 14051,
+ 14052,
+ 14053,
+ 14054,
+ 14055,
+ 14056,
+ 14057,
+ 14058,
+ 14059,
+ 14060,
+ 14061,
+ 14062,
+ 14063,
+ 14064,
+ 14065,
+ 14066,
+ 14067,
+ 14068,
+ 14069,
+ 14070,
+ 14071,
+ 14072,
+ 14073,
+ 14074,
+ 14075,
+ 14076,
+ 14077,
+ 14078,
+ 14079,
+ 14080,
+ 14081,
+ 14082,
+ 14083,
+ 14084,
+ 14085,
+ 14086,
+ 14087,
+ 14088,
+ 14089,
+ 14090,
+ 14091,
+ 14092,
+ 14093,
+ 14094,
+ 14095,
+ 14096,
+ 14097,
+ 14098,
+ 14099,
+ 14100,
+ 14101,
+ 14102,
+ 14103,
+ 14104,
+ 14105,
+ 14106,
+ 14107,
+ 14108,
+ 14109,
+ 14110,
+ 14111,
+ 14112,
+ 14113,
+ 14114,
+ 14115,
+ 14116,
+ 14117,
+ 14118,
+ 14119,
+ 14120,
+ 14121,
+ 14122,
+ 14123,
+ 14124,
+ 14125,
+ 14126,
+ 14127,
+ 14128,
+ 14129,
+ 14130,
+ 14131,
+ 14132,
+ 14133,
+ 14134,
+ 14135,
+ 14136,
+ 14137,
+ 14138,
+ 14139,
+ 14140,
+ 14141,
+ 14142,
+ 14143,
+ 14144,
+ 14145,
+ 14146,
+ 14147,
+ 14148,
+ 14149,
+ 14150,
+ 14151,
+ 14152,
+ 14153,
+ 14154,
+ 14155,
+ 14156,
+ 14157,
+ 14158,
+ 14159,
+ 14160,
+ 14161,
+ 14162,
+ 14163,
+ 14164,
+ 14165,
+ 14166,
+ 14167,
+ 14168,
+ 14169,
+ 14170,
+ 14171,
+ 14172,
+ 14173,
+ 14174,
+ 14175,
+ 14176,
+ 14177,
+ 14178,
+ 14179,
+ 14180,
+ 14181,
+ 14182,
+ 14183,
+ 14184,
+ 14185,
+ 14186,
+ 14187,
+ 14188,
+ 14189,
+ 14190,
+ 14191,
+ 14192,
+ 14193,
+ 14194,
+ 14195,
+ 14196,
+ 14197,
+ 14198,
+ 14199,
+ 14200,
+ 14201,
+ 14202,
+ 14203,
+ 14204,
+ 14205,
+ 14206,
+ 14207,
+ 14208,
+ 14209,
+ 14210,
+ 14211,
+ 14212,
+ 14213,
+ 14214,
+ 14215,
+ 14216,
+ 14217,
+ 14218,
+ 14219,
+ 14220,
+ 14221,
+ 14222,
+ 14223,
+ 14224,
+ 14225,
+ 14226,
+ 14227,
+ 14228,
+ 14229,
+ 14230,
+ 14231,
+ 14232,
+ 14233,
+ 14234,
+ 14235,
+ 14236,
+ 14237,
+ 14238,
+ 14239,
+ 14240,
+ 14241,
+ 14242,
+ 14243,
+ 14244,
+ 14245,
+ 14246,
+ 14247,
+ 14248,
+ 14249,
+ 14250,
+ 14251,
+ 14252,
+ 14253,
+ 14254,
+ 14255,
+ 14256,
+ 14257,
+ 14258,
+ 14259,
+ 14260,
+ 14261,
+ 14262,
+ 14263,
+ 14264,
+ 14265,
+ 14266,
+ 14267,
+ 14268,
+ 14269,
+ 14270,
+ 14271,
+ 14272,
+ 14273,
+ 14274,
+ 14275,
+ 14276,
+ 14277,
+ 14278,
+ 14279,
+ 14280,
+ 14281,
+ 14282,
+ 14283,
+ 14284,
+ 14285,
+ 14286,
+ 14287,
+ 14288,
+ 14289,
+ 14290,
+ 14291,
+ 14292,
+ 14293,
+ 14294,
+ 14295,
+ 14296,
+ 14297,
+ 14298,
+ 14299,
+ 14300,
+ 14301,
+ 14302,
+ 14303,
+ 14304,
+ 14305,
+ 14306,
+ 14307,
+ 14308,
+ 14309,
+ 14310,
+ 14311,
+ 14312,
+ 14313,
+ 14314,
+ 14315,
+ 14316,
+ 14317,
+ 14318,
+ 14319,
+ 14320,
+ 14321,
+ 14322,
+ 14323,
+ 14324,
+ 14325,
+ 14326,
+ 14327,
+ 14328,
+ 14329,
+ 14330,
+ 14331,
+ 14332,
+ 14333,
+ 14334,
+ 14335,
+ 14336,
+ 14337,
+ 14338,
+ 14339,
+ 14340,
+ 14341,
+ 14342,
+ 14343,
+ 14344,
+ 14345,
+ 14346,
+ 14347,
+ 14348,
+ 14349,
+ 14350,
+ 14351,
+ 14352,
+ 14353,
+ 14354,
+ 14355,
+ 14356,
+ 14357,
+ 14358,
+ 14359,
+ 14360,
+ 14361,
+ 14362,
+ 14363,
+ 14364,
+ 14365,
+ 14366,
+ 14367,
+ 14368,
+ 14369,
+ 14370,
+ 14371,
+ 14372,
+ 14373,
+ 14374,
+ 14375,
+ 14376,
+ 14377,
+ 14378,
+ 14379,
+ 14380,
+ 14381,
+ 14382,
+ 14383,
+ 14384,
+ 14385,
+ 14386,
+ 14387,
+ 14388,
+ 14389,
+ 14390,
+ 14391,
+ 14392,
+ 14393,
+ 14394,
+ 14395,
+ 14396,
+ 14397,
+ 14398,
+ 14399,
+ 14400,
+ 14401,
+ 14402,
+ 14403,
+ 14404,
+ 14405,
+ 14406,
+ 14407,
+ 14408,
+ 14409,
+ 14410,
+ 14411,
+ 14412,
+ 14413,
+ 14414,
+ 14415,
+ 14416,
+ 14417,
+ 14418,
+ 14419,
+ 14420,
+ 14421,
+ 14422,
+ 14423,
+ 14424,
+ 14425,
+ 14426,
+ 14427,
+ 14428,
+ 14429,
+ 14430,
+ 14431,
+ 14432,
+ 14433,
+ 14434,
+ 14435,
+ 14436,
+ 14437,
+ 14438,
+ 14439,
+ 14440,
+ 14441,
+ 14442,
+ 14443,
+ 14444,
+ 14445,
+ 14446,
+ 14447,
+ 14448,
+ 14449,
+ 14450,
+ 14451,
+ 14452,
+ 14453,
+ 14454,
+ 14455,
+ 14456,
+ 14457,
+ 14458,
+ 14459,
+ 14460,
+ 14461,
+ 14462,
+ 14463,
+ 14464,
+ 14465,
+ 14466,
+ 14467,
+ 14468,
+ 14469,
+ 14470,
+ 14471,
+ 14472,
+ 14473,
+ 14474,
+ 14475,
+ 14476,
+ 14477,
+ 14478,
+ 14479,
+ 14480,
+ 14481,
+ 14482,
+ 14483,
+ 14484,
+ 14485,
+ 14486,
+ 14487,
+ 14488,
+ 14489,
+ 14490,
+ 14491,
+ 14492,
+ 14493,
+ 14494,
+ 14495,
+ 14496,
+ 14497,
+ 14498,
+ 14499,
+ 14500,
+ 14501,
+ 14502,
+ 14503,
+ 14504,
+ 14505,
+ 14506,
+ 14507,
+ 14508,
+ 14509,
+ 14510,
+ 14511,
+ 14512,
+ 14513,
+ 14514,
+ 14515,
+ 14516,
+ 14517,
+ 14518,
+ 14519,
+ 14520,
+ 14521,
+ 14522,
+ 14523,
+ 14524,
+ 14525,
+ 14526,
+ 14527,
+ 14528,
+ 14529,
+ 14530,
+ 14531,
+ 14532,
+ 14533,
+ 14534,
+ 14535,
+ 14536,
+ 14537,
+ 14538,
+ 14539,
+ 14540,
+ 14541,
+ 14542,
+ 14543,
+ 14544,
+ 14545,
+ 14546,
+ 14547,
+ 14548,
+ 14549,
+ 14550,
+ 14551,
+ 14552,
+ 14553,
+ 14554,
+ 14555,
+ 14556,
+ 14557,
+ 14558,
+ 14559,
+ 14560,
+ 14561,
+ 14562,
+ 14563,
+ 14564,
+ 14565,
+ 14566,
+ 14567,
+ 14568,
+ 14569,
+ 14570,
+ 14571,
+ 14572,
+ 14573,
+ 14574,
+ 14575,
+ 14576,
+ 14577,
+ 14578,
+ 14579,
+ 14580,
+ 14581,
+ 14582,
+ 14583,
+ 14584,
+ 14585,
+ 14586,
+ 14587,
+ 14588,
+ 14589,
+ 14590,
+ 14591,
+ 14592,
+ 14593,
+ 14594,
+ 14595,
+ 14596,
+ 14597,
+ 14598,
+ 14599,
+ 14600,
+ 14601,
+ 14602,
+ 14603,
+ 14604,
+ 14605,
+ 14606,
+ 14607,
+ 14608,
+ 14609,
+ 14610,
+ 14611,
+ 14612,
+ 14613,
+ 14614,
+ 14615,
+ 14616,
+ 14617,
+ 14618,
+ 14619,
+ 14620,
+ 14621,
+ 14622,
+ 14623,
+ 14624,
+ 14625,
+ 14626,
+ 14627,
+ 14628,
+ 14629,
+ 14630,
+ 14631,
+ 14632,
+ 14633,
+ 14634,
+ 14635,
+ 14636,
+ 14637,
+ 14638,
+ 14639,
+ 14640,
+ 14641,
+ 14642,
+ 14643,
+ 14644,
+ 14645,
+ 14646,
+ 14647,
+ 14648,
+ 14649,
+ 14650,
+ 14651,
+ 14652,
+ 14653,
+ 14654,
+ 14655,
+ 14656,
+ 14657,
+ 14658,
+ 14659,
+ 14660,
+ 14661,
+ 14662,
+ 14663,
+ 14664,
+ 14665,
+ 14666,
+ 14667,
+ 14668,
+ 14669,
+ 14670,
+ 14671,
+ 14672,
+ 14673,
+ 14674,
+ 14675,
+ 14676,
+ 14677,
+ 14678,
+ 14679,
+ 14680,
+ 14681,
+ 14682,
+ 14683,
+ 14684,
+ 14685,
+ 14686,
+ 14687,
+ 14688,
+ 14689,
+ 14690,
+ 14691,
+ 14692,
+ 14693,
+ 14694,
+ 14695,
+ 14696,
+ 14697,
+ 14698,
+ 14699,
+ 14700,
+ 14701,
+ 14702,
+ 14703,
+ 14704,
+ 14705,
+ 14706,
+ 14707,
+ 14708,
+ 14709,
+ 14710,
+ 14711,
+ 14712,
+ 14713,
+ 14714,
+ 14715,
+ 14716,
+ 14717,
+ 14718,
+ 14719,
+ 14720,
+ 14721,
+ 14722,
+ 14723,
+ 14724,
+ 14725,
+ 14726,
+ 14727,
+ 14728,
+ 14729,
+ 14730,
+ 14731,
+ 14732,
+ 14733,
+ 14734,
+ 14735,
+ 14736,
+ 14737,
+ 14738,
+ 14739,
+ 14740,
+ 14741,
+ 14742,
+ 14743,
+ 14744,
+ 14745,
+ 14746,
+ 14747,
+ 14748,
+ 14749,
+ 14750,
+ 14751,
+ 14752,
+ 14753,
+ 14754,
+ 14755,
+ 14756,
+ 14757,
+ 14758,
+ 14759,
+ 14760,
+ 14761,
+ 14762,
+ 14763,
+ 14764,
+ 14765,
+ 14766,
+ 14767,
+ 14768,
+ 14769,
+ 14770,
+ 14771,
+ 14772,
+ 14773,
+ 14774,
+ 14775,
+ 14776,
+ 14777,
+ 14778,
+ 14779,
+ 14780,
+ 14781,
+ 14782,
+ 14783,
+ 14784,
+ 14785,
+ 14786,
+ 14787,
+ 14788,
+ 14789,
+ 14790,
+ 14791,
+ 14792,
+ 14793,
+ 14794,
+ 14795,
+ 14796,
+ 14797,
+ 14798,
+ 14799,
+ 14800,
+ 14801,
+ 14802,
+ 14803,
+ 14804,
+ 14805,
+ 14806,
+ 14807,
+ 14808,
+ 14809,
+ 14810,
+ 14811,
+ 14812,
+ 14813,
+ 14814,
+ 14815,
+ 14816,
+ 14817,
+ 14818,
+ 14819,
+ 14820,
+ 14821,
+ 14822,
+ 14823,
+ 14824,
+ 14825,
+ 14826,
+ 14827,
+ 14828,
+ 14829,
+ 14830,
+ 14831,
+ 14832,
+ 14833,
+ 14834,
+ 14835,
+ 14836,
+ 14837,
+ 14838,
+ 14839,
+ 14840,
+ 14841,
+ 14842,
+ 14843,
+ 14844,
+ 14845,
+ 14846,
+ 14847,
+ 14848,
+ 14849,
+ 14850,
+ 14851,
+ 14852,
+ 14853,
+ 14854,
+ 14855,
+ 14856,
+ 14857,
+ 14858,
+ 14859,
+ 14860,
+ 14861,
+ 14862,
+ 14863,
+ 14864,
+ 14865,
+ 14866,
+ 14867,
+ 14868,
+ 14869,
+ 14870,
+ 14871,
+ 14872,
+ 14873,
+ 14874,
+ 14875,
+ 14876,
+ 14877,
+ 14878,
+ 14879,
+ 14880,
+ 14881,
+ 14882,
+ 14883,
+ 14884,
+ 14885,
+ 14886,
+ 14887,
+ 14888,
+ 14889,
+ 14890,
+ 14891,
+ 14892,
+ 14893,
+ 14894,
+ 14895,
+ 14896,
+ 14897,
+ 14898,
+ 14899,
+ 14900,
+ 14901,
+ 14902,
+ 14903,
+ 14904,
+ 14905,
+ 14906,
+ 14907,
+ 14908,
+ 14909,
+ 14910,
+ 14911,
+ 14912,
+ 14913,
+ 14914,
+ 14915,
+ 14916,
+ 14917,
+ 14918,
+ 14919,
+ 14920,
+ 14921,
+ 14922,
+ 14923,
+ 14924,
+ 14925,
+ 14926,
+ 14927,
+ 14928,
+ 14929,
+ 14930,
+ 14931,
+ 14932,
+ 14933,
+ 14934,
+ 14935,
+ 14936,
+ 14937,
+ 14938,
+ 14939,
+ 14940,
+ 14941,
+ 14942,
+ 14943,
+ 14944,
+ 14945,
+ 14946,
+ 14947,
+ 14948,
+ 14949,
+ 14950,
+ 14951,
+ 14952,
+ 14953,
+ 14954,
+ 14955,
+ 14956,
+ 14957,
+ 14958,
+ 14959,
+ 14960,
+ 14961,
+ 14962,
+ 14963,
+ 14964,
+ 14965,
+ 14966,
+ 14967,
+ 14968,
+ 14969,
+ 14970,
+ 14971,
+ 14972,
+ 14973,
+ 14974,
+ 14975,
+ 14976,
+ 14977,
+ 14978,
+ 14979,
+ 14980,
+ 14981,
+ 14982,
+ 14983,
+ 14984,
+ 14985,
+ 14986,
+ 14987,
+ 14988,
+ 14989,
+ 14990,
+ 14991,
+ 14992,
+ 14993,
+ 14994,
+ 14995,
+ 14996,
+ 14997,
+ 14998,
+ 14999,
+ 15000,
+ 15001,
+ 15002,
+ 15003,
+ 15004,
+ 15005,
+ 15006,
+ 15007,
+ 15008,
+ 15009,
+ 15010,
+ 15011,
+ 15012,
+ 15013,
+ 15014,
+ 15015,
+ 15016,
+ 15017,
+ 15018,
+ 15019,
+ 15020,
+ 15021,
+ 15022,
+ 15023,
+ 15024,
+ 15025,
+ 15026,
+ 15027,
+ 15028,
+ 15029,
+ 15030,
+ 15031,
+ 15032,
+ 15033,
+ 15034,
+ 15035,
+ 15036,
+ 15037,
+ 15038,
+ 15039,
+ 15040,
+ 15041,
+ 15042,
+ 15043,
+ 15044,
+ 15045,
+ 15046,
+ 15047,
+ 15048,
+ 15049,
+ 15050,
+ 15051,
+ 15052,
+ 15053,
+ 15054,
+ 15055,
+ 15056,
+ 15057,
+ 15058,
+ 15059,
+ 15060,
+ 15061,
+ 15062,
+ 15063,
+ 15064,
+ 15065,
+ 15066,
+ 15067,
+ 15068,
+ 15069,
+ 15070,
+ 15071,
+ 15072,
+ 15073,
+ 15074,
+ 15075,
+ 15076,
+ 15077,
+ 15078,
+ 15079,
+ 15080,
+ 15081,
+ 15082,
+ 15083,
+ 15084,
+ 15085,
+ 15086,
+ 15087,
+ 15088,
+ 15089,
+ 15090,
+ 15091,
+ 15092,
+ 15093,
+ 15094,
+ 15095,
+ 15096,
+ 15097,
+ 15098,
+ 15099,
+ 15100,
+ 15101,
+ 15102,
+ 15103,
+ 15104,
+ 15105,
+ 15106,
+ 15107,
+ 15108,
+ 15109,
+ 15110,
+ 15111,
+ 15112,
+ 15113,
+ 15114,
+ 15115,
+ 15116,
+ 15117,
+ 15118,
+ 15119,
+ 15120,
+ 15121,
+ 15122,
+ 15123,
+ 15124,
+ 15125,
+ 15126,
+ 15127,
+ 15128,
+ 15129,
+ 15130,
+ 15131,
+ 15132,
+ 15133,
+ 15134,
+ 15135,
+ 15136,
+ 15137,
+ 15138,
+ 15139,
+ 15140,
+ 15141,
+ 15142,
+ 15143,
+ 15144,
+ 15145,
+ 15146,
+ 15147,
+ 15148,
+ 15149,
+ 15150,
+ 15151,
+ 15152,
+ 15153,
+ 15154,
+ 15155,
+ 15156,
+ 15157,
+ 15158,
+ 15159,
+ 15160,
+ 15161,
+ 15162,
+ 15163,
+ 15164,
+ 15165,
+ 15166,
+ 15167,
+ 15168,
+ 15169,
+ 15170,
+ 15171,
+ 15172,
+ 15173,
+ 15174,
+ 15175,
+ 15176,
+ 15177,
+ 15178,
+ 15179,
+ 15180,
+ 15181,
+ 15182,
+ 15183,
+ 15184,
+ 15185,
+ 15186,
+ 15187,
+ 15188,
+ 15189,
+ 15190,
+ 15191,
+ 15192,
+ 15193,
+ 15194,
+ 15195,
+ 15196,
+ 15197,
+ 15198,
+ 15199,
+ 15200,
+ 15201,
+ 15202,
+ 15203,
+ 15204,
+ 15205,
+ 15206,
+ 15207,
+ 15208,
+ 15209,
+ 15210,
+ 15211,
+ 15212,
+ 15213,
+ 15214,
+ 15215,
+ 15216,
+ 15217,
+ 15218,
+ 15219,
+ 15220,
+ 15221,
+ 15222,
+ 15223,
+ 15224,
+ 15225,
+ 15226,
+ 15227,
+ 15228,
+ 15229,
+ 15230,
+ 15231,
+ 15232,
+ 15233,
+ 15234,
+ 15235,
+ 15236,
+ 15237,
+ 15238,
+ 15239,
+ 15240,
+ 15241,
+ 15242,
+ 15243,
+ 15244,
+ 15245,
+ 15246,
+ 15247,
+ 15248,
+ 15249,
+ 15250,
+ 15251,
+ 15252,
+ 15253,
+ 15254,
+ 15255,
+ 15256,
+ 15257,
+ 15258,
+ 15259,
+ 15260,
+ 15261,
+ 15262,
+ 15263,
+ 15264,
+ 15265,
+ 15266,
+ 15267,
+ 15268,
+ 15269,
+ 15270,
+ 15271,
+ 15272,
+ 15273,
+ 15274,
+ 15275,
+ 15276,
+ 15277,
+ 15278,
+ 15279,
+ 15280,
+ 15281,
+ 15282,
+ 15283,
+ 15284,
+ 15285,
+ 15286,
+ 15287,
+ 15288,
+ 15289,
+ 15290,
+ 15291,
+ 15292,
+ 15293,
+ 15294,
+ 15295,
+ 15296,
+ 15297,
+ 15298,
+ 15299,
+ 15300,
+ 15301,
+ 15302,
+ 15303,
+ 15304,
+ 15305,
+ 15306,
+ 15307,
+ 15308,
+ 15309,
+ 15310,
+ 15311,
+ 15312,
+ 15313,
+ 15314,
+ 15315,
+ 15316,
+ 15317,
+ 15318,
+ 15319,
+ 15320,
+ 15321,
+ 15322,
+ 15323,
+ 15324,
+ 15325,
+ 15326,
+ 15327,
+ 15328,
+ 15329,
+ 15330,
+ 15331,
+ 15332,
+ 15333,
+ 15334,
+ 15335,
+ 15336,
+ 15337,
+ 15338,
+ 15339,
+ 15340,
+ 15341,
+ 15342,
+ 15343,
+ 15344,
+ 15345,
+ 15346,
+ 15347,
+ 15348,
+ 15349,
+ 15350,
+ 15351,
+ 15352,
+ 15353,
+ 15354,
+ 15355,
+ 15356,
+ 15357,
+ 15358,
+ 15359,
+ 15360,
+ 15361,
+ 15362,
+ 15363,
+ 15364,
+ 15365,
+ 15366,
+ 15367,
+ 15368,
+ 15369,
+ 15370,
+ 15371,
+ 15372,
+ 15373,
+ 15374,
+ 15375,
+ 15376,
+ 15377,
+ 15378,
+ 15379,
+ 15380,
+ 15381,
+ 15382,
+ 15383,
+ 15384,
+ 15385,
+ 15386,
+ 15387,
+ 15388,
+ 15389,
+ 15390,
+ 15391,
+ 15392,
+ 15393,
+ 15394,
+ 15395,
+ 15396,
+ 15397,
+ 15398,
+ 15399,
+ 15400,
+ 15401,
+ 15402,
+ 15403,
+ 15404,
+ 15405,
+ 15406,
+ 15407,
+ 15408,
+ 15409,
+ 15410,
+ 15411,
+ 15412,
+ 15413,
+ 15414,
+ 15415,
+ 15416,
+ 15417,
+ 15418,
+ 15419,
+ 15420,
+ 15421,
+ 15422,
+ 15423,
+ 15424,
+ 15425,
+ 15426,
+ 15427,
+ 15428,
+ 15429,
+ 15430,
+ 15431,
+ 15432,
+ 15433,
+ 15434,
+ 15435,
+ 15436,
+ 15437,
+ 15438,
+ 15439,
+ 15440,
+ 15441,
+ 15442,
+ 15443,
+ 15444,
+ 15445,
+ 15446,
+ 15447,
+ 15448,
+ 15449,
+ 15450,
+ 15451,
+ 15452,
+ 15453,
+ 15454,
+ 15455,
+ 15456,
+ 15457,
+ 15458,
+ 15459,
+ 15460,
+ 15461,
+ 15462,
+ 15463,
+ 15464,
+ 15465,
+ 15466,
+ 15467,
+ 15468,
+ 15469,
+ 15470,
+ 15471,
+ 15472,
+ 15473,
+ 15474,
+ 15475,
+ 15476,
+ 15477,
+ 15478,
+ 15479,
+ 15480,
+ 15481,
+ 15482,
+ 15483,
+ 15484,
+ 15485,
+ 15486,
+ 15487,
+ 15488,
+ 15489,
+ 15490,
+ 15491,
+ 15492,
+ 15493,
+ 15494,
+ 15495,
+ 15496,
+ 15497,
+ 15498,
+ 15499,
+ 15500,
+ 15501,
+ 15502,
+ 15503,
+ 15504,
+ 15505,
+ 15506,
+ 15507,
+ 15508,
+ 15509,
+ 15510,
+ 15511,
+ 15512,
+ 15513,
+ 15514,
+ 15515,
+ 15516,
+ 15517,
+ 15518,
+ 15519,
+ 15520,
+ 15521,
+ 15522,
+ 15523,
+ 15524,
+ 15525,
+ 15526,
+ 15527,
+ 15528,
+ 15529,
+ 15530,
+ 15531,
+ 15532,
+ 15533,
+ 15534,
+ 15535,
+ 15536,
+ 15537,
+ 15538,
+ 15539,
+ 15540,
+ 15541,
+ 15542,
+ 15543,
+ 15544,
+ 15545,
+ 15546,
+ 15547,
+ 15548,
+ 15549,
+ 15550,
+ 15551,
+ 15552,
+ 15553,
+ 15554,
+ 15555,
+ 15556,
+ 15557,
+ 15558,
+ 15559,
+ 15560,
+ 15561,
+ 15562,
+ 15563,
+ 15564,
+ 15565,
+ 15566,
+ 15567,
+ 15568,
+ 15569,
+ 15570,
+ 15571,
+ 15572,
+ 15573,
+ 15574,
+ 15575,
+ 15576,
+ 15577,
+ 15578,
+ 15579,
+ 15580,
+ 15581,
+ 15582,
+ 15583,
+ 15584,
+ 15585,
+ 15586,
+ 15587,
+ 15588,
+ 15589,
+ 15590,
+ 15591,
+ 15592,
+ 15593,
+ 15594,
+ 15595,
+ 15596,
+ 15597,
+ 15598,
+ 15599,
+ 15600,
+ 15601,
+ 15602,
+ 15603,
+ 15604,
+ 15605,
+ 15606,
+ 15607,
+ 15608,
+ 15609,
+ 15610,
+ 15611,
+ 15612,
+ 15613,
+ 15614,
+ 15615,
+ 15616,
+ 15617,
+ 15618,
+ 15619,
+ 15620,
+ 15621,
+ 15622,
+ 15623,
+ 15624,
+ 15625,
+ 15626,
+ 15627,
+ 15628,
+ 15629,
+ 15630,
+ 15631,
+ 15632,
+ 15633,
+ 15634,
+ 15635,
+ 15636,
+ 15637,
+ 15638,
+ 15639,
+ 15640,
+ 15641,
+ 15642,
+ 15643,
+ 15644,
+ 15645,
+ 15646,
+ 15647,
+ 15648,
+ 15649,
+ 15650,
+ 15651,
+ 15652,
+ 15653,
+ 15654,
+ 15655,
+ 15656,
+ 15657,
+ 15658,
+ 15659,
+ 15660,
+ 15661,
+ 15662,
+ 15663,
+ 15664,
+ 15665,
+ 15666,
+ 15667,
+ 15668,
+ 15669,
+ 15670,
+ 15671,
+ 15672,
+ 15673,
+ 15674,
+ 15675,
+ 15676,
+ 15677,
+ 15678,
+ 15679,
+ 15680,
+ 15681,
+ 15682,
+ 15683,
+ 15684,
+ 15685,
+ 15686,
+ 15687,
+ 15688,
+ 15689,
+ 15690,
+ 15691,
+ 15692,
+ 15693,
+ 15694,
+ 15695,
+ 15696,
+ 15697,
+ 15698,
+ 15699,
+ 15700,
+ 15701,
+ 15702,
+ 15703,
+ 15704,
+ 15705,
+ 15706,
+ 15707,
+ 15708,
+ 15709,
+ 15710,
+ 15711,
+ 15712,
+ 15713,
+ 15714,
+ 15715,
+ 15716,
+ 15717,
+ 15718,
+ 15719,
+ 15720,
+ 15721,
+ 15722,
+ 15723,
+ 15724,
+ 15725,
+ 15726,
+ 15727,
+ 15728,
+ 15729,
+ 15730,
+ 15731,
+ 15732,
+ 15733,
+ 15734,
+ 15735,
+ 15736,
+ 15737,
+ 15738,
+ 15739,
+ 15740,
+ 15741,
+ 15742,
+ 15743,
+ 15744,
+ 15745,
+ 15746,
+ 15747,
+ 15748,
+ 15749,
+ 15750,
+ 15751,
+ 15752,
+ 15753,
+ 15754,
+ 15755,
+ 15756,
+ 15757,
+ 15758,
+ 15759,
+ 15760,
+ 15761,
+ 15762,
+ 15763,
+ 15764,
+ 15765,
+ 15766,
+ 15767,
+ 15768,
+ 15769,
+ 15770,
+ 15771,
+ 15772,
+ 15773,
+ 15774,
+ 15775,
+ 15776,
+ 15777,
+ 15778,
+ 15779,
+ 15780,
+ 15781,
+ 15782,
+ 15783,
+ 15784,
+ 15785,
+ 15786,
+ 15787,
+ 15788,
+ 15789,
+ 15790,
+ 15791,
+ 15792,
+ 15793,
+ 15794,
+ 15795,
+ 15796,
+ 15797,
+ 15798,
+ 15799,
+ 15800,
+ 15801,
+ 15802,
+ 15803,
+ 15804,
+ 15805,
+ 15806,
+ 15807,
+ 15808,
+ 15809,
+ 15810,
+ 15811,
+ 15812,
+ 15813,
+ 15814,
+ 15815,
+ 15816,
+ 15817,
+ 15818,
+ 15819,
+ 15820,
+ 15821,
+ 15822,
+ 15823,
+ 15824,
+ 15825,
+ 15826,
+ 15827,
+ 15828,
+ 15829,
+ 15830,
+ 15831,
+ 15832,
+ 15833,
+ 15834,
+ 15835,
+ 15836,
+ 15837,
+ 15838,
+ 15839,
+ 15840,
+ 15841,
+ 15842,
+ 15843,
+ 15844,
+ 15845,
+ 15846,
+ 15847,
+ 15848,
+ 15849,
+ 15850,
+ 15851,
+ 15852,
+ 15853,
+ 15854,
+ 15855,
+ 15856,
+ 15857,
+ 15858,
+ 15859,
+ 15860,
+ 15861,
+ 15862,
+ 15863,
+ 15864,
+ 15865,
+ 15866,
+ 15867,
+ 15868,
+ 15869,
+ 15870,
+ 15871,
+ 15872,
+ 15873,
+ 15874,
+ 15875,
+ 15876,
+ 15877,
+ 15878,
+ 15879,
+ 15880,
+ 15881,
+ 15882,
+ 15883,
+ 15884,
+ 15885,
+ 15886,
+ 15887,
+ 15888,
+ 15889,
+ 15890,
+ 15891,
+ 15892,
+ 15893,
+ 15894,
+ 15895,
+ 15896,
+ 15897,
+ 15898,
+ 15899,
+ 15900,
+ 15901,
+ 15902,
+ 15903,
+ 15904,
+ 15905,
+ 15906,
+ 15907,
+ 15908,
+ 15909,
+ 15910,
+ 15911,
+ 15912,
+ 15913,
+ 15914,
+ 15915,
+ 15916,
+ 15917,
+ 15918,
+ 15919,
+ 15920,
+ 15921,
+ 15922,
+ 15923,
+ 15924,
+ 15925,
+ 15926,
+ 15927,
+ 15928,
+ 15929,
+ 15930,
+ 15931,
+ 15932,
+ 15933,
+ 15934,
+ 15935,
+ 15936,
+ 15937,
+ 15938,
+ 15939,
+ 15940,
+ 15941,
+ 15942,
+ 15943,
+ 15944,
+ 15945,
+ 15946,
+ 15947,
+ 15948,
+ 15949,
+ 15950,
+ 15951,
+ 15952,
+ 15953,
+ 15954,
+ 15955,
+ 15956,
+ 15957,
+ 15958,
+ 15959,
+ 15960,
+ 15961,
+ 15962,
+ 15963,
+ 15964,
+ 15965,
+ 15966,
+ 15967,
+ 15968,
+ 15969,
+ 15970,
+ 15971,
+ 15972,
+ 15973,
+ 15974,
+ 15975,
+ 15976,
+ 15977,
+ 15978,
+ 15979,
+ 15980,
+ 15981,
+ 15982,
+ 15983,
+ 15984,
+ 15985,
+ 15986,
+ 15987,
+ 15988,
+ 15989,
+ 15990,
+ 15991,
+ 15992,
+ 15993,
+ 15994,
+ 15995,
+ 15996,
+ 15997,
+ 15998,
+ 15999,
+ 16000,
+ 16001,
+ 16002,
+ 16003,
+ 16004,
+ 16005,
+ 16006,
+ 16007,
+ 16008,
+ 16009,
+ 16010,
+ 16011,
+ 16012,
+ 16013,
+ 16014,
+ 16015,
+ 16016,
+ 16017,
+ 16018,
+ 16019,
+ 16020,
+ 16021,
+ 16022,
+ 16023,
+ 16024,
+ 16025,
+ 16026,
+ 16027,
+ 16028,
+ 16029,
+ 16030,
+ 16031,
+ 16032,
+ 16033,
+ 16034,
+ 16035,
+ 16036,
+ 16037,
+ 16038,
+ 16039,
+ 16040,
+ 16041,
+ 16042,
+ 16043,
+ 16044,
+ 16045,
+ 16046,
+ 16047,
+ 16048,
+ 16049,
+ 16050,
+ 16051,
+ 16052,
+ 16053,
+ 16054,
+ 16055,
+ 16056,
+ 16057,
+ 16058,
+ 16059,
+ 16060,
+ 16061,
+ 16062,
+ 16063,
+ 16064,
+ 16065,
+ 16066,
+ 16067,
+ 16068,
+ 16069,
+ 16070,
+ 16071,
+ 16072,
+ 16073,
+ 16074,
+ 16075,
+ 16076,
+ 16077,
+ 16078,
+ 16079,
+ 16080,
+ 16081,
+ 16082,
+ 16083,
+ 16084,
+ 16085,
+ 16086,
+ 16087,
+ 16088,
+ 16089,
+ 16090,
+ 16091,
+ 16092,
+ 16093,
+ 16094,
+ 16095,
+ 16096,
+ 16097,
+ 16098,
+ 16099,
+ 16100,
+ 16101,
+ 16102,
+ 16103,
+ 16104,
+ 16105,
+ 16106,
+ 16107,
+ 16108,
+ 16109,
+ 16110,
+ 16111,
+ 16112,
+ 16113,
+ 16114,
+ 16115,
+ 16116,
+ 16117,
+ 16118,
+ 16119,
+ 16120,
+ 16121,
+ 16122,
+ 16123,
+ 16124,
+ 16125,
+ 16126,
+ 16127,
+ 16128,
+ 16129,
+ 16130,
+ 16131,
+ 16132,
+ 16133,
+ 16134,
+ 16135,
+ 16136,
+ 16137,
+ 16138,
+ 16139,
+ 16140,
+ 16141,
+ 16142,
+ 16143,
+ 16144,
+ 16145,
+ 16146,
+ 16147,
+ 16148,
+ 16149,
+ 16150,
+ 16151,
+ 16152,
+ 16153,
+ 16154,
+ 16155,
+ 16156,
+ 16157,
+ 16158,
+ 16159,
+ 16160,
+ 16161,
+ 16162,
+ 16163,
+ 16164,
+ 16165,
+ 16166,
+ 16167,
+ 16168,
+ 16169,
+ 16170,
+ 16171,
+ 16172,
+ 16173,
+ 16174,
+ 16175,
+ 16176,
+ 16177,
+ 16178,
+ 16179,
+ 16180,
+ 16181,
+ 16182,
+ 16183,
+ 16184,
+ 16185,
+ 16186,
+ 16187,
+ 16188,
+ 16189,
+ 16190,
+ 16191,
+ 16192,
+ 16193,
+ 16194,
+ 16195,
+ 16196,
+ 16197,
+ 16198,
+ 16199,
+ 16200,
+ 16201,
+ 16202,
+ 16203,
+ 16204,
+ 16205,
+ 16206,
+ 16207,
+ 16208,
+ 16209,
+ 16210,
+ 16211,
+ 16212,
+ 16213,
+ 16214,
+ 16215,
+ 16216,
+ 16217,
+ 16218,
+ 16219,
+ 16220,
+ 16221,
+ 16222,
+ 16223,
+ 16224,
+ 16225,
+ 16226,
+ 16227,
+ 16228,
+ 16229,
+ 16230,
+ 16231,
+ 16232,
+ 16233,
+ 16234,
+ 16235,
+ 16236,
+ 16237,
+ 16238,
+ 16239,
+ 16240,
+ 16241,
+ 16242,
+ 16243,
+ 16244,
+ 16245,
+ 16246,
+ 16247,
+ 16248,
+ 16249,
+ 16250,
+ 16251,
+ 16252,
+ 16253,
+ 16254,
+ 16255,
+ 16256,
+ 16257,
+ 16258,
+ 16259,
+ 16260,
+ 16261,
+ 16262,
+ 16263,
+ 16264,
+ 16265,
+ 16266,
+ 16267,
+ 16268,
+ 16269,
+ 16270,
+ 16271,
+ 16272,
+ 16273,
+ 16274,
+ 16275,
+ 16276,
+ 16277,
+ 16278,
+ 16279,
+ 16280,
+ 16281,
+ 16282,
+ 16283,
+ 16284,
+ 16285,
+ 16286,
+ 16287,
+ 16288,
+ 16289,
+ 16290,
+ 16291,
+ 16292,
+ 16293,
+ 16294,
+ 16295,
+ 16296,
+ 16297,
+ 16298,
+ 16299,
+ 16300,
+ 16301,
+ 16302,
+ 16303,
+ 16304,
+ 16305,
+ 16306,
+ 16307,
+ 16308,
+ 16309,
+ 16310,
+ 16311,
+ 16312,
+ 16313,
+ 16314,
+ 16315,
+ 16316,
+ 16317,
+ 16318,
+ 16319,
+ 16320,
+ 16321,
+ 16322,
+ 16323,
+ 16324,
+ 16325,
+ 16326,
+ 16327,
+ 16328,
+ 16329,
+ 16330,
+ 16331,
+ 16332,
+ 16333,
+ 16334,
+ 16335,
+ 16336,
+ 16337,
+ 16338,
+ 16339,
+ 16340,
+ 16341,
+ 16342,
+ 16343,
+ 16344,
+ 16345,
+ 16346,
+ 16347,
+ 16348,
+ 16349,
+ 16350,
+ 16351,
+ 16352,
+ 16353,
+ 16354,
+ 16355,
+ 16356,
+ 16357,
+ 16358,
+ 16359,
+ 16360,
+ 16361,
+ 16362,
+ 16363,
+ 16364,
+ 16365,
+ 16366,
+ 16367,
+ 16368,
+ 16369,
+ 16370,
+ 16371,
+ 16372,
+ 16373,
+ 16374,
+ 16375,
+ 16376,
+ 16377,
+ 16378,
+ 16379,
+ 16380,
+ 16381,
+ 16382,
+ 16383,
+ 16384,
+ 16385,
+ 16386,
+ 16387,
+ 16388,
+ 16389,
+ 16390,
+ 16391,
+ 16392,
+ 16393,
+ 16394,
+ 16395,
+ 16396,
+ 16397,
+ 16398,
+ 16399,
+ 16400,
+ 16401,
+ 16402,
+ 16403,
+ 16404,
+ 16405,
+ 16406,
+ 16407,
+ 16408,
+ 16409,
+ 16410,
+ 16411,
+ 16412,
+ 16413,
+ 16414,
+ 16415,
+ 16416,
+ 16417,
+ 16418,
+ 16419,
+ 16420,
+ 16421,
+ 16422,
+ 16423,
+ 16424,
+ 16425,
+ 16426,
+ 16427,
+ 16428,
+ 16429,
+ 16430,
+ 16431,
+ 16432,
+ 16433,
+ 16434,
+ 16435,
+ 16436,
+ 16437,
+ 16438,
+ 16439,
+ 16440,
+ 16441,
+ 16442,
+ 16443,
+ 16444,
+ 16445,
+ 16446,
+ 16447,
+ 16448,
+ 16449,
+ 16450,
+ 16451,
+ 16452,
+ 16453,
+ 16454,
+ 16455,
+ 16456,
+ 16457,
+ 16458,
+ 16459,
+ 16460,
+ 16461,
+ 16462,
+ 16463,
+ 16464,
+ 16465,
+ 16466,
+ 16467,
+ 16468,
+ 16469,
+ 16470,
+ 16471,
+ 16472,
+ 16473,
+ 16474,
+ 16475,
+ 16476,
+ 16477,
+ 16478,
+ 16479,
+ 16480,
+ 16481,
+ 16482,
+ 16483,
+ 16484,
+ 16485,
+ 16486,
+ 16487,
+ 16488,
+ 16489,
+ 16490,
+ 16491,
+ 16492,
+ 16493,
+ 16494,
+ 16495,
+ 16496,
+ 16497,
+ 16498,
+ 16499,
+ 16500,
+ 16501,
+ 16502,
+ 16503,
+ 16504,
+ 16505,
+ 16506,
+ 16507,
+ 16508,
+ 16509,
+ 16510,
+ 16511,
+ 16512,
+ 16513,
+ 16514,
+ 16515,
+ 16516,
+ 16517,
+ 16518,
+ 16519,
+ 16520,
+ 16521,
+ 16522,
+ 16523,
+ 16524,
+ 16525,
+ 16526,
+ 16527,
+ 16528,
+ 16529,
+ 16530,
+ 16531,
+ 16532,
+ 16533,
+ 16534,
+ 16535,
+ 16536,
+ 16537,
+ 16538,
+ 16539,
+ 16540,
+ 16541,
+ 16542,
+ 16543,
+ 16544,
+ 16545,
+ 16546,
+ 16547,
+ 16548,
+ 16549,
+ 16550,
+ 16551,
+ 16552,
+ 16553,
+ 16554,
+ 16555,
+ 16556,
+ 16557,
+ 16558,
+ 16559,
+ 16560,
+ 16561,
+ 16562,
+ 16563,
+ 16564,
+ 16565,
+ 16566,
+ 16567,
+ 16568,
+ 16569,
+ 16570,
+ 16571,
+ 16572,
+ 16573,
+ 16574,
+ 16575,
+ 16576,
+ 16577,
+ 16578,
+ 16579,
+ 16580,
+ 16581,
+ 16582,
+ 16583,
+ 16584,
+ 16585,
+ 16586,
+ 16587,
+ 16588,
+ 16589,
+ 16590,
+ 16591,
+ 16592,
+ 16593,
+ 16594,
+ 16595,
+ 16596,
+ 16597,
+ 16598,
+ 16599,
+ 16600,
+ 16601,
+ 16602,
+ 16603,
+ 16604,
+ 16605,
+ 16606,
+ 16607,
+ 16608,
+ 16609,
+ 16610,
+ 16611,
+ 16612,
+ 16613,
+ 16614,
+ 16615,
+ 16616,
+ 16617,
+ 16618,
+ 16619,
+ 16620,
+ 16621,
+ 16622,
+ 16623,
+ 16624,
+ 16625,
+ 16626,
+ 16627,
+ 16628,
+ 16629,
+ 16630,
+ 16631,
+ 16632,
+ 16633,
+ 16634,
+ 16635,
+ 16636,
+ 16637,
+ 16638,
+ 16639,
+ 16640,
+ 16641,
+ 16642,
+ 16643,
+ 16644,
+ 16645,
+ 16646,
+ 16647,
+ 16648,
+ 16649,
+ 16650,
+ 16651,
+ 16652,
+ 16653,
+ 16654,
+ 16655,
+ 16656,
+ 16657,
+ 16658,
+ 16659,
+ 16660,
+ 16661,
+ 16662,
+ 16663,
+ 16664,
+ 16665,
+ 16666,
+ 16667,
+ 16668,
+ 16669,
+ 16670,
+ 16671,
+ 16672,
+ 16673,
+ 16674,
+ 16675,
+ 16676,
+ 16677,
+ 16678,
+ 16679,
+ 16680,
+ 16681,
+ 16682,
+ 16683,
+ 16684,
+ 16685,
+ 16686,
+ 16687,
+ 16688,
+ 16689,
+ 16690,
+ 16691,
+ 16692,
+ 16693,
+ 16694,
+ 16695,
+ 16696,
+ 16697,
+ 16698,
+ 16699,
+ 16700,
+ 16701,
+ 16702,
+ 16703,
+ 16704,
+ 16705,
+ 16706,
+ 16707,
+ 16708,
+ 16709,
+ 16710,
+ 16711,
+ 16712,
+ 16713,
+ 16714,
+ 16715,
+ 16716,
+ 16717,
+ 16718,
+ 16719,
+ 16720,
+ 16721,
+ 16722,
+ 16723,
+ 16724,
+ 16725,
+ 16726,
+ 16727,
+ 16728,
+ 16729,
+ 16730,
+ 16731,
+ 16732,
+ 16733,
+ 16734,
+ 16735,
+ 16736,
+ 16737,
+ 16738,
+ 16739,
+ 16740,
+ 16741,
+ 16742,
+ 16743,
+ 16744,
+ 16745,
+ 16746,
+ 16747,
+ 16748,
+ 16749,
+ 16750,
+ 16751,
+ 16752,
+ 16753,
+ 16754,
+ 16755,
+ 16756,
+ 16757,
+ 16758,
+ 16759,
+ 16760,
+ 16761,
+ 16762,
+ 16763,
+ 16764,
+ 16765,
+ 16766,
+ 16767,
+ 16768,
+ 16769,
+ 16770,
+ 16771,
+ 16772,
+ 16773,
+ 16774,
+ 16775,
+ 16776,
+ 16777,
+ 16778,
+ 16779,
+ 16780,
+ 16781,
+ 16782,
+ 16783,
+ 16784,
+ 16785,
+ 16786,
+ 16787,
+ 16788,
+ 16789,
+ 16790,
+ 16791,
+ 16792,
+ 16793,
+ 16794,
+ 16795,
+ 16796,
+ 16797,
+ 16798,
+ 16799,
+ 16800,
+ 16801,
+ 16802,
+ 16803,
+ 16804,
+ 16805,
+ 16806,
+ 16807,
+ 16808,
+ 16809,
+ 16810,
+ 16811,
+ 16812,
+ 16813,
+ 16814,
+ 16815,
+ 16816,
+ 16817,
+ 16818,
+ 16819,
+ 16820,
+ 16821,
+ 16822,
+ 16823,
+ 16824,
+ 16825,
+ 16826,
+ 16827,
+ 16828,
+ 16829,
+ 16830,
+ 16831,
+ 16832,
+ 16833,
+ 16834,
+ 16835,
+ 16836,
+ 16837,
+ 16838,
+ 16839,
+ 16840,
+ 16841,
+ 16842,
+ 16843,
+ 16844,
+ 16845,
+ 16846,
+ 16847,
+ 16848,
+ 16849,
+ 16850,
+ 16851,
+ 16852,
+ 16853,
+ 16854,
+ 16855,
+ 16856,
+ 16857,
+ 16858,
+ 16859,
+ 16860,
+ 16861,
+ 16862,
+ 16863,
+ 16864,
+ 16865,
+ 16866,
+ 16867,
+ 16868,
+ 16869,
+ 16870,
+ 16871,
+ 16872,
+ 16873,
+ 16874,
+ 16875,
+ 16876,
+ 16877,
+ 16878,
+ 16879,
+ 16880,
+ 16881,
+ 16882,
+ 16883,
+ 16884,
+ 16885,
+ 16886,
+ 16887,
+ 16888,
+ 16889,
+ 16890,
+ 16891,
+ 16892,
+ 16893,
+ 16894,
+ 16895,
+ 16896,
+ 16897,
+ 16898,
+ 16899,
+ 16900,
+ 16901,
+ 16902,
+ 16903,
+ 16904,
+ 16905,
+ 16906,
+ 16907,
+ 16908,
+ 16909,
+ 16910,
+ 16911,
+ 16912,
+ 16913,
+ 16914,
+ 16915,
+ 16916,
+ 16917,
+ 16918,
+ 16919,
+ 16920,
+ 16921,
+ 16922,
+ 16923,
+ 16924,
+ 16925,
+ 16926,
+ 16927,
+ 16928,
+ 16929,
+ 16930,
+ 16931,
+ 16932,
+ 16933,
+ 16934,
+ 16935,
+ 16936,
+ 16937,
+ 16938,
+ 16939,
+ 16940,
+ 16941,
+ 16942,
+ 16943,
+ 16944,
+ 16945,
+ 16946,
+ 16947,
+ 16948,
+ 16949,
+ 16950,
+ 16951,
+ 16952,
+ 16953,
+ 16954,
+ 16955,
+ 16956,
+ 16957,
+ 16958,
+ 16959,
+ 16960,
+ 16961,
+ 16962,
+ 16963,
+ 16964,
+ 16965,
+ 16966,
+ 16967,
+ 16968,
+ 16969,
+ 16970,
+ 16971,
+ 16972,
+ 16973,
+ 16974,
+ 16975,
+ 16976,
+ 16977,
+ 16978,
+ 16979,
+ 16980,
+ 16981,
+ 16982,
+ 16983,
+ 16984,
+ 16985,
+ 16986,
+ 16987,
+ 16988,
+ 16989,
+ 16990,
+ 16991,
+ 16992,
+ 16993,
+ 16994,
+ 16995,
+ 16996,
+ 16997,
+ 16998,
+ 16999,
+ 17000,
+ 17001,
+ 17002,
+ 17003,
+ 17004,
+ 17005,
+ 17006,
+ 17007,
+ 17008,
+ 17009,
+ 17010,
+ 17011,
+ 17012,
+ 17013,
+ 17014,
+ 17015,
+ 17016,
+ 17017,
+ 17018,
+ 17019,
+ 17020,
+ 17021,
+ 17022,
+ 17023,
+ 17024,
+ 17025,
+ 17026,
+ 17027,
+ 17028,
+ 17029,
+ 17030,
+ 17031,
+ 17032,
+ 17033,
+ 17034,
+ 17035,
+ 17036,
+ 17037,
+ 17038,
+ 17039,
+ 17040,
+ 17041,
+ 17042,
+ 17043,
+ 17044,
+ 17045,
+ 17046,
+ 17047,
+ 17048,
+ 17049,
+ 17050,
+ 17051,
+ 17052,
+ 17053,
+ 17054,
+ 17055,
+ 17056,
+ 17057,
+ 17058,
+ 17059,
+ 17060,
+ 17061,
+ 17062,
+ 17063,
+ 17064,
+ 17065,
+ 17066,
+ 17067,
+ 17068,
+ 17069,
+ 17070,
+ 17071,
+ 17072,
+ 17073,
+ 17074,
+ 17075,
+ 17076,
+ 17077,
+ 17078,
+ 17079,
+ 17080,
+ 17081,
+ 17082,
+ 17083,
+ 17084,
+ 17085,
+ 17086,
+ 17087,
+ 17088,
+ 17089,
+ 17090,
+ 17091,
+ 17092,
+ 17093,
+ 17094,
+ 17095,
+ 17096,
+ 17097,
+ 17098,
+ 17099,
+ 17100,
+ 17101,
+ 17102,
+ 17103,
+ 17104,
+ 17105,
+ 17106,
+ 17107,
+ 17108,
+ 17109,
+ 17110,
+ 17111,
+ 17112,
+ 17113,
+ 17114,
+ 17115,
+ 17116,
+ 17117,
+ 17118,
+ 17119,
+ 17120,
+ 17121,
+ 17122,
+ 17123,
+ 17124,
+ 17125,
+ 17126,
+ 17127,
+ 17128,
+ 17129,
+ 17130,
+ 17131,
+ 17132,
+ 17133,
+ 17134,
+ 17135,
+ 17136,
+ 17137,
+ 17138,
+ 17139,
+ 17140,
+ 17141,
+ 17142,
+ 17143,
+ 17144,
+ 17145,
+ 17146,
+ 17147,
+ 17148,
+ 17149,
+ 17150,
+ 17151,
+ 17152,
+ 17153,
+ 17154,
+ 17155,
+ 17156,
+ 17157,
+ 17158,
+ 17159,
+ 17160,
+ 17161,
+ 17162,
+ 17163,
+ 17164,
+ 17165,
+ 17166,
+ 17167,
+ 17168,
+ 17169,
+ 17170,
+ 17171,
+ 17172,
+ 17173,
+ 17174,
+ 17175,
+ 17176,
+ 17177,
+ 17178,
+ 17179,
+ 17180,
+ 17181,
+ 17182,
+ 17183,
+ 17184,
+ 17185,
+ 17186,
+ 17187,
+ 17188,
+ 17189,
+ 17190,
+ 17191,
+ 17192,
+ 17193,
+ 17194,
+ 17195,
+ 17196,
+ 17197,
+ 17198,
+ 17199,
+ 17200,
+ 17201,
+ 17202,
+ 17203,
+ 17204,
+ 17205,
+ 17206,
+ 17207,
+ 17208,
+ 17209,
+ 17210,
+ 17211,
+ 17212,
+ 17213,
+ 17214,
+ 17215,
+ 17216,
+ 17217,
+ 17218,
+ 17219,
+ 17220,
+ 17221,
+ 17222,
+ 17223,
+ 17224,
+ 17225,
+ 17226,
+ 17227,
+ 17228,
+ 17229,
+ 17230,
+ 17231,
+ 17232,
+ 17233,
+ 17234,
+ 17235,
+ 17236,
+ 17237,
+ 17238,
+ 17239,
+ 17240,
+ 17241,
+ 17242,
+ 17243,
+ 17244,
+ 17245,
+ 17246,
+ 17247,
+ 17248,
+ 17249,
+ 17250,
+ 17251,
+ 17252,
+ 17253,
+ 17254,
+ 17255,
+ 17256,
+ 17257,
+ 17258,
+ 17259,
+ 17260,
+ 17261,
+ 17262,
+ 17263,
+ 17264,
+ 17265,
+ 17266,
+ 17267,
+ 17268,
+ 17269,
+ 17270,
+ 17271,
+ 17272,
+ 17273,
+ 17274,
+ 17275,
+ 17276,
+ 17277,
+ 17278,
+ 17279,
+ 17280,
+ 17281,
+ 17282,
+ 17283,
+ 17284,
+ 17285,
+ 17286,
+ 17287,
+ 17288,
+ 17289,
+ 17290,
+ 17291,
+ 17292,
+ 17293,
+ 17294,
+ 17295,
+ 17296,
+ 17297,
+ 17298,
+ 17299,
+ 17300,
+ 17301,
+ 17302,
+ 17303,
+ 17304,
+ 17305,
+ 17306,
+ 17307,
+ 17308,
+ 17309,
+ 17310,
+ 17311,
+ 17312,
+ 17313,
+ 17314,
+ 17315,
+ 17316,
+ 17317,
+ 17318,
+ 17319,
+ 17320,
+ 17321,
+ 17322,
+ 17323,
+ 17324,
+ 17325,
+ 17326,
+ 17327,
+ 17328,
+ 17329,
+ 17330,
+ 17331,
+ 17332,
+ 17333,
+ 17334,
+ 17335,
+ 17336,
+ 17337,
+ 17338,
+ 17339,
+ 17340,
+ 17341,
+ 17342,
+ 17343,
+ 17344,
+ 17345,
+ 17346,
+ 17347,
+ 17348,
+ 17349,
+ 17350,
+ 17351,
+ 17352,
+ 17353,
+ 17354,
+ 17355,
+ 17356,
+ 17357,
+ 17358,
+ 17359,
+ 17360,
+ 17361,
+ 17362,
+ 17363,
+ 17364,
+ 17365,
+ 17366,
+ 17367,
+ 17368,
+ 17369,
+ 17370,
+ 17371,
+ 17372,
+ 17373,
+ 17374,
+ 17375,
+ 17376,
+ 17377,
+ 17378,
+ 17379,
+ 17380,
+ 17381,
+ 17382,
+ 17383,
+ 17384,
+ 17385,
+ 17386,
+ 17387,
+ 17388,
+ 17389,
+ 17390,
+ 17391,
+ 17392,
+ 17393,
+ 17394,
+ 17395,
+ 17396,
+ 17397,
+ 17398,
+ 17399,
+ 17400,
+ 17401,
+ 17402,
+ 17403,
+ 17404,
+ 17405,
+ 17406,
+ 17407,
+ 17408,
+ 17409,
+ 17410,
+ 17411,
+ 17412,
+ 17413,
+ 17414,
+ 17415,
+ 17416,
+ 17417,
+ 17418,
+ 17419,
+ 17420,
+ 17421,
+ 17422,
+ 17423,
+ 17424,
+ 17425,
+ 17426,
+ 17427,
+ 17428,
+ 17429,
+ 17430,
+ 17431,
+ 17432,
+ 17433,
+ 17434,
+ 17435,
+ 17436,
+ 17437,
+ 17438,
+ 17439,
+ 17440,
+ 17441,
+ 17442,
+ 17443,
+ 17444,
+ 17445,
+ 17446,
+ 17447,
+ 17448,
+ 17449,
+ 17450,
+ 17451,
+ 17452,
+ 17453,
+ 17454,
+ 17455,
+ 17456,
+ 17457,
+ 17458,
+ 17459,
+ 17460,
+ 17461,
+ 17462,
+ 17463,
+ 17464,
+ 17465,
+ 17466,
+ 17467,
+ 17468,
+ 17469,
+ 17470,
+ 17471,
+ 17472,
+ 17473,
+ 17474,
+ 17475,
+ 17476,
+ 17477,
+ 17478,
+ 17479,
+ 17480,
+ 17481,
+ 17482,
+ 17483,
+ 17484,
+ 17485,
+ 17486,
+ 17487,
+ 17488,
+ 17489,
+ 17490,
+ 17491,
+ 17492,
+ 17493,
+ 17494,
+ 17495,
+ 17496,
+ 17497,
+ 17498,
+ 17499,
+ 17500,
+ 17501,
+ 17502,
+ 17503,
+ 17504,
+ 17505,
+ 17506,
+ 17507,
+ 17508,
+ 17509,
+ 17510,
+ 17511,
+ 17512,
+ 17513,
+ 17514,
+ 17515,
+ 17516,
+ 17517,
+ 17518,
+ 17519,
+ 17520,
+ 17521,
+ 17522,
+ 17523,
+ 17524,
+ 17525,
+ 17526,
+ 17527,
+ 17528,
+ 17529,
+ 17530,
+ 17531,
+ 17532,
+ 17533,
+ 17534,
+ 17535,
+ 17536,
+ 17537,
+ 17538,
+ 17539,
+ 17540,
+ 17541,
+ 17542,
+ 17543,
+ 17544,
+ 17545,
+ 17546,
+ 17547,
+ 17548,
+ 17549,
+ 17550,
+ 17551,
+ 17552,
+ 17553,
+ 17554,
+ 17555,
+ 17556,
+ 17557,
+ 17558,
+ 17559,
+ 17560,
+ 17561,
+ 17562,
+ 17563,
+ 17564,
+ 17565,
+ 17566,
+ 17567,
+ 17568,
+ 17569,
+ 17570,
+ 17571,
+ 17572,
+ 17573,
+ 17574,
+ 17575,
+ 17576,
+ 17577,
+ 17578,
+ 17579,
+ 17580,
+ 17581,
+ 17582,
+ 17583,
+ 17584,
+ 17585,
+ 17586,
+ 17587,
+ 17588,
+ 17589,
+ 17590,
+ 17591,
+ 17592,
+ 17593,
+ 17594,
+ 17595,
+ 17596,
+ 17597,
+ 17598,
+ 17599,
+ 17600,
+ 17601,
+ 17602,
+ 17603,
+ 17604,
+ 17605,
+ 17606,
+ 17607,
+ 17608,
+ 17609,
+ 17610,
+ 17611,
+ 17612,
+ 17613,
+ 17614,
+ 17615,
+ 17616,
+ 17617,
+ 17618,
+ 17619,
+ 17620,
+ 17621,
+ 17622,
+ 17623,
+ 17624,
+ 17625,
+ 17626,
+ 17627,
+ 17628,
+ 17629,
+ 17630,
+ 17631,
+ 17632,
+ 17633,
+ 17634,
+ 17635,
+ 17636,
+ 17637,
+ 17638,
+ 17639,
+ 17640,
+ 17641,
+ 17642,
+ 17643,
+ 17644,
+ 17645,
+ 17646,
+ 17647,
+ 17648,
+ 17649,
+ 17650,
+ 17651,
+ 17652,
+ 17653,
+ 17654,
+ 17655,
+ 17656,
+ 17657,
+ 17658,
+ 17659,
+ 17660,
+ 17661,
+ 17662,
+ 17663,
+ 17664,
+ 17665,
+ 17666,
+ 17667,
+ 17668,
+ 17669,
+ 17670,
+ 17671,
+ 17672,
+ 17673,
+ 17674,
+ 17675,
+ 17676,
+ 17677,
+ 17678,
+ 17679,
+ 17680,
+ 17681,
+ 17682,
+ 17683,
+ 17684,
+ 17685,
+ 17686,
+ 17687,
+ 17688,
+ 17689,
+ 17690,
+ 17691,
+ 17692,
+ 17693,
+ 17694,
+ 17695,
+ 17696,
+ 17697,
+ 17698,
+ 17699,
+ 17700,
+ 17701,
+ 17702,
+ 17703,
+ 17704,
+ 17705,
+ 17706,
+ 17707,
+ 17708,
+ 17709,
+ 17710,
+ 17711,
+ 17712,
+ 17713,
+ 17714,
+ 17715,
+ 17716,
+ 17717,
+ 17718,
+ 17719,
+ 17720,
+ 17721,
+ 17722,
+ 17723,
+ 17724,
+ 17725,
+ 17726,
+ 17727,
+ 17728,
+ 17729,
+ 17730,
+ 17731,
+ 17732,
+ 17733,
+ 17734,
+ 17735,
+ 17736,
+ 17737,
+ 17738,
+ 17739,
+ 17740,
+ 17741,
+ 17742,
+ 17743,
+ 17744,
+ 17745,
+ 17746,
+ 17747,
+ 17748,
+ 17749,
+ 17750,
+ 17751,
+ 17752,
+ 17753,
+ 17754,
+ 17755,
+ 17756,
+ 17757,
+ 17758,
+ 17759,
+ 17760,
+ 17761,
+ 17762,
+ 17763,
+ 17764,
+ 17765,
+ 17766,
+ 17767,
+ 17768,
+ 17769,
+ 17770,
+ 17771,
+ 17772,
+ 17773,
+ 17774,
+ 17775,
+ 17776,
+ 17777,
+ 17778,
+ 17779,
+ 17780,
+ 17781,
+ 17782,
+ 17783,
+ 17784,
+ 17785,
+ 17786,
+ 17787,
+ 17788,
+ 17789,
+ 17790,
+ 17791,
+ 17792,
+ 17793,
+ 17794,
+ 17795,
+ 17796,
+ 17797,
+ 17798,
+ 17799,
+ 17800,
+ 17801,
+ 17802,
+ 17803,
+ 17804,
+ 17805,
+ 17806,
+ 17807,
+ 17808,
+ 17809,
+ 17810,
+ 17811,
+ 17812,
+ 17813,
+ 17814,
+ 17815,
+ 17816,
+ 17817,
+ 17818,
+ 17819,
+ 17820,
+ 17821,
+ 17822,
+ 17823,
+ 17824,
+ 17825,
+ 17826,
+ 17827,
+ 17828,
+ 17829,
+ 17830,
+ 17831,
+ 17832,
+ 17833,
+ 17834,
+ 17835,
+ 17836,
+ 17837,
+ 17838,
+ 17839,
+ 17840,
+ 17841,
+ 17842,
+ 17843,
+ 17844,
+ 17845,
+ 17846,
+ 17847,
+ 17848,
+ 17849,
+ 17850,
+ 17851,
+ 17852,
+ 17853,
+ 17854,
+ 17855,
+ 17856,
+ 17857,
+ 17858,
+ 17859,
+ 17860,
+ 17861,
+ 17862,
+ 17863,
+ 17864,
+ 17865,
+ 17866,
+ 17867,
+ 17868,
+ 17869,
+ 17870,
+ 17871,
+ 17872,
+ 17873,
+ 17874,
+ 17875,
+ 17876,
+ 17877,
+ 17878,
+ 17879,
+ 17880,
+ 17881,
+ 17882,
+ 17883,
+ 17884,
+ 17885,
+ 17886,
+ 17887,
+ 17888,
+ 17889,
+ 17890,
+ 17891,
+ 17892,
+ 17893,
+ 17894,
+ 17895,
+ 17896,
+ 17897,
+ 17898,
+ 17899,
+ 17900,
+ 17901,
+ 17902,
+ 17903,
+ 17904,
+ 17905,
+ 17906,
+ 17907,
+ 17908,
+ 17909,
+ 17910,
+ 17911,
+ 17912,
+ 17913,
+ 17914,
+ 17915,
+ 17916,
+ 17917,
+ 17918,
+ 17919,
+ 17920,
+ 17921,
+ 17922,
+ 17923,
+ 17924,
+ 17925,
+ 17926,
+ 17927,
+ 17928,
+ 17929,
+ 17930,
+ 17931,
+ 17932,
+ 17933,
+ 17934,
+ 17935,
+ 17936,
+ 17937,
+ 17938,
+ 17939,
+ 17940,
+ 17941,
+ 17942,
+ 17943,
+ 17944,
+ 17945,
+ 17946,
+ 17947,
+ 17948,
+ 17949,
+ 17950,
+ 17951,
+ 17952,
+ 17953,
+ 17954,
+ 17955,
+ 17956,
+ 17957,
+ 17958,
+ 17959,
+ 17960,
+ 17961,
+ 17962,
+ 17963,
+ 17964,
+ 17965,
+ 17966,
+ 17967,
+ 17968,
+ 17969,
+ 17970,
+ 17971,
+ 17972,
+ 17973,
+ 17974,
+ 17975,
+ 17976,
+ 17977,
+ 17978,
+ 17979,
+ 17980,
+ 17981,
+ 17982,
+ 17983,
+ 17984,
+ 17985,
+ 17986,
+ 17987,
+ 17988,
+ 17989,
+ 17990,
+ 17991,
+ 17992,
+ 17993,
+ 17994,
+ 17995,
+ 17996,
+ 17997,
+ 17998,
+ 17999,
+ 18000,
+ 18001,
+ 18002,
+ 18003,
+ 18004,
+ 18005,
+ 18006,
+ 18007,
+ 18008,
+ 18009,
+ 18010,
+ 18011,
+ 18012,
+ 18013,
+ 18014,
+ 18015,
+ 18016,
+ 18017,
+ 18018,
+ 18019,
+ 18020,
+ 18021,
+ 18022,
+ 18023,
+ 18024,
+ 18025,
+ 18026,
+ 18027,
+ 18028,
+ 18029,
+ 18030,
+ 18031,
+ 18032,
+ 18033,
+ 18034,
+ 18035,
+ 18036,
+ 18037,
+ 18038,
+ 18039,
+ 18040,
+ 18041,
+ 18042,
+ 18043,
+ 18044,
+ 18045,
+ 18046,
+ 18047,
+ 18048,
+ 18049,
+ 18050,
+ 18051,
+ 18052,
+ 18053,
+ 18054,
+ 18055,
+ 18056,
+ 18057,
+ 18058,
+ 18059,
+ 18060,
+ 18061,
+ 18062,
+ 18063,
+ 18064,
+ 18065,
+ 18066,
+ 18067,
+ 18068,
+ 18069,
+ 18070,
+ 18071,
+ 18072,
+ 18073,
+ 18074,
+ 18075,
+ 18076,
+ 18077,
+ 18078,
+ 18079,
+ 18080,
+ 18081,
+ 18082,
+ 18083,
+ 18084,
+ 18085,
+ 18086,
+ 18087,
+ 18088,
+ 18089,
+ 18090,
+ 18091,
+ 18092,
+ 18093,
+ 18094,
+ 18095,
+ 18096,
+ 18097,
+ 18098,
+ 18099,
+ 18100,
+ 18101,
+ 18102,
+ 18103,
+ 18104,
+ 18105,
+ 18106,
+ 18107,
+ 18108,
+ 18109,
+ 18110,
+ 18111,
+ 18112,
+ 18113,
+ 18114,
+ 18115,
+ 18116,
+ 18117,
+ 18118,
+ 18119,
+ 18120,
+ 18121,
+ 18122,
+ 18123,
+ 18124,
+ 18125,
+ 18126,
+ 18127,
+ 18128,
+ 18129,
+ 18130,
+ 18131,
+ 18132,
+ 18133,
+ 18134,
+ 18135,
+ 18136,
+ 18137,
+ 18138,
+ 18139,
+ 18140,
+ 18141,
+ 18142,
+ 18143,
+ 18144,
+ 18145,
+ 18146,
+ 18147,
+ 18148,
+ 18149,
+ 18150,
+ 18151,
+ 18152,
+ 18153,
+ 18154,
+ 18155,
+ 18156,
+ 18157,
+ 18158,
+ 18159,
+ 18160,
+ 18161,
+ 18162,
+ 18163,
+ 18164,
+ 18165,
+ 18166,
+ 18167,
+ 18168,
+ 18169,
+ 18170,
+ 18171,
+ 18172,
+ 18173,
+ 18174,
+ 18175,
+ 18176,
+ 18177,
+ 18178,
+ 18179,
+ 18180,
+ 18181,
+ 18182,
+ 18183,
+ 18184,
+ 18185,
+ 18186,
+ 18187,
+ 18188,
+ 18189,
+ 18190,
+ 18191,
+ 18192,
+ 18193,
+ 18194,
+ 18195,
+ 18196,
+ 18197,
+ 18198,
+ 18199,
+ 18200,
+ 18201,
+ 18202,
+ 18203,
+ 18204,
+ 18205,
+ 18206,
+ 18207,
+ 18208,
+ 18209,
+ 18210,
+ 18211,
+ 18212,
+ 18213,
+ 18214,
+ 18215,
+ 18216,
+ 18217,
+ 18218,
+ 18219,
+ 18220,
+ 18221,
+ 18222,
+ 18223,
+ 18224,
+ 18225,
+ 18226,
+ 18227,
+ 18228,
+ 18229,
+ 18230,
+ 18231,
+ 18232,
+ 18233,
+ 18234,
+ 18235,
+ 18236,
+ 18237,
+ 18238,
+ 18239,
+ 18240,
+ 18241,
+ 18242,
+ 18243,
+ 18244,
+ 18245,
+ 18246,
+ 18247,
+ 18248,
+ 18249,
+ 18250,
+ 18251,
+ 18252,
+ 18253,
+ 18254,
+ 18255,
+ 18256,
+ 18257,
+ 18258,
+ 18259,
+ 18260,
+ 18261,
+ 18262,
+ 18263,
+ 18264,
+ 18265,
+ 18266,
+ 18267,
+ 18268,
+ 18269,
+ 18270,
+ 18271,
+ 18272,
+ 18273,
+ 18274,
+ 18275,
+ 18276,
+ 18277,
+ 18278,
+ 18279,
+ 18280,
+ 18281,
+ 18282,
+ 18283,
+ 18284,
+ 18285,
+ 18286,
+ 18287,
+ 18288,
+ 18289,
+ 18290,
+ 18291,
+ 18292,
+ 18293,
+ 18294,
+ 18295,
+ 18296,
+ 18297,
+ 18298,
+ 18299,
+ 18300,
+ 18301,
+ 18302,
+ 18303,
+ 18304,
+ 18305,
+ 18306,
+ 18307,
+ 18308,
+ 18309,
+ 18310,
+ 18311,
+ 18312,
+ 18313,
+ 18314,
+ 18315,
+ 18316,
+ 18317,
+ 18318,
+ 18319,
+ 18320,
+ 18321,
+ 18322,
+ 18323,
+ 18324,
+ 18325,
+ 18326,
+ 18327,
+ 18328,
+ 18329,
+ 18330,
+ 18331,
+ 18332,
+ 18333,
+ 18334,
+ 18335,
+ 18336,
+ 18337,
+ 18338,
+ 18339,
+ 18340,
+ 18341,
+ 18342,
+ 18343,
+ 18344,
+ 18345,
+ 18346,
+ 18347,
+ 18348,
+ 18349,
+ 18350,
+ 18351,
+ 18352,
+ 18353,
+ 18354,
+ 18355,
+ 18356,
+ 18357,
+ 18358,
+ 18359,
+ 18360,
+ 18361,
+ 18362,
+ 18363,
+ 18364,
+ 18365,
+ 18366,
+ 18367,
+ 18368,
+ 18369,
+ 18370,
+ 18371,
+ 18372,
+ 18373,
+ 18374,
+ 18375,
+ 18376,
+ 18377,
+ 18378,
+ 18379,
+ 18380,
+ 18381,
+ 18382,
+ 18383,
+ 18384,
+ 18385,
+ 18386,
+ 18387,
+ 18388,
+ 18389,
+ 18390,
+ 18391,
+ 18392,
+ 18393,
+ 18394,
+ 18395,
+ 18396,
+ 18397,
+ 18398,
+ 18399,
+ 18400,
+ 18401,
+ 18402,
+ 18403,
+ 18404,
+ 18405,
+ 18406,
+ 18407,
+ 18408,
+ 18409,
+ 18410,
+ 18411,
+ 18412,
+ 18413,
+ 18414,
+ 18415,
+ 18416,
+ 18417,
+ 18418,
+ 18419,
+ 18420,
+ 18421,
+ 18422,
+ 18423,
+ 18424,
+ 18425,
+ 18426,
+ 18427,
+ 18428,
+ 18429,
+ 18430,
+ 18431,
+ 18432,
+ 18433,
+ 18434,
+ 18435,
+ 18436,
+ 18437,
+ 18438,
+ 18439,
+ 18440,
+ 18441,
+ 18442,
+ 18443,
+ 18444,
+ 18445,
+ 18446,
+ 18447,
+ 18448,
+ 18449,
+ 18450,
+ 18451,
+ 18452,
+ 18453,
+ 18454,
+ 18455,
+ 18456,
+ 18457,
+ 18458,
+ 18459,
+ 18460,
+ 18461,
+ 18462,
+ 18463,
+ 18464,
+ 18465,
+ 18466,
+ 18467,
+ 18468,
+ 18469,
+ 18470,
+ 18471,
+ 18472,
+ 18473,
+ 18474,
+ 18475,
+ 18476,
+ 18477,
+ 18478,
+ 18479,
+ 18480,
+ 18481,
+ 18482,
+ 18483,
+ 18484,
+ 18485,
+ 18486,
+ 18487,
+ 18488,
+ 18489,
+ 18490,
+ 18491,
+ 18492,
+ 18493,
+ 18494,
+ 18495,
+ 18496,
+ 18497,
+ 18498,
+ 18499,
+ 18500,
+ 18501,
+ 18502,
+ 18503,
+ 18504,
+ 18505,
+ 18506,
+ 18507,
+ 18508,
+ 18509,
+ 18510,
+ 18511,
+ 18512,
+ 18513,
+ 18514,
+ 18515,
+ 18516,
+ 18517,
+ 18518,
+ 18519,
+ 18520,
+ 18521,
+ 18522,
+ 18523,
+ 18524,
+ 18525,
+ 18526,
+ 18527,
+ 18528,
+ 18529,
+ 18530,
+ 18531,
+ 18532,
+ 18533,
+ 18534,
+ 18535,
+ 18536,
+ 18537,
+ 18538,
+ 18539,
+ 18540,
+ 18541,
+ 18542,
+ 18543,
+ 18544,
+ 18545,
+ 18546,
+ 18547,
+ 18548,
+ 18549,
+ 18550,
+ 18551,
+ 18552,
+ 18553,
+ 18554,
+ 18555,
+ 18556,
+ 18557,
+ 18558,
+ 18559,
+ 18560,
+ 18561,
+ 18562,
+ 18563,
+ 18564,
+ 18565,
+ 18566,
+ 18567,
+ 18568,
+ 18569,
+ 18570,
+ 18571,
+ 18572,
+ 18573,
+ 18574,
+ 18575,
+ 18576,
+ 18577,
+ 18578,
+ 18579,
+ 18580,
+ 18581,
+ 18582,
+ 18583,
+ 18584,
+ 18585,
+ 18586,
+ 18587,
+ 18588,
+ 18589,
+ 18590,
+ 18591,
+ 18592,
+ 18593,
+ 18594,
+ 18595,
+ 18596,
+ 18597,
+ 18598,
+ 18599,
+ 18600,
+ 18601,
+ 18602,
+ 18603,
+ 18604,
+ 18605,
+ 18606,
+ 18607,
+ 18608,
+ 18609,
+ 18610,
+ 18611,
+ 18612,
+ 18613,
+ 18614,
+ 18615,
+ 18616,
+ 18617,
+ 18618,
+ 18619,
+ 18620,
+ 18621,
+ 18622,
+ 18623,
+ 18624,
+ 18625,
+ 18626,
+ 18627,
+ 18628,
+ 18629,
+ 18630,
+ 18631,
+ 18632,
+ 18633,
+ 18634,
+ 18635,
+ 18636,
+ 18637,
+ 18638,
+ 18639,
+ 18640,
+ 18641,
+ 18642,
+ 18643,
+ 18644,
+ 18645,
+ 18646,
+ 18647,
+ 18648,
+ 18649,
+ 18650,
+ 18651,
+ 18652,
+ 18653,
+ 18654,
+ 18655,
+ 18656,
+ 18657,
+ 18658,
+ 18659,
+ 18660,
+ 18661,
+ 18662,
+ 18663,
+ 18664,
+ 18665,
+ 18666,
+ 18667,
+ 18668,
+ 18669,
+ 18670,
+ 18671,
+ 18672,
+ 18673,
+ 18674,
+ 18675,
+ 18676,
+ 18677,
+ 18678,
+ 18679,
+ 18680,
+ 18681,
+ 18682,
+ 18683,
+ 18684,
+ 18685,
+ 18686,
+ 18687,
+ 18688,
+ 18689,
+ 18690,
+ 18691,
+ 18692,
+ 18693,
+ 18694,
+ 18695,
+ 18696,
+ 18697,
+ 18698,
+ 18699,
+ 18700,
+ 18701,
+ 18702,
+ 18703,
+ 18704,
+ 18705,
+ 18706,
+ 18707,
+ 18708,
+ 18709,
+ 18710,
+ 18711,
+ 18712,
+ 18713,
+ 18714,
+ 18715,
+ 18716,
+ 18717,
+ 18718,
+ 18719,
+ 18720,
+ 18721,
+ 18722,
+ 18723,
+ 18724,
+ 18725,
+ 18726,
+ 18727,
+ 18728,
+ 18729,
+ 18730,
+ 18731,
+ 18732,
+ 18733,
+ 18734,
+ 18735,
+ 18736,
+ 18737,
+ 18738,
+ 18739,
+ 18740,
+ 18741,
+ 18742,
+ 18743,
+ 18744,
+ 18745,
+ 18746,
+ 18747,
+ 18748,
+ 18749,
+ 18750,
+ 18751,
+ 18752,
+ 18753,
+ 18754,
+ 18755,
+ 18756,
+ 18757,
+ 18758,
+ 18759,
+ 18760,
+ 18761,
+ 18762,
+ 18763,
+ 18764,
+ 18765,
+ 18766,
+ 18767,
+ 18768,
+ 18769,
+ 18770,
+ 18771,
+ 18772,
+ 18773,
+ 18774,
+ 18775,
+ 18776,
+ 18777,
+ 18778,
+ 18779,
+ 18780,
+ 18781,
+ 18782,
+ 18783,
+ 18784,
+ 18785,
+ 18786,
+ 18787,
+ 18788,
+ 18789,
+ 18790,
+ 18791,
+ 18792,
+ 18793,
+ 18794,
+ 18795,
+ 18796,
+ 18797,
+ 18798,
+ 18799,
+ 18800,
+ 18801,
+ 18802,
+ 18803,
+ 18804,
+ 18805,
+ 18806,
+ 18807,
+ 18808,
+ 18809,
+ 18810,
+ 18811,
+ 18812,
+ 18813,
+ 18814,
+ 18815,
+ 18816,
+ 18817,
+ 18818,
+ 18819,
+ 18820,
+ 18821,
+ 18822,
+ 18823,
+ 18824,
+ 18825,
+ 18826,
+ 18827,
+ 18828,
+ 18829,
+ 18830,
+ 18831,
+ 18832,
+ 18833,
+ 18834,
+ 18835,
+ 18836,
+ 18837,
+ 18838,
+ 18839,
+ 18840,
+ 18841,
+ 18842,
+ 18843,
+ 18844,
+ 18845,
+ 18846,
+ 18847,
+ 18848,
+ 18849,
+ 18850,
+ 18851,
+ 18852,
+ 18853,
+ 18854,
+ 18855,
+ 18856,
+ 18857,
+ 18858,
+ 18859,
+ 18860,
+ 18861,
+ 18862,
+ 18863,
+ 18864,
+ 18865,
+ 18866,
+ 18867,
+ 18868,
+ 18869,
+ 18870,
+ 18871,
+ 18872,
+ 18873,
+ 18874,
+ 18875,
+ 18876,
+ 18877,
+ 18878,
+ 18879,
+ 18880,
+ 18881,
+ 18882,
+ 18883,
+ 18884,
+ 18885,
+ 18886,
+ 18887,
+ 18888,
+ 18889,
+ 18890,
+ 18891,
+ 18892,
+ 18893,
+ 18894,
+ 18895,
+ 18896,
+ 18897,
+ 18898,
+ 18899,
+ 18900,
+ 18901,
+ 18902,
+ 18903,
+ 18904,
+ 18905,
+ 18906,
+ 18907,
+ 18908,
+ 18909,
+ 18910,
+ 18911,
+ 18912,
+ 18913,
+ 18914,
+ 18915,
+ 18916,
+ 18917,
+ 18918,
+ 18919,
+ 18920,
+ 18921,
+ 18922,
+ 18923,
+ 18924,
+ 18925,
+ 18926,
+ 18927,
+ 18928,
+ 18929,
+ 18930,
+ 18931,
+ 18932,
+ 18933,
+ 18934,
+ 18935,
+ 18936,
+ 18937,
+ 18938,
+ 18939,
+ 18940,
+ 18941,
+ 18942,
+ 18943,
+ 18944,
+ 18945,
+ 18946,
+ 18947,
+ 18948,
+ 18949,
+ 18950,
+ 18951,
+ 18952,
+ 18953,
+ 18954,
+ 18955,
+ 18956,
+ 18957,
+ 18958,
+ 18959,
+ 18960,
+ 18961,
+ 18962,
+ 18963,
+ 18964,
+ 18965,
+ 18966,
+ 18967,
+ 18968,
+ 18969,
+ 18970,
+ 18971,
+ 18972,
+ 18973,
+ 18974,
+ 18975,
+ 18976,
+ 18977,
+ 18978,
+ 18979,
+ 18980,
+ 18981,
+ 18982,
+ 18983,
+ 18984,
+ 18985,
+ 18986,
+ 18987,
+ 18988,
+ 18989,
+ 18990,
+ 18991,
+ 18992,
+ 18993,
+ 18994,
+ 18995,
+ 18996,
+ 18997,
+ 18998,
+ 18999,
+ 19000,
+ 19001,
+ 19002,
+ 19003,
+ 19004,
+ 19005,
+ 19006,
+ 19007,
+ 19008,
+ 19009,
+ 19010,
+ 19011,
+ 19012,
+ 19013,
+ 19014,
+ 19015,
+ 19016,
+ 19017,
+ 19018,
+ 19019,
+ 19020,
+ 19021,
+ 19022,
+ 19023,
+ 19024,
+ 19025,
+ 19026,
+ 19027,
+ 19028,
+ 19029,
+ 19030,
+ 19031,
+ 19032,
+ 19033,
+ 19034,
+ 19035,
+ 19036,
+ 19037,
+ 19038,
+ 19039,
+ 19040,
+ 19041,
+ 19042,
+ 19043,
+ 19044,
+ 19045,
+ 19046,
+ 19047,
+ 19048,
+ 19049,
+ 19050,
+ 19051,
+ 19052,
+ 19053,
+ 19054,
+ 19055,
+ 19056,
+ 19057,
+ 19058,
+ 19059,
+ 19060,
+ 19061,
+ 19062,
+ 19063,
+ 19064,
+ 19065,
+ 19066,
+ 19067,
+ 19068,
+ 19069,
+ 19070,
+ 19071,
+ 19072,
+ 19073,
+ 19074,
+ 19075,
+ 19076,
+ 19077,
+ 19078,
+ 19079,
+ 19080,
+ 19081,
+ 19082,
+ 19083,
+ 19084,
+ 19085,
+ 19086,
+ 19087,
+ 19088,
+ 19089,
+ 19090,
+ 19091,
+ 19092,
+ 19093,
+ 19094,
+ 19095,
+ 19096,
+ 19097,
+ 19098,
+ 19099,
+ 19100,
+ 19101,
+ 19102,
+ 19103,
+ 19104,
+ 19105,
+ 19106,
+ 19107,
+ 19108,
+ 19109,
+ 19110,
+ 19111,
+ 19112,
+ 19113,
+ 19114,
+ 19115,
+ 19116,
+ 19117,
+ 19118,
+ 19119,
+ 19120,
+ 19121,
+ 19122,
+ 19123,
+ 19124,
+ 19125,
+ 19126,
+ 19127,
+ 19128,
+ 19129,
+ 19130,
+ 19131,
+ 19132,
+ 19133,
+ 19134,
+ 19135,
+ 19136,
+ 19137,
+ 19138,
+ 19139,
+ 19140,
+ 19141,
+ 19142,
+ 19143,
+ 19144,
+ 19145,
+ 19146,
+ 19147,
+ 19148,
+ 19149,
+ 19150,
+ 19151,
+ 19152,
+ 19153,
+ 19154,
+ 19155,
+ 19156,
+ 19157,
+ 19158,
+ 19159,
+ 19160,
+ 19161,
+ 19162,
+ 19163,
+ 19164,
+ 19165,
+ 19166,
+ 19167,
+ 19168,
+ 19169,
+ 19170,
+ 19171,
+ 19172,
+ 19173,
+ 19174,
+ 19175,
+ 19176,
+ 19177,
+ 19178,
+ 19179,
+ 19180,
+ 19181,
+ 19182,
+ 19183,
+ 19184,
+ 19185,
+ 19186,
+ 19187,
+ 19188,
+ 19189,
+ 19190,
+ 19191,
+ 19192,
+ 19193,
+ 19194,
+ 19195,
+ 19196,
+ 19197,
+ 19198,
+ 19199,
+ 19200,
+ 19201,
+ 19202,
+ 19203,
+ 19204,
+ 19205,
+ 19206,
+ 19207,
+ 19208,
+ 19209,
+ 19210,
+ 19211,
+ 19212,
+ 19213,
+ 19214,
+ 19215,
+ 19216,
+ 19217,
+ 19218,
+ 19219,
+ 19220,
+ 19221,
+ 19222,
+ 19223,
+ 19224,
+ 19225,
+ 19226,
+ 19227,
+ 19228,
+ 19229,
+ 19230,
+ 19231,
+ 19232,
+ 19233,
+ 19234,
+ 19235,
+ 19236,
+ 19237,
+ 19238,
+ 19239,
+ 19240,
+ 19241,
+ 19242,
+ 19243,
+ 19244,
+ 19245,
+ 19246,
+ 19247,
+ 19248,
+ 19249,
+ 19250,
+ 19251,
+ 19252,
+ 19253,
+ 19254,
+ 19255,
+ 19256,
+ 19257,
+ 19258,
+ 19259,
+ 19260,
+ 19261,
+ 19262,
+ 19263,
+ 19264,
+ 19265,
+ 19266,
+ 19267,
+ 19268,
+ 19269,
+ 19270,
+ 19271,
+ 19272,
+ 19273,
+ 19274,
+ 19275,
+ 19276,
+ 19277,
+ 19278,
+ 19279,
+ 19280,
+ 19281,
+ 19282,
+ 19283,
+ 19284,
+ 19285,
+ 19286,
+ 19287,
+ 19288,
+ 19289,
+ 19290,
+ 19291,
+ 19292,
+ 19293,
+ 19294,
+ 19295,
+ 19296,
+ 19297,
+ 19298,
+ 19299,
+ 19300,
+ 19301,
+ 19302,
+ 19303,
+ 19304,
+ 19305,
+ 19306,
+ 19307,
+ 19308,
+ 19309,
+ 19310,
+ 19311,
+ 19312,
+ 19313,
+ 19314,
+ 19315,
+ 19316,
+ 19317,
+ 19318,
+ 19319,
+ 19320,
+ 19321,
+ 19322,
+ 19323,
+ 19324,
+ 19325,
+ 19326,
+ 19327,
+ 19328,
+ 19329,
+ 19330,
+ 19331,
+ 19332,
+ 19333,
+ 19334,
+ 19335,
+ 19336,
+ 19337,
+ 19338,
+ 19339,
+ 19340,
+ 19341,
+ 19342,
+ 19343,
+ 19344,
+ 19345,
+ 19346,
+ 19347,
+ 19348,
+ 19349,
+ 19350,
+ 19351,
+ 19352,
+ 19353,
+ 19354,
+ 19355,
+ 19356,
+ 19357,
+ 19358,
+ 19359,
+ 19360,
+ 19361,
+ 19362,
+ 19363,
+ 19364,
+ 19365,
+ 19366,
+ 19367,
+ 19368,
+ 19369,
+ 19370,
+ 19371,
+ 19372,
+ 19373,
+ 19374,
+ 19375,
+ 19376,
+ 19377,
+ 19378,
+ 19379,
+ 19380,
+ 19381,
+ 19382,
+ 19383,
+ 19384,
+ 19385,
+ 19386,
+ 19387,
+ 19388,
+ 19389,
+ 19390,
+ 19391,
+ 19392,
+ 19393,
+ 19394,
+ 19395,
+ 19396,
+ 19397,
+ 19398,
+ 19399,
+ 19400,
+ 19401,
+ 19402,
+ 19403,
+ 19404,
+ 19405,
+ 19406,
+ 19407,
+ 19408,
+ 19409,
+ 19410,
+ 19411,
+ 19412,
+ 19413,
+ 19414,
+ 19415,
+ 19416,
+ 19417,
+ 19418,
+ 19419,
+ 19420,
+ 19421,
+ 19422,
+ 19423,
+ 19424,
+ 19425,
+ 19426,
+ 19427,
+ 19428,
+ 19429,
+ 19430,
+ 19431,
+ 19432,
+ 19433,
+ 19434,
+ 19435,
+ 19436,
+ 19437,
+ 19438,
+ 19439,
+ 19440,
+ 19441,
+ 19442,
+ 19443,
+ 19444,
+ 19445,
+ 19446,
+ 19447,
+ 19448,
+ 19449,
+ 19450,
+ 19451,
+ 19452,
+ 19453,
+ 19454,
+ 19455,
+ 19456,
+ 19457,
+ 19458,
+ 19459,
+ 19460,
+ 19461,
+ 19462,
+ 19463,
+ 19464,
+ 19465,
+ 19466,
+ 19467,
+ 19468,
+ 19469,
+ 19470,
+ 19471,
+ 19472,
+ 19473,
+ 19474,
+ 19475,
+ 19476,
+ 19477,
+ 19478,
+ 19479,
+ 19480,
+ 19481,
+ 19482,
+ 19483,
+ 19484,
+ 19485,
+ 19486,
+ 19487,
+ 19488,
+ 19489,
+ 19490,
+ 19491,
+ 19492,
+ 19493,
+ 19494,
+ 19495,
+ 19496,
+ 19497,
+ 19498,
+ 19499,
+ 19500,
+ 19501,
+ 19502,
+ 19503,
+ 19504,
+ 19505,
+ 19506,
+ 19507,
+ 19508,
+ 19509,
+ 19510,
+ 19511,
+ 19512,
+ 19513,
+ 19514,
+ 19515,
+ 19516,
+ 19517,
+ 19518,
+ 19519,
+ 19520,
+ 19521,
+ 19522,
+ 19523,
+ 19524,
+ 19525,
+ 19526,
+ 19527,
+ 19528,
+ 19529,
+ 19530,
+ 19531,
+ 19532,
+ 19533,
+ 19534,
+ 19535,
+ 19536,
+ 19537,
+ 19538,
+ 19539,
+ 19540,
+ 19541,
+ 19542,
+ 19543,
+ 19544,
+ 19545,
+ 19546,
+ 19547,
+ 19548,
+ 19549,
+ 19550,
+ 19551,
+ 19552,
+ 19553,
+ 19554,
+ 19555,
+ 19556,
+ 19557,
+ 19558,
+ 19559,
+ 19560,
+ 19561,
+ 19562,
+ 19563,
+ 19564,
+ 19565,
+ 19566,
+ 19567,
+ 19568,
+ 19569,
+ 19570,
+ 19571,
+ 19572,
+ 19573,
+ 19574,
+ 19575,
+ 19576,
+ 19577,
+ 19578,
+ 19579,
+ 19580,
+ 19581,
+ 19582,
+ 19583,
+ 19584,
+ 19585,
+ 19586,
+ 19587,
+ 19588,
+ 19589,
+ 19590,
+ 19591,
+ 19592,
+ 19593,
+ 19594,
+ 19595,
+ 19596,
+ 19597,
+ 19598,
+ 19599,
+ 19600,
+ 19601,
+ 19602,
+ 19603,
+ 19604,
+ 19605,
+ 19606,
+ 19607,
+ 19608,
+ 19609,
+ 19610,
+ 19611,
+ 19612,
+ 19613,
+ 19614,
+ 19615,
+ 19616,
+ 19617,
+ 19618,
+ 19619,
+ 19620,
+ 19621,
+ 19622,
+ 19623,
+ 19624,
+ 19625,
+ 19626,
+ 19627,
+ 19628,
+ 19629,
+ 19630,
+ 19631,
+ 19632,
+ 19633,
+ 19634,
+ 19635,
+ 19636,
+ 19637,
+ 19638,
+ 19639,
+ 19640,
+ 19641,
+ 19642,
+ 19643,
+ 19644,
+ 19645,
+ 19646,
+ 19647,
+ 19648,
+ 19649,
+ 19650,
+ 19651,
+ 19652,
+ 19653,
+ 19654,
+ 19655,
+ 19656,
+ 19657,
+ 19658,
+ 19659,
+ 19660,
+ 19661,
+ 19662,
+ 19663,
+ 19664,
+ 19665,
+ 19666,
+ 19667,
+ 19668,
+ 19669,
+ 19670,
+ 19671,
+ 19672,
+ 19673,
+ 19674,
+ 19675,
+ 19676,
+ 19677,
+ 19678,
+ 19679,
+ 19680,
+ 19681,
+ 19682,
+ 19683,
+ 19684,
+ 19685,
+ 19686,
+ 19687,
+ 19688,
+ 19689,
+ 19690,
+ 19691,
+ 19692,
+ 19693,
+ 19694,
+ 19695,
+ 19696,
+ 19697,
+ 19698,
+ 19699,
+ 19700,
+ 19701,
+ 19702,
+ 19703,
+ 19704,
+ 19705,
+ 19706,
+ 19707,
+ 19708,
+ 19709,
+ 19710,
+ 19711,
+ 19712,
+ 19713,
+ 19714,
+ 19715,
+ 19716,
+ 19717,
+ 19718,
+ 19719,
+ 19720,
+ 19721,
+ 19722,
+ 19723,
+ 19724,
+ 19725,
+ 19726,
+ 19727,
+ 19728,
+ 19729,
+ 19730,
+ 19731,
+ 19732,
+ 19733,
+ 19734,
+ 19735,
+ 19736,
+ 19737,
+ 19738,
+ 19739,
+ 19740,
+ 19741,
+ 19742,
+ 19743,
+ 19744,
+ 19745,
+ 19746,
+ 19747,
+ 19748,
+ 19749,
+ 19750,
+ 19751,
+ 19752,
+ 19753,
+ 19754,
+ 19755,
+ 19756,
+ 19757,
+ 19758,
+ 19759,
+ 19760,
+ 19761,
+ 19762,
+ 19763,
+ 19764,
+ 19765,
+ 19766,
+ 19767,
+ 19768,
+ 19769,
+ 19770,
+ 19771,
+ 19772,
+ 19773,
+ 19774,
+ 19775,
+ 19776,
+ 19777,
+ 19778,
+ 19779,
+ 19780,
+ 19781,
+ 19782,
+ 19783,
+ 19784,
+ 19785,
+ 19786,
+ 19787,
+ 19788,
+ 19789,
+ 19790,
+ 19791,
+ 19792,
+ 19793,
+ 19794,
+ 19795,
+ 19796,
+ 19797,
+ 19798,
+ 19799,
+ 19800,
+ 19801,
+ 19802,
+ 19803,
+ 19804,
+ 19805,
+ 19806,
+ 19807,
+ 19808,
+ 19809,
+ 19810,
+ 19811,
+ 19812,
+ 19813,
+ 19814,
+ 19815,
+ 19816,
+ 19817,
+ 19818,
+ 19819,
+ 19820,
+ 19821,
+ 19822,
+ 19823,
+ 19824,
+ 19825,
+ 19826,
+ 19827,
+ 19828,
+ 19829,
+ 19830,
+ 19831,
+ 19832,
+ 19833,
+ 19834,
+ 19835,
+ 19836,
+ 19837,
+ 19838,
+ 19839,
+ 19840,
+ 19841,
+ 19842,
+ 19843,
+ 19844,
+ 19845,
+ 19846,
+ 19847,
+ 19848,
+ 19849,
+ 19850,
+ 19851,
+ 19852,
+ 19853,
+ 19854,
+ 19855,
+ 19856,
+ 19857,
+ 19858,
+ 19859,
+ 19860,
+ 19861,
+ 19862,
+ 19863,
+ 19864,
+ 19865,
+ 19866,
+ 19867,
+ 19868,
+ 19869,
+ 19870,
+ 19871,
+ 19872,
+ 19873,
+ 19874,
+ 19875,
+ 19876,
+ 19877,
+ 19878,
+ 19879,
+ 19880,
+ 19881,
+ 19882,
+ 19883,
+ 19884,
+ 19885,
+ 19886,
+ 19887,
+ 19888,
+ 19889,
+ 19890,
+ 19891,
+ 19892,
+ 19893,
+ 19894,
+ 19895,
+ 19896,
+ 19897,
+ 19898,
+ 19899,
+ 19900,
+ 19901,
+ 19902,
+ 19903,
+ 19904,
+ 19905,
+ 19906,
+ 19907,
+ 19908,
+ 19909,
+ 19910,
+ 19911,
+ 19912,
+ 19913,
+ 19914,
+ 19915,
+ 19916,
+ 19917,
+ 19918,
+ 19919,
+ 19920,
+ 19921,
+ 19922,
+ 19923,
+ 19924,
+ 19925,
+ 19926,
+ 19927,
+ 19928,
+ 19929,
+ 19930,
+ 19931,
+ 19932,
+ 19933,
+ 19934,
+ 19935,
+ 19936,
+ 19937,
+ 19938,
+ 19939,
+ 19940,
+ 19941,
+ 19942,
+ 19943,
+ 19944,
+ 19945,
+ 19946,
+ 19947,
+ 19948,
+ 19949,
+ 19950,
+ 19951,
+ 19952,
+ 19953,
+ 19954,
+ 19955,
+ 19956,
+ 19957,
+ 19958,
+ 19959,
+ 19960,
+ 19961,
+ 19962,
+ 19963,
+ 19964,
+ 19965,
+ 19966,
+ 19967,
+ 19968,
+ 19969,
+ 19970,
+ 19971,
+ 19972,
+ 19973,
+ 19974,
+ 19975,
+ 19976,
+ 19977,
+ 19978,
+ 19979,
+ 19980,
+ 19981,
+ 19982,
+ 19983,
+ 19984,
+ 19985,
+ 19986,
+ 19987,
+ 19988,
+ 19989,
+ 19990,
+ 19991,
+ 19992,
+ 19993,
+ 19994,
+ 19995,
+ 19996,
+ 19997,
+ 19998,
+ 19999,
+ 20000,
+ 20001,
+ 20002,
+ 20003,
+ 20004,
+ 20005,
+ 20006,
+ 20007,
+ 20008,
+ 20009,
+ 20010,
+ 20011,
+ 20012,
+ 20013,
+ 20014,
+ 20015,
+ 20016,
+ 20017,
+ 20018,
+ 20019,
+ 20020,
+ 20021,
+ 20022,
+ 20023,
+ 20024,
+ 20025,
+ 20026,
+ 20027,
+ 20028,
+ 20029,
+ 20030,
+ 20031,
+ 20032,
+ 20033,
+ 20034,
+ 20035,
+ 20036,
+ 20037,
+ 20038,
+ 20039,
+ 20040,
+ 20041,
+ 20042,
+ 20043,
+ 20044,
+ 20045,
+ 20046,
+ 20047,
+ 20048,
+ 20049,
+ 20050,
+ 20051,
+ 20052,
+ 20053,
+ 20054,
+ 20055,
+ 20056,
+ 20057,
+ 20058,
+ 20059,
+ 20060,
+ 20061,
+ 20062,
+ 20063,
+ 20064,
+ 20065,
+ 20066,
+ 20067,
+ 20068,
+ 20069,
+ 20070,
+ 20071,
+ 20072,
+ 20073,
+ 20074,
+ 20075,
+ 20076,
+ 20077,
+ 20078,
+ 20079,
+ 20080,
+ 20081,
+ 20082,
+ 20083,
+ 20084,
+ 20085,
+ 20086,
+ 20087,
+ 20088,
+ 20089,
+ 20090,
+ 20091,
+ 20092,
+ 20093,
+ 20094,
+ 20095,
+ 20096,
+ 20097,
+ 20098,
+ 20099,
+ 20100,
+ 20101,
+ 20102,
+ 20103,
+ 20104,
+ 20105,
+ 20106,
+ 20107,
+ 20108,
+ 20109,
+ 20110,
+ 20111,
+ 20112,
+ 20113,
+ 20114,
+ 20115,
+ 20116,
+ 20117,
+ 20118,
+ 20119,
+ 20120,
+ 20121,
+ 20122,
+ 20123,
+ 20124,
+ 20125,
+ 20126,
+ 20127,
+ 20128,
+ 20129,
+ 20130,
+ 20131,
+ 20132,
+ 20133,
+ 20134,
+ 20135,
+ 20136,
+ 20137,
+ 20138,
+ 20139,
+ 20140,
+ 20141,
+ 20142,
+ 20143,
+ 20144,
+ 20145,
+ 20146,
+ 20147,
+ 20148,
+ 20149,
+ 20150,
+ 20151,
+ 20152,
+ 20153,
+ 20154,
+ 20155,
+ 20156,
+ 20157,
+ 20158,
+ 20159,
+ 20160,
+ 20161,
+ 20162,
+ 20163,
+ 20164,
+ 20165,
+ 20166,
+ 20167,
+ 20168,
+ 20169,
+ 20170,
+ 20171,
+ 20172,
+ 20173,
+ 20174,
+ 20175,
+ 20176,
+ 20177,
+ 20178,
+ 20179,
+ 20180,
+ 20181,
+ 20182,
+ 20183,
+ 20184,
+ 20185,
+ 20186,
+ 20187,
+ 20188,
+ 20189,
+ 20190,
+ 20191,
+ 20192,
+ 20193,
+ 20194,
+ 20195,
+ 20196,
+ 20197,
+ 20198,
+ 20199,
+ 20200,
+ 20201,
+ 20202,
+ 20203,
+ 20204,
+ 20205,
+ 20206,
+ 20207,
+ 20208,
+ 20209,
+ 20210,
+ 20211,
+ 20212,
+ 20213,
+ 20214,
+ 20215,
+ 20216,
+ 20217,
+ 20218,
+ 20219,
+ 20220,
+ 20221,
+ 20222,
+ 20223,
+ 20224,
+ 20225,
+ 20226,
+ 20227,
+ 20228,
+ 20229,
+ 20230,
+ 20231,
+ 20232,
+ 20233,
+ 20234,
+ 20235,
+ 20236,
+ 20237,
+ 20238,
+ 20239,
+ 20240,
+ 20241,
+ 20242,
+ 20243,
+ 20244,
+ 20245,
+ 20246,
+ 20247,
+ 20248,
+ 20249,
+ 20250,
+ 20251,
+ 20252,
+ 20253,
+ 20254,
+ 20255,
+ 20256,
+ 20257,
+ 20258,
+ 20259,
+ 20260,
+ 20261,
+ 20262,
+ 20263,
+ 20264,
+ 20265,
+ 20266,
+ 20267,
+ 20268,
+ 20269,
+ 20270,
+ 20271,
+ 20272,
+ 20273,
+ 20274,
+ 20275,
+ 20276,
+ 20277,
+ 20278,
+ 20279,
+ 20280,
+ 20281,
+ 20282,
+ 20283,
+ 20284,
+ 20285,
+ 20286,
+ 20287,
+ 20288,
+ 20289,
+ 20290,
+ 20291,
+ 20292,
+ 20293,
+ 20294,
+ 20295,
+ 20296,
+ 20297,
+ 20298,
+ 20299,
+ 20300,
+ 20301,
+ 20302,
+ 20303,
+ 20304,
+ 20305,
+ 20306,
+ 20307,
+ 20308,
+ 20309,
+ 20310,
+ 20311,
+ 20312,
+ 20313,
+ 20314,
+ 20315,
+ 20316,
+ 20317,
+ 20318,
+ 20319,
+ 20320,
+ 20321,
+ 20322,
+ 20323,
+ 20324,
+ 20325,
+ 20326,
+ 20327,
+ 20328,
+ 20329,
+ 20330,
+ 20331,
+ 20332,
+ 20333,
+ 20334,
+ 20335,
+ 20336,
+ 20337,
+ 20338,
+ 20339,
+ 20340,
+ 20341,
+ 20342,
+ 20343,
+ 20344,
+ 20345,
+ 20346,
+ 20347,
+ 20348,
+ 20349,
+ 20350,
+ 20351,
+ 20352,
+ 20353,
+ 20354,
+ 20355,
+ 20356,
+ 20357,
+ 20358,
+ 20359,
+ 20360,
+ 20361,
+ 20362,
+ 20363,
+ 20364,
+ 20365,
+ 20366,
+ 20367,
+ 20368,
+ 20369,
+ 20370,
+ 20371,
+ 20372,
+ 20373,
+ 20374,
+ 20375,
+ 20376,
+ 20377,
+ 20378,
+ 20379,
+ 20380,
+ 20381,
+ 20382,
+ 20383,
+ 20384,
+ 20385,
+ 20386,
+ 20387,
+ 20388,
+ 20389,
+ 20390,
+ 20391,
+ 20392,
+ 20393,
+ 20394,
+ 20395,
+ 20396,
+ 20397,
+ 20398,
+ 20399,
+ 20400,
+ 20401,
+ 20402,
+ 20403,
+ 20404,
+ 20405,
+ 20406,
+ 20407,
+ 20408,
+ 20409,
+ 20410,
+ 20411,
+ 20412,
+ 20413,
+ 20414,
+ 20415,
+ 20416,
+ 20417,
+ 20418,
+ 20419,
+ 20420,
+ 20421,
+ 20422,
+ 20423,
+ 20424,
+ 20425,
+ 20426,
+ 20427,
+ 20428,
+ 20429,
+ 20430,
+ 20431,
+ 20432,
+ 20433,
+ 20434,
+ 20435,
+ 20436,
+ 20437,
+ 20438,
+ 20439,
+ 20440,
+ 20441,
+ 20442,
+ 20443,
+ 20444,
+ 20445,
+ 20446,
+ 20447,
+ 20448,
+ 20449,
+ 20450,
+ 20451,
+ 20452,
+ 20453,
+ 20454,
+ 20455,
+ 20456,
+ 20457,
+ 20458,
+ 20459,
+ 20460,
+ 20461,
+ 20462,
+ 20463,
+ 20464,
+ 20465,
+ 20466,
+ 20467,
+ 20468,
+ 20469,
+ 20470,
+ 20471,
+ 20472,
+ 20473,
+ 20474,
+ 20475,
+ 20476,
+ 20477,
+ 20478,
+ 20479,
+ 20480,
+ 20481,
+ 20482,
+ 20483,
+ 20484,
+ 20485,
+ 20486,
+ 20487,
+ 20488,
+ 20489,
+ 20490,
+ 20491,
+ 20492,
+ 20493,
+ 20494,
+ 20495,
+ 20496,
+ 20497,
+ 20498,
+ 20499,
+ 20500,
+ 20501,
+ 20502,
+ 20503,
+ 20504,
+ 20505,
+ 20506,
+ 20507,
+ 20508,
+ 20509,
+ 20510,
+ 20511,
+ 20512,
+ 20513,
+ 20514,
+ 20515,
+ 20516,
+ 20517,
+ 20518,
+ 20519,
+ 20520,
+ 20521,
+ 20522,
+ 20523,
+ 20524,
+ 20525,
+ 20526,
+ 20527,
+ 20528,
+ 20529,
+ 20530,
+ 20531,
+ 20532,
+ 20533,
+ 20534,
+ 20535,
+ 20536,
+ 20537,
+ 20538,
+ 20539,
+ 20540,
+ 20541,
+ 20542,
+ 20543,
+ 20544,
+ 20545,
+ 20546,
+ 20547,
+ 20548,
+ 20549,
+ 20550,
+ 20551,
+ 20552,
+ 20553,
+ 20554,
+ 20555,
+ 20556,
+ 20557,
+ 20558,
+ 20559,
+ 20560,
+ 20561,
+ 20562,
+ 20563,
+ 20564,
+ 20565,
+ 20566,
+ 20567,
+ 20568,
+ 20569,
+ 20570,
+ 20571,
+ 20572,
+ 20573,
+ 20574,
+ 20575,
+ 20576,
+ 20577,
+ 20578,
+ 20579,
+ 20580,
+ 20581,
+ 20582,
+ 20583,
+ 20584,
+ 20585,
+ 20586,
+ 20587,
+ 20588,
+ 20589,
+ 20590,
+ 20591,
+ 20592,
+ 20593,
+ 20594,
+ 20595,
+ 20596,
+ 20597,
+ 20598,
+ 20599,
+ 20600,
+ 20601,
+ 20602,
+ 20603,
+ 20604,
+ 20605,
+ 20606,
+ 20607,
+ 20608,
+ 20609,
+ 20610,
+ 20611,
+ 20612,
+ 20613,
+ 20614,
+ 20615,
+ 20616,
+ 20617,
+ 20618,
+ 20619,
+ 20620,
+ 20621,
+ 20622,
+ 20623,
+ 20624,
+ 20625,
+ 20626,
+ 20627,
+ 20628,
+ 20629,
+ 20630,
+ 20631,
+ 20632,
+ 20633,
+ 20634,
+ 20635,
+ 20636,
+ 20637,
+ 20638,
+ 20639,
+ 20640,
+ 20641,
+ 20642,
+ 20643,
+ 20644,
+ 20645,
+ 20646,
+ 20647,
+ 20648,
+ 20649,
+ 20650,
+ 20651,
+ 20652,
+ 20653,
+ 20654,
+ 20655,
+ 20656,
+ 20657,
+ 20658,
+ 20659,
+ 20660,
+ 20661,
+ 20662,
+ 20663,
+ 20664,
+ 20665,
+ 20666,
+ 20667,
+ 20668,
+ 20669,
+ 20670,
+ 20671,
+ 20672,
+ 20673,
+ 20674,
+ 20675,
+ 20676,
+ 20677,
+ 20678,
+ 20679,
+ 20680,
+ 20681,
+ 20682,
+ 20683,
+ 20684,
+ 20685,
+ 20686,
+ 20687,
+ 20688,
+ 20689,
+ 20690,
+ 20691,
+ 20692,
+ 20693,
+ 20694,
+ 20695,
+ 20696,
+ 20697,
+ 20698,
+ 20699,
+ 20700,
+ 20701,
+ 20702,
+ 20703,
+ 20704,
+ 20705,
+ 20706,
+ 20707,
+ 20708,
+ 20709,
+ 20710,
+ 20711,
+ 20712,
+ 20713,
+ 20714,
+ 20715,
+ 20716,
+ 20717,
+ 20718,
+ 20719,
+ 20720,
+ 20721,
+ 20722,
+ 20723,
+ 20724,
+ 20725,
+ 20726,
+ 20727,
+ 20728,
+ 20729,
+ 20730,
+ 20731,
+ 20732,
+ 20733,
+ 20734,
+ 20735,
+ 20736,
+ 20737,
+ 20738,
+ 20739,
+ 20740,
+ 20741,
+ 20742,
+ 20743,
+ 20744,
+ 20745,
+ 20746,
+ 20747,
+ 20748,
+ 20749,
+ 20750,
+ 20751,
+ 20752,
+ 20753,
+ 20754,
+ 20755,
+ 20756,
+ 20757,
+ 20758,
+ 20759,
+ 20760,
+ 20761,
+ 20762,
+ 20763,
+ 20764,
+ 20765,
+ 20766,
+ 20767,
+ 20768,
+ 20769,
+ 20770,
+ 20771,
+ 20772,
+ 20773,
+ 20774,
+ 20775,
+ 20776,
+ 20777,
+ 20778,
+ 20779,
+ 20780,
+ 20781,
+ 20782,
+ 20783,
+ 20784,
+ 20785,
+ 20786,
+ 20787,
+ 20788,
+ 20789,
+ 20790,
+ 20791,
+ 20792,
+ 20793,
+ 20794,
+ 20795,
+ 20796,
+ 20797,
+ 20798,
+ 20799,
+ 20800,
+ 20801,
+ 20802,
+ 20803,
+ 20804,
+ 20805,
+ 20806,
+ 20807,
+ 20808,
+ 20809,
+ 20810,
+ 20811,
+ 20812,
+ 20813,
+ 20814,
+ 20815,
+ 20816,
+ 20817,
+ 20818,
+ 20819,
+ 20820,
+ 20821,
+ 20822,
+ 20823,
+ 20824,
+ 20825,
+ 20826,
+ 20827,
+ 20828,
+ 20829,
+ 20830,
+ 20831,
+ 20832,
+ 20833,
+ 20834,
+ 20835,
+ 20836,
+ 20837,
+ 20838,
+ 20839,
+ 20840,
+ 20841,
+ 20842,
+ 20843,
+ 20844,
+ 20845,
+ 20846,
+ 20847,
+ 20848,
+ 20849,
+ 20850,
+ 20851,
+ 20852,
+ 20853,
+ 20854,
+ 20855,
+ 20856,
+ 20857,
+ 20858,
+ 20859,
+ 20860,
+ 20861,
+ 20862,
+ 20863,
+ 20864,
+ 20865,
+ 20866,
+ 20867,
+ 20868,
+ 20869,
+ 20870,
+ 20871,
+ 20872,
+ 20873,
+ 20874,
+ 20875,
+ 20876,
+ 20877,
+ 20878,
+ 20879,
+ 20880,
+ 20881,
+ 20882,
+ 20883,
+ 20884,
+ 20885,
+ 20886,
+ 20887,
+ 20888,
+ 20889,
+ 20890,
+ 20891,
+ 20892,
+ 20893,
+ 20894,
+ 20895,
+ 20896,
+ 20897,
+ 20898,
+ 20899,
+ 20900,
+ 20901,
+ 20902,
+ 20903,
+ 20904,
+ 20905,
+ 20906,
+ 20907,
+ 20908,
+ 20909,
+ 20910,
+ 20911,
+ 20912,
+ 20913,
+ 20914,
+ 20915,
+ 20916,
+ 20917,
+ 20918,
+ 20919,
+ 20920,
+ 20921,
+ 20922,
+ 20923,
+ 20924,
+ 20925,
+ 20926,
+ 20927,
+ 20928,
+ 20929,
+ 20930,
+ 20931,
+ 20932,
+ 20933,
+ 20934,
+ 20935,
+ 20936,
+ 20937,
+ 20938,
+ 20939,
+ 20940,
+ 20941,
+ 20942,
+ 20943,
+ 20944,
+ 20945,
+ 20946,
+ 20947,
+ 20948,
+ 20949,
+ 20950,
+ 20951,
+ 20952,
+ 20953,
+ 20954,
+ 20955,
+ 20956,
+ 20957,
+ 20958,
+ 20959,
+ 20960,
+ 20961,
+ 20962,
+ 20963,
+ 20964,
+ 20965,
+ 20966,
+ 20967,
+ 20968,
+ 20969,
+ 20970,
+ 20971,
+ 20972,
+ 20973,
+ 20974,
+ 20975,
+ 20976,
+ 20977,
+ 20978,
+ 20979,
+ 20980,
+ 20981,
+ 20982,
+ 20983,
+ 20984,
+ 20985,
+ 20986,
+ 20987,
+ 20988,
+ 20989,
+ 20990,
+ 20991,
+ 20992,
+ 20993,
+ 20994,
+ 20995,
+ 20996,
+ 20997,
+ 20998,
+ 20999,
+ 21000,
+ 21001,
+ 21002,
+ 21003,
+ 21004,
+ 21005,
+ 21006,
+ 21007,
+ 21008,
+ 21009,
+ 21010,
+ 21011,
+ 21012,
+ 21013,
+ 21014,
+ 21015,
+ 21016,
+ 21017,
+ 21018,
+ 21019,
+ 21020,
+ 21021,
+ 21022,
+ 21023,
+ 21024,
+ 21025,
+ 21026,
+ 21027,
+ 21028,
+ 21029,
+ 21030,
+ 21031,
+ 21032,
+ 21033,
+ 21034,
+ 21035,
+ 21036,
+ 21037,
+ 21038,
+ 21039,
+ 21040,
+ 21041,
+ 21042,
+ 21043,
+ 21044,
+ 21045,
+ 21046,
+ 21047,
+ 21048,
+ 21049,
+ 21050,
+ 21051,
+ 21052,
+ 21053,
+ 21054,
+ 21055,
+ 21056,
+ 21057,
+ 21058,
+ 21059,
+ 21060,
+ 21061,
+ 21062,
+ 21063,
+ 21064,
+ 21065,
+ 21066,
+ 21067,
+ 21068,
+ 21069,
+ 21070,
+ 21071,
+ 21072,
+ 21073,
+ 21074,
+ 21075,
+ 21076,
+ 21077,
+ 21078,
+ 21079,
+ 21080,
+ 21081,
+ 21082,
+ 21083,
+ 21084,
+ 21085,
+ 21086,
+ 21087,
+ 21088,
+ 21089,
+ 21090,
+ 21091,
+ 21092,
+ 21093,
+ 21094,
+ 21095,
+ 21096,
+ 21097,
+ 21098,
+ 21099,
+ 21100,
+ 21101,
+ 21102,
+ 21103,
+ 21104,
+ 21105,
+ 21106,
+ 21107,
+ 21108,
+ 21109,
+ 21110,
+ 21111,
+ 21112,
+ 21113,
+ 21114,
+ 21115,
+ 21116,
+ 21117,
+ 21118,
+ 21119,
+ 21120,
+ 21121,
+ 21122,
+ 21123,
+ 21124,
+ 21125,
+ 21126,
+ 21127,
+ 21128,
+ 21129,
+ 21130,
+ 21131,
+ 21132,
+ 21133,
+ 21134,
+ 21135,
+ 21136,
+ 21137,
+ 21138,
+ 21139,
+ 21140,
+ 21141,
+ 21142,
+ 21143,
+ 21144,
+ 21145,
+ 21146,
+ 21147,
+ 21148,
+ 21149,
+ 21150,
+ 21151,
+ 21152,
+ 21153,
+ 21154,
+ 21155,
+ 21156,
+ 21157,
+ 21158,
+ 21159,
+ 21160,
+ 21161,
+ 21162,
+ 21163,
+ 21164,
+ 21165,
+ 21166,
+ 21167,
+ 21168,
+ 21169,
+ 21170,
+ 21171,
+ 21172,
+ 21173,
+ 21174,
+ 21175,
+ 21176,
+ 21177,
+ 21178,
+ 21179,
+ 21180,
+ 21181,
+ 21182,
+ 21183,
+ 21184,
+ 21185,
+ 21186,
+ 21187,
+ 21188,
+ 21189,
+ 21190,
+ 21191,
+ 21192,
+ 21193,
+ 21194,
+ 21195,
+ 21196,
+ 21197,
+ 21198,
+ 21199,
+ 21200,
+ 21201,
+ 21202,
+ 21203,
+ 21204,
+ 21205,
+ 21206,
+ 21207,
+ 21208,
+ 21209,
+ 21210,
+ 21211,
+ 21212,
+ 21213,
+ 21214,
+ 21215,
+ 21216,
+ 21217,
+ 21218,
+ 21219,
+ 21220,
+ 21221,
+ 21222,
+ 21223,
+ 21224,
+ 21225,
+ 21226,
+ 21227,
+ 21228,
+ 21229,
+ 21230,
+ 21231,
+ 21232,
+ 21233,
+ 21234,
+ 21235,
+ 21236,
+ 21237,
+ 21238,
+ 21239,
+ 21240,
+ 21241,
+ 21242,
+ 21243,
+ 21244,
+ 21245,
+ 21246,
+ 21247,
+ 21248,
+ 21249,
+ 21250,
+ 21251,
+ 21252,
+ 21253,
+ 21254,
+ 21255,
+ 21256,
+ 21257,
+ 21258,
+ 21259,
+ 21260,
+ 21261,
+ 21262,
+ 21263,
+ 21264,
+ 21265,
+ 21266,
+ 21267,
+ 21268,
+ 21269,
+ 21270,
+ 21271,
+ 21272,
+ 21273,
+ 21274,
+ 21275,
+ 21276,
+ 21277,
+ 21278,
+ 21279,
+ 21280,
+ 21281,
+ 21282,
+ 21283,
+ 21284,
+ 21285,
+ 21286,
+ 21287,
+ 21288,
+ 21289,
+ 21290,
+ 21291,
+ 21292,
+ 21293,
+ 21294,
+ 21295,
+ 21296,
+ 21297,
+ 21298,
+ 21299,
+ 21300,
+ 21301,
+ 21302,
+ 21303,
+ 21304,
+ 21305,
+ 21306,
+ 21307,
+ 21308,
+ 21309,
+ 21310,
+ 21311,
+ 21312,
+ 21313,
+ 21314,
+ 21315,
+ 21316,
+ 21317,
+ 21318,
+ 21319,
+ 21320,
+ 21321,
+ 21322,
+ 21323,
+ 21324,
+ 21325,
+ 21326,
+ 21327,
+ 21328,
+ 21329,
+ 21330,
+ 21331,
+ 21332,
+ 21333,
+ 21334,
+ 21335,
+ 21336,
+ 21337,
+ 21338,
+ 21339,
+ 21340,
+ 21341,
+ 21342,
+ 21343,
+ 21344,
+ 21345,
+ 21346,
+ 21347,
+ 21348,
+ 21349,
+ 21350,
+ 21351,
+ 21352,
+ 21353,
+ 21354,
+ 21355,
+ 21356,
+ 21357,
+ 21358,
+ 21359,
+ 21360,
+ 21361,
+ 21362,
+ 21363,
+ 21364,
+ 21365,
+ 21366,
+ 21367,
+ 21368,
+ 21369,
+ 21370,
+ 21371,
+ 21372,
+ 21373,
+ 21374,
+ 21375,
+ 21376,
+ 21377,
+ 21378,
+ 21379,
+ 21380,
+ 21381,
+ 21382,
+ 21383,
+ 21384,
+ 21385,
+ 21386,
+ 21387,
+ 21388,
+ 21389,
+ 21390,
+ 21391,
+ 21392,
+ 21393,
+ 21394,
+ 21395,
+ 21396,
+ 21397,
+ 21398,
+ 21399,
+ 21400,
+ 21401,
+ 21402,
+ 21403,
+ 21404,
+ 21405,
+ 21406,
+ 21407,
+ 21408,
+ 21409,
+ 21410,
+ 21411,
+ 21412,
+ 21413,
+ 21414,
+ 21415,
+ 21416,
+ 21417,
+ 21418,
+ 21419,
+ 21420,
+ 21421,
+ 21422,
+ 21423,
+ 21424,
+ 21425,
+ 21426,
+ 21427,
+ 21428,
+ 21429,
+ 21430,
+ 21431,
+ 21432,
+ 21433,
+ 21434,
+ 21435,
+ 21436,
+ 21437,
+ 21438,
+ 21439,
+ 21440,
+ 21441,
+ 21442,
+ 21443,
+ 21444,
+ 21445,
+ 21446,
+ 21447,
+ 21448,
+ 21449,
+ 21450,
+ 21451,
+ 21452,
+ 21453,
+ 21454,
+ 21455,
+ 21456,
+ 21457,
+ 21458,
+ 21459,
+ 21460,
+ 21461,
+ 21462,
+ 21463,
+ 21464,
+ 21465,
+ 21466,
+ 21467,
+ 21468,
+ 21469,
+ 21470,
+ 21471,
+ 21472,
+ 21473,
+ 21474,
+ 21475,
+ 21476,
+ 21477,
+ 21478,
+ 21479,
+ 21480,
+ 21481,
+ 21482,
+ 21483,
+ 21484,
+ 21485,
+ 21486,
+ 21487,
+ 21488,
+ 21489,
+ 21490,
+ 21491,
+ 21492,
+ 21493,
+ 21494,
+ 21495,
+ 21496,
+ 21497,
+ 21498,
+ 21499,
+ 21500,
+ 21501,
+ 21502,
+ 21503,
+ 21504,
+ 21505,
+ 21506,
+ 21507,
+ 21508,
+ 21509,
+ 21510,
+ 21511,
+ 21512,
+ 21513,
+ 21514,
+ 21515,
+ 21516,
+ 21517,
+ 21518,
+ 21519,
+ 21520,
+ 21521,
+ 21522,
+ 21523,
+ 21524,
+ 21525,
+ 21526,
+ 21527,
+ 21528,
+ 21529,
+ 21530,
+ 21531,
+ 21532,
+ 21533,
+ 21534,
+ 21535,
+ 21536,
+ 21537,
+ 21538,
+ 21539,
+ 21540,
+ 21541,
+ 21542,
+ 21543,
+ 21544,
+ 21545,
+ 21546,
+ 21547,
+ 21548,
+ 21549,
+ 21550,
+ 21551,
+ 21552,
+ 21553,
+ 21554,
+ 21555,
+ 21556,
+ 21557,
+ 21558,
+ 21559,
+ 21560,
+ 21561,
+ 21562,
+ 21563,
+ 21564,
+ 21565,
+ 21566,
+ 21567,
+ 21568,
+ 21569,
+ 21570,
+ 21571,
+ 21572,
+ 21573,
+ 21574,
+ 21575,
+ 21576,
+ 21577,
+ 21578,
+ 21579,
+ 21580,
+ 21581,
+ 21582,
+ 21583,
+ 21584,
+ 21585,
+ 21586,
+ 21587,
+ 21588,
+ 21589,
+ 21590,
+ 21591,
+ 21592,
+ 21593,
+ 21594,
+ 21595,
+ 21596,
+ 21597,
+ 21598,
+ 21599,
+ 21600,
+ 21601,
+ 21602,
+ 21603,
+ 21604,
+ 21605,
+ 21606,
+ 21607,
+ 21608,
+ 21609,
+ 21610,
+ 21611,
+ 21612,
+ 21613,
+ 21614,
+ 21615,
+ 21616,
+ 21617,
+ 21618,
+ 21619,
+ 21620,
+ 21621,
+ 21622,
+ 21623,
+ 21624,
+ 21625,
+ 21626,
+ 21627,
+ 21628,
+ 21629,
+ 21630,
+ 21631,
+ 21632,
+ 21633,
+ 21634,
+ 21635,
+ 21636,
+ 21637,
+ 21638,
+ 21639,
+ 21640,
+ 21641,
+ 21642,
+ 21643,
+ 21644,
+ 21645,
+ 21646,
+ 21647,
+ 21648,
+ 21649,
+ 21650,
+ 21651,
+ 21652,
+ 21653,
+ 21654,
+ 21655,
+ 21656,
+ 21657,
+ 21658,
+ 21659,
+ 21660,
+ 21661,
+ 21662,
+ 21663,
+ 21664,
+ 21665,
+ 21666,
+ 21667,
+ 21668,
+ 21669,
+ 21670,
+ 21671,
+ 21672,
+ 21673,
+ 21674,
+ 21675,
+ 21676,
+ 21677,
+ 21678,
+ 21679,
+ 21680,
+ 21681,
+ 21682,
+ 21683,
+ 21684,
+ 21685,
+ 21686,
+ 21687,
+ 21688,
+ 21689,
+ 21690,
+ 21691,
+ 21692,
+ 21693,
+ 21694,
+ 21695,
+ 21696,
+ 21697,
+ 21698,
+ 21699,
+ 21700,
+ 21701,
+ 21702,
+ 21703,
+ 21704,
+ 21705,
+ 21706,
+ 21707,
+ 21708,
+ 21709,
+ 21710,
+ 21711,
+ 21712,
+ 21713,
+ 21714,
+ 21715,
+ 21716,
+ 21717,
+ 21718,
+ 21719,
+ 21720,
+ 21721,
+ 21722,
+ 21723,
+ 21724,
+ 21725,
+ 21726,
+ 21727,
+ 21728,
+ 21729,
+ 21730,
+ 21731,
+ 21732,
+ 21733,
+ 21734,
+ 21735,
+ 21736,
+ 21737,
+ 21738,
+ 21739,
+ 21740,
+ 21741,
+ 21742,
+ 21743,
+ 21744,
+ 21745,
+ 21746,
+ 21747,
+ 21748,
+ 21749,
+ 21750,
+ 21751,
+ 21752,
+ 21753,
+ 21754,
+ 21755,
+ 21756,
+ 21757,
+ 21758,
+ 21759,
+ 21760,
+ 21761,
+ 21762,
+ 21763,
+ 21764,
+ 21765,
+ 21766,
+ 21767,
+ 21768,
+ 21769,
+ 21770,
+ 21771,
+ 21772,
+ 21773,
+ 21774,
+ 21775,
+ 21776,
+ 21777,
+ 21778,
+ 21779,
+ 21780,
+ 21781,
+ 21782,
+ 21783,
+ 21784,
+ 21785,
+ 21786,
+ 21787,
+ 21788,
+ 21789,
+ 21790,
+ 21791,
+ 21792,
+ 21793,
+ 21794,
+ 21795,
+ 21796,
+ 21797,
+ 21798,
+ 21799,
+ 21800,
+ 21801,
+ 21802,
+ 21803,
+ 21804,
+ 21805,
+ 21806,
+ 21807,
+ 21808,
+ 21809,
+ 21810,
+ 21811,
+ 21812,
+ 21813,
+ 21814,
+ 21815,
+ 21816,
+ 21817,
+ 21818,
+ 21819,
+ 21820,
+ 21821,
+ 21822,
+ 21823,
+ 21824,
+ 21825,
+ 21826,
+ 21827,
+ 21828,
+ 21829,
+ 21830,
+ 21831,
+ 21832,
+ 21833,
+ 21834,
+ 21835,
+ 21836,
+ 21837,
+ 21838,
+ 21839,
+ 21840,
+ 21841,
+ 21842,
+ 21843,
+ 21844,
+ 21845,
+ 21846,
+ 21847,
+ 21848,
+ 21849,
+ 21850,
+ 21851,
+ 21852,
+ 21853,
+ 21854,
+ 21855,
+ 21856,
+ 21857,
+ 21858,
+ 21859,
+ 21860,
+ 21861,
+ 21862,
+ 21863,
+ 21864,
+ 21865,
+ 21866,
+ 21867,
+ 21868,
+ 21869,
+ 21870,
+ 21871,
+ 21872,
+ 21873,
+ 21874,
+ 21875,
+ 21876,
+ 21877,
+ 21878,
+ 21879,
+ 21880,
+ 21881,
+ 21882,
+ 21883,
+ 21884,
+ 21885,
+ 21886,
+ 21887,
+ 21888,
+ 21889,
+ 21890,
+ 21891,
+ 21892,
+ 21893,
+ 21894,
+ 21895,
+ 21896,
+ 21897,
+ 21898,
+ 21899,
+ 21900,
+ 21901,
+ 21902,
+ 21903,
+ 21904,
+ 21905,
+ 21906,
+ 21907,
+ 21908,
+ 21909,
+ 21910,
+ 21911,
+ 21912,
+ 21913,
+ 21914,
+ 21915,
+ 21916,
+ 21917,
+ 21918,
+ 21919,
+ 21920,
+ 21921,
+ 21922,
+ 21923,
+ 21924,
+ 21925,
+ 21926,
+ 21927,
+ 21928,
+ 21929,
+ 21930,
+ 21931,
+ 21932,
+ 21933,
+ 21934,
+ 21935,
+ 21936,
+ 21937,
+ 21938,
+ 21939,
+ 21940,
+ 21941,
+ 21942,
+ 21943,
+ 21944,
+ 21945,
+ 21946,
+ 21947,
+ 21948,
+ 21949,
+ 21950,
+ 21951,
+ 21952,
+ 21953,
+ 21954,
+ 21955,
+ 21956,
+ 21957,
+ 21958,
+ 21959,
+ 21960,
+ 21961,
+ 21962,
+ 21963,
+ 21964,
+ 21965,
+ 21966,
+ 21967,
+ 21968,
+ 21969,
+ 21970,
+ 21971,
+ 21972,
+ 21973,
+ 21974,
+ 21975,
+ 21976,
+ 21977,
+ 21978,
+ 21979,
+ 21980,
+ 21981,
+ 21982,
+ 21983,
+ 21984,
+ 21985,
+ 21986,
+ 21987,
+ 21988,
+ 21989,
+ 21990,
+ 21991,
+ 21992,
+ 21993,
+ 21994,
+ 21995,
+ 21996,
+ 21997,
+ 21998,
+ 21999,
+ 22000,
+ 22001,
+ 22002,
+ 22003,
+ 22004,
+ 22005,
+ 22006,
+ 22007,
+ 22008,
+ 22009,
+ 22010,
+ 22011,
+ 22012,
+ 22013,
+ 22014,
+ 22015,
+ 22016,
+ 22017,
+ 22018,
+ 22019,
+ 22020,
+ 22021,
+ 22022,
+ 22023,
+ 22024,
+ 22025,
+ 22026,
+ 22027,
+ 22028,
+ 22029,
+ 22030,
+ 22031,
+ 22032,
+ 22033,
+ 22034,
+ 22035,
+ 22036,
+ 22037,
+ 22038,
+ 22039,
+ 22040,
+ 22041,
+ 22042,
+ 22043,
+ 22044,
+ 22045,
+ 22046,
+ 22047,
+ 22048,
+ 22049,
+ 22050,
+ 22051,
+ 22052,
+ 22053,
+ 22054,
+ 22055,
+ 22056,
+ 22057,
+ 22058,
+ 22059,
+ 22060,
+ 22061,
+ 22062,
+ 22063,
+ 22064,
+ 22065,
+ 22066,
+ 22067,
+ 22068,
+ 22069,
+ 22070,
+ 22071,
+ 22072,
+ 22073,
+ 22074,
+ 22075,
+ 22076,
+ 22077,
+ 22078,
+ 22079,
+ 22080,
+ 22081,
+ 22082,
+ 22083,
+ 22084,
+ 22085,
+ 22086,
+ 22087,
+ 22088,
+ 22089,
+ 22090,
+ 22091,
+ 22092,
+ 22093,
+ 22094,
+ 22095,
+ 22096,
+ 22097,
+ 22098,
+ 22099,
+ 22100,
+ 22101,
+ 22102,
+ 22103,
+ 22104,
+ 22105,
+ 22106,
+ 22107,
+ 22108,
+ 22109,
+ 22110,
+ 22111,
+ 22112,
+ 22113,
+ 22114,
+ 22115,
+ 22116,
+ 22117,
+ 22118,
+ 22119,
+ 22120,
+ 22121,
+ 22122,
+ 22123,
+ 22124,
+ 22125,
+ 22126,
+ 22127,
+ 22128,
+ 22129,
+ 22130,
+ 22131,
+ 22132,
+ 22133,
+ 22134,
+ 22135,
+ 22136,
+ 22137,
+ 22138,
+ 22139,
+ 22140,
+ 22141,
+ 22142,
+ 22143,
+ 22144,
+ 22145,
+ 22146,
+ 22147,
+ 22148,
+ 22149,
+ 22150,
+ 22151,
+ 22152,
+ 22153,
+ 22154,
+ 22155,
+ 22156,
+ 22157,
+ 22158,
+ 22159,
+ 22160,
+ 22161,
+ 22162,
+ 22163,
+ 22164,
+ 22165,
+ 22166,
+ 22167,
+ 22168,
+ 22169,
+ 22170,
+ 22171,
+ 22172,
+ 22173,
+ 22174,
+ 22175,
+ 22176,
+ 22177,
+ 22178,
+ 22179,
+ 22180,
+ 22181,
+ 22182,
+ 22183,
+ 22184,
+ 22185,
+ 22186,
+ 22187,
+ 22188,
+ 22189,
+ 22190,
+ 22191,
+ 22192,
+ 22193,
+ 22194,
+ 22195,
+ 22196,
+ 22197,
+ 22198,
+ 22199,
+ 22200,
+ 22201,
+ 22202,
+ 22203,
+ 22204,
+ 22205,
+ 22206,
+ 22207,
+ 22208,
+ 22209,
+ 22210,
+ 22211,
+ 22212,
+ 22213,
+ 22214,
+ 22215,
+ 22216,
+ 22217,
+ 22218,
+ 22219,
+ 22220,
+ 22221,
+ 22222,
+ 22223,
+ 22224,
+ 22225,
+ 22226,
+ 22227,
+ 22228,
+ 22229,
+ 22230,
+ 22231,
+ 22232,
+ 22233,
+ 22234,
+ 22235,
+ 22236,
+ 22237,
+ 22238,
+ 22239,
+ 22240,
+ 22241,
+ 22242,
+ 22243,
+ 22244,
+ 22245,
+ 22246,
+ 22247,
+ 22248,
+ 22249,
+ 22250,
+ 22251,
+ 22252,
+ 22253,
+ 22254,
+ 22255,
+ 22256,
+ 22257,
+ 22258,
+ 22259,
+ 22260,
+ 22261,
+ 22262,
+ 22263,
+ 22264,
+ 22265,
+ 22266,
+ 22267,
+ 22268,
+ 22269,
+ 22270,
+ 22271,
+ 22272,
+ 22273,
+ 22274,
+ 22275,
+ 22276,
+ 22277,
+ 22278,
+ 22279,
+ 22280,
+ 22281,
+ 22282,
+ 22283,
+ 22284,
+ 22285,
+ 22286,
+ 22287,
+ 22288,
+ 22289,
+ 22290,
+ 22291,
+ 22292,
+ 22293,
+ 22294,
+ 22295,
+ 22296,
+ 22297,
+ 22298,
+ 22299,
+ 22300,
+ 22301,
+ 22302,
+ 22303,
+ 22304,
+ 22305,
+ 22306,
+ 22307,
+ 22308,
+ 22309,
+ 22310,
+ 22311,
+ 22312,
+ 22313,
+ 22314,
+ 22315,
+ 22316,
+ 22317,
+ 22318,
+ 22319,
+ 22320,
+ 22321,
+ 22322,
+ 22323,
+ 22324,
+ 22325,
+ 22326,
+ 22327,
+ 22328,
+ 22329,
+ 22330,
+ 22331,
+ 22332,
+ 22333,
+ 22334,
+ 22335,
+ 22336,
+ 22337,
+ 22338,
+ 22339,
+ 22340,
+ 22341,
+ 22342,
+ 22343,
+ 22344,
+ 22345,
+ 22346,
+ 22347,
+ 22348,
+ 22349,
+ 22350,
+ 22351,
+ 22352,
+ 22353,
+ 22354,
+ 22355,
+ 22356,
+ 22357,
+ 22358,
+ 22359,
+ 22360,
+ 22361,
+ 22362,
+ 22363,
+ 22364,
+ 22365,
+ 22366,
+ 22367,
+ 22368,
+ 22369,
+ 22370,
+ 22371,
+ 22372,
+ 22373,
+ 22374,
+ 22375,
+ 22376,
+ 22377,
+ 22378,
+ 22379,
+ 22380,
+ 22381,
+ 22382,
+ 22383,
+ 22384,
+ 22385,
+ 22386,
+ 22387,
+ 22388,
+ 22389,
+ 22390,
+ 22391,
+ 22392,
+ 22393,
+ 22394,
+ 22395,
+ 22396,
+ 22397,
+ 22398,
+ 22399,
+ 22400,
+ 22401,
+ 22402,
+ 22403,
+ 22404,
+ 22405,
+ 22406,
+ 22407,
+ 22408,
+ 22409,
+ 22410,
+ 22411,
+ 22412,
+ 22413,
+ 22414,
+ 22415,
+ 22416,
+ 22417,
+ 22418,
+ 22419,
+ 22420,
+ 22421,
+ 22422,
+ 22423,
+ 22424,
+ 22425,
+ 22426,
+ 22427,
+ 22428,
+ 22429,
+ 22430,
+ 22431,
+ 22432,
+ 22433,
+ 22434,
+ 22435,
+ 22436,
+ 22437,
+ 22438,
+ 22439,
+ 22440,
+ 22441,
+ 22442,
+ 22443,
+ 22444,
+ 22445,
+ 22446,
+ 22447,
+ 22448,
+ 22449,
+ 22450,
+ 22451,
+ 22452,
+ 22453,
+ 22454,
+ 22455,
+ 22456,
+ 22457,
+ 22458,
+ 22459,
+ 22460,
+ 22461,
+ 22462,
+ 22463,
+ 22464,
+ 22465,
+ 22466,
+ 22467,
+ 22468,
+ 22469,
+ 22470,
+ 22471,
+ 22472,
+ 22473,
+ 22474,
+ 22475,
+ 22476,
+ 22477,
+ 22478,
+ 22479,
+ 22480,
+ 22481,
+ 22482,
+ 22483,
+ 22484,
+ 22485,
+ 22486,
+ 22487,
+ 22488,
+ 22489,
+ 22490,
+ 22491,
+ 22492,
+ 22493,
+ 22494,
+ 22495,
+ 22496,
+ 22497,
+ 22498,
+ 22499,
+ 22500,
+ 22501,
+ 22502,
+ 22503,
+ 22504,
+ 22505,
+ 22506,
+ 22507,
+ 22508,
+ 22509,
+ 22510,
+ 22511,
+ 22512,
+ 22513,
+ 22514,
+ 22515,
+ 22516,
+ 22517,
+ 22518,
+ 22519,
+ 22520,
+ 22521,
+ 22522,
+ 22523,
+ 22524,
+ 22525,
+ 22526,
+ 22527,
+ 22528,
+ 22529,
+ 22530,
+ 22531,
+ 22532,
+ 22533,
+ 22534,
+ 22535,
+ 22536,
+ 22537,
+ 22538,
+ 22539,
+ 22540,
+ 22541,
+ 22542,
+ 22543,
+ 22544,
+ 22545,
+ 22546,
+ 22547,
+ 22548,
+ 22549,
+ 22550,
+ 22551,
+ 22552,
+ 22553,
+ 22554,
+ 22555,
+ 22556,
+ 22557,
+ 22558,
+ 22559,
+ 22560,
+ 22561,
+ 22562,
+ 22563,
+ 22564,
+ 22565,
+ 22566,
+ 22567,
+ 22568,
+ 22569,
+ 22570,
+ 22571,
+ 22572,
+ 22573,
+ 22574,
+ 22575,
+ 22576,
+ 22577,
+ 22578,
+ 22579,
+ 22580,
+ 22581,
+ 22582,
+ 22583,
+ 22584,
+ 22585,
+ 22586,
+ 22587,
+ 22588,
+ 22589,
+ 22590,
+ 22591,
+ 22592,
+ 22593,
+ 22594,
+ 22595,
+ 22596,
+ 22597,
+ 22598,
+ 22599,
+ 22600,
+ 22601,
+ 22602,
+ 22603,
+ 22604,
+ 22605,
+ 22606,
+ 22607,
+ 22608,
+ 22609,
+ 22610,
+ 22611,
+ 22612,
+ 22613,
+ 22614,
+ 22615,
+ 22616,
+ 22617,
+ 22618,
+ 22619,
+ 22620,
+ 22621,
+ 22622,
+ 22623,
+ 22624,
+ 22625,
+ 22626,
+ 22627,
+ 22628,
+ 22629,
+ 22630,
+ 22631,
+ 22632,
+ 22633,
+ 22634,
+ 22635,
+ 22636,
+ 22637,
+ 22638,
+ 22639,
+ 22640,
+ 22641,
+ 22642,
+ 22643,
+ 22644,
+ 22645,
+ 22646,
+ 22647,
+ 22648,
+ 22649,
+ 22650,
+ 22651,
+ 22652,
+ 22653,
+ 22654,
+ 22655,
+ 22656,
+ 22657,
+ 22658,
+ 22659,
+ 22660,
+ 22661,
+ 22662,
+ 22663,
+ 22664,
+ 22665,
+ 22666,
+ 22667,
+ 22668,
+ 22669,
+ 22670,
+ 22671,
+ 22672,
+ 22673,
+ 22674,
+ 22675,
+ 22676,
+ 22677,
+ 22678,
+ 22679,
+ 22680,
+ 22681,
+ 22682,
+ 22683,
+ 22684,
+ 22685,
+ 22686,
+ 22687,
+ 22688,
+ 22689,
+ 22690,
+ 22691,
+ 22692,
+ 22693,
+ 22694,
+ 22695,
+ 22696,
+ 22697,
+ 22698,
+ 22699,
+ 22700,
+ 22701,
+ 22702,
+ 22703,
+ 22704,
+ 22705,
+ 22706,
+ 22707,
+ 22708,
+ 22709,
+ 22710,
+ 22711,
+ 22712,
+ 22713,
+ 22714,
+ 22715,
+ 22716,
+ 22717,
+ 22718,
+ 22719,
+ 22720,
+ 22721,
+ 22722,
+ 22723,
+ 22724,
+ 22725,
+ 22726,
+ 22727,
+ 22728,
+ 22729,
+ 22730,
+ 22731,
+ 22732,
+ 22733,
+ 22734,
+ 22735,
+ 22736,
+ 22737,
+ 22738,
+ 22739,
+ 22740,
+ 22741,
+ 22742,
+ 22743,
+ 22744,
+ 22745,
+ 22746,
+ 22747,
+ 22748,
+ 22749,
+ 22750,
+ 22751,
+ 22752,
+ 22753,
+ 22754,
+ 22755,
+ 22756,
+ 22757,
+ 22758,
+ 22759,
+ 22760,
+ 22761,
+ 22762,
+ 22763,
+ 22764,
+ 22765,
+ 22766,
+ 22767,
+ 22768,
+ 22769,
+ 22770,
+ 22771,
+ 22772,
+ 22773,
+ 22774,
+ 22775,
+ 22776,
+ 22777,
+ 22778,
+ 22779,
+ 22780,
+ 22781,
+ 22782,
+ 22783,
+ 22784,
+ 22785,
+ 22786,
+ 22787,
+ 22788,
+ 22789,
+ 22790,
+ 22791,
+ 22792,
+ 22793,
+ 22794,
+ 22795,
+ 22796,
+ 22797,
+ 22798,
+ 22799,
+ 22800,
+ 22801,
+ 22802,
+ 22803,
+ 22804,
+ 22805,
+ 22806,
+ 22807,
+ 22808,
+ 22809,
+ 22810,
+ 22811,
+ 22812,
+ 22813,
+ 22814,
+ 22815,
+ 22816,
+ 22817,
+ 22818,
+ 22819,
+ 22820,
+ 22821,
+ 22822,
+ 22823,
+ 22824,
+ 22825,
+ 22826,
+ 22827,
+ 22828,
+ 22829,
+ 22830,
+ 22831,
+ 22832,
+ 22833,
+ 22834,
+ 22835,
+ 22836,
+ 22837,
+ 22838,
+ 22839,
+ 22840,
+ 22841,
+ 22842,
+ 22843,
+ 22844,
+ 22845,
+ 22846,
+ 22847,
+ 22848,
+ 22849,
+ 22850,
+ 22851,
+ 22852,
+ 22853,
+ 22854,
+ 22855,
+ 22856,
+ 22857,
+ 22858,
+ 22859,
+ 22860,
+ 22861,
+ 22862,
+ 22863,
+ 22864,
+ 22865,
+ 22866,
+ 22867,
+ 22868,
+ 22869,
+ 22870,
+ 22871,
+ 22872,
+ 22873,
+ 22874,
+ 22875,
+ 22876,
+ 22877,
+ 22878,
+ 22879,
+ 22880,
+ 22881,
+ 22882,
+ 22883,
+ 22884,
+ 22885,
+ 22886,
+ 22887,
+ 22888,
+ 22889,
+ 22890,
+ 22891,
+ 22892,
+ 22893,
+ 22894,
+ 22895,
+ 22896,
+ 22897,
+ 22898,
+ 22899,
+ 22900,
+ 22901,
+ 22902,
+ 22903,
+ 22904,
+ 22905,
+ 22906,
+ 22907,
+ 22908,
+ 22909,
+ 22910,
+ 22911,
+ 22912,
+ 22913,
+ 22914,
+ 22915,
+ 22916,
+ 22917,
+ 22918,
+ 22919,
+ 22920,
+ 22921,
+ 22922,
+ 22923,
+ 22924,
+ 22925,
+ 22926,
+ 22927,
+ 22928,
+ 22929,
+ 22930,
+ 22931,
+ 22932,
+ 22933,
+ 22934,
+ 22935,
+ 22936,
+ 22937,
+ 22938,
+ 22939,
+ 22940,
+ 22941,
+ 22942,
+ 22943,
+ 22944,
+ 22945,
+ 22946,
+ 22947,
+ 22948,
+ 22949,
+ 22950,
+ 22951,
+ 22952,
+ 22953,
+ 22954,
+ 22955,
+ 22956,
+ 22957,
+ 22958,
+ 22959,
+ 22960,
+ 22961,
+ 22962,
+ 22963,
+ 22964,
+ 22965,
+ 22966,
+ 22967,
+ 22968,
+ 22969,
+ 22970,
+ 22971,
+ 22972,
+ 22973,
+ 22974,
+ 22975,
+ 22976,
+ 22977,
+ 22978,
+ 22979,
+ 22980,
+ 22981,
+ 22982,
+ 22983,
+ 22984,
+ 22985,
+ 22986,
+ 22987,
+ 22988,
+ 22989,
+ 22990,
+ 22991,
+ 22992,
+ 22993,
+ 22994,
+ 22995,
+ 22996,
+ 22997,
+ 22998,
+ 22999,
+ 23000,
+ 23001,
+ 23002,
+ 23003,
+ 23004,
+ 23005,
+ 23006,
+ 23007,
+ 23008,
+ 23009,
+ 23010,
+ 23011,
+ 23012,
+ 23013,
+ 23014,
+ 23015,
+ 23016,
+ 23017,
+ 23018,
+ 23019,
+ 23020,
+ 23021,
+ 23022,
+ 23023,
+ 23024,
+ 23025,
+ 23026,
+ 23027,
+ 23028,
+ 23029,
+ 23030,
+ 23031,
+ 23032,
+ 23033,
+ 23034,
+ 23035,
+ 23036,
+ 23037,
+ 23038,
+ 23039,
+ 23040,
+ 23041,
+ 23042,
+ 23043,
+ 23044,
+ 23045,
+ 23046,
+ 23047,
+ 23048,
+ 23049,
+ 23050,
+ 23051,
+ 23052,
+ 23053,
+ 23054,
+ 23055,
+ 23056,
+ 23057,
+ 23058,
+ 23059,
+ 23060,
+ 23061,
+ 23062,
+ 23063,
+ 23064,
+ 23065,
+ 23066,
+ 23067,
+ 23068,
+ 23069,
+ 23070,
+ 23071,
+ 23072,
+ 23073,
+ 23074,
+ 23075,
+ 23076,
+ 23077,
+ 23078,
+ 23079,
+ 23080,
+ 23081,
+ 23082,
+ 23083,
+ 23084,
+ 23085,
+ 23086,
+ 23087,
+ 23088,
+ 23089,
+ 23090,
+ 23091,
+ 23092,
+ 23093,
+ 23094,
+ 23095,
+ 23096,
+ 23097,
+ 23098,
+ 23099,
+ 23100,
+ 23101,
+ 23102,
+ 23103,
+ 23104,
+ 23105,
+ 23106,
+ 23107,
+ 23108,
+ 23109,
+ 23110,
+ 23111,
+ 23112,
+ 23113,
+ 23114,
+ 23115,
+ 23116,
+ 23117,
+ 23118,
+ 23119,
+ 23120,
+ 23121,
+ 23122,
+ 23123,
+ 23124,
+ 23125,
+ 23126,
+ 23127,
+ 23128,
+ 23129,
+ 23130,
+ 23131,
+ 23132,
+ 23133,
+ 23134,
+ 23135,
+ 23136,
+ 23137,
+ 23138,
+ 23139,
+ 23140,
+ 23141,
+ 23142,
+ 23143,
+ 23144,
+ 23145,
+ 23146,
+ 23147,
+ 23148,
+ 23149,
+ 23150,
+ 23151,
+ 23152,
+ 23153,
+ 23154,
+ 23155,
+ 23156,
+ 23157,
+ 23158,
+ 23159,
+ 23160,
+ 23161,
+ 23162,
+ 23163,
+ 23164,
+ 23165,
+ 23166,
+ 23167,
+ 23168,
+ 23169,
+ 23170,
+ 23171,
+ 23172,
+ 23173,
+ 23174,
+ 23175,
+ 23176,
+ 23177,
+ 23178,
+ 23179,
+ 23180,
+ 23181,
+ 23182,
+ 23183,
+ 23184,
+ 23185,
+ 23186,
+ 23187,
+ 23188,
+ 23189,
+ 23190,
+ 23191,
+ 23192,
+ 23193,
+ 23194,
+ 23195,
+ 23196,
+ 23197,
+ 23198,
+ 23199,
+ 23200,
+ 23201,
+ 23202,
+ 23203,
+ 23204,
+ 23205,
+ 23206,
+ 23207,
+ 23208,
+ 23209,
+ 23210,
+ 23211,
+ 23212,
+ 23213,
+ 23214,
+ 23215,
+ 23216,
+ 23217,
+ 23218,
+ 23219,
+ 23220,
+ 23221,
+ 23222,
+ 23223,
+ 23224,
+ 23225,
+ 23226,
+ 23227,
+ 23228,
+ 23229,
+ 23230,
+ 23231,
+ 23232,
+ 23233,
+ 23234,
+ 23235,
+ 23236,
+ 23237,
+ 23238,
+ 23239,
+ 23240,
+ 23241,
+ 23242,
+ 23243,
+ 23244,
+ 23245,
+ 23246,
+ 23247,
+ 23248,
+ 23249,
+ 23250,
+ 23251,
+ 23252,
+ 23253,
+ 23254,
+ 23255,
+ 23256,
+ 23257,
+ 23258,
+ 23259,
+ 23260,
+ 23261,
+ 23262,
+ 23263,
+ 23264,
+ 23265,
+ 23266,
+ 23267,
+ 23268,
+ 23269,
+ 23270,
+ 23271,
+ 23272,
+ 23273,
+ 23274,
+ 23275,
+ 23276,
+ 23277,
+ 23278,
+ 23279,
+ 23280,
+ 23281,
+ 23282,
+ 23283,
+ 23284,
+ 23285,
+ 23286,
+ 23287,
+ 23288,
+ 23289,
+ 23290,
+ 23291,
+ 23292,
+ 23293,
+ 23294,
+ 23295,
+ 23296,
+ 23297,
+ 23298,
+ 23299,
+ 23300,
+ 23301,
+ 23302,
+ 23303,
+ 23304,
+ 23305,
+ 23306,
+ 23307,
+ 23308,
+ 23309,
+ 23310,
+ 23311,
+ 23312,
+ 23313,
+ 23314,
+ 23315,
+ 23316,
+ 23317,
+ 23318,
+ 23319,
+ 23320,
+ 23321,
+ 23322,
+ 23323,
+ 23324,
+ 23325,
+ 23326,
+ 23327,
+ 23328,
+ 23329,
+ 23330,
+ 23331,
+ 23332,
+ 23333,
+ 23334,
+ 23335,
+ 23336,
+ 23337,
+ 23338,
+ 23339,
+ 23340,
+ 23341,
+ 23342,
+ 23343,
+ 23344,
+ 23345,
+ 23346,
+ 23347,
+ 23348,
+ 23349,
+ 23350,
+ 23351,
+ 23352,
+ 23353,
+ 23354,
+ 23355,
+ 23356,
+ 23357,
+ 23358,
+ 23359,
+ 23360,
+ 23361,
+ 23362,
+ 23363,
+ 23364,
+ 23365,
+ 23366,
+ 23367,
+ 23368,
+ 23369,
+ 23370,
+ 23371,
+ 23372,
+ 23373,
+ 23374,
+ 23375,
+ 23376,
+ 23377,
+ 23378,
+ 23379,
+ 23380,
+ 23381,
+ 23382,
+ 23383,
+ 23384,
+ 23385,
+ 23386,
+ 23387,
+ 23388,
+ 23389,
+ 23390,
+ 23391,
+ 23392,
+ 23393,
+ 23394,
+ 23395,
+ 23396,
+ 23397,
+ 23398,
+ 23399,
+ 23400,
+ 23401,
+ 23402,
+ 23403,
+ 23404,
+ 23405,
+ 23406,
+ 23407,
+ 23408,
+ 23409,
+ 23410,
+ 23411,
+ 23412,
+ 23413,
+ 23414,
+ 23415,
+ 23416,
+ 23417,
+ 23418,
+ 23419,
+ 23420,
+ 23421,
+ 23422,
+ 23423,
+ 23424,
+ 23425,
+ 23426,
+ 23427,
+ 23428,
+ 23429,
+ 23430,
+ 23431,
+ 23432,
+ 23433,
+ 23434,
+ 23435,
+ 23436,
+ 23437,
+ 23438,
+ 23439,
+ 23440,
+ 23441,
+ 23442,
+ 23443,
+ 23444,
+ 23445,
+ 23446,
+ 23447,
+ 23448,
+ 23449,
+ 23450,
+ 23451,
+ 23452,
+ 23453,
+ 23454,
+ 23455,
+ 23456,
+ 23457,
+ 23458,
+ 23459,
+ 23460,
+ 23461,
+ 23462,
+ 23463,
+ 23464,
+ 23465,
+ 23466,
+ 23467,
+ 23468,
+ 23469,
+ 23470,
+ 23471,
+ 23472,
+ 23473,
+ 23474,
+ 23475,
+ 23476,
+ 23477,
+ 23478,
+ 23479,
+ 23480,
+ 23481,
+ 23482,
+ 23483,
+ 23484,
+ 23485,
+ 23486,
+ 23487,
+ 23488,
+ 23489,
+ 23490,
+ 23491,
+ 23492,
+ 23493,
+ 23494,
+ 23495,
+ 23496,
+ 23497,
+ 23498,
+ 23499,
+ 23500,
+ 23501,
+ 23502,
+ 23503,
+ 23504,
+ 23505,
+ 23506,
+ 23507,
+ 23508,
+ 23509,
+ 23510,
+ 23511,
+ 23512,
+ 23513,
+ 23514,
+ 23515,
+ 23516,
+ 23517,
+ 23518,
+ 23519,
+ 23520,
+ 23521,
+ 23522,
+ 23523,
+ 23524,
+ 23525,
+ 23526,
+ 23527,
+ 23528,
+ 23529,
+ 23530,
+ 23531,
+ 23532,
+ 23533,
+ 23534,
+ 23535,
+ 23536,
+ 23537,
+ 23538,
+ 23539,
+ 23540,
+ 23541,
+ 23542,
+ 23543,
+ 23544,
+ 23545,
+ 23546,
+ 23547,
+ 23548,
+ 23549,
+ 23550,
+ 23551,
+ 23552,
+ 23553,
+ 23554,
+ 23555,
+ 23556,
+ 23557,
+ 23558,
+ 23559,
+ 23560,
+ 23561,
+ 23562,
+ 23563,
+ 23564,
+ 23565,
+ 23566,
+ 23567,
+ 23568,
+ 23569,
+ 23570,
+ 23571,
+ 23572,
+ 23573,
+ 23574,
+ 23575,
+ 23576,
+ 23577,
+ 23578,
+ 23579,
+ 23580,
+ 23581,
+ 23582,
+ 23583,
+ 23584,
+ 23585,
+ 23586,
+ 23587,
+ 23588,
+ 23589,
+ 23590,
+ 23591,
+ 23592,
+ 23593,
+ 23594,
+ 23595,
+ 23596,
+ 23597,
+ 23598,
+ 23599,
+ 23600,
+ 23601,
+ 23602,
+ 23603,
+ 23604,
+ 23605,
+ 23606,
+ 23607,
+ 23608,
+ 23609,
+ 23610,
+ 23611,
+ 23612,
+ 23613,
+ 23614,
+ 23615,
+ 23616,
+ 23617,
+ 23618,
+ 23619,
+ 23620,
+ 23621,
+ 23622,
+ 23623,
+ 23624,
+ 23625,
+ 23626,
+ 23627,
+ 23628,
+ 23629,
+ 23630,
+ 23631,
+ 23632,
+ 23633,
+ 23634,
+ 23635,
+ 23636,
+ 23637,
+ 23638,
+ 23639,
+ 23640,
+ 23641,
+ 23642,
+ 23643,
+ 23644,
+ 23645,
+ 23646,
+ 23647,
+ 23648,
+ 23649,
+ 23650,
+ 23651,
+ 23652,
+ 23653,
+ 23654,
+ 23655,
+ 23656,
+ 23657,
+ 23658,
+ 23659,
+ 23660,
+ 23661,
+ 23662,
+ 23663,
+ 23664,
+ 23665,
+ 23666,
+ 23667,
+ 23668,
+ 23669,
+ 23670,
+ 23671,
+ 23672,
+ 23673,
+ 23674,
+ 23675,
+ 23676,
+ 23677,
+ 23678,
+ 23679,
+ 23680,
+ 23681,
+ 23682,
+ 23683,
+ 23684,
+ 23685,
+ 23686,
+ 23687,
+ 23688,
+ 23689,
+ 23690,
+ 23691,
+ 23692,
+ 23693,
+ 23694,
+ 23695,
+ 23696,
+ 23697,
+ 23698,
+ 23699,
+ 23700,
+ 23701,
+ 23702,
+ 23703,
+ 23704,
+ 23705,
+ 23706,
+ 23707,
+ 23708,
+ 23709,
+ 23710,
+ 23711,
+ 23712,
+ 23713,
+ 23714,
+ 23715,
+ 23716,
+ 23717,
+ 23718,
+ 23719,
+ 23720,
+ 23721,
+ 23722,
+ 23723,
+ 23724,
+ 23725,
+ 23726,
+ 23727,
+ 23728,
+ 23729,
+ 23730,
+ 23731,
+ 23732,
+ 23733,
+ 23734,
+ 23735,
+ 23736,
+ 23737,
+ 23738,
+ 23739,
+ 23740,
+ 23741,
+ 23742,
+ 23743,
+ 23744,
+ 23745,
+ 23746,
+ 23747,
+ 23748,
+ 23749,
+ 23750,
+ 23751,
+ 23752,
+ 23753,
+ 23754,
+ 23755,
+ 23756,
+ 23757,
+ 23758,
+ 23759,
+ 23760,
+ 23761,
+ 23762,
+ 23763,
+ 23764,
+ 23765,
+ 23766,
+ 23767,
+ 23768,
+ 23769,
+ 23770,
+ 23771,
+ 23772,
+ 23773,
+ 23774,
+ 23775,
+ 23776,
+ 23777,
+ 23778,
+ 23779,
+ 23780,
+ 23781,
+ 23782,
+ 23783,
+ 23784,
+ 23785,
+ 23786,
+ 23787,
+ 23788,
+ 23789,
+ 23790,
+ 23791,
+ 23792,
+ 23793,
+ 23794,
+ 23795,
+ 23796,
+ 23797,
+ 23798,
+ 23799,
+ 23800,
+ 23801,
+ 23802,
+ 23803,
+ 23804,
+ 23805,
+ 23806,
+ 23807,
+ 23808,
+ 23809,
+ 23810,
+ 23811,
+ 23812,
+ 23813,
+ 23814,
+ 23815,
+ 23816,
+ 23817,
+ 23818,
+ 23819,
+ 23820,
+ 23821,
+ 23822,
+ 23823,
+ 23824,
+ 23825,
+ 23826,
+ 23827,
+ 23828,
+ 23829,
+ 23830,
+ 23831,
+ 23832,
+ 23833,
+ 23834,
+ 23835,
+ 23836,
+ 23837,
+ 23838,
+ 23839,
+ 23840,
+ 23841,
+ 23842,
+ 23843,
+ 23844,
+ 23845,
+ 23846,
+ 23847,
+ 23848,
+ 23849,
+ 23850,
+ 23851,
+ 23852,
+ 23853,
+ 23854,
+ 23855,
+ 23856,
+ 23857,
+ 23858,
+ 23859,
+ 23860,
+ 23861,
+ 23862,
+ 23863,
+ 23864,
+ 23865,
+ 23866,
+ 23867,
+ 23868,
+ 23869,
+ 23870,
+ 23871,
+ 23872,
+ 23873,
+ 23874,
+ 23875,
+ 23876,
+ 23877,
+ 23878,
+ 23879,
+ 23880,
+ 23881,
+ 23882,
+ 23883,
+ 23884,
+ 23885,
+ 23886,
+ 23887,
+ 23888,
+ 23889,
+ 23890,
+ 23891,
+ 23892,
+ 23893,
+ 23894,
+ 23895,
+ 23896,
+ 23897,
+ 23898,
+ 23899,
+ 23900,
+ 23901,
+ 23902,
+ 23903,
+ 23904,
+ 23905,
+ 23906,
+ 23907,
+ 23908,
+ 23909,
+ 23910,
+ 23911,
+ 23912,
+ 23913,
+ 23914,
+ 23915,
+ 23916,
+ 23917,
+ 23918,
+ 23919,
+ 23920,
+ 23921,
+ 23922,
+ 23923,
+ 23924,
+ 23925,
+ 23926,
+ 23927,
+ 23928,
+ 23929,
+ 23930,
+ 23931,
+ 23932,
+ 23933,
+ 23934,
+ 23935,
+ 23936,
+ 23937,
+ 23938,
+ 23939,
+ 23940,
+ 23941,
+ 23942,
+ 23943,
+ 23944,
+ 23945,
+ 23946,
+ 23947,
+ 23948,
+ 23949,
+ 23950,
+ 23951,
+ 23952,
+ 23953,
+ 23954,
+ 23955,
+ 23956,
+ 23957,
+ 23958,
+ 23959,
+ 23960,
+ 23961,
+ 23962,
+ 23963,
+ 23964,
+ 23965,
+ 23966,
+ 23967,
+ 23968,
+ 23969,
+ 23970,
+ 23971,
+ 23972,
+ 23973,
+ 23974,
+ 23975,
+ 23976,
+ 23977,
+ 23978,
+ 23979,
+ 23980,
+ 23981,
+ 23982,
+ 23983,
+ 23984,
+ 23985,
+ 23986,
+ 23987,
+ 23988,
+ 23989,
+ 23990,
+ 23991,
+ 23992,
+ 23993,
+ 23994,
+ 23995,
+ 23996,
+ 23997,
+ 23998,
+ 23999,
+ 24000,
+ 24001,
+ 24002,
+ 24003,
+ 24004,
+ 24005,
+ 24006,
+ 24007,
+ 24008,
+ 24009,
+ 24010,
+ 24011,
+ 24012,
+ 24013,
+ 24014,
+ 24015,
+ 24016,
+ 24017,
+ 24018,
+ 24019,
+ 24020,
+ 24021,
+ 24022,
+ 24023,
+ 24024,
+ 24025,
+ 24026,
+ 24027,
+ 24028,
+ 24029,
+ 24030,
+ 24031,
+ 24032,
+ 24033,
+ 24034,
+ 24035,
+ 24036,
+ 24037,
+ 24038,
+ 24039,
+ 24040,
+ 24041,
+ 24042,
+ 24043,
+ 24044,
+ 24045,
+ 24046,
+ 24047,
+ 24048,
+ 24049,
+ 24050,
+ 24051,
+ 24052,
+ 24053,
+ 24054,
+ 24055,
+ 24056,
+ 24057,
+ 24058,
+ 24059,
+ 24060,
+ 24061,
+ 24062,
+ 24063,
+ 24064,
+ 24065,
+ 24066,
+ 24067,
+ 24068,
+ 24069,
+ 24070,
+ 24071,
+ 24072,
+ 24073,
+ 24074,
+ 24075,
+ 24076,
+ 24077,
+ 24078,
+ 24079,
+ 24080,
+ 24081,
+ 24082,
+ 24083,
+ 24084,
+ 24085,
+ 24086,
+ 24087,
+ 24088,
+ 24089,
+ 24090,
+ 24091,
+ 24092,
+ 24093,
+ 24094,
+ 24095,
+ 24096,
+ 24097,
+ 24098,
+ 24099,
+ 24100,
+ 24101,
+ 24102,
+ 24103,
+ 24104,
+ 24105,
+ 24106,
+ 24107,
+ 24108,
+ 24109,
+ 24110,
+ 24111,
+ 24112,
+ 24113,
+ 24114,
+ 24115,
+ 24116,
+ 24117,
+ 24118,
+ 24119,
+ 24120,
+ 24121,
+ 24122,
+ 24123,
+ 24124,
+ 24125,
+ 24126,
+ 24127,
+ 24128,
+ 24129,
+ 24130,
+ 24131,
+ 24132,
+ 24133,
+ 24134,
+ 24135,
+ 24136,
+ 24137,
+ 24138,
+ 24139,
+ 24140,
+ 24141,
+ 24142,
+ 24143,
+ 24144,
+ 24145,
+ 24146,
+ 24147,
+ 24148,
+ 24149,
+ 24150,
+ 24151,
+ 24152,
+ 24153,
+ 24154,
+ 24155,
+ 24156,
+ 24157,
+ 24158,
+ 24159,
+ 24160,
+ 24161,
+ 24162,
+ 24163,
+ 24164,
+ 24165,
+ 24166,
+ 24167,
+ 24168,
+ 24169,
+ 24170,
+ 24171,
+ 24172,
+ 24173,
+ 24174,
+ 24175,
+ 24176,
+ 24177,
+ 24178,
+ 24179,
+ 24180,
+ 24181,
+ 24182,
+ 24183,
+ 24184,
+ 24185,
+ 24186,
+ 24187,
+ 24188,
+ 24189,
+ 24190,
+ 24191,
+ 24192,
+ 24193,
+ 24194,
+ 24195,
+ 24196,
+ 24197,
+ 24198,
+ 24199,
+ 24200,
+ 24201,
+ 24202,
+ 24203,
+ 24204,
+ 24205,
+ 24206,
+ 24207,
+ 24208,
+ 24209,
+ 24210,
+ 24211,
+ 24212,
+ 24213,
+ 24214,
+ 24215,
+ 24216,
+ 24217,
+ 24218,
+ 24219,
+ 24220,
+ 24221,
+ 24222,
+ 24223,
+ 24224,
+ 24225,
+ 24226,
+ 24227,
+ 24228,
+ 24229,
+ 24230,
+ 24231,
+ 24232,
+ 24233,
+ 24234,
+ 24235,
+ 24236,
+ 24237,
+ 24238,
+ 24239,
+ 24240,
+ 24241,
+ 24242,
+ 24243,
+ 24244,
+ 24245,
+ 24246,
+ 24247,
+ 24248,
+ 24249,
+ 24250,
+ 24251,
+ 24252,
+ 24253,
+ 24254,
+ 24255,
+ 24256,
+ 24257,
+ 24258,
+ 24259,
+ 24260,
+ 24261,
+ 24262,
+ 24263,
+ 24264,
+ 24265,
+ 24266,
+ 24267,
+ 24268,
+ 24269,
+ 24270,
+ 24271,
+ 24272,
+ 24273,
+ 24274,
+ 24275,
+ 24276,
+ 24277,
+ 24278,
+ 24279,
+ 24280,
+ 24281,
+ 24282,
+ 24283,
+ 24284,
+ 24285,
+ 24286,
+ 24287,
+ 24288,
+ 24289,
+ 24290,
+ 24291,
+ 24292,
+ 24293,
+ 24294,
+ 24295,
+ 24296,
+ 24297,
+ 24298,
+ 24299,
+ 24300,
+ 24301,
+ 24302,
+ 24303,
+ 24304,
+ 24305,
+ 24306,
+ 24307,
+ 24308,
+ 24309,
+ 24310,
+ 24311,
+ 24312,
+ 24313,
+ 24314,
+ 24315,
+ 24316,
+ 24317,
+ 24318,
+ 24319,
+ 24320,
+ 24321,
+ 24322,
+ 24323,
+ 24324,
+ 24325,
+ 24326,
+ 24327,
+ 24328,
+ 24329,
+ 24330,
+ 24331,
+ 24332,
+ 24333,
+ 24334,
+ 24335,
+ 24336,
+ 24337,
+ 24338,
+ 24339,
+ 24340,
+ 24341,
+ 24342,
+ 24343,
+ 24344,
+ 24345,
+ 24346,
+ 24347,
+ 24348,
+ 24349,
+ 24350,
+ 24351,
+ 24352,
+ 24353,
+ 24354,
+ 24355,
+ 24356,
+ 24357,
+ 24358,
+ 24359,
+ 24360,
+ 24361,
+ 24362,
+ 24363,
+ 24364,
+ 24365,
+ 24366,
+ 24367,
+ 24368,
+ 24369,
+ 24370,
+ 24371,
+ 24372,
+ 24373,
+ 24374,
+ 24375,
+ 24376,
+ 24377,
+ 24378,
+ 24379,
+ 24380,
+ 24381,
+ 24382,
+ 24383,
+ 24384,
+ 24385,
+ 24386,
+ 24387,
+ 24388,
+ 24389,
+ 24390,
+ 24391,
+ 24392,
+ 24393,
+ 24394,
+ 24395,
+ 24396,
+ 24397,
+ 24398,
+ 24399,
+ 24400,
+ 24401,
+ 24402,
+ 24403,
+ 24404,
+ 24405,
+ 24406,
+ 24407,
+ 24408,
+ 24409,
+ 24410,
+ 24411,
+ 24412,
+ 24413,
+ 24414,
+ 24415,
+ 24416,
+ 24417,
+ 24418,
+ 24419,
+ 24420,
+ 24421,
+ 24422,
+ 24423,
+ 24424,
+ 24425,
+ 24426,
+ 24427,
+ 24428,
+ 24429,
+ 24430,
+ 24431,
+ 24432,
+ 24433,
+ 24434,
+ 24435,
+ 24436,
+ 24437,
+ 24438,
+ 24439,
+ 24440,
+ 24441,
+ 24442,
+ 24443,
+ 24444,
+ 24445,
+ 24446,
+ 24447,
+ 24448,
+ 24449,
+ 24450,
+ 24451,
+ 24452,
+ 24453,
+ 24454,
+ 24455,
+ 24456,
+ 24457,
+ 24458,
+ 24459,
+ 24460,
+ 24461,
+ 24462,
+ 24463,
+ 24464,
+ 24465,
+ 24466,
+ 24467,
+ 24468,
+ 24469,
+ 24470,
+ 24471,
+ 24472,
+ 24473,
+ 24474,
+ 24475,
+ 24476,
+ 24477,
+ 24478,
+ 24479,
+ 24480,
+ 24481,
+ 24482,
+ 24483,
+ 24484,
+ 24485,
+ 24486,
+ 24487,
+ 24488,
+ 24489,
+ 24490,
+ 24491,
+ 24492,
+ 24493,
+ 24494,
+ 24495,
+ 24496,
+ 24497,
+ 24498,
+ 24499,
+ 24500,
+ 24501,
+ 24502,
+ 24503,
+ 24504,
+ 24505,
+ 24506,
+ 24507,
+ 24508,
+ 24509,
+ 24510,
+ 24511,
+ 24512,
+ 24513,
+ 24514,
+ 24515,
+ 24516,
+ 24517,
+ 24518,
+ 24519,
+ 24520,
+ 24521,
+ 24522,
+ 24523,
+ 24524,
+ 24525,
+ 24526,
+ 24527,
+ 24528,
+ 24529,
+ 24530,
+ 24531,
+ 24532,
+ 24533,
+ 24534,
+ 24535,
+ 24536,
+ 24537,
+ 24538,
+ 24539,
+ 24540,
+ 24541,
+ 24542,
+ 24543,
+ 24544,
+ 24545,
+ 24546,
+ 24547,
+ 24548,
+ 24549,
+ 24550,
+ 24551,
+ 24552,
+ 24553,
+ 24554,
+ 24555,
+ 24556,
+ 24557,
+ 24558,
+ 24559,
+ 24560,
+ 24561,
+ 24562,
+ 24563,
+ 24564,
+ 24565,
+ 24566,
+ 24567,
+ 24568,
+ 24569,
+ 24570,
+ 24571,
+ 24572,
+ 24573,
+ 24574,
+ 24575,
+ 24576,
+ 24577,
+ 24578,
+ 24579,
+ 24580,
+ 24581,
+ 24582,
+ 24583,
+ 24584,
+ 24585,
+ 24586,
+ 24587,
+ 24588,
+ 24589,
+ 24590,
+ 24591,
+ 24592,
+ 24593,
+ 24594,
+ 24595,
+ 24596,
+ 24597,
+ 24598,
+ 24599,
+ 24600,
+ 24601,
+ 24602,
+ 24603,
+ 24604,
+ 24605,
+ 24606,
+ 24607,
+ 24608,
+ 24609,
+ 24610,
+ 24611,
+ 24612,
+ 24613,
+ 24614,
+ 24615,
+ 24616,
+ 24617,
+ 24618,
+ 24619,
+ 24620,
+ 24621,
+ 24622,
+ 24623,
+ 24624,
+ 24625,
+ 24626,
+ 24627,
+ 24628,
+ 24629,
+ 24630,
+ 24631,
+ 24632,
+ 24633,
+ 24634,
+ 24635,
+ 24636,
+ 24637,
+ 24638,
+ 24639,
+ 24640,
+ 24641,
+ 24642,
+ 24643,
+ 24644,
+ 24645,
+ 24646,
+ 24647,
+ 24648,
+ 24649,
+ 24650,
+ 24651,
+ 24652,
+ 24653,
+ 24654,
+ 24655,
+ 24656,
+ 24657,
+ 24658,
+ 24659,
+ 24660,
+ 24661,
+ 24662,
+ 24663,
+ 24664,
+ 24665,
+ 24666,
+ 24667,
+ 24668,
+ 24669,
+ 24670,
+ 24671,
+ 24672,
+ 24673,
+ 24674,
+ 24675,
+ 24676,
+ 24677,
+ 24678,
+ 24679,
+ 24680,
+ 24681,
+ 24682,
+ 24683,
+ 24684,
+ 24685,
+ 24686,
+ 24687,
+ 24688,
+ 24689,
+ 24690,
+ 24691,
+ 24692,
+ 24693,
+ 24694,
+ 24695,
+ 24696,
+ 24697,
+ 24698,
+ 24699,
+ 24700,
+ 24701,
+ 24702,
+ 24703,
+ 24704,
+ 24705,
+ 24706,
+ 24707,
+ 24708,
+ 24709,
+ 24710,
+ 24711,
+ 24712,
+ 24713,
+ 24714,
+ 24715,
+ 24716,
+ 24717,
+ 24718,
+ 24719,
+ 24720,
+ 24721,
+ 24722,
+ 24723,
+ 24724,
+ 24725,
+ 24726,
+ 24727,
+ 24728,
+ 24729,
+ 24730,
+ 24731,
+ 24732,
+ 24733,
+ 24734,
+ 24735,
+ 24736,
+ 24737,
+ 24738,
+ 24739,
+ 24740,
+ 24741,
+ 24742,
+ 24743,
+ 24744,
+ 24745,
+ 24746,
+ 24747,
+ 24748,
+ 24749,
+ 24750,
+ 24751,
+ 24752,
+ 24753,
+ 24754,
+ 24755,
+ 24756,
+ 24757,
+ 24758,
+ 24759,
+ 24760,
+ 24761,
+ 24762,
+ 24763,
+ 24764,
+ 24765,
+ 24766,
+ 24767,
+ 24768,
+ 24769,
+ 24770,
+ 24771,
+ 24772,
+ 24773,
+ 24774,
+ 24775,
+ 24776,
+ 24777,
+ 24778,
+ 24779,
+ 24780,
+ 24781,
+ 24782,
+ 24783,
+ 24784,
+ 24785,
+ 24786,
+ 24787,
+ 24788,
+ 24789,
+ 24790,
+ 24791,
+ 24792,
+ 24793,
+ 24794,
+ 24795,
+ 24796,
+ 24797,
+ 24798,
+ 24799,
+ 24800,
+ 24801,
+ 24802,
+ 24803,
+ 24804,
+ 24805,
+ 24806,
+ 24807,
+ 24808,
+ 24809,
+ 24810,
+ 24811,
+ 24812,
+ 24813,
+ 24814,
+ 24815,
+ 24816,
+ 24817,
+ 24818,
+ 24819,
+ 24820,
+ 24821,
+ 24822,
+ 24823,
+ 24824,
+ 24825,
+ 24826,
+ 24827,
+ 24828,
+ 24829,
+ 24830,
+ 24831,
+ 24832,
+ 24833,
+ 24834,
+ 24835,
+ 24836,
+ 24837,
+ 24838,
+ 24839,
+ 24840,
+ 24841,
+ 24842,
+ 24843,
+ 24844,
+ 24845,
+ 24846,
+ 24847,
+ 24848,
+ 24849,
+ 24850,
+ 24851,
+ 24852,
+ 24853,
+ 24854,
+ 24855,
+ 24856,
+ 24857,
+ 24858,
+ 24859,
+ 24860,
+ 24861,
+ 24862,
+ 24863,
+ 24864,
+ 24865,
+ 24866,
+ 24867,
+ 24868,
+ 24869,
+ 24870,
+ 24871,
+ 24872,
+ 24873,
+ 24874,
+ 24875,
+ 24876,
+ 24877,
+ 24878,
+ 24879,
+ 24880,
+ 24881,
+ 24882,
+ 24883,
+ 24884,
+ 24885,
+ 24886,
+ 24887,
+ 24888,
+ 24889,
+ 24890,
+ 24891,
+ 24892,
+ 24893,
+ 24894,
+ 24895,
+ 24896,
+ 24897,
+ 24898,
+ 24899,
+ 24900,
+ 24901,
+ 24902,
+ 24903,
+ 24904,
+ 24905,
+ 24906,
+ 24907,
+ 24908,
+ 24909,
+ 24910,
+ 24911,
+ 24912,
+ 24913,
+ 24914,
+ 24915,
+ 24916,
+ 24917,
+ 24918,
+ 24919,
+ 24920,
+ 24921,
+ 24922,
+ 24923,
+ 24924,
+ 24925,
+ 24926
+]
\ No newline at end of file
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/scale.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/scale.npy
new file mode 100644
index 0000000000000000000000000000000000000000..63dcd81e129217671d439fa3d8188586e32dd9dd
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/scale.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d1e3a9ad91c1421ffc446780a7cd7227fca32e1d19cd04388819496d7cfea4d1
+size 144
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/subject_model.pth b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/subject_model.pth
new file mode 100644
index 0000000000000000000000000000000000000000..88f2eeb3231de3af1b947cd1327338e5b5cf5251
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/subject_model.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:e507b62594fe1d7cebbabf653d559acb9e9a72f9d31b57ea53721bb52e26d228
+size 1524384769
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/test_data.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/test_data.npy
new file mode 100644
index 0000000000000000000000000000000000000000..62094f0bbb57c480c7f7f9497a607c73369e1744
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/test_data.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:206096f239b771e8d12a88ac196562ac6a760fd050bbd1abec8e3f8c42c9da8a
+size 3873920
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_1/train_data.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/train_data.npy
new file mode 100644
index 0000000000000000000000000000000000000000..b0b9ab73baf0fa96fe17612be05395feda1f1966
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_1/train_data.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:f108ee34bab6336566ee678a151b507bc739f608d59c9c043a2ad60148ac6002
+size 76575872
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/base_dvi.pth b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/base_dvi.pth
new file mode 100644
index 0000000000000000000000000000000000000000..dce3af25ed019c3339998363a44b92d1227ae171
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/base_dvi.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:4539a62bfb97589fc21289309bca1128a3b2e57310a5f041e9ee8f5a5c438eb0
+size 9506759
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/bgimg.png b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/bgimg.png
new file mode 100644
index 0000000000000000000000000000000000000000..041c94fec760772a8884a5962161e2121b721562
Binary files /dev/null and b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/bgimg.png differ
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/embedding.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/embedding.npy
new file mode 100644
index 0000000000000000000000000000000000000000..defb425ef4a60e97775aaf066e66cb377c6cca06
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/embedding.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:f3664112c7d7b3ec5263c4ae0400bf3cc9229c5337cf5ce7e11c63180a07c43e
+size 199544
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/index.json b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/index.json
new file mode 100644
index 0000000000000000000000000000000000000000..9c13769254bdbcb6392dc4eb5ee76e59d645fb69
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/index.json
@@ -0,0 +1,24929 @@
+[
+ 0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6,
+ 7,
+ 8,
+ 9,
+ 10,
+ 11,
+ 12,
+ 13,
+ 14,
+ 15,
+ 16,
+ 17,
+ 18,
+ 19,
+ 20,
+ 21,
+ 22,
+ 23,
+ 24,
+ 25,
+ 26,
+ 27,
+ 28,
+ 29,
+ 30,
+ 31,
+ 32,
+ 33,
+ 34,
+ 35,
+ 36,
+ 37,
+ 38,
+ 39,
+ 40,
+ 41,
+ 42,
+ 43,
+ 44,
+ 45,
+ 46,
+ 47,
+ 48,
+ 49,
+ 50,
+ 51,
+ 52,
+ 53,
+ 54,
+ 55,
+ 56,
+ 57,
+ 58,
+ 59,
+ 60,
+ 61,
+ 62,
+ 63,
+ 64,
+ 65,
+ 66,
+ 67,
+ 68,
+ 69,
+ 70,
+ 71,
+ 72,
+ 73,
+ 74,
+ 75,
+ 76,
+ 77,
+ 78,
+ 79,
+ 80,
+ 81,
+ 82,
+ 83,
+ 84,
+ 85,
+ 86,
+ 87,
+ 88,
+ 89,
+ 90,
+ 91,
+ 92,
+ 93,
+ 94,
+ 95,
+ 96,
+ 97,
+ 98,
+ 99,
+ 100,
+ 101,
+ 102,
+ 103,
+ 104,
+ 105,
+ 106,
+ 107,
+ 108,
+ 109,
+ 110,
+ 111,
+ 112,
+ 113,
+ 114,
+ 115,
+ 116,
+ 117,
+ 118,
+ 119,
+ 120,
+ 121,
+ 122,
+ 123,
+ 124,
+ 125,
+ 126,
+ 127,
+ 128,
+ 129,
+ 130,
+ 131,
+ 132,
+ 133,
+ 134,
+ 135,
+ 136,
+ 137,
+ 138,
+ 139,
+ 140,
+ 141,
+ 142,
+ 143,
+ 144,
+ 145,
+ 146,
+ 147,
+ 148,
+ 149,
+ 150,
+ 151,
+ 152,
+ 153,
+ 154,
+ 155,
+ 156,
+ 157,
+ 158,
+ 159,
+ 160,
+ 161,
+ 162,
+ 163,
+ 164,
+ 165,
+ 166,
+ 167,
+ 168,
+ 169,
+ 170,
+ 171,
+ 172,
+ 173,
+ 174,
+ 175,
+ 176,
+ 177,
+ 178,
+ 179,
+ 180,
+ 181,
+ 182,
+ 183,
+ 184,
+ 185,
+ 186,
+ 187,
+ 188,
+ 189,
+ 190,
+ 191,
+ 192,
+ 193,
+ 194,
+ 195,
+ 196,
+ 197,
+ 198,
+ 199,
+ 200,
+ 201,
+ 202,
+ 203,
+ 204,
+ 205,
+ 206,
+ 207,
+ 208,
+ 209,
+ 210,
+ 211,
+ 212,
+ 213,
+ 214,
+ 215,
+ 216,
+ 217,
+ 218,
+ 219,
+ 220,
+ 221,
+ 222,
+ 223,
+ 224,
+ 225,
+ 226,
+ 227,
+ 228,
+ 229,
+ 230,
+ 231,
+ 232,
+ 233,
+ 234,
+ 235,
+ 236,
+ 237,
+ 238,
+ 239,
+ 240,
+ 241,
+ 242,
+ 243,
+ 244,
+ 245,
+ 246,
+ 247,
+ 248,
+ 249,
+ 250,
+ 251,
+ 252,
+ 253,
+ 254,
+ 255,
+ 256,
+ 257,
+ 258,
+ 259,
+ 260,
+ 261,
+ 262,
+ 263,
+ 264,
+ 265,
+ 266,
+ 267,
+ 268,
+ 269,
+ 270,
+ 271,
+ 272,
+ 273,
+ 274,
+ 275,
+ 276,
+ 277,
+ 278,
+ 279,
+ 280,
+ 281,
+ 282,
+ 283,
+ 284,
+ 285,
+ 286,
+ 287,
+ 288,
+ 289,
+ 290,
+ 291,
+ 292,
+ 293,
+ 294,
+ 295,
+ 296,
+ 297,
+ 298,
+ 299,
+ 300,
+ 301,
+ 302,
+ 303,
+ 304,
+ 305,
+ 306,
+ 307,
+ 308,
+ 309,
+ 310,
+ 311,
+ 312,
+ 313,
+ 314,
+ 315,
+ 316,
+ 317,
+ 318,
+ 319,
+ 320,
+ 321,
+ 322,
+ 323,
+ 324,
+ 325,
+ 326,
+ 327,
+ 328,
+ 329,
+ 330,
+ 331,
+ 332,
+ 333,
+ 334,
+ 335,
+ 336,
+ 337,
+ 338,
+ 339,
+ 340,
+ 341,
+ 342,
+ 343,
+ 344,
+ 345,
+ 346,
+ 347,
+ 348,
+ 349,
+ 350,
+ 351,
+ 352,
+ 353,
+ 354,
+ 355,
+ 356,
+ 357,
+ 358,
+ 359,
+ 360,
+ 361,
+ 362,
+ 363,
+ 364,
+ 365,
+ 366,
+ 367,
+ 368,
+ 369,
+ 370,
+ 371,
+ 372,
+ 373,
+ 374,
+ 375,
+ 376,
+ 377,
+ 378,
+ 379,
+ 380,
+ 381,
+ 382,
+ 383,
+ 384,
+ 385,
+ 386,
+ 387,
+ 388,
+ 389,
+ 390,
+ 391,
+ 392,
+ 393,
+ 394,
+ 395,
+ 396,
+ 397,
+ 398,
+ 399,
+ 400,
+ 401,
+ 402,
+ 403,
+ 404,
+ 405,
+ 406,
+ 407,
+ 408,
+ 409,
+ 410,
+ 411,
+ 412,
+ 413,
+ 414,
+ 415,
+ 416,
+ 417,
+ 418,
+ 419,
+ 420,
+ 421,
+ 422,
+ 423,
+ 424,
+ 425,
+ 426,
+ 427,
+ 428,
+ 429,
+ 430,
+ 431,
+ 432,
+ 433,
+ 434,
+ 435,
+ 436,
+ 437,
+ 438,
+ 439,
+ 440,
+ 441,
+ 442,
+ 443,
+ 444,
+ 445,
+ 446,
+ 447,
+ 448,
+ 449,
+ 450,
+ 451,
+ 452,
+ 453,
+ 454,
+ 455,
+ 456,
+ 457,
+ 458,
+ 459,
+ 460,
+ 461,
+ 462,
+ 463,
+ 464,
+ 465,
+ 466,
+ 467,
+ 468,
+ 469,
+ 470,
+ 471,
+ 472,
+ 473,
+ 474,
+ 475,
+ 476,
+ 477,
+ 478,
+ 479,
+ 480,
+ 481,
+ 482,
+ 483,
+ 484,
+ 485,
+ 486,
+ 487,
+ 488,
+ 489,
+ 490,
+ 491,
+ 492,
+ 493,
+ 494,
+ 495,
+ 496,
+ 497,
+ 498,
+ 499,
+ 500,
+ 501,
+ 502,
+ 503,
+ 504,
+ 505,
+ 506,
+ 507,
+ 508,
+ 509,
+ 510,
+ 511,
+ 512,
+ 513,
+ 514,
+ 515,
+ 516,
+ 517,
+ 518,
+ 519,
+ 520,
+ 521,
+ 522,
+ 523,
+ 524,
+ 525,
+ 526,
+ 527,
+ 528,
+ 529,
+ 530,
+ 531,
+ 532,
+ 533,
+ 534,
+ 535,
+ 536,
+ 537,
+ 538,
+ 539,
+ 540,
+ 541,
+ 542,
+ 543,
+ 544,
+ 545,
+ 546,
+ 547,
+ 548,
+ 549,
+ 550,
+ 551,
+ 552,
+ 553,
+ 554,
+ 555,
+ 556,
+ 557,
+ 558,
+ 559,
+ 560,
+ 561,
+ 562,
+ 563,
+ 564,
+ 565,
+ 566,
+ 567,
+ 568,
+ 569,
+ 570,
+ 571,
+ 572,
+ 573,
+ 574,
+ 575,
+ 576,
+ 577,
+ 578,
+ 579,
+ 580,
+ 581,
+ 582,
+ 583,
+ 584,
+ 585,
+ 586,
+ 587,
+ 588,
+ 589,
+ 590,
+ 591,
+ 592,
+ 593,
+ 594,
+ 595,
+ 596,
+ 597,
+ 598,
+ 599,
+ 600,
+ 601,
+ 602,
+ 603,
+ 604,
+ 605,
+ 606,
+ 607,
+ 608,
+ 609,
+ 610,
+ 611,
+ 612,
+ 613,
+ 614,
+ 615,
+ 616,
+ 617,
+ 618,
+ 619,
+ 620,
+ 621,
+ 622,
+ 623,
+ 624,
+ 625,
+ 626,
+ 627,
+ 628,
+ 629,
+ 630,
+ 631,
+ 632,
+ 633,
+ 634,
+ 635,
+ 636,
+ 637,
+ 638,
+ 639,
+ 640,
+ 641,
+ 642,
+ 643,
+ 644,
+ 645,
+ 646,
+ 647,
+ 648,
+ 649,
+ 650,
+ 651,
+ 652,
+ 653,
+ 654,
+ 655,
+ 656,
+ 657,
+ 658,
+ 659,
+ 660,
+ 661,
+ 662,
+ 663,
+ 664,
+ 665,
+ 666,
+ 667,
+ 668,
+ 669,
+ 670,
+ 671,
+ 672,
+ 673,
+ 674,
+ 675,
+ 676,
+ 677,
+ 678,
+ 679,
+ 680,
+ 681,
+ 682,
+ 683,
+ 684,
+ 685,
+ 686,
+ 687,
+ 688,
+ 689,
+ 690,
+ 691,
+ 692,
+ 693,
+ 694,
+ 695,
+ 696,
+ 697,
+ 698,
+ 699,
+ 700,
+ 701,
+ 702,
+ 703,
+ 704,
+ 705,
+ 706,
+ 707,
+ 708,
+ 709,
+ 710,
+ 711,
+ 712,
+ 713,
+ 714,
+ 715,
+ 716,
+ 717,
+ 718,
+ 719,
+ 720,
+ 721,
+ 722,
+ 723,
+ 724,
+ 725,
+ 726,
+ 727,
+ 728,
+ 729,
+ 730,
+ 731,
+ 732,
+ 733,
+ 734,
+ 735,
+ 736,
+ 737,
+ 738,
+ 739,
+ 740,
+ 741,
+ 742,
+ 743,
+ 744,
+ 745,
+ 746,
+ 747,
+ 748,
+ 749,
+ 750,
+ 751,
+ 752,
+ 753,
+ 754,
+ 755,
+ 756,
+ 757,
+ 758,
+ 759,
+ 760,
+ 761,
+ 762,
+ 763,
+ 764,
+ 765,
+ 766,
+ 767,
+ 768,
+ 769,
+ 770,
+ 771,
+ 772,
+ 773,
+ 774,
+ 775,
+ 776,
+ 777,
+ 778,
+ 779,
+ 780,
+ 781,
+ 782,
+ 783,
+ 784,
+ 785,
+ 786,
+ 787,
+ 788,
+ 789,
+ 790,
+ 791,
+ 792,
+ 793,
+ 794,
+ 795,
+ 796,
+ 797,
+ 798,
+ 799,
+ 800,
+ 801,
+ 802,
+ 803,
+ 804,
+ 805,
+ 806,
+ 807,
+ 808,
+ 809,
+ 810,
+ 811,
+ 812,
+ 813,
+ 814,
+ 815,
+ 816,
+ 817,
+ 818,
+ 819,
+ 820,
+ 821,
+ 822,
+ 823,
+ 824,
+ 825,
+ 826,
+ 827,
+ 828,
+ 829,
+ 830,
+ 831,
+ 832,
+ 833,
+ 834,
+ 835,
+ 836,
+ 837,
+ 838,
+ 839,
+ 840,
+ 841,
+ 842,
+ 843,
+ 844,
+ 845,
+ 846,
+ 847,
+ 848,
+ 849,
+ 850,
+ 851,
+ 852,
+ 853,
+ 854,
+ 855,
+ 856,
+ 857,
+ 858,
+ 859,
+ 860,
+ 861,
+ 862,
+ 863,
+ 864,
+ 865,
+ 866,
+ 867,
+ 868,
+ 869,
+ 870,
+ 871,
+ 872,
+ 873,
+ 874,
+ 875,
+ 876,
+ 877,
+ 878,
+ 879,
+ 880,
+ 881,
+ 882,
+ 883,
+ 884,
+ 885,
+ 886,
+ 887,
+ 888,
+ 889,
+ 890,
+ 891,
+ 892,
+ 893,
+ 894,
+ 895,
+ 896,
+ 897,
+ 898,
+ 899,
+ 900,
+ 901,
+ 902,
+ 903,
+ 904,
+ 905,
+ 906,
+ 907,
+ 908,
+ 909,
+ 910,
+ 911,
+ 912,
+ 913,
+ 914,
+ 915,
+ 916,
+ 917,
+ 918,
+ 919,
+ 920,
+ 921,
+ 922,
+ 923,
+ 924,
+ 925,
+ 926,
+ 927,
+ 928,
+ 929,
+ 930,
+ 931,
+ 932,
+ 933,
+ 934,
+ 935,
+ 936,
+ 937,
+ 938,
+ 939,
+ 940,
+ 941,
+ 942,
+ 943,
+ 944,
+ 945,
+ 946,
+ 947,
+ 948,
+ 949,
+ 950,
+ 951,
+ 952,
+ 953,
+ 954,
+ 955,
+ 956,
+ 957,
+ 958,
+ 959,
+ 960,
+ 961,
+ 962,
+ 963,
+ 964,
+ 965,
+ 966,
+ 967,
+ 968,
+ 969,
+ 970,
+ 971,
+ 972,
+ 973,
+ 974,
+ 975,
+ 976,
+ 977,
+ 978,
+ 979,
+ 980,
+ 981,
+ 982,
+ 983,
+ 984,
+ 985,
+ 986,
+ 987,
+ 988,
+ 989,
+ 990,
+ 991,
+ 992,
+ 993,
+ 994,
+ 995,
+ 996,
+ 997,
+ 998,
+ 999,
+ 1000,
+ 1001,
+ 1002,
+ 1003,
+ 1004,
+ 1005,
+ 1006,
+ 1007,
+ 1008,
+ 1009,
+ 1010,
+ 1011,
+ 1012,
+ 1013,
+ 1014,
+ 1015,
+ 1016,
+ 1017,
+ 1018,
+ 1019,
+ 1020,
+ 1021,
+ 1022,
+ 1023,
+ 1024,
+ 1025,
+ 1026,
+ 1027,
+ 1028,
+ 1029,
+ 1030,
+ 1031,
+ 1032,
+ 1033,
+ 1034,
+ 1035,
+ 1036,
+ 1037,
+ 1038,
+ 1039,
+ 1040,
+ 1041,
+ 1042,
+ 1043,
+ 1044,
+ 1045,
+ 1046,
+ 1047,
+ 1048,
+ 1049,
+ 1050,
+ 1051,
+ 1052,
+ 1053,
+ 1054,
+ 1055,
+ 1056,
+ 1057,
+ 1058,
+ 1059,
+ 1060,
+ 1061,
+ 1062,
+ 1063,
+ 1064,
+ 1065,
+ 1066,
+ 1067,
+ 1068,
+ 1069,
+ 1070,
+ 1071,
+ 1072,
+ 1073,
+ 1074,
+ 1075,
+ 1076,
+ 1077,
+ 1078,
+ 1079,
+ 1080,
+ 1081,
+ 1082,
+ 1083,
+ 1084,
+ 1085,
+ 1086,
+ 1087,
+ 1088,
+ 1089,
+ 1090,
+ 1091,
+ 1092,
+ 1093,
+ 1094,
+ 1095,
+ 1096,
+ 1097,
+ 1098,
+ 1099,
+ 1100,
+ 1101,
+ 1102,
+ 1103,
+ 1104,
+ 1105,
+ 1106,
+ 1107,
+ 1108,
+ 1109,
+ 1110,
+ 1111,
+ 1112,
+ 1113,
+ 1114,
+ 1115,
+ 1116,
+ 1117,
+ 1118,
+ 1119,
+ 1120,
+ 1121,
+ 1122,
+ 1123,
+ 1124,
+ 1125,
+ 1126,
+ 1127,
+ 1128,
+ 1129,
+ 1130,
+ 1131,
+ 1132,
+ 1133,
+ 1134,
+ 1135,
+ 1136,
+ 1137,
+ 1138,
+ 1139,
+ 1140,
+ 1141,
+ 1142,
+ 1143,
+ 1144,
+ 1145,
+ 1146,
+ 1147,
+ 1148,
+ 1149,
+ 1150,
+ 1151,
+ 1152,
+ 1153,
+ 1154,
+ 1155,
+ 1156,
+ 1157,
+ 1158,
+ 1159,
+ 1160,
+ 1161,
+ 1162,
+ 1163,
+ 1164,
+ 1165,
+ 1166,
+ 1167,
+ 1168,
+ 1169,
+ 1170,
+ 1171,
+ 1172,
+ 1173,
+ 1174,
+ 1175,
+ 1176,
+ 1177,
+ 1178,
+ 1179,
+ 1180,
+ 1181,
+ 1182,
+ 1183,
+ 1184,
+ 1185,
+ 1186,
+ 1187,
+ 1188,
+ 1189,
+ 1190,
+ 1191,
+ 1192,
+ 1193,
+ 1194,
+ 1195,
+ 1196,
+ 1197,
+ 1198,
+ 1199,
+ 1200,
+ 1201,
+ 1202,
+ 1203,
+ 1204,
+ 1205,
+ 1206,
+ 1207,
+ 1208,
+ 1209,
+ 1210,
+ 1211,
+ 1212,
+ 1213,
+ 1214,
+ 1215,
+ 1216,
+ 1217,
+ 1218,
+ 1219,
+ 1220,
+ 1221,
+ 1222,
+ 1223,
+ 1224,
+ 1225,
+ 1226,
+ 1227,
+ 1228,
+ 1229,
+ 1230,
+ 1231,
+ 1232,
+ 1233,
+ 1234,
+ 1235,
+ 1236,
+ 1237,
+ 1238,
+ 1239,
+ 1240,
+ 1241,
+ 1242,
+ 1243,
+ 1244,
+ 1245,
+ 1246,
+ 1247,
+ 1248,
+ 1249,
+ 1250,
+ 1251,
+ 1252,
+ 1253,
+ 1254,
+ 1255,
+ 1256,
+ 1257,
+ 1258,
+ 1259,
+ 1260,
+ 1261,
+ 1262,
+ 1263,
+ 1264,
+ 1265,
+ 1266,
+ 1267,
+ 1268,
+ 1269,
+ 1270,
+ 1271,
+ 1272,
+ 1273,
+ 1274,
+ 1275,
+ 1276,
+ 1277,
+ 1278,
+ 1279,
+ 1280,
+ 1281,
+ 1282,
+ 1283,
+ 1284,
+ 1285,
+ 1286,
+ 1287,
+ 1288,
+ 1289,
+ 1290,
+ 1291,
+ 1292,
+ 1293,
+ 1294,
+ 1295,
+ 1296,
+ 1297,
+ 1298,
+ 1299,
+ 1300,
+ 1301,
+ 1302,
+ 1303,
+ 1304,
+ 1305,
+ 1306,
+ 1307,
+ 1308,
+ 1309,
+ 1310,
+ 1311,
+ 1312,
+ 1313,
+ 1314,
+ 1315,
+ 1316,
+ 1317,
+ 1318,
+ 1319,
+ 1320,
+ 1321,
+ 1322,
+ 1323,
+ 1324,
+ 1325,
+ 1326,
+ 1327,
+ 1328,
+ 1329,
+ 1330,
+ 1331,
+ 1332,
+ 1333,
+ 1334,
+ 1335,
+ 1336,
+ 1337,
+ 1338,
+ 1339,
+ 1340,
+ 1341,
+ 1342,
+ 1343,
+ 1344,
+ 1345,
+ 1346,
+ 1347,
+ 1348,
+ 1349,
+ 1350,
+ 1351,
+ 1352,
+ 1353,
+ 1354,
+ 1355,
+ 1356,
+ 1357,
+ 1358,
+ 1359,
+ 1360,
+ 1361,
+ 1362,
+ 1363,
+ 1364,
+ 1365,
+ 1366,
+ 1367,
+ 1368,
+ 1369,
+ 1370,
+ 1371,
+ 1372,
+ 1373,
+ 1374,
+ 1375,
+ 1376,
+ 1377,
+ 1378,
+ 1379,
+ 1380,
+ 1381,
+ 1382,
+ 1383,
+ 1384,
+ 1385,
+ 1386,
+ 1387,
+ 1388,
+ 1389,
+ 1390,
+ 1391,
+ 1392,
+ 1393,
+ 1394,
+ 1395,
+ 1396,
+ 1397,
+ 1398,
+ 1399,
+ 1400,
+ 1401,
+ 1402,
+ 1403,
+ 1404,
+ 1405,
+ 1406,
+ 1407,
+ 1408,
+ 1409,
+ 1410,
+ 1411,
+ 1412,
+ 1413,
+ 1414,
+ 1415,
+ 1416,
+ 1417,
+ 1418,
+ 1419,
+ 1420,
+ 1421,
+ 1422,
+ 1423,
+ 1424,
+ 1425,
+ 1426,
+ 1427,
+ 1428,
+ 1429,
+ 1430,
+ 1431,
+ 1432,
+ 1433,
+ 1434,
+ 1435,
+ 1436,
+ 1437,
+ 1438,
+ 1439,
+ 1440,
+ 1441,
+ 1442,
+ 1443,
+ 1444,
+ 1445,
+ 1446,
+ 1447,
+ 1448,
+ 1449,
+ 1450,
+ 1451,
+ 1452,
+ 1453,
+ 1454,
+ 1455,
+ 1456,
+ 1457,
+ 1458,
+ 1459,
+ 1460,
+ 1461,
+ 1462,
+ 1463,
+ 1464,
+ 1465,
+ 1466,
+ 1467,
+ 1468,
+ 1469,
+ 1470,
+ 1471,
+ 1472,
+ 1473,
+ 1474,
+ 1475,
+ 1476,
+ 1477,
+ 1478,
+ 1479,
+ 1480,
+ 1481,
+ 1482,
+ 1483,
+ 1484,
+ 1485,
+ 1486,
+ 1487,
+ 1488,
+ 1489,
+ 1490,
+ 1491,
+ 1492,
+ 1493,
+ 1494,
+ 1495,
+ 1496,
+ 1497,
+ 1498,
+ 1499,
+ 1500,
+ 1501,
+ 1502,
+ 1503,
+ 1504,
+ 1505,
+ 1506,
+ 1507,
+ 1508,
+ 1509,
+ 1510,
+ 1511,
+ 1512,
+ 1513,
+ 1514,
+ 1515,
+ 1516,
+ 1517,
+ 1518,
+ 1519,
+ 1520,
+ 1521,
+ 1522,
+ 1523,
+ 1524,
+ 1525,
+ 1526,
+ 1527,
+ 1528,
+ 1529,
+ 1530,
+ 1531,
+ 1532,
+ 1533,
+ 1534,
+ 1535,
+ 1536,
+ 1537,
+ 1538,
+ 1539,
+ 1540,
+ 1541,
+ 1542,
+ 1543,
+ 1544,
+ 1545,
+ 1546,
+ 1547,
+ 1548,
+ 1549,
+ 1550,
+ 1551,
+ 1552,
+ 1553,
+ 1554,
+ 1555,
+ 1556,
+ 1557,
+ 1558,
+ 1559,
+ 1560,
+ 1561,
+ 1562,
+ 1563,
+ 1564,
+ 1565,
+ 1566,
+ 1567,
+ 1568,
+ 1569,
+ 1570,
+ 1571,
+ 1572,
+ 1573,
+ 1574,
+ 1575,
+ 1576,
+ 1577,
+ 1578,
+ 1579,
+ 1580,
+ 1581,
+ 1582,
+ 1583,
+ 1584,
+ 1585,
+ 1586,
+ 1587,
+ 1588,
+ 1589,
+ 1590,
+ 1591,
+ 1592,
+ 1593,
+ 1594,
+ 1595,
+ 1596,
+ 1597,
+ 1598,
+ 1599,
+ 1600,
+ 1601,
+ 1602,
+ 1603,
+ 1604,
+ 1605,
+ 1606,
+ 1607,
+ 1608,
+ 1609,
+ 1610,
+ 1611,
+ 1612,
+ 1613,
+ 1614,
+ 1615,
+ 1616,
+ 1617,
+ 1618,
+ 1619,
+ 1620,
+ 1621,
+ 1622,
+ 1623,
+ 1624,
+ 1625,
+ 1626,
+ 1627,
+ 1628,
+ 1629,
+ 1630,
+ 1631,
+ 1632,
+ 1633,
+ 1634,
+ 1635,
+ 1636,
+ 1637,
+ 1638,
+ 1639,
+ 1640,
+ 1641,
+ 1642,
+ 1643,
+ 1644,
+ 1645,
+ 1646,
+ 1647,
+ 1648,
+ 1649,
+ 1650,
+ 1651,
+ 1652,
+ 1653,
+ 1654,
+ 1655,
+ 1656,
+ 1657,
+ 1658,
+ 1659,
+ 1660,
+ 1661,
+ 1662,
+ 1663,
+ 1664,
+ 1665,
+ 1666,
+ 1667,
+ 1668,
+ 1669,
+ 1670,
+ 1671,
+ 1672,
+ 1673,
+ 1674,
+ 1675,
+ 1676,
+ 1677,
+ 1678,
+ 1679,
+ 1680,
+ 1681,
+ 1682,
+ 1683,
+ 1684,
+ 1685,
+ 1686,
+ 1687,
+ 1688,
+ 1689,
+ 1690,
+ 1691,
+ 1692,
+ 1693,
+ 1694,
+ 1695,
+ 1696,
+ 1697,
+ 1698,
+ 1699,
+ 1700,
+ 1701,
+ 1702,
+ 1703,
+ 1704,
+ 1705,
+ 1706,
+ 1707,
+ 1708,
+ 1709,
+ 1710,
+ 1711,
+ 1712,
+ 1713,
+ 1714,
+ 1715,
+ 1716,
+ 1717,
+ 1718,
+ 1719,
+ 1720,
+ 1721,
+ 1722,
+ 1723,
+ 1724,
+ 1725,
+ 1726,
+ 1727,
+ 1728,
+ 1729,
+ 1730,
+ 1731,
+ 1732,
+ 1733,
+ 1734,
+ 1735,
+ 1736,
+ 1737,
+ 1738,
+ 1739,
+ 1740,
+ 1741,
+ 1742,
+ 1743,
+ 1744,
+ 1745,
+ 1746,
+ 1747,
+ 1748,
+ 1749,
+ 1750,
+ 1751,
+ 1752,
+ 1753,
+ 1754,
+ 1755,
+ 1756,
+ 1757,
+ 1758,
+ 1759,
+ 1760,
+ 1761,
+ 1762,
+ 1763,
+ 1764,
+ 1765,
+ 1766,
+ 1767,
+ 1768,
+ 1769,
+ 1770,
+ 1771,
+ 1772,
+ 1773,
+ 1774,
+ 1775,
+ 1776,
+ 1777,
+ 1778,
+ 1779,
+ 1780,
+ 1781,
+ 1782,
+ 1783,
+ 1784,
+ 1785,
+ 1786,
+ 1787,
+ 1788,
+ 1789,
+ 1790,
+ 1791,
+ 1792,
+ 1793,
+ 1794,
+ 1795,
+ 1796,
+ 1797,
+ 1798,
+ 1799,
+ 1800,
+ 1801,
+ 1802,
+ 1803,
+ 1804,
+ 1805,
+ 1806,
+ 1807,
+ 1808,
+ 1809,
+ 1810,
+ 1811,
+ 1812,
+ 1813,
+ 1814,
+ 1815,
+ 1816,
+ 1817,
+ 1818,
+ 1819,
+ 1820,
+ 1821,
+ 1822,
+ 1823,
+ 1824,
+ 1825,
+ 1826,
+ 1827,
+ 1828,
+ 1829,
+ 1830,
+ 1831,
+ 1832,
+ 1833,
+ 1834,
+ 1835,
+ 1836,
+ 1837,
+ 1838,
+ 1839,
+ 1840,
+ 1841,
+ 1842,
+ 1843,
+ 1844,
+ 1845,
+ 1846,
+ 1847,
+ 1848,
+ 1849,
+ 1850,
+ 1851,
+ 1852,
+ 1853,
+ 1854,
+ 1855,
+ 1856,
+ 1857,
+ 1858,
+ 1859,
+ 1860,
+ 1861,
+ 1862,
+ 1863,
+ 1864,
+ 1865,
+ 1866,
+ 1867,
+ 1868,
+ 1869,
+ 1870,
+ 1871,
+ 1872,
+ 1873,
+ 1874,
+ 1875,
+ 1876,
+ 1877,
+ 1878,
+ 1879,
+ 1880,
+ 1881,
+ 1882,
+ 1883,
+ 1884,
+ 1885,
+ 1886,
+ 1887,
+ 1888,
+ 1889,
+ 1890,
+ 1891,
+ 1892,
+ 1893,
+ 1894,
+ 1895,
+ 1896,
+ 1897,
+ 1898,
+ 1899,
+ 1900,
+ 1901,
+ 1902,
+ 1903,
+ 1904,
+ 1905,
+ 1906,
+ 1907,
+ 1908,
+ 1909,
+ 1910,
+ 1911,
+ 1912,
+ 1913,
+ 1914,
+ 1915,
+ 1916,
+ 1917,
+ 1918,
+ 1919,
+ 1920,
+ 1921,
+ 1922,
+ 1923,
+ 1924,
+ 1925,
+ 1926,
+ 1927,
+ 1928,
+ 1929,
+ 1930,
+ 1931,
+ 1932,
+ 1933,
+ 1934,
+ 1935,
+ 1936,
+ 1937,
+ 1938,
+ 1939,
+ 1940,
+ 1941,
+ 1942,
+ 1943,
+ 1944,
+ 1945,
+ 1946,
+ 1947,
+ 1948,
+ 1949,
+ 1950,
+ 1951,
+ 1952,
+ 1953,
+ 1954,
+ 1955,
+ 1956,
+ 1957,
+ 1958,
+ 1959,
+ 1960,
+ 1961,
+ 1962,
+ 1963,
+ 1964,
+ 1965,
+ 1966,
+ 1967,
+ 1968,
+ 1969,
+ 1970,
+ 1971,
+ 1972,
+ 1973,
+ 1974,
+ 1975,
+ 1976,
+ 1977,
+ 1978,
+ 1979,
+ 1980,
+ 1981,
+ 1982,
+ 1983,
+ 1984,
+ 1985,
+ 1986,
+ 1987,
+ 1988,
+ 1989,
+ 1990,
+ 1991,
+ 1992,
+ 1993,
+ 1994,
+ 1995,
+ 1996,
+ 1997,
+ 1998,
+ 1999,
+ 2000,
+ 2001,
+ 2002,
+ 2003,
+ 2004,
+ 2005,
+ 2006,
+ 2007,
+ 2008,
+ 2009,
+ 2010,
+ 2011,
+ 2012,
+ 2013,
+ 2014,
+ 2015,
+ 2016,
+ 2017,
+ 2018,
+ 2019,
+ 2020,
+ 2021,
+ 2022,
+ 2023,
+ 2024,
+ 2025,
+ 2026,
+ 2027,
+ 2028,
+ 2029,
+ 2030,
+ 2031,
+ 2032,
+ 2033,
+ 2034,
+ 2035,
+ 2036,
+ 2037,
+ 2038,
+ 2039,
+ 2040,
+ 2041,
+ 2042,
+ 2043,
+ 2044,
+ 2045,
+ 2046,
+ 2047,
+ 2048,
+ 2049,
+ 2050,
+ 2051,
+ 2052,
+ 2053,
+ 2054,
+ 2055,
+ 2056,
+ 2057,
+ 2058,
+ 2059,
+ 2060,
+ 2061,
+ 2062,
+ 2063,
+ 2064,
+ 2065,
+ 2066,
+ 2067,
+ 2068,
+ 2069,
+ 2070,
+ 2071,
+ 2072,
+ 2073,
+ 2074,
+ 2075,
+ 2076,
+ 2077,
+ 2078,
+ 2079,
+ 2080,
+ 2081,
+ 2082,
+ 2083,
+ 2084,
+ 2085,
+ 2086,
+ 2087,
+ 2088,
+ 2089,
+ 2090,
+ 2091,
+ 2092,
+ 2093,
+ 2094,
+ 2095,
+ 2096,
+ 2097,
+ 2098,
+ 2099,
+ 2100,
+ 2101,
+ 2102,
+ 2103,
+ 2104,
+ 2105,
+ 2106,
+ 2107,
+ 2108,
+ 2109,
+ 2110,
+ 2111,
+ 2112,
+ 2113,
+ 2114,
+ 2115,
+ 2116,
+ 2117,
+ 2118,
+ 2119,
+ 2120,
+ 2121,
+ 2122,
+ 2123,
+ 2124,
+ 2125,
+ 2126,
+ 2127,
+ 2128,
+ 2129,
+ 2130,
+ 2131,
+ 2132,
+ 2133,
+ 2134,
+ 2135,
+ 2136,
+ 2137,
+ 2138,
+ 2139,
+ 2140,
+ 2141,
+ 2142,
+ 2143,
+ 2144,
+ 2145,
+ 2146,
+ 2147,
+ 2148,
+ 2149,
+ 2150,
+ 2151,
+ 2152,
+ 2153,
+ 2154,
+ 2155,
+ 2156,
+ 2157,
+ 2158,
+ 2159,
+ 2160,
+ 2161,
+ 2162,
+ 2163,
+ 2164,
+ 2165,
+ 2166,
+ 2167,
+ 2168,
+ 2169,
+ 2170,
+ 2171,
+ 2172,
+ 2173,
+ 2174,
+ 2175,
+ 2176,
+ 2177,
+ 2178,
+ 2179,
+ 2180,
+ 2181,
+ 2182,
+ 2183,
+ 2184,
+ 2185,
+ 2186,
+ 2187,
+ 2188,
+ 2189,
+ 2190,
+ 2191,
+ 2192,
+ 2193,
+ 2194,
+ 2195,
+ 2196,
+ 2197,
+ 2198,
+ 2199,
+ 2200,
+ 2201,
+ 2202,
+ 2203,
+ 2204,
+ 2205,
+ 2206,
+ 2207,
+ 2208,
+ 2209,
+ 2210,
+ 2211,
+ 2212,
+ 2213,
+ 2214,
+ 2215,
+ 2216,
+ 2217,
+ 2218,
+ 2219,
+ 2220,
+ 2221,
+ 2222,
+ 2223,
+ 2224,
+ 2225,
+ 2226,
+ 2227,
+ 2228,
+ 2229,
+ 2230,
+ 2231,
+ 2232,
+ 2233,
+ 2234,
+ 2235,
+ 2236,
+ 2237,
+ 2238,
+ 2239,
+ 2240,
+ 2241,
+ 2242,
+ 2243,
+ 2244,
+ 2245,
+ 2246,
+ 2247,
+ 2248,
+ 2249,
+ 2250,
+ 2251,
+ 2252,
+ 2253,
+ 2254,
+ 2255,
+ 2256,
+ 2257,
+ 2258,
+ 2259,
+ 2260,
+ 2261,
+ 2262,
+ 2263,
+ 2264,
+ 2265,
+ 2266,
+ 2267,
+ 2268,
+ 2269,
+ 2270,
+ 2271,
+ 2272,
+ 2273,
+ 2274,
+ 2275,
+ 2276,
+ 2277,
+ 2278,
+ 2279,
+ 2280,
+ 2281,
+ 2282,
+ 2283,
+ 2284,
+ 2285,
+ 2286,
+ 2287,
+ 2288,
+ 2289,
+ 2290,
+ 2291,
+ 2292,
+ 2293,
+ 2294,
+ 2295,
+ 2296,
+ 2297,
+ 2298,
+ 2299,
+ 2300,
+ 2301,
+ 2302,
+ 2303,
+ 2304,
+ 2305,
+ 2306,
+ 2307,
+ 2308,
+ 2309,
+ 2310,
+ 2311,
+ 2312,
+ 2313,
+ 2314,
+ 2315,
+ 2316,
+ 2317,
+ 2318,
+ 2319,
+ 2320,
+ 2321,
+ 2322,
+ 2323,
+ 2324,
+ 2325,
+ 2326,
+ 2327,
+ 2328,
+ 2329,
+ 2330,
+ 2331,
+ 2332,
+ 2333,
+ 2334,
+ 2335,
+ 2336,
+ 2337,
+ 2338,
+ 2339,
+ 2340,
+ 2341,
+ 2342,
+ 2343,
+ 2344,
+ 2345,
+ 2346,
+ 2347,
+ 2348,
+ 2349,
+ 2350,
+ 2351,
+ 2352,
+ 2353,
+ 2354,
+ 2355,
+ 2356,
+ 2357,
+ 2358,
+ 2359,
+ 2360,
+ 2361,
+ 2362,
+ 2363,
+ 2364,
+ 2365,
+ 2366,
+ 2367,
+ 2368,
+ 2369,
+ 2370,
+ 2371,
+ 2372,
+ 2373,
+ 2374,
+ 2375,
+ 2376,
+ 2377,
+ 2378,
+ 2379,
+ 2380,
+ 2381,
+ 2382,
+ 2383,
+ 2384,
+ 2385,
+ 2386,
+ 2387,
+ 2388,
+ 2389,
+ 2390,
+ 2391,
+ 2392,
+ 2393,
+ 2394,
+ 2395,
+ 2396,
+ 2397,
+ 2398,
+ 2399,
+ 2400,
+ 2401,
+ 2402,
+ 2403,
+ 2404,
+ 2405,
+ 2406,
+ 2407,
+ 2408,
+ 2409,
+ 2410,
+ 2411,
+ 2412,
+ 2413,
+ 2414,
+ 2415,
+ 2416,
+ 2417,
+ 2418,
+ 2419,
+ 2420,
+ 2421,
+ 2422,
+ 2423,
+ 2424,
+ 2425,
+ 2426,
+ 2427,
+ 2428,
+ 2429,
+ 2430,
+ 2431,
+ 2432,
+ 2433,
+ 2434,
+ 2435,
+ 2436,
+ 2437,
+ 2438,
+ 2439,
+ 2440,
+ 2441,
+ 2442,
+ 2443,
+ 2444,
+ 2445,
+ 2446,
+ 2447,
+ 2448,
+ 2449,
+ 2450,
+ 2451,
+ 2452,
+ 2453,
+ 2454,
+ 2455,
+ 2456,
+ 2457,
+ 2458,
+ 2459,
+ 2460,
+ 2461,
+ 2462,
+ 2463,
+ 2464,
+ 2465,
+ 2466,
+ 2467,
+ 2468,
+ 2469,
+ 2470,
+ 2471,
+ 2472,
+ 2473,
+ 2474,
+ 2475,
+ 2476,
+ 2477,
+ 2478,
+ 2479,
+ 2480,
+ 2481,
+ 2482,
+ 2483,
+ 2484,
+ 2485,
+ 2486,
+ 2487,
+ 2488,
+ 2489,
+ 2490,
+ 2491,
+ 2492,
+ 2493,
+ 2494,
+ 2495,
+ 2496,
+ 2497,
+ 2498,
+ 2499,
+ 2500,
+ 2501,
+ 2502,
+ 2503,
+ 2504,
+ 2505,
+ 2506,
+ 2507,
+ 2508,
+ 2509,
+ 2510,
+ 2511,
+ 2512,
+ 2513,
+ 2514,
+ 2515,
+ 2516,
+ 2517,
+ 2518,
+ 2519,
+ 2520,
+ 2521,
+ 2522,
+ 2523,
+ 2524,
+ 2525,
+ 2526,
+ 2527,
+ 2528,
+ 2529,
+ 2530,
+ 2531,
+ 2532,
+ 2533,
+ 2534,
+ 2535,
+ 2536,
+ 2537,
+ 2538,
+ 2539,
+ 2540,
+ 2541,
+ 2542,
+ 2543,
+ 2544,
+ 2545,
+ 2546,
+ 2547,
+ 2548,
+ 2549,
+ 2550,
+ 2551,
+ 2552,
+ 2553,
+ 2554,
+ 2555,
+ 2556,
+ 2557,
+ 2558,
+ 2559,
+ 2560,
+ 2561,
+ 2562,
+ 2563,
+ 2564,
+ 2565,
+ 2566,
+ 2567,
+ 2568,
+ 2569,
+ 2570,
+ 2571,
+ 2572,
+ 2573,
+ 2574,
+ 2575,
+ 2576,
+ 2577,
+ 2578,
+ 2579,
+ 2580,
+ 2581,
+ 2582,
+ 2583,
+ 2584,
+ 2585,
+ 2586,
+ 2587,
+ 2588,
+ 2589,
+ 2590,
+ 2591,
+ 2592,
+ 2593,
+ 2594,
+ 2595,
+ 2596,
+ 2597,
+ 2598,
+ 2599,
+ 2600,
+ 2601,
+ 2602,
+ 2603,
+ 2604,
+ 2605,
+ 2606,
+ 2607,
+ 2608,
+ 2609,
+ 2610,
+ 2611,
+ 2612,
+ 2613,
+ 2614,
+ 2615,
+ 2616,
+ 2617,
+ 2618,
+ 2619,
+ 2620,
+ 2621,
+ 2622,
+ 2623,
+ 2624,
+ 2625,
+ 2626,
+ 2627,
+ 2628,
+ 2629,
+ 2630,
+ 2631,
+ 2632,
+ 2633,
+ 2634,
+ 2635,
+ 2636,
+ 2637,
+ 2638,
+ 2639,
+ 2640,
+ 2641,
+ 2642,
+ 2643,
+ 2644,
+ 2645,
+ 2646,
+ 2647,
+ 2648,
+ 2649,
+ 2650,
+ 2651,
+ 2652,
+ 2653,
+ 2654,
+ 2655,
+ 2656,
+ 2657,
+ 2658,
+ 2659,
+ 2660,
+ 2661,
+ 2662,
+ 2663,
+ 2664,
+ 2665,
+ 2666,
+ 2667,
+ 2668,
+ 2669,
+ 2670,
+ 2671,
+ 2672,
+ 2673,
+ 2674,
+ 2675,
+ 2676,
+ 2677,
+ 2678,
+ 2679,
+ 2680,
+ 2681,
+ 2682,
+ 2683,
+ 2684,
+ 2685,
+ 2686,
+ 2687,
+ 2688,
+ 2689,
+ 2690,
+ 2691,
+ 2692,
+ 2693,
+ 2694,
+ 2695,
+ 2696,
+ 2697,
+ 2698,
+ 2699,
+ 2700,
+ 2701,
+ 2702,
+ 2703,
+ 2704,
+ 2705,
+ 2706,
+ 2707,
+ 2708,
+ 2709,
+ 2710,
+ 2711,
+ 2712,
+ 2713,
+ 2714,
+ 2715,
+ 2716,
+ 2717,
+ 2718,
+ 2719,
+ 2720,
+ 2721,
+ 2722,
+ 2723,
+ 2724,
+ 2725,
+ 2726,
+ 2727,
+ 2728,
+ 2729,
+ 2730,
+ 2731,
+ 2732,
+ 2733,
+ 2734,
+ 2735,
+ 2736,
+ 2737,
+ 2738,
+ 2739,
+ 2740,
+ 2741,
+ 2742,
+ 2743,
+ 2744,
+ 2745,
+ 2746,
+ 2747,
+ 2748,
+ 2749,
+ 2750,
+ 2751,
+ 2752,
+ 2753,
+ 2754,
+ 2755,
+ 2756,
+ 2757,
+ 2758,
+ 2759,
+ 2760,
+ 2761,
+ 2762,
+ 2763,
+ 2764,
+ 2765,
+ 2766,
+ 2767,
+ 2768,
+ 2769,
+ 2770,
+ 2771,
+ 2772,
+ 2773,
+ 2774,
+ 2775,
+ 2776,
+ 2777,
+ 2778,
+ 2779,
+ 2780,
+ 2781,
+ 2782,
+ 2783,
+ 2784,
+ 2785,
+ 2786,
+ 2787,
+ 2788,
+ 2789,
+ 2790,
+ 2791,
+ 2792,
+ 2793,
+ 2794,
+ 2795,
+ 2796,
+ 2797,
+ 2798,
+ 2799,
+ 2800,
+ 2801,
+ 2802,
+ 2803,
+ 2804,
+ 2805,
+ 2806,
+ 2807,
+ 2808,
+ 2809,
+ 2810,
+ 2811,
+ 2812,
+ 2813,
+ 2814,
+ 2815,
+ 2816,
+ 2817,
+ 2818,
+ 2819,
+ 2820,
+ 2821,
+ 2822,
+ 2823,
+ 2824,
+ 2825,
+ 2826,
+ 2827,
+ 2828,
+ 2829,
+ 2830,
+ 2831,
+ 2832,
+ 2833,
+ 2834,
+ 2835,
+ 2836,
+ 2837,
+ 2838,
+ 2839,
+ 2840,
+ 2841,
+ 2842,
+ 2843,
+ 2844,
+ 2845,
+ 2846,
+ 2847,
+ 2848,
+ 2849,
+ 2850,
+ 2851,
+ 2852,
+ 2853,
+ 2854,
+ 2855,
+ 2856,
+ 2857,
+ 2858,
+ 2859,
+ 2860,
+ 2861,
+ 2862,
+ 2863,
+ 2864,
+ 2865,
+ 2866,
+ 2867,
+ 2868,
+ 2869,
+ 2870,
+ 2871,
+ 2872,
+ 2873,
+ 2874,
+ 2875,
+ 2876,
+ 2877,
+ 2878,
+ 2879,
+ 2880,
+ 2881,
+ 2882,
+ 2883,
+ 2884,
+ 2885,
+ 2886,
+ 2887,
+ 2888,
+ 2889,
+ 2890,
+ 2891,
+ 2892,
+ 2893,
+ 2894,
+ 2895,
+ 2896,
+ 2897,
+ 2898,
+ 2899,
+ 2900,
+ 2901,
+ 2902,
+ 2903,
+ 2904,
+ 2905,
+ 2906,
+ 2907,
+ 2908,
+ 2909,
+ 2910,
+ 2911,
+ 2912,
+ 2913,
+ 2914,
+ 2915,
+ 2916,
+ 2917,
+ 2918,
+ 2919,
+ 2920,
+ 2921,
+ 2922,
+ 2923,
+ 2924,
+ 2925,
+ 2926,
+ 2927,
+ 2928,
+ 2929,
+ 2930,
+ 2931,
+ 2932,
+ 2933,
+ 2934,
+ 2935,
+ 2936,
+ 2937,
+ 2938,
+ 2939,
+ 2940,
+ 2941,
+ 2942,
+ 2943,
+ 2944,
+ 2945,
+ 2946,
+ 2947,
+ 2948,
+ 2949,
+ 2950,
+ 2951,
+ 2952,
+ 2953,
+ 2954,
+ 2955,
+ 2956,
+ 2957,
+ 2958,
+ 2959,
+ 2960,
+ 2961,
+ 2962,
+ 2963,
+ 2964,
+ 2965,
+ 2966,
+ 2967,
+ 2968,
+ 2969,
+ 2970,
+ 2971,
+ 2972,
+ 2973,
+ 2974,
+ 2975,
+ 2976,
+ 2977,
+ 2978,
+ 2979,
+ 2980,
+ 2981,
+ 2982,
+ 2983,
+ 2984,
+ 2985,
+ 2986,
+ 2987,
+ 2988,
+ 2989,
+ 2990,
+ 2991,
+ 2992,
+ 2993,
+ 2994,
+ 2995,
+ 2996,
+ 2997,
+ 2998,
+ 2999,
+ 3000,
+ 3001,
+ 3002,
+ 3003,
+ 3004,
+ 3005,
+ 3006,
+ 3007,
+ 3008,
+ 3009,
+ 3010,
+ 3011,
+ 3012,
+ 3013,
+ 3014,
+ 3015,
+ 3016,
+ 3017,
+ 3018,
+ 3019,
+ 3020,
+ 3021,
+ 3022,
+ 3023,
+ 3024,
+ 3025,
+ 3026,
+ 3027,
+ 3028,
+ 3029,
+ 3030,
+ 3031,
+ 3032,
+ 3033,
+ 3034,
+ 3035,
+ 3036,
+ 3037,
+ 3038,
+ 3039,
+ 3040,
+ 3041,
+ 3042,
+ 3043,
+ 3044,
+ 3045,
+ 3046,
+ 3047,
+ 3048,
+ 3049,
+ 3050,
+ 3051,
+ 3052,
+ 3053,
+ 3054,
+ 3055,
+ 3056,
+ 3057,
+ 3058,
+ 3059,
+ 3060,
+ 3061,
+ 3062,
+ 3063,
+ 3064,
+ 3065,
+ 3066,
+ 3067,
+ 3068,
+ 3069,
+ 3070,
+ 3071,
+ 3072,
+ 3073,
+ 3074,
+ 3075,
+ 3076,
+ 3077,
+ 3078,
+ 3079,
+ 3080,
+ 3081,
+ 3082,
+ 3083,
+ 3084,
+ 3085,
+ 3086,
+ 3087,
+ 3088,
+ 3089,
+ 3090,
+ 3091,
+ 3092,
+ 3093,
+ 3094,
+ 3095,
+ 3096,
+ 3097,
+ 3098,
+ 3099,
+ 3100,
+ 3101,
+ 3102,
+ 3103,
+ 3104,
+ 3105,
+ 3106,
+ 3107,
+ 3108,
+ 3109,
+ 3110,
+ 3111,
+ 3112,
+ 3113,
+ 3114,
+ 3115,
+ 3116,
+ 3117,
+ 3118,
+ 3119,
+ 3120,
+ 3121,
+ 3122,
+ 3123,
+ 3124,
+ 3125,
+ 3126,
+ 3127,
+ 3128,
+ 3129,
+ 3130,
+ 3131,
+ 3132,
+ 3133,
+ 3134,
+ 3135,
+ 3136,
+ 3137,
+ 3138,
+ 3139,
+ 3140,
+ 3141,
+ 3142,
+ 3143,
+ 3144,
+ 3145,
+ 3146,
+ 3147,
+ 3148,
+ 3149,
+ 3150,
+ 3151,
+ 3152,
+ 3153,
+ 3154,
+ 3155,
+ 3156,
+ 3157,
+ 3158,
+ 3159,
+ 3160,
+ 3161,
+ 3162,
+ 3163,
+ 3164,
+ 3165,
+ 3166,
+ 3167,
+ 3168,
+ 3169,
+ 3170,
+ 3171,
+ 3172,
+ 3173,
+ 3174,
+ 3175,
+ 3176,
+ 3177,
+ 3178,
+ 3179,
+ 3180,
+ 3181,
+ 3182,
+ 3183,
+ 3184,
+ 3185,
+ 3186,
+ 3187,
+ 3188,
+ 3189,
+ 3190,
+ 3191,
+ 3192,
+ 3193,
+ 3194,
+ 3195,
+ 3196,
+ 3197,
+ 3198,
+ 3199,
+ 3200,
+ 3201,
+ 3202,
+ 3203,
+ 3204,
+ 3205,
+ 3206,
+ 3207,
+ 3208,
+ 3209,
+ 3210,
+ 3211,
+ 3212,
+ 3213,
+ 3214,
+ 3215,
+ 3216,
+ 3217,
+ 3218,
+ 3219,
+ 3220,
+ 3221,
+ 3222,
+ 3223,
+ 3224,
+ 3225,
+ 3226,
+ 3227,
+ 3228,
+ 3229,
+ 3230,
+ 3231,
+ 3232,
+ 3233,
+ 3234,
+ 3235,
+ 3236,
+ 3237,
+ 3238,
+ 3239,
+ 3240,
+ 3241,
+ 3242,
+ 3243,
+ 3244,
+ 3245,
+ 3246,
+ 3247,
+ 3248,
+ 3249,
+ 3250,
+ 3251,
+ 3252,
+ 3253,
+ 3254,
+ 3255,
+ 3256,
+ 3257,
+ 3258,
+ 3259,
+ 3260,
+ 3261,
+ 3262,
+ 3263,
+ 3264,
+ 3265,
+ 3266,
+ 3267,
+ 3268,
+ 3269,
+ 3270,
+ 3271,
+ 3272,
+ 3273,
+ 3274,
+ 3275,
+ 3276,
+ 3277,
+ 3278,
+ 3279,
+ 3280,
+ 3281,
+ 3282,
+ 3283,
+ 3284,
+ 3285,
+ 3286,
+ 3287,
+ 3288,
+ 3289,
+ 3290,
+ 3291,
+ 3292,
+ 3293,
+ 3294,
+ 3295,
+ 3296,
+ 3297,
+ 3298,
+ 3299,
+ 3300,
+ 3301,
+ 3302,
+ 3303,
+ 3304,
+ 3305,
+ 3306,
+ 3307,
+ 3308,
+ 3309,
+ 3310,
+ 3311,
+ 3312,
+ 3313,
+ 3314,
+ 3315,
+ 3316,
+ 3317,
+ 3318,
+ 3319,
+ 3320,
+ 3321,
+ 3322,
+ 3323,
+ 3324,
+ 3325,
+ 3326,
+ 3327,
+ 3328,
+ 3329,
+ 3330,
+ 3331,
+ 3332,
+ 3333,
+ 3334,
+ 3335,
+ 3336,
+ 3337,
+ 3338,
+ 3339,
+ 3340,
+ 3341,
+ 3342,
+ 3343,
+ 3344,
+ 3345,
+ 3346,
+ 3347,
+ 3348,
+ 3349,
+ 3350,
+ 3351,
+ 3352,
+ 3353,
+ 3354,
+ 3355,
+ 3356,
+ 3357,
+ 3358,
+ 3359,
+ 3360,
+ 3361,
+ 3362,
+ 3363,
+ 3364,
+ 3365,
+ 3366,
+ 3367,
+ 3368,
+ 3369,
+ 3370,
+ 3371,
+ 3372,
+ 3373,
+ 3374,
+ 3375,
+ 3376,
+ 3377,
+ 3378,
+ 3379,
+ 3380,
+ 3381,
+ 3382,
+ 3383,
+ 3384,
+ 3385,
+ 3386,
+ 3387,
+ 3388,
+ 3389,
+ 3390,
+ 3391,
+ 3392,
+ 3393,
+ 3394,
+ 3395,
+ 3396,
+ 3397,
+ 3398,
+ 3399,
+ 3400,
+ 3401,
+ 3402,
+ 3403,
+ 3404,
+ 3405,
+ 3406,
+ 3407,
+ 3408,
+ 3409,
+ 3410,
+ 3411,
+ 3412,
+ 3413,
+ 3414,
+ 3415,
+ 3416,
+ 3417,
+ 3418,
+ 3419,
+ 3420,
+ 3421,
+ 3422,
+ 3423,
+ 3424,
+ 3425,
+ 3426,
+ 3427,
+ 3428,
+ 3429,
+ 3430,
+ 3431,
+ 3432,
+ 3433,
+ 3434,
+ 3435,
+ 3436,
+ 3437,
+ 3438,
+ 3439,
+ 3440,
+ 3441,
+ 3442,
+ 3443,
+ 3444,
+ 3445,
+ 3446,
+ 3447,
+ 3448,
+ 3449,
+ 3450,
+ 3451,
+ 3452,
+ 3453,
+ 3454,
+ 3455,
+ 3456,
+ 3457,
+ 3458,
+ 3459,
+ 3460,
+ 3461,
+ 3462,
+ 3463,
+ 3464,
+ 3465,
+ 3466,
+ 3467,
+ 3468,
+ 3469,
+ 3470,
+ 3471,
+ 3472,
+ 3473,
+ 3474,
+ 3475,
+ 3476,
+ 3477,
+ 3478,
+ 3479,
+ 3480,
+ 3481,
+ 3482,
+ 3483,
+ 3484,
+ 3485,
+ 3486,
+ 3487,
+ 3488,
+ 3489,
+ 3490,
+ 3491,
+ 3492,
+ 3493,
+ 3494,
+ 3495,
+ 3496,
+ 3497,
+ 3498,
+ 3499,
+ 3500,
+ 3501,
+ 3502,
+ 3503,
+ 3504,
+ 3505,
+ 3506,
+ 3507,
+ 3508,
+ 3509,
+ 3510,
+ 3511,
+ 3512,
+ 3513,
+ 3514,
+ 3515,
+ 3516,
+ 3517,
+ 3518,
+ 3519,
+ 3520,
+ 3521,
+ 3522,
+ 3523,
+ 3524,
+ 3525,
+ 3526,
+ 3527,
+ 3528,
+ 3529,
+ 3530,
+ 3531,
+ 3532,
+ 3533,
+ 3534,
+ 3535,
+ 3536,
+ 3537,
+ 3538,
+ 3539,
+ 3540,
+ 3541,
+ 3542,
+ 3543,
+ 3544,
+ 3545,
+ 3546,
+ 3547,
+ 3548,
+ 3549,
+ 3550,
+ 3551,
+ 3552,
+ 3553,
+ 3554,
+ 3555,
+ 3556,
+ 3557,
+ 3558,
+ 3559,
+ 3560,
+ 3561,
+ 3562,
+ 3563,
+ 3564,
+ 3565,
+ 3566,
+ 3567,
+ 3568,
+ 3569,
+ 3570,
+ 3571,
+ 3572,
+ 3573,
+ 3574,
+ 3575,
+ 3576,
+ 3577,
+ 3578,
+ 3579,
+ 3580,
+ 3581,
+ 3582,
+ 3583,
+ 3584,
+ 3585,
+ 3586,
+ 3587,
+ 3588,
+ 3589,
+ 3590,
+ 3591,
+ 3592,
+ 3593,
+ 3594,
+ 3595,
+ 3596,
+ 3597,
+ 3598,
+ 3599,
+ 3600,
+ 3601,
+ 3602,
+ 3603,
+ 3604,
+ 3605,
+ 3606,
+ 3607,
+ 3608,
+ 3609,
+ 3610,
+ 3611,
+ 3612,
+ 3613,
+ 3614,
+ 3615,
+ 3616,
+ 3617,
+ 3618,
+ 3619,
+ 3620,
+ 3621,
+ 3622,
+ 3623,
+ 3624,
+ 3625,
+ 3626,
+ 3627,
+ 3628,
+ 3629,
+ 3630,
+ 3631,
+ 3632,
+ 3633,
+ 3634,
+ 3635,
+ 3636,
+ 3637,
+ 3638,
+ 3639,
+ 3640,
+ 3641,
+ 3642,
+ 3643,
+ 3644,
+ 3645,
+ 3646,
+ 3647,
+ 3648,
+ 3649,
+ 3650,
+ 3651,
+ 3652,
+ 3653,
+ 3654,
+ 3655,
+ 3656,
+ 3657,
+ 3658,
+ 3659,
+ 3660,
+ 3661,
+ 3662,
+ 3663,
+ 3664,
+ 3665,
+ 3666,
+ 3667,
+ 3668,
+ 3669,
+ 3670,
+ 3671,
+ 3672,
+ 3673,
+ 3674,
+ 3675,
+ 3676,
+ 3677,
+ 3678,
+ 3679,
+ 3680,
+ 3681,
+ 3682,
+ 3683,
+ 3684,
+ 3685,
+ 3686,
+ 3687,
+ 3688,
+ 3689,
+ 3690,
+ 3691,
+ 3692,
+ 3693,
+ 3694,
+ 3695,
+ 3696,
+ 3697,
+ 3698,
+ 3699,
+ 3700,
+ 3701,
+ 3702,
+ 3703,
+ 3704,
+ 3705,
+ 3706,
+ 3707,
+ 3708,
+ 3709,
+ 3710,
+ 3711,
+ 3712,
+ 3713,
+ 3714,
+ 3715,
+ 3716,
+ 3717,
+ 3718,
+ 3719,
+ 3720,
+ 3721,
+ 3722,
+ 3723,
+ 3724,
+ 3725,
+ 3726,
+ 3727,
+ 3728,
+ 3729,
+ 3730,
+ 3731,
+ 3732,
+ 3733,
+ 3734,
+ 3735,
+ 3736,
+ 3737,
+ 3738,
+ 3739,
+ 3740,
+ 3741,
+ 3742,
+ 3743,
+ 3744,
+ 3745,
+ 3746,
+ 3747,
+ 3748,
+ 3749,
+ 3750,
+ 3751,
+ 3752,
+ 3753,
+ 3754,
+ 3755,
+ 3756,
+ 3757,
+ 3758,
+ 3759,
+ 3760,
+ 3761,
+ 3762,
+ 3763,
+ 3764,
+ 3765,
+ 3766,
+ 3767,
+ 3768,
+ 3769,
+ 3770,
+ 3771,
+ 3772,
+ 3773,
+ 3774,
+ 3775,
+ 3776,
+ 3777,
+ 3778,
+ 3779,
+ 3780,
+ 3781,
+ 3782,
+ 3783,
+ 3784,
+ 3785,
+ 3786,
+ 3787,
+ 3788,
+ 3789,
+ 3790,
+ 3791,
+ 3792,
+ 3793,
+ 3794,
+ 3795,
+ 3796,
+ 3797,
+ 3798,
+ 3799,
+ 3800,
+ 3801,
+ 3802,
+ 3803,
+ 3804,
+ 3805,
+ 3806,
+ 3807,
+ 3808,
+ 3809,
+ 3810,
+ 3811,
+ 3812,
+ 3813,
+ 3814,
+ 3815,
+ 3816,
+ 3817,
+ 3818,
+ 3819,
+ 3820,
+ 3821,
+ 3822,
+ 3823,
+ 3824,
+ 3825,
+ 3826,
+ 3827,
+ 3828,
+ 3829,
+ 3830,
+ 3831,
+ 3832,
+ 3833,
+ 3834,
+ 3835,
+ 3836,
+ 3837,
+ 3838,
+ 3839,
+ 3840,
+ 3841,
+ 3842,
+ 3843,
+ 3844,
+ 3845,
+ 3846,
+ 3847,
+ 3848,
+ 3849,
+ 3850,
+ 3851,
+ 3852,
+ 3853,
+ 3854,
+ 3855,
+ 3856,
+ 3857,
+ 3858,
+ 3859,
+ 3860,
+ 3861,
+ 3862,
+ 3863,
+ 3864,
+ 3865,
+ 3866,
+ 3867,
+ 3868,
+ 3869,
+ 3870,
+ 3871,
+ 3872,
+ 3873,
+ 3874,
+ 3875,
+ 3876,
+ 3877,
+ 3878,
+ 3879,
+ 3880,
+ 3881,
+ 3882,
+ 3883,
+ 3884,
+ 3885,
+ 3886,
+ 3887,
+ 3888,
+ 3889,
+ 3890,
+ 3891,
+ 3892,
+ 3893,
+ 3894,
+ 3895,
+ 3896,
+ 3897,
+ 3898,
+ 3899,
+ 3900,
+ 3901,
+ 3902,
+ 3903,
+ 3904,
+ 3905,
+ 3906,
+ 3907,
+ 3908,
+ 3909,
+ 3910,
+ 3911,
+ 3912,
+ 3913,
+ 3914,
+ 3915,
+ 3916,
+ 3917,
+ 3918,
+ 3919,
+ 3920,
+ 3921,
+ 3922,
+ 3923,
+ 3924,
+ 3925,
+ 3926,
+ 3927,
+ 3928,
+ 3929,
+ 3930,
+ 3931,
+ 3932,
+ 3933,
+ 3934,
+ 3935,
+ 3936,
+ 3937,
+ 3938,
+ 3939,
+ 3940,
+ 3941,
+ 3942,
+ 3943,
+ 3944,
+ 3945,
+ 3946,
+ 3947,
+ 3948,
+ 3949,
+ 3950,
+ 3951,
+ 3952,
+ 3953,
+ 3954,
+ 3955,
+ 3956,
+ 3957,
+ 3958,
+ 3959,
+ 3960,
+ 3961,
+ 3962,
+ 3963,
+ 3964,
+ 3965,
+ 3966,
+ 3967,
+ 3968,
+ 3969,
+ 3970,
+ 3971,
+ 3972,
+ 3973,
+ 3974,
+ 3975,
+ 3976,
+ 3977,
+ 3978,
+ 3979,
+ 3980,
+ 3981,
+ 3982,
+ 3983,
+ 3984,
+ 3985,
+ 3986,
+ 3987,
+ 3988,
+ 3989,
+ 3990,
+ 3991,
+ 3992,
+ 3993,
+ 3994,
+ 3995,
+ 3996,
+ 3997,
+ 3998,
+ 3999,
+ 4000,
+ 4001,
+ 4002,
+ 4003,
+ 4004,
+ 4005,
+ 4006,
+ 4007,
+ 4008,
+ 4009,
+ 4010,
+ 4011,
+ 4012,
+ 4013,
+ 4014,
+ 4015,
+ 4016,
+ 4017,
+ 4018,
+ 4019,
+ 4020,
+ 4021,
+ 4022,
+ 4023,
+ 4024,
+ 4025,
+ 4026,
+ 4027,
+ 4028,
+ 4029,
+ 4030,
+ 4031,
+ 4032,
+ 4033,
+ 4034,
+ 4035,
+ 4036,
+ 4037,
+ 4038,
+ 4039,
+ 4040,
+ 4041,
+ 4042,
+ 4043,
+ 4044,
+ 4045,
+ 4046,
+ 4047,
+ 4048,
+ 4049,
+ 4050,
+ 4051,
+ 4052,
+ 4053,
+ 4054,
+ 4055,
+ 4056,
+ 4057,
+ 4058,
+ 4059,
+ 4060,
+ 4061,
+ 4062,
+ 4063,
+ 4064,
+ 4065,
+ 4066,
+ 4067,
+ 4068,
+ 4069,
+ 4070,
+ 4071,
+ 4072,
+ 4073,
+ 4074,
+ 4075,
+ 4076,
+ 4077,
+ 4078,
+ 4079,
+ 4080,
+ 4081,
+ 4082,
+ 4083,
+ 4084,
+ 4085,
+ 4086,
+ 4087,
+ 4088,
+ 4089,
+ 4090,
+ 4091,
+ 4092,
+ 4093,
+ 4094,
+ 4095,
+ 4096,
+ 4097,
+ 4098,
+ 4099,
+ 4100,
+ 4101,
+ 4102,
+ 4103,
+ 4104,
+ 4105,
+ 4106,
+ 4107,
+ 4108,
+ 4109,
+ 4110,
+ 4111,
+ 4112,
+ 4113,
+ 4114,
+ 4115,
+ 4116,
+ 4117,
+ 4118,
+ 4119,
+ 4120,
+ 4121,
+ 4122,
+ 4123,
+ 4124,
+ 4125,
+ 4126,
+ 4127,
+ 4128,
+ 4129,
+ 4130,
+ 4131,
+ 4132,
+ 4133,
+ 4134,
+ 4135,
+ 4136,
+ 4137,
+ 4138,
+ 4139,
+ 4140,
+ 4141,
+ 4142,
+ 4143,
+ 4144,
+ 4145,
+ 4146,
+ 4147,
+ 4148,
+ 4149,
+ 4150,
+ 4151,
+ 4152,
+ 4153,
+ 4154,
+ 4155,
+ 4156,
+ 4157,
+ 4158,
+ 4159,
+ 4160,
+ 4161,
+ 4162,
+ 4163,
+ 4164,
+ 4165,
+ 4166,
+ 4167,
+ 4168,
+ 4169,
+ 4170,
+ 4171,
+ 4172,
+ 4173,
+ 4174,
+ 4175,
+ 4176,
+ 4177,
+ 4178,
+ 4179,
+ 4180,
+ 4181,
+ 4182,
+ 4183,
+ 4184,
+ 4185,
+ 4186,
+ 4187,
+ 4188,
+ 4189,
+ 4190,
+ 4191,
+ 4192,
+ 4193,
+ 4194,
+ 4195,
+ 4196,
+ 4197,
+ 4198,
+ 4199,
+ 4200,
+ 4201,
+ 4202,
+ 4203,
+ 4204,
+ 4205,
+ 4206,
+ 4207,
+ 4208,
+ 4209,
+ 4210,
+ 4211,
+ 4212,
+ 4213,
+ 4214,
+ 4215,
+ 4216,
+ 4217,
+ 4218,
+ 4219,
+ 4220,
+ 4221,
+ 4222,
+ 4223,
+ 4224,
+ 4225,
+ 4226,
+ 4227,
+ 4228,
+ 4229,
+ 4230,
+ 4231,
+ 4232,
+ 4233,
+ 4234,
+ 4235,
+ 4236,
+ 4237,
+ 4238,
+ 4239,
+ 4240,
+ 4241,
+ 4242,
+ 4243,
+ 4244,
+ 4245,
+ 4246,
+ 4247,
+ 4248,
+ 4249,
+ 4250,
+ 4251,
+ 4252,
+ 4253,
+ 4254,
+ 4255,
+ 4256,
+ 4257,
+ 4258,
+ 4259,
+ 4260,
+ 4261,
+ 4262,
+ 4263,
+ 4264,
+ 4265,
+ 4266,
+ 4267,
+ 4268,
+ 4269,
+ 4270,
+ 4271,
+ 4272,
+ 4273,
+ 4274,
+ 4275,
+ 4276,
+ 4277,
+ 4278,
+ 4279,
+ 4280,
+ 4281,
+ 4282,
+ 4283,
+ 4284,
+ 4285,
+ 4286,
+ 4287,
+ 4288,
+ 4289,
+ 4290,
+ 4291,
+ 4292,
+ 4293,
+ 4294,
+ 4295,
+ 4296,
+ 4297,
+ 4298,
+ 4299,
+ 4300,
+ 4301,
+ 4302,
+ 4303,
+ 4304,
+ 4305,
+ 4306,
+ 4307,
+ 4308,
+ 4309,
+ 4310,
+ 4311,
+ 4312,
+ 4313,
+ 4314,
+ 4315,
+ 4316,
+ 4317,
+ 4318,
+ 4319,
+ 4320,
+ 4321,
+ 4322,
+ 4323,
+ 4324,
+ 4325,
+ 4326,
+ 4327,
+ 4328,
+ 4329,
+ 4330,
+ 4331,
+ 4332,
+ 4333,
+ 4334,
+ 4335,
+ 4336,
+ 4337,
+ 4338,
+ 4339,
+ 4340,
+ 4341,
+ 4342,
+ 4343,
+ 4344,
+ 4345,
+ 4346,
+ 4347,
+ 4348,
+ 4349,
+ 4350,
+ 4351,
+ 4352,
+ 4353,
+ 4354,
+ 4355,
+ 4356,
+ 4357,
+ 4358,
+ 4359,
+ 4360,
+ 4361,
+ 4362,
+ 4363,
+ 4364,
+ 4365,
+ 4366,
+ 4367,
+ 4368,
+ 4369,
+ 4370,
+ 4371,
+ 4372,
+ 4373,
+ 4374,
+ 4375,
+ 4376,
+ 4377,
+ 4378,
+ 4379,
+ 4380,
+ 4381,
+ 4382,
+ 4383,
+ 4384,
+ 4385,
+ 4386,
+ 4387,
+ 4388,
+ 4389,
+ 4390,
+ 4391,
+ 4392,
+ 4393,
+ 4394,
+ 4395,
+ 4396,
+ 4397,
+ 4398,
+ 4399,
+ 4400,
+ 4401,
+ 4402,
+ 4403,
+ 4404,
+ 4405,
+ 4406,
+ 4407,
+ 4408,
+ 4409,
+ 4410,
+ 4411,
+ 4412,
+ 4413,
+ 4414,
+ 4415,
+ 4416,
+ 4417,
+ 4418,
+ 4419,
+ 4420,
+ 4421,
+ 4422,
+ 4423,
+ 4424,
+ 4425,
+ 4426,
+ 4427,
+ 4428,
+ 4429,
+ 4430,
+ 4431,
+ 4432,
+ 4433,
+ 4434,
+ 4435,
+ 4436,
+ 4437,
+ 4438,
+ 4439,
+ 4440,
+ 4441,
+ 4442,
+ 4443,
+ 4444,
+ 4445,
+ 4446,
+ 4447,
+ 4448,
+ 4449,
+ 4450,
+ 4451,
+ 4452,
+ 4453,
+ 4454,
+ 4455,
+ 4456,
+ 4457,
+ 4458,
+ 4459,
+ 4460,
+ 4461,
+ 4462,
+ 4463,
+ 4464,
+ 4465,
+ 4466,
+ 4467,
+ 4468,
+ 4469,
+ 4470,
+ 4471,
+ 4472,
+ 4473,
+ 4474,
+ 4475,
+ 4476,
+ 4477,
+ 4478,
+ 4479,
+ 4480,
+ 4481,
+ 4482,
+ 4483,
+ 4484,
+ 4485,
+ 4486,
+ 4487,
+ 4488,
+ 4489,
+ 4490,
+ 4491,
+ 4492,
+ 4493,
+ 4494,
+ 4495,
+ 4496,
+ 4497,
+ 4498,
+ 4499,
+ 4500,
+ 4501,
+ 4502,
+ 4503,
+ 4504,
+ 4505,
+ 4506,
+ 4507,
+ 4508,
+ 4509,
+ 4510,
+ 4511,
+ 4512,
+ 4513,
+ 4514,
+ 4515,
+ 4516,
+ 4517,
+ 4518,
+ 4519,
+ 4520,
+ 4521,
+ 4522,
+ 4523,
+ 4524,
+ 4525,
+ 4526,
+ 4527,
+ 4528,
+ 4529,
+ 4530,
+ 4531,
+ 4532,
+ 4533,
+ 4534,
+ 4535,
+ 4536,
+ 4537,
+ 4538,
+ 4539,
+ 4540,
+ 4541,
+ 4542,
+ 4543,
+ 4544,
+ 4545,
+ 4546,
+ 4547,
+ 4548,
+ 4549,
+ 4550,
+ 4551,
+ 4552,
+ 4553,
+ 4554,
+ 4555,
+ 4556,
+ 4557,
+ 4558,
+ 4559,
+ 4560,
+ 4561,
+ 4562,
+ 4563,
+ 4564,
+ 4565,
+ 4566,
+ 4567,
+ 4568,
+ 4569,
+ 4570,
+ 4571,
+ 4572,
+ 4573,
+ 4574,
+ 4575,
+ 4576,
+ 4577,
+ 4578,
+ 4579,
+ 4580,
+ 4581,
+ 4582,
+ 4583,
+ 4584,
+ 4585,
+ 4586,
+ 4587,
+ 4588,
+ 4589,
+ 4590,
+ 4591,
+ 4592,
+ 4593,
+ 4594,
+ 4595,
+ 4596,
+ 4597,
+ 4598,
+ 4599,
+ 4600,
+ 4601,
+ 4602,
+ 4603,
+ 4604,
+ 4605,
+ 4606,
+ 4607,
+ 4608,
+ 4609,
+ 4610,
+ 4611,
+ 4612,
+ 4613,
+ 4614,
+ 4615,
+ 4616,
+ 4617,
+ 4618,
+ 4619,
+ 4620,
+ 4621,
+ 4622,
+ 4623,
+ 4624,
+ 4625,
+ 4626,
+ 4627,
+ 4628,
+ 4629,
+ 4630,
+ 4631,
+ 4632,
+ 4633,
+ 4634,
+ 4635,
+ 4636,
+ 4637,
+ 4638,
+ 4639,
+ 4640,
+ 4641,
+ 4642,
+ 4643,
+ 4644,
+ 4645,
+ 4646,
+ 4647,
+ 4648,
+ 4649,
+ 4650,
+ 4651,
+ 4652,
+ 4653,
+ 4654,
+ 4655,
+ 4656,
+ 4657,
+ 4658,
+ 4659,
+ 4660,
+ 4661,
+ 4662,
+ 4663,
+ 4664,
+ 4665,
+ 4666,
+ 4667,
+ 4668,
+ 4669,
+ 4670,
+ 4671,
+ 4672,
+ 4673,
+ 4674,
+ 4675,
+ 4676,
+ 4677,
+ 4678,
+ 4679,
+ 4680,
+ 4681,
+ 4682,
+ 4683,
+ 4684,
+ 4685,
+ 4686,
+ 4687,
+ 4688,
+ 4689,
+ 4690,
+ 4691,
+ 4692,
+ 4693,
+ 4694,
+ 4695,
+ 4696,
+ 4697,
+ 4698,
+ 4699,
+ 4700,
+ 4701,
+ 4702,
+ 4703,
+ 4704,
+ 4705,
+ 4706,
+ 4707,
+ 4708,
+ 4709,
+ 4710,
+ 4711,
+ 4712,
+ 4713,
+ 4714,
+ 4715,
+ 4716,
+ 4717,
+ 4718,
+ 4719,
+ 4720,
+ 4721,
+ 4722,
+ 4723,
+ 4724,
+ 4725,
+ 4726,
+ 4727,
+ 4728,
+ 4729,
+ 4730,
+ 4731,
+ 4732,
+ 4733,
+ 4734,
+ 4735,
+ 4736,
+ 4737,
+ 4738,
+ 4739,
+ 4740,
+ 4741,
+ 4742,
+ 4743,
+ 4744,
+ 4745,
+ 4746,
+ 4747,
+ 4748,
+ 4749,
+ 4750,
+ 4751,
+ 4752,
+ 4753,
+ 4754,
+ 4755,
+ 4756,
+ 4757,
+ 4758,
+ 4759,
+ 4760,
+ 4761,
+ 4762,
+ 4763,
+ 4764,
+ 4765,
+ 4766,
+ 4767,
+ 4768,
+ 4769,
+ 4770,
+ 4771,
+ 4772,
+ 4773,
+ 4774,
+ 4775,
+ 4776,
+ 4777,
+ 4778,
+ 4779,
+ 4780,
+ 4781,
+ 4782,
+ 4783,
+ 4784,
+ 4785,
+ 4786,
+ 4787,
+ 4788,
+ 4789,
+ 4790,
+ 4791,
+ 4792,
+ 4793,
+ 4794,
+ 4795,
+ 4796,
+ 4797,
+ 4798,
+ 4799,
+ 4800,
+ 4801,
+ 4802,
+ 4803,
+ 4804,
+ 4805,
+ 4806,
+ 4807,
+ 4808,
+ 4809,
+ 4810,
+ 4811,
+ 4812,
+ 4813,
+ 4814,
+ 4815,
+ 4816,
+ 4817,
+ 4818,
+ 4819,
+ 4820,
+ 4821,
+ 4822,
+ 4823,
+ 4824,
+ 4825,
+ 4826,
+ 4827,
+ 4828,
+ 4829,
+ 4830,
+ 4831,
+ 4832,
+ 4833,
+ 4834,
+ 4835,
+ 4836,
+ 4837,
+ 4838,
+ 4839,
+ 4840,
+ 4841,
+ 4842,
+ 4843,
+ 4844,
+ 4845,
+ 4846,
+ 4847,
+ 4848,
+ 4849,
+ 4850,
+ 4851,
+ 4852,
+ 4853,
+ 4854,
+ 4855,
+ 4856,
+ 4857,
+ 4858,
+ 4859,
+ 4860,
+ 4861,
+ 4862,
+ 4863,
+ 4864,
+ 4865,
+ 4866,
+ 4867,
+ 4868,
+ 4869,
+ 4870,
+ 4871,
+ 4872,
+ 4873,
+ 4874,
+ 4875,
+ 4876,
+ 4877,
+ 4878,
+ 4879,
+ 4880,
+ 4881,
+ 4882,
+ 4883,
+ 4884,
+ 4885,
+ 4886,
+ 4887,
+ 4888,
+ 4889,
+ 4890,
+ 4891,
+ 4892,
+ 4893,
+ 4894,
+ 4895,
+ 4896,
+ 4897,
+ 4898,
+ 4899,
+ 4900,
+ 4901,
+ 4902,
+ 4903,
+ 4904,
+ 4905,
+ 4906,
+ 4907,
+ 4908,
+ 4909,
+ 4910,
+ 4911,
+ 4912,
+ 4913,
+ 4914,
+ 4915,
+ 4916,
+ 4917,
+ 4918,
+ 4919,
+ 4920,
+ 4921,
+ 4922,
+ 4923,
+ 4924,
+ 4925,
+ 4926,
+ 4927,
+ 4928,
+ 4929,
+ 4930,
+ 4931,
+ 4932,
+ 4933,
+ 4934,
+ 4935,
+ 4936,
+ 4937,
+ 4938,
+ 4939,
+ 4940,
+ 4941,
+ 4942,
+ 4943,
+ 4944,
+ 4945,
+ 4946,
+ 4947,
+ 4948,
+ 4949,
+ 4950,
+ 4951,
+ 4952,
+ 4953,
+ 4954,
+ 4955,
+ 4956,
+ 4957,
+ 4958,
+ 4959,
+ 4960,
+ 4961,
+ 4962,
+ 4963,
+ 4964,
+ 4965,
+ 4966,
+ 4967,
+ 4968,
+ 4969,
+ 4970,
+ 4971,
+ 4972,
+ 4973,
+ 4974,
+ 4975,
+ 4976,
+ 4977,
+ 4978,
+ 4979,
+ 4980,
+ 4981,
+ 4982,
+ 4983,
+ 4984,
+ 4985,
+ 4986,
+ 4987,
+ 4988,
+ 4989,
+ 4990,
+ 4991,
+ 4992,
+ 4993,
+ 4994,
+ 4995,
+ 4996,
+ 4997,
+ 4998,
+ 4999,
+ 5000,
+ 5001,
+ 5002,
+ 5003,
+ 5004,
+ 5005,
+ 5006,
+ 5007,
+ 5008,
+ 5009,
+ 5010,
+ 5011,
+ 5012,
+ 5013,
+ 5014,
+ 5015,
+ 5016,
+ 5017,
+ 5018,
+ 5019,
+ 5020,
+ 5021,
+ 5022,
+ 5023,
+ 5024,
+ 5025,
+ 5026,
+ 5027,
+ 5028,
+ 5029,
+ 5030,
+ 5031,
+ 5032,
+ 5033,
+ 5034,
+ 5035,
+ 5036,
+ 5037,
+ 5038,
+ 5039,
+ 5040,
+ 5041,
+ 5042,
+ 5043,
+ 5044,
+ 5045,
+ 5046,
+ 5047,
+ 5048,
+ 5049,
+ 5050,
+ 5051,
+ 5052,
+ 5053,
+ 5054,
+ 5055,
+ 5056,
+ 5057,
+ 5058,
+ 5059,
+ 5060,
+ 5061,
+ 5062,
+ 5063,
+ 5064,
+ 5065,
+ 5066,
+ 5067,
+ 5068,
+ 5069,
+ 5070,
+ 5071,
+ 5072,
+ 5073,
+ 5074,
+ 5075,
+ 5076,
+ 5077,
+ 5078,
+ 5079,
+ 5080,
+ 5081,
+ 5082,
+ 5083,
+ 5084,
+ 5085,
+ 5086,
+ 5087,
+ 5088,
+ 5089,
+ 5090,
+ 5091,
+ 5092,
+ 5093,
+ 5094,
+ 5095,
+ 5096,
+ 5097,
+ 5098,
+ 5099,
+ 5100,
+ 5101,
+ 5102,
+ 5103,
+ 5104,
+ 5105,
+ 5106,
+ 5107,
+ 5108,
+ 5109,
+ 5110,
+ 5111,
+ 5112,
+ 5113,
+ 5114,
+ 5115,
+ 5116,
+ 5117,
+ 5118,
+ 5119,
+ 5120,
+ 5121,
+ 5122,
+ 5123,
+ 5124,
+ 5125,
+ 5126,
+ 5127,
+ 5128,
+ 5129,
+ 5130,
+ 5131,
+ 5132,
+ 5133,
+ 5134,
+ 5135,
+ 5136,
+ 5137,
+ 5138,
+ 5139,
+ 5140,
+ 5141,
+ 5142,
+ 5143,
+ 5144,
+ 5145,
+ 5146,
+ 5147,
+ 5148,
+ 5149,
+ 5150,
+ 5151,
+ 5152,
+ 5153,
+ 5154,
+ 5155,
+ 5156,
+ 5157,
+ 5158,
+ 5159,
+ 5160,
+ 5161,
+ 5162,
+ 5163,
+ 5164,
+ 5165,
+ 5166,
+ 5167,
+ 5168,
+ 5169,
+ 5170,
+ 5171,
+ 5172,
+ 5173,
+ 5174,
+ 5175,
+ 5176,
+ 5177,
+ 5178,
+ 5179,
+ 5180,
+ 5181,
+ 5182,
+ 5183,
+ 5184,
+ 5185,
+ 5186,
+ 5187,
+ 5188,
+ 5189,
+ 5190,
+ 5191,
+ 5192,
+ 5193,
+ 5194,
+ 5195,
+ 5196,
+ 5197,
+ 5198,
+ 5199,
+ 5200,
+ 5201,
+ 5202,
+ 5203,
+ 5204,
+ 5205,
+ 5206,
+ 5207,
+ 5208,
+ 5209,
+ 5210,
+ 5211,
+ 5212,
+ 5213,
+ 5214,
+ 5215,
+ 5216,
+ 5217,
+ 5218,
+ 5219,
+ 5220,
+ 5221,
+ 5222,
+ 5223,
+ 5224,
+ 5225,
+ 5226,
+ 5227,
+ 5228,
+ 5229,
+ 5230,
+ 5231,
+ 5232,
+ 5233,
+ 5234,
+ 5235,
+ 5236,
+ 5237,
+ 5238,
+ 5239,
+ 5240,
+ 5241,
+ 5242,
+ 5243,
+ 5244,
+ 5245,
+ 5246,
+ 5247,
+ 5248,
+ 5249,
+ 5250,
+ 5251,
+ 5252,
+ 5253,
+ 5254,
+ 5255,
+ 5256,
+ 5257,
+ 5258,
+ 5259,
+ 5260,
+ 5261,
+ 5262,
+ 5263,
+ 5264,
+ 5265,
+ 5266,
+ 5267,
+ 5268,
+ 5269,
+ 5270,
+ 5271,
+ 5272,
+ 5273,
+ 5274,
+ 5275,
+ 5276,
+ 5277,
+ 5278,
+ 5279,
+ 5280,
+ 5281,
+ 5282,
+ 5283,
+ 5284,
+ 5285,
+ 5286,
+ 5287,
+ 5288,
+ 5289,
+ 5290,
+ 5291,
+ 5292,
+ 5293,
+ 5294,
+ 5295,
+ 5296,
+ 5297,
+ 5298,
+ 5299,
+ 5300,
+ 5301,
+ 5302,
+ 5303,
+ 5304,
+ 5305,
+ 5306,
+ 5307,
+ 5308,
+ 5309,
+ 5310,
+ 5311,
+ 5312,
+ 5313,
+ 5314,
+ 5315,
+ 5316,
+ 5317,
+ 5318,
+ 5319,
+ 5320,
+ 5321,
+ 5322,
+ 5323,
+ 5324,
+ 5325,
+ 5326,
+ 5327,
+ 5328,
+ 5329,
+ 5330,
+ 5331,
+ 5332,
+ 5333,
+ 5334,
+ 5335,
+ 5336,
+ 5337,
+ 5338,
+ 5339,
+ 5340,
+ 5341,
+ 5342,
+ 5343,
+ 5344,
+ 5345,
+ 5346,
+ 5347,
+ 5348,
+ 5349,
+ 5350,
+ 5351,
+ 5352,
+ 5353,
+ 5354,
+ 5355,
+ 5356,
+ 5357,
+ 5358,
+ 5359,
+ 5360,
+ 5361,
+ 5362,
+ 5363,
+ 5364,
+ 5365,
+ 5366,
+ 5367,
+ 5368,
+ 5369,
+ 5370,
+ 5371,
+ 5372,
+ 5373,
+ 5374,
+ 5375,
+ 5376,
+ 5377,
+ 5378,
+ 5379,
+ 5380,
+ 5381,
+ 5382,
+ 5383,
+ 5384,
+ 5385,
+ 5386,
+ 5387,
+ 5388,
+ 5389,
+ 5390,
+ 5391,
+ 5392,
+ 5393,
+ 5394,
+ 5395,
+ 5396,
+ 5397,
+ 5398,
+ 5399,
+ 5400,
+ 5401,
+ 5402,
+ 5403,
+ 5404,
+ 5405,
+ 5406,
+ 5407,
+ 5408,
+ 5409,
+ 5410,
+ 5411,
+ 5412,
+ 5413,
+ 5414,
+ 5415,
+ 5416,
+ 5417,
+ 5418,
+ 5419,
+ 5420,
+ 5421,
+ 5422,
+ 5423,
+ 5424,
+ 5425,
+ 5426,
+ 5427,
+ 5428,
+ 5429,
+ 5430,
+ 5431,
+ 5432,
+ 5433,
+ 5434,
+ 5435,
+ 5436,
+ 5437,
+ 5438,
+ 5439,
+ 5440,
+ 5441,
+ 5442,
+ 5443,
+ 5444,
+ 5445,
+ 5446,
+ 5447,
+ 5448,
+ 5449,
+ 5450,
+ 5451,
+ 5452,
+ 5453,
+ 5454,
+ 5455,
+ 5456,
+ 5457,
+ 5458,
+ 5459,
+ 5460,
+ 5461,
+ 5462,
+ 5463,
+ 5464,
+ 5465,
+ 5466,
+ 5467,
+ 5468,
+ 5469,
+ 5470,
+ 5471,
+ 5472,
+ 5473,
+ 5474,
+ 5475,
+ 5476,
+ 5477,
+ 5478,
+ 5479,
+ 5480,
+ 5481,
+ 5482,
+ 5483,
+ 5484,
+ 5485,
+ 5486,
+ 5487,
+ 5488,
+ 5489,
+ 5490,
+ 5491,
+ 5492,
+ 5493,
+ 5494,
+ 5495,
+ 5496,
+ 5497,
+ 5498,
+ 5499,
+ 5500,
+ 5501,
+ 5502,
+ 5503,
+ 5504,
+ 5505,
+ 5506,
+ 5507,
+ 5508,
+ 5509,
+ 5510,
+ 5511,
+ 5512,
+ 5513,
+ 5514,
+ 5515,
+ 5516,
+ 5517,
+ 5518,
+ 5519,
+ 5520,
+ 5521,
+ 5522,
+ 5523,
+ 5524,
+ 5525,
+ 5526,
+ 5527,
+ 5528,
+ 5529,
+ 5530,
+ 5531,
+ 5532,
+ 5533,
+ 5534,
+ 5535,
+ 5536,
+ 5537,
+ 5538,
+ 5539,
+ 5540,
+ 5541,
+ 5542,
+ 5543,
+ 5544,
+ 5545,
+ 5546,
+ 5547,
+ 5548,
+ 5549,
+ 5550,
+ 5551,
+ 5552,
+ 5553,
+ 5554,
+ 5555,
+ 5556,
+ 5557,
+ 5558,
+ 5559,
+ 5560,
+ 5561,
+ 5562,
+ 5563,
+ 5564,
+ 5565,
+ 5566,
+ 5567,
+ 5568,
+ 5569,
+ 5570,
+ 5571,
+ 5572,
+ 5573,
+ 5574,
+ 5575,
+ 5576,
+ 5577,
+ 5578,
+ 5579,
+ 5580,
+ 5581,
+ 5582,
+ 5583,
+ 5584,
+ 5585,
+ 5586,
+ 5587,
+ 5588,
+ 5589,
+ 5590,
+ 5591,
+ 5592,
+ 5593,
+ 5594,
+ 5595,
+ 5596,
+ 5597,
+ 5598,
+ 5599,
+ 5600,
+ 5601,
+ 5602,
+ 5603,
+ 5604,
+ 5605,
+ 5606,
+ 5607,
+ 5608,
+ 5609,
+ 5610,
+ 5611,
+ 5612,
+ 5613,
+ 5614,
+ 5615,
+ 5616,
+ 5617,
+ 5618,
+ 5619,
+ 5620,
+ 5621,
+ 5622,
+ 5623,
+ 5624,
+ 5625,
+ 5626,
+ 5627,
+ 5628,
+ 5629,
+ 5630,
+ 5631,
+ 5632,
+ 5633,
+ 5634,
+ 5635,
+ 5636,
+ 5637,
+ 5638,
+ 5639,
+ 5640,
+ 5641,
+ 5642,
+ 5643,
+ 5644,
+ 5645,
+ 5646,
+ 5647,
+ 5648,
+ 5649,
+ 5650,
+ 5651,
+ 5652,
+ 5653,
+ 5654,
+ 5655,
+ 5656,
+ 5657,
+ 5658,
+ 5659,
+ 5660,
+ 5661,
+ 5662,
+ 5663,
+ 5664,
+ 5665,
+ 5666,
+ 5667,
+ 5668,
+ 5669,
+ 5670,
+ 5671,
+ 5672,
+ 5673,
+ 5674,
+ 5675,
+ 5676,
+ 5677,
+ 5678,
+ 5679,
+ 5680,
+ 5681,
+ 5682,
+ 5683,
+ 5684,
+ 5685,
+ 5686,
+ 5687,
+ 5688,
+ 5689,
+ 5690,
+ 5691,
+ 5692,
+ 5693,
+ 5694,
+ 5695,
+ 5696,
+ 5697,
+ 5698,
+ 5699,
+ 5700,
+ 5701,
+ 5702,
+ 5703,
+ 5704,
+ 5705,
+ 5706,
+ 5707,
+ 5708,
+ 5709,
+ 5710,
+ 5711,
+ 5712,
+ 5713,
+ 5714,
+ 5715,
+ 5716,
+ 5717,
+ 5718,
+ 5719,
+ 5720,
+ 5721,
+ 5722,
+ 5723,
+ 5724,
+ 5725,
+ 5726,
+ 5727,
+ 5728,
+ 5729,
+ 5730,
+ 5731,
+ 5732,
+ 5733,
+ 5734,
+ 5735,
+ 5736,
+ 5737,
+ 5738,
+ 5739,
+ 5740,
+ 5741,
+ 5742,
+ 5743,
+ 5744,
+ 5745,
+ 5746,
+ 5747,
+ 5748,
+ 5749,
+ 5750,
+ 5751,
+ 5752,
+ 5753,
+ 5754,
+ 5755,
+ 5756,
+ 5757,
+ 5758,
+ 5759,
+ 5760,
+ 5761,
+ 5762,
+ 5763,
+ 5764,
+ 5765,
+ 5766,
+ 5767,
+ 5768,
+ 5769,
+ 5770,
+ 5771,
+ 5772,
+ 5773,
+ 5774,
+ 5775,
+ 5776,
+ 5777,
+ 5778,
+ 5779,
+ 5780,
+ 5781,
+ 5782,
+ 5783,
+ 5784,
+ 5785,
+ 5786,
+ 5787,
+ 5788,
+ 5789,
+ 5790,
+ 5791,
+ 5792,
+ 5793,
+ 5794,
+ 5795,
+ 5796,
+ 5797,
+ 5798,
+ 5799,
+ 5800,
+ 5801,
+ 5802,
+ 5803,
+ 5804,
+ 5805,
+ 5806,
+ 5807,
+ 5808,
+ 5809,
+ 5810,
+ 5811,
+ 5812,
+ 5813,
+ 5814,
+ 5815,
+ 5816,
+ 5817,
+ 5818,
+ 5819,
+ 5820,
+ 5821,
+ 5822,
+ 5823,
+ 5824,
+ 5825,
+ 5826,
+ 5827,
+ 5828,
+ 5829,
+ 5830,
+ 5831,
+ 5832,
+ 5833,
+ 5834,
+ 5835,
+ 5836,
+ 5837,
+ 5838,
+ 5839,
+ 5840,
+ 5841,
+ 5842,
+ 5843,
+ 5844,
+ 5845,
+ 5846,
+ 5847,
+ 5848,
+ 5849,
+ 5850,
+ 5851,
+ 5852,
+ 5853,
+ 5854,
+ 5855,
+ 5856,
+ 5857,
+ 5858,
+ 5859,
+ 5860,
+ 5861,
+ 5862,
+ 5863,
+ 5864,
+ 5865,
+ 5866,
+ 5867,
+ 5868,
+ 5869,
+ 5870,
+ 5871,
+ 5872,
+ 5873,
+ 5874,
+ 5875,
+ 5876,
+ 5877,
+ 5878,
+ 5879,
+ 5880,
+ 5881,
+ 5882,
+ 5883,
+ 5884,
+ 5885,
+ 5886,
+ 5887,
+ 5888,
+ 5889,
+ 5890,
+ 5891,
+ 5892,
+ 5893,
+ 5894,
+ 5895,
+ 5896,
+ 5897,
+ 5898,
+ 5899,
+ 5900,
+ 5901,
+ 5902,
+ 5903,
+ 5904,
+ 5905,
+ 5906,
+ 5907,
+ 5908,
+ 5909,
+ 5910,
+ 5911,
+ 5912,
+ 5913,
+ 5914,
+ 5915,
+ 5916,
+ 5917,
+ 5918,
+ 5919,
+ 5920,
+ 5921,
+ 5922,
+ 5923,
+ 5924,
+ 5925,
+ 5926,
+ 5927,
+ 5928,
+ 5929,
+ 5930,
+ 5931,
+ 5932,
+ 5933,
+ 5934,
+ 5935,
+ 5936,
+ 5937,
+ 5938,
+ 5939,
+ 5940,
+ 5941,
+ 5942,
+ 5943,
+ 5944,
+ 5945,
+ 5946,
+ 5947,
+ 5948,
+ 5949,
+ 5950,
+ 5951,
+ 5952,
+ 5953,
+ 5954,
+ 5955,
+ 5956,
+ 5957,
+ 5958,
+ 5959,
+ 5960,
+ 5961,
+ 5962,
+ 5963,
+ 5964,
+ 5965,
+ 5966,
+ 5967,
+ 5968,
+ 5969,
+ 5970,
+ 5971,
+ 5972,
+ 5973,
+ 5974,
+ 5975,
+ 5976,
+ 5977,
+ 5978,
+ 5979,
+ 5980,
+ 5981,
+ 5982,
+ 5983,
+ 5984,
+ 5985,
+ 5986,
+ 5987,
+ 5988,
+ 5989,
+ 5990,
+ 5991,
+ 5992,
+ 5993,
+ 5994,
+ 5995,
+ 5996,
+ 5997,
+ 5998,
+ 5999,
+ 6000,
+ 6001,
+ 6002,
+ 6003,
+ 6004,
+ 6005,
+ 6006,
+ 6007,
+ 6008,
+ 6009,
+ 6010,
+ 6011,
+ 6012,
+ 6013,
+ 6014,
+ 6015,
+ 6016,
+ 6017,
+ 6018,
+ 6019,
+ 6020,
+ 6021,
+ 6022,
+ 6023,
+ 6024,
+ 6025,
+ 6026,
+ 6027,
+ 6028,
+ 6029,
+ 6030,
+ 6031,
+ 6032,
+ 6033,
+ 6034,
+ 6035,
+ 6036,
+ 6037,
+ 6038,
+ 6039,
+ 6040,
+ 6041,
+ 6042,
+ 6043,
+ 6044,
+ 6045,
+ 6046,
+ 6047,
+ 6048,
+ 6049,
+ 6050,
+ 6051,
+ 6052,
+ 6053,
+ 6054,
+ 6055,
+ 6056,
+ 6057,
+ 6058,
+ 6059,
+ 6060,
+ 6061,
+ 6062,
+ 6063,
+ 6064,
+ 6065,
+ 6066,
+ 6067,
+ 6068,
+ 6069,
+ 6070,
+ 6071,
+ 6072,
+ 6073,
+ 6074,
+ 6075,
+ 6076,
+ 6077,
+ 6078,
+ 6079,
+ 6080,
+ 6081,
+ 6082,
+ 6083,
+ 6084,
+ 6085,
+ 6086,
+ 6087,
+ 6088,
+ 6089,
+ 6090,
+ 6091,
+ 6092,
+ 6093,
+ 6094,
+ 6095,
+ 6096,
+ 6097,
+ 6098,
+ 6099,
+ 6100,
+ 6101,
+ 6102,
+ 6103,
+ 6104,
+ 6105,
+ 6106,
+ 6107,
+ 6108,
+ 6109,
+ 6110,
+ 6111,
+ 6112,
+ 6113,
+ 6114,
+ 6115,
+ 6116,
+ 6117,
+ 6118,
+ 6119,
+ 6120,
+ 6121,
+ 6122,
+ 6123,
+ 6124,
+ 6125,
+ 6126,
+ 6127,
+ 6128,
+ 6129,
+ 6130,
+ 6131,
+ 6132,
+ 6133,
+ 6134,
+ 6135,
+ 6136,
+ 6137,
+ 6138,
+ 6139,
+ 6140,
+ 6141,
+ 6142,
+ 6143,
+ 6144,
+ 6145,
+ 6146,
+ 6147,
+ 6148,
+ 6149,
+ 6150,
+ 6151,
+ 6152,
+ 6153,
+ 6154,
+ 6155,
+ 6156,
+ 6157,
+ 6158,
+ 6159,
+ 6160,
+ 6161,
+ 6162,
+ 6163,
+ 6164,
+ 6165,
+ 6166,
+ 6167,
+ 6168,
+ 6169,
+ 6170,
+ 6171,
+ 6172,
+ 6173,
+ 6174,
+ 6175,
+ 6176,
+ 6177,
+ 6178,
+ 6179,
+ 6180,
+ 6181,
+ 6182,
+ 6183,
+ 6184,
+ 6185,
+ 6186,
+ 6187,
+ 6188,
+ 6189,
+ 6190,
+ 6191,
+ 6192,
+ 6193,
+ 6194,
+ 6195,
+ 6196,
+ 6197,
+ 6198,
+ 6199,
+ 6200,
+ 6201,
+ 6202,
+ 6203,
+ 6204,
+ 6205,
+ 6206,
+ 6207,
+ 6208,
+ 6209,
+ 6210,
+ 6211,
+ 6212,
+ 6213,
+ 6214,
+ 6215,
+ 6216,
+ 6217,
+ 6218,
+ 6219,
+ 6220,
+ 6221,
+ 6222,
+ 6223,
+ 6224,
+ 6225,
+ 6226,
+ 6227,
+ 6228,
+ 6229,
+ 6230,
+ 6231,
+ 6232,
+ 6233,
+ 6234,
+ 6235,
+ 6236,
+ 6237,
+ 6238,
+ 6239,
+ 6240,
+ 6241,
+ 6242,
+ 6243,
+ 6244,
+ 6245,
+ 6246,
+ 6247,
+ 6248,
+ 6249,
+ 6250,
+ 6251,
+ 6252,
+ 6253,
+ 6254,
+ 6255,
+ 6256,
+ 6257,
+ 6258,
+ 6259,
+ 6260,
+ 6261,
+ 6262,
+ 6263,
+ 6264,
+ 6265,
+ 6266,
+ 6267,
+ 6268,
+ 6269,
+ 6270,
+ 6271,
+ 6272,
+ 6273,
+ 6274,
+ 6275,
+ 6276,
+ 6277,
+ 6278,
+ 6279,
+ 6280,
+ 6281,
+ 6282,
+ 6283,
+ 6284,
+ 6285,
+ 6286,
+ 6287,
+ 6288,
+ 6289,
+ 6290,
+ 6291,
+ 6292,
+ 6293,
+ 6294,
+ 6295,
+ 6296,
+ 6297,
+ 6298,
+ 6299,
+ 6300,
+ 6301,
+ 6302,
+ 6303,
+ 6304,
+ 6305,
+ 6306,
+ 6307,
+ 6308,
+ 6309,
+ 6310,
+ 6311,
+ 6312,
+ 6313,
+ 6314,
+ 6315,
+ 6316,
+ 6317,
+ 6318,
+ 6319,
+ 6320,
+ 6321,
+ 6322,
+ 6323,
+ 6324,
+ 6325,
+ 6326,
+ 6327,
+ 6328,
+ 6329,
+ 6330,
+ 6331,
+ 6332,
+ 6333,
+ 6334,
+ 6335,
+ 6336,
+ 6337,
+ 6338,
+ 6339,
+ 6340,
+ 6341,
+ 6342,
+ 6343,
+ 6344,
+ 6345,
+ 6346,
+ 6347,
+ 6348,
+ 6349,
+ 6350,
+ 6351,
+ 6352,
+ 6353,
+ 6354,
+ 6355,
+ 6356,
+ 6357,
+ 6358,
+ 6359,
+ 6360,
+ 6361,
+ 6362,
+ 6363,
+ 6364,
+ 6365,
+ 6366,
+ 6367,
+ 6368,
+ 6369,
+ 6370,
+ 6371,
+ 6372,
+ 6373,
+ 6374,
+ 6375,
+ 6376,
+ 6377,
+ 6378,
+ 6379,
+ 6380,
+ 6381,
+ 6382,
+ 6383,
+ 6384,
+ 6385,
+ 6386,
+ 6387,
+ 6388,
+ 6389,
+ 6390,
+ 6391,
+ 6392,
+ 6393,
+ 6394,
+ 6395,
+ 6396,
+ 6397,
+ 6398,
+ 6399,
+ 6400,
+ 6401,
+ 6402,
+ 6403,
+ 6404,
+ 6405,
+ 6406,
+ 6407,
+ 6408,
+ 6409,
+ 6410,
+ 6411,
+ 6412,
+ 6413,
+ 6414,
+ 6415,
+ 6416,
+ 6417,
+ 6418,
+ 6419,
+ 6420,
+ 6421,
+ 6422,
+ 6423,
+ 6424,
+ 6425,
+ 6426,
+ 6427,
+ 6428,
+ 6429,
+ 6430,
+ 6431,
+ 6432,
+ 6433,
+ 6434,
+ 6435,
+ 6436,
+ 6437,
+ 6438,
+ 6439,
+ 6440,
+ 6441,
+ 6442,
+ 6443,
+ 6444,
+ 6445,
+ 6446,
+ 6447,
+ 6448,
+ 6449,
+ 6450,
+ 6451,
+ 6452,
+ 6453,
+ 6454,
+ 6455,
+ 6456,
+ 6457,
+ 6458,
+ 6459,
+ 6460,
+ 6461,
+ 6462,
+ 6463,
+ 6464,
+ 6465,
+ 6466,
+ 6467,
+ 6468,
+ 6469,
+ 6470,
+ 6471,
+ 6472,
+ 6473,
+ 6474,
+ 6475,
+ 6476,
+ 6477,
+ 6478,
+ 6479,
+ 6480,
+ 6481,
+ 6482,
+ 6483,
+ 6484,
+ 6485,
+ 6486,
+ 6487,
+ 6488,
+ 6489,
+ 6490,
+ 6491,
+ 6492,
+ 6493,
+ 6494,
+ 6495,
+ 6496,
+ 6497,
+ 6498,
+ 6499,
+ 6500,
+ 6501,
+ 6502,
+ 6503,
+ 6504,
+ 6505,
+ 6506,
+ 6507,
+ 6508,
+ 6509,
+ 6510,
+ 6511,
+ 6512,
+ 6513,
+ 6514,
+ 6515,
+ 6516,
+ 6517,
+ 6518,
+ 6519,
+ 6520,
+ 6521,
+ 6522,
+ 6523,
+ 6524,
+ 6525,
+ 6526,
+ 6527,
+ 6528,
+ 6529,
+ 6530,
+ 6531,
+ 6532,
+ 6533,
+ 6534,
+ 6535,
+ 6536,
+ 6537,
+ 6538,
+ 6539,
+ 6540,
+ 6541,
+ 6542,
+ 6543,
+ 6544,
+ 6545,
+ 6546,
+ 6547,
+ 6548,
+ 6549,
+ 6550,
+ 6551,
+ 6552,
+ 6553,
+ 6554,
+ 6555,
+ 6556,
+ 6557,
+ 6558,
+ 6559,
+ 6560,
+ 6561,
+ 6562,
+ 6563,
+ 6564,
+ 6565,
+ 6566,
+ 6567,
+ 6568,
+ 6569,
+ 6570,
+ 6571,
+ 6572,
+ 6573,
+ 6574,
+ 6575,
+ 6576,
+ 6577,
+ 6578,
+ 6579,
+ 6580,
+ 6581,
+ 6582,
+ 6583,
+ 6584,
+ 6585,
+ 6586,
+ 6587,
+ 6588,
+ 6589,
+ 6590,
+ 6591,
+ 6592,
+ 6593,
+ 6594,
+ 6595,
+ 6596,
+ 6597,
+ 6598,
+ 6599,
+ 6600,
+ 6601,
+ 6602,
+ 6603,
+ 6604,
+ 6605,
+ 6606,
+ 6607,
+ 6608,
+ 6609,
+ 6610,
+ 6611,
+ 6612,
+ 6613,
+ 6614,
+ 6615,
+ 6616,
+ 6617,
+ 6618,
+ 6619,
+ 6620,
+ 6621,
+ 6622,
+ 6623,
+ 6624,
+ 6625,
+ 6626,
+ 6627,
+ 6628,
+ 6629,
+ 6630,
+ 6631,
+ 6632,
+ 6633,
+ 6634,
+ 6635,
+ 6636,
+ 6637,
+ 6638,
+ 6639,
+ 6640,
+ 6641,
+ 6642,
+ 6643,
+ 6644,
+ 6645,
+ 6646,
+ 6647,
+ 6648,
+ 6649,
+ 6650,
+ 6651,
+ 6652,
+ 6653,
+ 6654,
+ 6655,
+ 6656,
+ 6657,
+ 6658,
+ 6659,
+ 6660,
+ 6661,
+ 6662,
+ 6663,
+ 6664,
+ 6665,
+ 6666,
+ 6667,
+ 6668,
+ 6669,
+ 6670,
+ 6671,
+ 6672,
+ 6673,
+ 6674,
+ 6675,
+ 6676,
+ 6677,
+ 6678,
+ 6679,
+ 6680,
+ 6681,
+ 6682,
+ 6683,
+ 6684,
+ 6685,
+ 6686,
+ 6687,
+ 6688,
+ 6689,
+ 6690,
+ 6691,
+ 6692,
+ 6693,
+ 6694,
+ 6695,
+ 6696,
+ 6697,
+ 6698,
+ 6699,
+ 6700,
+ 6701,
+ 6702,
+ 6703,
+ 6704,
+ 6705,
+ 6706,
+ 6707,
+ 6708,
+ 6709,
+ 6710,
+ 6711,
+ 6712,
+ 6713,
+ 6714,
+ 6715,
+ 6716,
+ 6717,
+ 6718,
+ 6719,
+ 6720,
+ 6721,
+ 6722,
+ 6723,
+ 6724,
+ 6725,
+ 6726,
+ 6727,
+ 6728,
+ 6729,
+ 6730,
+ 6731,
+ 6732,
+ 6733,
+ 6734,
+ 6735,
+ 6736,
+ 6737,
+ 6738,
+ 6739,
+ 6740,
+ 6741,
+ 6742,
+ 6743,
+ 6744,
+ 6745,
+ 6746,
+ 6747,
+ 6748,
+ 6749,
+ 6750,
+ 6751,
+ 6752,
+ 6753,
+ 6754,
+ 6755,
+ 6756,
+ 6757,
+ 6758,
+ 6759,
+ 6760,
+ 6761,
+ 6762,
+ 6763,
+ 6764,
+ 6765,
+ 6766,
+ 6767,
+ 6768,
+ 6769,
+ 6770,
+ 6771,
+ 6772,
+ 6773,
+ 6774,
+ 6775,
+ 6776,
+ 6777,
+ 6778,
+ 6779,
+ 6780,
+ 6781,
+ 6782,
+ 6783,
+ 6784,
+ 6785,
+ 6786,
+ 6787,
+ 6788,
+ 6789,
+ 6790,
+ 6791,
+ 6792,
+ 6793,
+ 6794,
+ 6795,
+ 6796,
+ 6797,
+ 6798,
+ 6799,
+ 6800,
+ 6801,
+ 6802,
+ 6803,
+ 6804,
+ 6805,
+ 6806,
+ 6807,
+ 6808,
+ 6809,
+ 6810,
+ 6811,
+ 6812,
+ 6813,
+ 6814,
+ 6815,
+ 6816,
+ 6817,
+ 6818,
+ 6819,
+ 6820,
+ 6821,
+ 6822,
+ 6823,
+ 6824,
+ 6825,
+ 6826,
+ 6827,
+ 6828,
+ 6829,
+ 6830,
+ 6831,
+ 6832,
+ 6833,
+ 6834,
+ 6835,
+ 6836,
+ 6837,
+ 6838,
+ 6839,
+ 6840,
+ 6841,
+ 6842,
+ 6843,
+ 6844,
+ 6845,
+ 6846,
+ 6847,
+ 6848,
+ 6849,
+ 6850,
+ 6851,
+ 6852,
+ 6853,
+ 6854,
+ 6855,
+ 6856,
+ 6857,
+ 6858,
+ 6859,
+ 6860,
+ 6861,
+ 6862,
+ 6863,
+ 6864,
+ 6865,
+ 6866,
+ 6867,
+ 6868,
+ 6869,
+ 6870,
+ 6871,
+ 6872,
+ 6873,
+ 6874,
+ 6875,
+ 6876,
+ 6877,
+ 6878,
+ 6879,
+ 6880,
+ 6881,
+ 6882,
+ 6883,
+ 6884,
+ 6885,
+ 6886,
+ 6887,
+ 6888,
+ 6889,
+ 6890,
+ 6891,
+ 6892,
+ 6893,
+ 6894,
+ 6895,
+ 6896,
+ 6897,
+ 6898,
+ 6899,
+ 6900,
+ 6901,
+ 6902,
+ 6903,
+ 6904,
+ 6905,
+ 6906,
+ 6907,
+ 6908,
+ 6909,
+ 6910,
+ 6911,
+ 6912,
+ 6913,
+ 6914,
+ 6915,
+ 6916,
+ 6917,
+ 6918,
+ 6919,
+ 6920,
+ 6921,
+ 6922,
+ 6923,
+ 6924,
+ 6925,
+ 6926,
+ 6927,
+ 6928,
+ 6929,
+ 6930,
+ 6931,
+ 6932,
+ 6933,
+ 6934,
+ 6935,
+ 6936,
+ 6937,
+ 6938,
+ 6939,
+ 6940,
+ 6941,
+ 6942,
+ 6943,
+ 6944,
+ 6945,
+ 6946,
+ 6947,
+ 6948,
+ 6949,
+ 6950,
+ 6951,
+ 6952,
+ 6953,
+ 6954,
+ 6955,
+ 6956,
+ 6957,
+ 6958,
+ 6959,
+ 6960,
+ 6961,
+ 6962,
+ 6963,
+ 6964,
+ 6965,
+ 6966,
+ 6967,
+ 6968,
+ 6969,
+ 6970,
+ 6971,
+ 6972,
+ 6973,
+ 6974,
+ 6975,
+ 6976,
+ 6977,
+ 6978,
+ 6979,
+ 6980,
+ 6981,
+ 6982,
+ 6983,
+ 6984,
+ 6985,
+ 6986,
+ 6987,
+ 6988,
+ 6989,
+ 6990,
+ 6991,
+ 6992,
+ 6993,
+ 6994,
+ 6995,
+ 6996,
+ 6997,
+ 6998,
+ 6999,
+ 7000,
+ 7001,
+ 7002,
+ 7003,
+ 7004,
+ 7005,
+ 7006,
+ 7007,
+ 7008,
+ 7009,
+ 7010,
+ 7011,
+ 7012,
+ 7013,
+ 7014,
+ 7015,
+ 7016,
+ 7017,
+ 7018,
+ 7019,
+ 7020,
+ 7021,
+ 7022,
+ 7023,
+ 7024,
+ 7025,
+ 7026,
+ 7027,
+ 7028,
+ 7029,
+ 7030,
+ 7031,
+ 7032,
+ 7033,
+ 7034,
+ 7035,
+ 7036,
+ 7037,
+ 7038,
+ 7039,
+ 7040,
+ 7041,
+ 7042,
+ 7043,
+ 7044,
+ 7045,
+ 7046,
+ 7047,
+ 7048,
+ 7049,
+ 7050,
+ 7051,
+ 7052,
+ 7053,
+ 7054,
+ 7055,
+ 7056,
+ 7057,
+ 7058,
+ 7059,
+ 7060,
+ 7061,
+ 7062,
+ 7063,
+ 7064,
+ 7065,
+ 7066,
+ 7067,
+ 7068,
+ 7069,
+ 7070,
+ 7071,
+ 7072,
+ 7073,
+ 7074,
+ 7075,
+ 7076,
+ 7077,
+ 7078,
+ 7079,
+ 7080,
+ 7081,
+ 7082,
+ 7083,
+ 7084,
+ 7085,
+ 7086,
+ 7087,
+ 7088,
+ 7089,
+ 7090,
+ 7091,
+ 7092,
+ 7093,
+ 7094,
+ 7095,
+ 7096,
+ 7097,
+ 7098,
+ 7099,
+ 7100,
+ 7101,
+ 7102,
+ 7103,
+ 7104,
+ 7105,
+ 7106,
+ 7107,
+ 7108,
+ 7109,
+ 7110,
+ 7111,
+ 7112,
+ 7113,
+ 7114,
+ 7115,
+ 7116,
+ 7117,
+ 7118,
+ 7119,
+ 7120,
+ 7121,
+ 7122,
+ 7123,
+ 7124,
+ 7125,
+ 7126,
+ 7127,
+ 7128,
+ 7129,
+ 7130,
+ 7131,
+ 7132,
+ 7133,
+ 7134,
+ 7135,
+ 7136,
+ 7137,
+ 7138,
+ 7139,
+ 7140,
+ 7141,
+ 7142,
+ 7143,
+ 7144,
+ 7145,
+ 7146,
+ 7147,
+ 7148,
+ 7149,
+ 7150,
+ 7151,
+ 7152,
+ 7153,
+ 7154,
+ 7155,
+ 7156,
+ 7157,
+ 7158,
+ 7159,
+ 7160,
+ 7161,
+ 7162,
+ 7163,
+ 7164,
+ 7165,
+ 7166,
+ 7167,
+ 7168,
+ 7169,
+ 7170,
+ 7171,
+ 7172,
+ 7173,
+ 7174,
+ 7175,
+ 7176,
+ 7177,
+ 7178,
+ 7179,
+ 7180,
+ 7181,
+ 7182,
+ 7183,
+ 7184,
+ 7185,
+ 7186,
+ 7187,
+ 7188,
+ 7189,
+ 7190,
+ 7191,
+ 7192,
+ 7193,
+ 7194,
+ 7195,
+ 7196,
+ 7197,
+ 7198,
+ 7199,
+ 7200,
+ 7201,
+ 7202,
+ 7203,
+ 7204,
+ 7205,
+ 7206,
+ 7207,
+ 7208,
+ 7209,
+ 7210,
+ 7211,
+ 7212,
+ 7213,
+ 7214,
+ 7215,
+ 7216,
+ 7217,
+ 7218,
+ 7219,
+ 7220,
+ 7221,
+ 7222,
+ 7223,
+ 7224,
+ 7225,
+ 7226,
+ 7227,
+ 7228,
+ 7229,
+ 7230,
+ 7231,
+ 7232,
+ 7233,
+ 7234,
+ 7235,
+ 7236,
+ 7237,
+ 7238,
+ 7239,
+ 7240,
+ 7241,
+ 7242,
+ 7243,
+ 7244,
+ 7245,
+ 7246,
+ 7247,
+ 7248,
+ 7249,
+ 7250,
+ 7251,
+ 7252,
+ 7253,
+ 7254,
+ 7255,
+ 7256,
+ 7257,
+ 7258,
+ 7259,
+ 7260,
+ 7261,
+ 7262,
+ 7263,
+ 7264,
+ 7265,
+ 7266,
+ 7267,
+ 7268,
+ 7269,
+ 7270,
+ 7271,
+ 7272,
+ 7273,
+ 7274,
+ 7275,
+ 7276,
+ 7277,
+ 7278,
+ 7279,
+ 7280,
+ 7281,
+ 7282,
+ 7283,
+ 7284,
+ 7285,
+ 7286,
+ 7287,
+ 7288,
+ 7289,
+ 7290,
+ 7291,
+ 7292,
+ 7293,
+ 7294,
+ 7295,
+ 7296,
+ 7297,
+ 7298,
+ 7299,
+ 7300,
+ 7301,
+ 7302,
+ 7303,
+ 7304,
+ 7305,
+ 7306,
+ 7307,
+ 7308,
+ 7309,
+ 7310,
+ 7311,
+ 7312,
+ 7313,
+ 7314,
+ 7315,
+ 7316,
+ 7317,
+ 7318,
+ 7319,
+ 7320,
+ 7321,
+ 7322,
+ 7323,
+ 7324,
+ 7325,
+ 7326,
+ 7327,
+ 7328,
+ 7329,
+ 7330,
+ 7331,
+ 7332,
+ 7333,
+ 7334,
+ 7335,
+ 7336,
+ 7337,
+ 7338,
+ 7339,
+ 7340,
+ 7341,
+ 7342,
+ 7343,
+ 7344,
+ 7345,
+ 7346,
+ 7347,
+ 7348,
+ 7349,
+ 7350,
+ 7351,
+ 7352,
+ 7353,
+ 7354,
+ 7355,
+ 7356,
+ 7357,
+ 7358,
+ 7359,
+ 7360,
+ 7361,
+ 7362,
+ 7363,
+ 7364,
+ 7365,
+ 7366,
+ 7367,
+ 7368,
+ 7369,
+ 7370,
+ 7371,
+ 7372,
+ 7373,
+ 7374,
+ 7375,
+ 7376,
+ 7377,
+ 7378,
+ 7379,
+ 7380,
+ 7381,
+ 7382,
+ 7383,
+ 7384,
+ 7385,
+ 7386,
+ 7387,
+ 7388,
+ 7389,
+ 7390,
+ 7391,
+ 7392,
+ 7393,
+ 7394,
+ 7395,
+ 7396,
+ 7397,
+ 7398,
+ 7399,
+ 7400,
+ 7401,
+ 7402,
+ 7403,
+ 7404,
+ 7405,
+ 7406,
+ 7407,
+ 7408,
+ 7409,
+ 7410,
+ 7411,
+ 7412,
+ 7413,
+ 7414,
+ 7415,
+ 7416,
+ 7417,
+ 7418,
+ 7419,
+ 7420,
+ 7421,
+ 7422,
+ 7423,
+ 7424,
+ 7425,
+ 7426,
+ 7427,
+ 7428,
+ 7429,
+ 7430,
+ 7431,
+ 7432,
+ 7433,
+ 7434,
+ 7435,
+ 7436,
+ 7437,
+ 7438,
+ 7439,
+ 7440,
+ 7441,
+ 7442,
+ 7443,
+ 7444,
+ 7445,
+ 7446,
+ 7447,
+ 7448,
+ 7449,
+ 7450,
+ 7451,
+ 7452,
+ 7453,
+ 7454,
+ 7455,
+ 7456,
+ 7457,
+ 7458,
+ 7459,
+ 7460,
+ 7461,
+ 7462,
+ 7463,
+ 7464,
+ 7465,
+ 7466,
+ 7467,
+ 7468,
+ 7469,
+ 7470,
+ 7471,
+ 7472,
+ 7473,
+ 7474,
+ 7475,
+ 7476,
+ 7477,
+ 7478,
+ 7479,
+ 7480,
+ 7481,
+ 7482,
+ 7483,
+ 7484,
+ 7485,
+ 7486,
+ 7487,
+ 7488,
+ 7489,
+ 7490,
+ 7491,
+ 7492,
+ 7493,
+ 7494,
+ 7495,
+ 7496,
+ 7497,
+ 7498,
+ 7499,
+ 7500,
+ 7501,
+ 7502,
+ 7503,
+ 7504,
+ 7505,
+ 7506,
+ 7507,
+ 7508,
+ 7509,
+ 7510,
+ 7511,
+ 7512,
+ 7513,
+ 7514,
+ 7515,
+ 7516,
+ 7517,
+ 7518,
+ 7519,
+ 7520,
+ 7521,
+ 7522,
+ 7523,
+ 7524,
+ 7525,
+ 7526,
+ 7527,
+ 7528,
+ 7529,
+ 7530,
+ 7531,
+ 7532,
+ 7533,
+ 7534,
+ 7535,
+ 7536,
+ 7537,
+ 7538,
+ 7539,
+ 7540,
+ 7541,
+ 7542,
+ 7543,
+ 7544,
+ 7545,
+ 7546,
+ 7547,
+ 7548,
+ 7549,
+ 7550,
+ 7551,
+ 7552,
+ 7553,
+ 7554,
+ 7555,
+ 7556,
+ 7557,
+ 7558,
+ 7559,
+ 7560,
+ 7561,
+ 7562,
+ 7563,
+ 7564,
+ 7565,
+ 7566,
+ 7567,
+ 7568,
+ 7569,
+ 7570,
+ 7571,
+ 7572,
+ 7573,
+ 7574,
+ 7575,
+ 7576,
+ 7577,
+ 7578,
+ 7579,
+ 7580,
+ 7581,
+ 7582,
+ 7583,
+ 7584,
+ 7585,
+ 7586,
+ 7587,
+ 7588,
+ 7589,
+ 7590,
+ 7591,
+ 7592,
+ 7593,
+ 7594,
+ 7595,
+ 7596,
+ 7597,
+ 7598,
+ 7599,
+ 7600,
+ 7601,
+ 7602,
+ 7603,
+ 7604,
+ 7605,
+ 7606,
+ 7607,
+ 7608,
+ 7609,
+ 7610,
+ 7611,
+ 7612,
+ 7613,
+ 7614,
+ 7615,
+ 7616,
+ 7617,
+ 7618,
+ 7619,
+ 7620,
+ 7621,
+ 7622,
+ 7623,
+ 7624,
+ 7625,
+ 7626,
+ 7627,
+ 7628,
+ 7629,
+ 7630,
+ 7631,
+ 7632,
+ 7633,
+ 7634,
+ 7635,
+ 7636,
+ 7637,
+ 7638,
+ 7639,
+ 7640,
+ 7641,
+ 7642,
+ 7643,
+ 7644,
+ 7645,
+ 7646,
+ 7647,
+ 7648,
+ 7649,
+ 7650,
+ 7651,
+ 7652,
+ 7653,
+ 7654,
+ 7655,
+ 7656,
+ 7657,
+ 7658,
+ 7659,
+ 7660,
+ 7661,
+ 7662,
+ 7663,
+ 7664,
+ 7665,
+ 7666,
+ 7667,
+ 7668,
+ 7669,
+ 7670,
+ 7671,
+ 7672,
+ 7673,
+ 7674,
+ 7675,
+ 7676,
+ 7677,
+ 7678,
+ 7679,
+ 7680,
+ 7681,
+ 7682,
+ 7683,
+ 7684,
+ 7685,
+ 7686,
+ 7687,
+ 7688,
+ 7689,
+ 7690,
+ 7691,
+ 7692,
+ 7693,
+ 7694,
+ 7695,
+ 7696,
+ 7697,
+ 7698,
+ 7699,
+ 7700,
+ 7701,
+ 7702,
+ 7703,
+ 7704,
+ 7705,
+ 7706,
+ 7707,
+ 7708,
+ 7709,
+ 7710,
+ 7711,
+ 7712,
+ 7713,
+ 7714,
+ 7715,
+ 7716,
+ 7717,
+ 7718,
+ 7719,
+ 7720,
+ 7721,
+ 7722,
+ 7723,
+ 7724,
+ 7725,
+ 7726,
+ 7727,
+ 7728,
+ 7729,
+ 7730,
+ 7731,
+ 7732,
+ 7733,
+ 7734,
+ 7735,
+ 7736,
+ 7737,
+ 7738,
+ 7739,
+ 7740,
+ 7741,
+ 7742,
+ 7743,
+ 7744,
+ 7745,
+ 7746,
+ 7747,
+ 7748,
+ 7749,
+ 7750,
+ 7751,
+ 7752,
+ 7753,
+ 7754,
+ 7755,
+ 7756,
+ 7757,
+ 7758,
+ 7759,
+ 7760,
+ 7761,
+ 7762,
+ 7763,
+ 7764,
+ 7765,
+ 7766,
+ 7767,
+ 7768,
+ 7769,
+ 7770,
+ 7771,
+ 7772,
+ 7773,
+ 7774,
+ 7775,
+ 7776,
+ 7777,
+ 7778,
+ 7779,
+ 7780,
+ 7781,
+ 7782,
+ 7783,
+ 7784,
+ 7785,
+ 7786,
+ 7787,
+ 7788,
+ 7789,
+ 7790,
+ 7791,
+ 7792,
+ 7793,
+ 7794,
+ 7795,
+ 7796,
+ 7797,
+ 7798,
+ 7799,
+ 7800,
+ 7801,
+ 7802,
+ 7803,
+ 7804,
+ 7805,
+ 7806,
+ 7807,
+ 7808,
+ 7809,
+ 7810,
+ 7811,
+ 7812,
+ 7813,
+ 7814,
+ 7815,
+ 7816,
+ 7817,
+ 7818,
+ 7819,
+ 7820,
+ 7821,
+ 7822,
+ 7823,
+ 7824,
+ 7825,
+ 7826,
+ 7827,
+ 7828,
+ 7829,
+ 7830,
+ 7831,
+ 7832,
+ 7833,
+ 7834,
+ 7835,
+ 7836,
+ 7837,
+ 7838,
+ 7839,
+ 7840,
+ 7841,
+ 7842,
+ 7843,
+ 7844,
+ 7845,
+ 7846,
+ 7847,
+ 7848,
+ 7849,
+ 7850,
+ 7851,
+ 7852,
+ 7853,
+ 7854,
+ 7855,
+ 7856,
+ 7857,
+ 7858,
+ 7859,
+ 7860,
+ 7861,
+ 7862,
+ 7863,
+ 7864,
+ 7865,
+ 7866,
+ 7867,
+ 7868,
+ 7869,
+ 7870,
+ 7871,
+ 7872,
+ 7873,
+ 7874,
+ 7875,
+ 7876,
+ 7877,
+ 7878,
+ 7879,
+ 7880,
+ 7881,
+ 7882,
+ 7883,
+ 7884,
+ 7885,
+ 7886,
+ 7887,
+ 7888,
+ 7889,
+ 7890,
+ 7891,
+ 7892,
+ 7893,
+ 7894,
+ 7895,
+ 7896,
+ 7897,
+ 7898,
+ 7899,
+ 7900,
+ 7901,
+ 7902,
+ 7903,
+ 7904,
+ 7905,
+ 7906,
+ 7907,
+ 7908,
+ 7909,
+ 7910,
+ 7911,
+ 7912,
+ 7913,
+ 7914,
+ 7915,
+ 7916,
+ 7917,
+ 7918,
+ 7919,
+ 7920,
+ 7921,
+ 7922,
+ 7923,
+ 7924,
+ 7925,
+ 7926,
+ 7927,
+ 7928,
+ 7929,
+ 7930,
+ 7931,
+ 7932,
+ 7933,
+ 7934,
+ 7935,
+ 7936,
+ 7937,
+ 7938,
+ 7939,
+ 7940,
+ 7941,
+ 7942,
+ 7943,
+ 7944,
+ 7945,
+ 7946,
+ 7947,
+ 7948,
+ 7949,
+ 7950,
+ 7951,
+ 7952,
+ 7953,
+ 7954,
+ 7955,
+ 7956,
+ 7957,
+ 7958,
+ 7959,
+ 7960,
+ 7961,
+ 7962,
+ 7963,
+ 7964,
+ 7965,
+ 7966,
+ 7967,
+ 7968,
+ 7969,
+ 7970,
+ 7971,
+ 7972,
+ 7973,
+ 7974,
+ 7975,
+ 7976,
+ 7977,
+ 7978,
+ 7979,
+ 7980,
+ 7981,
+ 7982,
+ 7983,
+ 7984,
+ 7985,
+ 7986,
+ 7987,
+ 7988,
+ 7989,
+ 7990,
+ 7991,
+ 7992,
+ 7993,
+ 7994,
+ 7995,
+ 7996,
+ 7997,
+ 7998,
+ 7999,
+ 8000,
+ 8001,
+ 8002,
+ 8003,
+ 8004,
+ 8005,
+ 8006,
+ 8007,
+ 8008,
+ 8009,
+ 8010,
+ 8011,
+ 8012,
+ 8013,
+ 8014,
+ 8015,
+ 8016,
+ 8017,
+ 8018,
+ 8019,
+ 8020,
+ 8021,
+ 8022,
+ 8023,
+ 8024,
+ 8025,
+ 8026,
+ 8027,
+ 8028,
+ 8029,
+ 8030,
+ 8031,
+ 8032,
+ 8033,
+ 8034,
+ 8035,
+ 8036,
+ 8037,
+ 8038,
+ 8039,
+ 8040,
+ 8041,
+ 8042,
+ 8043,
+ 8044,
+ 8045,
+ 8046,
+ 8047,
+ 8048,
+ 8049,
+ 8050,
+ 8051,
+ 8052,
+ 8053,
+ 8054,
+ 8055,
+ 8056,
+ 8057,
+ 8058,
+ 8059,
+ 8060,
+ 8061,
+ 8062,
+ 8063,
+ 8064,
+ 8065,
+ 8066,
+ 8067,
+ 8068,
+ 8069,
+ 8070,
+ 8071,
+ 8072,
+ 8073,
+ 8074,
+ 8075,
+ 8076,
+ 8077,
+ 8078,
+ 8079,
+ 8080,
+ 8081,
+ 8082,
+ 8083,
+ 8084,
+ 8085,
+ 8086,
+ 8087,
+ 8088,
+ 8089,
+ 8090,
+ 8091,
+ 8092,
+ 8093,
+ 8094,
+ 8095,
+ 8096,
+ 8097,
+ 8098,
+ 8099,
+ 8100,
+ 8101,
+ 8102,
+ 8103,
+ 8104,
+ 8105,
+ 8106,
+ 8107,
+ 8108,
+ 8109,
+ 8110,
+ 8111,
+ 8112,
+ 8113,
+ 8114,
+ 8115,
+ 8116,
+ 8117,
+ 8118,
+ 8119,
+ 8120,
+ 8121,
+ 8122,
+ 8123,
+ 8124,
+ 8125,
+ 8126,
+ 8127,
+ 8128,
+ 8129,
+ 8130,
+ 8131,
+ 8132,
+ 8133,
+ 8134,
+ 8135,
+ 8136,
+ 8137,
+ 8138,
+ 8139,
+ 8140,
+ 8141,
+ 8142,
+ 8143,
+ 8144,
+ 8145,
+ 8146,
+ 8147,
+ 8148,
+ 8149,
+ 8150,
+ 8151,
+ 8152,
+ 8153,
+ 8154,
+ 8155,
+ 8156,
+ 8157,
+ 8158,
+ 8159,
+ 8160,
+ 8161,
+ 8162,
+ 8163,
+ 8164,
+ 8165,
+ 8166,
+ 8167,
+ 8168,
+ 8169,
+ 8170,
+ 8171,
+ 8172,
+ 8173,
+ 8174,
+ 8175,
+ 8176,
+ 8177,
+ 8178,
+ 8179,
+ 8180,
+ 8181,
+ 8182,
+ 8183,
+ 8184,
+ 8185,
+ 8186,
+ 8187,
+ 8188,
+ 8189,
+ 8190,
+ 8191,
+ 8192,
+ 8193,
+ 8194,
+ 8195,
+ 8196,
+ 8197,
+ 8198,
+ 8199,
+ 8200,
+ 8201,
+ 8202,
+ 8203,
+ 8204,
+ 8205,
+ 8206,
+ 8207,
+ 8208,
+ 8209,
+ 8210,
+ 8211,
+ 8212,
+ 8213,
+ 8214,
+ 8215,
+ 8216,
+ 8217,
+ 8218,
+ 8219,
+ 8220,
+ 8221,
+ 8222,
+ 8223,
+ 8224,
+ 8225,
+ 8226,
+ 8227,
+ 8228,
+ 8229,
+ 8230,
+ 8231,
+ 8232,
+ 8233,
+ 8234,
+ 8235,
+ 8236,
+ 8237,
+ 8238,
+ 8239,
+ 8240,
+ 8241,
+ 8242,
+ 8243,
+ 8244,
+ 8245,
+ 8246,
+ 8247,
+ 8248,
+ 8249,
+ 8250,
+ 8251,
+ 8252,
+ 8253,
+ 8254,
+ 8255,
+ 8256,
+ 8257,
+ 8258,
+ 8259,
+ 8260,
+ 8261,
+ 8262,
+ 8263,
+ 8264,
+ 8265,
+ 8266,
+ 8267,
+ 8268,
+ 8269,
+ 8270,
+ 8271,
+ 8272,
+ 8273,
+ 8274,
+ 8275,
+ 8276,
+ 8277,
+ 8278,
+ 8279,
+ 8280,
+ 8281,
+ 8282,
+ 8283,
+ 8284,
+ 8285,
+ 8286,
+ 8287,
+ 8288,
+ 8289,
+ 8290,
+ 8291,
+ 8292,
+ 8293,
+ 8294,
+ 8295,
+ 8296,
+ 8297,
+ 8298,
+ 8299,
+ 8300,
+ 8301,
+ 8302,
+ 8303,
+ 8304,
+ 8305,
+ 8306,
+ 8307,
+ 8308,
+ 8309,
+ 8310,
+ 8311,
+ 8312,
+ 8313,
+ 8314,
+ 8315,
+ 8316,
+ 8317,
+ 8318,
+ 8319,
+ 8320,
+ 8321,
+ 8322,
+ 8323,
+ 8324,
+ 8325,
+ 8326,
+ 8327,
+ 8328,
+ 8329,
+ 8330,
+ 8331,
+ 8332,
+ 8333,
+ 8334,
+ 8335,
+ 8336,
+ 8337,
+ 8338,
+ 8339,
+ 8340,
+ 8341,
+ 8342,
+ 8343,
+ 8344,
+ 8345,
+ 8346,
+ 8347,
+ 8348,
+ 8349,
+ 8350,
+ 8351,
+ 8352,
+ 8353,
+ 8354,
+ 8355,
+ 8356,
+ 8357,
+ 8358,
+ 8359,
+ 8360,
+ 8361,
+ 8362,
+ 8363,
+ 8364,
+ 8365,
+ 8366,
+ 8367,
+ 8368,
+ 8369,
+ 8370,
+ 8371,
+ 8372,
+ 8373,
+ 8374,
+ 8375,
+ 8376,
+ 8377,
+ 8378,
+ 8379,
+ 8380,
+ 8381,
+ 8382,
+ 8383,
+ 8384,
+ 8385,
+ 8386,
+ 8387,
+ 8388,
+ 8389,
+ 8390,
+ 8391,
+ 8392,
+ 8393,
+ 8394,
+ 8395,
+ 8396,
+ 8397,
+ 8398,
+ 8399,
+ 8400,
+ 8401,
+ 8402,
+ 8403,
+ 8404,
+ 8405,
+ 8406,
+ 8407,
+ 8408,
+ 8409,
+ 8410,
+ 8411,
+ 8412,
+ 8413,
+ 8414,
+ 8415,
+ 8416,
+ 8417,
+ 8418,
+ 8419,
+ 8420,
+ 8421,
+ 8422,
+ 8423,
+ 8424,
+ 8425,
+ 8426,
+ 8427,
+ 8428,
+ 8429,
+ 8430,
+ 8431,
+ 8432,
+ 8433,
+ 8434,
+ 8435,
+ 8436,
+ 8437,
+ 8438,
+ 8439,
+ 8440,
+ 8441,
+ 8442,
+ 8443,
+ 8444,
+ 8445,
+ 8446,
+ 8447,
+ 8448,
+ 8449,
+ 8450,
+ 8451,
+ 8452,
+ 8453,
+ 8454,
+ 8455,
+ 8456,
+ 8457,
+ 8458,
+ 8459,
+ 8460,
+ 8461,
+ 8462,
+ 8463,
+ 8464,
+ 8465,
+ 8466,
+ 8467,
+ 8468,
+ 8469,
+ 8470,
+ 8471,
+ 8472,
+ 8473,
+ 8474,
+ 8475,
+ 8476,
+ 8477,
+ 8478,
+ 8479,
+ 8480,
+ 8481,
+ 8482,
+ 8483,
+ 8484,
+ 8485,
+ 8486,
+ 8487,
+ 8488,
+ 8489,
+ 8490,
+ 8491,
+ 8492,
+ 8493,
+ 8494,
+ 8495,
+ 8496,
+ 8497,
+ 8498,
+ 8499,
+ 8500,
+ 8501,
+ 8502,
+ 8503,
+ 8504,
+ 8505,
+ 8506,
+ 8507,
+ 8508,
+ 8509,
+ 8510,
+ 8511,
+ 8512,
+ 8513,
+ 8514,
+ 8515,
+ 8516,
+ 8517,
+ 8518,
+ 8519,
+ 8520,
+ 8521,
+ 8522,
+ 8523,
+ 8524,
+ 8525,
+ 8526,
+ 8527,
+ 8528,
+ 8529,
+ 8530,
+ 8531,
+ 8532,
+ 8533,
+ 8534,
+ 8535,
+ 8536,
+ 8537,
+ 8538,
+ 8539,
+ 8540,
+ 8541,
+ 8542,
+ 8543,
+ 8544,
+ 8545,
+ 8546,
+ 8547,
+ 8548,
+ 8549,
+ 8550,
+ 8551,
+ 8552,
+ 8553,
+ 8554,
+ 8555,
+ 8556,
+ 8557,
+ 8558,
+ 8559,
+ 8560,
+ 8561,
+ 8562,
+ 8563,
+ 8564,
+ 8565,
+ 8566,
+ 8567,
+ 8568,
+ 8569,
+ 8570,
+ 8571,
+ 8572,
+ 8573,
+ 8574,
+ 8575,
+ 8576,
+ 8577,
+ 8578,
+ 8579,
+ 8580,
+ 8581,
+ 8582,
+ 8583,
+ 8584,
+ 8585,
+ 8586,
+ 8587,
+ 8588,
+ 8589,
+ 8590,
+ 8591,
+ 8592,
+ 8593,
+ 8594,
+ 8595,
+ 8596,
+ 8597,
+ 8598,
+ 8599,
+ 8600,
+ 8601,
+ 8602,
+ 8603,
+ 8604,
+ 8605,
+ 8606,
+ 8607,
+ 8608,
+ 8609,
+ 8610,
+ 8611,
+ 8612,
+ 8613,
+ 8614,
+ 8615,
+ 8616,
+ 8617,
+ 8618,
+ 8619,
+ 8620,
+ 8621,
+ 8622,
+ 8623,
+ 8624,
+ 8625,
+ 8626,
+ 8627,
+ 8628,
+ 8629,
+ 8630,
+ 8631,
+ 8632,
+ 8633,
+ 8634,
+ 8635,
+ 8636,
+ 8637,
+ 8638,
+ 8639,
+ 8640,
+ 8641,
+ 8642,
+ 8643,
+ 8644,
+ 8645,
+ 8646,
+ 8647,
+ 8648,
+ 8649,
+ 8650,
+ 8651,
+ 8652,
+ 8653,
+ 8654,
+ 8655,
+ 8656,
+ 8657,
+ 8658,
+ 8659,
+ 8660,
+ 8661,
+ 8662,
+ 8663,
+ 8664,
+ 8665,
+ 8666,
+ 8667,
+ 8668,
+ 8669,
+ 8670,
+ 8671,
+ 8672,
+ 8673,
+ 8674,
+ 8675,
+ 8676,
+ 8677,
+ 8678,
+ 8679,
+ 8680,
+ 8681,
+ 8682,
+ 8683,
+ 8684,
+ 8685,
+ 8686,
+ 8687,
+ 8688,
+ 8689,
+ 8690,
+ 8691,
+ 8692,
+ 8693,
+ 8694,
+ 8695,
+ 8696,
+ 8697,
+ 8698,
+ 8699,
+ 8700,
+ 8701,
+ 8702,
+ 8703,
+ 8704,
+ 8705,
+ 8706,
+ 8707,
+ 8708,
+ 8709,
+ 8710,
+ 8711,
+ 8712,
+ 8713,
+ 8714,
+ 8715,
+ 8716,
+ 8717,
+ 8718,
+ 8719,
+ 8720,
+ 8721,
+ 8722,
+ 8723,
+ 8724,
+ 8725,
+ 8726,
+ 8727,
+ 8728,
+ 8729,
+ 8730,
+ 8731,
+ 8732,
+ 8733,
+ 8734,
+ 8735,
+ 8736,
+ 8737,
+ 8738,
+ 8739,
+ 8740,
+ 8741,
+ 8742,
+ 8743,
+ 8744,
+ 8745,
+ 8746,
+ 8747,
+ 8748,
+ 8749,
+ 8750,
+ 8751,
+ 8752,
+ 8753,
+ 8754,
+ 8755,
+ 8756,
+ 8757,
+ 8758,
+ 8759,
+ 8760,
+ 8761,
+ 8762,
+ 8763,
+ 8764,
+ 8765,
+ 8766,
+ 8767,
+ 8768,
+ 8769,
+ 8770,
+ 8771,
+ 8772,
+ 8773,
+ 8774,
+ 8775,
+ 8776,
+ 8777,
+ 8778,
+ 8779,
+ 8780,
+ 8781,
+ 8782,
+ 8783,
+ 8784,
+ 8785,
+ 8786,
+ 8787,
+ 8788,
+ 8789,
+ 8790,
+ 8791,
+ 8792,
+ 8793,
+ 8794,
+ 8795,
+ 8796,
+ 8797,
+ 8798,
+ 8799,
+ 8800,
+ 8801,
+ 8802,
+ 8803,
+ 8804,
+ 8805,
+ 8806,
+ 8807,
+ 8808,
+ 8809,
+ 8810,
+ 8811,
+ 8812,
+ 8813,
+ 8814,
+ 8815,
+ 8816,
+ 8817,
+ 8818,
+ 8819,
+ 8820,
+ 8821,
+ 8822,
+ 8823,
+ 8824,
+ 8825,
+ 8826,
+ 8827,
+ 8828,
+ 8829,
+ 8830,
+ 8831,
+ 8832,
+ 8833,
+ 8834,
+ 8835,
+ 8836,
+ 8837,
+ 8838,
+ 8839,
+ 8840,
+ 8841,
+ 8842,
+ 8843,
+ 8844,
+ 8845,
+ 8846,
+ 8847,
+ 8848,
+ 8849,
+ 8850,
+ 8851,
+ 8852,
+ 8853,
+ 8854,
+ 8855,
+ 8856,
+ 8857,
+ 8858,
+ 8859,
+ 8860,
+ 8861,
+ 8862,
+ 8863,
+ 8864,
+ 8865,
+ 8866,
+ 8867,
+ 8868,
+ 8869,
+ 8870,
+ 8871,
+ 8872,
+ 8873,
+ 8874,
+ 8875,
+ 8876,
+ 8877,
+ 8878,
+ 8879,
+ 8880,
+ 8881,
+ 8882,
+ 8883,
+ 8884,
+ 8885,
+ 8886,
+ 8887,
+ 8888,
+ 8889,
+ 8890,
+ 8891,
+ 8892,
+ 8893,
+ 8894,
+ 8895,
+ 8896,
+ 8897,
+ 8898,
+ 8899,
+ 8900,
+ 8901,
+ 8902,
+ 8903,
+ 8904,
+ 8905,
+ 8906,
+ 8907,
+ 8908,
+ 8909,
+ 8910,
+ 8911,
+ 8912,
+ 8913,
+ 8914,
+ 8915,
+ 8916,
+ 8917,
+ 8918,
+ 8919,
+ 8920,
+ 8921,
+ 8922,
+ 8923,
+ 8924,
+ 8925,
+ 8926,
+ 8927,
+ 8928,
+ 8929,
+ 8930,
+ 8931,
+ 8932,
+ 8933,
+ 8934,
+ 8935,
+ 8936,
+ 8937,
+ 8938,
+ 8939,
+ 8940,
+ 8941,
+ 8942,
+ 8943,
+ 8944,
+ 8945,
+ 8946,
+ 8947,
+ 8948,
+ 8949,
+ 8950,
+ 8951,
+ 8952,
+ 8953,
+ 8954,
+ 8955,
+ 8956,
+ 8957,
+ 8958,
+ 8959,
+ 8960,
+ 8961,
+ 8962,
+ 8963,
+ 8964,
+ 8965,
+ 8966,
+ 8967,
+ 8968,
+ 8969,
+ 8970,
+ 8971,
+ 8972,
+ 8973,
+ 8974,
+ 8975,
+ 8976,
+ 8977,
+ 8978,
+ 8979,
+ 8980,
+ 8981,
+ 8982,
+ 8983,
+ 8984,
+ 8985,
+ 8986,
+ 8987,
+ 8988,
+ 8989,
+ 8990,
+ 8991,
+ 8992,
+ 8993,
+ 8994,
+ 8995,
+ 8996,
+ 8997,
+ 8998,
+ 8999,
+ 9000,
+ 9001,
+ 9002,
+ 9003,
+ 9004,
+ 9005,
+ 9006,
+ 9007,
+ 9008,
+ 9009,
+ 9010,
+ 9011,
+ 9012,
+ 9013,
+ 9014,
+ 9015,
+ 9016,
+ 9017,
+ 9018,
+ 9019,
+ 9020,
+ 9021,
+ 9022,
+ 9023,
+ 9024,
+ 9025,
+ 9026,
+ 9027,
+ 9028,
+ 9029,
+ 9030,
+ 9031,
+ 9032,
+ 9033,
+ 9034,
+ 9035,
+ 9036,
+ 9037,
+ 9038,
+ 9039,
+ 9040,
+ 9041,
+ 9042,
+ 9043,
+ 9044,
+ 9045,
+ 9046,
+ 9047,
+ 9048,
+ 9049,
+ 9050,
+ 9051,
+ 9052,
+ 9053,
+ 9054,
+ 9055,
+ 9056,
+ 9057,
+ 9058,
+ 9059,
+ 9060,
+ 9061,
+ 9062,
+ 9063,
+ 9064,
+ 9065,
+ 9066,
+ 9067,
+ 9068,
+ 9069,
+ 9070,
+ 9071,
+ 9072,
+ 9073,
+ 9074,
+ 9075,
+ 9076,
+ 9077,
+ 9078,
+ 9079,
+ 9080,
+ 9081,
+ 9082,
+ 9083,
+ 9084,
+ 9085,
+ 9086,
+ 9087,
+ 9088,
+ 9089,
+ 9090,
+ 9091,
+ 9092,
+ 9093,
+ 9094,
+ 9095,
+ 9096,
+ 9097,
+ 9098,
+ 9099,
+ 9100,
+ 9101,
+ 9102,
+ 9103,
+ 9104,
+ 9105,
+ 9106,
+ 9107,
+ 9108,
+ 9109,
+ 9110,
+ 9111,
+ 9112,
+ 9113,
+ 9114,
+ 9115,
+ 9116,
+ 9117,
+ 9118,
+ 9119,
+ 9120,
+ 9121,
+ 9122,
+ 9123,
+ 9124,
+ 9125,
+ 9126,
+ 9127,
+ 9128,
+ 9129,
+ 9130,
+ 9131,
+ 9132,
+ 9133,
+ 9134,
+ 9135,
+ 9136,
+ 9137,
+ 9138,
+ 9139,
+ 9140,
+ 9141,
+ 9142,
+ 9143,
+ 9144,
+ 9145,
+ 9146,
+ 9147,
+ 9148,
+ 9149,
+ 9150,
+ 9151,
+ 9152,
+ 9153,
+ 9154,
+ 9155,
+ 9156,
+ 9157,
+ 9158,
+ 9159,
+ 9160,
+ 9161,
+ 9162,
+ 9163,
+ 9164,
+ 9165,
+ 9166,
+ 9167,
+ 9168,
+ 9169,
+ 9170,
+ 9171,
+ 9172,
+ 9173,
+ 9174,
+ 9175,
+ 9176,
+ 9177,
+ 9178,
+ 9179,
+ 9180,
+ 9181,
+ 9182,
+ 9183,
+ 9184,
+ 9185,
+ 9186,
+ 9187,
+ 9188,
+ 9189,
+ 9190,
+ 9191,
+ 9192,
+ 9193,
+ 9194,
+ 9195,
+ 9196,
+ 9197,
+ 9198,
+ 9199,
+ 9200,
+ 9201,
+ 9202,
+ 9203,
+ 9204,
+ 9205,
+ 9206,
+ 9207,
+ 9208,
+ 9209,
+ 9210,
+ 9211,
+ 9212,
+ 9213,
+ 9214,
+ 9215,
+ 9216,
+ 9217,
+ 9218,
+ 9219,
+ 9220,
+ 9221,
+ 9222,
+ 9223,
+ 9224,
+ 9225,
+ 9226,
+ 9227,
+ 9228,
+ 9229,
+ 9230,
+ 9231,
+ 9232,
+ 9233,
+ 9234,
+ 9235,
+ 9236,
+ 9237,
+ 9238,
+ 9239,
+ 9240,
+ 9241,
+ 9242,
+ 9243,
+ 9244,
+ 9245,
+ 9246,
+ 9247,
+ 9248,
+ 9249,
+ 9250,
+ 9251,
+ 9252,
+ 9253,
+ 9254,
+ 9255,
+ 9256,
+ 9257,
+ 9258,
+ 9259,
+ 9260,
+ 9261,
+ 9262,
+ 9263,
+ 9264,
+ 9265,
+ 9266,
+ 9267,
+ 9268,
+ 9269,
+ 9270,
+ 9271,
+ 9272,
+ 9273,
+ 9274,
+ 9275,
+ 9276,
+ 9277,
+ 9278,
+ 9279,
+ 9280,
+ 9281,
+ 9282,
+ 9283,
+ 9284,
+ 9285,
+ 9286,
+ 9287,
+ 9288,
+ 9289,
+ 9290,
+ 9291,
+ 9292,
+ 9293,
+ 9294,
+ 9295,
+ 9296,
+ 9297,
+ 9298,
+ 9299,
+ 9300,
+ 9301,
+ 9302,
+ 9303,
+ 9304,
+ 9305,
+ 9306,
+ 9307,
+ 9308,
+ 9309,
+ 9310,
+ 9311,
+ 9312,
+ 9313,
+ 9314,
+ 9315,
+ 9316,
+ 9317,
+ 9318,
+ 9319,
+ 9320,
+ 9321,
+ 9322,
+ 9323,
+ 9324,
+ 9325,
+ 9326,
+ 9327,
+ 9328,
+ 9329,
+ 9330,
+ 9331,
+ 9332,
+ 9333,
+ 9334,
+ 9335,
+ 9336,
+ 9337,
+ 9338,
+ 9339,
+ 9340,
+ 9341,
+ 9342,
+ 9343,
+ 9344,
+ 9345,
+ 9346,
+ 9347,
+ 9348,
+ 9349,
+ 9350,
+ 9351,
+ 9352,
+ 9353,
+ 9354,
+ 9355,
+ 9356,
+ 9357,
+ 9358,
+ 9359,
+ 9360,
+ 9361,
+ 9362,
+ 9363,
+ 9364,
+ 9365,
+ 9366,
+ 9367,
+ 9368,
+ 9369,
+ 9370,
+ 9371,
+ 9372,
+ 9373,
+ 9374,
+ 9375,
+ 9376,
+ 9377,
+ 9378,
+ 9379,
+ 9380,
+ 9381,
+ 9382,
+ 9383,
+ 9384,
+ 9385,
+ 9386,
+ 9387,
+ 9388,
+ 9389,
+ 9390,
+ 9391,
+ 9392,
+ 9393,
+ 9394,
+ 9395,
+ 9396,
+ 9397,
+ 9398,
+ 9399,
+ 9400,
+ 9401,
+ 9402,
+ 9403,
+ 9404,
+ 9405,
+ 9406,
+ 9407,
+ 9408,
+ 9409,
+ 9410,
+ 9411,
+ 9412,
+ 9413,
+ 9414,
+ 9415,
+ 9416,
+ 9417,
+ 9418,
+ 9419,
+ 9420,
+ 9421,
+ 9422,
+ 9423,
+ 9424,
+ 9425,
+ 9426,
+ 9427,
+ 9428,
+ 9429,
+ 9430,
+ 9431,
+ 9432,
+ 9433,
+ 9434,
+ 9435,
+ 9436,
+ 9437,
+ 9438,
+ 9439,
+ 9440,
+ 9441,
+ 9442,
+ 9443,
+ 9444,
+ 9445,
+ 9446,
+ 9447,
+ 9448,
+ 9449,
+ 9450,
+ 9451,
+ 9452,
+ 9453,
+ 9454,
+ 9455,
+ 9456,
+ 9457,
+ 9458,
+ 9459,
+ 9460,
+ 9461,
+ 9462,
+ 9463,
+ 9464,
+ 9465,
+ 9466,
+ 9467,
+ 9468,
+ 9469,
+ 9470,
+ 9471,
+ 9472,
+ 9473,
+ 9474,
+ 9475,
+ 9476,
+ 9477,
+ 9478,
+ 9479,
+ 9480,
+ 9481,
+ 9482,
+ 9483,
+ 9484,
+ 9485,
+ 9486,
+ 9487,
+ 9488,
+ 9489,
+ 9490,
+ 9491,
+ 9492,
+ 9493,
+ 9494,
+ 9495,
+ 9496,
+ 9497,
+ 9498,
+ 9499,
+ 9500,
+ 9501,
+ 9502,
+ 9503,
+ 9504,
+ 9505,
+ 9506,
+ 9507,
+ 9508,
+ 9509,
+ 9510,
+ 9511,
+ 9512,
+ 9513,
+ 9514,
+ 9515,
+ 9516,
+ 9517,
+ 9518,
+ 9519,
+ 9520,
+ 9521,
+ 9522,
+ 9523,
+ 9524,
+ 9525,
+ 9526,
+ 9527,
+ 9528,
+ 9529,
+ 9530,
+ 9531,
+ 9532,
+ 9533,
+ 9534,
+ 9535,
+ 9536,
+ 9537,
+ 9538,
+ 9539,
+ 9540,
+ 9541,
+ 9542,
+ 9543,
+ 9544,
+ 9545,
+ 9546,
+ 9547,
+ 9548,
+ 9549,
+ 9550,
+ 9551,
+ 9552,
+ 9553,
+ 9554,
+ 9555,
+ 9556,
+ 9557,
+ 9558,
+ 9559,
+ 9560,
+ 9561,
+ 9562,
+ 9563,
+ 9564,
+ 9565,
+ 9566,
+ 9567,
+ 9568,
+ 9569,
+ 9570,
+ 9571,
+ 9572,
+ 9573,
+ 9574,
+ 9575,
+ 9576,
+ 9577,
+ 9578,
+ 9579,
+ 9580,
+ 9581,
+ 9582,
+ 9583,
+ 9584,
+ 9585,
+ 9586,
+ 9587,
+ 9588,
+ 9589,
+ 9590,
+ 9591,
+ 9592,
+ 9593,
+ 9594,
+ 9595,
+ 9596,
+ 9597,
+ 9598,
+ 9599,
+ 9600,
+ 9601,
+ 9602,
+ 9603,
+ 9604,
+ 9605,
+ 9606,
+ 9607,
+ 9608,
+ 9609,
+ 9610,
+ 9611,
+ 9612,
+ 9613,
+ 9614,
+ 9615,
+ 9616,
+ 9617,
+ 9618,
+ 9619,
+ 9620,
+ 9621,
+ 9622,
+ 9623,
+ 9624,
+ 9625,
+ 9626,
+ 9627,
+ 9628,
+ 9629,
+ 9630,
+ 9631,
+ 9632,
+ 9633,
+ 9634,
+ 9635,
+ 9636,
+ 9637,
+ 9638,
+ 9639,
+ 9640,
+ 9641,
+ 9642,
+ 9643,
+ 9644,
+ 9645,
+ 9646,
+ 9647,
+ 9648,
+ 9649,
+ 9650,
+ 9651,
+ 9652,
+ 9653,
+ 9654,
+ 9655,
+ 9656,
+ 9657,
+ 9658,
+ 9659,
+ 9660,
+ 9661,
+ 9662,
+ 9663,
+ 9664,
+ 9665,
+ 9666,
+ 9667,
+ 9668,
+ 9669,
+ 9670,
+ 9671,
+ 9672,
+ 9673,
+ 9674,
+ 9675,
+ 9676,
+ 9677,
+ 9678,
+ 9679,
+ 9680,
+ 9681,
+ 9682,
+ 9683,
+ 9684,
+ 9685,
+ 9686,
+ 9687,
+ 9688,
+ 9689,
+ 9690,
+ 9691,
+ 9692,
+ 9693,
+ 9694,
+ 9695,
+ 9696,
+ 9697,
+ 9698,
+ 9699,
+ 9700,
+ 9701,
+ 9702,
+ 9703,
+ 9704,
+ 9705,
+ 9706,
+ 9707,
+ 9708,
+ 9709,
+ 9710,
+ 9711,
+ 9712,
+ 9713,
+ 9714,
+ 9715,
+ 9716,
+ 9717,
+ 9718,
+ 9719,
+ 9720,
+ 9721,
+ 9722,
+ 9723,
+ 9724,
+ 9725,
+ 9726,
+ 9727,
+ 9728,
+ 9729,
+ 9730,
+ 9731,
+ 9732,
+ 9733,
+ 9734,
+ 9735,
+ 9736,
+ 9737,
+ 9738,
+ 9739,
+ 9740,
+ 9741,
+ 9742,
+ 9743,
+ 9744,
+ 9745,
+ 9746,
+ 9747,
+ 9748,
+ 9749,
+ 9750,
+ 9751,
+ 9752,
+ 9753,
+ 9754,
+ 9755,
+ 9756,
+ 9757,
+ 9758,
+ 9759,
+ 9760,
+ 9761,
+ 9762,
+ 9763,
+ 9764,
+ 9765,
+ 9766,
+ 9767,
+ 9768,
+ 9769,
+ 9770,
+ 9771,
+ 9772,
+ 9773,
+ 9774,
+ 9775,
+ 9776,
+ 9777,
+ 9778,
+ 9779,
+ 9780,
+ 9781,
+ 9782,
+ 9783,
+ 9784,
+ 9785,
+ 9786,
+ 9787,
+ 9788,
+ 9789,
+ 9790,
+ 9791,
+ 9792,
+ 9793,
+ 9794,
+ 9795,
+ 9796,
+ 9797,
+ 9798,
+ 9799,
+ 9800,
+ 9801,
+ 9802,
+ 9803,
+ 9804,
+ 9805,
+ 9806,
+ 9807,
+ 9808,
+ 9809,
+ 9810,
+ 9811,
+ 9812,
+ 9813,
+ 9814,
+ 9815,
+ 9816,
+ 9817,
+ 9818,
+ 9819,
+ 9820,
+ 9821,
+ 9822,
+ 9823,
+ 9824,
+ 9825,
+ 9826,
+ 9827,
+ 9828,
+ 9829,
+ 9830,
+ 9831,
+ 9832,
+ 9833,
+ 9834,
+ 9835,
+ 9836,
+ 9837,
+ 9838,
+ 9839,
+ 9840,
+ 9841,
+ 9842,
+ 9843,
+ 9844,
+ 9845,
+ 9846,
+ 9847,
+ 9848,
+ 9849,
+ 9850,
+ 9851,
+ 9852,
+ 9853,
+ 9854,
+ 9855,
+ 9856,
+ 9857,
+ 9858,
+ 9859,
+ 9860,
+ 9861,
+ 9862,
+ 9863,
+ 9864,
+ 9865,
+ 9866,
+ 9867,
+ 9868,
+ 9869,
+ 9870,
+ 9871,
+ 9872,
+ 9873,
+ 9874,
+ 9875,
+ 9876,
+ 9877,
+ 9878,
+ 9879,
+ 9880,
+ 9881,
+ 9882,
+ 9883,
+ 9884,
+ 9885,
+ 9886,
+ 9887,
+ 9888,
+ 9889,
+ 9890,
+ 9891,
+ 9892,
+ 9893,
+ 9894,
+ 9895,
+ 9896,
+ 9897,
+ 9898,
+ 9899,
+ 9900,
+ 9901,
+ 9902,
+ 9903,
+ 9904,
+ 9905,
+ 9906,
+ 9907,
+ 9908,
+ 9909,
+ 9910,
+ 9911,
+ 9912,
+ 9913,
+ 9914,
+ 9915,
+ 9916,
+ 9917,
+ 9918,
+ 9919,
+ 9920,
+ 9921,
+ 9922,
+ 9923,
+ 9924,
+ 9925,
+ 9926,
+ 9927,
+ 9928,
+ 9929,
+ 9930,
+ 9931,
+ 9932,
+ 9933,
+ 9934,
+ 9935,
+ 9936,
+ 9937,
+ 9938,
+ 9939,
+ 9940,
+ 9941,
+ 9942,
+ 9943,
+ 9944,
+ 9945,
+ 9946,
+ 9947,
+ 9948,
+ 9949,
+ 9950,
+ 9951,
+ 9952,
+ 9953,
+ 9954,
+ 9955,
+ 9956,
+ 9957,
+ 9958,
+ 9959,
+ 9960,
+ 9961,
+ 9962,
+ 9963,
+ 9964,
+ 9965,
+ 9966,
+ 9967,
+ 9968,
+ 9969,
+ 9970,
+ 9971,
+ 9972,
+ 9973,
+ 9974,
+ 9975,
+ 9976,
+ 9977,
+ 9978,
+ 9979,
+ 9980,
+ 9981,
+ 9982,
+ 9983,
+ 9984,
+ 9985,
+ 9986,
+ 9987,
+ 9988,
+ 9989,
+ 9990,
+ 9991,
+ 9992,
+ 9993,
+ 9994,
+ 9995,
+ 9996,
+ 9997,
+ 9998,
+ 9999,
+ 10000,
+ 10001,
+ 10002,
+ 10003,
+ 10004,
+ 10005,
+ 10006,
+ 10007,
+ 10008,
+ 10009,
+ 10010,
+ 10011,
+ 10012,
+ 10013,
+ 10014,
+ 10015,
+ 10016,
+ 10017,
+ 10018,
+ 10019,
+ 10020,
+ 10021,
+ 10022,
+ 10023,
+ 10024,
+ 10025,
+ 10026,
+ 10027,
+ 10028,
+ 10029,
+ 10030,
+ 10031,
+ 10032,
+ 10033,
+ 10034,
+ 10035,
+ 10036,
+ 10037,
+ 10038,
+ 10039,
+ 10040,
+ 10041,
+ 10042,
+ 10043,
+ 10044,
+ 10045,
+ 10046,
+ 10047,
+ 10048,
+ 10049,
+ 10050,
+ 10051,
+ 10052,
+ 10053,
+ 10054,
+ 10055,
+ 10056,
+ 10057,
+ 10058,
+ 10059,
+ 10060,
+ 10061,
+ 10062,
+ 10063,
+ 10064,
+ 10065,
+ 10066,
+ 10067,
+ 10068,
+ 10069,
+ 10070,
+ 10071,
+ 10072,
+ 10073,
+ 10074,
+ 10075,
+ 10076,
+ 10077,
+ 10078,
+ 10079,
+ 10080,
+ 10081,
+ 10082,
+ 10083,
+ 10084,
+ 10085,
+ 10086,
+ 10087,
+ 10088,
+ 10089,
+ 10090,
+ 10091,
+ 10092,
+ 10093,
+ 10094,
+ 10095,
+ 10096,
+ 10097,
+ 10098,
+ 10099,
+ 10100,
+ 10101,
+ 10102,
+ 10103,
+ 10104,
+ 10105,
+ 10106,
+ 10107,
+ 10108,
+ 10109,
+ 10110,
+ 10111,
+ 10112,
+ 10113,
+ 10114,
+ 10115,
+ 10116,
+ 10117,
+ 10118,
+ 10119,
+ 10120,
+ 10121,
+ 10122,
+ 10123,
+ 10124,
+ 10125,
+ 10126,
+ 10127,
+ 10128,
+ 10129,
+ 10130,
+ 10131,
+ 10132,
+ 10133,
+ 10134,
+ 10135,
+ 10136,
+ 10137,
+ 10138,
+ 10139,
+ 10140,
+ 10141,
+ 10142,
+ 10143,
+ 10144,
+ 10145,
+ 10146,
+ 10147,
+ 10148,
+ 10149,
+ 10150,
+ 10151,
+ 10152,
+ 10153,
+ 10154,
+ 10155,
+ 10156,
+ 10157,
+ 10158,
+ 10159,
+ 10160,
+ 10161,
+ 10162,
+ 10163,
+ 10164,
+ 10165,
+ 10166,
+ 10167,
+ 10168,
+ 10169,
+ 10170,
+ 10171,
+ 10172,
+ 10173,
+ 10174,
+ 10175,
+ 10176,
+ 10177,
+ 10178,
+ 10179,
+ 10180,
+ 10181,
+ 10182,
+ 10183,
+ 10184,
+ 10185,
+ 10186,
+ 10187,
+ 10188,
+ 10189,
+ 10190,
+ 10191,
+ 10192,
+ 10193,
+ 10194,
+ 10195,
+ 10196,
+ 10197,
+ 10198,
+ 10199,
+ 10200,
+ 10201,
+ 10202,
+ 10203,
+ 10204,
+ 10205,
+ 10206,
+ 10207,
+ 10208,
+ 10209,
+ 10210,
+ 10211,
+ 10212,
+ 10213,
+ 10214,
+ 10215,
+ 10216,
+ 10217,
+ 10218,
+ 10219,
+ 10220,
+ 10221,
+ 10222,
+ 10223,
+ 10224,
+ 10225,
+ 10226,
+ 10227,
+ 10228,
+ 10229,
+ 10230,
+ 10231,
+ 10232,
+ 10233,
+ 10234,
+ 10235,
+ 10236,
+ 10237,
+ 10238,
+ 10239,
+ 10240,
+ 10241,
+ 10242,
+ 10243,
+ 10244,
+ 10245,
+ 10246,
+ 10247,
+ 10248,
+ 10249,
+ 10250,
+ 10251,
+ 10252,
+ 10253,
+ 10254,
+ 10255,
+ 10256,
+ 10257,
+ 10258,
+ 10259,
+ 10260,
+ 10261,
+ 10262,
+ 10263,
+ 10264,
+ 10265,
+ 10266,
+ 10267,
+ 10268,
+ 10269,
+ 10270,
+ 10271,
+ 10272,
+ 10273,
+ 10274,
+ 10275,
+ 10276,
+ 10277,
+ 10278,
+ 10279,
+ 10280,
+ 10281,
+ 10282,
+ 10283,
+ 10284,
+ 10285,
+ 10286,
+ 10287,
+ 10288,
+ 10289,
+ 10290,
+ 10291,
+ 10292,
+ 10293,
+ 10294,
+ 10295,
+ 10296,
+ 10297,
+ 10298,
+ 10299,
+ 10300,
+ 10301,
+ 10302,
+ 10303,
+ 10304,
+ 10305,
+ 10306,
+ 10307,
+ 10308,
+ 10309,
+ 10310,
+ 10311,
+ 10312,
+ 10313,
+ 10314,
+ 10315,
+ 10316,
+ 10317,
+ 10318,
+ 10319,
+ 10320,
+ 10321,
+ 10322,
+ 10323,
+ 10324,
+ 10325,
+ 10326,
+ 10327,
+ 10328,
+ 10329,
+ 10330,
+ 10331,
+ 10332,
+ 10333,
+ 10334,
+ 10335,
+ 10336,
+ 10337,
+ 10338,
+ 10339,
+ 10340,
+ 10341,
+ 10342,
+ 10343,
+ 10344,
+ 10345,
+ 10346,
+ 10347,
+ 10348,
+ 10349,
+ 10350,
+ 10351,
+ 10352,
+ 10353,
+ 10354,
+ 10355,
+ 10356,
+ 10357,
+ 10358,
+ 10359,
+ 10360,
+ 10361,
+ 10362,
+ 10363,
+ 10364,
+ 10365,
+ 10366,
+ 10367,
+ 10368,
+ 10369,
+ 10370,
+ 10371,
+ 10372,
+ 10373,
+ 10374,
+ 10375,
+ 10376,
+ 10377,
+ 10378,
+ 10379,
+ 10380,
+ 10381,
+ 10382,
+ 10383,
+ 10384,
+ 10385,
+ 10386,
+ 10387,
+ 10388,
+ 10389,
+ 10390,
+ 10391,
+ 10392,
+ 10393,
+ 10394,
+ 10395,
+ 10396,
+ 10397,
+ 10398,
+ 10399,
+ 10400,
+ 10401,
+ 10402,
+ 10403,
+ 10404,
+ 10405,
+ 10406,
+ 10407,
+ 10408,
+ 10409,
+ 10410,
+ 10411,
+ 10412,
+ 10413,
+ 10414,
+ 10415,
+ 10416,
+ 10417,
+ 10418,
+ 10419,
+ 10420,
+ 10421,
+ 10422,
+ 10423,
+ 10424,
+ 10425,
+ 10426,
+ 10427,
+ 10428,
+ 10429,
+ 10430,
+ 10431,
+ 10432,
+ 10433,
+ 10434,
+ 10435,
+ 10436,
+ 10437,
+ 10438,
+ 10439,
+ 10440,
+ 10441,
+ 10442,
+ 10443,
+ 10444,
+ 10445,
+ 10446,
+ 10447,
+ 10448,
+ 10449,
+ 10450,
+ 10451,
+ 10452,
+ 10453,
+ 10454,
+ 10455,
+ 10456,
+ 10457,
+ 10458,
+ 10459,
+ 10460,
+ 10461,
+ 10462,
+ 10463,
+ 10464,
+ 10465,
+ 10466,
+ 10467,
+ 10468,
+ 10469,
+ 10470,
+ 10471,
+ 10472,
+ 10473,
+ 10474,
+ 10475,
+ 10476,
+ 10477,
+ 10478,
+ 10479,
+ 10480,
+ 10481,
+ 10482,
+ 10483,
+ 10484,
+ 10485,
+ 10486,
+ 10487,
+ 10488,
+ 10489,
+ 10490,
+ 10491,
+ 10492,
+ 10493,
+ 10494,
+ 10495,
+ 10496,
+ 10497,
+ 10498,
+ 10499,
+ 10500,
+ 10501,
+ 10502,
+ 10503,
+ 10504,
+ 10505,
+ 10506,
+ 10507,
+ 10508,
+ 10509,
+ 10510,
+ 10511,
+ 10512,
+ 10513,
+ 10514,
+ 10515,
+ 10516,
+ 10517,
+ 10518,
+ 10519,
+ 10520,
+ 10521,
+ 10522,
+ 10523,
+ 10524,
+ 10525,
+ 10526,
+ 10527,
+ 10528,
+ 10529,
+ 10530,
+ 10531,
+ 10532,
+ 10533,
+ 10534,
+ 10535,
+ 10536,
+ 10537,
+ 10538,
+ 10539,
+ 10540,
+ 10541,
+ 10542,
+ 10543,
+ 10544,
+ 10545,
+ 10546,
+ 10547,
+ 10548,
+ 10549,
+ 10550,
+ 10551,
+ 10552,
+ 10553,
+ 10554,
+ 10555,
+ 10556,
+ 10557,
+ 10558,
+ 10559,
+ 10560,
+ 10561,
+ 10562,
+ 10563,
+ 10564,
+ 10565,
+ 10566,
+ 10567,
+ 10568,
+ 10569,
+ 10570,
+ 10571,
+ 10572,
+ 10573,
+ 10574,
+ 10575,
+ 10576,
+ 10577,
+ 10578,
+ 10579,
+ 10580,
+ 10581,
+ 10582,
+ 10583,
+ 10584,
+ 10585,
+ 10586,
+ 10587,
+ 10588,
+ 10589,
+ 10590,
+ 10591,
+ 10592,
+ 10593,
+ 10594,
+ 10595,
+ 10596,
+ 10597,
+ 10598,
+ 10599,
+ 10600,
+ 10601,
+ 10602,
+ 10603,
+ 10604,
+ 10605,
+ 10606,
+ 10607,
+ 10608,
+ 10609,
+ 10610,
+ 10611,
+ 10612,
+ 10613,
+ 10614,
+ 10615,
+ 10616,
+ 10617,
+ 10618,
+ 10619,
+ 10620,
+ 10621,
+ 10622,
+ 10623,
+ 10624,
+ 10625,
+ 10626,
+ 10627,
+ 10628,
+ 10629,
+ 10630,
+ 10631,
+ 10632,
+ 10633,
+ 10634,
+ 10635,
+ 10636,
+ 10637,
+ 10638,
+ 10639,
+ 10640,
+ 10641,
+ 10642,
+ 10643,
+ 10644,
+ 10645,
+ 10646,
+ 10647,
+ 10648,
+ 10649,
+ 10650,
+ 10651,
+ 10652,
+ 10653,
+ 10654,
+ 10655,
+ 10656,
+ 10657,
+ 10658,
+ 10659,
+ 10660,
+ 10661,
+ 10662,
+ 10663,
+ 10664,
+ 10665,
+ 10666,
+ 10667,
+ 10668,
+ 10669,
+ 10670,
+ 10671,
+ 10672,
+ 10673,
+ 10674,
+ 10675,
+ 10676,
+ 10677,
+ 10678,
+ 10679,
+ 10680,
+ 10681,
+ 10682,
+ 10683,
+ 10684,
+ 10685,
+ 10686,
+ 10687,
+ 10688,
+ 10689,
+ 10690,
+ 10691,
+ 10692,
+ 10693,
+ 10694,
+ 10695,
+ 10696,
+ 10697,
+ 10698,
+ 10699,
+ 10700,
+ 10701,
+ 10702,
+ 10703,
+ 10704,
+ 10705,
+ 10706,
+ 10707,
+ 10708,
+ 10709,
+ 10710,
+ 10711,
+ 10712,
+ 10713,
+ 10714,
+ 10715,
+ 10716,
+ 10717,
+ 10718,
+ 10719,
+ 10720,
+ 10721,
+ 10722,
+ 10723,
+ 10724,
+ 10725,
+ 10726,
+ 10727,
+ 10728,
+ 10729,
+ 10730,
+ 10731,
+ 10732,
+ 10733,
+ 10734,
+ 10735,
+ 10736,
+ 10737,
+ 10738,
+ 10739,
+ 10740,
+ 10741,
+ 10742,
+ 10743,
+ 10744,
+ 10745,
+ 10746,
+ 10747,
+ 10748,
+ 10749,
+ 10750,
+ 10751,
+ 10752,
+ 10753,
+ 10754,
+ 10755,
+ 10756,
+ 10757,
+ 10758,
+ 10759,
+ 10760,
+ 10761,
+ 10762,
+ 10763,
+ 10764,
+ 10765,
+ 10766,
+ 10767,
+ 10768,
+ 10769,
+ 10770,
+ 10771,
+ 10772,
+ 10773,
+ 10774,
+ 10775,
+ 10776,
+ 10777,
+ 10778,
+ 10779,
+ 10780,
+ 10781,
+ 10782,
+ 10783,
+ 10784,
+ 10785,
+ 10786,
+ 10787,
+ 10788,
+ 10789,
+ 10790,
+ 10791,
+ 10792,
+ 10793,
+ 10794,
+ 10795,
+ 10796,
+ 10797,
+ 10798,
+ 10799,
+ 10800,
+ 10801,
+ 10802,
+ 10803,
+ 10804,
+ 10805,
+ 10806,
+ 10807,
+ 10808,
+ 10809,
+ 10810,
+ 10811,
+ 10812,
+ 10813,
+ 10814,
+ 10815,
+ 10816,
+ 10817,
+ 10818,
+ 10819,
+ 10820,
+ 10821,
+ 10822,
+ 10823,
+ 10824,
+ 10825,
+ 10826,
+ 10827,
+ 10828,
+ 10829,
+ 10830,
+ 10831,
+ 10832,
+ 10833,
+ 10834,
+ 10835,
+ 10836,
+ 10837,
+ 10838,
+ 10839,
+ 10840,
+ 10841,
+ 10842,
+ 10843,
+ 10844,
+ 10845,
+ 10846,
+ 10847,
+ 10848,
+ 10849,
+ 10850,
+ 10851,
+ 10852,
+ 10853,
+ 10854,
+ 10855,
+ 10856,
+ 10857,
+ 10858,
+ 10859,
+ 10860,
+ 10861,
+ 10862,
+ 10863,
+ 10864,
+ 10865,
+ 10866,
+ 10867,
+ 10868,
+ 10869,
+ 10870,
+ 10871,
+ 10872,
+ 10873,
+ 10874,
+ 10875,
+ 10876,
+ 10877,
+ 10878,
+ 10879,
+ 10880,
+ 10881,
+ 10882,
+ 10883,
+ 10884,
+ 10885,
+ 10886,
+ 10887,
+ 10888,
+ 10889,
+ 10890,
+ 10891,
+ 10892,
+ 10893,
+ 10894,
+ 10895,
+ 10896,
+ 10897,
+ 10898,
+ 10899,
+ 10900,
+ 10901,
+ 10902,
+ 10903,
+ 10904,
+ 10905,
+ 10906,
+ 10907,
+ 10908,
+ 10909,
+ 10910,
+ 10911,
+ 10912,
+ 10913,
+ 10914,
+ 10915,
+ 10916,
+ 10917,
+ 10918,
+ 10919,
+ 10920,
+ 10921,
+ 10922,
+ 10923,
+ 10924,
+ 10925,
+ 10926,
+ 10927,
+ 10928,
+ 10929,
+ 10930,
+ 10931,
+ 10932,
+ 10933,
+ 10934,
+ 10935,
+ 10936,
+ 10937,
+ 10938,
+ 10939,
+ 10940,
+ 10941,
+ 10942,
+ 10943,
+ 10944,
+ 10945,
+ 10946,
+ 10947,
+ 10948,
+ 10949,
+ 10950,
+ 10951,
+ 10952,
+ 10953,
+ 10954,
+ 10955,
+ 10956,
+ 10957,
+ 10958,
+ 10959,
+ 10960,
+ 10961,
+ 10962,
+ 10963,
+ 10964,
+ 10965,
+ 10966,
+ 10967,
+ 10968,
+ 10969,
+ 10970,
+ 10971,
+ 10972,
+ 10973,
+ 10974,
+ 10975,
+ 10976,
+ 10977,
+ 10978,
+ 10979,
+ 10980,
+ 10981,
+ 10982,
+ 10983,
+ 10984,
+ 10985,
+ 10986,
+ 10987,
+ 10988,
+ 10989,
+ 10990,
+ 10991,
+ 10992,
+ 10993,
+ 10994,
+ 10995,
+ 10996,
+ 10997,
+ 10998,
+ 10999,
+ 11000,
+ 11001,
+ 11002,
+ 11003,
+ 11004,
+ 11005,
+ 11006,
+ 11007,
+ 11008,
+ 11009,
+ 11010,
+ 11011,
+ 11012,
+ 11013,
+ 11014,
+ 11015,
+ 11016,
+ 11017,
+ 11018,
+ 11019,
+ 11020,
+ 11021,
+ 11022,
+ 11023,
+ 11024,
+ 11025,
+ 11026,
+ 11027,
+ 11028,
+ 11029,
+ 11030,
+ 11031,
+ 11032,
+ 11033,
+ 11034,
+ 11035,
+ 11036,
+ 11037,
+ 11038,
+ 11039,
+ 11040,
+ 11041,
+ 11042,
+ 11043,
+ 11044,
+ 11045,
+ 11046,
+ 11047,
+ 11048,
+ 11049,
+ 11050,
+ 11051,
+ 11052,
+ 11053,
+ 11054,
+ 11055,
+ 11056,
+ 11057,
+ 11058,
+ 11059,
+ 11060,
+ 11061,
+ 11062,
+ 11063,
+ 11064,
+ 11065,
+ 11066,
+ 11067,
+ 11068,
+ 11069,
+ 11070,
+ 11071,
+ 11072,
+ 11073,
+ 11074,
+ 11075,
+ 11076,
+ 11077,
+ 11078,
+ 11079,
+ 11080,
+ 11081,
+ 11082,
+ 11083,
+ 11084,
+ 11085,
+ 11086,
+ 11087,
+ 11088,
+ 11089,
+ 11090,
+ 11091,
+ 11092,
+ 11093,
+ 11094,
+ 11095,
+ 11096,
+ 11097,
+ 11098,
+ 11099,
+ 11100,
+ 11101,
+ 11102,
+ 11103,
+ 11104,
+ 11105,
+ 11106,
+ 11107,
+ 11108,
+ 11109,
+ 11110,
+ 11111,
+ 11112,
+ 11113,
+ 11114,
+ 11115,
+ 11116,
+ 11117,
+ 11118,
+ 11119,
+ 11120,
+ 11121,
+ 11122,
+ 11123,
+ 11124,
+ 11125,
+ 11126,
+ 11127,
+ 11128,
+ 11129,
+ 11130,
+ 11131,
+ 11132,
+ 11133,
+ 11134,
+ 11135,
+ 11136,
+ 11137,
+ 11138,
+ 11139,
+ 11140,
+ 11141,
+ 11142,
+ 11143,
+ 11144,
+ 11145,
+ 11146,
+ 11147,
+ 11148,
+ 11149,
+ 11150,
+ 11151,
+ 11152,
+ 11153,
+ 11154,
+ 11155,
+ 11156,
+ 11157,
+ 11158,
+ 11159,
+ 11160,
+ 11161,
+ 11162,
+ 11163,
+ 11164,
+ 11165,
+ 11166,
+ 11167,
+ 11168,
+ 11169,
+ 11170,
+ 11171,
+ 11172,
+ 11173,
+ 11174,
+ 11175,
+ 11176,
+ 11177,
+ 11178,
+ 11179,
+ 11180,
+ 11181,
+ 11182,
+ 11183,
+ 11184,
+ 11185,
+ 11186,
+ 11187,
+ 11188,
+ 11189,
+ 11190,
+ 11191,
+ 11192,
+ 11193,
+ 11194,
+ 11195,
+ 11196,
+ 11197,
+ 11198,
+ 11199,
+ 11200,
+ 11201,
+ 11202,
+ 11203,
+ 11204,
+ 11205,
+ 11206,
+ 11207,
+ 11208,
+ 11209,
+ 11210,
+ 11211,
+ 11212,
+ 11213,
+ 11214,
+ 11215,
+ 11216,
+ 11217,
+ 11218,
+ 11219,
+ 11220,
+ 11221,
+ 11222,
+ 11223,
+ 11224,
+ 11225,
+ 11226,
+ 11227,
+ 11228,
+ 11229,
+ 11230,
+ 11231,
+ 11232,
+ 11233,
+ 11234,
+ 11235,
+ 11236,
+ 11237,
+ 11238,
+ 11239,
+ 11240,
+ 11241,
+ 11242,
+ 11243,
+ 11244,
+ 11245,
+ 11246,
+ 11247,
+ 11248,
+ 11249,
+ 11250,
+ 11251,
+ 11252,
+ 11253,
+ 11254,
+ 11255,
+ 11256,
+ 11257,
+ 11258,
+ 11259,
+ 11260,
+ 11261,
+ 11262,
+ 11263,
+ 11264,
+ 11265,
+ 11266,
+ 11267,
+ 11268,
+ 11269,
+ 11270,
+ 11271,
+ 11272,
+ 11273,
+ 11274,
+ 11275,
+ 11276,
+ 11277,
+ 11278,
+ 11279,
+ 11280,
+ 11281,
+ 11282,
+ 11283,
+ 11284,
+ 11285,
+ 11286,
+ 11287,
+ 11288,
+ 11289,
+ 11290,
+ 11291,
+ 11292,
+ 11293,
+ 11294,
+ 11295,
+ 11296,
+ 11297,
+ 11298,
+ 11299,
+ 11300,
+ 11301,
+ 11302,
+ 11303,
+ 11304,
+ 11305,
+ 11306,
+ 11307,
+ 11308,
+ 11309,
+ 11310,
+ 11311,
+ 11312,
+ 11313,
+ 11314,
+ 11315,
+ 11316,
+ 11317,
+ 11318,
+ 11319,
+ 11320,
+ 11321,
+ 11322,
+ 11323,
+ 11324,
+ 11325,
+ 11326,
+ 11327,
+ 11328,
+ 11329,
+ 11330,
+ 11331,
+ 11332,
+ 11333,
+ 11334,
+ 11335,
+ 11336,
+ 11337,
+ 11338,
+ 11339,
+ 11340,
+ 11341,
+ 11342,
+ 11343,
+ 11344,
+ 11345,
+ 11346,
+ 11347,
+ 11348,
+ 11349,
+ 11350,
+ 11351,
+ 11352,
+ 11353,
+ 11354,
+ 11355,
+ 11356,
+ 11357,
+ 11358,
+ 11359,
+ 11360,
+ 11361,
+ 11362,
+ 11363,
+ 11364,
+ 11365,
+ 11366,
+ 11367,
+ 11368,
+ 11369,
+ 11370,
+ 11371,
+ 11372,
+ 11373,
+ 11374,
+ 11375,
+ 11376,
+ 11377,
+ 11378,
+ 11379,
+ 11380,
+ 11381,
+ 11382,
+ 11383,
+ 11384,
+ 11385,
+ 11386,
+ 11387,
+ 11388,
+ 11389,
+ 11390,
+ 11391,
+ 11392,
+ 11393,
+ 11394,
+ 11395,
+ 11396,
+ 11397,
+ 11398,
+ 11399,
+ 11400,
+ 11401,
+ 11402,
+ 11403,
+ 11404,
+ 11405,
+ 11406,
+ 11407,
+ 11408,
+ 11409,
+ 11410,
+ 11411,
+ 11412,
+ 11413,
+ 11414,
+ 11415,
+ 11416,
+ 11417,
+ 11418,
+ 11419,
+ 11420,
+ 11421,
+ 11422,
+ 11423,
+ 11424,
+ 11425,
+ 11426,
+ 11427,
+ 11428,
+ 11429,
+ 11430,
+ 11431,
+ 11432,
+ 11433,
+ 11434,
+ 11435,
+ 11436,
+ 11437,
+ 11438,
+ 11439,
+ 11440,
+ 11441,
+ 11442,
+ 11443,
+ 11444,
+ 11445,
+ 11446,
+ 11447,
+ 11448,
+ 11449,
+ 11450,
+ 11451,
+ 11452,
+ 11453,
+ 11454,
+ 11455,
+ 11456,
+ 11457,
+ 11458,
+ 11459,
+ 11460,
+ 11461,
+ 11462,
+ 11463,
+ 11464,
+ 11465,
+ 11466,
+ 11467,
+ 11468,
+ 11469,
+ 11470,
+ 11471,
+ 11472,
+ 11473,
+ 11474,
+ 11475,
+ 11476,
+ 11477,
+ 11478,
+ 11479,
+ 11480,
+ 11481,
+ 11482,
+ 11483,
+ 11484,
+ 11485,
+ 11486,
+ 11487,
+ 11488,
+ 11489,
+ 11490,
+ 11491,
+ 11492,
+ 11493,
+ 11494,
+ 11495,
+ 11496,
+ 11497,
+ 11498,
+ 11499,
+ 11500,
+ 11501,
+ 11502,
+ 11503,
+ 11504,
+ 11505,
+ 11506,
+ 11507,
+ 11508,
+ 11509,
+ 11510,
+ 11511,
+ 11512,
+ 11513,
+ 11514,
+ 11515,
+ 11516,
+ 11517,
+ 11518,
+ 11519,
+ 11520,
+ 11521,
+ 11522,
+ 11523,
+ 11524,
+ 11525,
+ 11526,
+ 11527,
+ 11528,
+ 11529,
+ 11530,
+ 11531,
+ 11532,
+ 11533,
+ 11534,
+ 11535,
+ 11536,
+ 11537,
+ 11538,
+ 11539,
+ 11540,
+ 11541,
+ 11542,
+ 11543,
+ 11544,
+ 11545,
+ 11546,
+ 11547,
+ 11548,
+ 11549,
+ 11550,
+ 11551,
+ 11552,
+ 11553,
+ 11554,
+ 11555,
+ 11556,
+ 11557,
+ 11558,
+ 11559,
+ 11560,
+ 11561,
+ 11562,
+ 11563,
+ 11564,
+ 11565,
+ 11566,
+ 11567,
+ 11568,
+ 11569,
+ 11570,
+ 11571,
+ 11572,
+ 11573,
+ 11574,
+ 11575,
+ 11576,
+ 11577,
+ 11578,
+ 11579,
+ 11580,
+ 11581,
+ 11582,
+ 11583,
+ 11584,
+ 11585,
+ 11586,
+ 11587,
+ 11588,
+ 11589,
+ 11590,
+ 11591,
+ 11592,
+ 11593,
+ 11594,
+ 11595,
+ 11596,
+ 11597,
+ 11598,
+ 11599,
+ 11600,
+ 11601,
+ 11602,
+ 11603,
+ 11604,
+ 11605,
+ 11606,
+ 11607,
+ 11608,
+ 11609,
+ 11610,
+ 11611,
+ 11612,
+ 11613,
+ 11614,
+ 11615,
+ 11616,
+ 11617,
+ 11618,
+ 11619,
+ 11620,
+ 11621,
+ 11622,
+ 11623,
+ 11624,
+ 11625,
+ 11626,
+ 11627,
+ 11628,
+ 11629,
+ 11630,
+ 11631,
+ 11632,
+ 11633,
+ 11634,
+ 11635,
+ 11636,
+ 11637,
+ 11638,
+ 11639,
+ 11640,
+ 11641,
+ 11642,
+ 11643,
+ 11644,
+ 11645,
+ 11646,
+ 11647,
+ 11648,
+ 11649,
+ 11650,
+ 11651,
+ 11652,
+ 11653,
+ 11654,
+ 11655,
+ 11656,
+ 11657,
+ 11658,
+ 11659,
+ 11660,
+ 11661,
+ 11662,
+ 11663,
+ 11664,
+ 11665,
+ 11666,
+ 11667,
+ 11668,
+ 11669,
+ 11670,
+ 11671,
+ 11672,
+ 11673,
+ 11674,
+ 11675,
+ 11676,
+ 11677,
+ 11678,
+ 11679,
+ 11680,
+ 11681,
+ 11682,
+ 11683,
+ 11684,
+ 11685,
+ 11686,
+ 11687,
+ 11688,
+ 11689,
+ 11690,
+ 11691,
+ 11692,
+ 11693,
+ 11694,
+ 11695,
+ 11696,
+ 11697,
+ 11698,
+ 11699,
+ 11700,
+ 11701,
+ 11702,
+ 11703,
+ 11704,
+ 11705,
+ 11706,
+ 11707,
+ 11708,
+ 11709,
+ 11710,
+ 11711,
+ 11712,
+ 11713,
+ 11714,
+ 11715,
+ 11716,
+ 11717,
+ 11718,
+ 11719,
+ 11720,
+ 11721,
+ 11722,
+ 11723,
+ 11724,
+ 11725,
+ 11726,
+ 11727,
+ 11728,
+ 11729,
+ 11730,
+ 11731,
+ 11732,
+ 11733,
+ 11734,
+ 11735,
+ 11736,
+ 11737,
+ 11738,
+ 11739,
+ 11740,
+ 11741,
+ 11742,
+ 11743,
+ 11744,
+ 11745,
+ 11746,
+ 11747,
+ 11748,
+ 11749,
+ 11750,
+ 11751,
+ 11752,
+ 11753,
+ 11754,
+ 11755,
+ 11756,
+ 11757,
+ 11758,
+ 11759,
+ 11760,
+ 11761,
+ 11762,
+ 11763,
+ 11764,
+ 11765,
+ 11766,
+ 11767,
+ 11768,
+ 11769,
+ 11770,
+ 11771,
+ 11772,
+ 11773,
+ 11774,
+ 11775,
+ 11776,
+ 11777,
+ 11778,
+ 11779,
+ 11780,
+ 11781,
+ 11782,
+ 11783,
+ 11784,
+ 11785,
+ 11786,
+ 11787,
+ 11788,
+ 11789,
+ 11790,
+ 11791,
+ 11792,
+ 11793,
+ 11794,
+ 11795,
+ 11796,
+ 11797,
+ 11798,
+ 11799,
+ 11800,
+ 11801,
+ 11802,
+ 11803,
+ 11804,
+ 11805,
+ 11806,
+ 11807,
+ 11808,
+ 11809,
+ 11810,
+ 11811,
+ 11812,
+ 11813,
+ 11814,
+ 11815,
+ 11816,
+ 11817,
+ 11818,
+ 11819,
+ 11820,
+ 11821,
+ 11822,
+ 11823,
+ 11824,
+ 11825,
+ 11826,
+ 11827,
+ 11828,
+ 11829,
+ 11830,
+ 11831,
+ 11832,
+ 11833,
+ 11834,
+ 11835,
+ 11836,
+ 11837,
+ 11838,
+ 11839,
+ 11840,
+ 11841,
+ 11842,
+ 11843,
+ 11844,
+ 11845,
+ 11846,
+ 11847,
+ 11848,
+ 11849,
+ 11850,
+ 11851,
+ 11852,
+ 11853,
+ 11854,
+ 11855,
+ 11856,
+ 11857,
+ 11858,
+ 11859,
+ 11860,
+ 11861,
+ 11862,
+ 11863,
+ 11864,
+ 11865,
+ 11866,
+ 11867,
+ 11868,
+ 11869,
+ 11870,
+ 11871,
+ 11872,
+ 11873,
+ 11874,
+ 11875,
+ 11876,
+ 11877,
+ 11878,
+ 11879,
+ 11880,
+ 11881,
+ 11882,
+ 11883,
+ 11884,
+ 11885,
+ 11886,
+ 11887,
+ 11888,
+ 11889,
+ 11890,
+ 11891,
+ 11892,
+ 11893,
+ 11894,
+ 11895,
+ 11896,
+ 11897,
+ 11898,
+ 11899,
+ 11900,
+ 11901,
+ 11902,
+ 11903,
+ 11904,
+ 11905,
+ 11906,
+ 11907,
+ 11908,
+ 11909,
+ 11910,
+ 11911,
+ 11912,
+ 11913,
+ 11914,
+ 11915,
+ 11916,
+ 11917,
+ 11918,
+ 11919,
+ 11920,
+ 11921,
+ 11922,
+ 11923,
+ 11924,
+ 11925,
+ 11926,
+ 11927,
+ 11928,
+ 11929,
+ 11930,
+ 11931,
+ 11932,
+ 11933,
+ 11934,
+ 11935,
+ 11936,
+ 11937,
+ 11938,
+ 11939,
+ 11940,
+ 11941,
+ 11942,
+ 11943,
+ 11944,
+ 11945,
+ 11946,
+ 11947,
+ 11948,
+ 11949,
+ 11950,
+ 11951,
+ 11952,
+ 11953,
+ 11954,
+ 11955,
+ 11956,
+ 11957,
+ 11958,
+ 11959,
+ 11960,
+ 11961,
+ 11962,
+ 11963,
+ 11964,
+ 11965,
+ 11966,
+ 11967,
+ 11968,
+ 11969,
+ 11970,
+ 11971,
+ 11972,
+ 11973,
+ 11974,
+ 11975,
+ 11976,
+ 11977,
+ 11978,
+ 11979,
+ 11980,
+ 11981,
+ 11982,
+ 11983,
+ 11984,
+ 11985,
+ 11986,
+ 11987,
+ 11988,
+ 11989,
+ 11990,
+ 11991,
+ 11992,
+ 11993,
+ 11994,
+ 11995,
+ 11996,
+ 11997,
+ 11998,
+ 11999,
+ 12000,
+ 12001,
+ 12002,
+ 12003,
+ 12004,
+ 12005,
+ 12006,
+ 12007,
+ 12008,
+ 12009,
+ 12010,
+ 12011,
+ 12012,
+ 12013,
+ 12014,
+ 12015,
+ 12016,
+ 12017,
+ 12018,
+ 12019,
+ 12020,
+ 12021,
+ 12022,
+ 12023,
+ 12024,
+ 12025,
+ 12026,
+ 12027,
+ 12028,
+ 12029,
+ 12030,
+ 12031,
+ 12032,
+ 12033,
+ 12034,
+ 12035,
+ 12036,
+ 12037,
+ 12038,
+ 12039,
+ 12040,
+ 12041,
+ 12042,
+ 12043,
+ 12044,
+ 12045,
+ 12046,
+ 12047,
+ 12048,
+ 12049,
+ 12050,
+ 12051,
+ 12052,
+ 12053,
+ 12054,
+ 12055,
+ 12056,
+ 12057,
+ 12058,
+ 12059,
+ 12060,
+ 12061,
+ 12062,
+ 12063,
+ 12064,
+ 12065,
+ 12066,
+ 12067,
+ 12068,
+ 12069,
+ 12070,
+ 12071,
+ 12072,
+ 12073,
+ 12074,
+ 12075,
+ 12076,
+ 12077,
+ 12078,
+ 12079,
+ 12080,
+ 12081,
+ 12082,
+ 12083,
+ 12084,
+ 12085,
+ 12086,
+ 12087,
+ 12088,
+ 12089,
+ 12090,
+ 12091,
+ 12092,
+ 12093,
+ 12094,
+ 12095,
+ 12096,
+ 12097,
+ 12098,
+ 12099,
+ 12100,
+ 12101,
+ 12102,
+ 12103,
+ 12104,
+ 12105,
+ 12106,
+ 12107,
+ 12108,
+ 12109,
+ 12110,
+ 12111,
+ 12112,
+ 12113,
+ 12114,
+ 12115,
+ 12116,
+ 12117,
+ 12118,
+ 12119,
+ 12120,
+ 12121,
+ 12122,
+ 12123,
+ 12124,
+ 12125,
+ 12126,
+ 12127,
+ 12128,
+ 12129,
+ 12130,
+ 12131,
+ 12132,
+ 12133,
+ 12134,
+ 12135,
+ 12136,
+ 12137,
+ 12138,
+ 12139,
+ 12140,
+ 12141,
+ 12142,
+ 12143,
+ 12144,
+ 12145,
+ 12146,
+ 12147,
+ 12148,
+ 12149,
+ 12150,
+ 12151,
+ 12152,
+ 12153,
+ 12154,
+ 12155,
+ 12156,
+ 12157,
+ 12158,
+ 12159,
+ 12160,
+ 12161,
+ 12162,
+ 12163,
+ 12164,
+ 12165,
+ 12166,
+ 12167,
+ 12168,
+ 12169,
+ 12170,
+ 12171,
+ 12172,
+ 12173,
+ 12174,
+ 12175,
+ 12176,
+ 12177,
+ 12178,
+ 12179,
+ 12180,
+ 12181,
+ 12182,
+ 12183,
+ 12184,
+ 12185,
+ 12186,
+ 12187,
+ 12188,
+ 12189,
+ 12190,
+ 12191,
+ 12192,
+ 12193,
+ 12194,
+ 12195,
+ 12196,
+ 12197,
+ 12198,
+ 12199,
+ 12200,
+ 12201,
+ 12202,
+ 12203,
+ 12204,
+ 12205,
+ 12206,
+ 12207,
+ 12208,
+ 12209,
+ 12210,
+ 12211,
+ 12212,
+ 12213,
+ 12214,
+ 12215,
+ 12216,
+ 12217,
+ 12218,
+ 12219,
+ 12220,
+ 12221,
+ 12222,
+ 12223,
+ 12224,
+ 12225,
+ 12226,
+ 12227,
+ 12228,
+ 12229,
+ 12230,
+ 12231,
+ 12232,
+ 12233,
+ 12234,
+ 12235,
+ 12236,
+ 12237,
+ 12238,
+ 12239,
+ 12240,
+ 12241,
+ 12242,
+ 12243,
+ 12244,
+ 12245,
+ 12246,
+ 12247,
+ 12248,
+ 12249,
+ 12250,
+ 12251,
+ 12252,
+ 12253,
+ 12254,
+ 12255,
+ 12256,
+ 12257,
+ 12258,
+ 12259,
+ 12260,
+ 12261,
+ 12262,
+ 12263,
+ 12264,
+ 12265,
+ 12266,
+ 12267,
+ 12268,
+ 12269,
+ 12270,
+ 12271,
+ 12272,
+ 12273,
+ 12274,
+ 12275,
+ 12276,
+ 12277,
+ 12278,
+ 12279,
+ 12280,
+ 12281,
+ 12282,
+ 12283,
+ 12284,
+ 12285,
+ 12286,
+ 12287,
+ 12288,
+ 12289,
+ 12290,
+ 12291,
+ 12292,
+ 12293,
+ 12294,
+ 12295,
+ 12296,
+ 12297,
+ 12298,
+ 12299,
+ 12300,
+ 12301,
+ 12302,
+ 12303,
+ 12304,
+ 12305,
+ 12306,
+ 12307,
+ 12308,
+ 12309,
+ 12310,
+ 12311,
+ 12312,
+ 12313,
+ 12314,
+ 12315,
+ 12316,
+ 12317,
+ 12318,
+ 12319,
+ 12320,
+ 12321,
+ 12322,
+ 12323,
+ 12324,
+ 12325,
+ 12326,
+ 12327,
+ 12328,
+ 12329,
+ 12330,
+ 12331,
+ 12332,
+ 12333,
+ 12334,
+ 12335,
+ 12336,
+ 12337,
+ 12338,
+ 12339,
+ 12340,
+ 12341,
+ 12342,
+ 12343,
+ 12344,
+ 12345,
+ 12346,
+ 12347,
+ 12348,
+ 12349,
+ 12350,
+ 12351,
+ 12352,
+ 12353,
+ 12354,
+ 12355,
+ 12356,
+ 12357,
+ 12358,
+ 12359,
+ 12360,
+ 12361,
+ 12362,
+ 12363,
+ 12364,
+ 12365,
+ 12366,
+ 12367,
+ 12368,
+ 12369,
+ 12370,
+ 12371,
+ 12372,
+ 12373,
+ 12374,
+ 12375,
+ 12376,
+ 12377,
+ 12378,
+ 12379,
+ 12380,
+ 12381,
+ 12382,
+ 12383,
+ 12384,
+ 12385,
+ 12386,
+ 12387,
+ 12388,
+ 12389,
+ 12390,
+ 12391,
+ 12392,
+ 12393,
+ 12394,
+ 12395,
+ 12396,
+ 12397,
+ 12398,
+ 12399,
+ 12400,
+ 12401,
+ 12402,
+ 12403,
+ 12404,
+ 12405,
+ 12406,
+ 12407,
+ 12408,
+ 12409,
+ 12410,
+ 12411,
+ 12412,
+ 12413,
+ 12414,
+ 12415,
+ 12416,
+ 12417,
+ 12418,
+ 12419,
+ 12420,
+ 12421,
+ 12422,
+ 12423,
+ 12424,
+ 12425,
+ 12426,
+ 12427,
+ 12428,
+ 12429,
+ 12430,
+ 12431,
+ 12432,
+ 12433,
+ 12434,
+ 12435,
+ 12436,
+ 12437,
+ 12438,
+ 12439,
+ 12440,
+ 12441,
+ 12442,
+ 12443,
+ 12444,
+ 12445,
+ 12446,
+ 12447,
+ 12448,
+ 12449,
+ 12450,
+ 12451,
+ 12452,
+ 12453,
+ 12454,
+ 12455,
+ 12456,
+ 12457,
+ 12458,
+ 12459,
+ 12460,
+ 12461,
+ 12462,
+ 12463,
+ 12464,
+ 12465,
+ 12466,
+ 12467,
+ 12468,
+ 12469,
+ 12470,
+ 12471,
+ 12472,
+ 12473,
+ 12474,
+ 12475,
+ 12476,
+ 12477,
+ 12478,
+ 12479,
+ 12480,
+ 12481,
+ 12482,
+ 12483,
+ 12484,
+ 12485,
+ 12486,
+ 12487,
+ 12488,
+ 12489,
+ 12490,
+ 12491,
+ 12492,
+ 12493,
+ 12494,
+ 12495,
+ 12496,
+ 12497,
+ 12498,
+ 12499,
+ 12500,
+ 12501,
+ 12502,
+ 12503,
+ 12504,
+ 12505,
+ 12506,
+ 12507,
+ 12508,
+ 12509,
+ 12510,
+ 12511,
+ 12512,
+ 12513,
+ 12514,
+ 12515,
+ 12516,
+ 12517,
+ 12518,
+ 12519,
+ 12520,
+ 12521,
+ 12522,
+ 12523,
+ 12524,
+ 12525,
+ 12526,
+ 12527,
+ 12528,
+ 12529,
+ 12530,
+ 12531,
+ 12532,
+ 12533,
+ 12534,
+ 12535,
+ 12536,
+ 12537,
+ 12538,
+ 12539,
+ 12540,
+ 12541,
+ 12542,
+ 12543,
+ 12544,
+ 12545,
+ 12546,
+ 12547,
+ 12548,
+ 12549,
+ 12550,
+ 12551,
+ 12552,
+ 12553,
+ 12554,
+ 12555,
+ 12556,
+ 12557,
+ 12558,
+ 12559,
+ 12560,
+ 12561,
+ 12562,
+ 12563,
+ 12564,
+ 12565,
+ 12566,
+ 12567,
+ 12568,
+ 12569,
+ 12570,
+ 12571,
+ 12572,
+ 12573,
+ 12574,
+ 12575,
+ 12576,
+ 12577,
+ 12578,
+ 12579,
+ 12580,
+ 12581,
+ 12582,
+ 12583,
+ 12584,
+ 12585,
+ 12586,
+ 12587,
+ 12588,
+ 12589,
+ 12590,
+ 12591,
+ 12592,
+ 12593,
+ 12594,
+ 12595,
+ 12596,
+ 12597,
+ 12598,
+ 12599,
+ 12600,
+ 12601,
+ 12602,
+ 12603,
+ 12604,
+ 12605,
+ 12606,
+ 12607,
+ 12608,
+ 12609,
+ 12610,
+ 12611,
+ 12612,
+ 12613,
+ 12614,
+ 12615,
+ 12616,
+ 12617,
+ 12618,
+ 12619,
+ 12620,
+ 12621,
+ 12622,
+ 12623,
+ 12624,
+ 12625,
+ 12626,
+ 12627,
+ 12628,
+ 12629,
+ 12630,
+ 12631,
+ 12632,
+ 12633,
+ 12634,
+ 12635,
+ 12636,
+ 12637,
+ 12638,
+ 12639,
+ 12640,
+ 12641,
+ 12642,
+ 12643,
+ 12644,
+ 12645,
+ 12646,
+ 12647,
+ 12648,
+ 12649,
+ 12650,
+ 12651,
+ 12652,
+ 12653,
+ 12654,
+ 12655,
+ 12656,
+ 12657,
+ 12658,
+ 12659,
+ 12660,
+ 12661,
+ 12662,
+ 12663,
+ 12664,
+ 12665,
+ 12666,
+ 12667,
+ 12668,
+ 12669,
+ 12670,
+ 12671,
+ 12672,
+ 12673,
+ 12674,
+ 12675,
+ 12676,
+ 12677,
+ 12678,
+ 12679,
+ 12680,
+ 12681,
+ 12682,
+ 12683,
+ 12684,
+ 12685,
+ 12686,
+ 12687,
+ 12688,
+ 12689,
+ 12690,
+ 12691,
+ 12692,
+ 12693,
+ 12694,
+ 12695,
+ 12696,
+ 12697,
+ 12698,
+ 12699,
+ 12700,
+ 12701,
+ 12702,
+ 12703,
+ 12704,
+ 12705,
+ 12706,
+ 12707,
+ 12708,
+ 12709,
+ 12710,
+ 12711,
+ 12712,
+ 12713,
+ 12714,
+ 12715,
+ 12716,
+ 12717,
+ 12718,
+ 12719,
+ 12720,
+ 12721,
+ 12722,
+ 12723,
+ 12724,
+ 12725,
+ 12726,
+ 12727,
+ 12728,
+ 12729,
+ 12730,
+ 12731,
+ 12732,
+ 12733,
+ 12734,
+ 12735,
+ 12736,
+ 12737,
+ 12738,
+ 12739,
+ 12740,
+ 12741,
+ 12742,
+ 12743,
+ 12744,
+ 12745,
+ 12746,
+ 12747,
+ 12748,
+ 12749,
+ 12750,
+ 12751,
+ 12752,
+ 12753,
+ 12754,
+ 12755,
+ 12756,
+ 12757,
+ 12758,
+ 12759,
+ 12760,
+ 12761,
+ 12762,
+ 12763,
+ 12764,
+ 12765,
+ 12766,
+ 12767,
+ 12768,
+ 12769,
+ 12770,
+ 12771,
+ 12772,
+ 12773,
+ 12774,
+ 12775,
+ 12776,
+ 12777,
+ 12778,
+ 12779,
+ 12780,
+ 12781,
+ 12782,
+ 12783,
+ 12784,
+ 12785,
+ 12786,
+ 12787,
+ 12788,
+ 12789,
+ 12790,
+ 12791,
+ 12792,
+ 12793,
+ 12794,
+ 12795,
+ 12796,
+ 12797,
+ 12798,
+ 12799,
+ 12800,
+ 12801,
+ 12802,
+ 12803,
+ 12804,
+ 12805,
+ 12806,
+ 12807,
+ 12808,
+ 12809,
+ 12810,
+ 12811,
+ 12812,
+ 12813,
+ 12814,
+ 12815,
+ 12816,
+ 12817,
+ 12818,
+ 12819,
+ 12820,
+ 12821,
+ 12822,
+ 12823,
+ 12824,
+ 12825,
+ 12826,
+ 12827,
+ 12828,
+ 12829,
+ 12830,
+ 12831,
+ 12832,
+ 12833,
+ 12834,
+ 12835,
+ 12836,
+ 12837,
+ 12838,
+ 12839,
+ 12840,
+ 12841,
+ 12842,
+ 12843,
+ 12844,
+ 12845,
+ 12846,
+ 12847,
+ 12848,
+ 12849,
+ 12850,
+ 12851,
+ 12852,
+ 12853,
+ 12854,
+ 12855,
+ 12856,
+ 12857,
+ 12858,
+ 12859,
+ 12860,
+ 12861,
+ 12862,
+ 12863,
+ 12864,
+ 12865,
+ 12866,
+ 12867,
+ 12868,
+ 12869,
+ 12870,
+ 12871,
+ 12872,
+ 12873,
+ 12874,
+ 12875,
+ 12876,
+ 12877,
+ 12878,
+ 12879,
+ 12880,
+ 12881,
+ 12882,
+ 12883,
+ 12884,
+ 12885,
+ 12886,
+ 12887,
+ 12888,
+ 12889,
+ 12890,
+ 12891,
+ 12892,
+ 12893,
+ 12894,
+ 12895,
+ 12896,
+ 12897,
+ 12898,
+ 12899,
+ 12900,
+ 12901,
+ 12902,
+ 12903,
+ 12904,
+ 12905,
+ 12906,
+ 12907,
+ 12908,
+ 12909,
+ 12910,
+ 12911,
+ 12912,
+ 12913,
+ 12914,
+ 12915,
+ 12916,
+ 12917,
+ 12918,
+ 12919,
+ 12920,
+ 12921,
+ 12922,
+ 12923,
+ 12924,
+ 12925,
+ 12926,
+ 12927,
+ 12928,
+ 12929,
+ 12930,
+ 12931,
+ 12932,
+ 12933,
+ 12934,
+ 12935,
+ 12936,
+ 12937,
+ 12938,
+ 12939,
+ 12940,
+ 12941,
+ 12942,
+ 12943,
+ 12944,
+ 12945,
+ 12946,
+ 12947,
+ 12948,
+ 12949,
+ 12950,
+ 12951,
+ 12952,
+ 12953,
+ 12954,
+ 12955,
+ 12956,
+ 12957,
+ 12958,
+ 12959,
+ 12960,
+ 12961,
+ 12962,
+ 12963,
+ 12964,
+ 12965,
+ 12966,
+ 12967,
+ 12968,
+ 12969,
+ 12970,
+ 12971,
+ 12972,
+ 12973,
+ 12974,
+ 12975,
+ 12976,
+ 12977,
+ 12978,
+ 12979,
+ 12980,
+ 12981,
+ 12982,
+ 12983,
+ 12984,
+ 12985,
+ 12986,
+ 12987,
+ 12988,
+ 12989,
+ 12990,
+ 12991,
+ 12992,
+ 12993,
+ 12994,
+ 12995,
+ 12996,
+ 12997,
+ 12998,
+ 12999,
+ 13000,
+ 13001,
+ 13002,
+ 13003,
+ 13004,
+ 13005,
+ 13006,
+ 13007,
+ 13008,
+ 13009,
+ 13010,
+ 13011,
+ 13012,
+ 13013,
+ 13014,
+ 13015,
+ 13016,
+ 13017,
+ 13018,
+ 13019,
+ 13020,
+ 13021,
+ 13022,
+ 13023,
+ 13024,
+ 13025,
+ 13026,
+ 13027,
+ 13028,
+ 13029,
+ 13030,
+ 13031,
+ 13032,
+ 13033,
+ 13034,
+ 13035,
+ 13036,
+ 13037,
+ 13038,
+ 13039,
+ 13040,
+ 13041,
+ 13042,
+ 13043,
+ 13044,
+ 13045,
+ 13046,
+ 13047,
+ 13048,
+ 13049,
+ 13050,
+ 13051,
+ 13052,
+ 13053,
+ 13054,
+ 13055,
+ 13056,
+ 13057,
+ 13058,
+ 13059,
+ 13060,
+ 13061,
+ 13062,
+ 13063,
+ 13064,
+ 13065,
+ 13066,
+ 13067,
+ 13068,
+ 13069,
+ 13070,
+ 13071,
+ 13072,
+ 13073,
+ 13074,
+ 13075,
+ 13076,
+ 13077,
+ 13078,
+ 13079,
+ 13080,
+ 13081,
+ 13082,
+ 13083,
+ 13084,
+ 13085,
+ 13086,
+ 13087,
+ 13088,
+ 13089,
+ 13090,
+ 13091,
+ 13092,
+ 13093,
+ 13094,
+ 13095,
+ 13096,
+ 13097,
+ 13098,
+ 13099,
+ 13100,
+ 13101,
+ 13102,
+ 13103,
+ 13104,
+ 13105,
+ 13106,
+ 13107,
+ 13108,
+ 13109,
+ 13110,
+ 13111,
+ 13112,
+ 13113,
+ 13114,
+ 13115,
+ 13116,
+ 13117,
+ 13118,
+ 13119,
+ 13120,
+ 13121,
+ 13122,
+ 13123,
+ 13124,
+ 13125,
+ 13126,
+ 13127,
+ 13128,
+ 13129,
+ 13130,
+ 13131,
+ 13132,
+ 13133,
+ 13134,
+ 13135,
+ 13136,
+ 13137,
+ 13138,
+ 13139,
+ 13140,
+ 13141,
+ 13142,
+ 13143,
+ 13144,
+ 13145,
+ 13146,
+ 13147,
+ 13148,
+ 13149,
+ 13150,
+ 13151,
+ 13152,
+ 13153,
+ 13154,
+ 13155,
+ 13156,
+ 13157,
+ 13158,
+ 13159,
+ 13160,
+ 13161,
+ 13162,
+ 13163,
+ 13164,
+ 13165,
+ 13166,
+ 13167,
+ 13168,
+ 13169,
+ 13170,
+ 13171,
+ 13172,
+ 13173,
+ 13174,
+ 13175,
+ 13176,
+ 13177,
+ 13178,
+ 13179,
+ 13180,
+ 13181,
+ 13182,
+ 13183,
+ 13184,
+ 13185,
+ 13186,
+ 13187,
+ 13188,
+ 13189,
+ 13190,
+ 13191,
+ 13192,
+ 13193,
+ 13194,
+ 13195,
+ 13196,
+ 13197,
+ 13198,
+ 13199,
+ 13200,
+ 13201,
+ 13202,
+ 13203,
+ 13204,
+ 13205,
+ 13206,
+ 13207,
+ 13208,
+ 13209,
+ 13210,
+ 13211,
+ 13212,
+ 13213,
+ 13214,
+ 13215,
+ 13216,
+ 13217,
+ 13218,
+ 13219,
+ 13220,
+ 13221,
+ 13222,
+ 13223,
+ 13224,
+ 13225,
+ 13226,
+ 13227,
+ 13228,
+ 13229,
+ 13230,
+ 13231,
+ 13232,
+ 13233,
+ 13234,
+ 13235,
+ 13236,
+ 13237,
+ 13238,
+ 13239,
+ 13240,
+ 13241,
+ 13242,
+ 13243,
+ 13244,
+ 13245,
+ 13246,
+ 13247,
+ 13248,
+ 13249,
+ 13250,
+ 13251,
+ 13252,
+ 13253,
+ 13254,
+ 13255,
+ 13256,
+ 13257,
+ 13258,
+ 13259,
+ 13260,
+ 13261,
+ 13262,
+ 13263,
+ 13264,
+ 13265,
+ 13266,
+ 13267,
+ 13268,
+ 13269,
+ 13270,
+ 13271,
+ 13272,
+ 13273,
+ 13274,
+ 13275,
+ 13276,
+ 13277,
+ 13278,
+ 13279,
+ 13280,
+ 13281,
+ 13282,
+ 13283,
+ 13284,
+ 13285,
+ 13286,
+ 13287,
+ 13288,
+ 13289,
+ 13290,
+ 13291,
+ 13292,
+ 13293,
+ 13294,
+ 13295,
+ 13296,
+ 13297,
+ 13298,
+ 13299,
+ 13300,
+ 13301,
+ 13302,
+ 13303,
+ 13304,
+ 13305,
+ 13306,
+ 13307,
+ 13308,
+ 13309,
+ 13310,
+ 13311,
+ 13312,
+ 13313,
+ 13314,
+ 13315,
+ 13316,
+ 13317,
+ 13318,
+ 13319,
+ 13320,
+ 13321,
+ 13322,
+ 13323,
+ 13324,
+ 13325,
+ 13326,
+ 13327,
+ 13328,
+ 13329,
+ 13330,
+ 13331,
+ 13332,
+ 13333,
+ 13334,
+ 13335,
+ 13336,
+ 13337,
+ 13338,
+ 13339,
+ 13340,
+ 13341,
+ 13342,
+ 13343,
+ 13344,
+ 13345,
+ 13346,
+ 13347,
+ 13348,
+ 13349,
+ 13350,
+ 13351,
+ 13352,
+ 13353,
+ 13354,
+ 13355,
+ 13356,
+ 13357,
+ 13358,
+ 13359,
+ 13360,
+ 13361,
+ 13362,
+ 13363,
+ 13364,
+ 13365,
+ 13366,
+ 13367,
+ 13368,
+ 13369,
+ 13370,
+ 13371,
+ 13372,
+ 13373,
+ 13374,
+ 13375,
+ 13376,
+ 13377,
+ 13378,
+ 13379,
+ 13380,
+ 13381,
+ 13382,
+ 13383,
+ 13384,
+ 13385,
+ 13386,
+ 13387,
+ 13388,
+ 13389,
+ 13390,
+ 13391,
+ 13392,
+ 13393,
+ 13394,
+ 13395,
+ 13396,
+ 13397,
+ 13398,
+ 13399,
+ 13400,
+ 13401,
+ 13402,
+ 13403,
+ 13404,
+ 13405,
+ 13406,
+ 13407,
+ 13408,
+ 13409,
+ 13410,
+ 13411,
+ 13412,
+ 13413,
+ 13414,
+ 13415,
+ 13416,
+ 13417,
+ 13418,
+ 13419,
+ 13420,
+ 13421,
+ 13422,
+ 13423,
+ 13424,
+ 13425,
+ 13426,
+ 13427,
+ 13428,
+ 13429,
+ 13430,
+ 13431,
+ 13432,
+ 13433,
+ 13434,
+ 13435,
+ 13436,
+ 13437,
+ 13438,
+ 13439,
+ 13440,
+ 13441,
+ 13442,
+ 13443,
+ 13444,
+ 13445,
+ 13446,
+ 13447,
+ 13448,
+ 13449,
+ 13450,
+ 13451,
+ 13452,
+ 13453,
+ 13454,
+ 13455,
+ 13456,
+ 13457,
+ 13458,
+ 13459,
+ 13460,
+ 13461,
+ 13462,
+ 13463,
+ 13464,
+ 13465,
+ 13466,
+ 13467,
+ 13468,
+ 13469,
+ 13470,
+ 13471,
+ 13472,
+ 13473,
+ 13474,
+ 13475,
+ 13476,
+ 13477,
+ 13478,
+ 13479,
+ 13480,
+ 13481,
+ 13482,
+ 13483,
+ 13484,
+ 13485,
+ 13486,
+ 13487,
+ 13488,
+ 13489,
+ 13490,
+ 13491,
+ 13492,
+ 13493,
+ 13494,
+ 13495,
+ 13496,
+ 13497,
+ 13498,
+ 13499,
+ 13500,
+ 13501,
+ 13502,
+ 13503,
+ 13504,
+ 13505,
+ 13506,
+ 13507,
+ 13508,
+ 13509,
+ 13510,
+ 13511,
+ 13512,
+ 13513,
+ 13514,
+ 13515,
+ 13516,
+ 13517,
+ 13518,
+ 13519,
+ 13520,
+ 13521,
+ 13522,
+ 13523,
+ 13524,
+ 13525,
+ 13526,
+ 13527,
+ 13528,
+ 13529,
+ 13530,
+ 13531,
+ 13532,
+ 13533,
+ 13534,
+ 13535,
+ 13536,
+ 13537,
+ 13538,
+ 13539,
+ 13540,
+ 13541,
+ 13542,
+ 13543,
+ 13544,
+ 13545,
+ 13546,
+ 13547,
+ 13548,
+ 13549,
+ 13550,
+ 13551,
+ 13552,
+ 13553,
+ 13554,
+ 13555,
+ 13556,
+ 13557,
+ 13558,
+ 13559,
+ 13560,
+ 13561,
+ 13562,
+ 13563,
+ 13564,
+ 13565,
+ 13566,
+ 13567,
+ 13568,
+ 13569,
+ 13570,
+ 13571,
+ 13572,
+ 13573,
+ 13574,
+ 13575,
+ 13576,
+ 13577,
+ 13578,
+ 13579,
+ 13580,
+ 13581,
+ 13582,
+ 13583,
+ 13584,
+ 13585,
+ 13586,
+ 13587,
+ 13588,
+ 13589,
+ 13590,
+ 13591,
+ 13592,
+ 13593,
+ 13594,
+ 13595,
+ 13596,
+ 13597,
+ 13598,
+ 13599,
+ 13600,
+ 13601,
+ 13602,
+ 13603,
+ 13604,
+ 13605,
+ 13606,
+ 13607,
+ 13608,
+ 13609,
+ 13610,
+ 13611,
+ 13612,
+ 13613,
+ 13614,
+ 13615,
+ 13616,
+ 13617,
+ 13618,
+ 13619,
+ 13620,
+ 13621,
+ 13622,
+ 13623,
+ 13624,
+ 13625,
+ 13626,
+ 13627,
+ 13628,
+ 13629,
+ 13630,
+ 13631,
+ 13632,
+ 13633,
+ 13634,
+ 13635,
+ 13636,
+ 13637,
+ 13638,
+ 13639,
+ 13640,
+ 13641,
+ 13642,
+ 13643,
+ 13644,
+ 13645,
+ 13646,
+ 13647,
+ 13648,
+ 13649,
+ 13650,
+ 13651,
+ 13652,
+ 13653,
+ 13654,
+ 13655,
+ 13656,
+ 13657,
+ 13658,
+ 13659,
+ 13660,
+ 13661,
+ 13662,
+ 13663,
+ 13664,
+ 13665,
+ 13666,
+ 13667,
+ 13668,
+ 13669,
+ 13670,
+ 13671,
+ 13672,
+ 13673,
+ 13674,
+ 13675,
+ 13676,
+ 13677,
+ 13678,
+ 13679,
+ 13680,
+ 13681,
+ 13682,
+ 13683,
+ 13684,
+ 13685,
+ 13686,
+ 13687,
+ 13688,
+ 13689,
+ 13690,
+ 13691,
+ 13692,
+ 13693,
+ 13694,
+ 13695,
+ 13696,
+ 13697,
+ 13698,
+ 13699,
+ 13700,
+ 13701,
+ 13702,
+ 13703,
+ 13704,
+ 13705,
+ 13706,
+ 13707,
+ 13708,
+ 13709,
+ 13710,
+ 13711,
+ 13712,
+ 13713,
+ 13714,
+ 13715,
+ 13716,
+ 13717,
+ 13718,
+ 13719,
+ 13720,
+ 13721,
+ 13722,
+ 13723,
+ 13724,
+ 13725,
+ 13726,
+ 13727,
+ 13728,
+ 13729,
+ 13730,
+ 13731,
+ 13732,
+ 13733,
+ 13734,
+ 13735,
+ 13736,
+ 13737,
+ 13738,
+ 13739,
+ 13740,
+ 13741,
+ 13742,
+ 13743,
+ 13744,
+ 13745,
+ 13746,
+ 13747,
+ 13748,
+ 13749,
+ 13750,
+ 13751,
+ 13752,
+ 13753,
+ 13754,
+ 13755,
+ 13756,
+ 13757,
+ 13758,
+ 13759,
+ 13760,
+ 13761,
+ 13762,
+ 13763,
+ 13764,
+ 13765,
+ 13766,
+ 13767,
+ 13768,
+ 13769,
+ 13770,
+ 13771,
+ 13772,
+ 13773,
+ 13774,
+ 13775,
+ 13776,
+ 13777,
+ 13778,
+ 13779,
+ 13780,
+ 13781,
+ 13782,
+ 13783,
+ 13784,
+ 13785,
+ 13786,
+ 13787,
+ 13788,
+ 13789,
+ 13790,
+ 13791,
+ 13792,
+ 13793,
+ 13794,
+ 13795,
+ 13796,
+ 13797,
+ 13798,
+ 13799,
+ 13800,
+ 13801,
+ 13802,
+ 13803,
+ 13804,
+ 13805,
+ 13806,
+ 13807,
+ 13808,
+ 13809,
+ 13810,
+ 13811,
+ 13812,
+ 13813,
+ 13814,
+ 13815,
+ 13816,
+ 13817,
+ 13818,
+ 13819,
+ 13820,
+ 13821,
+ 13822,
+ 13823,
+ 13824,
+ 13825,
+ 13826,
+ 13827,
+ 13828,
+ 13829,
+ 13830,
+ 13831,
+ 13832,
+ 13833,
+ 13834,
+ 13835,
+ 13836,
+ 13837,
+ 13838,
+ 13839,
+ 13840,
+ 13841,
+ 13842,
+ 13843,
+ 13844,
+ 13845,
+ 13846,
+ 13847,
+ 13848,
+ 13849,
+ 13850,
+ 13851,
+ 13852,
+ 13853,
+ 13854,
+ 13855,
+ 13856,
+ 13857,
+ 13858,
+ 13859,
+ 13860,
+ 13861,
+ 13862,
+ 13863,
+ 13864,
+ 13865,
+ 13866,
+ 13867,
+ 13868,
+ 13869,
+ 13870,
+ 13871,
+ 13872,
+ 13873,
+ 13874,
+ 13875,
+ 13876,
+ 13877,
+ 13878,
+ 13879,
+ 13880,
+ 13881,
+ 13882,
+ 13883,
+ 13884,
+ 13885,
+ 13886,
+ 13887,
+ 13888,
+ 13889,
+ 13890,
+ 13891,
+ 13892,
+ 13893,
+ 13894,
+ 13895,
+ 13896,
+ 13897,
+ 13898,
+ 13899,
+ 13900,
+ 13901,
+ 13902,
+ 13903,
+ 13904,
+ 13905,
+ 13906,
+ 13907,
+ 13908,
+ 13909,
+ 13910,
+ 13911,
+ 13912,
+ 13913,
+ 13914,
+ 13915,
+ 13916,
+ 13917,
+ 13918,
+ 13919,
+ 13920,
+ 13921,
+ 13922,
+ 13923,
+ 13924,
+ 13925,
+ 13926,
+ 13927,
+ 13928,
+ 13929,
+ 13930,
+ 13931,
+ 13932,
+ 13933,
+ 13934,
+ 13935,
+ 13936,
+ 13937,
+ 13938,
+ 13939,
+ 13940,
+ 13941,
+ 13942,
+ 13943,
+ 13944,
+ 13945,
+ 13946,
+ 13947,
+ 13948,
+ 13949,
+ 13950,
+ 13951,
+ 13952,
+ 13953,
+ 13954,
+ 13955,
+ 13956,
+ 13957,
+ 13958,
+ 13959,
+ 13960,
+ 13961,
+ 13962,
+ 13963,
+ 13964,
+ 13965,
+ 13966,
+ 13967,
+ 13968,
+ 13969,
+ 13970,
+ 13971,
+ 13972,
+ 13973,
+ 13974,
+ 13975,
+ 13976,
+ 13977,
+ 13978,
+ 13979,
+ 13980,
+ 13981,
+ 13982,
+ 13983,
+ 13984,
+ 13985,
+ 13986,
+ 13987,
+ 13988,
+ 13989,
+ 13990,
+ 13991,
+ 13992,
+ 13993,
+ 13994,
+ 13995,
+ 13996,
+ 13997,
+ 13998,
+ 13999,
+ 14000,
+ 14001,
+ 14002,
+ 14003,
+ 14004,
+ 14005,
+ 14006,
+ 14007,
+ 14008,
+ 14009,
+ 14010,
+ 14011,
+ 14012,
+ 14013,
+ 14014,
+ 14015,
+ 14016,
+ 14017,
+ 14018,
+ 14019,
+ 14020,
+ 14021,
+ 14022,
+ 14023,
+ 14024,
+ 14025,
+ 14026,
+ 14027,
+ 14028,
+ 14029,
+ 14030,
+ 14031,
+ 14032,
+ 14033,
+ 14034,
+ 14035,
+ 14036,
+ 14037,
+ 14038,
+ 14039,
+ 14040,
+ 14041,
+ 14042,
+ 14043,
+ 14044,
+ 14045,
+ 14046,
+ 14047,
+ 14048,
+ 14049,
+ 14050,
+ 14051,
+ 14052,
+ 14053,
+ 14054,
+ 14055,
+ 14056,
+ 14057,
+ 14058,
+ 14059,
+ 14060,
+ 14061,
+ 14062,
+ 14063,
+ 14064,
+ 14065,
+ 14066,
+ 14067,
+ 14068,
+ 14069,
+ 14070,
+ 14071,
+ 14072,
+ 14073,
+ 14074,
+ 14075,
+ 14076,
+ 14077,
+ 14078,
+ 14079,
+ 14080,
+ 14081,
+ 14082,
+ 14083,
+ 14084,
+ 14085,
+ 14086,
+ 14087,
+ 14088,
+ 14089,
+ 14090,
+ 14091,
+ 14092,
+ 14093,
+ 14094,
+ 14095,
+ 14096,
+ 14097,
+ 14098,
+ 14099,
+ 14100,
+ 14101,
+ 14102,
+ 14103,
+ 14104,
+ 14105,
+ 14106,
+ 14107,
+ 14108,
+ 14109,
+ 14110,
+ 14111,
+ 14112,
+ 14113,
+ 14114,
+ 14115,
+ 14116,
+ 14117,
+ 14118,
+ 14119,
+ 14120,
+ 14121,
+ 14122,
+ 14123,
+ 14124,
+ 14125,
+ 14126,
+ 14127,
+ 14128,
+ 14129,
+ 14130,
+ 14131,
+ 14132,
+ 14133,
+ 14134,
+ 14135,
+ 14136,
+ 14137,
+ 14138,
+ 14139,
+ 14140,
+ 14141,
+ 14142,
+ 14143,
+ 14144,
+ 14145,
+ 14146,
+ 14147,
+ 14148,
+ 14149,
+ 14150,
+ 14151,
+ 14152,
+ 14153,
+ 14154,
+ 14155,
+ 14156,
+ 14157,
+ 14158,
+ 14159,
+ 14160,
+ 14161,
+ 14162,
+ 14163,
+ 14164,
+ 14165,
+ 14166,
+ 14167,
+ 14168,
+ 14169,
+ 14170,
+ 14171,
+ 14172,
+ 14173,
+ 14174,
+ 14175,
+ 14176,
+ 14177,
+ 14178,
+ 14179,
+ 14180,
+ 14181,
+ 14182,
+ 14183,
+ 14184,
+ 14185,
+ 14186,
+ 14187,
+ 14188,
+ 14189,
+ 14190,
+ 14191,
+ 14192,
+ 14193,
+ 14194,
+ 14195,
+ 14196,
+ 14197,
+ 14198,
+ 14199,
+ 14200,
+ 14201,
+ 14202,
+ 14203,
+ 14204,
+ 14205,
+ 14206,
+ 14207,
+ 14208,
+ 14209,
+ 14210,
+ 14211,
+ 14212,
+ 14213,
+ 14214,
+ 14215,
+ 14216,
+ 14217,
+ 14218,
+ 14219,
+ 14220,
+ 14221,
+ 14222,
+ 14223,
+ 14224,
+ 14225,
+ 14226,
+ 14227,
+ 14228,
+ 14229,
+ 14230,
+ 14231,
+ 14232,
+ 14233,
+ 14234,
+ 14235,
+ 14236,
+ 14237,
+ 14238,
+ 14239,
+ 14240,
+ 14241,
+ 14242,
+ 14243,
+ 14244,
+ 14245,
+ 14246,
+ 14247,
+ 14248,
+ 14249,
+ 14250,
+ 14251,
+ 14252,
+ 14253,
+ 14254,
+ 14255,
+ 14256,
+ 14257,
+ 14258,
+ 14259,
+ 14260,
+ 14261,
+ 14262,
+ 14263,
+ 14264,
+ 14265,
+ 14266,
+ 14267,
+ 14268,
+ 14269,
+ 14270,
+ 14271,
+ 14272,
+ 14273,
+ 14274,
+ 14275,
+ 14276,
+ 14277,
+ 14278,
+ 14279,
+ 14280,
+ 14281,
+ 14282,
+ 14283,
+ 14284,
+ 14285,
+ 14286,
+ 14287,
+ 14288,
+ 14289,
+ 14290,
+ 14291,
+ 14292,
+ 14293,
+ 14294,
+ 14295,
+ 14296,
+ 14297,
+ 14298,
+ 14299,
+ 14300,
+ 14301,
+ 14302,
+ 14303,
+ 14304,
+ 14305,
+ 14306,
+ 14307,
+ 14308,
+ 14309,
+ 14310,
+ 14311,
+ 14312,
+ 14313,
+ 14314,
+ 14315,
+ 14316,
+ 14317,
+ 14318,
+ 14319,
+ 14320,
+ 14321,
+ 14322,
+ 14323,
+ 14324,
+ 14325,
+ 14326,
+ 14327,
+ 14328,
+ 14329,
+ 14330,
+ 14331,
+ 14332,
+ 14333,
+ 14334,
+ 14335,
+ 14336,
+ 14337,
+ 14338,
+ 14339,
+ 14340,
+ 14341,
+ 14342,
+ 14343,
+ 14344,
+ 14345,
+ 14346,
+ 14347,
+ 14348,
+ 14349,
+ 14350,
+ 14351,
+ 14352,
+ 14353,
+ 14354,
+ 14355,
+ 14356,
+ 14357,
+ 14358,
+ 14359,
+ 14360,
+ 14361,
+ 14362,
+ 14363,
+ 14364,
+ 14365,
+ 14366,
+ 14367,
+ 14368,
+ 14369,
+ 14370,
+ 14371,
+ 14372,
+ 14373,
+ 14374,
+ 14375,
+ 14376,
+ 14377,
+ 14378,
+ 14379,
+ 14380,
+ 14381,
+ 14382,
+ 14383,
+ 14384,
+ 14385,
+ 14386,
+ 14387,
+ 14388,
+ 14389,
+ 14390,
+ 14391,
+ 14392,
+ 14393,
+ 14394,
+ 14395,
+ 14396,
+ 14397,
+ 14398,
+ 14399,
+ 14400,
+ 14401,
+ 14402,
+ 14403,
+ 14404,
+ 14405,
+ 14406,
+ 14407,
+ 14408,
+ 14409,
+ 14410,
+ 14411,
+ 14412,
+ 14413,
+ 14414,
+ 14415,
+ 14416,
+ 14417,
+ 14418,
+ 14419,
+ 14420,
+ 14421,
+ 14422,
+ 14423,
+ 14424,
+ 14425,
+ 14426,
+ 14427,
+ 14428,
+ 14429,
+ 14430,
+ 14431,
+ 14432,
+ 14433,
+ 14434,
+ 14435,
+ 14436,
+ 14437,
+ 14438,
+ 14439,
+ 14440,
+ 14441,
+ 14442,
+ 14443,
+ 14444,
+ 14445,
+ 14446,
+ 14447,
+ 14448,
+ 14449,
+ 14450,
+ 14451,
+ 14452,
+ 14453,
+ 14454,
+ 14455,
+ 14456,
+ 14457,
+ 14458,
+ 14459,
+ 14460,
+ 14461,
+ 14462,
+ 14463,
+ 14464,
+ 14465,
+ 14466,
+ 14467,
+ 14468,
+ 14469,
+ 14470,
+ 14471,
+ 14472,
+ 14473,
+ 14474,
+ 14475,
+ 14476,
+ 14477,
+ 14478,
+ 14479,
+ 14480,
+ 14481,
+ 14482,
+ 14483,
+ 14484,
+ 14485,
+ 14486,
+ 14487,
+ 14488,
+ 14489,
+ 14490,
+ 14491,
+ 14492,
+ 14493,
+ 14494,
+ 14495,
+ 14496,
+ 14497,
+ 14498,
+ 14499,
+ 14500,
+ 14501,
+ 14502,
+ 14503,
+ 14504,
+ 14505,
+ 14506,
+ 14507,
+ 14508,
+ 14509,
+ 14510,
+ 14511,
+ 14512,
+ 14513,
+ 14514,
+ 14515,
+ 14516,
+ 14517,
+ 14518,
+ 14519,
+ 14520,
+ 14521,
+ 14522,
+ 14523,
+ 14524,
+ 14525,
+ 14526,
+ 14527,
+ 14528,
+ 14529,
+ 14530,
+ 14531,
+ 14532,
+ 14533,
+ 14534,
+ 14535,
+ 14536,
+ 14537,
+ 14538,
+ 14539,
+ 14540,
+ 14541,
+ 14542,
+ 14543,
+ 14544,
+ 14545,
+ 14546,
+ 14547,
+ 14548,
+ 14549,
+ 14550,
+ 14551,
+ 14552,
+ 14553,
+ 14554,
+ 14555,
+ 14556,
+ 14557,
+ 14558,
+ 14559,
+ 14560,
+ 14561,
+ 14562,
+ 14563,
+ 14564,
+ 14565,
+ 14566,
+ 14567,
+ 14568,
+ 14569,
+ 14570,
+ 14571,
+ 14572,
+ 14573,
+ 14574,
+ 14575,
+ 14576,
+ 14577,
+ 14578,
+ 14579,
+ 14580,
+ 14581,
+ 14582,
+ 14583,
+ 14584,
+ 14585,
+ 14586,
+ 14587,
+ 14588,
+ 14589,
+ 14590,
+ 14591,
+ 14592,
+ 14593,
+ 14594,
+ 14595,
+ 14596,
+ 14597,
+ 14598,
+ 14599,
+ 14600,
+ 14601,
+ 14602,
+ 14603,
+ 14604,
+ 14605,
+ 14606,
+ 14607,
+ 14608,
+ 14609,
+ 14610,
+ 14611,
+ 14612,
+ 14613,
+ 14614,
+ 14615,
+ 14616,
+ 14617,
+ 14618,
+ 14619,
+ 14620,
+ 14621,
+ 14622,
+ 14623,
+ 14624,
+ 14625,
+ 14626,
+ 14627,
+ 14628,
+ 14629,
+ 14630,
+ 14631,
+ 14632,
+ 14633,
+ 14634,
+ 14635,
+ 14636,
+ 14637,
+ 14638,
+ 14639,
+ 14640,
+ 14641,
+ 14642,
+ 14643,
+ 14644,
+ 14645,
+ 14646,
+ 14647,
+ 14648,
+ 14649,
+ 14650,
+ 14651,
+ 14652,
+ 14653,
+ 14654,
+ 14655,
+ 14656,
+ 14657,
+ 14658,
+ 14659,
+ 14660,
+ 14661,
+ 14662,
+ 14663,
+ 14664,
+ 14665,
+ 14666,
+ 14667,
+ 14668,
+ 14669,
+ 14670,
+ 14671,
+ 14672,
+ 14673,
+ 14674,
+ 14675,
+ 14676,
+ 14677,
+ 14678,
+ 14679,
+ 14680,
+ 14681,
+ 14682,
+ 14683,
+ 14684,
+ 14685,
+ 14686,
+ 14687,
+ 14688,
+ 14689,
+ 14690,
+ 14691,
+ 14692,
+ 14693,
+ 14694,
+ 14695,
+ 14696,
+ 14697,
+ 14698,
+ 14699,
+ 14700,
+ 14701,
+ 14702,
+ 14703,
+ 14704,
+ 14705,
+ 14706,
+ 14707,
+ 14708,
+ 14709,
+ 14710,
+ 14711,
+ 14712,
+ 14713,
+ 14714,
+ 14715,
+ 14716,
+ 14717,
+ 14718,
+ 14719,
+ 14720,
+ 14721,
+ 14722,
+ 14723,
+ 14724,
+ 14725,
+ 14726,
+ 14727,
+ 14728,
+ 14729,
+ 14730,
+ 14731,
+ 14732,
+ 14733,
+ 14734,
+ 14735,
+ 14736,
+ 14737,
+ 14738,
+ 14739,
+ 14740,
+ 14741,
+ 14742,
+ 14743,
+ 14744,
+ 14745,
+ 14746,
+ 14747,
+ 14748,
+ 14749,
+ 14750,
+ 14751,
+ 14752,
+ 14753,
+ 14754,
+ 14755,
+ 14756,
+ 14757,
+ 14758,
+ 14759,
+ 14760,
+ 14761,
+ 14762,
+ 14763,
+ 14764,
+ 14765,
+ 14766,
+ 14767,
+ 14768,
+ 14769,
+ 14770,
+ 14771,
+ 14772,
+ 14773,
+ 14774,
+ 14775,
+ 14776,
+ 14777,
+ 14778,
+ 14779,
+ 14780,
+ 14781,
+ 14782,
+ 14783,
+ 14784,
+ 14785,
+ 14786,
+ 14787,
+ 14788,
+ 14789,
+ 14790,
+ 14791,
+ 14792,
+ 14793,
+ 14794,
+ 14795,
+ 14796,
+ 14797,
+ 14798,
+ 14799,
+ 14800,
+ 14801,
+ 14802,
+ 14803,
+ 14804,
+ 14805,
+ 14806,
+ 14807,
+ 14808,
+ 14809,
+ 14810,
+ 14811,
+ 14812,
+ 14813,
+ 14814,
+ 14815,
+ 14816,
+ 14817,
+ 14818,
+ 14819,
+ 14820,
+ 14821,
+ 14822,
+ 14823,
+ 14824,
+ 14825,
+ 14826,
+ 14827,
+ 14828,
+ 14829,
+ 14830,
+ 14831,
+ 14832,
+ 14833,
+ 14834,
+ 14835,
+ 14836,
+ 14837,
+ 14838,
+ 14839,
+ 14840,
+ 14841,
+ 14842,
+ 14843,
+ 14844,
+ 14845,
+ 14846,
+ 14847,
+ 14848,
+ 14849,
+ 14850,
+ 14851,
+ 14852,
+ 14853,
+ 14854,
+ 14855,
+ 14856,
+ 14857,
+ 14858,
+ 14859,
+ 14860,
+ 14861,
+ 14862,
+ 14863,
+ 14864,
+ 14865,
+ 14866,
+ 14867,
+ 14868,
+ 14869,
+ 14870,
+ 14871,
+ 14872,
+ 14873,
+ 14874,
+ 14875,
+ 14876,
+ 14877,
+ 14878,
+ 14879,
+ 14880,
+ 14881,
+ 14882,
+ 14883,
+ 14884,
+ 14885,
+ 14886,
+ 14887,
+ 14888,
+ 14889,
+ 14890,
+ 14891,
+ 14892,
+ 14893,
+ 14894,
+ 14895,
+ 14896,
+ 14897,
+ 14898,
+ 14899,
+ 14900,
+ 14901,
+ 14902,
+ 14903,
+ 14904,
+ 14905,
+ 14906,
+ 14907,
+ 14908,
+ 14909,
+ 14910,
+ 14911,
+ 14912,
+ 14913,
+ 14914,
+ 14915,
+ 14916,
+ 14917,
+ 14918,
+ 14919,
+ 14920,
+ 14921,
+ 14922,
+ 14923,
+ 14924,
+ 14925,
+ 14926,
+ 14927,
+ 14928,
+ 14929,
+ 14930,
+ 14931,
+ 14932,
+ 14933,
+ 14934,
+ 14935,
+ 14936,
+ 14937,
+ 14938,
+ 14939,
+ 14940,
+ 14941,
+ 14942,
+ 14943,
+ 14944,
+ 14945,
+ 14946,
+ 14947,
+ 14948,
+ 14949,
+ 14950,
+ 14951,
+ 14952,
+ 14953,
+ 14954,
+ 14955,
+ 14956,
+ 14957,
+ 14958,
+ 14959,
+ 14960,
+ 14961,
+ 14962,
+ 14963,
+ 14964,
+ 14965,
+ 14966,
+ 14967,
+ 14968,
+ 14969,
+ 14970,
+ 14971,
+ 14972,
+ 14973,
+ 14974,
+ 14975,
+ 14976,
+ 14977,
+ 14978,
+ 14979,
+ 14980,
+ 14981,
+ 14982,
+ 14983,
+ 14984,
+ 14985,
+ 14986,
+ 14987,
+ 14988,
+ 14989,
+ 14990,
+ 14991,
+ 14992,
+ 14993,
+ 14994,
+ 14995,
+ 14996,
+ 14997,
+ 14998,
+ 14999,
+ 15000,
+ 15001,
+ 15002,
+ 15003,
+ 15004,
+ 15005,
+ 15006,
+ 15007,
+ 15008,
+ 15009,
+ 15010,
+ 15011,
+ 15012,
+ 15013,
+ 15014,
+ 15015,
+ 15016,
+ 15017,
+ 15018,
+ 15019,
+ 15020,
+ 15021,
+ 15022,
+ 15023,
+ 15024,
+ 15025,
+ 15026,
+ 15027,
+ 15028,
+ 15029,
+ 15030,
+ 15031,
+ 15032,
+ 15033,
+ 15034,
+ 15035,
+ 15036,
+ 15037,
+ 15038,
+ 15039,
+ 15040,
+ 15041,
+ 15042,
+ 15043,
+ 15044,
+ 15045,
+ 15046,
+ 15047,
+ 15048,
+ 15049,
+ 15050,
+ 15051,
+ 15052,
+ 15053,
+ 15054,
+ 15055,
+ 15056,
+ 15057,
+ 15058,
+ 15059,
+ 15060,
+ 15061,
+ 15062,
+ 15063,
+ 15064,
+ 15065,
+ 15066,
+ 15067,
+ 15068,
+ 15069,
+ 15070,
+ 15071,
+ 15072,
+ 15073,
+ 15074,
+ 15075,
+ 15076,
+ 15077,
+ 15078,
+ 15079,
+ 15080,
+ 15081,
+ 15082,
+ 15083,
+ 15084,
+ 15085,
+ 15086,
+ 15087,
+ 15088,
+ 15089,
+ 15090,
+ 15091,
+ 15092,
+ 15093,
+ 15094,
+ 15095,
+ 15096,
+ 15097,
+ 15098,
+ 15099,
+ 15100,
+ 15101,
+ 15102,
+ 15103,
+ 15104,
+ 15105,
+ 15106,
+ 15107,
+ 15108,
+ 15109,
+ 15110,
+ 15111,
+ 15112,
+ 15113,
+ 15114,
+ 15115,
+ 15116,
+ 15117,
+ 15118,
+ 15119,
+ 15120,
+ 15121,
+ 15122,
+ 15123,
+ 15124,
+ 15125,
+ 15126,
+ 15127,
+ 15128,
+ 15129,
+ 15130,
+ 15131,
+ 15132,
+ 15133,
+ 15134,
+ 15135,
+ 15136,
+ 15137,
+ 15138,
+ 15139,
+ 15140,
+ 15141,
+ 15142,
+ 15143,
+ 15144,
+ 15145,
+ 15146,
+ 15147,
+ 15148,
+ 15149,
+ 15150,
+ 15151,
+ 15152,
+ 15153,
+ 15154,
+ 15155,
+ 15156,
+ 15157,
+ 15158,
+ 15159,
+ 15160,
+ 15161,
+ 15162,
+ 15163,
+ 15164,
+ 15165,
+ 15166,
+ 15167,
+ 15168,
+ 15169,
+ 15170,
+ 15171,
+ 15172,
+ 15173,
+ 15174,
+ 15175,
+ 15176,
+ 15177,
+ 15178,
+ 15179,
+ 15180,
+ 15181,
+ 15182,
+ 15183,
+ 15184,
+ 15185,
+ 15186,
+ 15187,
+ 15188,
+ 15189,
+ 15190,
+ 15191,
+ 15192,
+ 15193,
+ 15194,
+ 15195,
+ 15196,
+ 15197,
+ 15198,
+ 15199,
+ 15200,
+ 15201,
+ 15202,
+ 15203,
+ 15204,
+ 15205,
+ 15206,
+ 15207,
+ 15208,
+ 15209,
+ 15210,
+ 15211,
+ 15212,
+ 15213,
+ 15214,
+ 15215,
+ 15216,
+ 15217,
+ 15218,
+ 15219,
+ 15220,
+ 15221,
+ 15222,
+ 15223,
+ 15224,
+ 15225,
+ 15226,
+ 15227,
+ 15228,
+ 15229,
+ 15230,
+ 15231,
+ 15232,
+ 15233,
+ 15234,
+ 15235,
+ 15236,
+ 15237,
+ 15238,
+ 15239,
+ 15240,
+ 15241,
+ 15242,
+ 15243,
+ 15244,
+ 15245,
+ 15246,
+ 15247,
+ 15248,
+ 15249,
+ 15250,
+ 15251,
+ 15252,
+ 15253,
+ 15254,
+ 15255,
+ 15256,
+ 15257,
+ 15258,
+ 15259,
+ 15260,
+ 15261,
+ 15262,
+ 15263,
+ 15264,
+ 15265,
+ 15266,
+ 15267,
+ 15268,
+ 15269,
+ 15270,
+ 15271,
+ 15272,
+ 15273,
+ 15274,
+ 15275,
+ 15276,
+ 15277,
+ 15278,
+ 15279,
+ 15280,
+ 15281,
+ 15282,
+ 15283,
+ 15284,
+ 15285,
+ 15286,
+ 15287,
+ 15288,
+ 15289,
+ 15290,
+ 15291,
+ 15292,
+ 15293,
+ 15294,
+ 15295,
+ 15296,
+ 15297,
+ 15298,
+ 15299,
+ 15300,
+ 15301,
+ 15302,
+ 15303,
+ 15304,
+ 15305,
+ 15306,
+ 15307,
+ 15308,
+ 15309,
+ 15310,
+ 15311,
+ 15312,
+ 15313,
+ 15314,
+ 15315,
+ 15316,
+ 15317,
+ 15318,
+ 15319,
+ 15320,
+ 15321,
+ 15322,
+ 15323,
+ 15324,
+ 15325,
+ 15326,
+ 15327,
+ 15328,
+ 15329,
+ 15330,
+ 15331,
+ 15332,
+ 15333,
+ 15334,
+ 15335,
+ 15336,
+ 15337,
+ 15338,
+ 15339,
+ 15340,
+ 15341,
+ 15342,
+ 15343,
+ 15344,
+ 15345,
+ 15346,
+ 15347,
+ 15348,
+ 15349,
+ 15350,
+ 15351,
+ 15352,
+ 15353,
+ 15354,
+ 15355,
+ 15356,
+ 15357,
+ 15358,
+ 15359,
+ 15360,
+ 15361,
+ 15362,
+ 15363,
+ 15364,
+ 15365,
+ 15366,
+ 15367,
+ 15368,
+ 15369,
+ 15370,
+ 15371,
+ 15372,
+ 15373,
+ 15374,
+ 15375,
+ 15376,
+ 15377,
+ 15378,
+ 15379,
+ 15380,
+ 15381,
+ 15382,
+ 15383,
+ 15384,
+ 15385,
+ 15386,
+ 15387,
+ 15388,
+ 15389,
+ 15390,
+ 15391,
+ 15392,
+ 15393,
+ 15394,
+ 15395,
+ 15396,
+ 15397,
+ 15398,
+ 15399,
+ 15400,
+ 15401,
+ 15402,
+ 15403,
+ 15404,
+ 15405,
+ 15406,
+ 15407,
+ 15408,
+ 15409,
+ 15410,
+ 15411,
+ 15412,
+ 15413,
+ 15414,
+ 15415,
+ 15416,
+ 15417,
+ 15418,
+ 15419,
+ 15420,
+ 15421,
+ 15422,
+ 15423,
+ 15424,
+ 15425,
+ 15426,
+ 15427,
+ 15428,
+ 15429,
+ 15430,
+ 15431,
+ 15432,
+ 15433,
+ 15434,
+ 15435,
+ 15436,
+ 15437,
+ 15438,
+ 15439,
+ 15440,
+ 15441,
+ 15442,
+ 15443,
+ 15444,
+ 15445,
+ 15446,
+ 15447,
+ 15448,
+ 15449,
+ 15450,
+ 15451,
+ 15452,
+ 15453,
+ 15454,
+ 15455,
+ 15456,
+ 15457,
+ 15458,
+ 15459,
+ 15460,
+ 15461,
+ 15462,
+ 15463,
+ 15464,
+ 15465,
+ 15466,
+ 15467,
+ 15468,
+ 15469,
+ 15470,
+ 15471,
+ 15472,
+ 15473,
+ 15474,
+ 15475,
+ 15476,
+ 15477,
+ 15478,
+ 15479,
+ 15480,
+ 15481,
+ 15482,
+ 15483,
+ 15484,
+ 15485,
+ 15486,
+ 15487,
+ 15488,
+ 15489,
+ 15490,
+ 15491,
+ 15492,
+ 15493,
+ 15494,
+ 15495,
+ 15496,
+ 15497,
+ 15498,
+ 15499,
+ 15500,
+ 15501,
+ 15502,
+ 15503,
+ 15504,
+ 15505,
+ 15506,
+ 15507,
+ 15508,
+ 15509,
+ 15510,
+ 15511,
+ 15512,
+ 15513,
+ 15514,
+ 15515,
+ 15516,
+ 15517,
+ 15518,
+ 15519,
+ 15520,
+ 15521,
+ 15522,
+ 15523,
+ 15524,
+ 15525,
+ 15526,
+ 15527,
+ 15528,
+ 15529,
+ 15530,
+ 15531,
+ 15532,
+ 15533,
+ 15534,
+ 15535,
+ 15536,
+ 15537,
+ 15538,
+ 15539,
+ 15540,
+ 15541,
+ 15542,
+ 15543,
+ 15544,
+ 15545,
+ 15546,
+ 15547,
+ 15548,
+ 15549,
+ 15550,
+ 15551,
+ 15552,
+ 15553,
+ 15554,
+ 15555,
+ 15556,
+ 15557,
+ 15558,
+ 15559,
+ 15560,
+ 15561,
+ 15562,
+ 15563,
+ 15564,
+ 15565,
+ 15566,
+ 15567,
+ 15568,
+ 15569,
+ 15570,
+ 15571,
+ 15572,
+ 15573,
+ 15574,
+ 15575,
+ 15576,
+ 15577,
+ 15578,
+ 15579,
+ 15580,
+ 15581,
+ 15582,
+ 15583,
+ 15584,
+ 15585,
+ 15586,
+ 15587,
+ 15588,
+ 15589,
+ 15590,
+ 15591,
+ 15592,
+ 15593,
+ 15594,
+ 15595,
+ 15596,
+ 15597,
+ 15598,
+ 15599,
+ 15600,
+ 15601,
+ 15602,
+ 15603,
+ 15604,
+ 15605,
+ 15606,
+ 15607,
+ 15608,
+ 15609,
+ 15610,
+ 15611,
+ 15612,
+ 15613,
+ 15614,
+ 15615,
+ 15616,
+ 15617,
+ 15618,
+ 15619,
+ 15620,
+ 15621,
+ 15622,
+ 15623,
+ 15624,
+ 15625,
+ 15626,
+ 15627,
+ 15628,
+ 15629,
+ 15630,
+ 15631,
+ 15632,
+ 15633,
+ 15634,
+ 15635,
+ 15636,
+ 15637,
+ 15638,
+ 15639,
+ 15640,
+ 15641,
+ 15642,
+ 15643,
+ 15644,
+ 15645,
+ 15646,
+ 15647,
+ 15648,
+ 15649,
+ 15650,
+ 15651,
+ 15652,
+ 15653,
+ 15654,
+ 15655,
+ 15656,
+ 15657,
+ 15658,
+ 15659,
+ 15660,
+ 15661,
+ 15662,
+ 15663,
+ 15664,
+ 15665,
+ 15666,
+ 15667,
+ 15668,
+ 15669,
+ 15670,
+ 15671,
+ 15672,
+ 15673,
+ 15674,
+ 15675,
+ 15676,
+ 15677,
+ 15678,
+ 15679,
+ 15680,
+ 15681,
+ 15682,
+ 15683,
+ 15684,
+ 15685,
+ 15686,
+ 15687,
+ 15688,
+ 15689,
+ 15690,
+ 15691,
+ 15692,
+ 15693,
+ 15694,
+ 15695,
+ 15696,
+ 15697,
+ 15698,
+ 15699,
+ 15700,
+ 15701,
+ 15702,
+ 15703,
+ 15704,
+ 15705,
+ 15706,
+ 15707,
+ 15708,
+ 15709,
+ 15710,
+ 15711,
+ 15712,
+ 15713,
+ 15714,
+ 15715,
+ 15716,
+ 15717,
+ 15718,
+ 15719,
+ 15720,
+ 15721,
+ 15722,
+ 15723,
+ 15724,
+ 15725,
+ 15726,
+ 15727,
+ 15728,
+ 15729,
+ 15730,
+ 15731,
+ 15732,
+ 15733,
+ 15734,
+ 15735,
+ 15736,
+ 15737,
+ 15738,
+ 15739,
+ 15740,
+ 15741,
+ 15742,
+ 15743,
+ 15744,
+ 15745,
+ 15746,
+ 15747,
+ 15748,
+ 15749,
+ 15750,
+ 15751,
+ 15752,
+ 15753,
+ 15754,
+ 15755,
+ 15756,
+ 15757,
+ 15758,
+ 15759,
+ 15760,
+ 15761,
+ 15762,
+ 15763,
+ 15764,
+ 15765,
+ 15766,
+ 15767,
+ 15768,
+ 15769,
+ 15770,
+ 15771,
+ 15772,
+ 15773,
+ 15774,
+ 15775,
+ 15776,
+ 15777,
+ 15778,
+ 15779,
+ 15780,
+ 15781,
+ 15782,
+ 15783,
+ 15784,
+ 15785,
+ 15786,
+ 15787,
+ 15788,
+ 15789,
+ 15790,
+ 15791,
+ 15792,
+ 15793,
+ 15794,
+ 15795,
+ 15796,
+ 15797,
+ 15798,
+ 15799,
+ 15800,
+ 15801,
+ 15802,
+ 15803,
+ 15804,
+ 15805,
+ 15806,
+ 15807,
+ 15808,
+ 15809,
+ 15810,
+ 15811,
+ 15812,
+ 15813,
+ 15814,
+ 15815,
+ 15816,
+ 15817,
+ 15818,
+ 15819,
+ 15820,
+ 15821,
+ 15822,
+ 15823,
+ 15824,
+ 15825,
+ 15826,
+ 15827,
+ 15828,
+ 15829,
+ 15830,
+ 15831,
+ 15832,
+ 15833,
+ 15834,
+ 15835,
+ 15836,
+ 15837,
+ 15838,
+ 15839,
+ 15840,
+ 15841,
+ 15842,
+ 15843,
+ 15844,
+ 15845,
+ 15846,
+ 15847,
+ 15848,
+ 15849,
+ 15850,
+ 15851,
+ 15852,
+ 15853,
+ 15854,
+ 15855,
+ 15856,
+ 15857,
+ 15858,
+ 15859,
+ 15860,
+ 15861,
+ 15862,
+ 15863,
+ 15864,
+ 15865,
+ 15866,
+ 15867,
+ 15868,
+ 15869,
+ 15870,
+ 15871,
+ 15872,
+ 15873,
+ 15874,
+ 15875,
+ 15876,
+ 15877,
+ 15878,
+ 15879,
+ 15880,
+ 15881,
+ 15882,
+ 15883,
+ 15884,
+ 15885,
+ 15886,
+ 15887,
+ 15888,
+ 15889,
+ 15890,
+ 15891,
+ 15892,
+ 15893,
+ 15894,
+ 15895,
+ 15896,
+ 15897,
+ 15898,
+ 15899,
+ 15900,
+ 15901,
+ 15902,
+ 15903,
+ 15904,
+ 15905,
+ 15906,
+ 15907,
+ 15908,
+ 15909,
+ 15910,
+ 15911,
+ 15912,
+ 15913,
+ 15914,
+ 15915,
+ 15916,
+ 15917,
+ 15918,
+ 15919,
+ 15920,
+ 15921,
+ 15922,
+ 15923,
+ 15924,
+ 15925,
+ 15926,
+ 15927,
+ 15928,
+ 15929,
+ 15930,
+ 15931,
+ 15932,
+ 15933,
+ 15934,
+ 15935,
+ 15936,
+ 15937,
+ 15938,
+ 15939,
+ 15940,
+ 15941,
+ 15942,
+ 15943,
+ 15944,
+ 15945,
+ 15946,
+ 15947,
+ 15948,
+ 15949,
+ 15950,
+ 15951,
+ 15952,
+ 15953,
+ 15954,
+ 15955,
+ 15956,
+ 15957,
+ 15958,
+ 15959,
+ 15960,
+ 15961,
+ 15962,
+ 15963,
+ 15964,
+ 15965,
+ 15966,
+ 15967,
+ 15968,
+ 15969,
+ 15970,
+ 15971,
+ 15972,
+ 15973,
+ 15974,
+ 15975,
+ 15976,
+ 15977,
+ 15978,
+ 15979,
+ 15980,
+ 15981,
+ 15982,
+ 15983,
+ 15984,
+ 15985,
+ 15986,
+ 15987,
+ 15988,
+ 15989,
+ 15990,
+ 15991,
+ 15992,
+ 15993,
+ 15994,
+ 15995,
+ 15996,
+ 15997,
+ 15998,
+ 15999,
+ 16000,
+ 16001,
+ 16002,
+ 16003,
+ 16004,
+ 16005,
+ 16006,
+ 16007,
+ 16008,
+ 16009,
+ 16010,
+ 16011,
+ 16012,
+ 16013,
+ 16014,
+ 16015,
+ 16016,
+ 16017,
+ 16018,
+ 16019,
+ 16020,
+ 16021,
+ 16022,
+ 16023,
+ 16024,
+ 16025,
+ 16026,
+ 16027,
+ 16028,
+ 16029,
+ 16030,
+ 16031,
+ 16032,
+ 16033,
+ 16034,
+ 16035,
+ 16036,
+ 16037,
+ 16038,
+ 16039,
+ 16040,
+ 16041,
+ 16042,
+ 16043,
+ 16044,
+ 16045,
+ 16046,
+ 16047,
+ 16048,
+ 16049,
+ 16050,
+ 16051,
+ 16052,
+ 16053,
+ 16054,
+ 16055,
+ 16056,
+ 16057,
+ 16058,
+ 16059,
+ 16060,
+ 16061,
+ 16062,
+ 16063,
+ 16064,
+ 16065,
+ 16066,
+ 16067,
+ 16068,
+ 16069,
+ 16070,
+ 16071,
+ 16072,
+ 16073,
+ 16074,
+ 16075,
+ 16076,
+ 16077,
+ 16078,
+ 16079,
+ 16080,
+ 16081,
+ 16082,
+ 16083,
+ 16084,
+ 16085,
+ 16086,
+ 16087,
+ 16088,
+ 16089,
+ 16090,
+ 16091,
+ 16092,
+ 16093,
+ 16094,
+ 16095,
+ 16096,
+ 16097,
+ 16098,
+ 16099,
+ 16100,
+ 16101,
+ 16102,
+ 16103,
+ 16104,
+ 16105,
+ 16106,
+ 16107,
+ 16108,
+ 16109,
+ 16110,
+ 16111,
+ 16112,
+ 16113,
+ 16114,
+ 16115,
+ 16116,
+ 16117,
+ 16118,
+ 16119,
+ 16120,
+ 16121,
+ 16122,
+ 16123,
+ 16124,
+ 16125,
+ 16126,
+ 16127,
+ 16128,
+ 16129,
+ 16130,
+ 16131,
+ 16132,
+ 16133,
+ 16134,
+ 16135,
+ 16136,
+ 16137,
+ 16138,
+ 16139,
+ 16140,
+ 16141,
+ 16142,
+ 16143,
+ 16144,
+ 16145,
+ 16146,
+ 16147,
+ 16148,
+ 16149,
+ 16150,
+ 16151,
+ 16152,
+ 16153,
+ 16154,
+ 16155,
+ 16156,
+ 16157,
+ 16158,
+ 16159,
+ 16160,
+ 16161,
+ 16162,
+ 16163,
+ 16164,
+ 16165,
+ 16166,
+ 16167,
+ 16168,
+ 16169,
+ 16170,
+ 16171,
+ 16172,
+ 16173,
+ 16174,
+ 16175,
+ 16176,
+ 16177,
+ 16178,
+ 16179,
+ 16180,
+ 16181,
+ 16182,
+ 16183,
+ 16184,
+ 16185,
+ 16186,
+ 16187,
+ 16188,
+ 16189,
+ 16190,
+ 16191,
+ 16192,
+ 16193,
+ 16194,
+ 16195,
+ 16196,
+ 16197,
+ 16198,
+ 16199,
+ 16200,
+ 16201,
+ 16202,
+ 16203,
+ 16204,
+ 16205,
+ 16206,
+ 16207,
+ 16208,
+ 16209,
+ 16210,
+ 16211,
+ 16212,
+ 16213,
+ 16214,
+ 16215,
+ 16216,
+ 16217,
+ 16218,
+ 16219,
+ 16220,
+ 16221,
+ 16222,
+ 16223,
+ 16224,
+ 16225,
+ 16226,
+ 16227,
+ 16228,
+ 16229,
+ 16230,
+ 16231,
+ 16232,
+ 16233,
+ 16234,
+ 16235,
+ 16236,
+ 16237,
+ 16238,
+ 16239,
+ 16240,
+ 16241,
+ 16242,
+ 16243,
+ 16244,
+ 16245,
+ 16246,
+ 16247,
+ 16248,
+ 16249,
+ 16250,
+ 16251,
+ 16252,
+ 16253,
+ 16254,
+ 16255,
+ 16256,
+ 16257,
+ 16258,
+ 16259,
+ 16260,
+ 16261,
+ 16262,
+ 16263,
+ 16264,
+ 16265,
+ 16266,
+ 16267,
+ 16268,
+ 16269,
+ 16270,
+ 16271,
+ 16272,
+ 16273,
+ 16274,
+ 16275,
+ 16276,
+ 16277,
+ 16278,
+ 16279,
+ 16280,
+ 16281,
+ 16282,
+ 16283,
+ 16284,
+ 16285,
+ 16286,
+ 16287,
+ 16288,
+ 16289,
+ 16290,
+ 16291,
+ 16292,
+ 16293,
+ 16294,
+ 16295,
+ 16296,
+ 16297,
+ 16298,
+ 16299,
+ 16300,
+ 16301,
+ 16302,
+ 16303,
+ 16304,
+ 16305,
+ 16306,
+ 16307,
+ 16308,
+ 16309,
+ 16310,
+ 16311,
+ 16312,
+ 16313,
+ 16314,
+ 16315,
+ 16316,
+ 16317,
+ 16318,
+ 16319,
+ 16320,
+ 16321,
+ 16322,
+ 16323,
+ 16324,
+ 16325,
+ 16326,
+ 16327,
+ 16328,
+ 16329,
+ 16330,
+ 16331,
+ 16332,
+ 16333,
+ 16334,
+ 16335,
+ 16336,
+ 16337,
+ 16338,
+ 16339,
+ 16340,
+ 16341,
+ 16342,
+ 16343,
+ 16344,
+ 16345,
+ 16346,
+ 16347,
+ 16348,
+ 16349,
+ 16350,
+ 16351,
+ 16352,
+ 16353,
+ 16354,
+ 16355,
+ 16356,
+ 16357,
+ 16358,
+ 16359,
+ 16360,
+ 16361,
+ 16362,
+ 16363,
+ 16364,
+ 16365,
+ 16366,
+ 16367,
+ 16368,
+ 16369,
+ 16370,
+ 16371,
+ 16372,
+ 16373,
+ 16374,
+ 16375,
+ 16376,
+ 16377,
+ 16378,
+ 16379,
+ 16380,
+ 16381,
+ 16382,
+ 16383,
+ 16384,
+ 16385,
+ 16386,
+ 16387,
+ 16388,
+ 16389,
+ 16390,
+ 16391,
+ 16392,
+ 16393,
+ 16394,
+ 16395,
+ 16396,
+ 16397,
+ 16398,
+ 16399,
+ 16400,
+ 16401,
+ 16402,
+ 16403,
+ 16404,
+ 16405,
+ 16406,
+ 16407,
+ 16408,
+ 16409,
+ 16410,
+ 16411,
+ 16412,
+ 16413,
+ 16414,
+ 16415,
+ 16416,
+ 16417,
+ 16418,
+ 16419,
+ 16420,
+ 16421,
+ 16422,
+ 16423,
+ 16424,
+ 16425,
+ 16426,
+ 16427,
+ 16428,
+ 16429,
+ 16430,
+ 16431,
+ 16432,
+ 16433,
+ 16434,
+ 16435,
+ 16436,
+ 16437,
+ 16438,
+ 16439,
+ 16440,
+ 16441,
+ 16442,
+ 16443,
+ 16444,
+ 16445,
+ 16446,
+ 16447,
+ 16448,
+ 16449,
+ 16450,
+ 16451,
+ 16452,
+ 16453,
+ 16454,
+ 16455,
+ 16456,
+ 16457,
+ 16458,
+ 16459,
+ 16460,
+ 16461,
+ 16462,
+ 16463,
+ 16464,
+ 16465,
+ 16466,
+ 16467,
+ 16468,
+ 16469,
+ 16470,
+ 16471,
+ 16472,
+ 16473,
+ 16474,
+ 16475,
+ 16476,
+ 16477,
+ 16478,
+ 16479,
+ 16480,
+ 16481,
+ 16482,
+ 16483,
+ 16484,
+ 16485,
+ 16486,
+ 16487,
+ 16488,
+ 16489,
+ 16490,
+ 16491,
+ 16492,
+ 16493,
+ 16494,
+ 16495,
+ 16496,
+ 16497,
+ 16498,
+ 16499,
+ 16500,
+ 16501,
+ 16502,
+ 16503,
+ 16504,
+ 16505,
+ 16506,
+ 16507,
+ 16508,
+ 16509,
+ 16510,
+ 16511,
+ 16512,
+ 16513,
+ 16514,
+ 16515,
+ 16516,
+ 16517,
+ 16518,
+ 16519,
+ 16520,
+ 16521,
+ 16522,
+ 16523,
+ 16524,
+ 16525,
+ 16526,
+ 16527,
+ 16528,
+ 16529,
+ 16530,
+ 16531,
+ 16532,
+ 16533,
+ 16534,
+ 16535,
+ 16536,
+ 16537,
+ 16538,
+ 16539,
+ 16540,
+ 16541,
+ 16542,
+ 16543,
+ 16544,
+ 16545,
+ 16546,
+ 16547,
+ 16548,
+ 16549,
+ 16550,
+ 16551,
+ 16552,
+ 16553,
+ 16554,
+ 16555,
+ 16556,
+ 16557,
+ 16558,
+ 16559,
+ 16560,
+ 16561,
+ 16562,
+ 16563,
+ 16564,
+ 16565,
+ 16566,
+ 16567,
+ 16568,
+ 16569,
+ 16570,
+ 16571,
+ 16572,
+ 16573,
+ 16574,
+ 16575,
+ 16576,
+ 16577,
+ 16578,
+ 16579,
+ 16580,
+ 16581,
+ 16582,
+ 16583,
+ 16584,
+ 16585,
+ 16586,
+ 16587,
+ 16588,
+ 16589,
+ 16590,
+ 16591,
+ 16592,
+ 16593,
+ 16594,
+ 16595,
+ 16596,
+ 16597,
+ 16598,
+ 16599,
+ 16600,
+ 16601,
+ 16602,
+ 16603,
+ 16604,
+ 16605,
+ 16606,
+ 16607,
+ 16608,
+ 16609,
+ 16610,
+ 16611,
+ 16612,
+ 16613,
+ 16614,
+ 16615,
+ 16616,
+ 16617,
+ 16618,
+ 16619,
+ 16620,
+ 16621,
+ 16622,
+ 16623,
+ 16624,
+ 16625,
+ 16626,
+ 16627,
+ 16628,
+ 16629,
+ 16630,
+ 16631,
+ 16632,
+ 16633,
+ 16634,
+ 16635,
+ 16636,
+ 16637,
+ 16638,
+ 16639,
+ 16640,
+ 16641,
+ 16642,
+ 16643,
+ 16644,
+ 16645,
+ 16646,
+ 16647,
+ 16648,
+ 16649,
+ 16650,
+ 16651,
+ 16652,
+ 16653,
+ 16654,
+ 16655,
+ 16656,
+ 16657,
+ 16658,
+ 16659,
+ 16660,
+ 16661,
+ 16662,
+ 16663,
+ 16664,
+ 16665,
+ 16666,
+ 16667,
+ 16668,
+ 16669,
+ 16670,
+ 16671,
+ 16672,
+ 16673,
+ 16674,
+ 16675,
+ 16676,
+ 16677,
+ 16678,
+ 16679,
+ 16680,
+ 16681,
+ 16682,
+ 16683,
+ 16684,
+ 16685,
+ 16686,
+ 16687,
+ 16688,
+ 16689,
+ 16690,
+ 16691,
+ 16692,
+ 16693,
+ 16694,
+ 16695,
+ 16696,
+ 16697,
+ 16698,
+ 16699,
+ 16700,
+ 16701,
+ 16702,
+ 16703,
+ 16704,
+ 16705,
+ 16706,
+ 16707,
+ 16708,
+ 16709,
+ 16710,
+ 16711,
+ 16712,
+ 16713,
+ 16714,
+ 16715,
+ 16716,
+ 16717,
+ 16718,
+ 16719,
+ 16720,
+ 16721,
+ 16722,
+ 16723,
+ 16724,
+ 16725,
+ 16726,
+ 16727,
+ 16728,
+ 16729,
+ 16730,
+ 16731,
+ 16732,
+ 16733,
+ 16734,
+ 16735,
+ 16736,
+ 16737,
+ 16738,
+ 16739,
+ 16740,
+ 16741,
+ 16742,
+ 16743,
+ 16744,
+ 16745,
+ 16746,
+ 16747,
+ 16748,
+ 16749,
+ 16750,
+ 16751,
+ 16752,
+ 16753,
+ 16754,
+ 16755,
+ 16756,
+ 16757,
+ 16758,
+ 16759,
+ 16760,
+ 16761,
+ 16762,
+ 16763,
+ 16764,
+ 16765,
+ 16766,
+ 16767,
+ 16768,
+ 16769,
+ 16770,
+ 16771,
+ 16772,
+ 16773,
+ 16774,
+ 16775,
+ 16776,
+ 16777,
+ 16778,
+ 16779,
+ 16780,
+ 16781,
+ 16782,
+ 16783,
+ 16784,
+ 16785,
+ 16786,
+ 16787,
+ 16788,
+ 16789,
+ 16790,
+ 16791,
+ 16792,
+ 16793,
+ 16794,
+ 16795,
+ 16796,
+ 16797,
+ 16798,
+ 16799,
+ 16800,
+ 16801,
+ 16802,
+ 16803,
+ 16804,
+ 16805,
+ 16806,
+ 16807,
+ 16808,
+ 16809,
+ 16810,
+ 16811,
+ 16812,
+ 16813,
+ 16814,
+ 16815,
+ 16816,
+ 16817,
+ 16818,
+ 16819,
+ 16820,
+ 16821,
+ 16822,
+ 16823,
+ 16824,
+ 16825,
+ 16826,
+ 16827,
+ 16828,
+ 16829,
+ 16830,
+ 16831,
+ 16832,
+ 16833,
+ 16834,
+ 16835,
+ 16836,
+ 16837,
+ 16838,
+ 16839,
+ 16840,
+ 16841,
+ 16842,
+ 16843,
+ 16844,
+ 16845,
+ 16846,
+ 16847,
+ 16848,
+ 16849,
+ 16850,
+ 16851,
+ 16852,
+ 16853,
+ 16854,
+ 16855,
+ 16856,
+ 16857,
+ 16858,
+ 16859,
+ 16860,
+ 16861,
+ 16862,
+ 16863,
+ 16864,
+ 16865,
+ 16866,
+ 16867,
+ 16868,
+ 16869,
+ 16870,
+ 16871,
+ 16872,
+ 16873,
+ 16874,
+ 16875,
+ 16876,
+ 16877,
+ 16878,
+ 16879,
+ 16880,
+ 16881,
+ 16882,
+ 16883,
+ 16884,
+ 16885,
+ 16886,
+ 16887,
+ 16888,
+ 16889,
+ 16890,
+ 16891,
+ 16892,
+ 16893,
+ 16894,
+ 16895,
+ 16896,
+ 16897,
+ 16898,
+ 16899,
+ 16900,
+ 16901,
+ 16902,
+ 16903,
+ 16904,
+ 16905,
+ 16906,
+ 16907,
+ 16908,
+ 16909,
+ 16910,
+ 16911,
+ 16912,
+ 16913,
+ 16914,
+ 16915,
+ 16916,
+ 16917,
+ 16918,
+ 16919,
+ 16920,
+ 16921,
+ 16922,
+ 16923,
+ 16924,
+ 16925,
+ 16926,
+ 16927,
+ 16928,
+ 16929,
+ 16930,
+ 16931,
+ 16932,
+ 16933,
+ 16934,
+ 16935,
+ 16936,
+ 16937,
+ 16938,
+ 16939,
+ 16940,
+ 16941,
+ 16942,
+ 16943,
+ 16944,
+ 16945,
+ 16946,
+ 16947,
+ 16948,
+ 16949,
+ 16950,
+ 16951,
+ 16952,
+ 16953,
+ 16954,
+ 16955,
+ 16956,
+ 16957,
+ 16958,
+ 16959,
+ 16960,
+ 16961,
+ 16962,
+ 16963,
+ 16964,
+ 16965,
+ 16966,
+ 16967,
+ 16968,
+ 16969,
+ 16970,
+ 16971,
+ 16972,
+ 16973,
+ 16974,
+ 16975,
+ 16976,
+ 16977,
+ 16978,
+ 16979,
+ 16980,
+ 16981,
+ 16982,
+ 16983,
+ 16984,
+ 16985,
+ 16986,
+ 16987,
+ 16988,
+ 16989,
+ 16990,
+ 16991,
+ 16992,
+ 16993,
+ 16994,
+ 16995,
+ 16996,
+ 16997,
+ 16998,
+ 16999,
+ 17000,
+ 17001,
+ 17002,
+ 17003,
+ 17004,
+ 17005,
+ 17006,
+ 17007,
+ 17008,
+ 17009,
+ 17010,
+ 17011,
+ 17012,
+ 17013,
+ 17014,
+ 17015,
+ 17016,
+ 17017,
+ 17018,
+ 17019,
+ 17020,
+ 17021,
+ 17022,
+ 17023,
+ 17024,
+ 17025,
+ 17026,
+ 17027,
+ 17028,
+ 17029,
+ 17030,
+ 17031,
+ 17032,
+ 17033,
+ 17034,
+ 17035,
+ 17036,
+ 17037,
+ 17038,
+ 17039,
+ 17040,
+ 17041,
+ 17042,
+ 17043,
+ 17044,
+ 17045,
+ 17046,
+ 17047,
+ 17048,
+ 17049,
+ 17050,
+ 17051,
+ 17052,
+ 17053,
+ 17054,
+ 17055,
+ 17056,
+ 17057,
+ 17058,
+ 17059,
+ 17060,
+ 17061,
+ 17062,
+ 17063,
+ 17064,
+ 17065,
+ 17066,
+ 17067,
+ 17068,
+ 17069,
+ 17070,
+ 17071,
+ 17072,
+ 17073,
+ 17074,
+ 17075,
+ 17076,
+ 17077,
+ 17078,
+ 17079,
+ 17080,
+ 17081,
+ 17082,
+ 17083,
+ 17084,
+ 17085,
+ 17086,
+ 17087,
+ 17088,
+ 17089,
+ 17090,
+ 17091,
+ 17092,
+ 17093,
+ 17094,
+ 17095,
+ 17096,
+ 17097,
+ 17098,
+ 17099,
+ 17100,
+ 17101,
+ 17102,
+ 17103,
+ 17104,
+ 17105,
+ 17106,
+ 17107,
+ 17108,
+ 17109,
+ 17110,
+ 17111,
+ 17112,
+ 17113,
+ 17114,
+ 17115,
+ 17116,
+ 17117,
+ 17118,
+ 17119,
+ 17120,
+ 17121,
+ 17122,
+ 17123,
+ 17124,
+ 17125,
+ 17126,
+ 17127,
+ 17128,
+ 17129,
+ 17130,
+ 17131,
+ 17132,
+ 17133,
+ 17134,
+ 17135,
+ 17136,
+ 17137,
+ 17138,
+ 17139,
+ 17140,
+ 17141,
+ 17142,
+ 17143,
+ 17144,
+ 17145,
+ 17146,
+ 17147,
+ 17148,
+ 17149,
+ 17150,
+ 17151,
+ 17152,
+ 17153,
+ 17154,
+ 17155,
+ 17156,
+ 17157,
+ 17158,
+ 17159,
+ 17160,
+ 17161,
+ 17162,
+ 17163,
+ 17164,
+ 17165,
+ 17166,
+ 17167,
+ 17168,
+ 17169,
+ 17170,
+ 17171,
+ 17172,
+ 17173,
+ 17174,
+ 17175,
+ 17176,
+ 17177,
+ 17178,
+ 17179,
+ 17180,
+ 17181,
+ 17182,
+ 17183,
+ 17184,
+ 17185,
+ 17186,
+ 17187,
+ 17188,
+ 17189,
+ 17190,
+ 17191,
+ 17192,
+ 17193,
+ 17194,
+ 17195,
+ 17196,
+ 17197,
+ 17198,
+ 17199,
+ 17200,
+ 17201,
+ 17202,
+ 17203,
+ 17204,
+ 17205,
+ 17206,
+ 17207,
+ 17208,
+ 17209,
+ 17210,
+ 17211,
+ 17212,
+ 17213,
+ 17214,
+ 17215,
+ 17216,
+ 17217,
+ 17218,
+ 17219,
+ 17220,
+ 17221,
+ 17222,
+ 17223,
+ 17224,
+ 17225,
+ 17226,
+ 17227,
+ 17228,
+ 17229,
+ 17230,
+ 17231,
+ 17232,
+ 17233,
+ 17234,
+ 17235,
+ 17236,
+ 17237,
+ 17238,
+ 17239,
+ 17240,
+ 17241,
+ 17242,
+ 17243,
+ 17244,
+ 17245,
+ 17246,
+ 17247,
+ 17248,
+ 17249,
+ 17250,
+ 17251,
+ 17252,
+ 17253,
+ 17254,
+ 17255,
+ 17256,
+ 17257,
+ 17258,
+ 17259,
+ 17260,
+ 17261,
+ 17262,
+ 17263,
+ 17264,
+ 17265,
+ 17266,
+ 17267,
+ 17268,
+ 17269,
+ 17270,
+ 17271,
+ 17272,
+ 17273,
+ 17274,
+ 17275,
+ 17276,
+ 17277,
+ 17278,
+ 17279,
+ 17280,
+ 17281,
+ 17282,
+ 17283,
+ 17284,
+ 17285,
+ 17286,
+ 17287,
+ 17288,
+ 17289,
+ 17290,
+ 17291,
+ 17292,
+ 17293,
+ 17294,
+ 17295,
+ 17296,
+ 17297,
+ 17298,
+ 17299,
+ 17300,
+ 17301,
+ 17302,
+ 17303,
+ 17304,
+ 17305,
+ 17306,
+ 17307,
+ 17308,
+ 17309,
+ 17310,
+ 17311,
+ 17312,
+ 17313,
+ 17314,
+ 17315,
+ 17316,
+ 17317,
+ 17318,
+ 17319,
+ 17320,
+ 17321,
+ 17322,
+ 17323,
+ 17324,
+ 17325,
+ 17326,
+ 17327,
+ 17328,
+ 17329,
+ 17330,
+ 17331,
+ 17332,
+ 17333,
+ 17334,
+ 17335,
+ 17336,
+ 17337,
+ 17338,
+ 17339,
+ 17340,
+ 17341,
+ 17342,
+ 17343,
+ 17344,
+ 17345,
+ 17346,
+ 17347,
+ 17348,
+ 17349,
+ 17350,
+ 17351,
+ 17352,
+ 17353,
+ 17354,
+ 17355,
+ 17356,
+ 17357,
+ 17358,
+ 17359,
+ 17360,
+ 17361,
+ 17362,
+ 17363,
+ 17364,
+ 17365,
+ 17366,
+ 17367,
+ 17368,
+ 17369,
+ 17370,
+ 17371,
+ 17372,
+ 17373,
+ 17374,
+ 17375,
+ 17376,
+ 17377,
+ 17378,
+ 17379,
+ 17380,
+ 17381,
+ 17382,
+ 17383,
+ 17384,
+ 17385,
+ 17386,
+ 17387,
+ 17388,
+ 17389,
+ 17390,
+ 17391,
+ 17392,
+ 17393,
+ 17394,
+ 17395,
+ 17396,
+ 17397,
+ 17398,
+ 17399,
+ 17400,
+ 17401,
+ 17402,
+ 17403,
+ 17404,
+ 17405,
+ 17406,
+ 17407,
+ 17408,
+ 17409,
+ 17410,
+ 17411,
+ 17412,
+ 17413,
+ 17414,
+ 17415,
+ 17416,
+ 17417,
+ 17418,
+ 17419,
+ 17420,
+ 17421,
+ 17422,
+ 17423,
+ 17424,
+ 17425,
+ 17426,
+ 17427,
+ 17428,
+ 17429,
+ 17430,
+ 17431,
+ 17432,
+ 17433,
+ 17434,
+ 17435,
+ 17436,
+ 17437,
+ 17438,
+ 17439,
+ 17440,
+ 17441,
+ 17442,
+ 17443,
+ 17444,
+ 17445,
+ 17446,
+ 17447,
+ 17448,
+ 17449,
+ 17450,
+ 17451,
+ 17452,
+ 17453,
+ 17454,
+ 17455,
+ 17456,
+ 17457,
+ 17458,
+ 17459,
+ 17460,
+ 17461,
+ 17462,
+ 17463,
+ 17464,
+ 17465,
+ 17466,
+ 17467,
+ 17468,
+ 17469,
+ 17470,
+ 17471,
+ 17472,
+ 17473,
+ 17474,
+ 17475,
+ 17476,
+ 17477,
+ 17478,
+ 17479,
+ 17480,
+ 17481,
+ 17482,
+ 17483,
+ 17484,
+ 17485,
+ 17486,
+ 17487,
+ 17488,
+ 17489,
+ 17490,
+ 17491,
+ 17492,
+ 17493,
+ 17494,
+ 17495,
+ 17496,
+ 17497,
+ 17498,
+ 17499,
+ 17500,
+ 17501,
+ 17502,
+ 17503,
+ 17504,
+ 17505,
+ 17506,
+ 17507,
+ 17508,
+ 17509,
+ 17510,
+ 17511,
+ 17512,
+ 17513,
+ 17514,
+ 17515,
+ 17516,
+ 17517,
+ 17518,
+ 17519,
+ 17520,
+ 17521,
+ 17522,
+ 17523,
+ 17524,
+ 17525,
+ 17526,
+ 17527,
+ 17528,
+ 17529,
+ 17530,
+ 17531,
+ 17532,
+ 17533,
+ 17534,
+ 17535,
+ 17536,
+ 17537,
+ 17538,
+ 17539,
+ 17540,
+ 17541,
+ 17542,
+ 17543,
+ 17544,
+ 17545,
+ 17546,
+ 17547,
+ 17548,
+ 17549,
+ 17550,
+ 17551,
+ 17552,
+ 17553,
+ 17554,
+ 17555,
+ 17556,
+ 17557,
+ 17558,
+ 17559,
+ 17560,
+ 17561,
+ 17562,
+ 17563,
+ 17564,
+ 17565,
+ 17566,
+ 17567,
+ 17568,
+ 17569,
+ 17570,
+ 17571,
+ 17572,
+ 17573,
+ 17574,
+ 17575,
+ 17576,
+ 17577,
+ 17578,
+ 17579,
+ 17580,
+ 17581,
+ 17582,
+ 17583,
+ 17584,
+ 17585,
+ 17586,
+ 17587,
+ 17588,
+ 17589,
+ 17590,
+ 17591,
+ 17592,
+ 17593,
+ 17594,
+ 17595,
+ 17596,
+ 17597,
+ 17598,
+ 17599,
+ 17600,
+ 17601,
+ 17602,
+ 17603,
+ 17604,
+ 17605,
+ 17606,
+ 17607,
+ 17608,
+ 17609,
+ 17610,
+ 17611,
+ 17612,
+ 17613,
+ 17614,
+ 17615,
+ 17616,
+ 17617,
+ 17618,
+ 17619,
+ 17620,
+ 17621,
+ 17622,
+ 17623,
+ 17624,
+ 17625,
+ 17626,
+ 17627,
+ 17628,
+ 17629,
+ 17630,
+ 17631,
+ 17632,
+ 17633,
+ 17634,
+ 17635,
+ 17636,
+ 17637,
+ 17638,
+ 17639,
+ 17640,
+ 17641,
+ 17642,
+ 17643,
+ 17644,
+ 17645,
+ 17646,
+ 17647,
+ 17648,
+ 17649,
+ 17650,
+ 17651,
+ 17652,
+ 17653,
+ 17654,
+ 17655,
+ 17656,
+ 17657,
+ 17658,
+ 17659,
+ 17660,
+ 17661,
+ 17662,
+ 17663,
+ 17664,
+ 17665,
+ 17666,
+ 17667,
+ 17668,
+ 17669,
+ 17670,
+ 17671,
+ 17672,
+ 17673,
+ 17674,
+ 17675,
+ 17676,
+ 17677,
+ 17678,
+ 17679,
+ 17680,
+ 17681,
+ 17682,
+ 17683,
+ 17684,
+ 17685,
+ 17686,
+ 17687,
+ 17688,
+ 17689,
+ 17690,
+ 17691,
+ 17692,
+ 17693,
+ 17694,
+ 17695,
+ 17696,
+ 17697,
+ 17698,
+ 17699,
+ 17700,
+ 17701,
+ 17702,
+ 17703,
+ 17704,
+ 17705,
+ 17706,
+ 17707,
+ 17708,
+ 17709,
+ 17710,
+ 17711,
+ 17712,
+ 17713,
+ 17714,
+ 17715,
+ 17716,
+ 17717,
+ 17718,
+ 17719,
+ 17720,
+ 17721,
+ 17722,
+ 17723,
+ 17724,
+ 17725,
+ 17726,
+ 17727,
+ 17728,
+ 17729,
+ 17730,
+ 17731,
+ 17732,
+ 17733,
+ 17734,
+ 17735,
+ 17736,
+ 17737,
+ 17738,
+ 17739,
+ 17740,
+ 17741,
+ 17742,
+ 17743,
+ 17744,
+ 17745,
+ 17746,
+ 17747,
+ 17748,
+ 17749,
+ 17750,
+ 17751,
+ 17752,
+ 17753,
+ 17754,
+ 17755,
+ 17756,
+ 17757,
+ 17758,
+ 17759,
+ 17760,
+ 17761,
+ 17762,
+ 17763,
+ 17764,
+ 17765,
+ 17766,
+ 17767,
+ 17768,
+ 17769,
+ 17770,
+ 17771,
+ 17772,
+ 17773,
+ 17774,
+ 17775,
+ 17776,
+ 17777,
+ 17778,
+ 17779,
+ 17780,
+ 17781,
+ 17782,
+ 17783,
+ 17784,
+ 17785,
+ 17786,
+ 17787,
+ 17788,
+ 17789,
+ 17790,
+ 17791,
+ 17792,
+ 17793,
+ 17794,
+ 17795,
+ 17796,
+ 17797,
+ 17798,
+ 17799,
+ 17800,
+ 17801,
+ 17802,
+ 17803,
+ 17804,
+ 17805,
+ 17806,
+ 17807,
+ 17808,
+ 17809,
+ 17810,
+ 17811,
+ 17812,
+ 17813,
+ 17814,
+ 17815,
+ 17816,
+ 17817,
+ 17818,
+ 17819,
+ 17820,
+ 17821,
+ 17822,
+ 17823,
+ 17824,
+ 17825,
+ 17826,
+ 17827,
+ 17828,
+ 17829,
+ 17830,
+ 17831,
+ 17832,
+ 17833,
+ 17834,
+ 17835,
+ 17836,
+ 17837,
+ 17838,
+ 17839,
+ 17840,
+ 17841,
+ 17842,
+ 17843,
+ 17844,
+ 17845,
+ 17846,
+ 17847,
+ 17848,
+ 17849,
+ 17850,
+ 17851,
+ 17852,
+ 17853,
+ 17854,
+ 17855,
+ 17856,
+ 17857,
+ 17858,
+ 17859,
+ 17860,
+ 17861,
+ 17862,
+ 17863,
+ 17864,
+ 17865,
+ 17866,
+ 17867,
+ 17868,
+ 17869,
+ 17870,
+ 17871,
+ 17872,
+ 17873,
+ 17874,
+ 17875,
+ 17876,
+ 17877,
+ 17878,
+ 17879,
+ 17880,
+ 17881,
+ 17882,
+ 17883,
+ 17884,
+ 17885,
+ 17886,
+ 17887,
+ 17888,
+ 17889,
+ 17890,
+ 17891,
+ 17892,
+ 17893,
+ 17894,
+ 17895,
+ 17896,
+ 17897,
+ 17898,
+ 17899,
+ 17900,
+ 17901,
+ 17902,
+ 17903,
+ 17904,
+ 17905,
+ 17906,
+ 17907,
+ 17908,
+ 17909,
+ 17910,
+ 17911,
+ 17912,
+ 17913,
+ 17914,
+ 17915,
+ 17916,
+ 17917,
+ 17918,
+ 17919,
+ 17920,
+ 17921,
+ 17922,
+ 17923,
+ 17924,
+ 17925,
+ 17926,
+ 17927,
+ 17928,
+ 17929,
+ 17930,
+ 17931,
+ 17932,
+ 17933,
+ 17934,
+ 17935,
+ 17936,
+ 17937,
+ 17938,
+ 17939,
+ 17940,
+ 17941,
+ 17942,
+ 17943,
+ 17944,
+ 17945,
+ 17946,
+ 17947,
+ 17948,
+ 17949,
+ 17950,
+ 17951,
+ 17952,
+ 17953,
+ 17954,
+ 17955,
+ 17956,
+ 17957,
+ 17958,
+ 17959,
+ 17960,
+ 17961,
+ 17962,
+ 17963,
+ 17964,
+ 17965,
+ 17966,
+ 17967,
+ 17968,
+ 17969,
+ 17970,
+ 17971,
+ 17972,
+ 17973,
+ 17974,
+ 17975,
+ 17976,
+ 17977,
+ 17978,
+ 17979,
+ 17980,
+ 17981,
+ 17982,
+ 17983,
+ 17984,
+ 17985,
+ 17986,
+ 17987,
+ 17988,
+ 17989,
+ 17990,
+ 17991,
+ 17992,
+ 17993,
+ 17994,
+ 17995,
+ 17996,
+ 17997,
+ 17998,
+ 17999,
+ 18000,
+ 18001,
+ 18002,
+ 18003,
+ 18004,
+ 18005,
+ 18006,
+ 18007,
+ 18008,
+ 18009,
+ 18010,
+ 18011,
+ 18012,
+ 18013,
+ 18014,
+ 18015,
+ 18016,
+ 18017,
+ 18018,
+ 18019,
+ 18020,
+ 18021,
+ 18022,
+ 18023,
+ 18024,
+ 18025,
+ 18026,
+ 18027,
+ 18028,
+ 18029,
+ 18030,
+ 18031,
+ 18032,
+ 18033,
+ 18034,
+ 18035,
+ 18036,
+ 18037,
+ 18038,
+ 18039,
+ 18040,
+ 18041,
+ 18042,
+ 18043,
+ 18044,
+ 18045,
+ 18046,
+ 18047,
+ 18048,
+ 18049,
+ 18050,
+ 18051,
+ 18052,
+ 18053,
+ 18054,
+ 18055,
+ 18056,
+ 18057,
+ 18058,
+ 18059,
+ 18060,
+ 18061,
+ 18062,
+ 18063,
+ 18064,
+ 18065,
+ 18066,
+ 18067,
+ 18068,
+ 18069,
+ 18070,
+ 18071,
+ 18072,
+ 18073,
+ 18074,
+ 18075,
+ 18076,
+ 18077,
+ 18078,
+ 18079,
+ 18080,
+ 18081,
+ 18082,
+ 18083,
+ 18084,
+ 18085,
+ 18086,
+ 18087,
+ 18088,
+ 18089,
+ 18090,
+ 18091,
+ 18092,
+ 18093,
+ 18094,
+ 18095,
+ 18096,
+ 18097,
+ 18098,
+ 18099,
+ 18100,
+ 18101,
+ 18102,
+ 18103,
+ 18104,
+ 18105,
+ 18106,
+ 18107,
+ 18108,
+ 18109,
+ 18110,
+ 18111,
+ 18112,
+ 18113,
+ 18114,
+ 18115,
+ 18116,
+ 18117,
+ 18118,
+ 18119,
+ 18120,
+ 18121,
+ 18122,
+ 18123,
+ 18124,
+ 18125,
+ 18126,
+ 18127,
+ 18128,
+ 18129,
+ 18130,
+ 18131,
+ 18132,
+ 18133,
+ 18134,
+ 18135,
+ 18136,
+ 18137,
+ 18138,
+ 18139,
+ 18140,
+ 18141,
+ 18142,
+ 18143,
+ 18144,
+ 18145,
+ 18146,
+ 18147,
+ 18148,
+ 18149,
+ 18150,
+ 18151,
+ 18152,
+ 18153,
+ 18154,
+ 18155,
+ 18156,
+ 18157,
+ 18158,
+ 18159,
+ 18160,
+ 18161,
+ 18162,
+ 18163,
+ 18164,
+ 18165,
+ 18166,
+ 18167,
+ 18168,
+ 18169,
+ 18170,
+ 18171,
+ 18172,
+ 18173,
+ 18174,
+ 18175,
+ 18176,
+ 18177,
+ 18178,
+ 18179,
+ 18180,
+ 18181,
+ 18182,
+ 18183,
+ 18184,
+ 18185,
+ 18186,
+ 18187,
+ 18188,
+ 18189,
+ 18190,
+ 18191,
+ 18192,
+ 18193,
+ 18194,
+ 18195,
+ 18196,
+ 18197,
+ 18198,
+ 18199,
+ 18200,
+ 18201,
+ 18202,
+ 18203,
+ 18204,
+ 18205,
+ 18206,
+ 18207,
+ 18208,
+ 18209,
+ 18210,
+ 18211,
+ 18212,
+ 18213,
+ 18214,
+ 18215,
+ 18216,
+ 18217,
+ 18218,
+ 18219,
+ 18220,
+ 18221,
+ 18222,
+ 18223,
+ 18224,
+ 18225,
+ 18226,
+ 18227,
+ 18228,
+ 18229,
+ 18230,
+ 18231,
+ 18232,
+ 18233,
+ 18234,
+ 18235,
+ 18236,
+ 18237,
+ 18238,
+ 18239,
+ 18240,
+ 18241,
+ 18242,
+ 18243,
+ 18244,
+ 18245,
+ 18246,
+ 18247,
+ 18248,
+ 18249,
+ 18250,
+ 18251,
+ 18252,
+ 18253,
+ 18254,
+ 18255,
+ 18256,
+ 18257,
+ 18258,
+ 18259,
+ 18260,
+ 18261,
+ 18262,
+ 18263,
+ 18264,
+ 18265,
+ 18266,
+ 18267,
+ 18268,
+ 18269,
+ 18270,
+ 18271,
+ 18272,
+ 18273,
+ 18274,
+ 18275,
+ 18276,
+ 18277,
+ 18278,
+ 18279,
+ 18280,
+ 18281,
+ 18282,
+ 18283,
+ 18284,
+ 18285,
+ 18286,
+ 18287,
+ 18288,
+ 18289,
+ 18290,
+ 18291,
+ 18292,
+ 18293,
+ 18294,
+ 18295,
+ 18296,
+ 18297,
+ 18298,
+ 18299,
+ 18300,
+ 18301,
+ 18302,
+ 18303,
+ 18304,
+ 18305,
+ 18306,
+ 18307,
+ 18308,
+ 18309,
+ 18310,
+ 18311,
+ 18312,
+ 18313,
+ 18314,
+ 18315,
+ 18316,
+ 18317,
+ 18318,
+ 18319,
+ 18320,
+ 18321,
+ 18322,
+ 18323,
+ 18324,
+ 18325,
+ 18326,
+ 18327,
+ 18328,
+ 18329,
+ 18330,
+ 18331,
+ 18332,
+ 18333,
+ 18334,
+ 18335,
+ 18336,
+ 18337,
+ 18338,
+ 18339,
+ 18340,
+ 18341,
+ 18342,
+ 18343,
+ 18344,
+ 18345,
+ 18346,
+ 18347,
+ 18348,
+ 18349,
+ 18350,
+ 18351,
+ 18352,
+ 18353,
+ 18354,
+ 18355,
+ 18356,
+ 18357,
+ 18358,
+ 18359,
+ 18360,
+ 18361,
+ 18362,
+ 18363,
+ 18364,
+ 18365,
+ 18366,
+ 18367,
+ 18368,
+ 18369,
+ 18370,
+ 18371,
+ 18372,
+ 18373,
+ 18374,
+ 18375,
+ 18376,
+ 18377,
+ 18378,
+ 18379,
+ 18380,
+ 18381,
+ 18382,
+ 18383,
+ 18384,
+ 18385,
+ 18386,
+ 18387,
+ 18388,
+ 18389,
+ 18390,
+ 18391,
+ 18392,
+ 18393,
+ 18394,
+ 18395,
+ 18396,
+ 18397,
+ 18398,
+ 18399,
+ 18400,
+ 18401,
+ 18402,
+ 18403,
+ 18404,
+ 18405,
+ 18406,
+ 18407,
+ 18408,
+ 18409,
+ 18410,
+ 18411,
+ 18412,
+ 18413,
+ 18414,
+ 18415,
+ 18416,
+ 18417,
+ 18418,
+ 18419,
+ 18420,
+ 18421,
+ 18422,
+ 18423,
+ 18424,
+ 18425,
+ 18426,
+ 18427,
+ 18428,
+ 18429,
+ 18430,
+ 18431,
+ 18432,
+ 18433,
+ 18434,
+ 18435,
+ 18436,
+ 18437,
+ 18438,
+ 18439,
+ 18440,
+ 18441,
+ 18442,
+ 18443,
+ 18444,
+ 18445,
+ 18446,
+ 18447,
+ 18448,
+ 18449,
+ 18450,
+ 18451,
+ 18452,
+ 18453,
+ 18454,
+ 18455,
+ 18456,
+ 18457,
+ 18458,
+ 18459,
+ 18460,
+ 18461,
+ 18462,
+ 18463,
+ 18464,
+ 18465,
+ 18466,
+ 18467,
+ 18468,
+ 18469,
+ 18470,
+ 18471,
+ 18472,
+ 18473,
+ 18474,
+ 18475,
+ 18476,
+ 18477,
+ 18478,
+ 18479,
+ 18480,
+ 18481,
+ 18482,
+ 18483,
+ 18484,
+ 18485,
+ 18486,
+ 18487,
+ 18488,
+ 18489,
+ 18490,
+ 18491,
+ 18492,
+ 18493,
+ 18494,
+ 18495,
+ 18496,
+ 18497,
+ 18498,
+ 18499,
+ 18500,
+ 18501,
+ 18502,
+ 18503,
+ 18504,
+ 18505,
+ 18506,
+ 18507,
+ 18508,
+ 18509,
+ 18510,
+ 18511,
+ 18512,
+ 18513,
+ 18514,
+ 18515,
+ 18516,
+ 18517,
+ 18518,
+ 18519,
+ 18520,
+ 18521,
+ 18522,
+ 18523,
+ 18524,
+ 18525,
+ 18526,
+ 18527,
+ 18528,
+ 18529,
+ 18530,
+ 18531,
+ 18532,
+ 18533,
+ 18534,
+ 18535,
+ 18536,
+ 18537,
+ 18538,
+ 18539,
+ 18540,
+ 18541,
+ 18542,
+ 18543,
+ 18544,
+ 18545,
+ 18546,
+ 18547,
+ 18548,
+ 18549,
+ 18550,
+ 18551,
+ 18552,
+ 18553,
+ 18554,
+ 18555,
+ 18556,
+ 18557,
+ 18558,
+ 18559,
+ 18560,
+ 18561,
+ 18562,
+ 18563,
+ 18564,
+ 18565,
+ 18566,
+ 18567,
+ 18568,
+ 18569,
+ 18570,
+ 18571,
+ 18572,
+ 18573,
+ 18574,
+ 18575,
+ 18576,
+ 18577,
+ 18578,
+ 18579,
+ 18580,
+ 18581,
+ 18582,
+ 18583,
+ 18584,
+ 18585,
+ 18586,
+ 18587,
+ 18588,
+ 18589,
+ 18590,
+ 18591,
+ 18592,
+ 18593,
+ 18594,
+ 18595,
+ 18596,
+ 18597,
+ 18598,
+ 18599,
+ 18600,
+ 18601,
+ 18602,
+ 18603,
+ 18604,
+ 18605,
+ 18606,
+ 18607,
+ 18608,
+ 18609,
+ 18610,
+ 18611,
+ 18612,
+ 18613,
+ 18614,
+ 18615,
+ 18616,
+ 18617,
+ 18618,
+ 18619,
+ 18620,
+ 18621,
+ 18622,
+ 18623,
+ 18624,
+ 18625,
+ 18626,
+ 18627,
+ 18628,
+ 18629,
+ 18630,
+ 18631,
+ 18632,
+ 18633,
+ 18634,
+ 18635,
+ 18636,
+ 18637,
+ 18638,
+ 18639,
+ 18640,
+ 18641,
+ 18642,
+ 18643,
+ 18644,
+ 18645,
+ 18646,
+ 18647,
+ 18648,
+ 18649,
+ 18650,
+ 18651,
+ 18652,
+ 18653,
+ 18654,
+ 18655,
+ 18656,
+ 18657,
+ 18658,
+ 18659,
+ 18660,
+ 18661,
+ 18662,
+ 18663,
+ 18664,
+ 18665,
+ 18666,
+ 18667,
+ 18668,
+ 18669,
+ 18670,
+ 18671,
+ 18672,
+ 18673,
+ 18674,
+ 18675,
+ 18676,
+ 18677,
+ 18678,
+ 18679,
+ 18680,
+ 18681,
+ 18682,
+ 18683,
+ 18684,
+ 18685,
+ 18686,
+ 18687,
+ 18688,
+ 18689,
+ 18690,
+ 18691,
+ 18692,
+ 18693,
+ 18694,
+ 18695,
+ 18696,
+ 18697,
+ 18698,
+ 18699,
+ 18700,
+ 18701,
+ 18702,
+ 18703,
+ 18704,
+ 18705,
+ 18706,
+ 18707,
+ 18708,
+ 18709,
+ 18710,
+ 18711,
+ 18712,
+ 18713,
+ 18714,
+ 18715,
+ 18716,
+ 18717,
+ 18718,
+ 18719,
+ 18720,
+ 18721,
+ 18722,
+ 18723,
+ 18724,
+ 18725,
+ 18726,
+ 18727,
+ 18728,
+ 18729,
+ 18730,
+ 18731,
+ 18732,
+ 18733,
+ 18734,
+ 18735,
+ 18736,
+ 18737,
+ 18738,
+ 18739,
+ 18740,
+ 18741,
+ 18742,
+ 18743,
+ 18744,
+ 18745,
+ 18746,
+ 18747,
+ 18748,
+ 18749,
+ 18750,
+ 18751,
+ 18752,
+ 18753,
+ 18754,
+ 18755,
+ 18756,
+ 18757,
+ 18758,
+ 18759,
+ 18760,
+ 18761,
+ 18762,
+ 18763,
+ 18764,
+ 18765,
+ 18766,
+ 18767,
+ 18768,
+ 18769,
+ 18770,
+ 18771,
+ 18772,
+ 18773,
+ 18774,
+ 18775,
+ 18776,
+ 18777,
+ 18778,
+ 18779,
+ 18780,
+ 18781,
+ 18782,
+ 18783,
+ 18784,
+ 18785,
+ 18786,
+ 18787,
+ 18788,
+ 18789,
+ 18790,
+ 18791,
+ 18792,
+ 18793,
+ 18794,
+ 18795,
+ 18796,
+ 18797,
+ 18798,
+ 18799,
+ 18800,
+ 18801,
+ 18802,
+ 18803,
+ 18804,
+ 18805,
+ 18806,
+ 18807,
+ 18808,
+ 18809,
+ 18810,
+ 18811,
+ 18812,
+ 18813,
+ 18814,
+ 18815,
+ 18816,
+ 18817,
+ 18818,
+ 18819,
+ 18820,
+ 18821,
+ 18822,
+ 18823,
+ 18824,
+ 18825,
+ 18826,
+ 18827,
+ 18828,
+ 18829,
+ 18830,
+ 18831,
+ 18832,
+ 18833,
+ 18834,
+ 18835,
+ 18836,
+ 18837,
+ 18838,
+ 18839,
+ 18840,
+ 18841,
+ 18842,
+ 18843,
+ 18844,
+ 18845,
+ 18846,
+ 18847,
+ 18848,
+ 18849,
+ 18850,
+ 18851,
+ 18852,
+ 18853,
+ 18854,
+ 18855,
+ 18856,
+ 18857,
+ 18858,
+ 18859,
+ 18860,
+ 18861,
+ 18862,
+ 18863,
+ 18864,
+ 18865,
+ 18866,
+ 18867,
+ 18868,
+ 18869,
+ 18870,
+ 18871,
+ 18872,
+ 18873,
+ 18874,
+ 18875,
+ 18876,
+ 18877,
+ 18878,
+ 18879,
+ 18880,
+ 18881,
+ 18882,
+ 18883,
+ 18884,
+ 18885,
+ 18886,
+ 18887,
+ 18888,
+ 18889,
+ 18890,
+ 18891,
+ 18892,
+ 18893,
+ 18894,
+ 18895,
+ 18896,
+ 18897,
+ 18898,
+ 18899,
+ 18900,
+ 18901,
+ 18902,
+ 18903,
+ 18904,
+ 18905,
+ 18906,
+ 18907,
+ 18908,
+ 18909,
+ 18910,
+ 18911,
+ 18912,
+ 18913,
+ 18914,
+ 18915,
+ 18916,
+ 18917,
+ 18918,
+ 18919,
+ 18920,
+ 18921,
+ 18922,
+ 18923,
+ 18924,
+ 18925,
+ 18926,
+ 18927,
+ 18928,
+ 18929,
+ 18930,
+ 18931,
+ 18932,
+ 18933,
+ 18934,
+ 18935,
+ 18936,
+ 18937,
+ 18938,
+ 18939,
+ 18940,
+ 18941,
+ 18942,
+ 18943,
+ 18944,
+ 18945,
+ 18946,
+ 18947,
+ 18948,
+ 18949,
+ 18950,
+ 18951,
+ 18952,
+ 18953,
+ 18954,
+ 18955,
+ 18956,
+ 18957,
+ 18958,
+ 18959,
+ 18960,
+ 18961,
+ 18962,
+ 18963,
+ 18964,
+ 18965,
+ 18966,
+ 18967,
+ 18968,
+ 18969,
+ 18970,
+ 18971,
+ 18972,
+ 18973,
+ 18974,
+ 18975,
+ 18976,
+ 18977,
+ 18978,
+ 18979,
+ 18980,
+ 18981,
+ 18982,
+ 18983,
+ 18984,
+ 18985,
+ 18986,
+ 18987,
+ 18988,
+ 18989,
+ 18990,
+ 18991,
+ 18992,
+ 18993,
+ 18994,
+ 18995,
+ 18996,
+ 18997,
+ 18998,
+ 18999,
+ 19000,
+ 19001,
+ 19002,
+ 19003,
+ 19004,
+ 19005,
+ 19006,
+ 19007,
+ 19008,
+ 19009,
+ 19010,
+ 19011,
+ 19012,
+ 19013,
+ 19014,
+ 19015,
+ 19016,
+ 19017,
+ 19018,
+ 19019,
+ 19020,
+ 19021,
+ 19022,
+ 19023,
+ 19024,
+ 19025,
+ 19026,
+ 19027,
+ 19028,
+ 19029,
+ 19030,
+ 19031,
+ 19032,
+ 19033,
+ 19034,
+ 19035,
+ 19036,
+ 19037,
+ 19038,
+ 19039,
+ 19040,
+ 19041,
+ 19042,
+ 19043,
+ 19044,
+ 19045,
+ 19046,
+ 19047,
+ 19048,
+ 19049,
+ 19050,
+ 19051,
+ 19052,
+ 19053,
+ 19054,
+ 19055,
+ 19056,
+ 19057,
+ 19058,
+ 19059,
+ 19060,
+ 19061,
+ 19062,
+ 19063,
+ 19064,
+ 19065,
+ 19066,
+ 19067,
+ 19068,
+ 19069,
+ 19070,
+ 19071,
+ 19072,
+ 19073,
+ 19074,
+ 19075,
+ 19076,
+ 19077,
+ 19078,
+ 19079,
+ 19080,
+ 19081,
+ 19082,
+ 19083,
+ 19084,
+ 19085,
+ 19086,
+ 19087,
+ 19088,
+ 19089,
+ 19090,
+ 19091,
+ 19092,
+ 19093,
+ 19094,
+ 19095,
+ 19096,
+ 19097,
+ 19098,
+ 19099,
+ 19100,
+ 19101,
+ 19102,
+ 19103,
+ 19104,
+ 19105,
+ 19106,
+ 19107,
+ 19108,
+ 19109,
+ 19110,
+ 19111,
+ 19112,
+ 19113,
+ 19114,
+ 19115,
+ 19116,
+ 19117,
+ 19118,
+ 19119,
+ 19120,
+ 19121,
+ 19122,
+ 19123,
+ 19124,
+ 19125,
+ 19126,
+ 19127,
+ 19128,
+ 19129,
+ 19130,
+ 19131,
+ 19132,
+ 19133,
+ 19134,
+ 19135,
+ 19136,
+ 19137,
+ 19138,
+ 19139,
+ 19140,
+ 19141,
+ 19142,
+ 19143,
+ 19144,
+ 19145,
+ 19146,
+ 19147,
+ 19148,
+ 19149,
+ 19150,
+ 19151,
+ 19152,
+ 19153,
+ 19154,
+ 19155,
+ 19156,
+ 19157,
+ 19158,
+ 19159,
+ 19160,
+ 19161,
+ 19162,
+ 19163,
+ 19164,
+ 19165,
+ 19166,
+ 19167,
+ 19168,
+ 19169,
+ 19170,
+ 19171,
+ 19172,
+ 19173,
+ 19174,
+ 19175,
+ 19176,
+ 19177,
+ 19178,
+ 19179,
+ 19180,
+ 19181,
+ 19182,
+ 19183,
+ 19184,
+ 19185,
+ 19186,
+ 19187,
+ 19188,
+ 19189,
+ 19190,
+ 19191,
+ 19192,
+ 19193,
+ 19194,
+ 19195,
+ 19196,
+ 19197,
+ 19198,
+ 19199,
+ 19200,
+ 19201,
+ 19202,
+ 19203,
+ 19204,
+ 19205,
+ 19206,
+ 19207,
+ 19208,
+ 19209,
+ 19210,
+ 19211,
+ 19212,
+ 19213,
+ 19214,
+ 19215,
+ 19216,
+ 19217,
+ 19218,
+ 19219,
+ 19220,
+ 19221,
+ 19222,
+ 19223,
+ 19224,
+ 19225,
+ 19226,
+ 19227,
+ 19228,
+ 19229,
+ 19230,
+ 19231,
+ 19232,
+ 19233,
+ 19234,
+ 19235,
+ 19236,
+ 19237,
+ 19238,
+ 19239,
+ 19240,
+ 19241,
+ 19242,
+ 19243,
+ 19244,
+ 19245,
+ 19246,
+ 19247,
+ 19248,
+ 19249,
+ 19250,
+ 19251,
+ 19252,
+ 19253,
+ 19254,
+ 19255,
+ 19256,
+ 19257,
+ 19258,
+ 19259,
+ 19260,
+ 19261,
+ 19262,
+ 19263,
+ 19264,
+ 19265,
+ 19266,
+ 19267,
+ 19268,
+ 19269,
+ 19270,
+ 19271,
+ 19272,
+ 19273,
+ 19274,
+ 19275,
+ 19276,
+ 19277,
+ 19278,
+ 19279,
+ 19280,
+ 19281,
+ 19282,
+ 19283,
+ 19284,
+ 19285,
+ 19286,
+ 19287,
+ 19288,
+ 19289,
+ 19290,
+ 19291,
+ 19292,
+ 19293,
+ 19294,
+ 19295,
+ 19296,
+ 19297,
+ 19298,
+ 19299,
+ 19300,
+ 19301,
+ 19302,
+ 19303,
+ 19304,
+ 19305,
+ 19306,
+ 19307,
+ 19308,
+ 19309,
+ 19310,
+ 19311,
+ 19312,
+ 19313,
+ 19314,
+ 19315,
+ 19316,
+ 19317,
+ 19318,
+ 19319,
+ 19320,
+ 19321,
+ 19322,
+ 19323,
+ 19324,
+ 19325,
+ 19326,
+ 19327,
+ 19328,
+ 19329,
+ 19330,
+ 19331,
+ 19332,
+ 19333,
+ 19334,
+ 19335,
+ 19336,
+ 19337,
+ 19338,
+ 19339,
+ 19340,
+ 19341,
+ 19342,
+ 19343,
+ 19344,
+ 19345,
+ 19346,
+ 19347,
+ 19348,
+ 19349,
+ 19350,
+ 19351,
+ 19352,
+ 19353,
+ 19354,
+ 19355,
+ 19356,
+ 19357,
+ 19358,
+ 19359,
+ 19360,
+ 19361,
+ 19362,
+ 19363,
+ 19364,
+ 19365,
+ 19366,
+ 19367,
+ 19368,
+ 19369,
+ 19370,
+ 19371,
+ 19372,
+ 19373,
+ 19374,
+ 19375,
+ 19376,
+ 19377,
+ 19378,
+ 19379,
+ 19380,
+ 19381,
+ 19382,
+ 19383,
+ 19384,
+ 19385,
+ 19386,
+ 19387,
+ 19388,
+ 19389,
+ 19390,
+ 19391,
+ 19392,
+ 19393,
+ 19394,
+ 19395,
+ 19396,
+ 19397,
+ 19398,
+ 19399,
+ 19400,
+ 19401,
+ 19402,
+ 19403,
+ 19404,
+ 19405,
+ 19406,
+ 19407,
+ 19408,
+ 19409,
+ 19410,
+ 19411,
+ 19412,
+ 19413,
+ 19414,
+ 19415,
+ 19416,
+ 19417,
+ 19418,
+ 19419,
+ 19420,
+ 19421,
+ 19422,
+ 19423,
+ 19424,
+ 19425,
+ 19426,
+ 19427,
+ 19428,
+ 19429,
+ 19430,
+ 19431,
+ 19432,
+ 19433,
+ 19434,
+ 19435,
+ 19436,
+ 19437,
+ 19438,
+ 19439,
+ 19440,
+ 19441,
+ 19442,
+ 19443,
+ 19444,
+ 19445,
+ 19446,
+ 19447,
+ 19448,
+ 19449,
+ 19450,
+ 19451,
+ 19452,
+ 19453,
+ 19454,
+ 19455,
+ 19456,
+ 19457,
+ 19458,
+ 19459,
+ 19460,
+ 19461,
+ 19462,
+ 19463,
+ 19464,
+ 19465,
+ 19466,
+ 19467,
+ 19468,
+ 19469,
+ 19470,
+ 19471,
+ 19472,
+ 19473,
+ 19474,
+ 19475,
+ 19476,
+ 19477,
+ 19478,
+ 19479,
+ 19480,
+ 19481,
+ 19482,
+ 19483,
+ 19484,
+ 19485,
+ 19486,
+ 19487,
+ 19488,
+ 19489,
+ 19490,
+ 19491,
+ 19492,
+ 19493,
+ 19494,
+ 19495,
+ 19496,
+ 19497,
+ 19498,
+ 19499,
+ 19500,
+ 19501,
+ 19502,
+ 19503,
+ 19504,
+ 19505,
+ 19506,
+ 19507,
+ 19508,
+ 19509,
+ 19510,
+ 19511,
+ 19512,
+ 19513,
+ 19514,
+ 19515,
+ 19516,
+ 19517,
+ 19518,
+ 19519,
+ 19520,
+ 19521,
+ 19522,
+ 19523,
+ 19524,
+ 19525,
+ 19526,
+ 19527,
+ 19528,
+ 19529,
+ 19530,
+ 19531,
+ 19532,
+ 19533,
+ 19534,
+ 19535,
+ 19536,
+ 19537,
+ 19538,
+ 19539,
+ 19540,
+ 19541,
+ 19542,
+ 19543,
+ 19544,
+ 19545,
+ 19546,
+ 19547,
+ 19548,
+ 19549,
+ 19550,
+ 19551,
+ 19552,
+ 19553,
+ 19554,
+ 19555,
+ 19556,
+ 19557,
+ 19558,
+ 19559,
+ 19560,
+ 19561,
+ 19562,
+ 19563,
+ 19564,
+ 19565,
+ 19566,
+ 19567,
+ 19568,
+ 19569,
+ 19570,
+ 19571,
+ 19572,
+ 19573,
+ 19574,
+ 19575,
+ 19576,
+ 19577,
+ 19578,
+ 19579,
+ 19580,
+ 19581,
+ 19582,
+ 19583,
+ 19584,
+ 19585,
+ 19586,
+ 19587,
+ 19588,
+ 19589,
+ 19590,
+ 19591,
+ 19592,
+ 19593,
+ 19594,
+ 19595,
+ 19596,
+ 19597,
+ 19598,
+ 19599,
+ 19600,
+ 19601,
+ 19602,
+ 19603,
+ 19604,
+ 19605,
+ 19606,
+ 19607,
+ 19608,
+ 19609,
+ 19610,
+ 19611,
+ 19612,
+ 19613,
+ 19614,
+ 19615,
+ 19616,
+ 19617,
+ 19618,
+ 19619,
+ 19620,
+ 19621,
+ 19622,
+ 19623,
+ 19624,
+ 19625,
+ 19626,
+ 19627,
+ 19628,
+ 19629,
+ 19630,
+ 19631,
+ 19632,
+ 19633,
+ 19634,
+ 19635,
+ 19636,
+ 19637,
+ 19638,
+ 19639,
+ 19640,
+ 19641,
+ 19642,
+ 19643,
+ 19644,
+ 19645,
+ 19646,
+ 19647,
+ 19648,
+ 19649,
+ 19650,
+ 19651,
+ 19652,
+ 19653,
+ 19654,
+ 19655,
+ 19656,
+ 19657,
+ 19658,
+ 19659,
+ 19660,
+ 19661,
+ 19662,
+ 19663,
+ 19664,
+ 19665,
+ 19666,
+ 19667,
+ 19668,
+ 19669,
+ 19670,
+ 19671,
+ 19672,
+ 19673,
+ 19674,
+ 19675,
+ 19676,
+ 19677,
+ 19678,
+ 19679,
+ 19680,
+ 19681,
+ 19682,
+ 19683,
+ 19684,
+ 19685,
+ 19686,
+ 19687,
+ 19688,
+ 19689,
+ 19690,
+ 19691,
+ 19692,
+ 19693,
+ 19694,
+ 19695,
+ 19696,
+ 19697,
+ 19698,
+ 19699,
+ 19700,
+ 19701,
+ 19702,
+ 19703,
+ 19704,
+ 19705,
+ 19706,
+ 19707,
+ 19708,
+ 19709,
+ 19710,
+ 19711,
+ 19712,
+ 19713,
+ 19714,
+ 19715,
+ 19716,
+ 19717,
+ 19718,
+ 19719,
+ 19720,
+ 19721,
+ 19722,
+ 19723,
+ 19724,
+ 19725,
+ 19726,
+ 19727,
+ 19728,
+ 19729,
+ 19730,
+ 19731,
+ 19732,
+ 19733,
+ 19734,
+ 19735,
+ 19736,
+ 19737,
+ 19738,
+ 19739,
+ 19740,
+ 19741,
+ 19742,
+ 19743,
+ 19744,
+ 19745,
+ 19746,
+ 19747,
+ 19748,
+ 19749,
+ 19750,
+ 19751,
+ 19752,
+ 19753,
+ 19754,
+ 19755,
+ 19756,
+ 19757,
+ 19758,
+ 19759,
+ 19760,
+ 19761,
+ 19762,
+ 19763,
+ 19764,
+ 19765,
+ 19766,
+ 19767,
+ 19768,
+ 19769,
+ 19770,
+ 19771,
+ 19772,
+ 19773,
+ 19774,
+ 19775,
+ 19776,
+ 19777,
+ 19778,
+ 19779,
+ 19780,
+ 19781,
+ 19782,
+ 19783,
+ 19784,
+ 19785,
+ 19786,
+ 19787,
+ 19788,
+ 19789,
+ 19790,
+ 19791,
+ 19792,
+ 19793,
+ 19794,
+ 19795,
+ 19796,
+ 19797,
+ 19798,
+ 19799,
+ 19800,
+ 19801,
+ 19802,
+ 19803,
+ 19804,
+ 19805,
+ 19806,
+ 19807,
+ 19808,
+ 19809,
+ 19810,
+ 19811,
+ 19812,
+ 19813,
+ 19814,
+ 19815,
+ 19816,
+ 19817,
+ 19818,
+ 19819,
+ 19820,
+ 19821,
+ 19822,
+ 19823,
+ 19824,
+ 19825,
+ 19826,
+ 19827,
+ 19828,
+ 19829,
+ 19830,
+ 19831,
+ 19832,
+ 19833,
+ 19834,
+ 19835,
+ 19836,
+ 19837,
+ 19838,
+ 19839,
+ 19840,
+ 19841,
+ 19842,
+ 19843,
+ 19844,
+ 19845,
+ 19846,
+ 19847,
+ 19848,
+ 19849,
+ 19850,
+ 19851,
+ 19852,
+ 19853,
+ 19854,
+ 19855,
+ 19856,
+ 19857,
+ 19858,
+ 19859,
+ 19860,
+ 19861,
+ 19862,
+ 19863,
+ 19864,
+ 19865,
+ 19866,
+ 19867,
+ 19868,
+ 19869,
+ 19870,
+ 19871,
+ 19872,
+ 19873,
+ 19874,
+ 19875,
+ 19876,
+ 19877,
+ 19878,
+ 19879,
+ 19880,
+ 19881,
+ 19882,
+ 19883,
+ 19884,
+ 19885,
+ 19886,
+ 19887,
+ 19888,
+ 19889,
+ 19890,
+ 19891,
+ 19892,
+ 19893,
+ 19894,
+ 19895,
+ 19896,
+ 19897,
+ 19898,
+ 19899,
+ 19900,
+ 19901,
+ 19902,
+ 19903,
+ 19904,
+ 19905,
+ 19906,
+ 19907,
+ 19908,
+ 19909,
+ 19910,
+ 19911,
+ 19912,
+ 19913,
+ 19914,
+ 19915,
+ 19916,
+ 19917,
+ 19918,
+ 19919,
+ 19920,
+ 19921,
+ 19922,
+ 19923,
+ 19924,
+ 19925,
+ 19926,
+ 19927,
+ 19928,
+ 19929,
+ 19930,
+ 19931,
+ 19932,
+ 19933,
+ 19934,
+ 19935,
+ 19936,
+ 19937,
+ 19938,
+ 19939,
+ 19940,
+ 19941,
+ 19942,
+ 19943,
+ 19944,
+ 19945,
+ 19946,
+ 19947,
+ 19948,
+ 19949,
+ 19950,
+ 19951,
+ 19952,
+ 19953,
+ 19954,
+ 19955,
+ 19956,
+ 19957,
+ 19958,
+ 19959,
+ 19960,
+ 19961,
+ 19962,
+ 19963,
+ 19964,
+ 19965,
+ 19966,
+ 19967,
+ 19968,
+ 19969,
+ 19970,
+ 19971,
+ 19972,
+ 19973,
+ 19974,
+ 19975,
+ 19976,
+ 19977,
+ 19978,
+ 19979,
+ 19980,
+ 19981,
+ 19982,
+ 19983,
+ 19984,
+ 19985,
+ 19986,
+ 19987,
+ 19988,
+ 19989,
+ 19990,
+ 19991,
+ 19992,
+ 19993,
+ 19994,
+ 19995,
+ 19996,
+ 19997,
+ 19998,
+ 19999,
+ 20000,
+ 20001,
+ 20002,
+ 20003,
+ 20004,
+ 20005,
+ 20006,
+ 20007,
+ 20008,
+ 20009,
+ 20010,
+ 20011,
+ 20012,
+ 20013,
+ 20014,
+ 20015,
+ 20016,
+ 20017,
+ 20018,
+ 20019,
+ 20020,
+ 20021,
+ 20022,
+ 20023,
+ 20024,
+ 20025,
+ 20026,
+ 20027,
+ 20028,
+ 20029,
+ 20030,
+ 20031,
+ 20032,
+ 20033,
+ 20034,
+ 20035,
+ 20036,
+ 20037,
+ 20038,
+ 20039,
+ 20040,
+ 20041,
+ 20042,
+ 20043,
+ 20044,
+ 20045,
+ 20046,
+ 20047,
+ 20048,
+ 20049,
+ 20050,
+ 20051,
+ 20052,
+ 20053,
+ 20054,
+ 20055,
+ 20056,
+ 20057,
+ 20058,
+ 20059,
+ 20060,
+ 20061,
+ 20062,
+ 20063,
+ 20064,
+ 20065,
+ 20066,
+ 20067,
+ 20068,
+ 20069,
+ 20070,
+ 20071,
+ 20072,
+ 20073,
+ 20074,
+ 20075,
+ 20076,
+ 20077,
+ 20078,
+ 20079,
+ 20080,
+ 20081,
+ 20082,
+ 20083,
+ 20084,
+ 20085,
+ 20086,
+ 20087,
+ 20088,
+ 20089,
+ 20090,
+ 20091,
+ 20092,
+ 20093,
+ 20094,
+ 20095,
+ 20096,
+ 20097,
+ 20098,
+ 20099,
+ 20100,
+ 20101,
+ 20102,
+ 20103,
+ 20104,
+ 20105,
+ 20106,
+ 20107,
+ 20108,
+ 20109,
+ 20110,
+ 20111,
+ 20112,
+ 20113,
+ 20114,
+ 20115,
+ 20116,
+ 20117,
+ 20118,
+ 20119,
+ 20120,
+ 20121,
+ 20122,
+ 20123,
+ 20124,
+ 20125,
+ 20126,
+ 20127,
+ 20128,
+ 20129,
+ 20130,
+ 20131,
+ 20132,
+ 20133,
+ 20134,
+ 20135,
+ 20136,
+ 20137,
+ 20138,
+ 20139,
+ 20140,
+ 20141,
+ 20142,
+ 20143,
+ 20144,
+ 20145,
+ 20146,
+ 20147,
+ 20148,
+ 20149,
+ 20150,
+ 20151,
+ 20152,
+ 20153,
+ 20154,
+ 20155,
+ 20156,
+ 20157,
+ 20158,
+ 20159,
+ 20160,
+ 20161,
+ 20162,
+ 20163,
+ 20164,
+ 20165,
+ 20166,
+ 20167,
+ 20168,
+ 20169,
+ 20170,
+ 20171,
+ 20172,
+ 20173,
+ 20174,
+ 20175,
+ 20176,
+ 20177,
+ 20178,
+ 20179,
+ 20180,
+ 20181,
+ 20182,
+ 20183,
+ 20184,
+ 20185,
+ 20186,
+ 20187,
+ 20188,
+ 20189,
+ 20190,
+ 20191,
+ 20192,
+ 20193,
+ 20194,
+ 20195,
+ 20196,
+ 20197,
+ 20198,
+ 20199,
+ 20200,
+ 20201,
+ 20202,
+ 20203,
+ 20204,
+ 20205,
+ 20206,
+ 20207,
+ 20208,
+ 20209,
+ 20210,
+ 20211,
+ 20212,
+ 20213,
+ 20214,
+ 20215,
+ 20216,
+ 20217,
+ 20218,
+ 20219,
+ 20220,
+ 20221,
+ 20222,
+ 20223,
+ 20224,
+ 20225,
+ 20226,
+ 20227,
+ 20228,
+ 20229,
+ 20230,
+ 20231,
+ 20232,
+ 20233,
+ 20234,
+ 20235,
+ 20236,
+ 20237,
+ 20238,
+ 20239,
+ 20240,
+ 20241,
+ 20242,
+ 20243,
+ 20244,
+ 20245,
+ 20246,
+ 20247,
+ 20248,
+ 20249,
+ 20250,
+ 20251,
+ 20252,
+ 20253,
+ 20254,
+ 20255,
+ 20256,
+ 20257,
+ 20258,
+ 20259,
+ 20260,
+ 20261,
+ 20262,
+ 20263,
+ 20264,
+ 20265,
+ 20266,
+ 20267,
+ 20268,
+ 20269,
+ 20270,
+ 20271,
+ 20272,
+ 20273,
+ 20274,
+ 20275,
+ 20276,
+ 20277,
+ 20278,
+ 20279,
+ 20280,
+ 20281,
+ 20282,
+ 20283,
+ 20284,
+ 20285,
+ 20286,
+ 20287,
+ 20288,
+ 20289,
+ 20290,
+ 20291,
+ 20292,
+ 20293,
+ 20294,
+ 20295,
+ 20296,
+ 20297,
+ 20298,
+ 20299,
+ 20300,
+ 20301,
+ 20302,
+ 20303,
+ 20304,
+ 20305,
+ 20306,
+ 20307,
+ 20308,
+ 20309,
+ 20310,
+ 20311,
+ 20312,
+ 20313,
+ 20314,
+ 20315,
+ 20316,
+ 20317,
+ 20318,
+ 20319,
+ 20320,
+ 20321,
+ 20322,
+ 20323,
+ 20324,
+ 20325,
+ 20326,
+ 20327,
+ 20328,
+ 20329,
+ 20330,
+ 20331,
+ 20332,
+ 20333,
+ 20334,
+ 20335,
+ 20336,
+ 20337,
+ 20338,
+ 20339,
+ 20340,
+ 20341,
+ 20342,
+ 20343,
+ 20344,
+ 20345,
+ 20346,
+ 20347,
+ 20348,
+ 20349,
+ 20350,
+ 20351,
+ 20352,
+ 20353,
+ 20354,
+ 20355,
+ 20356,
+ 20357,
+ 20358,
+ 20359,
+ 20360,
+ 20361,
+ 20362,
+ 20363,
+ 20364,
+ 20365,
+ 20366,
+ 20367,
+ 20368,
+ 20369,
+ 20370,
+ 20371,
+ 20372,
+ 20373,
+ 20374,
+ 20375,
+ 20376,
+ 20377,
+ 20378,
+ 20379,
+ 20380,
+ 20381,
+ 20382,
+ 20383,
+ 20384,
+ 20385,
+ 20386,
+ 20387,
+ 20388,
+ 20389,
+ 20390,
+ 20391,
+ 20392,
+ 20393,
+ 20394,
+ 20395,
+ 20396,
+ 20397,
+ 20398,
+ 20399,
+ 20400,
+ 20401,
+ 20402,
+ 20403,
+ 20404,
+ 20405,
+ 20406,
+ 20407,
+ 20408,
+ 20409,
+ 20410,
+ 20411,
+ 20412,
+ 20413,
+ 20414,
+ 20415,
+ 20416,
+ 20417,
+ 20418,
+ 20419,
+ 20420,
+ 20421,
+ 20422,
+ 20423,
+ 20424,
+ 20425,
+ 20426,
+ 20427,
+ 20428,
+ 20429,
+ 20430,
+ 20431,
+ 20432,
+ 20433,
+ 20434,
+ 20435,
+ 20436,
+ 20437,
+ 20438,
+ 20439,
+ 20440,
+ 20441,
+ 20442,
+ 20443,
+ 20444,
+ 20445,
+ 20446,
+ 20447,
+ 20448,
+ 20449,
+ 20450,
+ 20451,
+ 20452,
+ 20453,
+ 20454,
+ 20455,
+ 20456,
+ 20457,
+ 20458,
+ 20459,
+ 20460,
+ 20461,
+ 20462,
+ 20463,
+ 20464,
+ 20465,
+ 20466,
+ 20467,
+ 20468,
+ 20469,
+ 20470,
+ 20471,
+ 20472,
+ 20473,
+ 20474,
+ 20475,
+ 20476,
+ 20477,
+ 20478,
+ 20479,
+ 20480,
+ 20481,
+ 20482,
+ 20483,
+ 20484,
+ 20485,
+ 20486,
+ 20487,
+ 20488,
+ 20489,
+ 20490,
+ 20491,
+ 20492,
+ 20493,
+ 20494,
+ 20495,
+ 20496,
+ 20497,
+ 20498,
+ 20499,
+ 20500,
+ 20501,
+ 20502,
+ 20503,
+ 20504,
+ 20505,
+ 20506,
+ 20507,
+ 20508,
+ 20509,
+ 20510,
+ 20511,
+ 20512,
+ 20513,
+ 20514,
+ 20515,
+ 20516,
+ 20517,
+ 20518,
+ 20519,
+ 20520,
+ 20521,
+ 20522,
+ 20523,
+ 20524,
+ 20525,
+ 20526,
+ 20527,
+ 20528,
+ 20529,
+ 20530,
+ 20531,
+ 20532,
+ 20533,
+ 20534,
+ 20535,
+ 20536,
+ 20537,
+ 20538,
+ 20539,
+ 20540,
+ 20541,
+ 20542,
+ 20543,
+ 20544,
+ 20545,
+ 20546,
+ 20547,
+ 20548,
+ 20549,
+ 20550,
+ 20551,
+ 20552,
+ 20553,
+ 20554,
+ 20555,
+ 20556,
+ 20557,
+ 20558,
+ 20559,
+ 20560,
+ 20561,
+ 20562,
+ 20563,
+ 20564,
+ 20565,
+ 20566,
+ 20567,
+ 20568,
+ 20569,
+ 20570,
+ 20571,
+ 20572,
+ 20573,
+ 20574,
+ 20575,
+ 20576,
+ 20577,
+ 20578,
+ 20579,
+ 20580,
+ 20581,
+ 20582,
+ 20583,
+ 20584,
+ 20585,
+ 20586,
+ 20587,
+ 20588,
+ 20589,
+ 20590,
+ 20591,
+ 20592,
+ 20593,
+ 20594,
+ 20595,
+ 20596,
+ 20597,
+ 20598,
+ 20599,
+ 20600,
+ 20601,
+ 20602,
+ 20603,
+ 20604,
+ 20605,
+ 20606,
+ 20607,
+ 20608,
+ 20609,
+ 20610,
+ 20611,
+ 20612,
+ 20613,
+ 20614,
+ 20615,
+ 20616,
+ 20617,
+ 20618,
+ 20619,
+ 20620,
+ 20621,
+ 20622,
+ 20623,
+ 20624,
+ 20625,
+ 20626,
+ 20627,
+ 20628,
+ 20629,
+ 20630,
+ 20631,
+ 20632,
+ 20633,
+ 20634,
+ 20635,
+ 20636,
+ 20637,
+ 20638,
+ 20639,
+ 20640,
+ 20641,
+ 20642,
+ 20643,
+ 20644,
+ 20645,
+ 20646,
+ 20647,
+ 20648,
+ 20649,
+ 20650,
+ 20651,
+ 20652,
+ 20653,
+ 20654,
+ 20655,
+ 20656,
+ 20657,
+ 20658,
+ 20659,
+ 20660,
+ 20661,
+ 20662,
+ 20663,
+ 20664,
+ 20665,
+ 20666,
+ 20667,
+ 20668,
+ 20669,
+ 20670,
+ 20671,
+ 20672,
+ 20673,
+ 20674,
+ 20675,
+ 20676,
+ 20677,
+ 20678,
+ 20679,
+ 20680,
+ 20681,
+ 20682,
+ 20683,
+ 20684,
+ 20685,
+ 20686,
+ 20687,
+ 20688,
+ 20689,
+ 20690,
+ 20691,
+ 20692,
+ 20693,
+ 20694,
+ 20695,
+ 20696,
+ 20697,
+ 20698,
+ 20699,
+ 20700,
+ 20701,
+ 20702,
+ 20703,
+ 20704,
+ 20705,
+ 20706,
+ 20707,
+ 20708,
+ 20709,
+ 20710,
+ 20711,
+ 20712,
+ 20713,
+ 20714,
+ 20715,
+ 20716,
+ 20717,
+ 20718,
+ 20719,
+ 20720,
+ 20721,
+ 20722,
+ 20723,
+ 20724,
+ 20725,
+ 20726,
+ 20727,
+ 20728,
+ 20729,
+ 20730,
+ 20731,
+ 20732,
+ 20733,
+ 20734,
+ 20735,
+ 20736,
+ 20737,
+ 20738,
+ 20739,
+ 20740,
+ 20741,
+ 20742,
+ 20743,
+ 20744,
+ 20745,
+ 20746,
+ 20747,
+ 20748,
+ 20749,
+ 20750,
+ 20751,
+ 20752,
+ 20753,
+ 20754,
+ 20755,
+ 20756,
+ 20757,
+ 20758,
+ 20759,
+ 20760,
+ 20761,
+ 20762,
+ 20763,
+ 20764,
+ 20765,
+ 20766,
+ 20767,
+ 20768,
+ 20769,
+ 20770,
+ 20771,
+ 20772,
+ 20773,
+ 20774,
+ 20775,
+ 20776,
+ 20777,
+ 20778,
+ 20779,
+ 20780,
+ 20781,
+ 20782,
+ 20783,
+ 20784,
+ 20785,
+ 20786,
+ 20787,
+ 20788,
+ 20789,
+ 20790,
+ 20791,
+ 20792,
+ 20793,
+ 20794,
+ 20795,
+ 20796,
+ 20797,
+ 20798,
+ 20799,
+ 20800,
+ 20801,
+ 20802,
+ 20803,
+ 20804,
+ 20805,
+ 20806,
+ 20807,
+ 20808,
+ 20809,
+ 20810,
+ 20811,
+ 20812,
+ 20813,
+ 20814,
+ 20815,
+ 20816,
+ 20817,
+ 20818,
+ 20819,
+ 20820,
+ 20821,
+ 20822,
+ 20823,
+ 20824,
+ 20825,
+ 20826,
+ 20827,
+ 20828,
+ 20829,
+ 20830,
+ 20831,
+ 20832,
+ 20833,
+ 20834,
+ 20835,
+ 20836,
+ 20837,
+ 20838,
+ 20839,
+ 20840,
+ 20841,
+ 20842,
+ 20843,
+ 20844,
+ 20845,
+ 20846,
+ 20847,
+ 20848,
+ 20849,
+ 20850,
+ 20851,
+ 20852,
+ 20853,
+ 20854,
+ 20855,
+ 20856,
+ 20857,
+ 20858,
+ 20859,
+ 20860,
+ 20861,
+ 20862,
+ 20863,
+ 20864,
+ 20865,
+ 20866,
+ 20867,
+ 20868,
+ 20869,
+ 20870,
+ 20871,
+ 20872,
+ 20873,
+ 20874,
+ 20875,
+ 20876,
+ 20877,
+ 20878,
+ 20879,
+ 20880,
+ 20881,
+ 20882,
+ 20883,
+ 20884,
+ 20885,
+ 20886,
+ 20887,
+ 20888,
+ 20889,
+ 20890,
+ 20891,
+ 20892,
+ 20893,
+ 20894,
+ 20895,
+ 20896,
+ 20897,
+ 20898,
+ 20899,
+ 20900,
+ 20901,
+ 20902,
+ 20903,
+ 20904,
+ 20905,
+ 20906,
+ 20907,
+ 20908,
+ 20909,
+ 20910,
+ 20911,
+ 20912,
+ 20913,
+ 20914,
+ 20915,
+ 20916,
+ 20917,
+ 20918,
+ 20919,
+ 20920,
+ 20921,
+ 20922,
+ 20923,
+ 20924,
+ 20925,
+ 20926,
+ 20927,
+ 20928,
+ 20929,
+ 20930,
+ 20931,
+ 20932,
+ 20933,
+ 20934,
+ 20935,
+ 20936,
+ 20937,
+ 20938,
+ 20939,
+ 20940,
+ 20941,
+ 20942,
+ 20943,
+ 20944,
+ 20945,
+ 20946,
+ 20947,
+ 20948,
+ 20949,
+ 20950,
+ 20951,
+ 20952,
+ 20953,
+ 20954,
+ 20955,
+ 20956,
+ 20957,
+ 20958,
+ 20959,
+ 20960,
+ 20961,
+ 20962,
+ 20963,
+ 20964,
+ 20965,
+ 20966,
+ 20967,
+ 20968,
+ 20969,
+ 20970,
+ 20971,
+ 20972,
+ 20973,
+ 20974,
+ 20975,
+ 20976,
+ 20977,
+ 20978,
+ 20979,
+ 20980,
+ 20981,
+ 20982,
+ 20983,
+ 20984,
+ 20985,
+ 20986,
+ 20987,
+ 20988,
+ 20989,
+ 20990,
+ 20991,
+ 20992,
+ 20993,
+ 20994,
+ 20995,
+ 20996,
+ 20997,
+ 20998,
+ 20999,
+ 21000,
+ 21001,
+ 21002,
+ 21003,
+ 21004,
+ 21005,
+ 21006,
+ 21007,
+ 21008,
+ 21009,
+ 21010,
+ 21011,
+ 21012,
+ 21013,
+ 21014,
+ 21015,
+ 21016,
+ 21017,
+ 21018,
+ 21019,
+ 21020,
+ 21021,
+ 21022,
+ 21023,
+ 21024,
+ 21025,
+ 21026,
+ 21027,
+ 21028,
+ 21029,
+ 21030,
+ 21031,
+ 21032,
+ 21033,
+ 21034,
+ 21035,
+ 21036,
+ 21037,
+ 21038,
+ 21039,
+ 21040,
+ 21041,
+ 21042,
+ 21043,
+ 21044,
+ 21045,
+ 21046,
+ 21047,
+ 21048,
+ 21049,
+ 21050,
+ 21051,
+ 21052,
+ 21053,
+ 21054,
+ 21055,
+ 21056,
+ 21057,
+ 21058,
+ 21059,
+ 21060,
+ 21061,
+ 21062,
+ 21063,
+ 21064,
+ 21065,
+ 21066,
+ 21067,
+ 21068,
+ 21069,
+ 21070,
+ 21071,
+ 21072,
+ 21073,
+ 21074,
+ 21075,
+ 21076,
+ 21077,
+ 21078,
+ 21079,
+ 21080,
+ 21081,
+ 21082,
+ 21083,
+ 21084,
+ 21085,
+ 21086,
+ 21087,
+ 21088,
+ 21089,
+ 21090,
+ 21091,
+ 21092,
+ 21093,
+ 21094,
+ 21095,
+ 21096,
+ 21097,
+ 21098,
+ 21099,
+ 21100,
+ 21101,
+ 21102,
+ 21103,
+ 21104,
+ 21105,
+ 21106,
+ 21107,
+ 21108,
+ 21109,
+ 21110,
+ 21111,
+ 21112,
+ 21113,
+ 21114,
+ 21115,
+ 21116,
+ 21117,
+ 21118,
+ 21119,
+ 21120,
+ 21121,
+ 21122,
+ 21123,
+ 21124,
+ 21125,
+ 21126,
+ 21127,
+ 21128,
+ 21129,
+ 21130,
+ 21131,
+ 21132,
+ 21133,
+ 21134,
+ 21135,
+ 21136,
+ 21137,
+ 21138,
+ 21139,
+ 21140,
+ 21141,
+ 21142,
+ 21143,
+ 21144,
+ 21145,
+ 21146,
+ 21147,
+ 21148,
+ 21149,
+ 21150,
+ 21151,
+ 21152,
+ 21153,
+ 21154,
+ 21155,
+ 21156,
+ 21157,
+ 21158,
+ 21159,
+ 21160,
+ 21161,
+ 21162,
+ 21163,
+ 21164,
+ 21165,
+ 21166,
+ 21167,
+ 21168,
+ 21169,
+ 21170,
+ 21171,
+ 21172,
+ 21173,
+ 21174,
+ 21175,
+ 21176,
+ 21177,
+ 21178,
+ 21179,
+ 21180,
+ 21181,
+ 21182,
+ 21183,
+ 21184,
+ 21185,
+ 21186,
+ 21187,
+ 21188,
+ 21189,
+ 21190,
+ 21191,
+ 21192,
+ 21193,
+ 21194,
+ 21195,
+ 21196,
+ 21197,
+ 21198,
+ 21199,
+ 21200,
+ 21201,
+ 21202,
+ 21203,
+ 21204,
+ 21205,
+ 21206,
+ 21207,
+ 21208,
+ 21209,
+ 21210,
+ 21211,
+ 21212,
+ 21213,
+ 21214,
+ 21215,
+ 21216,
+ 21217,
+ 21218,
+ 21219,
+ 21220,
+ 21221,
+ 21222,
+ 21223,
+ 21224,
+ 21225,
+ 21226,
+ 21227,
+ 21228,
+ 21229,
+ 21230,
+ 21231,
+ 21232,
+ 21233,
+ 21234,
+ 21235,
+ 21236,
+ 21237,
+ 21238,
+ 21239,
+ 21240,
+ 21241,
+ 21242,
+ 21243,
+ 21244,
+ 21245,
+ 21246,
+ 21247,
+ 21248,
+ 21249,
+ 21250,
+ 21251,
+ 21252,
+ 21253,
+ 21254,
+ 21255,
+ 21256,
+ 21257,
+ 21258,
+ 21259,
+ 21260,
+ 21261,
+ 21262,
+ 21263,
+ 21264,
+ 21265,
+ 21266,
+ 21267,
+ 21268,
+ 21269,
+ 21270,
+ 21271,
+ 21272,
+ 21273,
+ 21274,
+ 21275,
+ 21276,
+ 21277,
+ 21278,
+ 21279,
+ 21280,
+ 21281,
+ 21282,
+ 21283,
+ 21284,
+ 21285,
+ 21286,
+ 21287,
+ 21288,
+ 21289,
+ 21290,
+ 21291,
+ 21292,
+ 21293,
+ 21294,
+ 21295,
+ 21296,
+ 21297,
+ 21298,
+ 21299,
+ 21300,
+ 21301,
+ 21302,
+ 21303,
+ 21304,
+ 21305,
+ 21306,
+ 21307,
+ 21308,
+ 21309,
+ 21310,
+ 21311,
+ 21312,
+ 21313,
+ 21314,
+ 21315,
+ 21316,
+ 21317,
+ 21318,
+ 21319,
+ 21320,
+ 21321,
+ 21322,
+ 21323,
+ 21324,
+ 21325,
+ 21326,
+ 21327,
+ 21328,
+ 21329,
+ 21330,
+ 21331,
+ 21332,
+ 21333,
+ 21334,
+ 21335,
+ 21336,
+ 21337,
+ 21338,
+ 21339,
+ 21340,
+ 21341,
+ 21342,
+ 21343,
+ 21344,
+ 21345,
+ 21346,
+ 21347,
+ 21348,
+ 21349,
+ 21350,
+ 21351,
+ 21352,
+ 21353,
+ 21354,
+ 21355,
+ 21356,
+ 21357,
+ 21358,
+ 21359,
+ 21360,
+ 21361,
+ 21362,
+ 21363,
+ 21364,
+ 21365,
+ 21366,
+ 21367,
+ 21368,
+ 21369,
+ 21370,
+ 21371,
+ 21372,
+ 21373,
+ 21374,
+ 21375,
+ 21376,
+ 21377,
+ 21378,
+ 21379,
+ 21380,
+ 21381,
+ 21382,
+ 21383,
+ 21384,
+ 21385,
+ 21386,
+ 21387,
+ 21388,
+ 21389,
+ 21390,
+ 21391,
+ 21392,
+ 21393,
+ 21394,
+ 21395,
+ 21396,
+ 21397,
+ 21398,
+ 21399,
+ 21400,
+ 21401,
+ 21402,
+ 21403,
+ 21404,
+ 21405,
+ 21406,
+ 21407,
+ 21408,
+ 21409,
+ 21410,
+ 21411,
+ 21412,
+ 21413,
+ 21414,
+ 21415,
+ 21416,
+ 21417,
+ 21418,
+ 21419,
+ 21420,
+ 21421,
+ 21422,
+ 21423,
+ 21424,
+ 21425,
+ 21426,
+ 21427,
+ 21428,
+ 21429,
+ 21430,
+ 21431,
+ 21432,
+ 21433,
+ 21434,
+ 21435,
+ 21436,
+ 21437,
+ 21438,
+ 21439,
+ 21440,
+ 21441,
+ 21442,
+ 21443,
+ 21444,
+ 21445,
+ 21446,
+ 21447,
+ 21448,
+ 21449,
+ 21450,
+ 21451,
+ 21452,
+ 21453,
+ 21454,
+ 21455,
+ 21456,
+ 21457,
+ 21458,
+ 21459,
+ 21460,
+ 21461,
+ 21462,
+ 21463,
+ 21464,
+ 21465,
+ 21466,
+ 21467,
+ 21468,
+ 21469,
+ 21470,
+ 21471,
+ 21472,
+ 21473,
+ 21474,
+ 21475,
+ 21476,
+ 21477,
+ 21478,
+ 21479,
+ 21480,
+ 21481,
+ 21482,
+ 21483,
+ 21484,
+ 21485,
+ 21486,
+ 21487,
+ 21488,
+ 21489,
+ 21490,
+ 21491,
+ 21492,
+ 21493,
+ 21494,
+ 21495,
+ 21496,
+ 21497,
+ 21498,
+ 21499,
+ 21500,
+ 21501,
+ 21502,
+ 21503,
+ 21504,
+ 21505,
+ 21506,
+ 21507,
+ 21508,
+ 21509,
+ 21510,
+ 21511,
+ 21512,
+ 21513,
+ 21514,
+ 21515,
+ 21516,
+ 21517,
+ 21518,
+ 21519,
+ 21520,
+ 21521,
+ 21522,
+ 21523,
+ 21524,
+ 21525,
+ 21526,
+ 21527,
+ 21528,
+ 21529,
+ 21530,
+ 21531,
+ 21532,
+ 21533,
+ 21534,
+ 21535,
+ 21536,
+ 21537,
+ 21538,
+ 21539,
+ 21540,
+ 21541,
+ 21542,
+ 21543,
+ 21544,
+ 21545,
+ 21546,
+ 21547,
+ 21548,
+ 21549,
+ 21550,
+ 21551,
+ 21552,
+ 21553,
+ 21554,
+ 21555,
+ 21556,
+ 21557,
+ 21558,
+ 21559,
+ 21560,
+ 21561,
+ 21562,
+ 21563,
+ 21564,
+ 21565,
+ 21566,
+ 21567,
+ 21568,
+ 21569,
+ 21570,
+ 21571,
+ 21572,
+ 21573,
+ 21574,
+ 21575,
+ 21576,
+ 21577,
+ 21578,
+ 21579,
+ 21580,
+ 21581,
+ 21582,
+ 21583,
+ 21584,
+ 21585,
+ 21586,
+ 21587,
+ 21588,
+ 21589,
+ 21590,
+ 21591,
+ 21592,
+ 21593,
+ 21594,
+ 21595,
+ 21596,
+ 21597,
+ 21598,
+ 21599,
+ 21600,
+ 21601,
+ 21602,
+ 21603,
+ 21604,
+ 21605,
+ 21606,
+ 21607,
+ 21608,
+ 21609,
+ 21610,
+ 21611,
+ 21612,
+ 21613,
+ 21614,
+ 21615,
+ 21616,
+ 21617,
+ 21618,
+ 21619,
+ 21620,
+ 21621,
+ 21622,
+ 21623,
+ 21624,
+ 21625,
+ 21626,
+ 21627,
+ 21628,
+ 21629,
+ 21630,
+ 21631,
+ 21632,
+ 21633,
+ 21634,
+ 21635,
+ 21636,
+ 21637,
+ 21638,
+ 21639,
+ 21640,
+ 21641,
+ 21642,
+ 21643,
+ 21644,
+ 21645,
+ 21646,
+ 21647,
+ 21648,
+ 21649,
+ 21650,
+ 21651,
+ 21652,
+ 21653,
+ 21654,
+ 21655,
+ 21656,
+ 21657,
+ 21658,
+ 21659,
+ 21660,
+ 21661,
+ 21662,
+ 21663,
+ 21664,
+ 21665,
+ 21666,
+ 21667,
+ 21668,
+ 21669,
+ 21670,
+ 21671,
+ 21672,
+ 21673,
+ 21674,
+ 21675,
+ 21676,
+ 21677,
+ 21678,
+ 21679,
+ 21680,
+ 21681,
+ 21682,
+ 21683,
+ 21684,
+ 21685,
+ 21686,
+ 21687,
+ 21688,
+ 21689,
+ 21690,
+ 21691,
+ 21692,
+ 21693,
+ 21694,
+ 21695,
+ 21696,
+ 21697,
+ 21698,
+ 21699,
+ 21700,
+ 21701,
+ 21702,
+ 21703,
+ 21704,
+ 21705,
+ 21706,
+ 21707,
+ 21708,
+ 21709,
+ 21710,
+ 21711,
+ 21712,
+ 21713,
+ 21714,
+ 21715,
+ 21716,
+ 21717,
+ 21718,
+ 21719,
+ 21720,
+ 21721,
+ 21722,
+ 21723,
+ 21724,
+ 21725,
+ 21726,
+ 21727,
+ 21728,
+ 21729,
+ 21730,
+ 21731,
+ 21732,
+ 21733,
+ 21734,
+ 21735,
+ 21736,
+ 21737,
+ 21738,
+ 21739,
+ 21740,
+ 21741,
+ 21742,
+ 21743,
+ 21744,
+ 21745,
+ 21746,
+ 21747,
+ 21748,
+ 21749,
+ 21750,
+ 21751,
+ 21752,
+ 21753,
+ 21754,
+ 21755,
+ 21756,
+ 21757,
+ 21758,
+ 21759,
+ 21760,
+ 21761,
+ 21762,
+ 21763,
+ 21764,
+ 21765,
+ 21766,
+ 21767,
+ 21768,
+ 21769,
+ 21770,
+ 21771,
+ 21772,
+ 21773,
+ 21774,
+ 21775,
+ 21776,
+ 21777,
+ 21778,
+ 21779,
+ 21780,
+ 21781,
+ 21782,
+ 21783,
+ 21784,
+ 21785,
+ 21786,
+ 21787,
+ 21788,
+ 21789,
+ 21790,
+ 21791,
+ 21792,
+ 21793,
+ 21794,
+ 21795,
+ 21796,
+ 21797,
+ 21798,
+ 21799,
+ 21800,
+ 21801,
+ 21802,
+ 21803,
+ 21804,
+ 21805,
+ 21806,
+ 21807,
+ 21808,
+ 21809,
+ 21810,
+ 21811,
+ 21812,
+ 21813,
+ 21814,
+ 21815,
+ 21816,
+ 21817,
+ 21818,
+ 21819,
+ 21820,
+ 21821,
+ 21822,
+ 21823,
+ 21824,
+ 21825,
+ 21826,
+ 21827,
+ 21828,
+ 21829,
+ 21830,
+ 21831,
+ 21832,
+ 21833,
+ 21834,
+ 21835,
+ 21836,
+ 21837,
+ 21838,
+ 21839,
+ 21840,
+ 21841,
+ 21842,
+ 21843,
+ 21844,
+ 21845,
+ 21846,
+ 21847,
+ 21848,
+ 21849,
+ 21850,
+ 21851,
+ 21852,
+ 21853,
+ 21854,
+ 21855,
+ 21856,
+ 21857,
+ 21858,
+ 21859,
+ 21860,
+ 21861,
+ 21862,
+ 21863,
+ 21864,
+ 21865,
+ 21866,
+ 21867,
+ 21868,
+ 21869,
+ 21870,
+ 21871,
+ 21872,
+ 21873,
+ 21874,
+ 21875,
+ 21876,
+ 21877,
+ 21878,
+ 21879,
+ 21880,
+ 21881,
+ 21882,
+ 21883,
+ 21884,
+ 21885,
+ 21886,
+ 21887,
+ 21888,
+ 21889,
+ 21890,
+ 21891,
+ 21892,
+ 21893,
+ 21894,
+ 21895,
+ 21896,
+ 21897,
+ 21898,
+ 21899,
+ 21900,
+ 21901,
+ 21902,
+ 21903,
+ 21904,
+ 21905,
+ 21906,
+ 21907,
+ 21908,
+ 21909,
+ 21910,
+ 21911,
+ 21912,
+ 21913,
+ 21914,
+ 21915,
+ 21916,
+ 21917,
+ 21918,
+ 21919,
+ 21920,
+ 21921,
+ 21922,
+ 21923,
+ 21924,
+ 21925,
+ 21926,
+ 21927,
+ 21928,
+ 21929,
+ 21930,
+ 21931,
+ 21932,
+ 21933,
+ 21934,
+ 21935,
+ 21936,
+ 21937,
+ 21938,
+ 21939,
+ 21940,
+ 21941,
+ 21942,
+ 21943,
+ 21944,
+ 21945,
+ 21946,
+ 21947,
+ 21948,
+ 21949,
+ 21950,
+ 21951,
+ 21952,
+ 21953,
+ 21954,
+ 21955,
+ 21956,
+ 21957,
+ 21958,
+ 21959,
+ 21960,
+ 21961,
+ 21962,
+ 21963,
+ 21964,
+ 21965,
+ 21966,
+ 21967,
+ 21968,
+ 21969,
+ 21970,
+ 21971,
+ 21972,
+ 21973,
+ 21974,
+ 21975,
+ 21976,
+ 21977,
+ 21978,
+ 21979,
+ 21980,
+ 21981,
+ 21982,
+ 21983,
+ 21984,
+ 21985,
+ 21986,
+ 21987,
+ 21988,
+ 21989,
+ 21990,
+ 21991,
+ 21992,
+ 21993,
+ 21994,
+ 21995,
+ 21996,
+ 21997,
+ 21998,
+ 21999,
+ 22000,
+ 22001,
+ 22002,
+ 22003,
+ 22004,
+ 22005,
+ 22006,
+ 22007,
+ 22008,
+ 22009,
+ 22010,
+ 22011,
+ 22012,
+ 22013,
+ 22014,
+ 22015,
+ 22016,
+ 22017,
+ 22018,
+ 22019,
+ 22020,
+ 22021,
+ 22022,
+ 22023,
+ 22024,
+ 22025,
+ 22026,
+ 22027,
+ 22028,
+ 22029,
+ 22030,
+ 22031,
+ 22032,
+ 22033,
+ 22034,
+ 22035,
+ 22036,
+ 22037,
+ 22038,
+ 22039,
+ 22040,
+ 22041,
+ 22042,
+ 22043,
+ 22044,
+ 22045,
+ 22046,
+ 22047,
+ 22048,
+ 22049,
+ 22050,
+ 22051,
+ 22052,
+ 22053,
+ 22054,
+ 22055,
+ 22056,
+ 22057,
+ 22058,
+ 22059,
+ 22060,
+ 22061,
+ 22062,
+ 22063,
+ 22064,
+ 22065,
+ 22066,
+ 22067,
+ 22068,
+ 22069,
+ 22070,
+ 22071,
+ 22072,
+ 22073,
+ 22074,
+ 22075,
+ 22076,
+ 22077,
+ 22078,
+ 22079,
+ 22080,
+ 22081,
+ 22082,
+ 22083,
+ 22084,
+ 22085,
+ 22086,
+ 22087,
+ 22088,
+ 22089,
+ 22090,
+ 22091,
+ 22092,
+ 22093,
+ 22094,
+ 22095,
+ 22096,
+ 22097,
+ 22098,
+ 22099,
+ 22100,
+ 22101,
+ 22102,
+ 22103,
+ 22104,
+ 22105,
+ 22106,
+ 22107,
+ 22108,
+ 22109,
+ 22110,
+ 22111,
+ 22112,
+ 22113,
+ 22114,
+ 22115,
+ 22116,
+ 22117,
+ 22118,
+ 22119,
+ 22120,
+ 22121,
+ 22122,
+ 22123,
+ 22124,
+ 22125,
+ 22126,
+ 22127,
+ 22128,
+ 22129,
+ 22130,
+ 22131,
+ 22132,
+ 22133,
+ 22134,
+ 22135,
+ 22136,
+ 22137,
+ 22138,
+ 22139,
+ 22140,
+ 22141,
+ 22142,
+ 22143,
+ 22144,
+ 22145,
+ 22146,
+ 22147,
+ 22148,
+ 22149,
+ 22150,
+ 22151,
+ 22152,
+ 22153,
+ 22154,
+ 22155,
+ 22156,
+ 22157,
+ 22158,
+ 22159,
+ 22160,
+ 22161,
+ 22162,
+ 22163,
+ 22164,
+ 22165,
+ 22166,
+ 22167,
+ 22168,
+ 22169,
+ 22170,
+ 22171,
+ 22172,
+ 22173,
+ 22174,
+ 22175,
+ 22176,
+ 22177,
+ 22178,
+ 22179,
+ 22180,
+ 22181,
+ 22182,
+ 22183,
+ 22184,
+ 22185,
+ 22186,
+ 22187,
+ 22188,
+ 22189,
+ 22190,
+ 22191,
+ 22192,
+ 22193,
+ 22194,
+ 22195,
+ 22196,
+ 22197,
+ 22198,
+ 22199,
+ 22200,
+ 22201,
+ 22202,
+ 22203,
+ 22204,
+ 22205,
+ 22206,
+ 22207,
+ 22208,
+ 22209,
+ 22210,
+ 22211,
+ 22212,
+ 22213,
+ 22214,
+ 22215,
+ 22216,
+ 22217,
+ 22218,
+ 22219,
+ 22220,
+ 22221,
+ 22222,
+ 22223,
+ 22224,
+ 22225,
+ 22226,
+ 22227,
+ 22228,
+ 22229,
+ 22230,
+ 22231,
+ 22232,
+ 22233,
+ 22234,
+ 22235,
+ 22236,
+ 22237,
+ 22238,
+ 22239,
+ 22240,
+ 22241,
+ 22242,
+ 22243,
+ 22244,
+ 22245,
+ 22246,
+ 22247,
+ 22248,
+ 22249,
+ 22250,
+ 22251,
+ 22252,
+ 22253,
+ 22254,
+ 22255,
+ 22256,
+ 22257,
+ 22258,
+ 22259,
+ 22260,
+ 22261,
+ 22262,
+ 22263,
+ 22264,
+ 22265,
+ 22266,
+ 22267,
+ 22268,
+ 22269,
+ 22270,
+ 22271,
+ 22272,
+ 22273,
+ 22274,
+ 22275,
+ 22276,
+ 22277,
+ 22278,
+ 22279,
+ 22280,
+ 22281,
+ 22282,
+ 22283,
+ 22284,
+ 22285,
+ 22286,
+ 22287,
+ 22288,
+ 22289,
+ 22290,
+ 22291,
+ 22292,
+ 22293,
+ 22294,
+ 22295,
+ 22296,
+ 22297,
+ 22298,
+ 22299,
+ 22300,
+ 22301,
+ 22302,
+ 22303,
+ 22304,
+ 22305,
+ 22306,
+ 22307,
+ 22308,
+ 22309,
+ 22310,
+ 22311,
+ 22312,
+ 22313,
+ 22314,
+ 22315,
+ 22316,
+ 22317,
+ 22318,
+ 22319,
+ 22320,
+ 22321,
+ 22322,
+ 22323,
+ 22324,
+ 22325,
+ 22326,
+ 22327,
+ 22328,
+ 22329,
+ 22330,
+ 22331,
+ 22332,
+ 22333,
+ 22334,
+ 22335,
+ 22336,
+ 22337,
+ 22338,
+ 22339,
+ 22340,
+ 22341,
+ 22342,
+ 22343,
+ 22344,
+ 22345,
+ 22346,
+ 22347,
+ 22348,
+ 22349,
+ 22350,
+ 22351,
+ 22352,
+ 22353,
+ 22354,
+ 22355,
+ 22356,
+ 22357,
+ 22358,
+ 22359,
+ 22360,
+ 22361,
+ 22362,
+ 22363,
+ 22364,
+ 22365,
+ 22366,
+ 22367,
+ 22368,
+ 22369,
+ 22370,
+ 22371,
+ 22372,
+ 22373,
+ 22374,
+ 22375,
+ 22376,
+ 22377,
+ 22378,
+ 22379,
+ 22380,
+ 22381,
+ 22382,
+ 22383,
+ 22384,
+ 22385,
+ 22386,
+ 22387,
+ 22388,
+ 22389,
+ 22390,
+ 22391,
+ 22392,
+ 22393,
+ 22394,
+ 22395,
+ 22396,
+ 22397,
+ 22398,
+ 22399,
+ 22400,
+ 22401,
+ 22402,
+ 22403,
+ 22404,
+ 22405,
+ 22406,
+ 22407,
+ 22408,
+ 22409,
+ 22410,
+ 22411,
+ 22412,
+ 22413,
+ 22414,
+ 22415,
+ 22416,
+ 22417,
+ 22418,
+ 22419,
+ 22420,
+ 22421,
+ 22422,
+ 22423,
+ 22424,
+ 22425,
+ 22426,
+ 22427,
+ 22428,
+ 22429,
+ 22430,
+ 22431,
+ 22432,
+ 22433,
+ 22434,
+ 22435,
+ 22436,
+ 22437,
+ 22438,
+ 22439,
+ 22440,
+ 22441,
+ 22442,
+ 22443,
+ 22444,
+ 22445,
+ 22446,
+ 22447,
+ 22448,
+ 22449,
+ 22450,
+ 22451,
+ 22452,
+ 22453,
+ 22454,
+ 22455,
+ 22456,
+ 22457,
+ 22458,
+ 22459,
+ 22460,
+ 22461,
+ 22462,
+ 22463,
+ 22464,
+ 22465,
+ 22466,
+ 22467,
+ 22468,
+ 22469,
+ 22470,
+ 22471,
+ 22472,
+ 22473,
+ 22474,
+ 22475,
+ 22476,
+ 22477,
+ 22478,
+ 22479,
+ 22480,
+ 22481,
+ 22482,
+ 22483,
+ 22484,
+ 22485,
+ 22486,
+ 22487,
+ 22488,
+ 22489,
+ 22490,
+ 22491,
+ 22492,
+ 22493,
+ 22494,
+ 22495,
+ 22496,
+ 22497,
+ 22498,
+ 22499,
+ 22500,
+ 22501,
+ 22502,
+ 22503,
+ 22504,
+ 22505,
+ 22506,
+ 22507,
+ 22508,
+ 22509,
+ 22510,
+ 22511,
+ 22512,
+ 22513,
+ 22514,
+ 22515,
+ 22516,
+ 22517,
+ 22518,
+ 22519,
+ 22520,
+ 22521,
+ 22522,
+ 22523,
+ 22524,
+ 22525,
+ 22526,
+ 22527,
+ 22528,
+ 22529,
+ 22530,
+ 22531,
+ 22532,
+ 22533,
+ 22534,
+ 22535,
+ 22536,
+ 22537,
+ 22538,
+ 22539,
+ 22540,
+ 22541,
+ 22542,
+ 22543,
+ 22544,
+ 22545,
+ 22546,
+ 22547,
+ 22548,
+ 22549,
+ 22550,
+ 22551,
+ 22552,
+ 22553,
+ 22554,
+ 22555,
+ 22556,
+ 22557,
+ 22558,
+ 22559,
+ 22560,
+ 22561,
+ 22562,
+ 22563,
+ 22564,
+ 22565,
+ 22566,
+ 22567,
+ 22568,
+ 22569,
+ 22570,
+ 22571,
+ 22572,
+ 22573,
+ 22574,
+ 22575,
+ 22576,
+ 22577,
+ 22578,
+ 22579,
+ 22580,
+ 22581,
+ 22582,
+ 22583,
+ 22584,
+ 22585,
+ 22586,
+ 22587,
+ 22588,
+ 22589,
+ 22590,
+ 22591,
+ 22592,
+ 22593,
+ 22594,
+ 22595,
+ 22596,
+ 22597,
+ 22598,
+ 22599,
+ 22600,
+ 22601,
+ 22602,
+ 22603,
+ 22604,
+ 22605,
+ 22606,
+ 22607,
+ 22608,
+ 22609,
+ 22610,
+ 22611,
+ 22612,
+ 22613,
+ 22614,
+ 22615,
+ 22616,
+ 22617,
+ 22618,
+ 22619,
+ 22620,
+ 22621,
+ 22622,
+ 22623,
+ 22624,
+ 22625,
+ 22626,
+ 22627,
+ 22628,
+ 22629,
+ 22630,
+ 22631,
+ 22632,
+ 22633,
+ 22634,
+ 22635,
+ 22636,
+ 22637,
+ 22638,
+ 22639,
+ 22640,
+ 22641,
+ 22642,
+ 22643,
+ 22644,
+ 22645,
+ 22646,
+ 22647,
+ 22648,
+ 22649,
+ 22650,
+ 22651,
+ 22652,
+ 22653,
+ 22654,
+ 22655,
+ 22656,
+ 22657,
+ 22658,
+ 22659,
+ 22660,
+ 22661,
+ 22662,
+ 22663,
+ 22664,
+ 22665,
+ 22666,
+ 22667,
+ 22668,
+ 22669,
+ 22670,
+ 22671,
+ 22672,
+ 22673,
+ 22674,
+ 22675,
+ 22676,
+ 22677,
+ 22678,
+ 22679,
+ 22680,
+ 22681,
+ 22682,
+ 22683,
+ 22684,
+ 22685,
+ 22686,
+ 22687,
+ 22688,
+ 22689,
+ 22690,
+ 22691,
+ 22692,
+ 22693,
+ 22694,
+ 22695,
+ 22696,
+ 22697,
+ 22698,
+ 22699,
+ 22700,
+ 22701,
+ 22702,
+ 22703,
+ 22704,
+ 22705,
+ 22706,
+ 22707,
+ 22708,
+ 22709,
+ 22710,
+ 22711,
+ 22712,
+ 22713,
+ 22714,
+ 22715,
+ 22716,
+ 22717,
+ 22718,
+ 22719,
+ 22720,
+ 22721,
+ 22722,
+ 22723,
+ 22724,
+ 22725,
+ 22726,
+ 22727,
+ 22728,
+ 22729,
+ 22730,
+ 22731,
+ 22732,
+ 22733,
+ 22734,
+ 22735,
+ 22736,
+ 22737,
+ 22738,
+ 22739,
+ 22740,
+ 22741,
+ 22742,
+ 22743,
+ 22744,
+ 22745,
+ 22746,
+ 22747,
+ 22748,
+ 22749,
+ 22750,
+ 22751,
+ 22752,
+ 22753,
+ 22754,
+ 22755,
+ 22756,
+ 22757,
+ 22758,
+ 22759,
+ 22760,
+ 22761,
+ 22762,
+ 22763,
+ 22764,
+ 22765,
+ 22766,
+ 22767,
+ 22768,
+ 22769,
+ 22770,
+ 22771,
+ 22772,
+ 22773,
+ 22774,
+ 22775,
+ 22776,
+ 22777,
+ 22778,
+ 22779,
+ 22780,
+ 22781,
+ 22782,
+ 22783,
+ 22784,
+ 22785,
+ 22786,
+ 22787,
+ 22788,
+ 22789,
+ 22790,
+ 22791,
+ 22792,
+ 22793,
+ 22794,
+ 22795,
+ 22796,
+ 22797,
+ 22798,
+ 22799,
+ 22800,
+ 22801,
+ 22802,
+ 22803,
+ 22804,
+ 22805,
+ 22806,
+ 22807,
+ 22808,
+ 22809,
+ 22810,
+ 22811,
+ 22812,
+ 22813,
+ 22814,
+ 22815,
+ 22816,
+ 22817,
+ 22818,
+ 22819,
+ 22820,
+ 22821,
+ 22822,
+ 22823,
+ 22824,
+ 22825,
+ 22826,
+ 22827,
+ 22828,
+ 22829,
+ 22830,
+ 22831,
+ 22832,
+ 22833,
+ 22834,
+ 22835,
+ 22836,
+ 22837,
+ 22838,
+ 22839,
+ 22840,
+ 22841,
+ 22842,
+ 22843,
+ 22844,
+ 22845,
+ 22846,
+ 22847,
+ 22848,
+ 22849,
+ 22850,
+ 22851,
+ 22852,
+ 22853,
+ 22854,
+ 22855,
+ 22856,
+ 22857,
+ 22858,
+ 22859,
+ 22860,
+ 22861,
+ 22862,
+ 22863,
+ 22864,
+ 22865,
+ 22866,
+ 22867,
+ 22868,
+ 22869,
+ 22870,
+ 22871,
+ 22872,
+ 22873,
+ 22874,
+ 22875,
+ 22876,
+ 22877,
+ 22878,
+ 22879,
+ 22880,
+ 22881,
+ 22882,
+ 22883,
+ 22884,
+ 22885,
+ 22886,
+ 22887,
+ 22888,
+ 22889,
+ 22890,
+ 22891,
+ 22892,
+ 22893,
+ 22894,
+ 22895,
+ 22896,
+ 22897,
+ 22898,
+ 22899,
+ 22900,
+ 22901,
+ 22902,
+ 22903,
+ 22904,
+ 22905,
+ 22906,
+ 22907,
+ 22908,
+ 22909,
+ 22910,
+ 22911,
+ 22912,
+ 22913,
+ 22914,
+ 22915,
+ 22916,
+ 22917,
+ 22918,
+ 22919,
+ 22920,
+ 22921,
+ 22922,
+ 22923,
+ 22924,
+ 22925,
+ 22926,
+ 22927,
+ 22928,
+ 22929,
+ 22930,
+ 22931,
+ 22932,
+ 22933,
+ 22934,
+ 22935,
+ 22936,
+ 22937,
+ 22938,
+ 22939,
+ 22940,
+ 22941,
+ 22942,
+ 22943,
+ 22944,
+ 22945,
+ 22946,
+ 22947,
+ 22948,
+ 22949,
+ 22950,
+ 22951,
+ 22952,
+ 22953,
+ 22954,
+ 22955,
+ 22956,
+ 22957,
+ 22958,
+ 22959,
+ 22960,
+ 22961,
+ 22962,
+ 22963,
+ 22964,
+ 22965,
+ 22966,
+ 22967,
+ 22968,
+ 22969,
+ 22970,
+ 22971,
+ 22972,
+ 22973,
+ 22974,
+ 22975,
+ 22976,
+ 22977,
+ 22978,
+ 22979,
+ 22980,
+ 22981,
+ 22982,
+ 22983,
+ 22984,
+ 22985,
+ 22986,
+ 22987,
+ 22988,
+ 22989,
+ 22990,
+ 22991,
+ 22992,
+ 22993,
+ 22994,
+ 22995,
+ 22996,
+ 22997,
+ 22998,
+ 22999,
+ 23000,
+ 23001,
+ 23002,
+ 23003,
+ 23004,
+ 23005,
+ 23006,
+ 23007,
+ 23008,
+ 23009,
+ 23010,
+ 23011,
+ 23012,
+ 23013,
+ 23014,
+ 23015,
+ 23016,
+ 23017,
+ 23018,
+ 23019,
+ 23020,
+ 23021,
+ 23022,
+ 23023,
+ 23024,
+ 23025,
+ 23026,
+ 23027,
+ 23028,
+ 23029,
+ 23030,
+ 23031,
+ 23032,
+ 23033,
+ 23034,
+ 23035,
+ 23036,
+ 23037,
+ 23038,
+ 23039,
+ 23040,
+ 23041,
+ 23042,
+ 23043,
+ 23044,
+ 23045,
+ 23046,
+ 23047,
+ 23048,
+ 23049,
+ 23050,
+ 23051,
+ 23052,
+ 23053,
+ 23054,
+ 23055,
+ 23056,
+ 23057,
+ 23058,
+ 23059,
+ 23060,
+ 23061,
+ 23062,
+ 23063,
+ 23064,
+ 23065,
+ 23066,
+ 23067,
+ 23068,
+ 23069,
+ 23070,
+ 23071,
+ 23072,
+ 23073,
+ 23074,
+ 23075,
+ 23076,
+ 23077,
+ 23078,
+ 23079,
+ 23080,
+ 23081,
+ 23082,
+ 23083,
+ 23084,
+ 23085,
+ 23086,
+ 23087,
+ 23088,
+ 23089,
+ 23090,
+ 23091,
+ 23092,
+ 23093,
+ 23094,
+ 23095,
+ 23096,
+ 23097,
+ 23098,
+ 23099,
+ 23100,
+ 23101,
+ 23102,
+ 23103,
+ 23104,
+ 23105,
+ 23106,
+ 23107,
+ 23108,
+ 23109,
+ 23110,
+ 23111,
+ 23112,
+ 23113,
+ 23114,
+ 23115,
+ 23116,
+ 23117,
+ 23118,
+ 23119,
+ 23120,
+ 23121,
+ 23122,
+ 23123,
+ 23124,
+ 23125,
+ 23126,
+ 23127,
+ 23128,
+ 23129,
+ 23130,
+ 23131,
+ 23132,
+ 23133,
+ 23134,
+ 23135,
+ 23136,
+ 23137,
+ 23138,
+ 23139,
+ 23140,
+ 23141,
+ 23142,
+ 23143,
+ 23144,
+ 23145,
+ 23146,
+ 23147,
+ 23148,
+ 23149,
+ 23150,
+ 23151,
+ 23152,
+ 23153,
+ 23154,
+ 23155,
+ 23156,
+ 23157,
+ 23158,
+ 23159,
+ 23160,
+ 23161,
+ 23162,
+ 23163,
+ 23164,
+ 23165,
+ 23166,
+ 23167,
+ 23168,
+ 23169,
+ 23170,
+ 23171,
+ 23172,
+ 23173,
+ 23174,
+ 23175,
+ 23176,
+ 23177,
+ 23178,
+ 23179,
+ 23180,
+ 23181,
+ 23182,
+ 23183,
+ 23184,
+ 23185,
+ 23186,
+ 23187,
+ 23188,
+ 23189,
+ 23190,
+ 23191,
+ 23192,
+ 23193,
+ 23194,
+ 23195,
+ 23196,
+ 23197,
+ 23198,
+ 23199,
+ 23200,
+ 23201,
+ 23202,
+ 23203,
+ 23204,
+ 23205,
+ 23206,
+ 23207,
+ 23208,
+ 23209,
+ 23210,
+ 23211,
+ 23212,
+ 23213,
+ 23214,
+ 23215,
+ 23216,
+ 23217,
+ 23218,
+ 23219,
+ 23220,
+ 23221,
+ 23222,
+ 23223,
+ 23224,
+ 23225,
+ 23226,
+ 23227,
+ 23228,
+ 23229,
+ 23230,
+ 23231,
+ 23232,
+ 23233,
+ 23234,
+ 23235,
+ 23236,
+ 23237,
+ 23238,
+ 23239,
+ 23240,
+ 23241,
+ 23242,
+ 23243,
+ 23244,
+ 23245,
+ 23246,
+ 23247,
+ 23248,
+ 23249,
+ 23250,
+ 23251,
+ 23252,
+ 23253,
+ 23254,
+ 23255,
+ 23256,
+ 23257,
+ 23258,
+ 23259,
+ 23260,
+ 23261,
+ 23262,
+ 23263,
+ 23264,
+ 23265,
+ 23266,
+ 23267,
+ 23268,
+ 23269,
+ 23270,
+ 23271,
+ 23272,
+ 23273,
+ 23274,
+ 23275,
+ 23276,
+ 23277,
+ 23278,
+ 23279,
+ 23280,
+ 23281,
+ 23282,
+ 23283,
+ 23284,
+ 23285,
+ 23286,
+ 23287,
+ 23288,
+ 23289,
+ 23290,
+ 23291,
+ 23292,
+ 23293,
+ 23294,
+ 23295,
+ 23296,
+ 23297,
+ 23298,
+ 23299,
+ 23300,
+ 23301,
+ 23302,
+ 23303,
+ 23304,
+ 23305,
+ 23306,
+ 23307,
+ 23308,
+ 23309,
+ 23310,
+ 23311,
+ 23312,
+ 23313,
+ 23314,
+ 23315,
+ 23316,
+ 23317,
+ 23318,
+ 23319,
+ 23320,
+ 23321,
+ 23322,
+ 23323,
+ 23324,
+ 23325,
+ 23326,
+ 23327,
+ 23328,
+ 23329,
+ 23330,
+ 23331,
+ 23332,
+ 23333,
+ 23334,
+ 23335,
+ 23336,
+ 23337,
+ 23338,
+ 23339,
+ 23340,
+ 23341,
+ 23342,
+ 23343,
+ 23344,
+ 23345,
+ 23346,
+ 23347,
+ 23348,
+ 23349,
+ 23350,
+ 23351,
+ 23352,
+ 23353,
+ 23354,
+ 23355,
+ 23356,
+ 23357,
+ 23358,
+ 23359,
+ 23360,
+ 23361,
+ 23362,
+ 23363,
+ 23364,
+ 23365,
+ 23366,
+ 23367,
+ 23368,
+ 23369,
+ 23370,
+ 23371,
+ 23372,
+ 23373,
+ 23374,
+ 23375,
+ 23376,
+ 23377,
+ 23378,
+ 23379,
+ 23380,
+ 23381,
+ 23382,
+ 23383,
+ 23384,
+ 23385,
+ 23386,
+ 23387,
+ 23388,
+ 23389,
+ 23390,
+ 23391,
+ 23392,
+ 23393,
+ 23394,
+ 23395,
+ 23396,
+ 23397,
+ 23398,
+ 23399,
+ 23400,
+ 23401,
+ 23402,
+ 23403,
+ 23404,
+ 23405,
+ 23406,
+ 23407,
+ 23408,
+ 23409,
+ 23410,
+ 23411,
+ 23412,
+ 23413,
+ 23414,
+ 23415,
+ 23416,
+ 23417,
+ 23418,
+ 23419,
+ 23420,
+ 23421,
+ 23422,
+ 23423,
+ 23424,
+ 23425,
+ 23426,
+ 23427,
+ 23428,
+ 23429,
+ 23430,
+ 23431,
+ 23432,
+ 23433,
+ 23434,
+ 23435,
+ 23436,
+ 23437,
+ 23438,
+ 23439,
+ 23440,
+ 23441,
+ 23442,
+ 23443,
+ 23444,
+ 23445,
+ 23446,
+ 23447,
+ 23448,
+ 23449,
+ 23450,
+ 23451,
+ 23452,
+ 23453,
+ 23454,
+ 23455,
+ 23456,
+ 23457,
+ 23458,
+ 23459,
+ 23460,
+ 23461,
+ 23462,
+ 23463,
+ 23464,
+ 23465,
+ 23466,
+ 23467,
+ 23468,
+ 23469,
+ 23470,
+ 23471,
+ 23472,
+ 23473,
+ 23474,
+ 23475,
+ 23476,
+ 23477,
+ 23478,
+ 23479,
+ 23480,
+ 23481,
+ 23482,
+ 23483,
+ 23484,
+ 23485,
+ 23486,
+ 23487,
+ 23488,
+ 23489,
+ 23490,
+ 23491,
+ 23492,
+ 23493,
+ 23494,
+ 23495,
+ 23496,
+ 23497,
+ 23498,
+ 23499,
+ 23500,
+ 23501,
+ 23502,
+ 23503,
+ 23504,
+ 23505,
+ 23506,
+ 23507,
+ 23508,
+ 23509,
+ 23510,
+ 23511,
+ 23512,
+ 23513,
+ 23514,
+ 23515,
+ 23516,
+ 23517,
+ 23518,
+ 23519,
+ 23520,
+ 23521,
+ 23522,
+ 23523,
+ 23524,
+ 23525,
+ 23526,
+ 23527,
+ 23528,
+ 23529,
+ 23530,
+ 23531,
+ 23532,
+ 23533,
+ 23534,
+ 23535,
+ 23536,
+ 23537,
+ 23538,
+ 23539,
+ 23540,
+ 23541,
+ 23542,
+ 23543,
+ 23544,
+ 23545,
+ 23546,
+ 23547,
+ 23548,
+ 23549,
+ 23550,
+ 23551,
+ 23552,
+ 23553,
+ 23554,
+ 23555,
+ 23556,
+ 23557,
+ 23558,
+ 23559,
+ 23560,
+ 23561,
+ 23562,
+ 23563,
+ 23564,
+ 23565,
+ 23566,
+ 23567,
+ 23568,
+ 23569,
+ 23570,
+ 23571,
+ 23572,
+ 23573,
+ 23574,
+ 23575,
+ 23576,
+ 23577,
+ 23578,
+ 23579,
+ 23580,
+ 23581,
+ 23582,
+ 23583,
+ 23584,
+ 23585,
+ 23586,
+ 23587,
+ 23588,
+ 23589,
+ 23590,
+ 23591,
+ 23592,
+ 23593,
+ 23594,
+ 23595,
+ 23596,
+ 23597,
+ 23598,
+ 23599,
+ 23600,
+ 23601,
+ 23602,
+ 23603,
+ 23604,
+ 23605,
+ 23606,
+ 23607,
+ 23608,
+ 23609,
+ 23610,
+ 23611,
+ 23612,
+ 23613,
+ 23614,
+ 23615,
+ 23616,
+ 23617,
+ 23618,
+ 23619,
+ 23620,
+ 23621,
+ 23622,
+ 23623,
+ 23624,
+ 23625,
+ 23626,
+ 23627,
+ 23628,
+ 23629,
+ 23630,
+ 23631,
+ 23632,
+ 23633,
+ 23634,
+ 23635,
+ 23636,
+ 23637,
+ 23638,
+ 23639,
+ 23640,
+ 23641,
+ 23642,
+ 23643,
+ 23644,
+ 23645,
+ 23646,
+ 23647,
+ 23648,
+ 23649,
+ 23650,
+ 23651,
+ 23652,
+ 23653,
+ 23654,
+ 23655,
+ 23656,
+ 23657,
+ 23658,
+ 23659,
+ 23660,
+ 23661,
+ 23662,
+ 23663,
+ 23664,
+ 23665,
+ 23666,
+ 23667,
+ 23668,
+ 23669,
+ 23670,
+ 23671,
+ 23672,
+ 23673,
+ 23674,
+ 23675,
+ 23676,
+ 23677,
+ 23678,
+ 23679,
+ 23680,
+ 23681,
+ 23682,
+ 23683,
+ 23684,
+ 23685,
+ 23686,
+ 23687,
+ 23688,
+ 23689,
+ 23690,
+ 23691,
+ 23692,
+ 23693,
+ 23694,
+ 23695,
+ 23696,
+ 23697,
+ 23698,
+ 23699,
+ 23700,
+ 23701,
+ 23702,
+ 23703,
+ 23704,
+ 23705,
+ 23706,
+ 23707,
+ 23708,
+ 23709,
+ 23710,
+ 23711,
+ 23712,
+ 23713,
+ 23714,
+ 23715,
+ 23716,
+ 23717,
+ 23718,
+ 23719,
+ 23720,
+ 23721,
+ 23722,
+ 23723,
+ 23724,
+ 23725,
+ 23726,
+ 23727,
+ 23728,
+ 23729,
+ 23730,
+ 23731,
+ 23732,
+ 23733,
+ 23734,
+ 23735,
+ 23736,
+ 23737,
+ 23738,
+ 23739,
+ 23740,
+ 23741,
+ 23742,
+ 23743,
+ 23744,
+ 23745,
+ 23746,
+ 23747,
+ 23748,
+ 23749,
+ 23750,
+ 23751,
+ 23752,
+ 23753,
+ 23754,
+ 23755,
+ 23756,
+ 23757,
+ 23758,
+ 23759,
+ 23760,
+ 23761,
+ 23762,
+ 23763,
+ 23764,
+ 23765,
+ 23766,
+ 23767,
+ 23768,
+ 23769,
+ 23770,
+ 23771,
+ 23772,
+ 23773,
+ 23774,
+ 23775,
+ 23776,
+ 23777,
+ 23778,
+ 23779,
+ 23780,
+ 23781,
+ 23782,
+ 23783,
+ 23784,
+ 23785,
+ 23786,
+ 23787,
+ 23788,
+ 23789,
+ 23790,
+ 23791,
+ 23792,
+ 23793,
+ 23794,
+ 23795,
+ 23796,
+ 23797,
+ 23798,
+ 23799,
+ 23800,
+ 23801,
+ 23802,
+ 23803,
+ 23804,
+ 23805,
+ 23806,
+ 23807,
+ 23808,
+ 23809,
+ 23810,
+ 23811,
+ 23812,
+ 23813,
+ 23814,
+ 23815,
+ 23816,
+ 23817,
+ 23818,
+ 23819,
+ 23820,
+ 23821,
+ 23822,
+ 23823,
+ 23824,
+ 23825,
+ 23826,
+ 23827,
+ 23828,
+ 23829,
+ 23830,
+ 23831,
+ 23832,
+ 23833,
+ 23834,
+ 23835,
+ 23836,
+ 23837,
+ 23838,
+ 23839,
+ 23840,
+ 23841,
+ 23842,
+ 23843,
+ 23844,
+ 23845,
+ 23846,
+ 23847,
+ 23848,
+ 23849,
+ 23850,
+ 23851,
+ 23852,
+ 23853,
+ 23854,
+ 23855,
+ 23856,
+ 23857,
+ 23858,
+ 23859,
+ 23860,
+ 23861,
+ 23862,
+ 23863,
+ 23864,
+ 23865,
+ 23866,
+ 23867,
+ 23868,
+ 23869,
+ 23870,
+ 23871,
+ 23872,
+ 23873,
+ 23874,
+ 23875,
+ 23876,
+ 23877,
+ 23878,
+ 23879,
+ 23880,
+ 23881,
+ 23882,
+ 23883,
+ 23884,
+ 23885,
+ 23886,
+ 23887,
+ 23888,
+ 23889,
+ 23890,
+ 23891,
+ 23892,
+ 23893,
+ 23894,
+ 23895,
+ 23896,
+ 23897,
+ 23898,
+ 23899,
+ 23900,
+ 23901,
+ 23902,
+ 23903,
+ 23904,
+ 23905,
+ 23906,
+ 23907,
+ 23908,
+ 23909,
+ 23910,
+ 23911,
+ 23912,
+ 23913,
+ 23914,
+ 23915,
+ 23916,
+ 23917,
+ 23918,
+ 23919,
+ 23920,
+ 23921,
+ 23922,
+ 23923,
+ 23924,
+ 23925,
+ 23926,
+ 23927,
+ 23928,
+ 23929,
+ 23930,
+ 23931,
+ 23932,
+ 23933,
+ 23934,
+ 23935,
+ 23936,
+ 23937,
+ 23938,
+ 23939,
+ 23940,
+ 23941,
+ 23942,
+ 23943,
+ 23944,
+ 23945,
+ 23946,
+ 23947,
+ 23948,
+ 23949,
+ 23950,
+ 23951,
+ 23952,
+ 23953,
+ 23954,
+ 23955,
+ 23956,
+ 23957,
+ 23958,
+ 23959,
+ 23960,
+ 23961,
+ 23962,
+ 23963,
+ 23964,
+ 23965,
+ 23966,
+ 23967,
+ 23968,
+ 23969,
+ 23970,
+ 23971,
+ 23972,
+ 23973,
+ 23974,
+ 23975,
+ 23976,
+ 23977,
+ 23978,
+ 23979,
+ 23980,
+ 23981,
+ 23982,
+ 23983,
+ 23984,
+ 23985,
+ 23986,
+ 23987,
+ 23988,
+ 23989,
+ 23990,
+ 23991,
+ 23992,
+ 23993,
+ 23994,
+ 23995,
+ 23996,
+ 23997,
+ 23998,
+ 23999,
+ 24000,
+ 24001,
+ 24002,
+ 24003,
+ 24004,
+ 24005,
+ 24006,
+ 24007,
+ 24008,
+ 24009,
+ 24010,
+ 24011,
+ 24012,
+ 24013,
+ 24014,
+ 24015,
+ 24016,
+ 24017,
+ 24018,
+ 24019,
+ 24020,
+ 24021,
+ 24022,
+ 24023,
+ 24024,
+ 24025,
+ 24026,
+ 24027,
+ 24028,
+ 24029,
+ 24030,
+ 24031,
+ 24032,
+ 24033,
+ 24034,
+ 24035,
+ 24036,
+ 24037,
+ 24038,
+ 24039,
+ 24040,
+ 24041,
+ 24042,
+ 24043,
+ 24044,
+ 24045,
+ 24046,
+ 24047,
+ 24048,
+ 24049,
+ 24050,
+ 24051,
+ 24052,
+ 24053,
+ 24054,
+ 24055,
+ 24056,
+ 24057,
+ 24058,
+ 24059,
+ 24060,
+ 24061,
+ 24062,
+ 24063,
+ 24064,
+ 24065,
+ 24066,
+ 24067,
+ 24068,
+ 24069,
+ 24070,
+ 24071,
+ 24072,
+ 24073,
+ 24074,
+ 24075,
+ 24076,
+ 24077,
+ 24078,
+ 24079,
+ 24080,
+ 24081,
+ 24082,
+ 24083,
+ 24084,
+ 24085,
+ 24086,
+ 24087,
+ 24088,
+ 24089,
+ 24090,
+ 24091,
+ 24092,
+ 24093,
+ 24094,
+ 24095,
+ 24096,
+ 24097,
+ 24098,
+ 24099,
+ 24100,
+ 24101,
+ 24102,
+ 24103,
+ 24104,
+ 24105,
+ 24106,
+ 24107,
+ 24108,
+ 24109,
+ 24110,
+ 24111,
+ 24112,
+ 24113,
+ 24114,
+ 24115,
+ 24116,
+ 24117,
+ 24118,
+ 24119,
+ 24120,
+ 24121,
+ 24122,
+ 24123,
+ 24124,
+ 24125,
+ 24126,
+ 24127,
+ 24128,
+ 24129,
+ 24130,
+ 24131,
+ 24132,
+ 24133,
+ 24134,
+ 24135,
+ 24136,
+ 24137,
+ 24138,
+ 24139,
+ 24140,
+ 24141,
+ 24142,
+ 24143,
+ 24144,
+ 24145,
+ 24146,
+ 24147,
+ 24148,
+ 24149,
+ 24150,
+ 24151,
+ 24152,
+ 24153,
+ 24154,
+ 24155,
+ 24156,
+ 24157,
+ 24158,
+ 24159,
+ 24160,
+ 24161,
+ 24162,
+ 24163,
+ 24164,
+ 24165,
+ 24166,
+ 24167,
+ 24168,
+ 24169,
+ 24170,
+ 24171,
+ 24172,
+ 24173,
+ 24174,
+ 24175,
+ 24176,
+ 24177,
+ 24178,
+ 24179,
+ 24180,
+ 24181,
+ 24182,
+ 24183,
+ 24184,
+ 24185,
+ 24186,
+ 24187,
+ 24188,
+ 24189,
+ 24190,
+ 24191,
+ 24192,
+ 24193,
+ 24194,
+ 24195,
+ 24196,
+ 24197,
+ 24198,
+ 24199,
+ 24200,
+ 24201,
+ 24202,
+ 24203,
+ 24204,
+ 24205,
+ 24206,
+ 24207,
+ 24208,
+ 24209,
+ 24210,
+ 24211,
+ 24212,
+ 24213,
+ 24214,
+ 24215,
+ 24216,
+ 24217,
+ 24218,
+ 24219,
+ 24220,
+ 24221,
+ 24222,
+ 24223,
+ 24224,
+ 24225,
+ 24226,
+ 24227,
+ 24228,
+ 24229,
+ 24230,
+ 24231,
+ 24232,
+ 24233,
+ 24234,
+ 24235,
+ 24236,
+ 24237,
+ 24238,
+ 24239,
+ 24240,
+ 24241,
+ 24242,
+ 24243,
+ 24244,
+ 24245,
+ 24246,
+ 24247,
+ 24248,
+ 24249,
+ 24250,
+ 24251,
+ 24252,
+ 24253,
+ 24254,
+ 24255,
+ 24256,
+ 24257,
+ 24258,
+ 24259,
+ 24260,
+ 24261,
+ 24262,
+ 24263,
+ 24264,
+ 24265,
+ 24266,
+ 24267,
+ 24268,
+ 24269,
+ 24270,
+ 24271,
+ 24272,
+ 24273,
+ 24274,
+ 24275,
+ 24276,
+ 24277,
+ 24278,
+ 24279,
+ 24280,
+ 24281,
+ 24282,
+ 24283,
+ 24284,
+ 24285,
+ 24286,
+ 24287,
+ 24288,
+ 24289,
+ 24290,
+ 24291,
+ 24292,
+ 24293,
+ 24294,
+ 24295,
+ 24296,
+ 24297,
+ 24298,
+ 24299,
+ 24300,
+ 24301,
+ 24302,
+ 24303,
+ 24304,
+ 24305,
+ 24306,
+ 24307,
+ 24308,
+ 24309,
+ 24310,
+ 24311,
+ 24312,
+ 24313,
+ 24314,
+ 24315,
+ 24316,
+ 24317,
+ 24318,
+ 24319,
+ 24320,
+ 24321,
+ 24322,
+ 24323,
+ 24324,
+ 24325,
+ 24326,
+ 24327,
+ 24328,
+ 24329,
+ 24330,
+ 24331,
+ 24332,
+ 24333,
+ 24334,
+ 24335,
+ 24336,
+ 24337,
+ 24338,
+ 24339,
+ 24340,
+ 24341,
+ 24342,
+ 24343,
+ 24344,
+ 24345,
+ 24346,
+ 24347,
+ 24348,
+ 24349,
+ 24350,
+ 24351,
+ 24352,
+ 24353,
+ 24354,
+ 24355,
+ 24356,
+ 24357,
+ 24358,
+ 24359,
+ 24360,
+ 24361,
+ 24362,
+ 24363,
+ 24364,
+ 24365,
+ 24366,
+ 24367,
+ 24368,
+ 24369,
+ 24370,
+ 24371,
+ 24372,
+ 24373,
+ 24374,
+ 24375,
+ 24376,
+ 24377,
+ 24378,
+ 24379,
+ 24380,
+ 24381,
+ 24382,
+ 24383,
+ 24384,
+ 24385,
+ 24386,
+ 24387,
+ 24388,
+ 24389,
+ 24390,
+ 24391,
+ 24392,
+ 24393,
+ 24394,
+ 24395,
+ 24396,
+ 24397,
+ 24398,
+ 24399,
+ 24400,
+ 24401,
+ 24402,
+ 24403,
+ 24404,
+ 24405,
+ 24406,
+ 24407,
+ 24408,
+ 24409,
+ 24410,
+ 24411,
+ 24412,
+ 24413,
+ 24414,
+ 24415,
+ 24416,
+ 24417,
+ 24418,
+ 24419,
+ 24420,
+ 24421,
+ 24422,
+ 24423,
+ 24424,
+ 24425,
+ 24426,
+ 24427,
+ 24428,
+ 24429,
+ 24430,
+ 24431,
+ 24432,
+ 24433,
+ 24434,
+ 24435,
+ 24436,
+ 24437,
+ 24438,
+ 24439,
+ 24440,
+ 24441,
+ 24442,
+ 24443,
+ 24444,
+ 24445,
+ 24446,
+ 24447,
+ 24448,
+ 24449,
+ 24450,
+ 24451,
+ 24452,
+ 24453,
+ 24454,
+ 24455,
+ 24456,
+ 24457,
+ 24458,
+ 24459,
+ 24460,
+ 24461,
+ 24462,
+ 24463,
+ 24464,
+ 24465,
+ 24466,
+ 24467,
+ 24468,
+ 24469,
+ 24470,
+ 24471,
+ 24472,
+ 24473,
+ 24474,
+ 24475,
+ 24476,
+ 24477,
+ 24478,
+ 24479,
+ 24480,
+ 24481,
+ 24482,
+ 24483,
+ 24484,
+ 24485,
+ 24486,
+ 24487,
+ 24488,
+ 24489,
+ 24490,
+ 24491,
+ 24492,
+ 24493,
+ 24494,
+ 24495,
+ 24496,
+ 24497,
+ 24498,
+ 24499,
+ 24500,
+ 24501,
+ 24502,
+ 24503,
+ 24504,
+ 24505,
+ 24506,
+ 24507,
+ 24508,
+ 24509,
+ 24510,
+ 24511,
+ 24512,
+ 24513,
+ 24514,
+ 24515,
+ 24516,
+ 24517,
+ 24518,
+ 24519,
+ 24520,
+ 24521,
+ 24522,
+ 24523,
+ 24524,
+ 24525,
+ 24526,
+ 24527,
+ 24528,
+ 24529,
+ 24530,
+ 24531,
+ 24532,
+ 24533,
+ 24534,
+ 24535,
+ 24536,
+ 24537,
+ 24538,
+ 24539,
+ 24540,
+ 24541,
+ 24542,
+ 24543,
+ 24544,
+ 24545,
+ 24546,
+ 24547,
+ 24548,
+ 24549,
+ 24550,
+ 24551,
+ 24552,
+ 24553,
+ 24554,
+ 24555,
+ 24556,
+ 24557,
+ 24558,
+ 24559,
+ 24560,
+ 24561,
+ 24562,
+ 24563,
+ 24564,
+ 24565,
+ 24566,
+ 24567,
+ 24568,
+ 24569,
+ 24570,
+ 24571,
+ 24572,
+ 24573,
+ 24574,
+ 24575,
+ 24576,
+ 24577,
+ 24578,
+ 24579,
+ 24580,
+ 24581,
+ 24582,
+ 24583,
+ 24584,
+ 24585,
+ 24586,
+ 24587,
+ 24588,
+ 24589,
+ 24590,
+ 24591,
+ 24592,
+ 24593,
+ 24594,
+ 24595,
+ 24596,
+ 24597,
+ 24598,
+ 24599,
+ 24600,
+ 24601,
+ 24602,
+ 24603,
+ 24604,
+ 24605,
+ 24606,
+ 24607,
+ 24608,
+ 24609,
+ 24610,
+ 24611,
+ 24612,
+ 24613,
+ 24614,
+ 24615,
+ 24616,
+ 24617,
+ 24618,
+ 24619,
+ 24620,
+ 24621,
+ 24622,
+ 24623,
+ 24624,
+ 24625,
+ 24626,
+ 24627,
+ 24628,
+ 24629,
+ 24630,
+ 24631,
+ 24632,
+ 24633,
+ 24634,
+ 24635,
+ 24636,
+ 24637,
+ 24638,
+ 24639,
+ 24640,
+ 24641,
+ 24642,
+ 24643,
+ 24644,
+ 24645,
+ 24646,
+ 24647,
+ 24648,
+ 24649,
+ 24650,
+ 24651,
+ 24652,
+ 24653,
+ 24654,
+ 24655,
+ 24656,
+ 24657,
+ 24658,
+ 24659,
+ 24660,
+ 24661,
+ 24662,
+ 24663,
+ 24664,
+ 24665,
+ 24666,
+ 24667,
+ 24668,
+ 24669,
+ 24670,
+ 24671,
+ 24672,
+ 24673,
+ 24674,
+ 24675,
+ 24676,
+ 24677,
+ 24678,
+ 24679,
+ 24680,
+ 24681,
+ 24682,
+ 24683,
+ 24684,
+ 24685,
+ 24686,
+ 24687,
+ 24688,
+ 24689,
+ 24690,
+ 24691,
+ 24692,
+ 24693,
+ 24694,
+ 24695,
+ 24696,
+ 24697,
+ 24698,
+ 24699,
+ 24700,
+ 24701,
+ 24702,
+ 24703,
+ 24704,
+ 24705,
+ 24706,
+ 24707,
+ 24708,
+ 24709,
+ 24710,
+ 24711,
+ 24712,
+ 24713,
+ 24714,
+ 24715,
+ 24716,
+ 24717,
+ 24718,
+ 24719,
+ 24720,
+ 24721,
+ 24722,
+ 24723,
+ 24724,
+ 24725,
+ 24726,
+ 24727,
+ 24728,
+ 24729,
+ 24730,
+ 24731,
+ 24732,
+ 24733,
+ 24734,
+ 24735,
+ 24736,
+ 24737,
+ 24738,
+ 24739,
+ 24740,
+ 24741,
+ 24742,
+ 24743,
+ 24744,
+ 24745,
+ 24746,
+ 24747,
+ 24748,
+ 24749,
+ 24750,
+ 24751,
+ 24752,
+ 24753,
+ 24754,
+ 24755,
+ 24756,
+ 24757,
+ 24758,
+ 24759,
+ 24760,
+ 24761,
+ 24762,
+ 24763,
+ 24764,
+ 24765,
+ 24766,
+ 24767,
+ 24768,
+ 24769,
+ 24770,
+ 24771,
+ 24772,
+ 24773,
+ 24774,
+ 24775,
+ 24776,
+ 24777,
+ 24778,
+ 24779,
+ 24780,
+ 24781,
+ 24782,
+ 24783,
+ 24784,
+ 24785,
+ 24786,
+ 24787,
+ 24788,
+ 24789,
+ 24790,
+ 24791,
+ 24792,
+ 24793,
+ 24794,
+ 24795,
+ 24796,
+ 24797,
+ 24798,
+ 24799,
+ 24800,
+ 24801,
+ 24802,
+ 24803,
+ 24804,
+ 24805,
+ 24806,
+ 24807,
+ 24808,
+ 24809,
+ 24810,
+ 24811,
+ 24812,
+ 24813,
+ 24814,
+ 24815,
+ 24816,
+ 24817,
+ 24818,
+ 24819,
+ 24820,
+ 24821,
+ 24822,
+ 24823,
+ 24824,
+ 24825,
+ 24826,
+ 24827,
+ 24828,
+ 24829,
+ 24830,
+ 24831,
+ 24832,
+ 24833,
+ 24834,
+ 24835,
+ 24836,
+ 24837,
+ 24838,
+ 24839,
+ 24840,
+ 24841,
+ 24842,
+ 24843,
+ 24844,
+ 24845,
+ 24846,
+ 24847,
+ 24848,
+ 24849,
+ 24850,
+ 24851,
+ 24852,
+ 24853,
+ 24854,
+ 24855,
+ 24856,
+ 24857,
+ 24858,
+ 24859,
+ 24860,
+ 24861,
+ 24862,
+ 24863,
+ 24864,
+ 24865,
+ 24866,
+ 24867,
+ 24868,
+ 24869,
+ 24870,
+ 24871,
+ 24872,
+ 24873,
+ 24874,
+ 24875,
+ 24876,
+ 24877,
+ 24878,
+ 24879,
+ 24880,
+ 24881,
+ 24882,
+ 24883,
+ 24884,
+ 24885,
+ 24886,
+ 24887,
+ 24888,
+ 24889,
+ 24890,
+ 24891,
+ 24892,
+ 24893,
+ 24894,
+ 24895,
+ 24896,
+ 24897,
+ 24898,
+ 24899,
+ 24900,
+ 24901,
+ 24902,
+ 24903,
+ 24904,
+ 24905,
+ 24906,
+ 24907,
+ 24908,
+ 24909,
+ 24910,
+ 24911,
+ 24912,
+ 24913,
+ 24914,
+ 24915,
+ 24916,
+ 24917,
+ 24918,
+ 24919,
+ 24920,
+ 24921,
+ 24922,
+ 24923,
+ 24924,
+ 24925,
+ 24926
+]
\ No newline at end of file
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/scale.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/scale.npy
new file mode 100644
index 0000000000000000000000000000000000000000..0a97f6b85494860512e37fb90dd47a8fa1f8a789
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/scale.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:1341dfba85e04a8a7bbbc37f743f425a19dd6b2bc436329197fe93581fbe41c9
+size 144
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/subject_model.pth b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/subject_model.pth
new file mode 100644
index 0000000000000000000000000000000000000000..88f2eeb3231de3af1b947cd1327338e5b5cf5251
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/subject_model.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:e507b62594fe1d7cebbabf653d559acb9e9a72f9d31b57ea53721bb52e26d228
+size 1524384769
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/test_data.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/test_data.npy
new file mode 100644
index 0000000000000000000000000000000000000000..a88a0a442f3ec0b76407a221013de0a50c4b1bbd
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/test_data.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d5b836191dbb4c7a6ed3e9a762a859a9bd3f4ec6eefc9f5fb31adcc2bea76d88
+size 3873920
diff --git a/saved_models/codesearch_contrastive_learning/Model/Epoch_2/train_data.npy b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/train_data.npy
new file mode 100644
index 0000000000000000000000000000000000000000..26b6b061552ae13db2f7741411aed71c8c981de8
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/Epoch_2/train_data.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:15a96c83f0154fe93e57987c99b3ad060558e85bb33bcd347cf195c1280cd6bd
+size 76575872
diff --git a/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-37.pyc b/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-37.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..f096ed0b5e947cd2c9970c688e17f68fccc90bab
Binary files /dev/null and b/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-37.pyc differ
diff --git a/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-38.pyc b/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-38.pyc
new file mode 100644
index 0000000000000000000000000000000000000000..b72939719c5b1c1c1f02fc1ed611f7bfaafed510
Binary files /dev/null and b/saved_models/codesearch_contrastive_learning/Model/__pycache__/model.cpython-38.pyc differ
diff --git a/saved_models/codesearch_contrastive_learning/Model/model-cs.py b/saved_models/codesearch_contrastive_learning/Model/model-cs.py
new file mode 100644
index 0000000000000000000000000000000000000000..35390f646d7170a534761e4835a67fe9b341ff13
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/model-cs.py
@@ -0,0 +1,396 @@
+import torch
+import torch.nn as nn
+from prettytable import PrettyTable
+from torch.nn.modules.activation import Tanh
+import copy
+import logging
+logger = logging.getLogger(__name__)
+from transformers import (WEIGHTS_NAME, AdamW, get_linear_schedule_with_warmup,
+ RobertaConfig, RobertaModel, RobertaTokenizer)
+def whitening_torch_final(embeddings):
+ mu = torch.mean(embeddings, dim=0, keepdim=True)
+ cov = torch.mm((embeddings - mu).t(), embeddings - mu)
+ u, s, vt = torch.svd(cov)
+ W = torch.mm(u, torch.diag(1/torch.sqrt(s)))
+ embeddings = torch.mm(embeddings - mu, W)
+ return embeddings
+
+class BaseModel(nn.Module):
+ def __init__(self, ):
+ super().__init__()
+
+ def model_parameters(self):
+ table = PrettyTable()
+ table.field_names = ["Layer Name", "Output Shape", "Param #"]
+ table.align["Layer Name"] = "l"
+ table.align["Output Shape"] = "r"
+ table.align["Param #"] = "r"
+ for name, parameters in self.named_parameters():
+ if parameters.requires_grad:
+ table.add_row([name, str(list(parameters.shape)), parameters.numel()])
+ return table
+class Model(BaseModel):
+ def __init__(self, encoder):
+ super(Model, self).__init__()
+ self.encoder = encoder
+
+ def forward(self, code_inputs=None, nl_inputs=None):
+ # code_inputs [bs, seq]
+ if code_inputs is not None:
+ outputs = self.encoder(code_inputs,attention_mask=code_inputs.ne(1))[0] #[bs, seq_len, dim]
+ outputs = (outputs*code_inputs.ne(1)[:,:,None]).sum(1)/code_inputs.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ return torch.nn.functional.normalize(outputs, p=2, dim=1)
+ else:
+ outputs = self.encoder(nl_inputs,attention_mask=nl_inputs.ne(1))[0]
+ outputs = (outputs*nl_inputs.ne(1)[:,:,None]).sum(1)/nl_inputs.ne(1).sum(-1)[:,None]
+ return torch.nn.functional.normalize(outputs, p=2, dim=1)
+
+
+class Multi_Loss_CoCoSoDa( BaseModel):
+
+ def __init__(self, base_encoder, args, mlp=False):
+ super(Multi_Loss_CoCoSoDa, self).__init__()
+
+ self.K = args.moco_k
+ self.m = args.moco_m
+ self.T = args.moco_t
+ dim= args.moco_dim
+
+ # create the encoders
+ # num_classes is the output fc dimension
+ self.code_encoder_q = base_encoder
+ self.code_encoder_k = copy.deepcopy(base_encoder)
+ self.nl_encoder_q = base_encoder
+ # self.nl_encoder_q = RobertaModel.from_pretrained("roberta-base")
+ self.nl_encoder_k = copy.deepcopy(self.nl_encoder_q)
+ self.mlp = mlp
+ self.time_score= args.time_score
+ self.do_whitening = args.do_whitening
+ self.do_ineer_loss = args.do_ineer_loss
+ self.agg_way = args.agg_way
+ self.args = args
+
+ for param_q, param_k in zip(self.code_encoder_q.parameters(), self.code_encoder_k.parameters()):
+ param_k.data.copy_(param_q.data) # initialize
+ param_k.requires_grad = False # not update by gradient
+
+ for param_q, param_k in zip(self.nl_encoder_q.parameters(), self.nl_encoder_k.parameters()):
+ param_k.data.copy_(param_q.data) # initialize
+ param_k.requires_grad = False # not update by gradient
+
+ # create the code queue
+ torch.manual_seed(3047)
+ torch.cuda.manual_seed(3047)
+ self.register_buffer("code_queue", torch.randn(dim,self.K ))
+ self.code_queue = nn.functional.normalize(self.code_queue, dim=0)
+ self.register_buffer("code_queue_ptr", torch.zeros(1, dtype=torch.long))
+ # create the masked code queue
+ self.register_buffer("masked_code_queue", torch.randn(dim, self.K ))
+ self.masked_code_queue = nn.functional.normalize(self.masked_code_queue, dim=0)
+ self.register_buffer("masked_code_queue_ptr", torch.zeros(1, dtype=torch.long))
+
+
+ # create the nl queue
+ self.register_buffer("nl_queue", torch.randn(dim, self.K ))
+ self.nl_queue = nn.functional.normalize(self.nl_queue, dim=0)
+ self.register_buffer("nl_queue_ptr", torch.zeros(1, dtype=torch.long))
+ # create the masked nl queue
+ self.register_buffer("masked_nl_queue", torch.randn(dim, self.K ))
+ self.masked_nl_queue= nn.functional.normalize(self.masked_nl_queue, dim=0)
+ self.register_buffer("masked_nl_queue_ptr", torch.zeros(1, dtype=torch.long))
+
+
+
+
+ @torch.no_grad()
+ def _momentum_update_key_encoder(self):
+ """
+ Momentum update of the key encoder
+ % key encoder的Momentum update
+ """
+ for param_q, param_k in zip(self.code_encoder_q.parameters(), self.code_encoder_k.parameters()):
+ param_k.data = param_k.data * self.m + param_q.data * (1. - self.m)
+ for param_q, param_k in zip(self.nl_encoder_q.parameters(), self.nl_encoder_k.parameters()):
+ param_k.data = param_k.data * self.m + param_q.data * (1. - self.m)
+ if self.mlp:
+ for param_q, param_k in zip(self.code_encoder_q_fc.parameters(), self.code_encoder_k_fc.parameters()):
+ param_k.data = param_k.data * self.m + param_q.data * (1. - self.m)
+ for param_q, param_k in zip(self.nl_encoder_q_fc.parameters(), self.nl_encoder_k_fc.parameters()):
+ param_k.data = param_k.data * self.m + param_q.data * (1. - self.m)
+
+ @torch.no_grad()
+ def _dequeue_and_enqueue(self, keys, option='code'):
+ # gather keys before updating queue
+ # keys = concat_all_gather(keys)
+
+ batch_size = keys.shape[0]
+ if option == 'code':
+ code_ptr = int(self.code_queue_ptr)
+ assert self.K % batch_size == 0 # for simplicity
+
+ # replace the keys at ptr (dequeue and enqueue)
+ try:
+ self.code_queue[:, code_ptr:code_ptr + batch_size] = keys.T
+ except:
+ print(code_ptr)
+ print(batch_size)
+ print(keys.shape)
+ exit(111)
+ code_ptr = (code_ptr + batch_size) % self.K # move pointer ptr->pointer
+
+ self.code_queue_ptr[0] = code_ptr
+
+ elif option == 'masked_code':
+ masked_code_ptr = int(self.masked_code_queue_ptr)
+ assert self.K % batch_size == 0 # for simplicity
+
+ # replace the keys at ptr (dequeue and enqueue)
+ try:
+ self.masked_code_queue[:, masked_code_ptr:masked_code_ptr + batch_size] = keys.T
+ except:
+ print(masked_code_ptr)
+ print(batch_size)
+ print(keys.shape)
+ exit(111)
+ masked_code_ptr = (masked_code_ptr + batch_size) % self.K # move pointer ptr->pointer
+
+ self.masked_code_queue_ptr[0] = masked_code_ptr
+
+ elif option == 'nl':
+
+ nl_ptr = int(self.nl_queue_ptr)
+ assert self.K % batch_size == 0 # for simplicity
+
+ # replace the keys at ptr (dequeue and enqueue)
+ self.nl_queue[:, nl_ptr:nl_ptr + batch_size] = keys.T
+ nl_ptr = (nl_ptr + batch_size) % self.K # move pointer ptr->pointer
+
+ self.nl_queue_ptr[0] = nl_ptr
+ elif option == 'masked_nl':
+
+ masked_nl_ptr = int(self.masked_nl_queue_ptr)
+ assert self.K % batch_size == 0 # for simplicity
+
+ # replace the keys at ptr (dequeue and enqueue)
+ self.masked_nl_queue[:, masked_nl_ptr:masked_nl_ptr + batch_size] = keys.T
+ masked_nl_ptr = (masked_nl_ptr + batch_size) % self.K # move pointer ptr->pointer
+
+ self.masked_nl_queue_ptr[0] = masked_nl_ptr
+
+
+
+ def forward(self, source_code_q, source_code_k, nl_q,nl_k):
+ """
+ Input:
+ im_q: a batch of query images
+ im_k: a batch of key images
+ Output:
+ logits, targets
+ """
+ if not self.args.do_multi_lang_continue_pre_train:
+ # logger.info(".do_multi_lang_continue_pre_train")
+ outputs = self.code_encoder_q(source_code_q, attention_mask=source_code_q.ne(1))[0]
+ code_q = (outputs*source_code_q.ne(1)[:,:,None]).sum(1)/source_code_q.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ code_q = torch.nn.functional.normalize(code_q, p=2, dim=1)
+ # compute query features for nl
+ outputs= self.nl_encoder_q(nl_q, attention_mask=nl_q.ne(1))[0] # queries: NxC bs*feature_dim
+ nl_q = (outputs*nl_q.ne(1)[:,:,None]).sum(1)/nl_q.ne(1).sum(-1)[:,None]
+ nl_q = torch.nn.functional.normalize(nl_q, p=2, dim=1)
+ code2nl_logits = torch.einsum("ab,cb->ac", code_q,nl_q )
+ # loss = self.loss_fct(scores*20, torch.arange(code_inputs.size(0), device=scores.device))
+ code2nl_logits /= self.T
+ # label
+ code2nl_label = torch.arange(code2nl_logits.size(0), device=code2nl_logits.device)
+ return code2nl_logits,code2nl_label, None, None
+ if self.agg_way == "avg":
+ # compute query features for source code
+ outputs = self.code_encoder_q(source_code_q, attention_mask=source_code_q.ne(1))[0]
+ code_q = (outputs*source_code_q.ne(1)[:,:,None]).sum(1)/source_code_q.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ code_q = torch.nn.functional.normalize(code_q, p=2, dim=1)
+ # compute query features for nl
+ outputs= self.nl_encoder_q(nl_q, attention_mask=nl_q.ne(1))[0] # queries: NxC bs*feature_dim
+ nl_q = (outputs*nl_q.ne(1)[:,:,None]).sum(1)/nl_q.ne(1).sum(-1)[:,None]
+ nl_q = torch.nn.functional.normalize(nl_q, p=2, dim=1)
+
+ # compute key features
+ with torch.no_grad(): # no gradient to keys
+ self._momentum_update_key_encoder() # update the key encoder
+
+ # shuffle for making use of BN
+ # im_k, idx_unshuffle = self._batch_shuffle_ddp(im_k)
+
+ # masked code
+ outputs = self.code_encoder_k(source_code_k, attention_mask=source_code_k.ne(1))[0] # keys: NxC
+ code_k = (outputs*source_code_k.ne(1)[:,:,None]).sum(1)/source_code_k.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ code_k = torch.nn.functional.normalize( code_k, p=2, dim=1)
+ # masked nl
+ outputs = self.nl_encoder_k(nl_k, attention_mask=nl_k.ne(1))[0] # keys: bs*dim
+ nl_k = (outputs*nl_k.ne(1)[:,:,None]).sum(1)/nl_k.ne(1).sum(-1)[:,None]
+ nl_k = torch.nn.functional.normalize(nl_k, p=2, dim=1)
+
+ elif self.agg_way == "cls_pooler":
+ # logger.info(self.agg_way )
+ # compute query features for source code
+ outputs = self.code_encoder_q(source_code_q, attention_mask=source_code_q.ne(1))[1]
+ code_q = torch.nn.functional.normalize(code_q, p=2, dim=1)
+ # compute query features for nl
+ outputs= self.nl_encoder_q(nl_q, attention_mask=nl_q.ne(1))[1] # queries: NxC bs*feature_dim
+ nl_q = torch.nn.functional.normalize(nl_q, p=2, dim=1)
+
+ # compute key features
+ with torch.no_grad(): # no gradient to keys
+ self._momentum_update_key_encoder() # update the key encoder
+
+ # shuffle for making use of BN
+ # im_k, idx_unshuffle = self._batch_shuffle_ddp(im_k)
+
+ # masked code
+ outputs = self.code_encoder_k(source_code_k, attention_mask=source_code_k.ne(1))[1] # keys: NxC
+ code_k = torch.nn.functional.normalize( code_k, p=2, dim=1)
+ # masked nl
+ outputs = self.nl_encoder_k(nl_k, attention_mask=nl_k.ne(1))[1] # keys: bs*dim
+ nl_k = torch.nn.functional.normalize(nl_k, p=2, dim=1)
+
+ elif self.agg_way == "avg_cls_pooler":
+ # logger.info(self.agg_way )
+ outputs = self.code_encoder_q(source_code_q, attention_mask=source_code_q.ne(1))
+ code_q_cls = outputs[1]
+ outputs = outputs[0]
+ code_q_avg = (outputs*source_code_q.ne(1)[:,:,None]).sum(1)/source_code_q.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ code_q = code_q_cls + code_q_avg
+ code_q = torch.nn.functional.normalize(code_q, p=2, dim=1)
+ # compute query features for nl
+ outputs= self.nl_encoder_q(nl_q, attention_mask=nl_q.ne(1))
+ nl_q_cls = outputs[1]
+ outputs= outputs[0] # queries: NxC bs*feature_dim
+ nl_q_avg = (outputs*nl_q.ne(1)[:,:,None]).sum(1)/nl_q.ne(1).sum(-1)[:,None]
+ nl_q = nl_q_avg + nl_q_cls
+ nl_q = torch.nn.functional.normalize(nl_q, p=2, dim=1)
+
+ # compute key features
+ with torch.no_grad(): # no gradient to keys
+ self._momentum_update_key_encoder() # update the key encoder
+
+ # shuffle for making use of BN
+ # im_k, idx_unshuffle = self._batch_shuffle_ddp(im_k)
+
+ # masked code
+
+ outputs = self.code_encoder_k(source_code_k, attention_mask=source_code_k.ne(1))
+ code_k_cls = outputs[1] # keys: NxC
+ outputs = outputs[0]
+ code_k_avg = (outputs*source_code_k.ne(1)[:,:,None]).sum(1)/source_code_k.ne(1).sum(-1)[:,None] # None作为ndarray或tensor的索引作用是增加维度,
+ code_k = code_k_cls + code_k_avg
+ code_k = torch.nn.functional.normalize( code_k, p=2, dim=1)
+ # masked nl
+ outputs = self.nl_encoder_k(nl_k, attention_mask=nl_k.ne(1))
+ nl_k_cls = outputs[1] # keys: bs*dim
+ outputs = outputs[0]
+ nl_k_avg = (outputs*nl_k.ne(1)[:,:,None]).sum(1)/nl_k.ne(1).sum(-1)[:,None]
+ nl_k = nl_k_cls + nl_k_avg
+ nl_k = torch.nn.functional.normalize(nl_k, p=2, dim=1)
+
+ # ## do_whitening
+ # if self.do_whitening:
+ # code_q = whitening_torch_final(code_q)
+ # code_k = whitening_torch_final(code_k)
+ # nl_q = whitening_torch_final(nl_q)
+ # nl_k = whitening_torch_final(nl_k)
+
+
+ ## code vs nl
+ code2nl_pos = torch.einsum('nc,bc->nb', [code_q, nl_q])
+ # negative logits: NxK
+ code2nl_neg = torch.einsum('nc,ck->nk', [code_q, self.nl_queue.clone().detach()])
+ # logits: Nx(n+K)
+ code2nl_logits = torch.cat([self.time_score*code2nl_pos, code2nl_neg], dim=1)
+ # apply temperature
+ code2nl_logits /= self.T
+ # label
+ code2nl_label = torch.arange(code2nl_logits.size(0), device=code2nl_logits.device)
+
+ ## code vs masked nl
+ code2maskednl_pos = torch.einsum('nc,bc->nb', [code_q, nl_k])
+ # negative logits: NxK
+ code2maskednl_neg = torch.einsum('nc,ck->nk', [code_q, self.masked_nl_queue.clone().detach()])
+ # logits: Nx(n+K)
+ code2maskednl_logits = torch.cat([self.time_score*code2maskednl_pos, code2maskednl_neg], dim=1)
+ # apply temperature
+ code2maskednl_logits /= self.T
+ # label
+ code2maskednl_label = torch.arange(code2maskednl_logits.size(0), device=code2maskednl_logits.device)
+
+ ## nl vs code
+ # nl2code_pos = torch.einsum('nc,nc->n', [nl_q, code_k]).unsqueeze(-1)
+ nl2code_pos = torch.einsum('nc,bc->nb', [nl_q, code_q])
+ # negative logits: bsxK
+ nl2code_neg = torch.einsum('nc,ck->nk', [nl_q, self.code_queue.clone().detach()])
+ # nl2code_logits: bsx(n+K)
+ nl2code_logits = torch.cat([self.time_score*nl2code_pos, nl2code_neg], dim=1)
+ # apply temperature
+ nl2code_logits /= self.T
+ # label
+ nl2code_label = torch.arange(nl2code_logits.size(0), device=nl2code_logits.device)
+
+ ## nl vs masked code
+ # nl2code_pos = torch.einsum('nc,nc->n', [nl_q, code_k]).unsqueeze(-1)
+ nl2maskedcode_pos = torch.einsum('nc,bc->nb', [nl_q, code_k])
+ # negative logits: bsxK
+ nl2maskedcode_neg = torch.einsum('nc,ck->nk', [nl_q, self.masked_code_queue.clone().detach()])
+ # nl2code_logits: bsx(n+K)
+ nl2maskedcode_logits = torch.cat([self.time_score*nl2maskedcode_pos, nl2maskedcode_neg], dim=1)
+ # apply temperature
+ nl2maskedcode_logits /= self.T
+ # label
+ nl2maskedcode_label = torch.arange(nl2maskedcode_logits.size(0), device=nl2maskedcode_logits.device)
+
+ #logit 4*bsx(1+K)
+ inter_logits = torch.cat((code2nl_logits, code2maskednl_logits, nl2code_logits ,nl2maskedcode_logits ), dim=0)
+
+ # labels: positive key indicators
+ # inter_labels = torch.zeros(inter_logits.shape[0], dtype=torch.long).cuda()
+ inter_labels = torch.cat((code2nl_label, code2maskednl_label, nl2code_label, nl2maskedcode_label), dim=0)
+
+ if self.do_ineer_loss:
+ # logger.info("do_ineer_loss")
+ ## code vs masked code
+ code2maskedcode_pos = torch.einsum('nc,bc->nb', [code_q, code_k])
+ # negative logits: NxK
+ code2maskedcode_neg = torch.einsum('nc,ck->nk', [code_q, self.masked_code_queue.clone().detach()])
+ # logits: Nx(n+K)
+ code2maskedcode_logits = torch.cat([self.time_score*code2maskedcode_pos, code2maskedcode_neg], dim=1)
+ # apply temperature
+ code2maskedcode_logits /= self.T
+ # label
+ code2maskedcode_label = torch.arange(code2maskedcode_logits.size(0), device=code2maskedcode_logits.device)
+
+
+ ## nl vs masked nl
+ # nl2code_pos = torch.einsum('nc,nc->n', [nl_q, code_k]).unsqueeze(-1)
+ nl2maskednl_pos = torch.einsum('nc,bc->nb', [nl_q, nl_k])
+ # negative logits: bsxK
+ nl2maskednl_neg = torch.einsum('nc,ck->nk', [nl_q, self.masked_nl_queue.clone().detach()])
+ # nl2code_logits: bsx(n+K)
+ nl2maskednl_logits = torch.cat([self.time_score*nl2maskednl_pos, nl2maskednl_neg], dim=1)
+ # apply temperature
+ nl2maskednl_logits /= self.T
+ # label
+ nl2maskednl_label = torch.arange(nl2maskednl_logits.size(0), device=nl2maskednl_logits.device)
+
+
+ #logit 6*bsx(1+K)
+ inter_logits = torch.cat((inter_logits, code2maskedcode_logits, nl2maskednl_logits), dim=0)
+
+ # labels: positive key indicators
+ # inter_labels = torch.zeros(inter_logits.shape[0], dtype=torch.long).cuda()
+ inter_labels = torch.cat(( inter_labels, code2maskedcode_label, nl2maskednl_label ), dim=0)
+
+
+ # dequeue and enqueue
+ self._dequeue_and_enqueue(code_q, option='code')
+ self._dequeue_and_enqueue(nl_q, option='nl')
+ self._dequeue_and_enqueue(code_k, option='masked_code')
+ self._dequeue_and_enqueue(nl_k, option='masked_nl')
+
+ return inter_logits, inter_labels, code_q, nl_q
+
diff --git a/saved_models/codesearch_contrastive_learning/Model/model.py b/saved_models/codesearch_contrastive_learning/Model/model.py
new file mode 100644
index 0000000000000000000000000000000000000000..14565d0ce1b9bd2b0c71fd93760a68307e205a3c
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/model.py
@@ -0,0 +1,453 @@
+import torch
+import torch.nn as nn
+import os
+
+
+__all__ = [
+ "ResNet",
+ "resnet18_with_dropout",
+ "resnet18",
+ "dropout_resnet18"
+]
+
+
+def conv3x3(in_planes, out_planes, stride=1, groups=1, dilation=1):
+ """3x3 convolution with padding"""
+ return nn.Conv2d(
+ in_planes,
+ out_planes,
+ kernel_size=3,
+ stride=stride,
+ padding=dilation,
+ groups=groups,
+ bias=False,
+ dilation=dilation,
+ )
+
+
+def conv1x1(in_planes, out_planes, stride=1):
+ """1x1 convolution"""
+ return nn.Conv2d(in_planes, out_planes, kernel_size=1, stride=stride, bias=False)
+
+class BasicBlock(nn.Module):
+ expansion = 1
+
+ def __init__(
+ self,
+ inplanes,
+ planes,
+ stride=1,
+ downsample=None,
+ groups=1,
+ base_width=64,
+ dilation=1,
+ norm_layer=None,
+ ):
+ super(BasicBlock, self).__init__()
+ if norm_layer is None:
+ norm_layer = nn.BatchNorm2d
+ if groups != 1 or base_width != 64:
+ raise ValueError("BasicBlock only supports groups=1 and base_width=64")
+ if dilation > 1:
+ raise NotImplementedError("Dilation > 1 not supported in BasicBlock")
+ # Both self.conv1 and self.downsample layers downsample the input when stride != 1
+ self.conv1 = conv3x3(inplanes, planes, stride)
+ self.bn1 = norm_layer(planes)
+ self.relu = nn.ReLU(inplace=True)
+ self.conv2 = conv3x3(planes, planes)
+ self.bn2 = norm_layer(planes)
+ self.downsample = downsample
+ self.stride = stride
+
+
+ def forward(self, x):
+ identity = x
+
+ out = self.conv1(x)
+ out = self.bn1(out)
+ out = self.relu(out)
+
+ out = self.conv2(out)
+ out = self.bn2(out)
+
+ if self.downsample is not None:
+ identity = self.downsample(x)
+
+ out += identity
+ out = self.relu(out)
+
+ return out
+
+class BasicBlock_withDropout(nn.Module):
+ expansion = 1
+
+ def __init__(
+ self,
+ inplanes,
+ planes,
+ stride=1,
+ downsample=None,
+ groups=1,
+ base_width=64,
+ dilation=1,
+ norm_layer=None,
+ ):
+ super(BasicBlock_withDropout, self).__init__()
+ if norm_layer is None:
+ norm_layer = nn.BatchNorm2d
+ if groups != 1 or base_width != 64:
+ raise ValueError("BasicBlock only supports groups=1 and base_width=64")
+ if dilation > 1:
+ raise NotImplementedError("Dilation > 1 not supported in BasicBlock")
+ # Both self.conv1 and self.downsample layers downsample the input when stride != 1
+ self.dropout = nn.Dropout(p=0.5)
+ self.conv1 = conv3x3(inplanes, planes, stride)
+ self.bn1 = norm_layer(planes)
+ self.relu = nn.ReLU(inplace=True)
+ self.conv2 = conv3x3(planes, planes)
+ self.bn2 = norm_layer(planes)
+ self.downsample = downsample
+ self.stride = stride
+ # print('with_dropout',self.with_dropout)
+
+ def forward(self, x):
+ identity = x
+
+ out = self.conv1(x)
+ out = self.bn1(out)
+ out = self.relu(out)
+
+
+ out = self.conv2(out)
+ out = self.bn2(out)
+
+ if self.downsample is not None:
+ identity = self.downsample(x)
+
+ out += identity
+ out = self.relu(out)
+
+ return out
+
+
+class Bottleneck(nn.Module):
+ expansion = 4
+
+ def __init__(
+ self,
+ inplanes,
+ planes,
+ stride=1,
+ downsample=None,
+ groups=1,
+ base_width=64,
+ dilation=1,
+ norm_layer=None,
+ ):
+ super(Bottleneck, self).__init__()
+ if norm_layer is None:
+ norm_layer = nn.BatchNorm2d
+ width = int(planes * (base_width / 64.0)) * groups
+ # Both self.conv2 and self.downsample layers downsample the input when stride != 1
+ self.conv1 = conv1x1(inplanes, width)
+ self.bn1 = norm_layer(width)
+ self.conv2 = conv3x3(width, width, stride, groups, dilation)
+ self.bn2 = norm_layer(width)
+ self.conv3 = conv1x1(width, planes * self.expansion)
+ self.bn3 = norm_layer(planes * self.expansion)
+ self.relu = nn.ReLU(inplace=True)
+ self.downsample = downsample
+ self.stride = stride
+
+ def forward(self, x):
+ identity = x
+
+ out = self.conv1(x)
+ out = self.bn1(out)
+ out = self.relu(out)
+
+ out = self.conv2(out)
+ out = self.bn2(out)
+ out = self.relu(out)
+
+ out = self.conv3(out)
+ out = self.bn3(out)
+
+ if self.downsample is not None:
+ identity = self.downsample(x)
+
+ out += identity
+ out = self.relu(out)
+
+ return out
+
+
+class ResNet(nn.Module):
+ def __init__(
+ self,
+ block,
+ layers,
+ with_dropout,
+ num_classes=10,
+ zero_init_residual=False,
+ groups=1,
+ width_per_group=64,
+ replace_stride_with_dilation=None,
+ norm_layer=None,
+
+ ):
+ super(ResNet, self).__init__()
+ if norm_layer is None:
+ norm_layer = nn.BatchNorm2d
+ self._norm_layer = norm_layer
+
+ self.inplanes = 64
+ self.dilation = 1
+ if replace_stride_with_dilation is None:
+ # each element in the tuple indicates if we should replace
+ # the 2x2 stride with a dilated convolution instead
+ replace_stride_with_dilation = [False, False, False]
+ if len(replace_stride_with_dilation) != 3:
+ raise ValueError(
+ "replace_stride_with_dilation should be None "
+ "or a 3-element tuple, got {}".format(replace_stride_with_dilation)
+ )
+
+ self.with_dropout = with_dropout
+ self.groups = groups
+ self.base_width = width_per_group
+
+ # CIFAR10: kernel_size 7 -> 3, stride 2 -> 1, padding 3->1
+ self.conv1 = nn.Conv2d(
+ 3, self.inplanes, kernel_size=3, stride=1, padding=1, bias=False
+ )
+ # END
+
+ self.bn1 = norm_layer(self.inplanes)
+ self.relu = nn.ReLU(inplace=True)
+
+ self.maxpool = nn.MaxPool2d(kernel_size=3, stride=2, padding=1)
+ self.layer1 = self._make_layer(block, 64, layers[0])
+ self.layer2 = self._make_layer(
+ block, 128, layers[1], stride=2, dilate=replace_stride_with_dilation[0]
+ )
+ self.layer3 = self._make_layer(
+ block, 256, layers[2], stride=2, dilate=replace_stride_with_dilation[1]
+ )
+ self.layer4 = self._make_layer(
+ block, 512, layers[3], stride=2, dilate=replace_stride_with_dilation[2]
+ )
+ self.avgpool = nn.AdaptiveAvgPool2d((1, 1))
+ self.fc = nn.Linear(512 * block.expansion, num_classes)
+
+ if self.with_dropout:
+ self.fc = nn.Sequential(nn.Flatten(),nn.Dropout(0.5),nn.Linear(512 * block.expansion, num_classes))
+
+
+
+ for m in self.modules():
+ if isinstance(m, nn.Conv2d):
+ nn.init.kaiming_normal_(m.weight, mode="fan_out", nonlinearity="relu")
+ elif isinstance(m, (nn.BatchNorm2d, nn.GroupNorm)):
+ nn.init.constant_(m.weight, 1)
+ nn.init.constant_(m.bias, 0)
+
+ # Zero-initialize the last BN in each residual branch,
+ # so that the residual branch starts with zeros, and each residual block behaves like an identity.
+ # This improves the model by 0.2~0.3% according to https://arxiv.org/abs/1706.02677
+ if zero_init_residual:
+ for m in self.modules():
+ if isinstance(m, Bottleneck):
+ nn.init.constant_(m.bn3.weight, 0)
+ elif isinstance(m, BasicBlock):
+ nn.init.constant_(m.bn2.weight, 0)
+
+ def _make_layer(self, block, planes, blocks, stride=1, dilate=False):
+ norm_layer = self._norm_layer
+ downsample = None
+ previous_dilation = self.dilation
+ if dilate:
+ self.dilation *= stride
+ stride = 1
+ if stride != 1 or self.inplanes != planes * block.expansion:
+ downsample = nn.Sequential(
+ conv1x1(self.inplanes, planes * block.expansion, stride),
+ norm_layer(planes * block.expansion),
+ )
+
+ layers = []
+ layers.append(
+ block(
+ self.inplanes,
+ planes,
+ stride,
+ downsample,
+ self.groups,
+ self.base_width,
+ previous_dilation,
+ norm_layer,
+ )
+ )
+ self.inplanes = planes * block.expansion
+ for _ in range(1, blocks):
+ layers.append(
+ block(
+ self.inplanes,
+ planes,
+ groups=self.groups,
+ base_width=self.base_width,
+ dilation=self.dilation,
+ norm_layer=norm_layer,
+ )
+ )
+
+ return nn.Sequential(*layers)
+
+ def forward(self, x):
+ x = self.conv1(x)
+ x = self.bn1(x)
+ x = self.relu(x)
+ x = self.maxpool(x)
+
+ x = self.layer1(x)
+
+ x = self.layer2(x)
+
+ x = self.layer3(x)
+
+ x = self.layer4(x)
+
+ x = self.avgpool(x)
+ x = x.reshape(x.size(0), -1)
+ x = self.fc(x)
+
+ return x
+
+ def feature(self, x):
+ x = self.conv1(x)
+ x = self.bn1(x)
+ x = self.relu(x)
+ x = self.maxpool(x)
+
+ x = self.layer1(x)
+ x = self.layer2(x)
+ x = self.layer3(x)
+ x = self.layer4(x)
+
+ x = self.avgpool(x)
+ x = x.reshape(x.size(0), -1)
+ return x
+ def prediction(self,x):
+ x = self.fc(x)
+
+ return x
+
+ # def gap(self, x):
+ # x = self.conv1(x)
+ # x = self.bn1(x)
+ # x = self.relu(x)
+ # x = self.maxpool(x)
+
+ # x = self.layer1(x)
+ # x = self.layer2(x)
+ # x = self.layer3(x)
+ # x = self.layer4(x)
+
+ # x = self.avgpool(x)
+ # x = x.reshape(x.size(0), -1)
+ # return x
+
+
+def _resnet(arch, block, layers, pretrained, progress, device, with_dropout, **kwargs):
+ model = ResNet(block, layers, with_dropout, **kwargs)
+ if pretrained:
+ script_dir = os.path.dirname(__file__)
+ state_dict = torch.load(
+ script_dir + "/state_dicts/" + arch + ".pt", map_location=device
+ )
+ model.load_state_dict(state_dict)
+ return model
+
+
+def resnet18_with_dropout(pretrained=False, progress=True, device="cpu", **kwargs):
+ """Constructs a ResNet-18 model.
+ Args:
+ pretrained (bool): If True, returns a model pre-trained on ImageNet
+ progress (bool): If True, displays a progress bar of the download to stderr
+ """
+ return _resnet(
+ "resnet18", BasicBlock_withDropout, [2, 2, 2, 2], pretrained, progress, device, with_dropout = True, **kwargs
+ )
+
+def resnet18(pretrained=False, progress=True, device="cpu", **kwargs):
+ """Constructs a ResNet-18 model.
+ Args:
+ pretrained (bool): If True, returns a model pre-trained on ImageNet
+ progress (bool): If True, displays a progress bar of the download to stderr
+ """
+ return _resnet(
+ "resnet18", BasicBlock, [2, 2, 2, 2], pretrained, progress, device, with_dropout = False, **kwargs
+ )
+
+
+def resnet34(pretrained=False, progress=True, device="cpu", **kwargs):
+ """Constructs a ResNet-34 model.
+ Args:
+ pretrained (bool): If True, returns a model pre-trained on ImageNet
+ progress (bool): If True, displays a progress bar of the download to stderr
+ """
+ return _resnet(
+ "resnet34", BasicBlock, [3, 4, 6, 3], pretrained, progress, device, **kwargs
+ )
+
+
+def resnet50(pretrained=False, progress=True, device="cpu", **kwargs):
+ """Constructs a ResNet-50 model.
+ Args:
+ pretrained (bool): If True, returns a model pre-trained on ImageNet
+ progress (bool): If True, displays a progress bar of the download to stderr
+ """
+ return _resnet(
+ "resnet50", Bottleneck, [3, 4, 6, 3], pretrained, progress, device, **kwargs
+ )
+
+# class dropout_residual(nn.Module):
+# def __init__(self, input_channels, num_channels, dropout_rate, dropout_type, init_dict, use_1x1conv=False, strides=1, **kwargs):
+# super().__init__(**kwargs)
+# self.conv1 = Dropout_Conv2D(input_channels, num_channels, kernel_size=3, padding=1, stride=strides, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict)
+# self.conv2 = Dropout_Conv2D(num_channels, num_channels, kernel_size=3, padding=1, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict)
+
+# if use_1x1conv:
+# self.conv3 = Dropout_Conv2D(input_channels, num_channels, kernel_size=1, stride=strides, dropout_rate=dropout_rate, dropout_type=dropout_type)
+# else:
+# self.conv3 = None
+
+# self.bn1 = nn.BatchNorm2d(num_channels)
+# self.bn2 = nn.BatchNorm2d(num_channels)
+
+# def dropout_resnet_block(input_channels, num_channels, num_residuals, dropout_rate, dropout_type, init_dict, first_block=False):
+# blk = []
+# for i in range(num_residuals):
+# if i == 0 and not first_block:
+# blk.append(dropout_residual(input_channels, num_channels, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict, use_1x1conv=True, strides=2))
+# else:
+# blk.append(dropout_residual(num_channels, num_channels, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict))
+# return blk
+
+# def dropout_resnet18(dropout_rate=0.5, dropout_type="w", init_dict=dict()):
+# b1 = nn.Sequential(
+# Dropout_Conv2D(1, 64, kernel_size=7, stride=2, padding=3, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict),
+# nn.BatchNorm2d(64),
+# nn.ReLU(),
+# nn.MaxPool2d(kernel_size=3, stride=2, padding=1)
+# )
+# b2 = nn.Sequential(*dropout_resnet_block(64, 64, 2, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict, first_block=True))
+# b3 = nn.Sequential(*dropout_resnet_block(64, 128, 2, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict))
+# b4 = nn.Sequential(*dropout_resnet_block(128, 256, 2, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict))
+# b5 = nn.Sequential(*dropout_resnet_block(256, 512, 2, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict))
+
+# return nn.Sequential(b1, b2, b3, b4, b5,
+# nn.AdaptiveAvgPool2d((1,1)),
+# nn.Flatten(),
+# Dropout_Linear(512, 20, dropout_rate=dropout_rate, dropout_type=dropout_type, init_dict=init_dict))
+
diff --git a/saved_models/codesearch_contrastive_learning/Model/time_base_dvi.json b/saved_models/codesearch_contrastive_learning/Model/time_base_dvi.json
new file mode 100644
index 0000000000000000000000000000000000000000..973b64fc74936280196b4681586548c2146811d8
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Model/time_base_dvi.json
@@ -0,0 +1 @@
+{"complex_construction": {"1": 11.107, "2": 11.239}, "training": {"1": 210.918, "2": 216.733}}
\ No newline at end of file
diff --git a/saved_models/codesearch_contrastive_learning/Testing_data/testing_dataset_label.pth b/saved_models/codesearch_contrastive_learning/Testing_data/testing_dataset_label.pth
new file mode 100644
index 0000000000000000000000000000000000000000..42dbe8b332af00df31ef2011dbb48563d25d6c80
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Testing_data/testing_dataset_label.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d4d5db38fa60eca28dbc4c1b14f5833385f954d95f46536e3c30212004bb1f73
+size 2955
diff --git a/saved_models/codesearch_contrastive_learning/Training_data/training_dataset_label.pth b/saved_models/codesearch_contrastive_learning/Training_data/training_dataset_label.pth
new file mode 100644
index 0000000000000000000000000000000000000000..e791d9fcd97ecd471499d40dc73c7586c6d90290
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/Training_data/training_dataset_label.pth
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:8821e7f4b0cec0c3d59d148845a4bd1e0f4f0be576e3da2d1bc97fb74a663eea
+size 50445
diff --git a/saved_models/codesearch_contrastive_learning/config.json b/saved_models/codesearch_contrastive_learning/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..3887c109e8f6f0588774b2f2f00a4ccffeb6acd3
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/config.json
@@ -0,0 +1,101 @@
+{
+ "SETTING": "normal",
+ "CLASSES": ["plane", "car", "bird", "cat", "deer", "dog", "frog", "horse", "ship", "truck"],
+ "DATASET": "cifar10",
+ "EPOCH_START": 1,
+ "EPOCH_END": 200,
+ "EPOCH_PERIOD": 1,
+ "GPU":0,
+ "TRAINING": {
+ "NET": "resnet18",
+ "loader_tr_args": {"batch_size": 128, "num_workers": 1},
+ "loader_te_args": {"batch_size": 1000, "num_workers": 1},
+ "optimizer_args": {"lr": 0.1, "momentum": 0.9, "weight_decay": 5e-4},
+ "num_class": 10,
+ "train_num": 50000,
+ "test_num": 10000,
+ "milestone":[160]
+ },
+ "VISUALIZATION":{
+
+ "S_LAMBDA":1,
+ "PREPROCESS":0,
+ "BOUNDARY":{
+ "B_N_EPOCHS": 0,
+ "L_BOUND":0.6
+ },
+ "INIT_NUM":300,
+
+ "ALPHA":0,
+ "BETA":0.1,
+ "MAX_HAUSDORFF":0.4,
+
+ "LAMBDA": 10.0,
+ "HIDDEN_LAYER":4,
+ "ENCODER_DIMS": [512,256,256,256,256,2],
+ "DECODER_DIMS": [2,256,256,256,256,512],
+ "N_NEIGHBORS":15,
+ "MAX_EPOCH": 20,
+ "S_N_EPOCHS": 5,
+ "T_N_EPOCHS": 100,
+ "PATIENT": 3,
+ "RESOLUTION":300,
+ "VIS_MODEL_NAME": "vis",
+ "EVALUATION_NAME": "evalution"
+ },
+ "DVI": {
+ "SETTING": "normal",
+ "CLASSES": ["0"],
+ "DATASET": "cifar10",
+ "GPU": "0",
+ "EPOCH_START": 1,
+ "EPOCH_END": 2,
+ "EPOCH_PERIOD": 1,
+ "EPOCH_NAME":"Epoch",
+ "TRAINING": {
+ "NET": "resnet18",
+ "loader_tr_args": {
+ "batch_size": 128,
+ "num_workers": 1
+ },
+ "loader_te_args": {
+ "batch_size": 1000,
+ "num_workers": 1
+ },
+ "optimizer_args": {
+ "lr": 0.1,
+ "momentum": 0.9,
+ "weight_decay": 0.0005
+ },
+ "num_class": 1,
+ "train_num": 24927,
+ "test_num": 1261,
+ "milestone": [
+ 10
+ ]
+ },
+ "VISUALIZATION": {
+ "PREPROCESS": 1,
+ "BOUNDARY": {
+ "B_N_EPOCHS": 0,
+ "L_BOUND": 0.4
+ },
+ "BATCH_SIZE":1000,
+ "LAMBDA1": 5.0,
+ "LAMBDA2": 0.3,
+
+ "ENCODER_DIMS_O": [128,64,64,64,64,2],
+ "DECODER_DIMS_O": [2,64,64,64,64,128],
+ "ENCODER_DIMS": [768,256,256,256,256,2],
+ "DECODER_DIMS": [2,256,256,256,256,768],
+ "N_NEIGHBORS": 15,
+ "MAX_EPOCH": 20,
+ "S_N_EPOCHS": 10,
+ "PATIENT": 3,
+ "RESOLUTION": 300,
+ "VIS_MODEL_NAME": "dvi",
+ "FLAG": "_temporal_id_withoutB",
+ "EVALUATION_NAME": "evaluation_tfDVI"
+ }
+ }
+}
diff --git a/saved_models/codesearch_contrastive_learning/config_dvi_modi.json b/saved_models/codesearch_contrastive_learning/config_dvi_modi.json
new file mode 100644
index 0000000000000000000000000000000000000000..54e2688428eb1a53e94fc558dc6cc07d3b4bfb40
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/config_dvi_modi.json
@@ -0,0 +1,55 @@
+{
+ "SETTING": "normal",
+ "CLASSES": [
+ "0"
+ ],
+ "GPU": "0",
+ "DATASET": "cifar10",
+ "EPOCH_START": 1,
+ "EPOCH_END": 1,
+ "EPOCH_PERIOD": 1,
+ "TRAINING": {
+ "NET": "resnet18",
+ "num_class": 1,
+ "train_num": 24927,
+ "test_num": 1261
+ },
+ "VISUALIZATION": {
+ "PREPROCESS": 1,
+ "BOUNDARY": {
+ "B_N_EPOCHS": 0,
+ "L_BOUND": 0.5
+ },
+ "INIT_NUM": 300,
+ "ALPHA": 1,
+ "BETA": 1,
+ "MAX_HAUSDORFF": 0.33,
+ "LAMBDA1": 1,
+ "LAMBDA2": 0.3,
+ "S_LAMBDA": 1,
+ "ENCODER_DIMS": [
+ 768,
+ 256,
+ 256,
+ 256,
+ 256,
+ 2
+ ],
+ "DECODER_DIMS": [
+ 2,
+ 256,
+ 256,
+ 256,
+ 256,
+ 768
+ ],
+ "N_NEIGHBORS": 15,
+ "MAX_EPOCH": 200,
+ "S_N_EPOCHS": 5,
+ "T_N_EPOCHS": 20,
+ "PATIENT": 3,
+ "RESOLUTION": 300,
+ "VIS_MODEL_NAME": "dvi",
+ "EVALUATION_NAME": "test_evaluation_dvi"
+ }
+}
\ No newline at end of file
diff --git a/saved_models/codesearch_contrastive_learning/iteration_structure.json b/saved_models/codesearch_contrastive_learning/iteration_structure.json
new file mode 100644
index 0000000000000000000000000000000000000000..b7cb43991b0f115afcb0c6b6d2137350176d040c
--- /dev/null
+++ b/saved_models/codesearch_contrastive_learning/iteration_structure.json
@@ -0,0 +1,12 @@
+[
+ {
+ "value": 1,
+ "name": "code",
+ "pid": ""
+ },
+ {
+ "value": 2,
+ "name": "query",
+ "pid": 1
+ }
+]
\ No newline at end of file
diff --git a/saved_models/fine_tune/Ruby/running.log b/saved_models/fine_tune/Ruby/running.log
new file mode 100644
index 0000000000000000000000000000000000000000..c1c434c4eea995be1c0277c84364540bf367aba4
--- /dev/null
+++ b/saved_models/fine_tune/Ruby/running.log
@@ -0,0 +1,215 @@
+02/17/2024 13:45:08 - INFO - __main__ - device: cuda, n_gpu: 1
+02/17/2024 13:45:12 - INFO - __main__ - +------------------------------------------------------------+--------------+----------+
+| Layer Name | Output Shape | Param # |
++------------------------------------------------------------+--------------+----------+
+| encoder.embeddings.word_embeddings.weight | [51451, 768] | 39514368 |
+| encoder.embeddings.position_embeddings.weight | [1026, 768] | 787968 |
+| encoder.embeddings.token_type_embeddings.weight | [10, 768] | 7680 |
+| encoder.embeddings.LayerNorm.weight | [768] | 768 |
+| encoder.embeddings.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.0.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.0.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.0.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.0.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.0.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.0.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.1.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.1.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.1.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.1.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.1.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.1.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.2.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.2.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.2.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.2.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.2.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.2.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.3.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.3.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.3.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.3.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.3.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.3.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.4.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.4.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.4.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.4.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.4.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.4.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.5.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.5.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.5.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.5.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.5.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.5.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.6.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.6.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.6.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.6.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.6.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.6.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.7.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.7.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.7.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.7.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.7.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.7.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.8.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.8.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.8.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.8.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.8.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.8.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.9.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.9.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.9.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.9.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.9.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.9.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.10.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.10.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.10.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.10.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.10.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.10.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.11.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.11.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.11.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.11.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.11.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.11.output.LayerNorm.bias | [768] | 768 |
+| encoder.pooler.dense.weight | [768, 768] | 589824 |
+| encoder.pooler.dense.bias | [768] | 768 |
++------------------------------------------------------------+--------------+----------+
+02/17/2024 13:45:12 - INFO - __main__ - Training/evaluation parameters Namespace(agg_way='avg', aug_type_way='random_replace_type', code_length=256, codebase_file='dataset/Ruby/codebase.jsonl', config_name='DeepSoftwareAnalytics/CoCoSoDa', couninue_pre_train_data_files=['dataset/ruby/train.jsonl', 'dataset/java/train.jsonl'], data_aug_type='random_mask', data_flow_length=0, debug=False, device=device(type='cuda'), do_avg=False, do_continue_pre_trained=False, do_eval=False, do_fine_tune=False, do_ineer_loss=False, do_multi_lang_continue_pre_train=False, do_single_lang_continue_pre_train=False, do_test=True, do_train=True, do_whitening=False, do_zero_short=False, epoch=50, eval_batch_size=64, eval_data_file='dataset/Ruby/valid.jsonl', eval_frequency=100, fp16=False, gradient_accumulation_steps=1, hidden_size=768, lang='Ruby', learning_rate=2e-05, loaded_codebert_model_filename=None, loaded_model_filename=None, local_rank=-1, logging_steps=50, max_codeblock_num=10, max_grad_norm=1.0, max_steps=100, mlm_probability=0.1, mlp=False, moco_dim=768, moco_k=1024, moco_m=0.999, moco_t=0.07, moco_type='encoder_queue', model_name_or_path='DeepSoftwareAnalytics/CoCoSoDa', model_type='base', n_debug_samples=100, n_gpu=1, nl_length=128, num_train_epochs=5, num_warmup_steps=0, only_save_the_nl_code_vec=False, output_dir='./saved_models/fine_tune/Ruby', print_align_unif_loss=False, save_evaluation_reuslt=False, save_evaluation_reuslt_dir=None, save_steps=50, seed=123456, test_data_file='dataset/Ruby/test.jsonl', time_score=1, tokenizer_name='DeepSoftwareAnalytics/CoCoSoDa', train_batch_size=128, train_data_file='dataset/Ruby/train.jsonl', use_best_mrr_model=False, weight_decay=0.01)
+Traceback (most recent call last):
+ File "run.py", line 1188, in
+ main()
+ File "run.py", line 1154, in main
+ train(args, model, tokenizer, pool)
+ File "run.py", line 534, in train
+ train_dataset=TextDataset_unixcoder(tokenizer, args, args.train_data_file, pool)
+ File "run.py", line 393, in __init__
+ with open(file_path) as f:
+FileNotFoundError: [Errno 2] No such file or directory: 'dataset/Ruby/train.jsonl'
diff --git a/saved_models/fine_tune/java/running.log b/saved_models/fine_tune/java/running.log
new file mode 100644
index 0000000000000000000000000000000000000000..1ceeab815168a77c43e47dd5e998f37d41c1fca8
--- /dev/null
+++ b/saved_models/fine_tune/java/running.log
@@ -0,0 +1,268 @@
+02/17/2024 13:45:37 - INFO - __main__ - device: cuda, n_gpu: 1
+02/17/2024 13:45:41 - INFO - __main__ - +------------------------------------------------------------+--------------+----------+
+| Layer Name | Output Shape | Param # |
++------------------------------------------------------------+--------------+----------+
+| encoder.embeddings.word_embeddings.weight | [51451, 768] | 39514368 |
+| encoder.embeddings.position_embeddings.weight | [1026, 768] | 787968 |
+| encoder.embeddings.token_type_embeddings.weight | [10, 768] | 7680 |
+| encoder.embeddings.LayerNorm.weight | [768] | 768 |
+| encoder.embeddings.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.0.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.0.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.0.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.0.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.0.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.0.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.0.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.0.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.1.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.1.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.1.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.1.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.1.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.1.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.1.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.1.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.2.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.2.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.2.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.2.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.2.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.2.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.2.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.2.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.3.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.3.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.3.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.3.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.3.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.3.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.3.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.3.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.4.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.4.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.4.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.4.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.4.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.4.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.4.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.4.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.5.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.5.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.5.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.5.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.5.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.5.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.5.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.5.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.6.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.6.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.6.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.6.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.6.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.6.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.6.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.6.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.7.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.7.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.7.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.7.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.7.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.7.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.7.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.7.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.8.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.8.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.8.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.8.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.8.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.8.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.8.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.8.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.9.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.9.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.9.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.9.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.9.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.9.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.9.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.9.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.10.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.10.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.10.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.10.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.10.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.10.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.10.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.10.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.query.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.query.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.key.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.key.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.self.value.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.self.value.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.dense.weight | [768, 768] | 589824 |
+| encoder.encoder.layer.11.attention.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.11.attention.output.LayerNorm.bias | [768] | 768 |
+| encoder.encoder.layer.11.intermediate.dense.weight | [3072, 768] | 2359296 |
+| encoder.encoder.layer.11.intermediate.dense.bias | [3072] | 3072 |
+| encoder.encoder.layer.11.output.dense.weight | [768, 3072] | 2359296 |
+| encoder.encoder.layer.11.output.dense.bias | [768] | 768 |
+| encoder.encoder.layer.11.output.LayerNorm.weight | [768] | 768 |
+| encoder.encoder.layer.11.output.LayerNorm.bias | [768] | 768 |
+| encoder.pooler.dense.weight | [768, 768] | 589824 |
+| encoder.pooler.dense.bias | [768] | 768 |
++------------------------------------------------------------+--------------+----------+
+02/17/2024 13:45:41 - INFO - __main__ - Training/evaluation parameters Namespace(agg_way='avg', aug_type_way='random_replace_type', code_length=256, codebase_file='dataset/java/codebase.jsonl', config_name='DeepSoftwareAnalytics/CoCoSoDa', couninue_pre_train_data_files=['dataset/ruby/train.jsonl', 'dataset/java/train.jsonl'], data_aug_type='random_mask', data_flow_length=0, debug=False, device=device(type='cuda'), do_avg=False, do_continue_pre_trained=False, do_eval=False, do_fine_tune=False, do_ineer_loss=False, do_multi_lang_continue_pre_train=False, do_single_lang_continue_pre_train=False, do_test=True, do_train=True, do_whitening=False, do_zero_short=False, epoch=50, eval_batch_size=64, eval_data_file='dataset/java/valid.jsonl', eval_frequency=100, fp16=False, gradient_accumulation_steps=1, hidden_size=768, lang='java', learning_rate=2e-05, loaded_codebert_model_filename=None, loaded_model_filename=None, local_rank=-1, logging_steps=50, max_codeblock_num=10, max_grad_norm=1.0, max_steps=100, mlm_probability=0.1, mlp=False, moco_dim=768, moco_k=1024, moco_m=0.999, moco_t=0.07, moco_type='encoder_queue', model_name_or_path='DeepSoftwareAnalytics/CoCoSoDa', model_type='base', n_debug_samples=100, n_gpu=1, nl_length=128, num_train_epochs=5, num_warmup_steps=0, only_save_the_nl_code_vec=False, output_dir='./saved_models/fine_tune/java', print_align_unif_loss=False, save_evaluation_reuslt=False, save_evaluation_reuslt_dir=None, save_steps=50, seed=123456, test_data_file='dataset/java/test.jsonl', time_score=1, tokenizer_name='DeepSoftwareAnalytics/CoCoSoDa', train_batch_size=128, train_data_file='dataset/java/train.jsonl', use_best_mrr_model=False, weight_decay=0.01)
+02/17/2024 13:48:46 - INFO - __main__ - *** Example ***
+02/17/2024 13:48:46 - INFO - __main__ - idx: 0
+02/17/2024 13:48:46 - INFO - __main__ - code_tokens: ['', '', ' ', '@', '_Override', '_public', '_Image', 'Source', '_apply', '_(', '_Image', 'Source', '_input', '_)', '_{', '_final', '_int', '_[', '_]', '_[', '_]', '_pixel', 'Matrix', '_=', '_new', '_int', '_[', '_3', '_]', '_[', '_3', '_]', '_;', '_int', '_w', '_=', '_input', '_.', '_getWidth', '_(', '_)', '_;', '_int', '_h', '_=', '_input', '_.', '_getHeight', '_(', '_)', '_;', '_int', '_[', '_]', '_[', '_]', '_output', '_=', '_new', '_int', '_[', '_h', '_]', '_[', '_w', '_]', '_;', '_for', '_(', '_int', '_j', '_=', '_1', '_;', '_j', '_<', '_h', '_-', '_1', '_;', '_j', '_++', '_)', '_{', '_for', '_(', '_int', '_i', '_=', '_1', '_;', '_i', '_<', '_w', '_-', '_1', '_;', '_i', '_++', '_)', '_{', '_pixel', 'Matrix', '_[', '_0', '_]', '_[', '_0', '_]', '_=', '_input', '_.', '_get', 'R', '_(', '_i', '_-', '_1', '_,', '_j', '_-', '_1', '_)', '_;', '_pixel', 'Matrix', '_[', '_0', '_]', '_[', '_1', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_-', '_1', '_,', '_j', '_)', '_;', '_pixel', 'Matrix', '_[', '_0', '_]', '_[', '_2', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_-', '_1', '_,', '_j', '_+', '_1', '_)', '_;', '_pixel', 'Matrix', '_[', '_1', '_]', '_[', '_0', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_,', '_j', '_-', '_1', '_)', '_;', '_pixel', 'Matrix', '_[', '_1', '_]', '_[', '_2', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_,', '_j', '_+', '_1', '_)', '_;', '_pixel', 'Matrix', '_[', '_2', '_]', '_[', '_0', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_+', '_1', '_,', '_j', '_-', '_1', '_)', '_;', '_pixel', 'Matrix', '_[', '_2', '_]', '_[', '_1', '_]', '_=', '_input', '_.', '_get', 'RGB', '_(', '_i', '_+', '_1', '_,', '_j', '_)', '_;', '_pixel', '']
+02/17/2024 13:48:46 - INFO - __main__ - code_ids: 0 6 2 150 19505 1240 6085 1768 5230 400 6085 1768 1586 743 399 1920 554 626 2406 626 2406 5578 3679 385 579 554 626 995 2406 626 995 2406 2476 554 477 385 1586 746 32671 400 743 2476 554 566 385 1586 746 32720 400 743 2476 554 626 2406 626 2406 1721 385 579 554 626 566 2406 626 477 2406 2476 563 400 554 913 385 524 2476 913 517 566 581 524 2476 913 1932 743 399 563 400 554 548 385 524 2476 548 517 477 581 524 2476 548 1932 743 399 5578 3679 626 461 2406 626 461 2406 385 1586 746 744 168 400 548 581 524 2019 913 581 524 743 2476 5578 3679 626 461 2406 626 524 2406 385 1586 746 744 7664 400 548 581 524 2019 913 743 2476 5578 3679 626 461 2406 626 688 2406 385 1586 746 744 7664 400 548 581 524 2019 913 513 524 743 2476 5578 3679 626 524 2406 626 461 2406 385 1586 746 744 7664 400 548 2019 913 581 524 743 2476 5578 3679 626 524 2406 626 688 2406 385 1586 746 744 7664 400 548 2019 913 513 524 743 2476 5578 3679 626 688 2406 626 461 2406 385 1586 746 744 7664 400 548 513 524 2019 913 581 524 743 2476 5578 3679 626 688 2406 626 524 2406 385 1586 746 744 7664 400 548 513 524 2019 913 743 2476 5578 2
+02/17/2024 13:48:46 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Expect', 's', '_a', '_height', '_mat', '_as', '_input', '']
+02/17/2024 13:48:46 - INFO - __main__ - nl_ids: 0 6 2 7871 201 434 3082 5772 880 1586 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 13:48:46 - INFO - __main__ - *** Example ***
+02/17/2024 13:48:46 - INFO - __main__ - idx: 1
+02/17/2024 13:48:46 - INFO - __main__ - code_tokens: ['', '', ' ', 'public', '_<', '_L', 'extends', 'Listener', '_>', '_void', '_pop', 'Event', '_(', '_Event', '_<', '_?', '_,', '_L', '_>', '_expected', '_)', '_{', '_synchronized', '_(', '_this', '_.', '_stack', '_)', '_{', '_final', '_Event', '_<', '_?', '_,', '_?', '_>', '_actual', '_=', '_this', '_.', '_stack', '_.', '_pop', '_(', '_)', '_;', '_if', '_(', '_actual', '_!=', '_expected', '_)', '_{', '_throw', '_new', '_IllegalStateException', '_(', '_String', '_.', '_format', '_(', '"', 'Un', 'balanced', '_pop', ':', '_expected', "_'%", 's', "'", '_but', '_encountered', "_'%", 's', "'", '"', ',', '_expected', '_.', '_get', 'Listener', 'Class', '_(', '_)', '_,', '_actual', '_)', '_)', '_;', '_}', '_}', '_}', '']
+02/17/2024 13:48:46 - INFO - __main__ - code_ids: 0 6 2 653 517 747 13125 2486 711 723 5012 1089 400 3916 517 999 2019 747 711 2048 743 399 9401 400 547 746 3325 743 399 1920 3916 517 999 2019 999 711 3780 385 547 746 3325 746 5012 400 743 2476 462 400 3780 620 2048 743 399 1185 579 16219 400 1167 746 2021 400 120 965 37707 5012 144 2048 3421 201 125 2107 17038 3421 201 125 120 130 2048 746 744 2486 1128 400 743 2019 3780 743 743 2476 425 425 425 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 13:48:46 - INFO - __main__ - nl_tokens: ['', '', ' ', 'P', 'ops', '_the', '_top', '_event', '_off', '_the', '_current', '_event', '_stack', '_.', '_This', '_action', '_has', '_to', '_be', '_performed', '_immediately', '_after', '_the', '_event', '_has', '_been', '_dispatched', '_to', '_all', '_listeners', '_.', '']
+02/17/2024 13:48:46 - INFO - __main__ - nl_ids: 0 6 2 166 2489 448 3194 1488 3413 448 1434 1488 3325 746 1600 2657 1559 508 661 13181 10086 2493 448 1488 1559 3022 43340 508 1345 11839 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 13:48:46 - INFO - __main__ - *** Example ***
+02/17/2024 13:48:46 - INFO - __main__ - idx: 2
+02/17/2024 13:48:46 - INFO - __main__ - code_tokens: ['', '', ' ', 'protected', '_void', '_modify', '_(', '_Transaction', '_t', '_)', '_{', '_try', '_{', '_this', '_.', '_lock', '_.', '_write', 'Lock', '_(', '_)', '_.', '_lock', '_(', '_)', '_;', '_t', '_.', '_perform', '_(', '_)', '_;', '_}', '_finally', '_{', '_this', '_.', '_lock', '_.', '_write', 'Lock', '_(', '_)', '_.', '_unlock', '_(', '_)', '_;', '_}', '_}', '']
+02/17/2024 13:48:46 - INFO - __main__ - code_ids: 0 6 2 1933 723 8660 400 13081 422 743 399 1568 399 547 746 3505 746 2250 2896 400 743 746 3505 400 743 2476 422 746 4729 400 743 2476 425 6110 399 547 746 3505 746 2250 2896 400 743 746 14552 400 743 2476 425 425 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 13:48:46 - INFO - __main__ - nl_tokens: ['', '', ' ', 'Executes', '_the', '_given', '_transaction', '_within', '_the', '_con', 'text', 'of', '_a', '_write', '_lock', '_.', '']
+02/17/2024 13:48:46 - INFO - __main__ - nl_ids: 0 6 2 40551 448 2076 4993 5289 448 549 625 757 434 2250 3505 746 2 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
+02/17/2024 13:48:46 - INFO - __main__ - ***** Running training *****
+02/17/2024 13:48:46 - INFO - __main__ - Num examples = 164923
+02/17/2024 13:48:46 - INFO - __main__ - Num Epochs = 5
+02/17/2024 13:48:46 - INFO - __main__ - Num quene = 1024
+02/17/2024 13:48:46 - INFO - __main__ - Instantaneous batch size per GPU = 128
+02/17/2024 13:48:46 - INFO - __main__ - Total train batch size = 128
+02/17/2024 13:48:46 - INFO - __main__ - Total optimization steps = 6440
+Traceback (most recent call last):
+ File "run.py", line 1188, in
+ main()
+ File "run.py", line 1154, in main
+ train(args, model, tokenizer, pool)
+ File "run.py", line 585, in train
+ code_vec = model(code_inputs=code_inputs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/cocosoda/CoCoSoDa/model.py", line 40, in forward
+ outputs = self.encoder(code_inputs,attention_mask=code_inputs.ne(1))[0] #[bs, seq_len, dim]
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1120, in _call_impl
+ result = forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/transformers/models/roberta/modeling_roberta.py", line 860, in forward
+ return_dict=return_dict,
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/transformers/models/roberta/modeling_roberta.py", line 531, in forward
+ output_attentions,
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/transformers/models/roberta/modeling_roberta.py", line 415, in forward
+ past_key_value=self_attn_past_key_value,
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/transformers/models/roberta/modeling_roberta.py", line 344, in forward
+ output_attentions,
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/transformers/models/roberta/modeling_roberta.py", line 267, in forward
+ attention_probs = self.dropout(attention_probs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/module.py", line 1102, in _call_impl
+ return forward_call(*input, **kwargs)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/modules/dropout.py", line 58, in forward
+ return F.dropout(input, self.p, self.training, self.inplace)
+ File "/home/yiming/anaconda3/envs/CoCoSoDa/lib/python3.6/site-packages/torch/nn/functional.py", line 1169, in dropout
+ return _VF.dropout_(input, p, training) if inplace else _VF.dropout(input, p, training)
+RuntimeError: CUDA out of memory. Tried to allocate 384.00 MiB (GPU 0; 14.75 GiB total capacity; 12.96 GiB already allocated; 173.94 MiB free; 13.02 GiB reserved in total by PyTorch) If reserved memory is >> allocated memory try setting max_split_size_mb to avoid fragmentation. See documentation for Memory Management and PYTORCH_CUDA_ALLOC_CONF
diff --git a/saved_models/fine_tune/ruby/0/model.bin b/saved_models/fine_tune/ruby/0/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..e16c2679b8c5240ebbf626cea65d98220a5a8d06
--- /dev/null
+++ b/saved_models/fine_tune/ruby/0/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:c8e9079fe0c63cf5b89b754bbcbd82424a11bf0bd9e5af6f5714c6d5a4c5a42d
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/1/all_code_vec.npy b/saved_models/fine_tune/ruby/1/all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..173699e2c5224600ee47abc5e891c852344ea40f
--- /dev/null
+++ b/saved_models/fine_tune/ruby/1/all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d853b87902ece32e8427671590a29d8e69153f352fdbbcb89c9b2fa09df03f1e
+size 76575872
diff --git a/saved_models/fine_tune/ruby/1/all_nl_vec.npy b/saved_models/fine_tune/ruby/1/all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..b9b91ac60c006bd65f120fab00f5982d50b7ba8d
--- /dev/null
+++ b/saved_models/fine_tune/ruby/1/all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:321dfa145a7cfc4e5176980a2354cdafea7a48043288a88c65c831b15462dbfa
+size 76575872
diff --git a/saved_models/fine_tune/ruby/1/model.bin b/saved_models/fine_tune/ruby/1/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..7bd6cad658d328e7d11afcf4bb41a6c8c6a30a5a
--- /dev/null
+++ b/saved_models/fine_tune/ruby/1/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:a4b64b0755d42a48072d1390d69a1d0979aaa779eee94bc63444511ddd59b793
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/1/test_all_code_vec.npy b/saved_models/fine_tune/ruby/1/test_all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..fde98ea4f4136dcc46b5300ca4dbf59357cccae1
--- /dev/null
+++ b/saved_models/fine_tune/ruby/1/test_all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:b907f0004db84850c59214fc63e8b59eddfab8127fb435712632eaec0ec07fb0
+size 3873920
diff --git a/saved_models/fine_tune/ruby/1/test_all_nl_vec.npy b/saved_models/fine_tune/ruby/1/test_all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..79a5836cc1626fbcd2b6576edf5324d47af9287d
--- /dev/null
+++ b/saved_models/fine_tune/ruby/1/test_all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:aa8eecb652e9879e0cd5bef34fb8ce16adc43b88cb097f00a39ccb538861308e
+size 3873920
diff --git a/saved_models/fine_tune/ruby/2/all_code_vec.npy b/saved_models/fine_tune/ruby/2/all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..247683a9d17ef6457bf2588faa3f808248ca600d
--- /dev/null
+++ b/saved_models/fine_tune/ruby/2/all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d2c34ce22cef54b838cb15be43f74ce72cba04ff7c3523ec16923db2e3cc479f
+size 76575872
diff --git a/saved_models/fine_tune/ruby/2/all_nl_vec.npy b/saved_models/fine_tune/ruby/2/all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..c9cd8ad98a41c2bf9955696edfdb8a298d0d998a
--- /dev/null
+++ b/saved_models/fine_tune/ruby/2/all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:470bce39b439f6151ca0acabb6c5b3754f92a9f4cdd63bf29cabd88fac57e26f
+size 76575872
diff --git a/saved_models/fine_tune/ruby/2/model.bin b/saved_models/fine_tune/ruby/2/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..78369524315b9d72704ec0566ef584b2d8ce357d
--- /dev/null
+++ b/saved_models/fine_tune/ruby/2/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:6fdc86d2b72e082fc9ab35102f060ae270f952b2755d26ff492a0ec8fc5b19ee
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/2/test_all_code_vec.npy b/saved_models/fine_tune/ruby/2/test_all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..e53ba1cd81eb60bfeced71a059cd1c3476df685d
--- /dev/null
+++ b/saved_models/fine_tune/ruby/2/test_all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:8d5eea680c7a2423d1e7e482e5850a935fd6c977c94c595992e766beba1a42a5
+size 3873920
diff --git a/saved_models/fine_tune/ruby/2/test_all_nl_vec.npy b/saved_models/fine_tune/ruby/2/test_all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..7f33b0db68c58ad0642ec71c87555422b0e823dc
--- /dev/null
+++ b/saved_models/fine_tune/ruby/2/test_all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:a30742e7e82e6d0ca1533773cf5aa747b346ca102f8526e8fa5170f56e88657a
+size 3873920
diff --git a/saved_models/fine_tune/ruby/3/all_code_vec.npy b/saved_models/fine_tune/ruby/3/all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..6428af440625365452937d32ea9c6aa422d8839b
--- /dev/null
+++ b/saved_models/fine_tune/ruby/3/all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:70f73384f0d8a01e3c6208c534d295d2c2cd1af98dee5cd1fb7dc046fde88567
+size 76575872
diff --git a/saved_models/fine_tune/ruby/3/all_nl_vec.npy b/saved_models/fine_tune/ruby/3/all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..6c420541f3ccf35f6ae18ca9f6eebde2f444a17c
--- /dev/null
+++ b/saved_models/fine_tune/ruby/3/all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:1c8e440149458ad89a9ce02f62d2d050b51f4d7d23f1d044f53bdde25c541526
+size 76575872
diff --git a/saved_models/fine_tune/ruby/3/model.bin b/saved_models/fine_tune/ruby/3/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..6af508974f7bfd361a4f6f8b83a51a8282f41de1
--- /dev/null
+++ b/saved_models/fine_tune/ruby/3/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:8bce2703c09f8b5c78aa2a0c31b92f80a0fca266dbab3101927552f3998c5794
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/3/test_all_code_vec.npy b/saved_models/fine_tune/ruby/3/test_all_code_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..770b6afe880d532a92a4cd6a2b94f45c3e27d0e7
--- /dev/null
+++ b/saved_models/fine_tune/ruby/3/test_all_code_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:b9dd02d38f7aad13eea34fcdc02d24857437a5a48e5f813ef7659717edc03961
+size 3873920
diff --git a/saved_models/fine_tune/ruby/3/test_all_nl_vec.npy b/saved_models/fine_tune/ruby/3/test_all_nl_vec.npy
new file mode 100644
index 0000000000000000000000000000000000000000..820b5134203d80882b221228c06150085a4489ef
--- /dev/null
+++ b/saved_models/fine_tune/ruby/3/test_all_nl_vec.npy
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:8d367df01e5f400124be2aefbf77eb39bc5dc575b30db1f7593bad1f6949d742
+size 3873920
diff --git a/saved_models/fine_tune/ruby/4/model.bin b/saved_models/fine_tune/ruby/4/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..88f2eeb3231de3af1b947cd1327338e5b5cf5251
--- /dev/null
+++ b/saved_models/fine_tune/ruby/4/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:e507b62594fe1d7cebbabf653d559acb9e9a72f9d31b57ea53721bb52e26d228
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/checkpoint-best-mrr/model.bin b/saved_models/fine_tune/ruby/checkpoint-best-mrr/model.bin
new file mode 100644
index 0000000000000000000000000000000000000000..88f2eeb3231de3af1b947cd1327338e5b5cf5251
--- /dev/null
+++ b/saved_models/fine_tune/ruby/checkpoint-best-mrr/model.bin
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:e507b62594fe1d7cebbabf653d559acb9e9a72f9d31b57ea53721bb52e26d228
+size 1524384769
diff --git a/saved_models/fine_tune/ruby/docstring_list.json b/saved_models/fine_tune/ruby/docstring_list.json
new file mode 100644
index 0000000000000000000000000000000000000000..02cc35ed62bc7738b26c697cd48559d54d9a54c0
--- /dev/null
+++ b/saved_models/fine_tune/ruby/docstring_list.json
@@ -0,0 +1 @@
+["Render but returns a valid Rack body. If fibers are defined, we return\n a streaming body that renders the template piece by piece.\n\n Note that partials are not supported to be rendered with streaming,\n so in such cases, we just wrap them in an array.", "+attribute_missing+ is like +method_missing+, but for attributes. When\n +method_missing+ is called we check to see if there is a matching\n attribute method. If so, we tell +attribute_missing+ to dispatch the\n attribute. This method can be overloaded to customize the behavior.", "Returns a struct representing the matching attribute method.\n The struct's attributes are prefix, base and suffix.", "Removes the module part from the expression in the string.\n\n demodulize('ActiveSupport::Inflector::Inflections') # => \"Inflections\"\n demodulize('Inflections') # => \"Inflections\"\n demodulize('::Inflections') # => \"Inflections\"\n demodulize('') # => \"\"\n\n See also #deconstantize.", "Mounts a regular expression, returned as a string to ease interpolation,\n that will match part by part the given constant.\n\n const_regexp(\"Foo::Bar::Baz\") # => \"Foo(::Bar(::Baz)?)?\"\n const_regexp(\"::\") # => \"::\"", "Applies inflection rules for +singularize+ and +pluralize+.\n\n If passed an optional +locale+ parameter, the uncountables will be\n found for that locale.\n\n apply_inflections('post', inflections.plurals, :en) # => \"posts\"\n apply_inflections('posts', inflections.singulars, :en) # => \"post\"", "Attempt to autoload the provided module name by searching for a directory\n matching the expected path suffix. If found, the module is created and\n assigned to +into+'s constants with the name +const_name+. Provided that\n the directory was loaded from a reloadable base path, it is added to the\n set of constants that are to be unloaded.", "Parse an XML Document string or IO into a simple hash.\n\n Same as XmlSimple::xml_in but doesn't shoot itself in the foot,\n and uses the defaults from Active Support.\n\n data::\n XML Document string or IO to parse", "Connects a model to the databases specified. The +database+ keyword\n takes a hash consisting of a +role+ and a +database_key+.\n\n This will create a connection handler for switching between connections,\n look up the config hash using the +database_key+ and finally\n establishes a connection to that config.\n\n class AnimalsModel < ApplicationRecord\n self.abstract_class = true\n\n connects_to database: { writing: :primary, reading: :primary_replica }\n end\n\n Returns an array of established connections.", "Clears the query cache for all connections associated with the current thread.", "turns 20170404131909 into \"2017_04_04_131909\"", "Keep it for indexing materialized views", "Returns a formatted string of the offset from UTC, or an alternative\n string if the time zone is already UTC.\n\n Time.zone = 'Eastern Time (US & Canada)' # => \"Eastern Time (US & Canada)\"\n Time.zone.now.formatted_offset(true) # => \"-05:00\"\n Time.zone.now.formatted_offset(false) # => \"-0500\"\n Time.zone = 'UTC' # => \"UTC\"\n Time.zone.now.formatted_offset(true, \"0\") # => \"0\"", "Uses Date to provide precise Time calculations for years, months, and days\n according to the proleptic Gregorian calendar. The result is returned as a\n new TimeWithZone object.\n\n The +options+ parameter takes a hash with any of these keys:\n :years , :months , :weeks , :days ,\n :hours , :minutes , :seconds .\n\n If advancing by a value of variable length (i.e., years, weeks, months,\n days), move forward from #time, otherwise move forward from #utc, for\n accuracy when moving across DST boundaries.\n\n Time.zone = 'Eastern Time (US & Canada)' # => 'Eastern Time (US & Canada)'\n now = Time.zone.now # => Sun, 02 Nov 2014 01:26:28 EDT -04:00\n now.advance(seconds: 1) # => Sun, 02 Nov 2014 01:26:29 EDT -04:00\n now.advance(minutes: 1) # => Sun, 02 Nov 2014 01:27:28 EDT -04:00\n now.advance(hours: 1) # => Sun, 02 Nov 2014 01:26:28 EST -05:00\n now.advance(days: 1) # => Mon, 03 Nov 2014 01:26:28 EST -05:00\n now.advance(weeks: 1) # => Sun, 09 Nov 2014 01:26:28 EST -05:00\n now.advance(months: 1) # => Tue, 02 Dec 2014 01:26:28 EST -05:00\n now.advance(years: 1) # => Mon, 02 Nov 2015 01:26:28 EST -05:00", "Calls the action going through the entire action dispatch stack.\n\n The actual method that is called is determined by calling\n #method_for_action. If no method can handle the action, then an\n AbstractController::ActionNotFound error is raised.\n\n ==== Returns\n * self ", "Passes each element of +candidates+ collection to ArrayInquirer collection.\n The method returns true if any element from the ArrayInquirer collection\n is equal to the stringified or symbolized form of any element in the +candidates+ collection.\n\n If +candidates+ collection is not given, method returns true.\n\n variants = ActiveSupport::ArrayInquirer.new([:phone, :tablet])\n\n variants.any? # => true\n variants.any?(:phone, :tablet) # => true\n variants.any?('phone', 'desktop') # => true\n variants.any?(:desktop, :watch) # => false", "Returns a stable cache key that can be used to identify this record.\n\n Product.new.cache_key # => \"products/new\"\n Product.find(5).cache_key # => \"products/5\"\n\n If ActiveRecord::Base.cache_versioning is turned off, as it was in Rails 5.1 and earlier,\n the cache key will also include a version.\n\n Product.cache_versioning = false\n Product.find(5).cache_key # => \"products/5-20071224150000\" (updated_at available)", "Returns +text+ wrapped at +len+ columns and indented +indent+ spaces.\n By default column length +len+ equals 72 characters and indent\n +indent+ equal two spaces.\n\n my_text = 'Here is a sample text with more than 40 characters'\n\n format_paragraph(my_text, 25, 4)\n # => \" Here is a sample text with\\n more than 40 characters\"", "Yields each batch of records that was found by the find options as\n an array.\n\n Person.where(\"age > 21\").find_in_batches do |group|\n sleep(50) # Make sure it doesn't get too crowded in there!\n group.each { |person| person.party_all_night! }\n end\n\n If you do not provide a block to #find_in_batches, it will return an Enumerator\n for chaining with other methods:\n\n Person.find_in_batches.with_index do |group, batch|\n puts \"Processing group ##{batch}\"\n group.each(&:recover_from_last_night!)\n end\n\n To be yielded each record one by one, use #find_each instead.\n\n ==== Options\n * :batch_size - Specifies the size of the batch. Defaults to 1000.\n * :start - Specifies the primary key value to start from, inclusive of the value.\n * :finish - Specifies the primary key value to end at, inclusive of the value.\n * :error_on_ignore - Overrides the application config to specify if an error should be raised when\n an order is present in the relation.\n\n Limits are honored, and if present there is no requirement for the batch\n size: it can be less than, equal to, or greater than the limit.\n\n The options +start+ and +finish+ are especially useful if you want\n multiple workers dealing with the same processing queue. You can make\n worker 1 handle all the records between id 1 and 9999 and worker 2\n handle from 10000 and beyond by setting the +:start+ and +:finish+\n option on each worker.\n\n # Let's process from record 10_000 on.\n Person.find_in_batches(start: 10_000) do |group|\n group.each { |person| person.party_all_night! }\n end\n\n NOTE: It's not possible to set the order. That is automatically set to\n ascending on the primary key (\"id ASC\") to make the batch ordering\n work. This also means that this method only works when the primary key is\n orderable (e.g. an integer or string).\n\n NOTE: By its nature, batch processing is subject to race conditions if\n other processes are modifying the database.", "See if error matches provided +attribute+, +type+ and +options+.", "`order_by` is an enumerable object containing keys of the cache,\n all keys are passed in whether found already or not.\n\n `cached_partials` is a hash. If the value exists\n it represents the rendered partial from the cache\n otherwise `Hash#fetch` will take the value of its block.\n\n This method expects a block that will return the rendered\n partial. An example is to render all results\n for each element that was not found in the cache and store it as an array.\n Order it so that the first empty cache element in `cached_partials`\n corresponds to the first element in `rendered_partials`.\n\n If the partial is not already cached it will also be\n written back to the underlying cache store.", "Runs the callbacks for the given event.\n\n Calls the before and around callbacks in the order they were set, yields\n the block (if given one), and then runs the after callbacks in reverse\n order.\n\n If the callback chain was halted, returns +false+. Otherwise returns the\n result of the block, +nil+ if no callbacks have been set, or +true+\n if callbacks have been set but no block is given.\n\n run_callbacks :save do\n save\n end\n\n--\n\n As this method is used in many places, and often wraps large portions of\n user code, it has an additional design goal of minimizing its impact on\n the visible call stack. An exception from inside a :before or :after\n callback can be as noisy as it likes -- but when control has passed\n smoothly through and into the supplied block, we want as little evidence\n as possible that we were here.", "If +file+ is the filename of a file that contains annotations this method returns\n a hash with a single entry that maps +file+ to an array of its annotations.\n Otherwise it returns an empty hash.", "Checks if we should perform parameters wrapping.", "create a new session. If a block is given, the new session will be yielded\n to the block before being returned.", "reloads the environment", "The DOM id convention is to use the singular form of an object or class with the id following an underscore.\n If no id is found, prefix with \"new_\" instead.\n\n dom_id(Post.find(45)) # => \"post_45\"\n dom_id(Post.new) # => \"new_post\"\n\n If you need to address multiple instances of the same class in the same view, you can prefix the dom_id:\n\n dom_id(Post.find(45), :edit) # => \"edit_post_45\"\n dom_id(Post.new, :custom) # => \"custom_post\"", "Evaluate given block in context of base class,\n so that you can write class macros here.\n When you define more than one +included+ block, it raises an exception.", "Define class methods from given block.\n You can define private class methods as well.\n\n module Example\n extend ActiveSupport::Concern\n\n class_methods do\n def foo; puts 'foo'; end\n\n private\n def bar; puts 'bar'; end\n end\n end\n\n class Buzz\n include Example\n end\n\n Buzz.foo # => \"foo\"\n Buzz.bar # => private method 'bar' called for Buzz:Class(NoMethodError)", "Convenience accessor.", "Checks if a signed message could have been generated by signing an object\n with the +MessageVerifier+'s secret.\n\n verifier = ActiveSupport::MessageVerifier.new 's3Krit'\n signed_message = verifier.generate 'a private message'\n verifier.valid_message?(signed_message) # => true\n\n tampered_message = signed_message.chop # editing the message invalidates the signature\n verifier.valid_message?(tampered_message) # => false", "Decodes the signed message using the +MessageVerifier+'s secret.\n\n verifier = ActiveSupport::MessageVerifier.new 's3Krit'\n\n signed_message = verifier.generate 'a private message'\n verifier.verified(signed_message) # => 'a private message'\n\n Returns +nil+ if the message was not signed with the same secret.\n\n other_verifier = ActiveSupport::MessageVerifier.new 'd1ff3r3nt-s3Krit'\n other_verifier.verified(signed_message) # => nil\n\n Returns +nil+ if the message is not Base64-encoded.\n\n invalid_message = \"f--46a0120593880c733a53b6dad75b42ddc1c8996d\"\n verifier.verified(invalid_message) # => nil\n\n Raises any error raised while decoding the signed message.\n\n incompatible_message = \"test--dad7b06c94abba8d46a15fafaef56c327665d5ff\"\n verifier.verified(incompatible_message) # => TypeError: incompatible marshal file format", "Generates a signed message for the provided value.\n\n The message is signed with the +MessageVerifier+'s secret. Without knowing\n the secret, the original value cannot be extracted from the message.\n\n verifier = ActiveSupport::MessageVerifier.new 's3Krit'\n verifier.generate 'a private message' # => \"BAhJIhRwcml2YXRlLW1lc3NhZ2UGOgZFVA==--e2d724331ebdee96a10fb99b089508d1c72bd772\"", "Creates a new job instance. Takes the arguments that will be\n passed to the perform method.\n Returns a hash with the job data that can safely be passed to the\n queuing adapter.", "Attaches the stored job data to the current instance. Receives a hash\n returned from +serialize+\n\n ==== Examples\n\n class DeliverWebhookJob < ActiveJob::Base\n attr_writer :attempt_number\n\n def attempt_number\n @attempt_number ||= 0\n end\n\n def serialize\n super.merge('attempt_number' => attempt_number + 1)\n end\n\n def deserialize(job_data)\n super\n self.attempt_number = job_data['attempt_number']\n end\n\n rescue_from(Timeout::Error) do |exception|\n raise exception if attempt_number > 5\n retry_job(wait: 10)\n end\n end", "Takes a path to a file. If the file is found, has valid encoding, and has\n correct read permissions, the return value is a URI-escaped string\n representing the filename. Otherwise, false is returned.\n\n Used by the +Static+ class to check the existence of a valid file\n in the server's +public/+ directory (see Static#call).", "Compares one Duration with another or a Numeric to this Duration.\n Numeric values are treated as seconds.\n Adds another Duration or a Numeric to this Duration. Numeric values\n are treated as seconds.", "Multiplies this Duration by a Numeric and returns a new Duration.", "Returns the modulo of this Duration by another Duration or Numeric.\n Numeric values are treated as seconds.", "Overload locale= to also set the I18n.locale. If the current I18n.config object responds\n to original_config, it means that it has a copy of the original I18n configuration and it's\n acting as proxy, which we need to skip.", "Normalizes the arguments and passes it on to find_templates.", "Handles templates caching. If a key is given and caching is on\n always check the cache before hitting the resolver. Otherwise,\n it always hits the resolver but if the key is present, check if the\n resolver is fresher before returning it.", "Extract handler, formats and variant from path. If a format cannot be found neither\n from the path, or the handler, we should return the array of formats given\n to the resolver.", "For streaming, instead of rendering a given a template, we return a Body\n object that responds to each. This object is initialized with a block\n that knows how to render the template.", "If the record is new or it has changed, returns true.", "Replaces non-ASCII characters with an ASCII approximation, or if none\n exists, a replacement character which defaults to \"?\".\n\n transliterate('\u00c6r\u00f8sk\u00f8bing')\n # => \"AEroskobing\"\n\n Default approximations are provided for Western/Latin characters,\n e.g, \"\u00f8\", \"\u00f1\", \"\u00e9\", \"\u00df\", etc.\n\n This method is I18n aware, so you can set up custom approximations for a\n locale. This can be useful, for example, to transliterate German's \"\u00fc\"\n and \"\u00f6\" to \"ue\" and \"oe\", or to add support for transliterating Russian\n to ASCII.\n\n In order to make your custom transliterations available, you must set\n them as the i18n.transliterate.rule i18n key:\n\n # Store the transliterations in locales/de.yml\n i18n:\n transliterate:\n rule:\n \u00fc: \"ue\"\n \u00f6: \"oe\"\n\n # Or set them using Ruby\n I18n.backend.store_translations(:de, i18n: {\n transliterate: {\n rule: {\n '\u00fc' => 'ue',\n '\u00f6' => 'oe'\n }\n }\n })\n\n The value for i18n.transliterate.rule can be a simple Hash that\n maps characters to ASCII approximations as shown above, or, for more\n complex requirements, a Proc:\n\n I18n.backend.store_translations(:de, i18n: {\n transliterate: {\n rule: ->(string) { MyTransliterator.transliterate(string) }\n }\n })\n\n Now you can have different transliterations for each locale:\n\n transliterate('J\u00fcrgen', locale: :en)\n # => \"Jurgen\"\n\n transliterate('J\u00fcrgen', locale: :de)\n # => \"Juergen\"", "Imports one error\n Imported errors are wrapped as a NestedError,\n providing access to original error object.\n If attribute or type needs to be overriden, use `override_options`.\n\n override_options - Hash\n @option override_options [Symbol] :attribute Override the attribute the error belongs to\n @option override_options [Symbol] :type Override type of the error.", "Removes all errors except the given keys. Returns a hash containing the removed errors.\n\n person.errors.keys # => [:name, :age, :gender, :city]\n person.errors.slice!(:age, :gender) # => { :name=>[\"cannot be nil\"], :city=>[\"cannot be nil\"] }\n person.errors.keys # => [:age, :gender]", "Search for errors matching +attribute+, +type+ or +options+.\n\n Only supplied params will be matched.\n\n person.errors.where(:name) # => all name errors.\n person.errors.where(:name, :too_short) # => all name errors being too short\n person.errors.where(:name, :too_short, minimum: 2) # => all name errors being too short and minimum is 2", "Delete messages for +key+. Returns the deleted messages.\n\n person.errors[:name] # => [\"cannot be nil\"]\n person.errors.delete(:name) # => [\"cannot be nil\"]\n person.errors[:name] # => []", "Iterates through each error key, value pair in the error messages hash.\n Yields the attribute and the error for that attribute. If the attribute\n has more than one error message, yields once for each error message.\n\n person.errors.add(:name, :blank, message: \"can't be blank\")\n person.errors.each do |attribute, error|\n # Will yield :name and \"can't be blank\"\n end\n\n person.errors.add(:name, :not_specified, message: \"must be specified\")\n person.errors.each do |attribute, error|\n # Will yield :name and \"can't be blank\"\n # then yield :name and \"must be specified\"\n end", "Returns an xml formatted representation of the Errors hash.\n\n person.errors.add(:name, :blank, message: \"can't be blank\")\n person.errors.add(:name, :not_specified, message: \"must be specified\")\n person.errors.to_xml\n # =>\n # \n # \n # name can't be blank \n # name must be specified \n # ", "Reverses the migration commands for the given block and\n the given migrations.\n\n The following migration will remove the table 'horses'\n and create the table 'apples' on the way up, and the reverse\n on the way down.\n\n class FixTLMigration < ActiveRecord::Migration[5.0]\n def change\n revert do\n create_table(:horses) do |t|\n t.text :content\n t.datetime :remind_at\n end\n end\n create_table(:apples) do |t|\n t.string :variety\n end\n end\n end\n\n Or equivalently, if +TenderloveMigration+ is defined as in the\n documentation for Migration:\n\n require_relative '20121212123456_tenderlove_migration'\n\n class FixupTLMigration < ActiveRecord::Migration[5.0]\n def change\n revert TenderloveMigration\n\n create_table(:apples) do |t|\n t.string :variety\n end\n end\n end\n\n This command can be nested.", "Outputs text along with how long it took to run its block.\n If the block returns an integer it assumes it is the number of rows affected.", "Determines the version number of the next migration.", "Used for running a specific migration.", "Used for running multiple migrations up to or down to a certain value.", "Sets the +permitted+ attribute to +true+. This can be used to pass\n mass assignment. Returns +self+.\n\n class Person < ActiveRecord::Base\n end\n\n params = ActionController::Parameters.new(name: \"Francesco\")\n params.permitted? # => false\n Person.new(params) # => ActiveModel::ForbiddenAttributesError\n params.permit!\n params.permitted? # => true\n Person.new(params) # => #", "This method accepts both a single key and an array of keys.\n\n When passed a single key, if it exists and its associated value is\n either present or the singleton +false+, returns said value:\n\n ActionController::Parameters.new(person: { name: \"Francesco\" }).require(:person)\n # => \"Francesco\"} permitted: false>\n\n Otherwise raises ActionController::ParameterMissing :\n\n ActionController::Parameters.new.require(:person)\n # ActionController::ParameterMissing: param is missing or the value is empty: person\n\n ActionController::Parameters.new(person: nil).require(:person)\n # ActionController::ParameterMissing: param is missing or the value is empty: person\n\n ActionController::Parameters.new(person: \"\\t\").require(:person)\n # ActionController::ParameterMissing: param is missing or the value is empty: person\n\n ActionController::Parameters.new(person: {}).require(:person)\n # ActionController::ParameterMissing: param is missing or the value is empty: person\n\n When given an array of keys, the method tries to require each one of them\n in order. If it succeeds, an array with the respective return values is\n returned:\n\n params = ActionController::Parameters.new(user: { ... }, profile: { ... })\n user_params, profile_params = params.require([:user, :profile])\n\n Otherwise, the method re-raises the first exception found:\n\n params = ActionController::Parameters.new(user: {}, profile: {})\n user_params, profile_params = params.require([:user, :profile])\n # ActionController::ParameterMissing: param is missing or the value is empty: user\n\n Technically this method can be used to fetch terminal values:\n\n # CAREFUL\n params = ActionController::Parameters.new(person: { name: \"Finn\" })\n name = params.require(:person).require(:name) # CAREFUL\n\n but take into account that at some point those ones have to be permitted:\n\n def person_params\n params.require(:person).permit(:name).tap do |person_params|\n person_params.require(:name) # SAFER\n end\n end\n\n for example.", "Adds existing keys to the params if their values are scalar.\n\n For example:\n\n puts self.keys #=> [\"zipcode(90210i)\"]\n params = {}\n\n permitted_scalar_filter(params, \"zipcode\")\n\n puts params.keys # => [\"zipcode\"]", "Overwrite process to setup I18n proxy.", "Find and render a template based on the options given.", "Normalize options.", "Enqueues the job to be performed by the queue adapter.\n\n ==== Options\n * :wait - Enqueues the job with the specified delay\n * :wait_until - Enqueues the job at the time specified\n * :queue - Enqueues the job on the specified queue\n * :priority - Enqueues the job with the specified priority\n\n ==== Examples\n\n my_job_instance.enqueue\n my_job_instance.enqueue wait: 5.minutes\n my_job_instance.enqueue queue: :important\n my_job_instance.enqueue wait_until: Date.tomorrow.midnight\n my_job_instance.enqueue priority: 10", "Returns a hash of rows to be inserted. The key is the table, the value is\n a list of rows to insert to that table.", "Loads the fixtures from the YAML file at +path+.\n If the file sets the +model_class+ and current instance value is not set,\n it uses the file value.", "Efficiently downloads blob data into the given file.", "Sets an HTTP 1.1 Cache-Control header. Defaults to issuing a +private+\n instruction, so that intermediate caches must not cache the response.\n\n expires_in 20.minutes\n expires_in 3.hours, public: true\n expires_in 3.hours, public: true, must_revalidate: true\n\n This method will overwrite an existing Cache-Control header.\n See https://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html for more possibilities.\n\n HTTP Cache-Control Extensions for Stale Content. See https://tools.ietf.org/html/rfc5861\n It helps to cache an asset and serve it while is being revalidated and/or returning with an error.\n\n expires_in 3.hours, public: true, stale_while_revalidate: 60.seconds\n expires_in 3.hours, public: true, stale_while_revalidate: 60.seconds, stale_if_error: 5.minutes\n\n The method will also ensure an HTTP Date header for client compatibility.", "Cache or yield the block. The cache is supposed to never expire.\n\n You can use this method when you have an HTTP response that never changes,\n and the browser and proxies should cache it indefinitely.\n\n * +public+: By default, HTTP responses are private, cached only on the\n user's web browser. To allow proxies to cache the response, set +true+ to\n indicate that they can serve the cached response to all users.", "Executes a system command, capturing its binary output in a tempfile. Yields the tempfile.\n\n Use this method to shell out to a system library (e.g. muPDF or FFmpeg) for preview image\n generation. The resulting tempfile can be used as the +:io+ value in an attachable Hash:\n\n def preview\n download_blob_to_tempfile do |input|\n draw \"my-drawing-command\", input.path, \"--format\", \"png\", \"-\" do |output|\n yield io: output, filename: \"#{blob.filename.base}.png\", content_type: \"image/png\"\n end\n end\n end\n\n The output tempfile is opened in the directory returned by #tmpdir.", "Overwrite render_to_string because body can now be set to a Rack body.", "Normalize both text and status options.", "Process controller specific options, as status, content-type and location.", "Create a new +RemoteIp+ middleware instance.\n\n The +ip_spoofing_check+ option is on by default. When on, an exception\n is raised if it looks like the client is trying to lie about its own IP\n address. It makes sense to turn off this check on sites aimed at non-IP\n clients (like WAP devices), or behind proxies that set headers in an\n incorrect or confusing way (like AWS ELB).\n\n The +custom_proxies+ argument can take an Array of string, IPAddr, or\n Regexp objects which will be used instead of +TRUSTED_PROXIES+. If a\n single string, IPAddr, or Regexp object is provided, it will be used in\n addition to +TRUSTED_PROXIES+. Any proxy setup will put the value you\n want in the middle (or at the beginning) of the X-Forwarded-For list,\n with your proxy servers after it. If your proxies aren't removed, pass\n them in via the +custom_proxies+ parameter. That way, the middleware will\n ignore those IP addresses, and return the one that you want.\n Since the IP address may not be needed, we store the object here\n without calculating the IP to keep from slowing down the majority of\n requests. For those requests that do need to know the IP, the\n GetIp#calculate_ip method will calculate the memoized client IP address.", "Passes the record off to the class or classes specified and allows them\n to add errors based on more complex conditions.\n\n class Person\n include ActiveModel::Validations\n\n validate :instance_validations\n\n def instance_validations\n validates_with MyValidator\n end\n end\n\n Please consult the class method documentation for more information on\n creating your own validator.\n\n You may also pass it multiple classes, like so:\n\n class Person\n include ActiveModel::Validations\n\n validate :instance_validations, on: :create\n\n def instance_validations\n validates_with MyValidator, MyOtherValidator\n end\n end\n\n Standard configuration options (:on , :if and\n :unless ), which are available on the class version of\n +validates_with+, should instead be placed on the +validates+ method\n as these are applied and tested in the callback.\n\n If you pass any additional configuration options, they will be passed\n to the class and available as +options+, please refer to the\n class version of this method for more information.", "Render a template. If the template was not compiled yet, it is done\n exactly before rendering.\n\n This method is instrumented as \"!render_template.action_view\". Notice that\n we use a bang in this instrumentation because you don't want to\n consume this in production. This is only slow if it's being listened to.", "Compile a template. This method ensures a template is compiled\n just once and removes the source after it is compiled.", "Reloads the record from the database.\n\n This method finds the record by its primary key (which could be assigned\n manually) and modifies the receiver in-place:\n\n account = Account.new\n # => #\n account.id = 1\n account.reload\n # Account Load (1.2ms) SELECT \"accounts\".* FROM \"accounts\" WHERE \"accounts\".\"id\" = $1 LIMIT 1 [[\"id\", 1]]\n # => #\n\n Attributes are reloaded from the database, and caches busted, in\n particular the associations cache and the QueryCache.\n\n If the record no longer exists in the database ActiveRecord::RecordNotFound\n is raised. Otherwise, in addition to the in-place modification the method\n returns +self+ for convenience.\n\n The optional :lock flag option allows you to lock the reloaded record:\n\n reload(lock: true) # reload with pessimistic locking\n\n Reloading is commonly used in test suites to test something is actually\n written to the database, or when some action modifies the corresponding\n row in the database but not the object in memory:\n\n assert account.deposit!(25)\n assert_equal 25, account.credit # check it is updated in memory\n assert_equal 25, account.reload.credit # check it is also persisted\n\n Another common use case is optimistic locking handling:\n\n def with_optimistic_retry\n begin\n yield\n rescue ActiveRecord::StaleObjectError\n begin\n # Reload lock_version in particular.\n reload\n rescue ActiveRecord::RecordNotFound\n # If the record is gone there is nothing to do.\n else\n retry\n end\n end\n end", "Creates a masked version of the authenticity token that varies\n on each request. The masking is used to mitigate SSL attacks\n like BREACH.", "Checks the client's masked token to see if it matches the\n session token. Essentially the inverse of\n +masked_authenticity_token+.", "Checks if the request originated from the same origin by looking at the\n Origin header.", "Save the new record state and id of a record so it can be restored later if a transaction fails.", "Updates the attributes on this particular Active Record object so that\n if it's associated with a transaction, then the state of the Active Record\n object will be updated to reflect the current state of the transaction.\n\n The @transaction_state variable stores the states of the associated\n transaction. This relies on the fact that a transaction can only be in\n one rollback or commit (otherwise a list of states would be required).\n Each Active Record object inside of a transaction carries that transaction's\n TransactionState.\n\n This method checks to see if the ActiveRecord object's state reflects\n the TransactionState, and rolls back or commits the Active Record object\n as appropriate.", "Constant time string comparison, for fixed length strings.\n\n The values compared should be of fixed length, such as strings\n that have already been processed by HMAC. Raises in case of length mismatch.", "Constant time string comparison, for variable length strings.\n\n The values are first processed by SHA256, so that we don't leak length info\n via timing attacks.", "Declares a block that will be executed when a Rails component is fully\n loaded.\n\n Options:\n\n * :yield - Yields the object that run_load_hooks to +block+.\n * :run_once - Given +block+ will run only once.", "This method should return a hash with assigns.\n You can overwrite this configuration per controller.", "Normalize args and options.", "Provides options for converting numbers into formatted strings.\n Options are provided for phone numbers, currency, percentage,\n precision, positional notation, file size and pretty printing.\n\n ==== Options\n\n For details on which formats use which options, see ActiveSupport::NumberHelper\n\n ==== Examples\n\n Phone Numbers:\n 5551234.to_s(:phone) # => \"555-1234\"\n 1235551234.to_s(:phone) # => \"123-555-1234\"\n 1235551234.to_s(:phone, area_code: true) # => \"(123) 555-1234\"\n 1235551234.to_s(:phone, delimiter: ' ') # => \"123 555 1234\"\n 1235551234.to_s(:phone, area_code: true, extension: 555) # => \"(123) 555-1234 x 555\"\n 1235551234.to_s(:phone, country_code: 1) # => \"+1-123-555-1234\"\n 1235551234.to_s(:phone, country_code: 1, extension: 1343, delimiter: '.')\n # => \"+1.123.555.1234 x 1343\"\n\n Currency:\n 1234567890.50.to_s(:currency) # => \"$1,234,567,890.50\"\n 1234567890.506.to_s(:currency) # => \"$1,234,567,890.51\"\n 1234567890.506.to_s(:currency, precision: 3) # => \"$1,234,567,890.506\"\n 1234567890.506.to_s(:currency, locale: :fr) # => \"1 234 567 890,51 \u20ac\"\n -1234567890.50.to_s(:currency, negative_format: '(%u%n)')\n # => \"($1,234,567,890.50)\"\n 1234567890.50.to_s(:currency, unit: '£', separator: ',', delimiter: '')\n # => \"£1234567890,50\"\n 1234567890.50.to_s(:currency, unit: '£', separator: ',', delimiter: '', format: '%n %u')\n # => \"1234567890,50 £\"\n\n Percentage:\n 100.to_s(:percentage) # => \"100.000%\"\n 100.to_s(:percentage, precision: 0) # => \"100%\"\n 1000.to_s(:percentage, delimiter: '.', separator: ',') # => \"1.000,000%\"\n 302.24398923423.to_s(:percentage, precision: 5) # => \"302.24399%\"\n 1000.to_s(:percentage, locale: :fr) # => \"1 000,000%\"\n 100.to_s(:percentage, format: '%n %') # => \"100.000 %\"\n\n Delimited:\n 12345678.to_s(:delimited) # => \"12,345,678\"\n 12345678.05.to_s(:delimited) # => \"12,345,678.05\"\n 12345678.to_s(:delimited, delimiter: '.') # => \"12.345.678\"\n 12345678.to_s(:delimited, delimiter: ',') # => \"12,345,678\"\n 12345678.05.to_s(:delimited, separator: ' ') # => \"12,345,678 05\"\n 12345678.05.to_s(:delimited, locale: :fr) # => \"12 345 678,05\"\n 98765432.98.to_s(:delimited, delimiter: ' ', separator: ',')\n # => \"98 765 432,98\"\n\n Rounded:\n 111.2345.to_s(:rounded) # => \"111.235\"\n 111.2345.to_s(:rounded, precision: 2) # => \"111.23\"\n 13.to_s(:rounded, precision: 5) # => \"13.00000\"\n 389.32314.to_s(:rounded, precision: 0) # => \"389\"\n 111.2345.to_s(:rounded, significant: true) # => \"111\"\n 111.2345.to_s(:rounded, precision: 1, significant: true) # => \"100\"\n 13.to_s(:rounded, precision: 5, significant: true) # => \"13.000\"\n 111.234.to_s(:rounded, locale: :fr) # => \"111,234\"\n 13.to_s(:rounded, precision: 5, significant: true, strip_insignificant_zeros: true)\n # => \"13\"\n 389.32314.to_s(:rounded, precision: 4, significant: true) # => \"389.3\"\n 1111.2345.to_s(:rounded, precision: 2, separator: ',', delimiter: '.')\n # => \"1.111,23\"\n\n Human-friendly size in Bytes:\n 123.to_s(:human_size) # => \"123 Bytes\"\n 1234.to_s(:human_size) # => \"1.21 KB\"\n 12345.to_s(:human_size) # => \"12.1 KB\"\n 1234567.to_s(:human_size) # => \"1.18 MB\"\n 1234567890.to_s(:human_size) # => \"1.15 GB\"\n 1234567890123.to_s(:human_size) # => \"1.12 TB\"\n 1234567890123456.to_s(:human_size) # => \"1.1 PB\"\n 1234567890123456789.to_s(:human_size) # => \"1.07 EB\"\n 1234567.to_s(:human_size, precision: 2) # => \"1.2 MB\"\n 483989.to_s(:human_size, precision: 2) # => \"470 KB\"\n 1234567.to_s(:human_size, precision: 2, separator: ',') # => \"1,2 MB\"\n 1234567890123.to_s(:human_size, precision: 5) # => \"1.1228 TB\"\n 524288000.to_s(:human_size, precision: 5) # => \"500 MB\"\n\n Human-friendly format:\n 123.to_s(:human) # => \"123\"\n 1234.to_s(:human) # => \"1.23 Thousand\"\n 12345.to_s(:human) # => \"12.3 Thousand\"\n 1234567.to_s(:human) # => \"1.23 Million\"\n 1234567890.to_s(:human) # => \"1.23 Billion\"\n 1234567890123.to_s(:human) # => \"1.23 Trillion\"\n 1234567890123456.to_s(:human) # => \"1.23 Quadrillion\"\n 1234567890123456789.to_s(:human) # => \"1230 Quadrillion\"\n 489939.to_s(:human, precision: 2) # => \"490 Thousand\"\n 489939.to_s(:human, precision: 4) # => \"489.9 Thousand\"\n 1234567.to_s(:human, precision: 4,\n significant: false) # => \"1.2346 Million\"\n 1234567.to_s(:human, precision: 1,\n separator: ',',\n significant: false) # => \"1,2 Million\"", "Returns the config hash that corresponds with the environment\n\n If the application has multiple databases +default_hash+ will\n return the first config hash for the environment.\n\n { database: \"my_db\", adapter: \"mysql2\" }", "Returns a single DatabaseConfig object based on the requested environment.\n\n If the application has multiple databases +find_db_config+ will return\n the first DatabaseConfig for the environment.", "Returns the DatabaseConfigurations object as a Hash.", "An email was delivered.", "Returns the backtrace after all filters and silencers have been run\n against it. Filters run first, then silencers.", "Determine the template to be rendered using the given options.", "Renders the given template. A string representing the layout can be\n supplied as well.", "Set proper cache control and transfer encoding when streaming", "Call render_body if we are streaming instead of usual +render+.", "Determine the layout for a given name, taking into account the name type.\n\n ==== Parameters\n * name - The name of the template", "Returns the default layout for this controller.\n Optionally raises an exception if the layout could not be found.\n\n ==== Parameters\n * formats - The formats accepted to this layout\n * require_layout - If set to +true+ and layout is not found,\n an +ArgumentError+ exception is raised (defaults to +false+)\n\n ==== Returns\n * template - The template object for the default layout (or +nil+)", "Runs all the specified validations and returns +true+ if no errors were\n added otherwise +false+.\n\n class Person\n include ActiveModel::Validations\n\n attr_accessor :name\n validates_presence_of :name\n end\n\n person = Person.new\n person.name = ''\n person.valid? # => false\n person.name = 'david'\n person.valid? # => true\n\n Context can optionally be supplied to define which callbacks to test\n against (the context is defined on the validations using :on ).\n\n class Person\n include ActiveModel::Validations\n\n attr_accessor :name\n validates_presence_of :name, on: :new\n end\n\n person = Person.new\n person.valid? # => true\n person.valid?(:new) # => false", "Returns a message verifier object.\n\n This verifier can be used to generate and verify signed messages in the application.\n\n It is recommended not to use the same verifier for different things, so you can get different\n verifiers passing the +verifier_name+ argument.\n\n ==== Parameters\n\n * +verifier_name+ - the name of the message verifier.\n\n ==== Examples\n\n message = Rails.application.message_verifier('sensitive_data').generate('my sensible data')\n Rails.application.message_verifier('sensitive_data').verify(message)\n # => 'my sensible data'\n\n See the +ActiveSupport::MessageVerifier+ documentation for more information.", "Stores some of the Rails initial environment parameters which\n will be used by middlewares and engines to configure themselves.", "Shorthand to decrypt any encrypted configurations or files.\n\n For any file added with rails encrypted:edit call +read+ to decrypt\n the file with the master key.\n The master key is either stored in +config/master.key+ or ENV[\"RAILS_MASTER_KEY\"] .\n\n Rails.application.encrypted(\"config/mystery_man.txt.enc\").read\n # => \"We've met before, haven't we?\"\n\n It's also possible to interpret encrypted YAML files with +config+.\n\n Rails.application.encrypted(\"config/credentials.yml.enc\").config\n # => { next_guys_line: \"I don't think so. Where was it you think we met?\" }\n\n Any top-level configs are also accessible directly on the return value:\n\n Rails.application.encrypted(\"config/credentials.yml.enc\").next_guys_line\n # => \"I don't think so. Where was it you think we met?\"\n\n The files or configs can also be encrypted with a custom key. To decrypt with\n a key in the +ENV+, use:\n\n Rails.application.encrypted(\"config/special_tokens.yml.enc\", env_key: \"SPECIAL_TOKENS\")\n\n Or to decrypt with a file, that should be version control ignored, relative to +Rails.root+:\n\n Rails.application.encrypted(\"config/special_tokens.yml.enc\", key_path: \"config/special_tokens.key\")", "Returns the ordered railties for this application considering railties_order.", "Read the request \\body. This is useful for web services that need to\n work with raw requests directly.", "The request body is an IO input stream. If the RAW_POST_DATA environment\n variable is already set, wrap it in a StringIO.", "Override Rack's GET method to support indifferent access.", "Override Rack's POST method to support indifferent access.", "Sets up instance variables needed for rendering a partial. This method\n finds the options and details and extracts them. The method also contains\n logic that handles the type of object passed in as the partial.\n\n If +options[:partial]+ is a string, then the @path instance variable is\n set to that string. Otherwise, the +options[:partial]+ object must\n respond to +to_partial_path+ in order to setup the path.", "Obtains the path to where the object's partial is located. If the object\n responds to +to_partial_path+, then +to_partial_path+ will be called and\n will provide the path. If the object does not respond to +to_partial_path+,\n then an +ArgumentError+ is raised.\n\n If +prefix_partial_path_with_controller_namespace+ is true, then this\n method will prefix the partial paths with a namespace.", "Returns a serialized hash of your object.\n\n class Person\n include ActiveModel::Serialization\n\n attr_accessor :name, :age\n\n def attributes\n {'name' => nil, 'age' => nil}\n end\n\n def capitalized_name\n name.capitalize\n end\n end\n\n person = Person.new\n person.name = 'bob'\n person.age = 22\n person.serializable_hash # => {\"name\"=>\"bob\", \"age\"=>22}\n person.serializable_hash(only: :name) # => {\"name\"=>\"bob\"}\n person.serializable_hash(except: :name) # => {\"age\"=>22}\n person.serializable_hash(methods: :capitalized_name)\n # => {\"name\"=>\"bob\", \"age\"=>22, \"capitalized_name\"=>\"Bob\"}\n\n Example with :include option\n\n class User\n include ActiveModel::Serializers::JSON\n attr_accessor :name, :notes # Emulate has_many :notes\n def attributes\n {'name' => nil}\n end\n end\n\n class Note\n include ActiveModel::Serializers::JSON\n attr_accessor :title, :text\n def attributes\n {'title' => nil, 'text' => nil}\n end\n end\n\n note = Note.new\n note.title = 'Battle of Austerlitz'\n note.text = 'Some text here'\n\n user = User.new\n user.name = 'Napoleon'\n user.notes = [note]\n\n user.serializable_hash\n # => {\"name\" => \"Napoleon\"}\n user.serializable_hash(include: { notes: { only: 'title' }})\n # => {\"name\" => \"Napoleon\", \"notes\" => [{\"title\"=>\"Battle of Austerlitz\"}]}", "Returns a module with all the helpers defined for the engine.", "Returns the underlying Rack application for this engine.", "Defines the routes for this engine. If a block is given to\n routes, it is appended to the engine.", "Attaches an +attachable+ to the record.\n\n If the record is persisted and unchanged, the attachment is saved to\n the database immediately. Otherwise, it'll be saved to the DB when the\n record is next saved.\n\n person.avatar.attach(params[:avatar]) # ActionDispatch::Http::UploadedFile object\n person.avatar.attach(params[:signed_blob_id]) # Signed reference to blob from direct upload\n person.avatar.attach(io: File.open(\"/path/to/face.jpg\"), filename: \"face.jpg\", content_type: \"image/jpg\")\n person.avatar.attach(avatar_blob) # ActiveStorage::Blob object", "Reads the file for the given key in chunks, yielding each to the block.", "It accepts two parameters on initialization. The first is an array\n of files and the second is an optional hash of directories. The hash must\n have directories as keys and the value is an array of extensions to be\n watched under that directory.\n\n This method must also receive a block that will be called once a path\n changes. The array of files and list of directories cannot be changed\n after FileUpdateChecker has been initialized.\n Check if any of the entries were updated. If so, the watched and/or\n updated_at values are cached until the block is executed via +execute+\n or +execute_if_updated+.", "This method returns the maximum mtime of the files in +paths+, or +nil+\n if the array is empty.\n\n Files with a mtime in the future are ignored. Such abnormal situation\n can happen for example if the user changes the clock by hand. It is\n healthy to consider this edge case because with mtimes in the future\n reloading is not triggered.", "Allows you to measure the execution time of a block in a template and\n records the result to the log. Wrap this block around expensive operations\n or possible bottlenecks to get a time reading for the operation. For\n example, let's say you thought your file processing method was taking too\n long; you could wrap it in a benchmark block.\n\n <% benchmark 'Process data files' do %>\n <%= expensive_files_operation %>\n <% end %>\n\n That would add something like \"Process data files (345.2ms)\" to the log,\n which you can then use to compare timings when optimizing your code.\n\n You may give an optional logger level (:debug , :info ,\n :warn , :error ) as the :level option. The\n default logger level value is :info .\n\n <% benchmark 'Low-level files', level: :debug do %>\n <%= lowlevel_files_operation %>\n <% end %>\n\n Finally, you can pass true as the third argument to silence all log\n activity (other than the timing information) from inside the block. This\n is great for boiling down a noisy block to just a single statement that\n produces one log line:\n\n <% benchmark 'Process data files', level: :info, silence: true do %>\n <%= expensive_and_chatty_files_operation %>\n <% end %>", "Initializes new record from relation while maintaining the current\n scope.\n\n Expects arguments in the same format as {ActiveRecord::Base.new}[rdoc-ref:Core.new].\n\n users = User.where(name: 'DHH')\n user = users.new # => #\n\n You can also pass a block to new with the new record as argument:\n\n user = users.new { |user| user.name = 'Oscar' }\n user.name # => Oscar", "Tries to create a new record with the same scoped attributes\n defined in the relation. Returns the initialized object if validation fails.\n\n Expects arguments in the same format as\n {ActiveRecord::Base.create}[rdoc-ref:Persistence::ClassMethods#create].\n\n ==== Examples\n\n users = User.where(name: 'Oscar')\n users.create # => #\n\n users.create(name: 'fxn')\n users.create # => #\n\n users.create { |user| user.name = 'tenderlove' }\n # => #\n\n users.create(name: nil) # validation on name\n # => #", "Returns sql statement for the relation.\n\n User.where(name: 'Oscar').to_sql\n # => SELECT \"users\".* FROM \"users\" WHERE \"users\".\"name\" = 'Oscar'", "Initialize an empty model object from +attributes+.\n +attributes+ should be an attributes object, and unlike the\n `initialize` method, no assignment calls are made per attribute.", "Returns the contents of the record as a nicely formatted string.", "The main method that creates the message and renders the email templates. There are\n two ways to call this method, with a block, or without a block.\n\n It accepts a headers hash. This hash allows you to specify\n the most used headers in an email message, these are:\n\n * +:subject+ - The subject of the message, if this is omitted, Action Mailer will\n ask the Rails I18n class for a translated +:subject+ in the scope of\n [mailer_scope, action_name] or if this is missing, will translate the\n humanized version of the +action_name+\n * +:to+ - Who the message is destined for, can be a string of addresses, or an array\n of addresses.\n * +:from+ - Who the message is from\n * +:cc+ - Who you would like to Carbon-Copy on this email, can be a string of addresses,\n or an array of addresses.\n * +:bcc+ - Who you would like to Blind-Carbon-Copy on this email, can be a string of\n addresses, or an array of addresses.\n * +:reply_to+ - Who to set the Reply-To header of the email to.\n * +:date+ - The date to say the email was sent on.\n\n You can set default values for any of the above headers (except +:date+)\n by using the ::default class method:\n\n class Notifier < ActionMailer::Base\n default from: 'no-reply@test.lindsaar.net',\n bcc: 'email_logger@test.lindsaar.net',\n reply_to: 'bounces@test.lindsaar.net'\n end\n\n If you need other headers not listed above, you can either pass them in\n as part of the headers hash or use the headers['name'] = value \n method.\n\n When a +:return_path+ is specified as header, that value will be used as\n the 'envelope from' address for the Mail message. Setting this is useful\n when you want delivery notifications sent to a different address than the\n one in +:from+. Mail will actually use the +:return_path+ in preference\n to the +:sender+ in preference to the +:from+ field for the 'envelope\n from' value.\n\n If you do not pass a block to the +mail+ method, it will find all\n templates in the view paths using by default the mailer name and the\n method name that it is being called from, it will then create parts for\n each of these templates intelligently, making educated guesses on correct\n content type and sequence, and return a fully prepared Mail::Message \n ready to call :deliver on to send.\n\n For example:\n\n class Notifier < ActionMailer::Base\n default from: 'no-reply@test.lindsaar.net'\n\n def welcome\n mail(to: 'mikel@test.lindsaar.net')\n end\n end\n\n Will look for all templates at \"app/views/notifier\" with name \"welcome\".\n If no welcome template exists, it will raise an ActionView::MissingTemplate error.\n\n However, those can be customized:\n\n mail(template_path: 'notifications', template_name: 'another')\n\n And now it will look for all templates at \"app/views/notifications\" with name \"another\".\n\n If you do pass a block, you can render specific templates of your choice:\n\n mail(to: 'mikel@test.lindsaar.net') do |format|\n format.text\n format.html\n end\n\n You can even render plain text directly without using a template:\n\n mail(to: 'mikel@test.lindsaar.net') do |format|\n format.text { render plain: \"Hello Mikel!\" }\n format.html { render html: \"Hello Mikel! \".html_safe }\n end\n\n Which will render a +multipart/alternative+ email with +text/plain+ and\n +text/html+ parts.\n\n The block syntax also allows you to customize the part headers if desired:\n\n mail(to: 'mikel@test.lindsaar.net') do |format|\n format.text(content_transfer_encoding: \"base64\")\n format.html\n end", "Attaches one or more +attachables+ to the record.\n\n If the record is persisted and unchanged, the attachments are saved to\n the database immediately. Otherwise, they'll be saved to the DB when the\n record is next saved.\n\n document.images.attach(params[:images]) # Array of ActionDispatch::Http::UploadedFile objects\n document.images.attach(params[:signed_blob_id]) # Signed reference to blob from direct upload\n document.images.attach(io: File.open(\"/path/to/racecar.jpg\"), filename: \"racecar.jpg\", content_type: \"image/jpg\")\n document.images.attach([ first_blob, second_blob ])", "Sets the HTTP character set. In case of +nil+ parameter\n it sets the charset to +default_charset+.\n\n response.charset = 'utf-16' # => 'utf-16'\n response.charset = nil # => 'utf-8'", "Returns the number of days to the start of the week on the given day.\n Week is assumed to start on +start_day+, default is\n +Date.beginning_of_week+ or +config.beginning_of_week+ when set.", "remote_send sends a request to the remote endpoint.\n\n It blocks until the remote endpoint accepts the message.\n\n @param req [Object, String] the object to send or it's marshal form.\n @param marshalled [false, true] indicates if the object is already\n marshalled.", "send_status sends a status to the remote endpoint.\n\n @param code [int] the status code to send\n @param details [String] details\n @param assert_finished [true, false] when true(default), waits for\n FINISHED.\n @param metadata [Hash] metadata to send to the server. If a value is a\n list, mulitple metadata for its key are sent", "remote_read reads a response from the remote endpoint.\n\n It blocks until the remote endpoint replies with a message or status.\n On receiving a message, it returns the response after unmarshalling it.\n On receiving a status, it returns nil if the status is OK, otherwise\n raising BadStatus", "each_remote_read passes each response to the given block or returns an\n enumerator the responses if no block is given.\n Used to generate the request enumerable for\n server-side client-streaming RPC's.\n\n == Enumerator ==\n\n * #next blocks until the remote endpoint sends a READ or FINISHED\n * for each read, enumerator#next yields the response\n * on status\n * if it's is OK, enumerator#next raises StopException\n * if is not OK, enumerator#next raises RuntimeException\n\n == Block ==\n\n * if provided it is executed for each response\n * the call blocks until no more responses are provided\n\n @return [Enumerator] if no block was given", "each_remote_read_then_finish passes each response to the given block or\n returns an enumerator of the responses if no block is given.\n\n It is like each_remote_read, but it blocks on finishing on detecting\n the final message.\n\n == Enumerator ==\n\n * #next blocks until the remote endpoint sends a READ or FINISHED\n * for each read, enumerator#next yields the response\n * on status\n * if it's is OK, enumerator#next raises StopException\n * if is not OK, enumerator#next raises RuntimeException\n\n == Block ==\n\n * if provided it is executed for each response\n * the call blocks until no more responses are provided\n\n @return [Enumerator] if no block was given", "request_response sends a request to a GRPC server, and returns the\n response.\n\n @param req [Object] the request sent to the server\n @param metadata [Hash] metadata to be sent to the server. If a value is\n a list, multiple metadata for its key are sent\n @return [Object] the response received from the server", "client_streamer sends a stream of requests to a GRPC server, and\n returns a single response.\n\n requests provides an 'iterable' of Requests. I.e. it follows Ruby's\n #each enumeration protocol. In the simplest case, requests will be an\n array of marshallable objects; in typical case it will be an Enumerable\n that allows dynamic construction of the marshallable objects.\n\n @param requests [Object] an Enumerable of requests to send\n @param metadata [Hash] metadata to be sent to the server. If a value is\n a list, multiple metadata for its key are sent\n @return [Object] the response received from the server", "server_streamer sends one request to the GRPC server, which yields a\n stream of responses.\n\n responses provides an enumerator over the streamed responses, i.e. it\n follows Ruby's #each iteration protocol. The enumerator blocks while\n waiting for each response, stops when the server signals that no\n further responses will be supplied. If the implicit block is provided,\n it is executed with each response as the argument and no result is\n returned.\n\n @param req [Object] the request sent to the server\n @param metadata [Hash] metadata to be sent to the server. If a value is\n a list, multiple metadata for its key are sent\n @return [Enumerator|nil] a response Enumerator", "bidi_streamer sends a stream of requests to the GRPC server, and yields\n a stream of responses.\n\n This method takes an Enumerable of requests, and returns and enumerable\n of responses.\n\n == requests ==\n\n requests provides an 'iterable' of Requests. I.e. it follows Ruby's\n #each enumeration protocol. In the simplest case, requests will be an\n array of marshallable objects; in typical case it will be an\n Enumerable that allows dynamic construction of the marshallable\n objects.\n\n == responses ==\n\n This is an enumerator of responses. I.e, its #next method blocks\n waiting for the next response. Also, if at any point the block needs\n to consume all the remaining responses, this can be done using #each or\n #collect. Calling #each or #collect should only be done if\n the_call#writes_done has been called, otherwise the block will loop\n forever.\n\n @param requests [Object] an Enumerable of requests to send\n @param metadata [Hash] metadata to be sent to the server. If a value is\n a list, multiple metadata for its key are sent\n @return [Enumerator, nil] a response Enumerator", "run_server_bidi orchestrates a BiDi stream processing on a server.\n\n N.B. gen_each_reply is a func(Enumerable)\n\n It takes an enumerable of requests as an arg, in case there is a\n relationship between the stream of requests and the stream of replies.\n\n This does not mean that must necessarily be one. E.g, the replies\n produced by gen_each_reply could ignore the received_msgs\n\n @param mth [Proc] generates the BiDi stream replies\n @param interception_ctx [InterceptionContext]", "Creates a BidiCall.\n\n BidiCall should only be created after a call is accepted. That means\n different things on a client and a server. On the client, the call is\n accepted after call.invoke. On the server, this is after call.accept.\n\n #initialize cannot determine if the call is accepted or not; so if a\n call that's not accepted is used here, the error won't be visible until\n the BidiCall#run is called.\n\n deadline is the absolute deadline for the call.\n\n @param call [Call] the call used by the ActiveCall\n @param marshal [Function] f(obj)->string that marshal requests\n @param unmarshal [Function] f(string)->obj that unmarshals responses\n @param metadata_received [true|false] indicates if metadata has already\n been received. Should always be true for server calls\n Begins orchestration of the Bidi stream for a client sending requests.\n\n The method either returns an Enumerator of the responses, or accepts a\n block that can be invoked with each response.\n\n @param requests the Enumerable of requests to send\n @param set_input_stream_done [Proc] called back when we're done\n reading the input stream\n @param set_output_stream_done [Proc] called back when we're done\n sending data on the output stream\n @return an Enumerator of requests to yield", "Begins orchestration of the Bidi stream for a server generating replies.\n\n N.B. gen_each_reply is a func(Enumerable)\n\n It takes an enumerable of requests as an arg, in case there is a\n relationship between the stream of requests and the stream of replies.\n\n This does not mean that must necessarily be one. E.g, the replies\n produced by gen_each_reply could ignore the received_msgs\n\n @param [Proc] gen_each_reply generates the BiDi stream replies.\n @param [Enumerable] requests The enumerable of requests to run", "performs a read using @call.run_batch, ensures metadata is set up", "set_output_stream_done is relevant on client-side", "Provides an enumerator that yields results of remote reads", "Runs the given block on the queue with the provided args.\n\n @param args the args passed blk when it is called\n @param blk the block to call", "Starts running the jobs in the thread pool.", "Stops the jobs in the pool", "Forcibly shutdown any threads that are still alive.", "Creates a new RpcServer.\n\n The RPC server is configured using keyword arguments.\n\n There are some specific keyword args used to configure the RpcServer\n instance.\n\n * pool_size: the size of the thread pool the server uses to run its\n threads. No more concurrent requests can be made than the size\n of the thread pool\n\n * max_waiting_requests: Deprecated due to internal changes to the thread\n pool. This is still an argument for compatibility but is ignored.\n\n * poll_period: The amount of time in seconds to wait for\n currently-serviced RPC's to finish before cancelling them when shutting\n down the server.\n\n * pool_keep_alive: The amount of time in seconds to wait\n for currently busy thread-pool threads to finish before\n forcing an abrupt exit to each thread.\n\n * connect_md_proc:\n when non-nil is a proc for determining metadata to send back the client\n on receiving an invocation req. The proc signature is:\n {key: val, ..} func(method_name, {key: val, ...})\n\n * server_args:\n A server arguments hash to be passed down to the underlying core server\n\n * interceptors:\n Am array of GRPC::ServerInterceptor objects that will be used for\n intercepting server handlers to provide extra functionality.\n Interceptors are an EXPERIMENTAL API.\n\n stops a running server\n\n the call has no impact if the server is already stopped, otherwise\n server's current call loop is it's last.", "Can only be called while holding @run_mutex", "handle registration of classes\n\n service is either a class that includes GRPC::GenericService and whose\n #new function can be called without argument or any instance of such a\n class.\n\n E.g, after\n\n class Divider\n include GRPC::GenericService\n rpc :div DivArgs, DivReply # single request, single response\n def initialize(optional_arg='default option') # no args\n ...\n end\n\n srv = GRPC::RpcServer.new(...)\n\n # Either of these works\n\n srv.handle(Divider)\n\n # or\n\n srv.handle(Divider.new('replace optional arg'))\n\n It raises RuntimeError:\n - if service is not valid service class or object\n - its handler methods are already registered\n - if the server is already running\n\n @param service [Object|Class] a service class or object as described\n above", "runs the server\n\n - if no rpc_descs are registered, this exits immediately, otherwise it\n continues running permanently and does not return until program exit.\n\n - #running? returns true after this is called, until #stop cause the\n the server to stop.", "runs the server with signal handlers\n @param signals\n List of String, Integer or both representing signals that the user\n would like to send to the server for graceful shutdown\n @param wait_interval (optional)\n Integer seconds that user would like stop_server_thread to poll\n stop_server", "Sends RESOURCE_EXHAUSTED if there are too many unprocessed jobs", "Sends UNIMPLEMENTED if the method is not implemented by this server", "handles calls to the server", "Creates a new ClientStub.\n\n Minimally, a stub is created with the just the host of the gRPC service\n it wishes to access, e.g.,\n\n my_stub = ClientStub.new(example.host.com:50505,\n :this_channel_is_insecure)\n\n If a channel_override argument is passed, it will be used as the\n underlying channel. Otherwise, the channel_args argument will be used\n to construct a new underlying channel.\n\n There are some specific keyword args that are not used to configure the\n channel:\n\n - :channel_override\n when present, this must be a pre-created GRPC::Core::Channel. If it's\n present the host and arbitrary keyword arg areignored, and the RPC\n connection uses this channel.\n\n - :timeout\n when present, this is the default timeout used for calls\n\n @param host [String] the host the stub connects to\n @param creds [Core::ChannelCredentials|Symbol] the channel credentials, or\n :this_channel_is_insecure, which explicitly indicates that the client\n should be created with an insecure connection. Note: this argument is\n ignored if the channel_override argument is provided.\n @param channel_override [Core::Channel] a pre-created channel\n @param timeout [Number] the default timeout to use in requests\n @param propagate_mask [Number] A bitwise combination of flags in\n GRPC::Core::PropagateMasks. Indicates how data should be propagated\n from parent server calls to child client calls if this client is being\n used within a gRPC server.\n @param channel_args [Hash] the channel arguments. Note: this argument is\n ignored if the channel_override argument is provided.\n @param interceptors [Array] An array of\n GRPC::ClientInterceptor objects that will be used for\n intercepting calls before they are executed\n Interceptors are an EXPERIMENTAL API.\n request_response sends a request to a GRPC server, and returns the\n response.\n\n == Flow Control ==\n This is a blocking call.\n\n * it does not return until a response is received.\n\n * the requests is sent only when GRPC core's flow control allows it to\n be sent.\n\n == Errors ==\n An RuntimeError is raised if\n\n * the server responds with a non-OK status\n\n * the deadline is exceeded\n\n == Return Value ==\n\n If return_op is false, the call returns the response\n\n If return_op is true, the call returns an Operation, calling execute\n on the Operation returns the response.\n\n @param method [String] the RPC method to call on the GRPC server\n @param req [Object] the request sent to the server\n @param marshal [Function] f(obj)->string that marshals requests\n @param unmarshal [Function] f(string)->obj that unmarshals responses\n @param deadline [Time] (optional) the time the request should complete\n @param return_op [true|false] return an Operation if true\n @param parent [Core::Call] a prior call whose reserved metadata\n will be propagated by this one.\n @param credentials [Core::CallCredentials] credentials to use when making\n the call\n @param metadata [Hash] metadata to be sent to the server\n @return [Object] the response received from the server", "Creates a new active stub\n\n @param method [string] the method being called.\n @param marshal [Function] f(obj)->string that marshals requests\n @param unmarshal [Function] f(string)->obj that unmarshals responses\n @param parent [Grpc::Call] a parent call, available when calls are\n made from server\n @param credentials [Core::CallCredentials] credentials to use when making\n the call", "Lookup a Liquid variable in the given context.\n\n context - the Liquid context in question.\n variable - the variable name, as a string.\n\n Returns the value of the variable in the context\n or the variable name if not found.", "Determine which converters to use based on this document's\n extension.\n\n Returns Array of Converter instances.", "Prepare payload and render the document\n\n Returns String rendered document output", "Render the document.\n\n Returns String rendered document output\n rubocop: disable AbcSize", "Render layouts and place document content inside.\n\n Returns String rendered content", "Checks if the layout specified in the document actually exists\n\n layout - the layout to check\n Returns nothing", "Render layout content into document.output\n\n Returns String rendered content", "Set page content to payload and assign pager if document has one.\n\n Returns nothing", "Read Site data from disk and load it into internal data structures.\n\n Returns nothing.", "Recursively traverse directories with the read_directories function.\n\n base - The String representing the site's base directory.\n dir - The String representing the directory to traverse down.\n dot_dirs - The Array of subdirectories in the dir.\n\n Returns nothing.", "Read the entries from a particular directory for processing\n\n dir - The String representing the relative path of the directory to read.\n subfolder - The String representing the directory to read.\n\n Returns the list of entries to process", "Write static files, pages, and posts.\n\n Returns nothing.", "Construct a Hash of Posts indexed by the specified Post attribute.\n\n post_attr - The String name of the Post attribute.\n\n Examples\n\n post_attr_hash('categories')\n # => { 'tech' => [, ],\n # 'ruby' => [] }\n\n Returns the Hash: { attr => posts } where\n attr - One of the values for the requested attribute.\n posts - The Array of Posts with the given attr value.", "Get the implementation class for the given Converter.\n Returns the Converter instance implementing the given Converter.\n klass - The Class of the Converter to fetch.", "klass - class or module containing the subclasses.\n Returns array of instances of subclasses of parameter.\n Create array of instances of the subclasses of the class or module\n passed in as argument.", "Get all the documents\n\n Returns an Array of all Documents", "Disable Marshaling cache to disk in Safe Mode", "Finds a default value for a given setting, filtered by path and type\n\n path - the path (relative to the source) of the page,\n post or :draft the default is used in\n type - a symbol indicating whether a :page,\n a :post or a :draft calls this method\n\n Returns the default value or nil if none was found", "Collects a hash with all default values for a page or post\n\n path - the relative path of the page or post\n type - a symbol indicating the type (:post, :page or :draft)\n\n Returns a hash with all default values (an empty hash if there are none)", "Returns a list of valid sets\n\n This is not cached to allow plugins to modify the configuration\n and have their changes take effect\n\n Returns an array of hashes", "Retrieve a cached item\n Raises if key does not exist in cache\n\n Returns cached value", "Add an item to cache\n\n Returns nothing.", "Remove one particular item from the cache\n\n Returns nothing.", "Check if `key` already exists in this cache\n\n Returns true if key exists in the cache, false otherwise", "Given a hashed key, return the path to where this item would be saved on disk.", "Render Liquid in the content\n\n content - the raw Liquid content to render\n payload - the payload for Liquid\n info - the info for Liquid\n\n Returns the converted content", "Convert this Convertible's data to a Hash suitable for use by Liquid.\n\n Returns the Hash representation of this Convertible.", "Recursively render layouts\n\n layouts - a list of the layouts\n payload - the payload for Liquid\n info - the info for Liquid\n\n Returns nothing", "Add any necessary layouts to this convertible document.\n\n payload - The site payload Drop or Hash.\n layouts - A Hash of {\"name\" => \"layout\"}.\n\n Returns nothing.", "Require each of the runtime_dependencies specified by the theme's gemspec.\n\n Returns false only if no dependencies have been specified, otherwise nothing.", "Require all .rb files if safe mode is off\n\n Returns nothing.", "Initialize a new StaticFile.\n\n site - The Site.\n base - The String path to the .\n dir - The String path between and the file.\n name - The String filename of the file.\n rubocop: disable ParameterLists\n rubocop: enable ParameterLists\n Returns source file path.", "Merge some data in with this document's data.\n\n Returns the merged data.", "Merges a master hash with another hash, recursively.\n\n master_hash - the \"parent\" hash whose values will be overridden\n other_hash - the other hash whose values will be persisted after the merge\n\n This code was lovingly stolen from some random gem:\n http://gemjack.com/gems/tartan-0.1.1/classes/Hash.html\n\n Thanks to whoever made it.", "Read array from the supplied hash favouring the singular key\n and then the plural key, and handling any nil entries.\n\n hash - the hash to read from\n singular_key - the singular key\n plural_key - the plural key\n\n Returns an array", "Determine whether the given content string contains Liquid Tags or Vaiables\n\n Returns true is the string contains sequences of `{%` or `{{`", "Add an appropriate suffix to template so that it matches the specified\n permalink style.\n\n template - permalink template without trailing slash or file extension\n permalink_style - permalink style, either built-in or custom\n\n The returned permalink template will use the same ending style as\n specified in permalink_style. For example, if permalink_style contains a\n trailing slash (or is :pretty, which indirectly has a trailing slash),\n then so will the returned template. If permalink_style has a trailing\n \":output_ext\" (or is :none, :date, or :ordinal) then so will the returned\n template. Otherwise, template will be returned without modification.\n\n Examples:\n add_permalink_suffix(\"/:basename\", :pretty)\n # => \"/:basename/\"\n\n add_permalink_suffix(\"/:basename\", :date)\n # => \"/:basename:output_ext\"\n\n add_permalink_suffix(\"/:basename\", \"/:year/:month/:title/\")\n # => \"/:basename/\"\n\n add_permalink_suffix(\"/:basename\", \"/:year/:month/:title\")\n # => \"/:basename\"\n\n Returns the updated permalink template", "Replace each character sequence with a hyphen.\n\n See Utils#slugify for a description of the character sequence specified\n by each mode.", "Extract information from the page filename.\n\n name - The String filename of the page file.\n\n NOTE: `String#gsub` removes all trailing periods (in comparison to `String#chomp`)\n Returns nothing.", "Add any necessary layouts to this post\n\n layouts - The Hash of {\"name\" => \"layout\"}.\n site_payload - The site payload Hash.\n\n Returns String rendered page.", "Filters an array of objects against an expression\n\n input - the object array\n variable - the variable to assign each item to in the expression\n expression - a Liquid comparison expression passed in as a string\n\n Returns the filtered array of objects", "Sort an array of objects\n\n input - the object array\n property - property within each object to filter by\n nils ('first' | 'last') - nils appear before or after non-nil values\n\n Returns the filtered array of objects", "Sort the input Enumerable by the given property.\n If the property doesn't exist, return the sort order respective of\n which item doesn't have the property.\n We also utilize the Schwartzian transform to make this more efficient.", "`where` filter helper", "All the entries in this collection.\n\n Returns an Array of file paths to the documents in this collection\n relative to the collection's directory", "The full path to the directory containing the collection, with\n optional subpaths.\n\n *files - (optional) any other path pieces relative to the\n directory to append to the path\n\n Returns a String containing th directory name where the collection\n is stored on the filesystem.", "Add a path to the metadata\n\n Returns true, also on failure.", "Add a dependency of a path\n\n Returns nothing.", "Write the metadata to disk\n\n Returns nothing.", "Fetches the finished configuration for a given path. This will try to look for a specific value\n and fallback to a default value if nothing was found", "Use absolute paths instead of relative", "this endpoint is used by Xcode to fetch provisioning profiles.\n The response is an xml plist but has the added benefit of containing the appId of each provisioning profile.\n\n Use this method over `provisioning_profiles` if possible because no secondary API calls are necessary to populate the ProvisioningProfile data model.", "Ensures that there are csrf tokens for the appropriate entity type\n Relies on store_csrf_tokens to set csrf_tokens to the appropriate value\n then stores that in the correct place in cache\n This method also takes a block, if you want to send a custom request, instead of\n calling `.all` on the given klass. This is used for provisioning profiles.", "puts the screenshot into the frame", "Everything below is related to title, background, etc. and is not used in the easy mode\n\n this is used to correct the 1:1 offset information\n the offset information is stored to work for the template images\n since we resize the template images to have higher quality screenshots\n we need to modify the offset information by a certain factor", "Horizontal adding around the frames", "Minimum height for the title", "Returns a correctly sized background image", "Resize the frame as it's too low quality by default", "Add the title above or below the device", "This will build up to 2 individual images with the title and optional keyword, which will then be added to the real image", "Fetches the title + keyword for this particular screenshot", "The font we want to use", "If itc_provider was explicitly specified, use it.\n If there are multiple teams, infer the provider from the selected team name.\n If there are fewer than two teams, don't infer the provider.", "Responsible for setting all required header attributes for the requests\n to succeed", "Uploads the modified package back to App Store Connect\n @param app_id [Integer] The unique App ID\n @param dir [String] the path in which the package file is located\n @return (Bool) True if everything worked fine\n @raise [Deliver::TransporterTransferError] when something went wrong\n when transferring", "Returns the password to be used with the transporter", "Tells the user how to get an application specific password", "Used when creating a new certificate or profile", "Helpers\n Every installation setup that needs an Xcode project should\n call this method", "Set a new team ID which will be used from now on", "Returns preferred path for storing cookie\n for two step verification.", "Handles the paging for you... for free\n Just pass a block and use the parameter as page number", "Authenticates with Apple's web services. This method has to be called once\n to generate a valid session. The session will automatically be used from then\n on.\n\n This method will automatically use the username from the Appfile (if available)\n and fetch the password from the Keychain (if available)\n\n @param user (String) (optional): The username (usually the email address)\n @param password (String) (optional): The password\n\n @raise InvalidUserCredentialsError: raised if authentication failed\n\n @return (Spaceship::Client) The client the login method was called for", "This method is used for both the Apple Dev Portal and App Store Connect\n This will also handle 2 step verification and 2 factor authentication\n\n It is called in `send_login_request` of sub classes (which the method `login`, above, transferred over to via `do_login`)", "Get contract messages from App Store Connect's \"olympus\" endpoint", "This also gets called from subclasses", "Actually sends the request to the remote server\n Automatically retries the request up to 3 times if something goes wrong", "Returns a path relative to FastlaneFolder.path\n This is needed as the Preview.html file is located inside FastlaneFolder.path", "Renders all data available to quickly see if everything was correctly generated.\n @param export_path (String) The path to a folder where the resulting HTML file should be stored.", "Execute shell command", "pass an array of device types", "Append a lane to the current Fastfile template we're generating", "This method is responsible for ensuring there is a working\n Gemfile, and that `fastlane` is defined as a dependency\n while also having `rubygems` as a gem source", "Parses command options and executes actions", "Add entry to Apple Keychain using AccountManager", "This method takes care of creating a new 'deliver' folder, containing the app metadata\n and screenshots folders", "Checks if the gem name is still free on RubyGems", "Applies a series of replacement rules to turn the requested plugin name into one\n that is acceptable, returning that suggestion", "Hash of available signing identities", "Initializes the listing to use the given api client, language, and fills it with the current listing if available\n Updates the listing in the current edit", "Call this method to ask the user to re-enter the credentials\n @param force: if false, the user is asked before it gets deleted\n @return: Did the user decide to remove the old entry and enter a new password?", "Use env variables from this method to augment internet password item with additional data.\n These variables are used by Xamarin Studio to authenticate Apple developers.", "Called just as the investigation has begun.", "Called once the inspector has received a report with more than one issue.", "Shows a team selection for the user in the terminal. This should not be\n called on CI systems\n\n @param team_id (String) (optional): The ID of an App Store Connect team\n @param team_name (String) (optional): The name of an App Store Connect team", "Sometimes we get errors or info nested in our data\n This method allows you to pass in a set of keys to check for\n along with the name of the sub_section of your original data\n where we should check\n Returns a mapping of keys to data array if we find anything, otherwise, empty map", "Creates a new application on App Store Connect\n @param name (String): The name of your app as it will appear on the App Store.\n This can't be longer than 255 characters.\n @param primary_language (String): If localized app information isn't available in an\n App Store territory, the information from your primary language will be used instead.\n @param version *DEPRECATED: Use `Spaceship::Tunes::Application.ensure_version!` method instead*\n (String): The version number is shown on the App Store and should match the one you used in Xcode.\n @param sku (String): A unique ID for your app that is not visible on the App Store.\n @param bundle_id (String): The bundle ID must match the one you used in Xcode. It\n can't be changed after you submit your first build.", "Returns an array of all available pricing tiers\n\n @note Although this information is publicly available, the current spaceship implementation requires you to have a logged in client to access it\n\n @return [Array] the PricingTier objects (Spaceship::Tunes::PricingTier)\n [{\n \"tierStem\": \"0\",\n \"tierName\": \"Free\",\n \"pricingInfo\": [{\n \"country\": \"United States\",\n \"countryCode\": \"US\",\n \"currencySymbol\": \"$\",\n \"currencyCode\": \"USD\",\n \"wholesalePrice\": 0.0,\n \"retailPrice\": 0.0,\n \"fRetailPrice\": \"$0.00\",\n \"fWholesalePrice\": \"$0.00\"\n }, {\n ...\n }, {\n ...", "Returns an array of all supported territories\n\n @note Although this information is publicly available, the current spaceship implementation requires you to have a logged in client to access it\n\n @return [Array] the Territory objects (Spaceship::Tunes::Territory)", "Uploads a watch icon\n @param app_version (AppVersion): The version of your app\n @param upload_image (UploadFile): The icon to upload\n @return [JSON] the response", "Uploads an In-App-Purchase Review screenshot\n @param app_id (AppId): The id of the app\n @param upload_image (UploadFile): The icon to upload\n @return [JSON] the screenshot data, ready to be added to an In-App-Purchase", "Uploads a screenshot\n @param app_version (AppVersion): The version of your app\n @param upload_image (UploadFile): The image to upload\n @param device (string): The target device\n @param is_messages (Bool): True if the screenshot is for iMessage\n @return [JSON] the response", "Uploads an iMessage screenshot\n @param app_version (AppVersion): The version of your app\n @param upload_image (UploadFile): The image to upload\n @param device (string): The target device\n @return [JSON] the response", "Uploads the trailer preview\n @param app_version (AppVersion): The version of your app\n @param upload_trailer_preview (UploadFile): The trailer preview to upload\n @param device (string): The target device\n @return [JSON] the response", "Fetches the App Version Reference information from ITC\n @return [AppVersionRef] the response", "All build trains, even if there is no TestFlight", "updates an In-App-Purchases-Family", "updates an In-App-Purchases", "Creates an In-App-Purchases", "generates group hash used in the analytics time_series API.\n Using rank=DESCENDING and limit=3 as this is what the App Store Connect analytics dashboard uses.", "This is its own method so that it can re-try if the tests fail randomly\n @return true/false depending on if the tests succeeded", "Returns true if it succeeded", "Verifies the default value is also valid", "This method takes care of parsing and using the configuration file as values\n Call this once you know where the config file might be located\n Take a look at how `gym` uses this method\n\n @param config_file_name [String] The name of the configuration file to use (optional)\n @param block_for_missing [Block] A ruby block that is called when there is an unknown method\n in the configuration file", "Allows the user to call an action from an action", "Makes sure to get the value for the language\n Instead of using the user's value `UK English` spaceship should send\n `English_UK` to the server", "lookup if an alias exists", "This is being called from `method_missing` from the Fastfile\n It's also used when an action is called from another action\n @param from_action Indicates if this action is being trigged by another action.\n If so, it won't show up in summary.", "Called internally to setup the runner object\n\n @param lane [Lane] A lane object", "Makes sure a Fastfile is available\n Shows an appropriate message to the user\n if that's not the case\n return true if the Fastfile is available", "Make sure the version on App Store Connect matches the one in the ipa\n If not, the new version will automatically be created", "Upload all metadata, screenshots, pricing information, etc. to App Store Connect", "Upload the binary to App Store Connect", "Upload binary apk and obb and corresponding change logs with client\n\n @param [String] apk_path\n Path of the apk file to upload.\n\n @return [Integer] The apk version code returned after uploading, or nil if there was a problem", "returns only language directories from metadata_path", "searches for obbs in the directory where the apk is located and\n upload at most one main and one patch file. Do nothing if it finds\n more than one of either of them.", "Calls the appropriate methods for commander to show the available parameters", "Intialize with values from Scan.config matching these param names", "Aborts the current edit deleting all pending changes", "Commits the current edit saving all pending changes on Google Play", "Returns the listing for the given language filled with the current values if it already exists", "Get a list of all APK version codes - returns the list of version codes", "Get a list of all AAB version codes - returns the list of version codes", "Get list of version codes for track", "Returns an array of gems that are added to the Gemfile or Pluginfile", "Check if a plugin is added as dependency to either the\n Gemfile or the Pluginfile", "Modify the user's Gemfile to load the plugins", "Prints a table all the plugins that were loaded", "Some device commands fail if executed against a device path that does not exist, so this helper method\n provides a way to conditionally execute a block only if the provided path exists on the device.", "Return an array of packages that are installed on the device", "Fetches a profile matching the user's search requirements", "Create a new profile and return it", "Certificate to use based on the current distribution mode", "Downloads and stores the provisioning profile", "Makes sure the current App ID exists. If not, it will show an appropriate error message", "Download all valid provisioning profiles", "we got a server control command from the client to do something like shutdown", "send json back to client", "execute fastlane action command", "Get all available schemes in an array", "Let the user select a scheme\n Use a scheme containing the preferred_to_include string when multiple schemes were found", "Get all available configurations in an array", "Returns the build settings and sets the default scheme to the options hash", "Print tables to ask the user", "Make sure to call `load_from_filesystem` before calling upload", "Uploads metadata individually by language to help identify exactly which items have issues", "Makes sure all languages we need are actually created", "Loads the metadata files and stores them into the options object", "Normalizes languages keys from symbols to strings", "Identifies the resolution of a video or an image.\n Supports all video and images required by DU-UTC right now\n @param path (String) the path to the file", "Some actions have special handling in fast_file.rb, that means we can't directly call the action\n but we have to use the same logic that is in fast_file.rb instead.\n That's where this switch statement comes into play", "Builds the app and prepares the archive", "Post-processing of build_app", "Moves over the binary and dsym file to the output directory\n @return (String) The path to the resulting ipa file", "Copies the .app from the archive into the output directory", "Move the manifest.plist if exists into the output directory", "Move the app-thinning.plist file into the output directory", "Move the App Thinning Size Report.txt file into the output directory", "Move the Apps folder to the output directory", "compares the new file content to the old and figures out what api_version the new content should be", "expects format to be \"X.Y.Z\" where each value is a number", "Override Appfile configuration for a specific lane.\n\n lane_name - Symbol representing a lane name. (Can be either :name, 'name' or 'platform name')\n block - Block to execute to override configuration values.\n\n Discussion If received lane name does not match the lane name available as environment variable, no changes will\n be applied.", "compares source file against the target file's FastlaneRunnerAPIVersion and returned `true` if there is a difference", "currently just copies file, even if not needed.", "exceptions that happen in worker threads simply cause that thread\n to die and another to be spawned in its place.", "Write the character ch as part of a JSON string, escaping as appropriate.", "Write out the contents of the string str as a JSON string, escaping characters as appropriate.", "Write out the contents of the string as JSON string, base64-encoding\n the string's contents, and escaping as appropriate", "Convert the given double to a JSON string, which is either the number,\n \"NaN\" or \"Infinity\" or \"-Infinity\".", "Decodes the four hex parts of a JSON escaped string character and returns\n the character via out.\n\n Note - this only supports Unicode characters in the BMP (U+0000 to U+FFFF);\n characters above the BMP are encoded as two escape sequences (surrogate pairs),\n which is not yet implemented", "Decodes a JSON string, including unescaping, and returns the string via str", "Reads a block of base64 characters, decoding it, and returns via str", "Reads a sequence of characters, stopping at the first one that is not\n a valid JSON numeric character.", "Reads a sequence of characters and assembles them into a number,\n returning them via num", "Reads a JSON number or string and interprets it as a double.", "Writes a field based on the field information, field ID and value.\n\n field_info - A Hash containing the definition of the field:\n :name - The name of the field.\n :type - The type of the field, which must be a Thrift::Types constant.\n :binary - A Boolean flag that indicates if Thrift::Types::STRING is a binary string (string without encoding).\n fid - The ID of the field.\n value - The field's value to write; object type varies based on :type.\n\n Returns nothing.", "Writes a field value based on the field information.\n\n field_info - A Hash containing the definition of the field:\n :type - The Thrift::Types constant that determines how the value is written.\n :binary - A Boolean flag that indicates if Thrift::Types::STRING is a binary string (string without encoding).\n value - The field's value to write; object type varies based on field_info[:type].\n\n Returns nothing.", "Reads a field value based on the field information.\n\n field_info - A Hash containing the pertinent data to write:\n :type - The Thrift::Types constant that determines how the value is written.\n :binary - A flag that indicates if Thrift::Types::STRING is a binary string (string without encoding).\n\n Returns the value read; object type varies based on field_info[:type].", "The workhorse of writeFieldBegin. It has the option of doing a\n 'type override' of the type header. This is used specifically in the\n boolean field case.", "Abstract method for writing the start of lists and sets. List and sets on\n the wire differ only by the type indicator.", "Reads a number of bytes from the transport into the buffer passed.\n\n buffer - The String (byte buffer) to write data to; this is assumed to have a BINARY encoding.\n size - The number of bytes to read from the transport and write to the buffer.\n\n Returns the number of bytes read.", "1-based index into the fibonacci sequence", "Writes the output buffer to the stream in the format of a 4-byte length\n followed by the actual data.", "Parse an input into a URI object, optionally resolving it\n against a base URI if given.\n\n A URI object will have the following properties: scheme,\n userinfo, host, port, registry, path, opaque, query, and\n fragment.", "Escape a string for use in XPath expression", "This method returns true if the result should be stored as a new event.\n If mode is set to 'on_change', this method may return false and update an existing\n event to expire further in the future.", "Run all the queued up actions, parallelizing if possible.\n\n This will parallelize if and only if the provider of every machine\n supports parallelization and parallelization is possible from\n initialization of the class.", "Get a value by the given key.\n\n This will evaluate the block given to `register` and return the\n resulting value.", "Merge one registry with another and return a completely new\n registry. Note that the result cache is completely busted, so\n any gets on the new registry will result in a cache miss.", "Initializes Bundler and the various gem paths so that we can begin\n loading gems.", "Update updates the given plugins, or every plugin if none is given.\n\n @param [Hash] plugins\n @param [Array] specific Specific plugin names to update. If\n empty or nil, all plugins will be updated.", "Clean removes any unused gems.", "Iterates each configured RubyGem source to validate that it is properly\n available. If source is unavailable an exception is raised.", "Generate the builtin resolver set", "Activate a given solution", "Initializes a MachineIndex at the given file location.\n\n @param [Pathname] data_dir Path to the directory where data for the\n index can be stored. This folder should exist and must be writable.\n Deletes a machine by UUID.\n\n The machine being deleted with this UUID must either be locked\n by this index or must be unlocked.\n\n @param [Entry] entry The entry to delete.\n @return [Boolean] true if delete is successful", "Finds a machine where the UUID is prefixed by the given string.\n\n @return [Hash]", "Locks a machine exclusively to us, returning the file handle\n that holds the lock.\n\n If the lock cannot be acquired, then nil is returned.\n\n This should be called within an index lock.\n\n @return [File]", "Releases a local lock on a machine. This does not acquire any locks\n so make sure to lock around it.\n\n @param [String] id", "This will reload the data without locking the index. It is assumed\n the caller with lock the index outside of this call.\n\n @param [File] f", "This will hold a lock to the index so it can be read or updated.", "Loads the metadata associated with the box from the given\n IO.\n\n @param [IO] io An IO object to read the metadata from.\n Returns data about a single version that is included in this\n metadata.\n\n @param [String] version The version to return, this can also\n be a constraint.\n @return [Version] The matching version or nil if a matching\n version was not found.", "This prints out the help for the CLI.", "Action runner for executing actions in the context of this environment.\n\n @return [Action::Runner]", "Returns a list of machines that this environment is currently\n managing that physically have been created.\n\n An \"active\" machine is a machine that Vagrant manages that has\n been created. The machine itself may be in any state such as running,\n suspended, etc. but if a machine is \"active\" then it exists.\n\n Note that the machines in this array may no longer be present in\n the Vagrantfile of this environment. In this case the machine can\n be considered an \"orphan.\" Determining which machines are orphan\n and which aren't is not currently a supported feature, but will\n be in a future version.\n\n @return [Array]", "This creates a new batch action, yielding it, and then running it\n once the block is called.\n\n This handles the case where batch actions are disabled by the\n VAGRANT_NO_PARALLEL environmental variable.", "This defines a hook point where plugin action hooks that are registered\n against the given name will be run in the context of this environment.\n\n @param [Symbol] name Name of the hook.\n @param [Action::Runner] action_runner A custom action runner for running hooks.", "Returns the host object associated with this environment.\n\n @return [Class]", "This acquires a process-level lock with the given name.\n\n The lock file is held within the data directory of this environment,\n so make sure that all environments that are locking are sharing\n the same data directory.\n\n This will raise Errors::EnvironmentLockedError if the lock can't\n be obtained.\n\n @param [String] name Name of the lock, since multiple locks can\n be held at one time.", "This executes the push with the given name, raising any exceptions that\n occur.\n\n Precondition: the push is not nil and exists.", "This returns a machine with the proper provider for this environment.\n The machine named by `name` must be in this environment.\n\n @param [Symbol] name Name of the machine (as configured in the\n Vagrantfile).\n @param [Symbol] provider The provider that this machine should be\n backed by.\n @param [Boolean] refresh If true, then if there is a cached version\n it is reloaded.\n @return [Machine]", "This creates the local data directory and show an error if it\n couldn't properly be created.", "Check for any local plugins defined within the Vagrantfile. If\n found, validate they are available. If they are not available,\n request to install them, or raise an exception\n\n @return [Hash] plugin list for loading", "This method copies the private key into the home directory if it\n doesn't already exist.\n\n This must be done because `ssh` requires that the key is chmod\n 0600, but if Vagrant is installed as a separate user, then the\n effective uid won't be able to read the key. So the key is copied\n to the home directory and chmod 0600.", "Finds the Vagrantfile in the given directory.\n\n @param [Pathname] path Path to search in.\n @return [Pathname]", "This upgrades a home directory that was in the v1.1 format to the\n v1.5 format. It will raise exceptions if anything fails.", "This upgrades a Vagrant 1.0.x \"dotfile\" to the new V2 format.\n\n This is a destructive process. Once the upgrade is complete, the\n old dotfile is removed, and the environment becomes incompatible for\n Vagrant 1.0 environments.\n\n @param [Pathname] path The path to the dotfile", "This will detect the proper guest OS for the machine and set up\n the class to actually execute capabilities.", "Initializes by loading a Vagrantfile.\n\n @param [Config::Loader] loader Configuration loader that should\n already be configured with the proper Vagrantfile locations.\n This usually comes from {Vagrant::Environment}\n @param [Array] keys The Vagrantfiles to load and the\n order to load them in (keys within the loader).\n Returns a {Machine} for the given name and provider that\n is represented by this Vagrantfile.\n\n @param [Symbol] name Name of the machine.\n @param [Symbol] provider The provider the machine should\n be backed by (required for provider overrides).\n @param [BoxCollection] boxes BoxCollection to look up the\n box Vagrantfile.\n @param [Pathname] data_path Path where local machine data\n can be stored.\n @param [Environment] env The environment running this machine\n @return [Machine]", "Returns a list of the machine names as well as the options that\n were specified for that machine.\n\n @return [Hash]", "Returns the name of the machine that is designated as the\n \"primary.\"\n\n In the case of a single-machine environment, this is just the\n single machine name. In the case of a multi-machine environment,\n then this is the machine that is marked as primary, or nil if\n no primary machine was specified.\n\n @return [Symbol]", "Initialize a new machine.\n\n @param [String] name Name of the virtual machine.\n @param [Class] provider The provider backing this machine. This is\n currently expected to be a V1 `provider` plugin.\n @param [Object] provider_config The provider-specific configuration for\n this machine.\n @param [Hash] provider_options The provider-specific options from the\n plugin definition.\n @param [Object] config The configuration for this machine.\n @param [Pathname] data_dir The directory where machine-specific data\n can be stored. This directory is ensured to exist.\n @param [Box] box The box that is backing this virtual machine.\n @param [Environment] env The environment that this machine is a\n part of.\n This calls an action on the provider. The provider may or may not\n actually implement the action.\n\n @param [Symbol] name Name of the action to run.\n @param [Hash] extra_env This data will be passed into the action runner\n as extra data set on the environment hash for the middleware\n runner.", "This calls a raw callable in the proper context of the machine using\n the middleware stack.\n\n @param [Symbol] name Name of the action\n @param [Proc] callable\n @param [Hash] extra_env Extra env for the action env.\n @return [Hash] The resulting env", "This sets the unique ID associated with this machine. This will\n persist this ID so that in the future Vagrant will be able to find\n this machine again. The unique ID must be absolutely unique to the\n virtual machine, and can be used by providers for finding the\n actual machine associated with this instance.\n\n **WARNING:** Only providers should ever use this method.\n\n @param [String] value The ID.", "This reloads the ID of the underlying machine.", "Returns the state of this machine. The state is queried from the\n backing provider, so it can be any arbitrary symbol.\n\n @return [MachineState]", "Checks the current directory for a given machine\n and displays a warning if that machine has moved\n from its previous location on disk. If the machine\n has moved, it prints a warning to the user.", "This returns an array of all the boxes on the system, given by\n their name and their provider.\n\n @return [Array] Array of `[name, version, provider]` of the boxes\n installed on this system.", "Find a box in the collection with the given name and provider.\n\n @param [String] name Name of the box (logical name).\n @param [Array] providers Providers that the box implements.\n @param [String] version Version constraints to adhere to. Example:\n \"~> 1.0\" or \"= 1.0, ~> 1.1\"\n @return [Box] The box found, or `nil` if not found.", "This upgrades a v1.1 - v1.4 box directory structure up to a v1.5\n directory structure. This will raise exceptions if it fails in any\n way.", "Cleans the directory for a box by removing the folders that are\n empty.", "Returns the directory name for the box of the given name.\n\n @param [String] name\n @return [String]", "Returns the directory name for the box cleaned up", "This upgrades the V1 box contained unpacked in the given directory\n and returns the directory of the upgraded version. This is\n _destructive_ to the contents of the old directory. That is, the\n contents of the old V1 box will be destroyed or moved.\n\n Preconditions:\n * `dir` is a valid V1 box. Verify with {#v1_box?}\n\n @param [Pathname] dir Directory where the V1 box is unpacked.\n @return [Pathname] Path to the unpackaged V2 box.", "This is a helper that makes sure that our temporary directories\n are cleaned up no matter what.\n\n @param [String] dir Path to a temporary directory\n @return [Object] The result of whatever the yield is", "Initializes the capability system by detecting the proper capability\n host to execute on and building the chain of capabilities to execute.\n\n @param [Symbol] host The host to use for the capabilities, or nil if\n we should auto-detect it.\n @param [Hash>] hosts Potential capability\n hosts. The key is the name of the host, value[0] is a class that\n implements `#detect?` and value[1] is a parent host (if any).\n @param [Hash>] capabilities The capabilities\n that are supported. The key is the host of the capability. Within that\n is a hash where the key is the name of the capability and the value\n is the class/module implementing it.", "Executes the capability with the given name, optionally passing more\n arguments onwards to the capability. If the capability returns a value,\n it will be returned.\n\n @param [Symbol] cap_name Name of the capability", "Returns the registered module for a capability with the given name.\n\n @param [Symbol] cap_name\n @return [Module]", "Checks if this box is in use according to the given machine\n index and returns the entries that appear to be using the box.\n\n The entries returned, if any, are not tested for validity\n with {MachineIndex::Entry#valid?}, so the caller should do that\n if the caller cares.\n\n @param [MachineIndex] index\n @return [Array]", "Loads the metadata URL and returns the latest metadata associated\n with this box.\n\n @param [Hash] download_options Options to pass to the downloader.\n @return [BoxMetadata]", "Checks if the box has an update and returns the metadata, version,\n and provider. If the box doesn't have an update that satisfies the\n constraints, it will return nil.\n\n This will potentially make a network call if it has to load the\n metadata from the network.\n\n @param [String] version Version constraints the update must\n satisfy. If nil, the version constrain defaults to being a\n larger version than this box.\n @return [Array]", "Check if a box update check is allowed. Uses a file\n in the box data directory to track when the last auto\n update check was performed and returns true if the\n BOX_UPDATE_CHECK_INTERVAL has passed.\n\n @return [Boolean]", "This repackages this box and outputs it to the given path.\n\n @param [Pathname] path The full path (filename included) of where\n to output this box.\n @return [Boolean] true if this succeeds.", "This interprets a raw line from the aliases file.", "This registers an alias.", "Halt processing and redirect to the URI provided.", "Generates the absolute URI for a given path in the app.\n Takes Rack routers and reverse proxies into account.", "Set the Content-Type of the response body given a media type or file\n extension.", "Allows to start sending data to the client even though later parts of\n the response body have not yet been generated.\n\n The close parameter specifies whether Stream#close should be called\n after the block has been executed. This is only relevant for evented\n servers like Thin or Rainbows.", "Helper method checking if a ETag value list includes the current ETag.", "logic shared between builder and nokogiri", "Run filters defined on the class and all superclasses.", "Run routes defined on the class and all superclasses.", "Creates a Hash with indifferent access.", "reduce 21 omitted", "Set Engine's dry_run_mode true to override all target_id of worker sections", "This method returns MultiEventStream, because there are no reason\n to surve binary serialized by msgpack.", "return chunk id to be committed", "to include TimeParseError", "search a plugin by plugin_id", "This method returns an array because\n multiple plugins could have the same type", "get monitor info from the plugin `pe` and return a hash object", "Sanitize the parameters for a specific +action+.\n\n === Arguments\n\n * +action+ - A +Symbol+ with the action that the controller is\n performing, like +sign_up+, +sign_in+, etc.\n\n === Examples\n\n # Inside the `RegistrationsController#create` action.\n resource = build_resource(devise_parameter_sanitizer.sanitize(:sign_up))\n resource.save\n\n Returns an +ActiveSupport::HashWithIndifferentAccess+ with the permitted\n attributes.", "Add or remove new parameters to the permitted list of an +action+.\n\n === Arguments\n\n * +action+ - A +Symbol+ with the action that the controller is\n performing, like +sign_up+, +sign_in+, etc.\n * +keys:+ - An +Array+ of keys that also should be permitted.\n * +except:+ - An +Array+ of keys that shouldn't be permitted.\n * +block+ - A block that should be used to permit the action\n parameters instead of the +Array+ based approach. The block will be\n called with an +ActionController::Parameters+ instance.\n\n === Examples\n\n # Adding new parameters to be permitted in the `sign_up` action.\n devise_parameter_sanitizer.permit(:sign_up, keys: [:subscribe_newsletter])\n\n # Removing the `password` parameter from the `account_update` action.\n devise_parameter_sanitizer.permit(:account_update, except: [:password])\n\n # Using the block form to completely override how we permit the\n # parameters for the `sign_up` action.\n devise_parameter_sanitizer.permit(:sign_up) do |user|\n user.permit(:email, :password, :password_confirmation)\n end\n\n\n Returns nothing.", "Force keys to be string to avoid injection on mongoid related database.", "Parse source code.\n Returns self for easy chaining", "Render takes a hash with local variables.\n\n if you use the same filters over and over again consider registering them globally\n with Template.register_filter \n\n if profiling was enabled in Template#parse then the resulting profiling information\n will be available via Template#profiler \n\n Following options can be passed:\n\n * filters : array with local filters\n * registers : hash with register variables. Those can be accessed from\n filters and tags and might be useful to integrate liquid more with its host application", "Truncate a string down to x characters", "Sort elements of the array\n provide optional property with which to sort an array of hashes or drops", "Filter the elements of an array to those with a certain property value.\n By default the target is any truthy value.", "Remove duplicate elements from an array\n provide optional property with which to determine uniqueness", "Replace occurrences of a string with another", "Replace the first occurrences of a string with another", "Pushes a new local scope on the stack, pops it at the end of the block\n\n Example:\n context.stack do\n context['var'] = 'hi'\n end\n\n context['var] #=> nil", "Fetches an object starting at the local scope and then moving up the hierachy", "Restore an offense object loaded from a JSON file.", "Checks if there is whitespace before token", "Sets a value in the @options hash, based on the given long option and its\n value, in addition to calling the block if a block is given.", "Returns true if there's a chance that an Include pattern matches hidden\n files, false if that's definitely not possible.", "Check whether a run created source identical to a previous run, which\n means that we definitely have an infinite loop.", "Finds all Ruby source files under the current or other supplied\n directory. A Ruby source file is defined as a file with the `.rb`\n extension or a file with no extension that has a ruby shebang line\n as its first line.\n It is possible to specify includes and excludes using the config file,\n so you can include other Ruby files like Rakefiles and gemspecs.\n @param base_dir Root directory under which to search for\n ruby source files\n @return [Array] Array of filenames", "The checksum of the rubocop program running the inspection.", "Return a hash of the options given at invocation, minus the ones that have\n no effect on which offenses and disabled line ranges are found, and thus\n don't affect caching.", "Return a recursive merge of two hashes. That is, a normal hash merge,\n with the addition that any value that is a hash, and occurs in both\n arguments, will also be merged. And so on.\n\n rubocop:disable Metrics/AbcSize", "DoppelGanger implementation of build_node. preserves as many of the node's\n attributes, and does not save updates to the server", "paper over inconsistencies in the model classes APIs, and return the objects\n the user wanted instead of the URI=>object stuff", "Apply default configuration values for workstation-style tools.\n\n Global defaults should go in {ChefConfig::Config} instead, this is only\n for things like `knife` and `chef`.\n\n @api private\n @since 14.3\n @return [void]", "Look for a default key file.\n\n This searches for any of a list of possible default keys, checking both\n the local `.chef/` folder and the home directory `~/.chef/`. Returns `nil`\n if no matching file is found.\n\n @api private\n @since 14.3\n @param key_names [Array] A list of possible filenames to check for.\n The first one found will be returned.\n @return [String, nil]", "Set or retrieve the response status code.", "Loads the configuration from the YAML files whose +paths+ are passed as\n arguments, filtering the settings for the current environment. Note that\n these +paths+ can actually be globs.", "Returns true if supplied with a hash that has any recognized\n +environments+ in its root keys.", "Sets Link HTTP header and returns HTML tags for using stylesheets.", "Sets Link HTTP header and returns corresponding HTML tags.\n\n Example:\n\n # Sets header:\n # Link: ; rel=\"next\"\n # Returns String:\n # ' '\n link '/foo', :rel => :next\n\n # Multiple URLs\n link :stylesheet, '/a.css', '/b.css'", "Parse a file of run definitions and yield each run.\n\n @params [ String ] file The YAML file containing the matrix of test run definitions.\n\n @yieldparam [ Hash ] A test run definition.\n\n @since 7.0.0", "Adds an attribute to the factory.\n The attribute value will be generated \"lazily\"\n by calling the block whenever an instance is generated.\n The block will not be called if the\n attribute is overridden for a specific instance.\n\n Arguments:\n * name: +Symbol+ or +String+\n The name of this attribute. This will be assigned using \"name=\" for\n generated instances.", "Adds an attribute that will have unique values generated by a sequence with\n a specified format.\n\n The result of:\n factory :user do\n sequence(:email) { |n| \"person#{n}@example.com\" }\n end\n\n Is equal to:\n sequence(:email) { |n| \"person#{n}@example.com\" }\n\n factory :user do\n email { FactoryBot.generate(:email) }\n end\n\n Except that no globally available sequence will be defined.", "Adds an attribute that builds an association. The associated instance will\n be built using the same build strategy as the parent instance.\n\n Example:\n factory :user do\n name 'Joey'\n end\n\n factory :post do\n association :author, factory: :user\n end\n\n Arguments:\n * name: +Symbol+\n The name of this attribute.\n * options: +Hash+\n\n Options:\n * factory: +Symbol+ or +String+\n The name of the factory to use when building the associated instance.\n If no name is given, the name of the attribute is assumed to be the\n name of the factory. For example, a \"user\" association will by\n default use the \"user\" factory.", "A lookahead for the root selections of this query\n @return [GraphQL::Execution::Lookahead]", "Get the result for this query, executing it once\n @return [Hash] A GraphQL response, with `\"data\"` and/or `\"errors\"` keys", "Declare that this object implements this interface.\n This declaration will be validated when the schema is defined.\n @param interfaces [Array] add a new interface that this type implements\n @param inherits [Boolean] If true, copy the interfaces' field definitions to this type", "Given a callable whose API used to take `from` arguments,\n check its arity, and if needed, apply a wrapper so that\n it can be called with `to` arguments.\n If a wrapper is applied, warn the application with `name`.\n\n If `last`, then use the last arguments to call the function.", "`event` was triggered on `object`, and `subscription_id` was subscribed,\n so it should be updated.\n\n Load `subscription_id`'s GraphQL data, re-evaluate the query, and deliver the result.\n\n This is where a queue may be inserted to push updates in the background.\n\n @param subscription_id [String]\n @param event [GraphQL::Subscriptions::Event] The event which was triggered\n @param object [Object] The value for the subscription field\n @return [void]", "Event `event` occurred on `object`,\n Update all subscribers.\n @param event [Subscriptions::Event]\n @param object [Object]\n @return [void]", "Return a GraphQL string for the type definition\n @param schema [GraphQL::Schema]\n @param printer [GraphQL::Schema::Printer]\n @see {GraphQL::Schema::Printer#initialize for additional options}\n @return [String] type definition", "Use the provided `method_name` to generate a string from the specified schema\n then write it to `file`.", "Use the Rake DSL to add tasks", "Prepare a lazy value for this field. It may be `then`-ed and resolved later.\n @return [GraphQL::Execution::Lazy] A lazy wrapper around `obj` and its registered method name", "Returns true if `member, ctx` passes this filter", "Visit `query`'s internal representation, calling `analyzers` along the way.\n\n - First, query analyzers are filtered down by calling `.analyze?(query)`, if they respond to that method\n - Then, query analyzers are initialized by calling `.initial_value(query)`, if they respond to that method.\n - Then, they receive `.call(memo, visit_type, irep_node)`, where visit type is `:enter` or `:leave`.\n - Last, they receive `.final_value(memo)`, if they respond to that method.\n\n It returns an array of final `memo` values in the order that `analyzers` were passed in.\n\n @param query [GraphQL::Query]\n @param analyzers [Array<#call>] Objects that respond to `#call(memo, visit_type, irep_node)`\n @return [Array] Results from those analyzers", "Enter the node, visit its children, then leave the node.", "Validate a query string according to this schema.\n @param string_or_document [String, GraphQL::Language::Nodes::Document]\n @return [Array]", "Execute a query on itself. Raises an error if the schema definition is invalid.\n @see {Query#initialize} for arguments.\n @return [Hash] query result, ready to be serialized as JSON", "This is a compatibility hack so that instance-level and class-level\n methods can get correctness checks without calling one another\n @api private", "Get a unique identifier from this object\n @param object [Any] An application object\n @param type [GraphQL::BaseType] The current type definition\n @param ctx [GraphQL::Query::Context] the context for the current query\n @return [String] a unique identifier for `object` which clients can use to refetch it", "Return the GraphQL IDL for the schema\n @param context [Hash]\n @param only [<#call(member, ctx)>]\n @param except [<#call(member, ctx)>]\n @return [String]", "Get the underlying value for this enum value\n\n @example get episode value from Enum\n episode = EpisodeEnum.coerce(\"NEWHOPE\")\n episode # => 6\n\n @param value_name [String] the string representation of this enum value\n @return [Object] the underlying value for this enum value", "This is for testing input object behavior", "Customize the JSON serialization for Elasticsearch", "Text representation of the client, masking tokens and passwords\n\n @return [String]", "Hypermedia agent for the GitHub API\n\n @return [Sawyer::Agent]", "Executes the request, checking if it was successful\n\n @return [Boolean] True on success, false otherwise", "Adds the `aria-selected` attribute to a link when it's pointing to the\n current path. The API is the same than the `link_to` one, and uses this\n helper internally.\n\n text - a String with the link text\n link - Where the link should point to. Accepts the same value than\n `link_to` helper.\n options - An options Hash that will be passed to `link_to`.", "Renders all form attributes defined by the handler.\n\n Returns a String.", "Renders a single attribute from the form handlers.\n\n name - The String name of the attribute.\n options - An optional Hash, accepted options are:\n :as - A String name with the type the field to render\n :input - An optional Hash to pass to the field method.\n\n Returns a String.", "All the resource types that are eligible to be included as an activity.", "Creates a ew authorization form in a view, accepts the same arguments as\n `form_for`.\n\n record - The record to use in the form, it shoulde be a descendant of\n AuthorizationHandler.\n options - An optional hash with options to pass wo the form builder.\n block - A block with the content of the form.\n\n Returns a String.", "Stores the url where the user will be redirected after login.\n\n Uses the `redirect_url` param or the current url if there's no param.\n In Devise controllers we only store the URL if it's from the params, we don't\n want to overwrite the stored URL for a Devise one.", "Checks if the resource should show its scope or not.\n resource - the resource to analize\n\n Returns boolean.", "Renders a scopes picker field in a form, not linked to a specific model.\n name - name for the input\n value - value for the input\n\n Returns nothing.", "Renders the emendations of an amendable resource\n\n Returns Html grid of CardM.", "Checks if the user can accept and reject the emendation", "Checks if the user can promote the emendation", "Checks if the unique ActionLog created in the promote command exists.", "Renders a UserGroup select field in a form.", "Return the edited field value or presents the original attribute value in a form.", "Renders a link to openstreetmaps with the resource latitude and longitude.\n The link's content is a static map image.\n\n resource - A geolocalizable resource\n options - An optional hash of options (default: { zoom: 17 })\n * zoom: A number to represent the zoom value of the map", "Renders the attachment's title.\n Checks if the attachment's title is translated or not and use\n the correct render method.\n\n attachment - An Attachment object\n\n Returns String.", "Overrides the submit tags to always be buttons instead of inputs.\n Buttons are much more stylable and less prone to bugs.\n\n value - The text of the button\n options - Options to provide to the actual tag.\n\n Returns a SafeString with the tag.", "Calls the `create` method to the given class and sets the author of the version.\n\n klass - An ActiveRecord class that implements `Decidim::Traceable`\n author - An object that implements `to_gid` or a String\n params - a Hash with the attributes of the new resource\n extra_log_info - a Hash with extra info that will be saved to the log\n\n Returns an instance of `klass`.", "Calls the `create!` method to the given class and sets the author of the version.\n\n klass - An ActiveRecord class that implements `Decidim::Traceable`\n author - An object that implements `to_gid` or a String\n params - a Hash with the attributes of the new resource\n extra_log_info - a Hash with extra info that will be saved to the log\n\n Returns an instance of `klass`.", "Performs the given block and sets the author of the action.\n It also logs the action with the given `action` parameter.\n The action and the logging are run inside a transaction.\n\n action - a String or Symbol representing the action performed\n resource - An ActiveRecord instance that implements `Decidim::Traceable`\n author - An object that implements `to_gid` or a String\n extra_log_info - a Hash with extra info that will be saved to the log\n\n Returns whatever the given block returns.", "Updates the `resource` with `update!` and sets the author of the version.\n\n resource - An ActiveRecord instance that implements `Decidim::Traceable`\n author - An object that implements `to_gid` or a String\n params - a Hash with the attributes to update to the resource\n extra_log_info - a Hash with extra info that will be saved to the log\n\n Returns the updated `resource`.", "Truncates a given text respecting its HTML tags.\n\n text - The String text to be truncated.\n options - A Hash with the options to truncate the text (default: {}):\n :length - An Integer number with the max length of the text.\n :separator - A String to append to the text when it's being\n truncated. See `truncato` gem for more options.\n\n Returns a String.", "Generates a link to be added to the global Edit link so admins\n can easily manage data without having to look for it at the admin\n panel when they're at a public page.\n\n link - The String with the URL.\n action - The Symbol action to check the permissions for.\n subject - The Symbol subject to perform the action to.\n extra_context - An optional Hash to check the permissions.\n\n Returns nothing.", "A context used to set the layout and behavior of a participatory space. Full documentation can\n be found looking at the `ParticipatorySpaceContextManifest` class.\n\n Example:\n\n context(:public) do |context|\n context.layout \"layouts/decidim/some_layout\"\n end\n\n context(:public).layout\n # => \"layouts/decidim/some_layout\"\n\n Returns Nothing.", "Returns the creation date in a friendly relative format.", "Search for all Participatory Space manifests and then all records available\n Limited to ParticipatoryProcesses only", "Converts a given array of strings to an array of Objects representing\n locales.\n\n collection - an Array of Strings. By default it uses all the available\n locales in Decidim, but you can passa nother collection of locales (for\n example, the available locales for an organization)", "Initializes the Rack Middleware.\n\n app - The Rack application\n Main entry point for a Rack Middleware.\n\n env - A Hash.", "Destroy a user's account.\n\n user - The user to be updated.\n form - The form with the data.", "Initializes the ActionAuthorizer.\n\n user - The user to authorize against.\n action - The action to authenticate.\n component - The component to authenticate against.\n resource - The resource to authenticate against. Can be nil.\n\n\n Authorize user to perform an action in the context of a component.\n\n Returns:\n :ok an empty hash - When there is no authorization handler related to the action.\n result of authorization handler check - When there is an authorization handler related to the action. Check Decidim::Verifications::DefaultActionAuthorizer class docs.", "Updates a user's account.\n\n user - The user to be updated.\n form - The form with the data.", "Renders a collection of linked resources for a resource.\n\n resource - The resource to get the links from.\n type - The String type fo the resources we want to render.\n link_name - The String name of the link between the resources.\n\n Example to render the proposals in a meeting view:\n\n linked_resources_for(:meeting, :proposals, \"proposals_from_meeting\")\n\n Returns nothing.", "Returns a descriptive title for the resource", "Displays pagination links for the given collection, setting the correct\n theme. This mostly acts as a proxy for the underlying pagination engine.\n\n collection - a collection of elements that need to be paginated\n paginate_params - a Hash with options to delegate to the pagination helper.", "Lazy loads the `participatory_space` association through BatchLoader, can be used\n as a regular object.", "Handles the scope_id filter. When we want to show only those that do not\n have a scope_id set, we cannot pass an empty String or nil because Searchlight\n will automatically filter out these params, so the method will not be used.\n Instead, we need to pass a fake ID and then convert it inside. In this case,\n in order to select those elements that do not have a scope_id set we use\n `\"global\"` as parameter, and in the method we do the needed changes to search\n properly.", "this method is used to generate the root link on mail with the utm_codes\n If the newsletter_id is nil, it returns the root_url", "Outputs an SVG-based icon.\n\n name - The String with the icon name.\n options - The Hash options used to customize the icon (default {}):\n :width - The Number of width in pixels (optional).\n :height - The Number of height in pixels (optional).\n :aria_label - The String to set as aria label (optional).\n :aria_hidden - The Truthy value to enable aria_hidden (optional).\n :role - The String to set as the role (optional).\n :class - The String to add as a CSS class (optional).\n\n Returns a String.", "Outputs a SVG icon from an external file. It apparently renders an image\n tag, but then a JS script kicks in and replaces it with an inlined SVG\n version.\n\n path - The asset's path\n\n Returns an tag with the SVG icon.", "Initializes the class with a polymorphic subject\n\n subject - A in instance of a subclass of ActiveRecord::Base to be tracked\n\n Public: Tracks the past activity of a user to update the continuity badge's\n score. It will set it to the amount of consecutive days a user has logged into\n the system.\n\n date - The date of the last user's activity. Usually `Time.zone.today`.\n\n Returns nothing.", "Sends an email with the invitation instructions to a new user.\n\n user - The User that has been invited.\n token - The String to be sent as a token to verify the invitation.\n opts - A Hash with options to send the email (optional).", "Since we're rendering each activity separatedly we need to trigger\n BatchLoader in order to accumulate all the ids to be found later.", "Returns the defined root path for a given component.\n\n component - the Component we want to find the root path for.\n\n Returns a relative url.", "Returns the defined root url for a given component.\n\n component - the Component we want to find the root path for.\n\n Returns an absolute url.", "Returns the defined admin root path for a given component.\n\n component - the Component we want to find the root path for.\n\n Returns a relative url.", "Renders the human name of the given class name.\n\n klass_name - a String representing the class name of the resource to render\n count - (optional) the number of resources so that the I18n backend\n can decide to translate into singluar or plural form.", "Generates a link to filter the current search by the given type. If no\n type is given, it generates a link to the main results page.\n\n resource_type - An optional String with the name of the model class to filter\n space_state - An optional String with the name of the state of the space", "Generates the path and link to filter by space state, taking into account\n the other filters applied.", "A custom form for that injects client side validations with Abide.\n\n record - The object to build the form for.\n options - A Hash of options to pass to the form builder.\n &block - The block to execute as content of the form.\n\n Returns a String.", "A custom helper to include an editor field without requiring a form object\n\n name - The input name\n value - The input value\n options - The set of options to send to the field\n :label - The Boolean value to create or not the input label (optional) (default: true)\n :toolbar - The String value to configure WYSIWYG toolbar. It should be 'basic' or\n or 'full' (optional) (default: 'basic')\n :lines - The Integer to indicate how many lines should editor have (optional)\n\n Returns a rich editor to be included in an html template.", "A custom helper to include a scope picker field without requiring a form\n object\n\n name - The input name\n value - The input value as a scope id\n options - The set of options to send to the field\n :id - The id to generate for the element (optional)\n\n Returns a scopes picker tag to be included in an html template.", "A custom helper to include a translated field without requiring a form object.\n\n type - The type of the translated input field.\n object_name - The object name used to identify the Foundation tabs.\n name - The name of the input which will be suffixed with the corresponding locales.\n value - A hash containing the value for each locale.\n options - An optional hash of options.\n * enable_tabs: Adds the data-tabs attribute so Foundation picks up automatically.\n * tabs_id: The id to identify the Foundation tabs element.\n * label: The label used for the field.\n\n Returns a Foundation tabs element with the translated input field.", "Helper method to show how slugs will look like. Intended to be used in forms\n together with some JavaScript code. More precisely, this will most probably\n show in help texts in forms. The space slug is surrounded with a `span` so\n the slug can be updated via JavaScript with the input value.\n\n prepend_path - a path to prepend to the slug, without final slash\n value - the initial value of the slug field, so that edit forms have a value\n\n Returns an HTML-safe String.", "Renders the avatar and author name of the author of the last version of the given\n resource.\n\n resource - an object implementing `Decidim::Traceable`\n\n Returns an HTML-safe String representing the HTML to render the author.", "Renders the avatar and author name of the author of the given version.\n\n version - an object that responds to `whodunnit` and returns a String.\n\n Returns an HTML-safe String representing the HTML to render the author.", "Caches a DiffRenderer instance for the `current_version`.", "Renders the given value in a user-friendly way based on the value class.\n\n value - an object to be rendered\n\n Returns an HTML-ready String.", "The title to show at the card.\n\n The card will also be displayed OK if there's no title.", "The description to show at the card.\n\n The card will also be displayed OK if there's no description.", "Renders the Call To Action button. Link and text can be configured\n per organization.", "Finds the CTA button path to reuse it in other places.", "Returns a String with the absolute file_path to be read or generate.", "This method wraps everything in a div with class filters and calls\n the form_for helper with a custom builder\n\n filter - A filter object\n url - A String with the URL to post the from. Self URL by default.\n block - A block to be called with the form builder\n\n Returns the filter resource form wrapped in a div", "Checks if the file is an image based on the content type. We need this so\n we only create different versions of the file when it's an image.\n\n new_file - The uploaded file.\n\n Returns a Boolean.", "Copies the content type and file size to the model where this is mounted.\n\n Returns nothing.", "Wrap the radio buttons collection in a custom fieldset.\n It also renders the inputs inside its labels.", "Wrap the check_boxes collection in a custom fieldset.\n It also renders the inputs inside its labels.", "Catch common beginner mistake and give a helpful error message on stderr", "Loop through all methods for each class and makes special prewarm call to each method.", "The user must at least pass in an SQL statement", "Accounts for inherited class_properties", "Properties managed by Jets with merged with finality.", "only process policy_document once", "1. Convert API Gateway event event to Rack env\n 2. Process using full Rack middleware stack\n 3. Convert back to API gateway response structure payload", "Validate routes that deployable", "resources macro expands to all the routes", "Useful for creating API Gateway Resources", "Useful for RouterMatcher\n\n Precedence:\n 1. Routes with no captures get highest precedence: posts/new\n 2. Then consider the routes with captures: post/:id\n 3. Last consider the routes with wildcards: *catchall\n\n Within these 2 groups we consider the routes with the longest path first\n since posts/:id and posts/:id/edit can both match.", "Show pretty route table for user to help with debugging in non-production mode", "Always the pre-flight headers in this case", "Runs in the child process", "blocks until rack server is up", "Only need to override the add method as the other calls all lead to it.", "Use command's long description as main description", "Use for both jets.gemspec and rake rdoc task", "Written as method to easily not include webpacker for case when either\n webpacker not installed at all or disabled upon `jets deploy`.", "aws sts get-caller-identity", "Checks that all routes are validate and have corresponding lambda functions", "Checks for a few things before deciding to delete the parent stack\n\n * Parent stack status status is ROLLBACK_COMPLETE\n * Parent resources are in the DELETE_COMPLETE state", "Class heirachry in top to down order", "For anonymous classes method_added during task registration contains \"\"\n for the class name. We adjust it here.", "Returns the content of a section.\n\n @return [String] Generate section content", "Parse issue and generate single line formatted issue line.\n\n Example output:\n - Add coveralls integration [\\#223](https://github.com/github-changelog-generator/github-changelog-generator/pull/223) (@github-changelog-generator)\n\n @param [Hash] issue Fetched issue from GitHub\n @return [String] Markdown-formatted single issue", "Encapsulate characters to make Markdown look as expected.\n\n @param [String] string\n @return [String] encapsulated input string", "Async fetching of all tags dates", "Find correct closed dates, if issues was closed by commits", "Adds a key \"first_occurring_tag\" to each PR with a value of the oldest\n tag that a PR's merge commit occurs in in the git history. This should\n indicate the release of each PR by git's history regardless of dates and\n divergent branches.\n\n @param [Array] tags The tags sorted by time, newest to oldest.\n @param [Array] prs The PRs to discover the tags of.\n @return [Nil] No return; PRs are updated in-place.", "Associate merged PRs by the merge SHA contained in each tag. If the\n merge_commit_sha is not found in any tag's history, skip association.\n\n @param [Array] tags The tags sorted by time, newest to oldest.\n @param [Array] prs The PRs to associate.\n @return [Array] PRs without their merge_commit_sha in a tag.", "Set closed date from this issue\n\n @param [Hash] event\n @param [Hash] issue", "Returns the number of pages for a API call\n\n @return [Integer] number of pages for this API call in total", "Fill input array with tags\n\n @return [Array ] array of tags in repo", "Fetch event for all issues and add them to 'events'\n\n @param [Array] issues\n @return [Void]", "Fetch comments for PRs and add them to \"comments\"\n\n @param [Array] prs The array of PRs.\n @return [Void] No return; PRs are updated in-place.", "Fetch tag time from repo\n\n @param [Hash] tag GitHub data item about a Tag\n\n @return [Time] time of specified tag", "Fetch and cache comparison between two github refs\n\n @param [String] older The older sha/tag/branch.\n @param [String] newer The newer sha/tag/branch.\n @return [Hash] Github api response for comparison.", "Fetch commit for specified event\n\n @param [String] commit_id the SHA of a commit to fetch\n @return [Hash]", "Fetch all SHAs occurring in or before a given tag and add them to\n \"shas_in_tag\"\n\n @param [Array] tags The array of tags.\n @return [Nil] No return; tags are updated in-place.", "This is wrapper with rescue block\n\n @return [Object] returns exactly the same, what you put in the block, but wrap it with begin-rescue block", "fetch, filter tags, fetch dates and sort them in time order", "Returns date for given GitHub Tag hash\n\n Memoize the date by tag name.\n\n @param [Hash] tag_name\n\n @return [Time] time of specified tag", "Detect link, name and time for specified tag.\n\n @param [Hash] newer_tag newer tag. Can be nil, if it's Unreleased section.\n @return [Array] link, name and time of the tag", "Parse a single heading and return a Hash\n\n The following heading structures are currently valid:\n - ## [v1.0.2](https://github.com/zanui/chef-thumbor/tree/v1.0.1) (2015-03-24)\n - ## [v1.0.2](https://github.com/zanui/chef-thumbor/tree/v1.0.1)\n - ## v1.0.2 (2015-03-24)\n - ## v1.0.2\n\n @param [String] heading Heading from the ChangeLog File\n @return [Hash] Returns a structured Hash with version, url and date", "Parse the given ChangeLog data into a list of Hashes\n\n @param [String] data File data from the ChangeLog.md\n @return [Array] Parsed data, e.g. [{ 'version' => ..., 'url' => ..., 'date' => ..., 'content' => ...}, ...]", "Add all issues, that should be in that tag, according milestone\n\n @param [Array] all_issues\n @param [String] tag_name\n @return [Array] issues with milestone #tag_name", "General filtered function\n\n @param [Array] all_issues PRs or issues\n @return [Array] filtered issues", "Generates log entry with header and body\n\n @param [Array] pull_requests List or PR's in new section\n @param [Array] issues List of issues in new section\n @param [String] newer_tag_name Name of the newer tag. Could be nil for `Unreleased` section.\n @param [String] newer_tag_link Name of the newer tag. Could be \"HEAD\" for `Unreleased` section.\n @param [Time] newer_tag_time Time of the newer tag\n @param [Hash, nil] older_tag_name Older tag, used for the links. Could be nil for last tag.\n @return [String] Ready and parsed section content.", "Generates header text for an entry.\n\n @param [String] newer_tag_name The name of a newer tag\n @param [String] newer_tag_link Used for URL generation. Could be same as #newer_tag_name or some specific value, like HEAD\n @param [Time] newer_tag_time Time when the newer tag was created\n @param [String] older_tag_name The name of an older tag; used for URLs.\n @param [String] project_url URL for the current project.\n @return [String] Header text content.", "Sorts issues and PRs into entry sections by labels and lack of labels.\n\n @param [Array] pull_requests\n @param [Array] issues\n @return [Nil]", "Iterates through sections and sorts labeled issues into them based on\n the label mapping. Returns any unmapped or unlabeled issues.\n\n @param [Array] issues Issues or pull requests.\n @return [Array] Issues that were not mapped into any sections.", "Returns a the option name as a symbol and its string value sans newlines.\n\n @param line [String] unparsed line from config file\n @return [Array]", "Class, responsible for whole changelog generation cycle\n @return initialised instance of ChangelogGenerator\n The entry point of this script to generate changelog\n @raise (ChangelogGeneratorError) Is thrown when one of specified tags was not found in list of tags.", "Generate log only between 2 specified tags\n @param [String] older_tag all issues before this tag date will be excluded. May be nil, if it's first tag\n @param [String] newer_tag all issue after this tag will be excluded. May be nil for unreleased section", "Filters issues and pull requests based on, respectively, `actual_date`\n and `merged_at` timestamp fields. `actual_date` is the detected form of\n `closed_at` based on merge event SHA commit times.\n\n @return [Array] filtered issues and pull requests", "The full cycle of generation for whole project\n @return [String] All entries in the changelog", "Serialize the most relevant settings into a Hash\n\n @return [::Hash]\n\n @since 0.1.0\n @api private", "The root of the application\n\n By default it returns the current directory, for this reason, **all the\n commands must be executed from the top level directory of the project**.\n\n If for some reason, that constraint above cannot be satisfied, please\n configure the root directory, so that commands can be executed from\n everywhere.\n\n This is part of a DSL, for this reason when this method is called with\n an argument, it will set the corresponding instance variable. When\n called without, it will return the already set value, or the default.\n\n @overload root(value)\n Sets the given value\n @param value [String,Pathname,#to_pathname] The root directory of the app\n\n @overload root\n Gets the value\n @return [Pathname]\n @raise [Errno::ENOENT] if the path cannot be found\n\n @since 0.1.0\n\n @see http://www.ruby-doc.org/core/Dir.html#method-c-pwd\n\n @example Getting the value\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n end\n end\n\n Bookshelf::Application.configuration.root # => #\n\n @example Setting the value\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n configure do\n root '/path/to/another/root'\n end\n end\n end", "Application routes.\n\n Specify a set of routes for the application, by passing a block, or a\n relative path where to find the file that describes them.\n\n By default it's `nil`.\n\n This is part of a DSL, for this reason when this method is called with\n an argument, it will set the corresponding instance variable. When\n called without, it will return the already set value, or the default.\n\n @overload routes(blk)\n Specify a set of routes in the given block\n @param blk [Proc] the routes definitions\n\n @overload routes(path)\n Specify a relative path where to find the routes file\n @param path [String] the relative path\n\n @overload routes\n Gets the value\n @return [Hanami::Config::Routes] the set of routes\n\n @since 0.1.0\n\n @see http://rdoc.info/gems/hanami-router/Hanami/Router\n\n @example Getting the value\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n end\n end\n\n Bookshelf::Application.configuration.routes\n # => nil\n\n @example Setting the value, by passing a block\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n configure do\n routes do\n get '/', to: 'dashboard#index'\n resources :books\n end\n end\n end\n end\n\n Bookshelf::Application.configuration.routes\n # => #, @path=#>\n\n @example Setting the value, by passing a relative path\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n configure do\n routes 'config/routes'\n end\n end\n end\n\n Bookshelf::Application.configuration.routes\n # => #>", "The URI port for this application.\n This is used by the router helpers to generate absolute URLs.\n\n By default this value is `2300`.\n\n This is part of a DSL, for this reason when this method is called with\n an argument, it will set the corresponding instance variable. When\n called without, it will return the already set value, or the default.\n\n @overload port(value)\n Sets the given value\n @param value [#to_int] the URI port\n @raise [TypeError] if the given value cannot be coerced to Integer\n\n @overload scheme\n Gets the value\n @return [String]\n\n @since 0.1.0\n\n @see http://en.wikipedia.org/wiki/URI_scheme\n\n @example Getting the value\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n end\n end\n\n Bookshelf::Application.configuration.port # => 2300\n\n @example Setting the value\n require 'hanami'\n\n module Bookshelf\n class Application < Hanami::Application\n configure do\n port 8080\n end\n end\n end\n\n Bookshelf::Application.configuration.port # => 8080", "Loads a dotenv file and updates self\n\n @param path [String, Pathname] the path to the dotenv file\n\n @return void\n\n @since 0.9.0\n @api private", "Default values for writing the hanamirc file\n\n @since 0.5.1\n @api private\n\n @see Hanami::Hanamirc#options", "Read hanamirc file and parse it's values\n\n @since 0.8.0\n @api private\n\n @return [Hash] hanamirc parsed values", "Instantiate a middleware stack\n\n @param configuration [Hanami::ApplicationConfiguration] the application's configuration\n\n @return [Hanami::MiddlewareStack] the new stack\n\n @since 0.1.0\n @api private\n\n @see Hanami::ApplicationConfiguration\n Load the middleware stack\n\n @return [Hanami::MiddlewareStack] the loaded middleware stack\n\n @since 0.2.0\n @api private\n\n @see http://rdoc.info/gems/rack/Rack/Builder", "Append a middleware to the stack.\n\n @param middleware [Object] a Rack middleware\n @param args [Array] optional arguments to pass to the Rack middleware\n @param blk [Proc] an optional block to pass to the Rack middleware\n\n @return [Array] the middleware that was added\n\n @since 0.2.0\n\n @see Hanami::MiddlewareStack#prepend\n\n @example\n # apps/web/application.rb\n module Web\n class Application < Hanami::Application\n configure do\n # ...\n use MyRackMiddleware, foo: 'bar'\n end\n end\n end", "Prepend a middleware to the stack.\n\n @param middleware [Object] a Rack middleware\n @param args [Array] optional arguments to pass to the Rack middleware\n @param blk [Proc] an optional block to pass to the Rack middleware\n\n @return [Array] the middleware that was added\n\n @since 0.6.0\n\n @see Hanami::MiddlewareStack#use\n\n @example\n # apps/web/application.rb\n module Web\n class Application < Hanami::Application\n configure do\n # ...\n prepend MyRackMiddleware, foo: 'bar'\n end\n end\n end", "Initialize the factory\n\n @param routes [Hanami::Router] a routes set\n\n @return [Hanami::Routes] the factory\n\n @since 0.1.0\n @api private\n Return a relative path for the given route name\n\n @param name [Symbol] the route name\n @param args [Array,nil] an optional set of arguments that is passed down\n to the wrapped route set.\n\n @return [Hanami::Utils::Escape::SafeString] the corresponding relative URL\n\n @raise Hanami::Routing::InvalidRouteException\n\n @since 0.1.0\n\n @see http://rdoc.info/gems/hanami-router/Hanami/Router#path-instance_method\n\n @example Basic example\n require 'hanami'\n\n module Web\n class Application < Hanami::Application\n configure do\n routes do\n get '/login', to: 'sessions#new', as: :login\n end\n end\n end\n end\n\n Web.routes.path(:login)\n # => '/login'\n\n Web.routes.path(:login, return_to: '/dashboard')\n # => '/login?return_to=%2Fdashboard'\n\n @example Dynamic finders\n require 'hanami'\n\n module Web\n class Application < Hanami::Application\n configure do\n routes do\n get '/login', to: 'sessions#new', as: :login\n end\n end\n end\n end\n\n Web.routes.login_path\n # => '/login'\n\n Web.routes.login_path(return_to: '/dashboard')\n # => '/login?return_to=%2Fdashboard'", "Return an absolute path for the given route name\n\n @param name [Symbol] the route name\n @param args [Array,nil] an optional set of arguments that is passed down\n to the wrapped route set.\n\n @return [Hanami::Utils::Escape::SafeString] the corresponding absolute URL\n\n @raise Hanami::Routing::InvalidRouteException\n\n @since 0.1.0\n\n @see http://rdoc.info/gems/hanami-router/Hanami/Router#url-instance_method\n\n @example Basic example\n require 'hanami'\n\n module Web\n class Application < Hanami::Application\n configure do\n routes do\n scheme 'https'\n host 'bookshelf.org'\n\n get '/login', to: 'sessions#new', as: :login\n end\n end\n end\n end\n\n Web.routes.url(:login)\n # => 'https://bookshelf.org/login'\n\n Web.routes.url(:login, return_to: '/dashboard')\n # => 'https://bookshelf.org/login?return_to=%2Fdashboard'\n\n @example Dynamic finders\n require 'hanami'\n\n module Web\n class Application < Hanami::Application\n configure do\n routes do\n scheme 'https'\n host 'bookshelf.org'\n\n get '/login', to: 'sessions#new', as: :login\n end\n end\n end\n end\n\n Web.routes.login_url\n # => 'https://bookshelf.org/login'\n\n Web.routes.login_url(return_to: '/dashboard')\n # => 'https://bookshelf.org/login?return_to=%2Fdashboard'", "Returns true if the service exists, false otherwise.\n\n @param [String] service_name name of the service", "Start a windows service\n\n @param [String] service_name name of the service to start\n @param optional [Integer] timeout the minumum number of seconds to wait before timing out", "Stop a windows service\n\n @param [String] service_name name of the service to stop\n @param optional [Integer] timeout the minumum number of seconds to wait before timing out", "Resume a paused windows service\n\n @param [String] service_name name of the service to resume\n @param optional [Integer] :timeout the minumum number of seconds to wait before timing out", "Query the state of a service using QueryServiceStatusEx\n\n @param [string] service_name name of the service to query\n @return [string] the status of the service", "Query the configuration of a service using QueryServiceConfigW\n\n @param [String] service_name name of the service to query\n @return [QUERY_SERVICE_CONFIGW.struct] the configuration of the service", "Change the startup mode of a windows service\n\n @param [string] service_name the name of the service to modify\n @param [Int] startup_type a code corresponding to a start type for\n windows service, see the \"Service start type codes\" section in the\n Puppet::Util::Windows::Service file for the list of available codes", "enumerate over all services in all states and return them as a hash\n\n @return [Hash] a hash containing services:\n { 'service name' => {\n 'display_name' => 'display name',\n 'service_status_process' => SERVICE_STATUS_PROCESS struct\n }\n }", "generate all the subdirectories, modules, classes and files", "generate a top index", "generate the all classes index file and the combo index", "returns the initial_page url", "return the relative file name to store this class in,\n which is also its url", "Checks whether all feature predicate methods are available.\n @param obj [Object, Class] the object or class to check if feature predicates are available or not.\n @return [Boolean] Returns whether all of the required methods are available or not in the given object.", "Merges the current set of metadata with another metadata hash. This\n method also handles the validation of module names and versions, in an\n effort to be proactive about module publishing constraints.", "Validates the name and version_requirement for a dependency, then creates\n the Dependency and adds it.\n Returns the Dependency that was added.", "Do basic validation and parsing of the name parameter.", "Do basic parsing of the source parameter. If the source is hosted on\n GitHub, we can predict sensible defaults for both project_page and\n issues_url.", "Validates and parses the dependencies.", "Validates that the given module name is both namespaced and well-formed.", "Validates that the version string can be parsed as per SemVer.", "Validates that the given _value_ is a symbolic name that starts with a letter\n and then contains only letters, digits, or underscore. Will raise an ArgumentError\n if that's not the case.\n\n @param value [Object] The value to be tested", "Validates that the version range can be parsed by Semantic.", "force regular ACLs to be present", "Common helper for set_userflags and unset_userflags.\n\n @api private", "Iterate through the list of records for this service\n and yield each server and port pair. Records are only fetched\n via DNS query the first time and cached for the duration of their\n service's TTL thereafter.\n @param [String] domain the domain to search for\n @param [Symbol] service_name the key of the service we are querying\n @yields [String, Integer] server and port of selected record", "Given a list of records of the same priority, chooses a random one\n from among them, favoring those with higher weights.\n @param [[Resolv::DNS::Resource::IN::SRV]] records a list of records\n of the same priority\n @return [Resolv::DNS::Resource::IN:SRV] the chosen record", "Checks if the cached entry for the given service has expired.\n @param [String] service_name the name of the service to check\n @return [Boolean] true if the entry has expired, false otherwise.\n Always returns true if the record had no TTL.", "Removes all environment variables\n @param mode [Symbol] Which operating system mode to use e.g. :posix or :windows. Use nil to autodetect\n @api private", "Resolve a path for an executable to the absolute path. This tries to behave\n in the same manner as the unix `which` command and uses the `PATH`\n environment variable.\n\n @api public\n @param bin [String] the name of the executable to find.\n @return [String] the absolute path to the found executable.", "Convert a path to a file URI", "Get the path component of a URI", "Executes a block of code, wrapped with some special exception handling. Causes the ruby interpreter to\n exit if the block throws an exception.\n\n @api public\n @param [String] message a message to log if the block fails\n @param [Integer] code the exit code that the ruby interpreter should return if the block fails\n @yield", "Converts 4x supported values to a 3x values.\n\n @param args [Array] Array of values to convert\n @param scope [Puppet::Parser::Scope] The scope to use when converting\n @param undef_value [Object] The value that nil is converted to\n @return [Array] The converted values", "Removes an attribute from the object; useful in testing or in cleanup\n when an error has been encountered\n @todo Don't know what the attr is (name or Property/Parameter?). Guessing it is a String name...\n @todo Is it possible to delete a meta-parameter?\n @todo What does delete mean? Is it deleted from the type or is its value state 'is'/'should' deleted?\n @param attr [String] the attribute to delete from this object. WHAT IS THE TYPE?\n @raise [Puppet::DecError] when an attempt is made to delete an attribute that does not exists.", "Returns true if the instance is a managed instance.\n A 'yes' here means that the instance was created from the language, vs. being created\n in order resolve other questions, such as finding a package in a list.\n @note An object that is managed always stays managed, but an object that is not managed\n may become managed later in its lifecycle.\n @return [Boolean] true if the object is managed", "Retrieves the current value of all contained properties.\n Parameters and meta-parameters are not included in the result.\n @todo As opposed to all non contained properties? How is this different than any of the other\n methods that also \"gets\" properties/parameters/etc. ?\n @return [Puppet::Resource] array of all property values (mix of types)\n @raise [fail???] if there is a provider and it is not suitable for the host this is evaluated for.", "Builds the dependencies associated with this resource.\n\n @return [Array] list of relationships to other resources", "Mark parameters associated with this type as sensitive, based on the associated resource.\n\n Currently, only instances of `Puppet::Property` can be easily marked for sensitive data handling\n and information redaction is limited to redacting events generated while synchronizing\n properties. While support for redaction will be broadened in the future we can't automatically\n deduce how to redact arbitrary parameters, so if a parameter is marked for redaction the best\n we can do is warn that we can't handle treating that parameter as sensitive and move on.\n\n In some unusual cases a given parameter will be marked as sensitive but that sensitive context\n needs to be transferred to another parameter. In this case resource types may need to override\n this method in order to copy the sensitive context from one parameter to another (and in the\n process force the early generation of a parameter that might otherwise be lazily generated.)\n See `Puppet::Type.type(:file)#set_sensitive_parameters` for an example of this.\n\n @note This method visibility is protected since it should only be called by #initialize, but is\n marked as public as subclasses may need to override this method.\n\n @api public\n\n @param sensitive_parameters [Array] A list of parameters to mark as sensitive.\n\n @return [void]", "Finishes any outstanding processing.\n This method should be called as a final step in setup,\n to allow the parameters that have associated auto-require needs to be processed.\n\n @todo what is the expected sequence here - who is responsible for calling this? When?\n Is the returned type correct?\n @return [Array] the validated list/set of attributes", "Create an anonymous environment.\n\n @param module_path [String] A list of module directories separated by the\n PATH_SEPARATOR\n @param manifest [String] The path to the manifest\n @return A new environment with the `name` `:anonymous`\n\n @api private", "Returns a basic environment configuration object tied to the environment's\n implementation values. Will not interpolate.\n\n @!macro loader_get_conf", "Adds a cache entry to the cache", "Clears all environments that have expired, either by exceeding their time to live, or\n through an explicit eviction determined by the cache expiration service.", "Creates a suitable cache entry given the time to live for one environment", "Evicts the entry if it has expired\n Also clears caches in Settings that may prevent the entry from being updated", "Return checksums for object's +Pathname+, generate if it's needed.\n Result is a hash of path strings to checksum strings.", "Create a Route containing information for querying the given API,\n hosted at a server determined either by SRV service or by the\n fallback server on the fallback port.\n @param [String] api the path leading to the root of the API. Must\n contain a trailing slash for proper endpoint path\n construction\n @param [Symbol] server_setting the setting to check for special\n server configuration\n @param [Symbol] port_setting the setting to check for speical\n port configuration\n @param [Symbol] srv_service the name of the service when using SRV\n records\n Select a server and port to create a base URL for the API specified by this\n route. If the connection fails and SRV records are in use, the next suitable\n server will be tried. If SRV records are not in use or no successful connection\n could be made, fall back to the configured server and port for this API, taking\n into account failover settings.\n @parma [Puppet::Network::Resolver] dns_resolver the DNS resolver to use to check\n SRV records\n @yield [URI] supply a base URL to make a request with\n @raise [Puppet::Error] if connection to selected server and port fails, and SRV\n records are not in use", "Execute the application.\n @api public\n @return [void]", "Output basic information about the runtime environment for debugging\n purposes.\n\n @api public\n\n @param extra_info [Hash{String => #to_s}] a flat hash of extra information\n to log. Intended to be passed to super by subclasses.\n @return [void]", "Defines a repeated positional parameter with _type_ and _name_ that may occur 1 to \"infinite\" number of times.\n It may only appear last or just before a block parameter.\n\n @param type [String] The type specification for the parameter.\n @param name [Symbol] The name of the parameter. This is primarily used\n for error message output and does not have to match an implementation\n method parameter.\n @return [Void]\n\n @api public", "Defines one required block parameter that may appear last. If type and name is missing the\n default type is \"Callable\", and the name is \"block\". If only one\n parameter is given, then that is the name and the type is \"Callable\".\n\n @api public", "Defines a local type alias, the given string should be a Puppet Language type alias expression\n in string form without the leading 'type' keyword.\n Calls to local_type must be made before the first parameter definition or an error will\n be raised.\n\n @param assignment_string [String] a string on the form 'AliasType = ExistingType'\n @api public", "Merges the result of yielding the given _lookup_variants_ to a given block.\n\n @param lookup_variants [Array] The variants to pass as second argument to the given block\n @return [Object] the merged value.\n @yield [} ]\n @yieldparam variant [Object] each variant given in the _lookup_variants_ array.\n @yieldreturn [Object] the value to merge with other values\n @throws :no_such_key if the lookup was unsuccessful\n\n Merges the result of yielding the given _lookup_variants_ to a given block.\n\n @param lookup_variants [Array] The variants to pass as second argument to the given block\n @return [Object] the merged value.\n @yield [} ]\n @yieldparam variant [Object] each variant given in the _lookup_variants_ array.\n @yieldreturn [Object] the value to merge with other values\n @throws :no_such_key if the lookup was unsuccessful", "return an uncompressed body if the response has been\n compressed", "Define a new right to which access can be provided.", "Is a given combination of name and ip address allowed? If either input\n is non-nil, then both inputs must be provided. If neither input\n is provided, then the authstore is considered local and defaults to \"true\".", "Returns a Type instance by name.\n This will load the type if not already defined.\n @param [String, Symbol] name of the wanted Type\n @return [Puppet::Type, nil] the type or nil if the type was not defined and could not be loaded", "Lookup a loader by its unique name.\n\n @param [String] loader_name the name of the loader to lookup\n @return [Loader] the found loader\n @raise [Puppet::ParserError] if no loader is found", "Finds the appropriate loader for the given `module_name`, or for the environment in case `module_name`\n is `nil` or empty.\n\n @param module_name [String,nil] the name of the module\n @return [Loader::Loader] the found loader\n @raise [Puppet::ParseError] if no loader can be found\n @api private", "Load the main manifest for the given environment\n\n There are two sources that can be used for the initial parse:\n\n 1. The value of `Puppet[:code]`: Puppet can take a string from\n its settings and parse that as a manifest. This is used by various\n Puppet applications to read in a manifest and pass it to the\n environment as a side effect. This is attempted first.\n 2. The contents of the environment's +manifest+ attribute: Puppet will\n try to load the environment manifest. The manifest must be a file.\n\n @return [Model::Program] The manifest parsed into a model object", "Add 4.x definitions found in the given program to the given loader.", "Add given 4.x definition to the given loader.", "Set the entry 'key=value'. If no entry with the\n given key exists, one is appended to the end of the section", "Format the section as text in the way it should be\n written to file", "Read and parse the on-disk file associated with this object", "Create a new section and store it in the file contents\n\n @api private\n @param name [String] The name of the section to create\n @return [Puppet::Util::IniConfig::Section]", "May be called with 3 arguments for message, file, line, and exception, or\n 4 args including the position on the line.", "Handles the Retry-After header of a HTTPResponse\n\n This method checks the response for a Retry-After header and handles\n it by sleeping for the indicated number of seconds. The response is\n returned unmodified if no Retry-After header is present.\n\n @param response [Net::HTTPResponse] A response received from the\n HTTP client.\n\n @return [nil] Sleeps and returns nil if the response contained a\n Retry-After header that indicated the request should be retried.\n @return [Net::HTTPResponse] Returns the `response` unmodified if\n no Retry-After header was present or the Retry-After header could\n not be parsed as an integer or RFC 2822 date.", "Parse the value of a Retry-After header\n\n Parses a string containing an Integer or RFC 2822 datestamp and returns\n an integer number of seconds before a request can be retried.\n\n @param header_value [String] The value of the Retry-After header.\n\n @return [Integer] Number of seconds to wait before retrying the\n request. Will be equal to 0 for the case of date that has already\n passed.\n @return [nil] Returns `nil` when the `header_value` can't be\n parsed as an Integer or RFC 2822 date.", "Retrieve a set of values from a registry key given their names\n Value names listed but not found in the registry will not be added to the\n resultant Hashtable\n\n @param key [RegistryKey] An open handle to a Registry Key\n @param names [String[]] An array of names of registry values to return if they exist\n @return [Hashtable] A hashtable of all of the found values in the registry key", "Customize this so we can do a bit of validation.", "Convert a record into a line by joining the fields together appropriately.\n This is pulled into a separate method so it can be called by the hooks.", "Assign the topic partitions to the group members.\n\n @param members [Array] member ids\n @param topics [Array] topics\n @return [Hash] a hash mapping member\n ids to assignments.", "Clears buffered messages for the given topic and partition.\n\n @param topic [String] the name of the topic.\n @param partition [Integer] the partition id.\n\n @return [nil]", "Initializes a new Kafka client.\n\n @param seed_brokers [Array, String] the list of brokers used to initialize\n the client. Either an Array of connections, or a comma separated string of connections.\n A connection can either be a string of \"host:port\" or a full URI with a scheme.\n If there's a scheme it's ignored and only host/port are used.\n\n @param client_id [String] the identifier for this application.\n\n @param logger [Logger] the logger that should be used by the client.\n\n @param connect_timeout [Integer, nil] the timeout setting for connecting\n to brokers. See {BrokerPool#initialize}.\n\n @param socket_timeout [Integer, nil] the timeout setting for socket\n connections. See {BrokerPool#initialize}.\n\n @param ssl_ca_cert [String, Array, nil] a PEM encoded CA cert, or an Array of\n PEM encoded CA certs, to use with an SSL connection.\n\n @param ssl_ca_cert_file_path [String, nil] a path on the filesystem to a PEM encoded CA cert\n to use with an SSL connection.\n\n @param ssl_client_cert [String, nil] a PEM encoded client cert to use with an\n SSL connection. Must be used in combination with ssl_client_cert_key.\n\n @param ssl_client_cert_key [String, nil] a PEM encoded client cert key to use with an\n SSL connection. Must be used in combination with ssl_client_cert.\n\n @param ssl_client_cert_key_password [String, nil] the password required to read the\n ssl_client_cert_key. Must be used in combination with ssl_client_cert_key.\n\n @param sasl_gssapi_principal [String, nil] a KRB5 principal\n\n @param sasl_gssapi_keytab [String, nil] a KRB5 keytab filepath\n\n @param sasl_scram_username [String, nil] SCRAM username\n\n @param sasl_scram_password [String, nil] SCRAM password\n\n @param sasl_scram_mechanism [String, nil] Scram mechanism, either \"sha256\" or \"sha512\"\n\n @param sasl_over_ssl [Boolean] whether to enforce SSL with SASL\n\n @param sasl_oauth_token_provider [Object, nil] OAuthBearer Token Provider instance that\n implements method token. See {Sasl::OAuth#initialize}\n\n @return [Client]\n Delivers a single message to the Kafka cluster.\n\n **Note:** Only use this API for low-throughput scenarios. If you want to deliver\n many messages at a high rate, or if you want to configure the way messages are\n sent, use the {#producer} or {#async_producer} APIs instead.\n\n @param value [String, nil] the message value.\n @param key [String, nil] the message key.\n @param headers [Hash] the headers for the message.\n @param topic [String] the topic that the message should be written to.\n @param partition [Integer, nil] the partition that the message should be written\n to, or `nil` if either `partition_key` is passed or the partition should be\n chosen at random.\n @param partition_key [String] a value used to deterministically choose a\n partition to write to.\n @param retries [Integer] the number of times to retry the delivery before giving\n up.\n @return [nil]", "Initializes a new Kafka producer.\n\n @param ack_timeout [Integer] The number of seconds a broker can wait for\n replicas to acknowledge a write before responding with a timeout.\n\n @param required_acks [Integer, Symbol] The number of replicas that must acknowledge\n a write, or `:all` if all in-sync replicas must acknowledge.\n\n @param max_retries [Integer] the number of retries that should be attempted\n before giving up sending messages to the cluster. Does not include the\n original attempt.\n\n @param retry_backoff [Integer] the number of seconds to wait between retries.\n\n @param max_buffer_size [Integer] the number of messages allowed in the buffer\n before new writes will raise {BufferOverflow} exceptions.\n\n @param max_buffer_bytesize [Integer] the maximum size of the buffer in bytes.\n attempting to produce messages when the buffer reaches this size will\n result in {BufferOverflow} being raised.\n\n @param compression_codec [Symbol, nil] the name of the compression codec to\n use, or nil if no compression should be performed. Valid codecs: `:snappy`,\n `:gzip`, `:lz4`, `:zstd`\n\n @param compression_threshold [Integer] the number of messages that needs to\n be in a message set before it should be compressed. Note that message sets\n are per-partition rather than per-topic or per-producer.\n\n @return [Kafka::Producer] the Kafka producer.", "Creates a new AsyncProducer instance.\n\n All parameters allowed by {#producer} can be passed. In addition to this,\n a few extra parameters can be passed when creating an async producer.\n\n @param max_queue_size [Integer] the maximum number of messages allowed in\n the queue.\n @param delivery_threshold [Integer] if greater than zero, the number of\n buffered messages that will automatically trigger a delivery.\n @param delivery_interval [Integer] if greater than zero, the number of\n seconds between automatic message deliveries.\n\n @see AsyncProducer\n @return [AsyncProducer]", "Creates a new Kafka consumer.\n\n @param group_id [String] the id of the group that the consumer should join.\n @param session_timeout [Integer] the number of seconds after which, if a client\n hasn't contacted the Kafka cluster, it will be kicked out of the group.\n @param offset_commit_interval [Integer] the interval between offset commits,\n in seconds.\n @param offset_commit_threshold [Integer] the number of messages that can be\n processed before their offsets are committed. If zero, offset commits are\n not triggered by message processing.\n @param heartbeat_interval [Integer] the interval between heartbeats; must be less\n than the session window.\n @param offset_retention_time [Integer] the time period that committed\n offsets will be retained, in seconds. Defaults to the broker setting.\n @param fetcher_max_queue_size [Integer] max number of items in the fetch queue that\n are stored for further processing. Note, that each item in the queue represents a\n response from a single broker.\n @return [Consumer]", "Fetches a batch of messages from a single partition. Note that it's possible\n to get back empty batches.\n\n The starting point for the fetch can be configured with the `:offset` argument.\n If you pass a number, the fetch will start at that offset. However, there are\n two special Symbol values that can be passed instead:\n\n * `:earliest` \u2014 the first offset in the partition.\n * `:latest` \u2014 the next offset that will be written to, effectively making the\n call block until there is a new message in the partition.\n\n The Kafka protocol specifies the numeric values of these two options: -2 and -1,\n respectively. You can also pass in these numbers directly.\n\n ## Example\n\n When enumerating the messages in a partition, you typically fetch batches\n sequentially.\n\n offset = :earliest\n\n loop do\n messages = kafka.fetch_messages(\n topic: \"my-topic\",\n partition: 42,\n offset: offset,\n )\n\n messages.each do |message|\n puts message.offset, message.key, message.value\n\n # Set the next offset that should be read to be the subsequent\n # offset.\n offset = message.offset + 1\n end\n end\n\n See a working example in `examples/simple-consumer.rb`.\n\n @param topic [String] the topic that messages should be fetched from.\n\n @param partition [Integer] the partition that messages should be fetched from.\n\n @param offset [Integer, Symbol] the offset to start reading from. Default is\n the latest offset.\n\n @param max_wait_time [Integer] the maximum amount of time to wait before\n the server responds, in seconds.\n\n @param min_bytes [Integer] the minimum number of bytes to wait for. If set to\n zero, the broker will respond immediately, but the response may be empty.\n The default is 1 byte, which means that the broker will respond as soon as\n a message is written to the partition.\n\n @param max_bytes [Integer] the maximum number of bytes to include in the\n response message set. Default is 1 MB. You need to set this higher if you\n expect messages to be larger than this.\n\n @return [Array] the messages returned from the broker.", "Enumerate all messages in a topic.\n\n @param topic [String] the topic to consume messages from.\n\n @param start_from_beginning [Boolean] whether to start from the beginning\n of the topic or just subscribe to new messages being produced.\n\n @param max_wait_time [Integer] the maximum amount of time to wait before\n the server responds, in seconds.\n\n @param min_bytes [Integer] the minimum number of bytes to wait for. If set to\n zero, the broker will respond immediately, but the response may be empty.\n The default is 1 byte, which means that the broker will respond as soon as\n a message is written to the partition.\n\n @param max_bytes [Integer] the maximum number of bytes to include in the\n response message set. Default is 1 MB. You need to set this higher if you\n expect messages to be larger than this.\n\n @return [nil]", "Creates a topic in the cluster.\n\n @example Creating a topic with log compaction\n # Enable log compaction:\n config = { \"cleanup.policy\" => \"compact\" }\n\n # Create the topic:\n kafka.create_topic(\"dns-mappings\", config: config)\n\n @param name [String] the name of the topic.\n @param num_partitions [Integer] the number of partitions that should be created\n in the topic.\n @param replication_factor [Integer] the replication factor of the topic.\n @param timeout [Integer] a duration of time to wait for the topic to be\n completely created.\n @param config [Hash] topic configuration entries. See\n [the Kafka documentation](https://kafka.apache.org/documentation/#topicconfigs)\n for more information.\n @raise [Kafka::TopicAlreadyExists] if the topic already exists.\n @return [nil]", "Create partitions for a topic.\n\n @param name [String] the name of the topic.\n @param num_partitions [Integer] the number of desired partitions for\n the topic\n @param timeout [Integer] a duration of time to wait for the new\n partitions to be added.\n @return [nil]", "Retrieve the offset of the last message in each partition of the specified topics.\n\n @param topics [Array] topic names.\n @return [Hash>]\n @example\n last_offsets_for('topic-1', 'topic-2') # =>\n # {\n # 'topic-1' => { 0 => 100, 1 => 100 },\n # 'topic-2' => { 0 => 100, 1 => 100 }\n # }", "Initializes a Cluster with a set of seed brokers.\n\n The cluster will try to fetch cluster metadata from one of the brokers.\n\n @param seed_brokers [Array]\n @param broker_pool [Kafka::BrokerPool]\n @param logger [Logger]\n Adds a list of topics to the target list. Only the topics on this list will\n be queried for metadata.\n\n @param topics [Array]\n @return [nil]", "Finds the broker acting as the coordinator of the given transaction.\n\n @param transactional_id: [String]\n @return [Broker] the broker that's currently coordinator.", "Lists all topics in the cluster.", "Fetches the cluster metadata.\n\n This is used to update the partition leadership information, among other things.\n The methods will go through each node listed in `seed_brokers`, connecting to the\n first one that is available. This node will be queried for the cluster metadata.\n\n @raise [ConnectionError] if none of the nodes in `seed_brokers` are available.\n @return [Protocol::MetadataResponse] the cluster metadata.", "Initializes a new AsyncProducer.\n\n @param sync_producer [Kafka::Producer] the synchronous producer that should\n be used in the background.\n @param max_queue_size [Integer] the maximum number of messages allowed in\n the queue.\n @param delivery_threshold [Integer] if greater than zero, the number of\n buffered messages that will automatically trigger a delivery.\n @param delivery_interval [Integer] if greater than zero, the number of\n seconds between automatic message deliveries.\n\n Produces a message to the specified topic.\n\n @see Kafka::Producer#produce\n @param (see Kafka::Producer#produce)\n @raise [BufferOverflow] if the message queue is full.\n @return [nil]", "Writes bytes to the socket, possible with a timeout.\n\n @param bytes [String] the data that should be written to the socket.\n @raise [Errno::ETIMEDOUT] if the timeout is exceeded.\n @return [Integer] the number of bytes written.", "Subscribes the consumer to a topic.\n\n Typically you either want to start reading messages from the very\n beginning of the topic's partitions or you simply want to wait for new\n messages to be written. In the former case, set `start_from_beginning`\n to true (the default); in the latter, set it to false.\n\n @param topic_or_regex [String, Regexp] subscribe to single topic with a string\n or multiple topics matching a regex.\n @param default_offset [Symbol] whether to start from the beginning or the\n end of the topic's partitions. Deprecated.\n @param start_from_beginning [Boolean] whether to start from the beginning\n of the topic or just subscribe to new messages being produced. This\n only applies when first consuming a topic partition \u2013 once the consumer\n has checkpointed its progress, it will always resume from the last\n checkpoint.\n @param max_bytes_per_partition [Integer] the maximum amount of data fetched\n from a single partition at a time.\n @return [nil]", "Pause processing of a specific topic partition.\n\n When a specific message causes the processor code to fail, it can be a good\n idea to simply pause the partition until the error can be resolved, allowing\n the rest of the partitions to continue being processed.\n\n If the `timeout` argument is passed, the partition will automatically be\n resumed when the timeout expires. If `exponential_backoff` is enabled, each\n subsequent pause will cause the timeout to double until a message from the\n partition has been successfully processed.\n\n @param topic [String]\n @param partition [Integer]\n @param timeout [nil, Integer] the number of seconds to pause the partition for,\n or `nil` if the partition should not be automatically resumed.\n @param max_timeout [nil, Integer] the maximum number of seconds to pause for,\n or `nil` if no maximum should be enforced.\n @param exponential_backoff [Boolean] whether to enable exponential backoff.\n @return [nil]", "Resume processing of a topic partition.\n\n @see #pause\n @param topic [String]\n @param partition [Integer]\n @return [nil]", "Whether the topic partition is currently paused.\n\n @see #pause\n @param topic [String]\n @param partition [Integer]\n @return [Boolean] true if the partition is paused, false otherwise.", "Move the consumer's position in the partition back to the configured default\n offset, either the first or latest in the partition.\n\n @param topic [String] the name of the topic.\n @param partition [Integer] the partition number.\n @return [nil]", "Move the consumer's position in the partition to the specified offset.\n\n @param topic [String] the name of the topic.\n @param partition [Integer] the partition number.\n @param offset [Integer] the offset that the consumer position should be moved to.\n @return [nil]", "Return the next offset that should be fetched for the specified partition.\n\n @param topic [String] the name of the topic.\n @param partition [Integer] the partition number.\n @return [Integer] the next offset that should be fetched.", "Commit offsets of messages that have been marked as processed.\n\n If `recommit` is set to true, we will also commit the existing positions\n even if no messages have been processed on a partition. This is done\n in order to avoid the offset information expiring in cases where messages\n are very rare -- it's essentially a keep-alive.\n\n @param recommit [Boolean] whether to recommit offsets that have already been\n committed.\n @return [nil]", "Clear stored offset information for all partitions except those specified\n in `excluded`.\n\n offset_manager.clear_offsets_excluding(\"my-topic\" => [1, 2, 3])\n\n @return [nil]", "Sends a request over the connection.\n\n @param request [#encode, #response_class] the request that should be\n encoded and written.\n\n @return [Object] the response.", "Writes a request over the connection.\n\n @param request [#encode] the request that should be encoded and written.\n\n @return [nil]", "Reads a response from the connection.\n\n @param response_class [#decode] an object that can decode the response from\n a given Decoder.\n\n @return [nil]", "Sends all buffered messages to the Kafka brokers.\n\n Depending on the value of `required_acks` used when initializing the producer,\n this call may block until the specified number of replicas have acknowledged\n the writes. The `ack_timeout` setting places an upper bound on the amount of\n time the call will block before failing.\n\n @raise [DeliveryFailed] if not all messages could be successfully sent.\n @return [nil]", "Sends batch last offset to the consumer group coordinator, and also marks\n this offset as part of the current transaction. This offset will be considered\n committed only if the transaction is committed successfully.\n\n This method should be used when you need to batch consumed and produced messages\n together, typically in a consume-transform-produce pattern. Thus, the specified\n group_id should be the same as config parameter group_id of the used\n consumer.\n\n @return [nil]", "Syntactic sugar to enable easier transaction usage. Do the following steps\n\n - Start the transaction (with Producer#begin_transaction)\n - Yield the given block\n - Commit the transaction (with Producer#commit_transaction)\n\n If the block raises exception, the transaction is automatically aborted\n *before* bubble up the exception.\n\n If the block raises Kafka::Producer::AbortTransaction indicator exception,\n it aborts the transaction silently, without throwing up that exception.\n\n @return [nil]", "Open new window.\n Current window doesn't change as the result of this call.\n It should be switched to explicitly.\n\n @return [Capybara::Window] window that has been opened", "Registers the constants to be auto loaded.\n\n @param prefix [String] The require prefix. If the path is inside Faraday,\n then it will be prefixed with the root path of this loaded\n Faraday version.\n @param options [{ Symbol => String }] library names.\n\n @example\n\n Faraday.autoload_all 'faraday/foo',\n Bar: 'bar'\n\n # requires faraday/foo/bar to load Faraday::Bar.\n Faraday::Bar\n\n @return [void]", "Filters the module's contents with those that have been already\n autoloaded.\n\n @return [Array]", "parse a multipart MIME message, returning a hash of any multipart errors", "Executes a block which should try to require and reference dependent\n libraries", "Check if the adapter is parallel-capable.\n\n @yield if the adapter isn't parallel-capable, or if no adapter is set yet.\n\n @return [Object, nil] a parallel manager or nil if yielded\n @api private", "Parses the given URL with URI and stores the individual\n components in this connection. These components serve as defaults for\n requests made by this connection.\n\n @param url [String, URI]\n @param encoder [Object]\n\n @example\n\n conn = Faraday::Connection.new { ... }\n conn.url_prefix = \"https://sushi.com/api\"\n conn.scheme # => https\n conn.path_prefix # => \"/api\"\n\n conn.get(\"nigiri?page=2\") # accesses https://sushi.com/api/nigiri", "Takes a relative url for a request and combines it with the defaults\n set on the connection instance.\n\n @param url [String]\n @param extra_params [Hash]\n\n @example\n conn = Faraday::Connection.new { ... }\n conn.url_prefix = \"https://sushi.com/api?token=abc\"\n conn.scheme # => https\n conn.path_prefix # => \"/api\"\n\n conn.build_url(\"nigiri?page=2\")\n # => https://sushi.com/api/nigiri?token=abc&page=2\n\n conn.build_url(\"nigiri\", page: 2)\n # => https://sushi.com/api/nigiri?token=abc&page=2", "Creates and configures the request object.\n\n @param method [Symbol]\n\n @yield [Faraday::Request] if block given\n @return [Faraday::Request]", "Build an absolute URL based on url_prefix.\n\n @param url [String, URI]\n @param params [Faraday::Utils::ParamsHash] A Faraday::Utils::ParamsHash to\n replace the query values\n of the resulting url (default: nil).\n\n @return [URI]", "Receives a String or URI and returns just\n the path with the query string sorted.", "Recursive hash update", "Update path and params.\n\n @param path [URI, String]\n @param params [Hash, nil]\n @return [void]", "Marshal serialization support.\n\n @return [Hash] the hash ready to be serialized in Marshal.", "Marshal serialization support.\n Restores the instance variables according to the +serialised+.\n @param serialised [Hash] the serialised object.", "Returns the policy of a specified bucket.\n\n @option params [required, String] :bucket\n\n @return [Types::GetBucketPolicyOutput] Returns a {Seahorse::Client::Response response} object which responds to the following methods:\n\n * {Types::GetBucketPolicyOutput#policy #policy} => IO\n\n\n @example Example: To get bucket policy\n\n # The following example returns bucket policy associated with a bucket.\n\n resp = client.get_bucket_policy({\n bucket: \"examplebucket\",\n })\n\n resp.to_h outputs the following:\n {\n policy: \"{\\\"Version\\\":\\\"2008-10-17\\\",\\\"Id\\\":\\\"LogPolicy\\\",\\\"Statement\\\":[{\\\"Sid\\\":\\\"Enables the log delivery group to publish logs to your bucket \\\",\\\"Effect\\\":\\\"Allow\\\",\\\"Principal\\\":{\\\"AWS\\\":\\\"111122223333\\\"},\\\"Action\\\":[\\\"s3:GetBucketAcl\\\",\\\"s3:GetObjectAcl\\\",\\\"s3:PutObject\\\"],\\\"Resource\\\":[\\\"arn:aws:s3:::policytest1/*\\\",\\\"arn:aws:s3:::policytest1\\\"]}]}\",\n }\n\n @example Request syntax with placeholder values\n\n resp = client.get_bucket_policy({\n bucket: \"BucketName\", # required\n })\n\n @example Response structure\n\n resp.policy #=> String\n\n @see http://docs.aws.amazon.com/goto/WebAPI/s3-2006-03-01/GetBucketPolicy AWS API Documentation\n\n @overload get_bucket_policy(params = {})\n @param [Hash] params ({})", "Retrieves objects from Amazon S3.\n\n @option params [String, IO] :response_target\n Where to write response data, file path, or IO object.\n\n @option params [required, String] :bucket\n\n @option params [String] :if_match\n Return the object only if its entity tag (ETag) is the same as the one\n specified, otherwise return a 412 (precondition failed).\n\n @option params [Time,DateTime,Date,Integer,String] :if_modified_since\n Return the object only if it has been modified since the specified\n time, otherwise return a 304 (not modified).\n\n @option params [String] :if_none_match\n Return the object only if its entity tag (ETag) is different from the\n one specified, otherwise return a 304 (not modified).\n\n @option params [Time,DateTime,Date,Integer,String] :if_unmodified_since\n Return the object only if it has not been modified since the specified\n time, otherwise return a 412 (precondition failed).\n\n @option params [required, String] :key\n\n @option params [String] :range\n Downloads the specified range bytes of an object. For more information\n about the HTTP Range header, go to\n http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.35.\n\n @option params [String] :response_cache_control\n Sets the Cache-Control header of the response.\n\n @option params [String] :response_content_disposition\n Sets the Content-Disposition header of the response\n\n @option params [String] :response_content_encoding\n Sets the Content-Encoding header of the response.\n\n @option params [String] :response_content_language\n Sets the Content-Language header of the response.\n\n @option params [String] :response_content_type\n Sets the Content-Type header of the response.\n\n @option params [Time,DateTime,Date,Integer,String] :response_expires\n Sets the Expires header of the response.\n\n @option params [String] :version_id\n VersionId used to reference a specific version of the object.\n\n @option params [String] :sse_customer_algorithm\n Specifies the algorithm to use to when encrypting the object (e.g.,\n AES256).\n\n @option params [String] :sse_customer_key\n Specifies the customer-provided encryption key for Amazon S3 to use in\n encrypting data. This value is used to store the object and then it is\n discarded; Amazon does not store the encryption key. The key must be\n appropriate for use with the algorithm specified in the\n x-amz-server-side\u200b-encryption\u200b-customer-algorithm header.\n\n @option params [String] :sse_customer_key_md5\n Specifies the 128-bit MD5 digest of the encryption key according to\n RFC 1321. Amazon S3 uses this header for a message integrity check to\n ensure the encryption key was transmitted without error.\n\n @option params [String] :request_payer\n Confirms that the requester knows that she or he will be charged for\n the request. Bucket owners need not specify this parameter in their\n requests. Documentation on downloading objects from requester pays\n buckets can be found at\n http://docs.aws.amazon.com/AmazonS3/latest/dev/ObjectsinRequesterPaysBuckets.html\n\n @option params [Integer] :part_number\n Part number of the object being read. This is a positive integer\n between 1 and 10,000. Effectively performs a 'ranged' GET request\n for the part specified. Useful for downloading just a part of an\n object.\n\n @return [Types::GetObjectOutput] Returns a {Seahorse::Client::Response response} object which responds to the following methods:\n\n * {Types::GetObjectOutput#body #body} => IO\n * {Types::GetObjectOutput#delete_marker #delete_marker} => Boolean\n * {Types::GetObjectOutput#accept_ranges #accept_ranges} => String\n * {Types::GetObjectOutput#expiration #expiration} => String\n * {Types::GetObjectOutput#restore #restore} => String\n * {Types::GetObjectOutput#last_modified #last_modified} => Time\n * {Types::GetObjectOutput#content_length #content_length} => Integer\n * {Types::GetObjectOutput#etag #etag} => String\n * {Types::GetObjectOutput#missing_meta #missing_meta} => Integer\n * {Types::GetObjectOutput#version_id #version_id} => String\n * {Types::GetObjectOutput#cache_control #cache_control} => String\n * {Types::GetObjectOutput#content_disposition #content_disposition} => String\n * {Types::GetObjectOutput#content_encoding #content_encoding} => String\n * {Types::GetObjectOutput#content_language #content_language} => String\n * {Types::GetObjectOutput#content_range #content_range} => String\n * {Types::GetObjectOutput#content_type #content_type} => String\n * {Types::GetObjectOutput#expires #expires} => Time\n * {Types::GetObjectOutput#expires_string #expires_string} => String\n * {Types::GetObjectOutput#website_redirect_location #website_redirect_location} => String\n * {Types::GetObjectOutput#server_side_encryption #server_side_encryption} => String\n * {Types::GetObjectOutput#metadata #metadata} => Hash<String,String>\n * {Types::GetObjectOutput#sse_customer_algorithm #sse_customer_algorithm} => String\n * {Types::GetObjectOutput#sse_customer_key_md5 #sse_customer_key_md5} => String\n * {Types::GetObjectOutput#ssekms_key_id #ssekms_key_id} => String\n * {Types::GetObjectOutput#storage_class #storage_class} => String\n * {Types::GetObjectOutput#request_charged #request_charged} => String\n * {Types::GetObjectOutput#replication_status #replication_status} => String\n * {Types::GetObjectOutput#parts_count #parts_count} => Integer\n * {Types::GetObjectOutput#tag_count #tag_count} => Integer\n * {Types::GetObjectOutput#object_lock_mode #object_lock_mode} => String\n * {Types::GetObjectOutput#object_lock_retain_until_date #object_lock_retain_until_date} => Time\n * {Types::GetObjectOutput#object_lock_legal_hold_status #object_lock_legal_hold_status} => String\n\n\n @example Example: To retrieve an object\n\n # The following example retrieves an object for an S3 bucket.\n\n resp = client.get_object({\n bucket: \"examplebucket\",\n key: \"HappyFace.jpg\",\n })\n\n resp.to_h outputs the following:\n {\n accept_ranges: \"bytes\",\n content_length: 3191,\n content_type: \"image/jpeg\",\n etag: \"\\\"6805f2cfc46c0f04559748bb039d69ae\\\"\",\n last_modified: Time.parse(\"Thu, 15 Dec 2016 01:19:41 GMT\"),\n metadata: {\n },\n tag_count: 2,\n version_id: \"null\",\n }\n\n @example Example: To retrieve a byte range of an object\n\n # The following example retrieves an object for an S3 bucket. The request specifies the range header to retrieve a\n # specific byte range.\n\n resp = client.get_object({\n bucket: \"examplebucket\",\n key: \"SampleFile.txt\",\n range: \"bytes=0-9\",\n })\n\n resp.to_h outputs the following:\n {\n accept_ranges: \"bytes\",\n content_length: 10,\n content_range: \"bytes 0-9/43\",\n content_type: \"text/plain\",\n etag: \"\\\"0d94420ffd0bc68cd3d152506b97a9cc\\\"\",\n last_modified: Time.parse(\"Thu, 09 Oct 2014 22:57:28 GMT\"),\n metadata: {\n },\n version_id: \"null\",\n }\n\n @example Download an object to disk\n # stream object directly to disk\n resp = s3.get_object(\n response_target: '/path/to/file',\n bucket: 'bucket-name',\n key: 'object-key')\n\n # you can still access other response data\n resp.metadata #=> { ... }\n resp.etag #=> \"...\"\n\n @example Download object into memory\n # omit :response_target to download to a StringIO in memory\n resp = s3.get_object(bucket: 'bucket-name', key: 'object-key')\n\n # call #read or #string on the response body\n resp.body.read\n #=> '...'\n\n @example Streaming data to a block\n # WARNING: yielding data to a block disables retries of networking errors\n File.open('/path/to/file', 'wb') do |file|\n s3.get_object(bucket: 'bucket-name', key: 'object-key') do |chunk|\n file.write(chunk)\n end\n end\n\n @example Request syntax with placeholder values\n\n resp = client.get_object({\n bucket: \"BucketName\", # required\n if_match: \"IfMatch\",\n if_modified_since: Time.now,\n if_none_match: \"IfNoneMatch\",\n if_unmodified_since: Time.now,\n key: \"ObjectKey\", # required\n range: \"Range\",\n response_cache_control: \"ResponseCacheControl\",\n response_content_disposition: \"ResponseContentDisposition\",\n response_content_encoding: \"ResponseContentEncoding\",\n response_content_language: \"ResponseContentLanguage\",\n response_content_type: \"ResponseContentType\",\n response_expires: Time.now,\n version_id: \"ObjectVersionId\",\n sse_customer_algorithm: \"SSECustomerAlgorithm\",\n sse_customer_key: \"SSECustomerKey\",\n sse_customer_key_md5: \"SSECustomerKeyMD5\",\n request_payer: \"requester\", # accepts requester\n part_number: 1,\n })\n\n @example Response structure\n\n resp.body #=> IO\n resp.delete_marker #=> Boolean\n resp.accept_ranges #=> String\n resp.expiration #=> String\n resp.restore #=> String\n resp.last_modified #=> Time\n resp.content_length #=> Integer\n resp.etag #=> String\n resp.missing_meta #=> Integer\n resp.version_id #=> String\n resp.cache_control #=> String\n resp.content_disposition #=> String\n resp.content_encoding #=> String\n resp.content_language #=> String\n resp.content_range #=> String\n resp.content_type #=> String\n resp.expires #=> Time\n resp.expires_string #=> String\n resp.website_redirect_location #=> String\n resp.server_side_encryption #=> String, one of \"AES256\", \"aws:kms\"\n resp.metadata #=> Hash\n resp.metadata[\"MetadataKey\"] #=> String\n resp.sse_customer_algorithm #=> String\n resp.sse_customer_key_md5 #=> String\n resp.ssekms_key_id #=> String\n resp.storage_class #=> String, one of \"STANDARD\", \"REDUCED_REDUNDANCY\", \"STANDARD_IA\", \"ONEZONE_IA\", \"INTELLIGENT_TIERING\", \"GLACIER\", \"DEEP_ARCHIVE\"\n resp.request_charged #=> String, one of \"requester\"\n resp.replication_status #=> String, one of \"COMPLETE\", \"PENDING\", \"FAILED\", \"REPLICA\"\n resp.parts_count #=> Integer\n resp.tag_count #=> Integer\n resp.object_lock_mode #=> String, one of \"GOVERNANCE\", \"COMPLIANCE\"\n resp.object_lock_retain_until_date #=> Time\n resp.object_lock_legal_hold_status #=> String, one of \"ON\", \"OFF\"\n\n @see http://docs.aws.amazon.com/goto/WebAPI/s3-2006-03-01/GetObject AWS API Documentation\n\n @overload get_object(params = {})\n @param [Hash] params ({})", "Return torrent files from a bucket.\n\n @option params [String, IO] :response_target\n Where to write response data, file path, or IO object.\n\n @option params [required, String] :bucket\n\n @option params [required, String] :key\n\n @option params [String] :request_payer\n Confirms that the requester knows that she or he will be charged for\n the request. Bucket owners need not specify this parameter in their\n requests. Documentation on downloading objects from requester pays\n buckets can be found at\n http://docs.aws.amazon.com/AmazonS3/latest/dev/ObjectsinRequesterPaysBuckets.html\n\n @return [Types::GetObjectTorrentOutput] Returns a {Seahorse::Client::Response response} object which responds to the following methods:\n\n * {Types::GetObjectTorrentOutput#body #body} => IO\n * {Types::GetObjectTorrentOutput#request_charged #request_charged} => String\n\n\n @example Example: To retrieve torrent files for an object\n\n # The following example retrieves torrent files of an object.\n\n resp = client.get_object_torrent({\n bucket: \"examplebucket\",\n key: \"HappyFace.jpg\",\n })\n\n resp.to_h outputs the following:\n {\n }\n\n @example Request syntax with placeholder values\n\n resp = client.get_object_torrent({\n bucket: \"BucketName\", # required\n key: \"ObjectKey\", # required\n request_payer: \"requester\", # accepts requester\n })\n\n @example Response structure\n\n resp.body #=> IO\n resp.request_charged #=> String, one of \"requester\"\n\n @see http://docs.aws.amazon.com/goto/WebAPI/s3-2006-03-01/GetObjectTorrent AWS API Documentation\n\n @overload get_object_torrent(params = {})\n @param [Hash] params ({})", "Polls an API operation until a resource enters a desired state.\n\n ## Basic Usage\n\n A waiter will call an API operation until:\n\n * It is successful\n * It enters a terminal state\n * It makes the maximum number of attempts\n\n In between attempts, the waiter will sleep.\n\n # polls in a loop, sleeping between attempts\n client.wait_until(waiter_name, params)\n\n ## Configuration\n\n You can configure the maximum number of polling attempts, and the\n delay (in seconds) between each polling attempt. You can pass\n configuration as the final arguments hash.\n\n # poll for ~25 seconds\n client.wait_until(waiter_name, params, {\n max_attempts: 5,\n delay: 5,\n })\n\n ## Callbacks\n\n You can be notified before each polling attempt and before each\n delay. If you throw `:success` or `:failure` from these callbacks,\n it will terminate the waiter.\n\n started_at = Time.now\n client.wait_until(waiter_name, params, {\n\n # disable max attempts\n max_attempts: nil,\n\n # poll for 1 hour, instead of a number of attempts\n before_wait: -> (attempts, response) do\n throw :failure if Time.now - started_at > 3600\n end\n })\n\n ## Handling Errors\n\n When a waiter is unsuccessful, it will raise an error.\n All of the failure errors extend from\n {Aws::Waiters::Errors::WaiterFailed}.\n\n begin\n client.wait_until(...)\n rescue Aws::Waiters::Errors::WaiterFailed\n # resource did not enter the desired state in time\n end\n\n ## Valid Waiters\n\n The following table lists the valid waiter names, the operations they call,\n and the default `:delay` and `:max_attempts` values.\n\n | waiter_name | params | :delay | :max_attempts |\n | ----------------- | -------------- | -------- | ------------- |\n | bucket_exists | {#head_bucket} | 5 | 20 |\n | bucket_not_exists | {#head_bucket} | 5 | 20 |\n | object_exists | {#head_object} | 5 | 20 |\n | object_not_exists | {#head_object} | 5 | 20 |\n\n @raise [Errors::FailureStateError] Raised when the waiter terminates\n because the waiter has entered a state that it will not transition\n out of, preventing success.\n\n @raise [Errors::TooManyAttemptsError] Raised when the configured\n maximum number of attempts have been made, and the waiter is not\n yet successful.\n\n @raise [Errors::UnexpectedError] Raised when an error is encounted\n while polling for a resource that is not expected.\n\n @raise [Errors::NoSuchWaiterError] Raised when you request to wait\n for an unknown state.\n\n @return [Boolean] Returns `true` if the waiter was successful.\n @param [Symbol] waiter_name\n @param [Hash] params ({})\n @param [Hash] options ({})\n @option options [Integer] :max_attempts\n @option options [Integer] :delay\n @option options [Proc] :before_attempt\n @option options [Proc] :before_wait", "Constructs a new SharedConfig provider object. This will load the shared\n credentials file, and optionally the shared configuration file, as ini\n files which support profiles.\n\n By default, the shared credential file (the default path for which is\n `~/.aws/credentials`) and the shared config file (the default path for\n which is `~/.aws/config`) are loaded. However, if you set the\n `ENV['AWS_SDK_CONFIG_OPT_OUT']` environment variable, only the shared\n credential file will be loaded. You can specify the shared credential\n file path with the `ENV['AWS_SHARED_CREDENTIALS_FILE']` environment\n variable or with the `:credentials_path` option. Similarly, you can\n specify the shared config file path with the `ENV['AWS_CONFIG_FILE']`\n environment variable or with the `:config_path` option.\n\n The default profile name is 'default'. You can specify the profile name\n with the `ENV['AWS_PROFILE']` environment variable or with the\n `:profile_name` option.\n\n @param [Hash] options\n @option options [String] :credentials_path Path to the shared credentials\n file. If not specified, will check `ENV['AWS_SHARED_CREDENTIALS_FILE']`\n before using the default value of \"#{Dir.home}/.aws/credentials\".\n @option options [String] :config_path Path to the shared config file.\n If not specified, will check `ENV['AWS_CONFIG_FILE']` before using the\n default value of \"#{Dir.home}/.aws/config\".\n @option options [String] :profile_name The credential/config profile name\n to use. If not specified, will check `ENV['AWS_PROFILE']` before using\n the fixed default value of 'default'.\n @option options [Boolean] :config_enabled If true, loads the shared config\n file and enables new config values outside of the old shared credential\n spec.\n @api private", "Attempts to assume a role from shared config or shared credentials file.\n Will always attempt first to assume a role from the shared credentials\n file, if present.", "Deeply converts the Structure into a hash. Structure members that\n are `nil` are omitted from the resultant hash.\n\n You can call #orig_to_h to get vanilla #to_h behavior as defined\n in stdlib Struct.\n\n @return [Hash]", "Allows you to access all of the requests that the stubbed client has made\n\n @params [Boolean] exclude_presign Setting to true for filtering out not sent requests from\n generating presigned urls. Default to false.\n @return [Array] Returns an array of the api requests made, each request object contains the\n :operation_name, :params, and :context of the request.\n @raise [NotImplementedError] Raises `NotImplementedError` when the client is not stubbed", "Generates and returns stubbed response data from the named operation.\n\n s3 = Aws::S3::Client.new\n s3.stub_data(:list_buckets)\n #=> #>\n\n In addition to generating default stubs, you can provide data to\n apply to the response stub.\n\n s3.stub_data(:list_buckets, buckets:[{name:'aws-sdk'}])\n #=> #],\n owner=#>\n\n @param [Symbol] operation_name\n @param [Hash] data\n @return [Structure] Returns a stubbed response data structure. The\n actual class returned will depend on the given `operation_name`.", "Yields the current and each following response to the given block.\n @yieldparam [Response] response\n @return [Enumerable,nil] Returns a new Enumerable if no block is given.", "This operation downloads the output of the job you initiated using\n InitiateJob. Depending on the job type you specified when you\n initiated the job, the output will be either the content of an archive\n or a vault inventory.\n\n You can download all the job output or download a portion of the\n output by specifying a byte range. In the case of an archive retrieval\n job, depending on the byte range you specify, Amazon Glacier returns\n the checksum for the portion of the data. You can compute the checksum\n on the client and verify that the values match to ensure the portion\n you downloaded is the correct data.\n\n A job ID will not expire for at least 24 hours after Amazon Glacier\n completes the job. That a byte range. For both archive and inventory\n retrieval jobs, you should verify the downloaded size against the size\n returned in the headers from the **Get Job Output** response.\n\n For archive retrieval jobs, you should also verify that the size is\n what you expected. If you download a portion of the output, the\n expected size is based on the range of bytes you specified. For\n example, if you specify a range of `bytes=0-1048575`, you should\n verify your download size is 1,048,576 bytes. If you download an\n entire archive, the expected size is the size of the archive when you\n uploaded it to Amazon Glacier The expected size is also returned in\n the headers from the **Get Job Output** response.\n\n In the case of an archive retrieval job, depending on the byte range\n you specify, Amazon Glacier returns the checksum for the portion of\n the data. To ensure the portion you downloaded is the correct data,\n compute the checksum on the client, verify that the values match, and\n verify that the size is what you expected.\n\n A job ID does not expire for at least 24 hours after Amazon Glacier\n completes the job. That is, you can download the job output within the\n 24 hours period after Amazon Glacier completes the job.\n\n An AWS account has full permission to perform all operations\n (actions). However, AWS Identity and Access Management (IAM) users\n don't have any permissions by default. You must grant them explicit\n permission to perform specific actions. For more information, see\n [Access Control Using AWS Identity and Access Management (IAM)][1].\n\n For conceptual information and the underlying REST API, see\n [Downloading a Vault Inventory][2], [Downloading an Archive][3], and\n [Get Job Output ][4]\n\n\n\n [1]: http://docs.aws.amazon.com/amazonglacier/latest/dev/using-iam-with-amazon-glacier.html\n [2]: http://docs.aws.amazon.com/amazonglacier/latest/dev/vault-inventory.html\n [3]: http://docs.aws.amazon.com/amazonglacier/latest/dev/downloading-an-archive.html\n [4]: http://docs.aws.amazon.com/amazonglacier/latest/dev/api-job-output-get.html\n\n @option params [required, String] :account_id\n The `AccountId` value is the AWS account ID of the account that owns\n the vault. You can either specify an AWS account ID or optionally a\n single '`-`' (hyphen), in which case Amazon Glacier uses the AWS\n account ID associated with the credentials used to sign the request.\n If you use an account ID, do not include any hyphens ('-') in the\n ID.\n\n @option params [required, String] :vault_name\n The name of the vault.\n\n @option params [required, String] :job_id\n The job ID whose data is downloaded.\n\n @option params [String] :range\n The range of bytes to retrieve from the output. For example, if you\n want to download the first 1,048,576 bytes, specify the range as\n `bytes=0-1048575`. By default, this operation downloads the entire\n output.\n\n If the job output is large, then you can use a range to retrieve a\n portion of the output. This allows you to download the entire output\n in smaller chunks of bytes. For example, suppose you have 1 GB of job\n output you want to download and you decide to download 128 MB chunks\n of data at a time, which is a total of eight Get Job Output requests.\n You use the following process to download the job output:\n\n 1. Download a 128 MB chunk of output by specifying the appropriate\n byte range. Verify that all 128 MB of data was received.\n\n 2. Along with the data, the response includes a SHA256 tree hash of\n the payload. You compute the checksum of the payload on the client\n and compare it with the checksum you received in the response to\n ensure you received all the expected data.\n\n 3. Repeat steps 1 and 2 for all the eight 128 MB chunks of output\n data, each time specifying the appropriate byte range.\n\n 4. After downloading all the parts of the job output, you have a list\n of eight checksum values. Compute the tree hash of these values to\n find the checksum of the entire output. Using the DescribeJob API,\n obtain job information of the job that provided you the output.\n The response includes the checksum of the entire archive stored in\n Amazon Glacier. You compare this value with the checksum you\n computed to ensure you have downloaded the entire archive content\n with no errors.\n\n @return [Types::GetJobOutputOutput] Returns a {Seahorse::Client::Response response} object which responds to the following methods:\n\n * {Types::GetJobOutputOutput#body #body} => IO\n * {Types::GetJobOutputOutput#checksum #checksum} => String\n * {Types::GetJobOutputOutput#status #status} => Integer\n * {Types::GetJobOutputOutput#content_range #content_range} => String\n * {Types::GetJobOutputOutput#accept_ranges #accept_ranges} => String\n * {Types::GetJobOutputOutput#content_type #content_type} => String\n * {Types::GetJobOutputOutput#archive_description #archive_description} => String\n\n\n @example Example: To get the output of a previously initiated job\n\n # The example downloads the output of a previously initiated inventory retrieval job that is identified by the job ID.\n\n resp = client.get_job_output({\n account_id: \"-\",\n job_id: \"zbxcm3Z_3z5UkoroF7SuZKrxgGoDc3RloGduS7Eg-RO47Yc6FxsdGBgf_Q2DK5Ejh18CnTS5XW4_XqlNHS61dsO4CnMW\",\n range: \"\",\n vault_name: \"my-vaul\",\n })\n\n resp.to_h outputs the following:\n {\n accept_ranges: \"bytes\",\n body: \"inventory-data\",\n content_type: \"application/json\",\n status: 200,\n }\n\n @example Request syntax with placeholder values\n\n resp = client.get_job_output({\n account_id: \"string\", # required\n vault_name: \"string\", # required\n job_id: \"string\", # required\n range: \"string\",\n })\n\n @example Response structure\n\n resp.body #=> IO\n resp.checksum #=> String\n resp.status #=> Integer\n resp.content_range #=> String\n resp.accept_ranges #=> String\n resp.content_type #=> String\n resp.archive_description #=> String\n\n @overload get_job_output(params = {})\n @param [Hash] params ({})", "checking whether an unexpired endpoint key exists in cache\n @param [String] key\n @return [Boolean]", "extract the key to be used in the cache from request context\n @param [RequestContext] ctx\n @return [String]", "Create a ruby hash from a string passed by the jekyll tag", "Ensure that your plugin conforms to good hook naming conventions.\n\n Resque::Plugin.lint(MyResquePlugin)", "DEPRECATED. Processes a single job. If none is given, it will\n try to produce one. Usually run in the child.", "Reports the exception and marks the job as failed", "Processes a given job in the child.", "Attempts to grab a job off one of the provided queues. Returns\n nil if no job can be found.", "Reconnect to Redis to avoid sharing a connection with the parent,\n retry up to 3 times with increasing delay before giving up.", "Kill the child and shutdown immediately.\n If not forking, abort this process.", "Runs a named hook, passing along any arguments.", "Unregisters ourself as a worker. Useful when shutting down.", "Given a job, tells Redis we're working on it. Useful for seeing\n what workers are doing and when.", "Returns an Array of string pids of all the other workers on this\n machine. Useful when pruning dead workers on startup.", "Given an exception object, hands off the needed parameters to\n the Failure module.", "Create a new endpoint.\n @param new_settings [InheritableSetting] settings to determine the params,\n validations, and other properties from.\n @param options [Hash] attributes of this endpoint\n @option options path [String or Array] the path to this endpoint, within\n the current scope.\n @option options method [String or Array] which HTTP method(s) can be used\n to reach this endpoint.\n @option options route_options [Hash]\n @note This happens at the time of API definition, so in this context the\n endpoint does not know if it will be mounted under a different endpoint.\n @yield a block defining what your API should do when this endpoint is hit\n Update our settings from a given set of stackable parameters. Used when\n the endpoint's API is mounted under another one.", "Prior to version 4.1 of rails double quotes were inadventently removed in json_escape.\n This adds the correct json_escape functionality to rails versions < 4.1", "Register a resource into this namespace. The preffered method to access this is to\n use the global registration ActiveAdmin.register which delegates to the proper\n namespace instance.", "Add a callback to be ran when we build the menu\n\n @param [Symbol] name The name of the menu. Default: :default\n @yield [ActiveAdmin::Menu] The block to be ran when the menu is built\n\n @return [void]", "The default logout menu item\n\n @param [ActiveAdmin::MenuItem] menu The menu to add the logout link to\n @param [Fixnum] priority The numeric priority for the order in which it appears\n @param [Hash] html_options An options hash to pass along to link_to", "The default user session menu item\n\n @param [ActiveAdmin::MenuItem] menu The menu to add the logout link to\n @param [Fixnum] priority The numeric priority for the order in which it appears\n @param [Hash] html_options An options hash to pass along to link_to", "Page content.\n\n The block should define the view using Arbre.\n\n Example:\n\n ActiveAdmin.register \"My Page\" do\n content do\n para \"Sweet!\"\n end\n end", "Finds a resource based on the resource name, resource class, or base class.", "Registers a brand new configuration for the given resource.", "Creates a namespace for the given name\n\n Yields the namespace if a block is given\n\n @return [Namespace] the new or existing namespace", "Register a page\n\n @param name [String] The page name\n @option [Hash] Accepts option :namespace.\n @&block The registration block.", "Loads all ruby files that are within the load_paths setting.\n To reload everything simply call `ActiveAdmin.unload!`", "Creates all the necessary routes for the ActiveAdmin configurations\n\n Use this within the routes.rb file:\n\n Application.routes.draw do |map|\n ActiveAdmin.routes(self)\n end\n\n @param rails_router [ActionDispatch::Routing::Mapper]", "Hook into the Rails code reloading mechanism so that things are reloaded\n properly in development mode.\n\n If any of the app files (e.g. models) has changed, we need to reload all\n the admin files. If the admin files themselves has changed, we need to\n regenerate the routes as well.", "remove options that should not render as attributes", "Renders the Formtastic inputs then appends ActiveAdmin delete and sort actions.", "Capture the ADD JS", "Defines the routes for each resource", "Defines member and collection actions", "Simple callback system. Implements before and after callbacks for\n use within the controllers.\n\n We didn't use the ActiveSupport callbacks because they do not support\n passing in any arbitrary object into the callback method (which we\n need to do)", "Keys included in the `permitted_params` setting are automatically whitelisted.\n\n Either\n\n permit_params :title, :author, :body, tags: []\n\n Or\n\n permit_params do\n defaults = [:title, :body]\n if current_user.admin?\n defaults + [:author]\n else\n defaults\n end\n end", "Configure the index page for the resource", "Configure the show page for the resource", "Configure the CSV format\n\n For example:\n\n csv do\n column :name\n column(\"Author\") { |post| post.author.full_name }\n end\n\n csv col_sep: \";\", force_quotes: true do\n column :name\n end", "Member Actions give you the functionality of defining both the\n action and the route directly from your ActiveAdmin registration\n block.\n\n For example:\n\n ActiveAdmin.register Post do\n member_action :comments do\n @post = Post.find(params[:id])\n @comments = @post.comments\n end\n end\n\n Will create a new controller action comments and will hook it up to\n the named route (comments_admin_post_path) /admin/posts/:id/comments\n\n You can treat everything within the block as a standard Rails controller\n action.", "compute the price range", "Loads a configuration, ensuring it extends the default configuration.", "Filter out directories. This could happen when changing a symlink to a\n directory as part of an amendment, since the symlink will still appear as\n a file, but the actual working tree will have a directory.", "Check the yard coverage\n\n Return a :pass if the coverage is enough, :warn if it couldn't be read,\n otherwise, it has been read successfully.", "Create the error messages", "Get a list of files that were added, copied, or modified in the merge\n commit. Renames and deletions are ignored, since there should be nothing\n to check.", "Get a list of files that have been added or modified as part of a\n rewritten commit. Renames and deletions are ignored, since there should be\n nothing to check.", "Returns status and output for messages assuming no special treatment of\n messages occurring on unmodified lines.", "Runs the hook and transforms the status returned based on the hook's\n configuration.\n\n Poorly named because we already have a bunch of hooks in the wild that\n implement `#run`, and we needed a wrapper step to transform the status\n based on any custom configuration.", "If the hook defines required library paths that it wants to load, attempt\n to load them.", "Stash unstaged contents of files so hooks don't see changes that aren't\n about to be committed.", "Restore unstaged changes and reset file modification times so it appears\n as if nothing ever changed.\n\n We want to restore the modification times for each of the files after\n every step to ensure as little time as possible has passed while the\n modification time on the file was newer. This helps us play more nicely\n with file watchers.", "Get a list of added, copied, or modified files that have been staged.\n Renames and deletions are ignored, since there should be nothing to check.", "Clears the working tree so that the stash can be applied.", "Applies the stash to the working tree to restore the user's state.", "Stores the modification times for all modified files to make it appear like\n they never changed.\n\n This prevents (some) editors from complaining about files changing when we\n stash changes before running the hooks.", "Restores the file modification times for all modified files to make it\n appear like they never changed.", "Validates hash for any invalid options, normalizing where possible.\n\n @param config [Overcommit::Configuration]\n @param hash [Hash] hash representation of YAML config\n @param options[Hash]\n @option default [Boolean] whether hash represents the default built-in config\n @option logger [Overcommit::Logger] logger to output warnings to\n @return [Hash] validated hash (potentially modified)", "Normalizes `nil` values to empty hashes.\n\n This is useful for when we want to merge two configuration hashes\n together, since it's easier to merge two hashes than to have to check if\n one of the values is nil.", "Prints an error message and raises an exception if a hook has an\n invalid name, since this can result in strange errors elsewhere.", "Prints a warning if there are any hooks listed in the configuration\n without `enabled` explicitly set.", "Prints a warning if any hook has a number of processors larger than the\n global `concurrency` setting.", "Returns configuration for all built-in hooks in each hook type.\n\n @return [Hash]", "Returns configuration for all plugin hooks in each hook type.\n\n @return [Hash]", "Returns the built-in hooks that have been enabled for a hook type.", "Returns the ad hoc hooks that have been enabled for a hook type.", "Returns a non-modifiable configuration for a hook.", "Applies additional configuration settings based on the provided\n environment variables.", "Returns the stored signature of this repo's Overcommit configuration.\n\n This is intended to be compared against the current signature of this\n configuration object.\n\n @return [String]", "Returns the names of all files that are tracked by git.\n\n @return [Array] list of absolute file paths", "Restore any relevant files that were present when repo was in the middle\n of a merge.", "Restore any relevant files that were present when repo was in the middle\n of a cherry-pick.", "Update the current stored signature for this hook.", "Calculates a hash of a hook using a combination of its configuration and\n file contents.\n\n This way, if either the plugin code changes or its configuration changes,\n the hash will change and we can alert the user to this change.", "Executed at the end of an individual hook run.", "Process one logical line of makefile data.", "Invoke the task if it is needed. Prerequisites are invoked first.", "Transform the list of comments as specified by the block and\n join with the separator.", "Merge the given options with the default values.", "Check that the options do not contain options not listed in\n +optdecl+. An ArgumentError exception is thrown if non-declared\n options are found.", "Trim +n+ innermost scope levels from the scope. In no case will\n this trim beyond the toplevel scope.", "Initialize the command line parameters and app name.", "True if one of the files in RAKEFILES is in the current directory.\n If a match is found, it is copied into @rakefile.", "Return a new FileList with the results of running +sub+ against each\n element of the original list.\n\n Example:\n FileList['a.c', 'b.c'].sub(/\\.c$/, '.o') => ['a.o', 'b.o']", "Return a new FileList with the results of running +gsub+ against each\n element of the original list.\n\n Example:\n FileList['lib/test/file', 'x/y'].gsub(/\\//, \"\\\\\")\n => ['lib\\\\test\\\\file', 'x\\\\y']", "Same as +sub+ except that the original file list is modified.", "Same as +gsub+ except that the original file list is modified.", "Create the tasks defined by this task library.", "Waits until the queue of futures is empty and all threads have exited.", "processes one item on the queue. Returns true if there was an\n item to process, false if there was no item", "Resolve task arguments for a task or rule when there are no\n dependencies declared.\n\n The patterns recognized by this argument resolving function are:\n\n task :t\n task :t, [:a]", "If a rule can be found that matches the task name, enhance the\n task with the prerequisites and actions from the rule. Set the\n source attribute of the task appropriately for the rule. Return\n the enhanced task or nil of no rule was found.", "Find the location that called into the dsl layer.", "Attempt to create a rule given the list of prerequisites.", "Are there any prerequisites with a later time than the given time stamp?", "Create a new argument scope using the prerequisite argument\n names.", "If no one else is working this promise, go ahead and do the chore.", "Loops until the block returns a true value", "Purge cached DNS records", "vm always returns a vm", "Processes VM data from BOSH Director,\n extracts relevant agent data, wraps it into Agent object\n and adds it to a list of managed agents.", "subscribe to an inbox, if not already subscribed", "This call only makes sense if all dependencies have already been compiled,\n otherwise it raises an exception\n @return [Hash] Hash representation of all package dependencies. Agent uses\n that to download package dependencies before compiling the package on a\n compilation VM.", "Returns formatted exception information\n @param [Hash|#to_s] exception Serialized exception\n @return [String]", "the blob is removed from the blobstore once we have fetched it,\n but if there is a crash before it is injected into the response\n and then logged, there is a chance that we lose it", "Downloads a remote file\n @param [String] resource Resource name to be logged\n @param [String] remote_file Remote file to download\n @param [String] local_file Local file to store the downloaded file\n @raise [Bosh::Director::ResourceNotFound] If remote file is not found\n @raise [Bosh::Director::ResourceError] If there's a network problem", "Updates instance settings\n @param [String] instance_id instance id (instance record\n will be created in DB if it doesn't already exist)\n @param [String] settings New settings for the instance", "Reads instance settings\n @param [String] instance_id instance id\n @param [optional, String] remote_ip If this IP is provided,\n check will be performed to see if it instance id\n actually has this IP address according to the IaaS.", "Used by provider, not using alias because want to update existing provider intent when alias changes", "A consumer which is within the same deployment", "Do not add retries_left default value", "Creates new lock with the given name.\n\n @param name lock name\n @option opts [Number] timeout how long to wait before giving up\n @option opts [Number] expiration how long to wait before expiring an old\n lock\n Acquire a lock.\n\n @yield [void] optional block to do work before automatically releasing\n the lock.\n @return [void]", "Release a lock that was not auto released by the lock method.\n\n @return [void]", "returns a list of orphaned networks", "Instantiates and performs director job.\n @param [Array] args Opaque list of job arguments that will be used to\n instantiate the new job object.\n @return [void]", "Spawns a thread that periodically updates task checkpoint time.\n There is no need to kill this thread as job execution lifetime is the\n same as worker process lifetime.\n @return [Thread] Checkpoint thread", "Truncates string to fit task result length\n @param [String] string The original string\n @param [Integer] len Desired string length\n @return [String] Truncated string", "Marks task completion\n @param [Symbol] state Task completion state\n @param [#to_s] result", "Logs the exception in the event log\n @param [Exception] exception", "The rquirements hash passed in by the caller will be populated with CompiledPackageRequirement objects", "Binds template models for each release spec in the deployment plan\n @return [void]", "Ensures the given value is properly double quoted.\n This also ensures we don't have conflicts with reversed keywords.\n\n IE: `user` is a reserved keyword in PG. But `\"user\"` is allowed and works the same\n when used as an column/tbl alias.", "Ensures the key is properly single quoted and treated as a actual PG key reference.", "Converts a potential subquery into a compatible Arel SQL node.\n\n Note:\n We convert relations to SQL to maintain compatibility with Rails 5.[0/1].\n Only Rails 5.2+ maintains bound attributes in Arel, so its better to be safe then sorry.\n When we drop support for Rails 5.[0/1], we then can then drop the '.to_sql' conversation", "Finds Records that contains a nested set elements\n\n Array Column Type:\n User.where.contains(tags: [1, 3])\n # SELECT user.* FROM user WHERE user.tags @> {1,3}\n\n HStore Column Type:\n User.where.contains(data: { nickname: 'chainer' })\n # SELECT user.* FROM user WHERE user.data @> 'nickname' => 'chainer'\n\n JSONB Column Type:\n User.where.contains(data: { nickname: 'chainer' })\n # SELECT user.* FROM user WHERE user.data @> {'nickname': 'chainer'}\n\n This can also be used along side joined tables\n\n JSONB Column Type Example:\n Tag.joins(:user).where.contains(user: { data: { nickname: 'chainer' } })\n # SELECT tags.* FROM tags INNER JOIN user on user.id = tags.user_id WHERE user.data @> { nickname: 'chainer' }", "Absolute URL to the API representation of this resource", "Returns a hash suitable for use as an API response.\n\n For Documents and Pages:\n\n 1. Adds the file's raw content to the `raw_content` field\n 2. Adds the file's raw YAML front matter to the `front_matter` field\n\n For Static Files it addes the Base64 `encoded_content` field\n\n Options:\n\n include_content - if true, includes the content in the respond, false by default\n to support mapping on indexes where we only want metadata\n\n\n Returns a hash (which can then be to_json'd)", "Returns a hash of content fields for inclusion in the API output", "Returns the path to the requested file's containing directory", "Write a file to disk with the given content", "Delete the file at the given path", "verbose 'null' values in front matter", "Return whether this rule set occupies a single line.\n\n Note that this allows:\n a,\n b,\n i { margin: 0; padding: 0; }\n\n and:\n\n p { margin: 0; padding: 0; }\n\n In other words, the line of the opening curly brace is the line that the\n rule set is considered to occupy.", "Compare each property against the next property to see if they are on\n the same line.\n\n @param properties [Array]", "Executed before a node has been visited.\n\n @param node [Sass::Tree::Node]", "Gets the child of the node that resides on the lowest line in the file.\n\n This is necessary due to the fact that our monkey patching of the parse\n tree's {#children} method does not return nodes sorted by their line\n number.\n\n Returns `nil` if node has no children or no children with associated line\n numbers.\n\n @param node [Sass::Tree::Node, Sass::Script::Tree::Node]\n @return [Sass::Tree::Node, Sass::Script::Tree::Node]", "Checks if a simple sequence contains a\n simple selector of a certain class.\n\n @param seq [Sass::Selector::SimpleSequence]\n @param selector_class [Sass::Selector::Simple]\n @returns [Boolean]", "Find the maximum depth of all sequences in a comma sequence.", "Allow rulesets to be indented any amount when the indent is zero, as long\n as it's a multiple of the indent width", "Returns whether node is indented exactly one indent width greater than its\n parent.\n\n @param node [Sass::Tree::Node]\n @return [true,false]", "An expression enclosed in parens will include or not include each paren, depending\n on whitespace. Here we feel out for enclosing parens, and return them as the new\n source for the node.", "In cases where the previous node is not a block declaration, we won't\n have run any checks against it, so we need to check here if the previous\n line is an empty line", "Offset of value for property", "Friendly description that shows the full command that will be executed.", "Create a CLI that outputs to the specified logger.\n\n @param logger [SCSSLint::Logger]", "Return the path of the configuration file that should be loaded.\n\n @param options [Hash]\n @return [String]", "The Sass parser sometimes doesn't assign line numbers in cases where it\n should. This is a helper to easily correct that.", "Create a linter.\n Run this linter against a parsed document with the given configuration,\n returning the lints that were found.\n\n @param engine [Engine]\n @param config [Config]\n @return [Array]", "Helper for creating lint from a parse tree node\n\n @param node_or_line_or_location [Sass::Script::Tree::Node, Fixnum,\n SCSSLint::Location, Sass::Source::Position]\n @param message [String]", "Extracts the original source code given a range.\n\n @param source_range [Sass::Source::Range]\n @return [String] the original source code", "Returns whether a given node spans only a single line.\n\n @param node [Sass::Tree::Node]\n @return [true,false] whether the node spans a single line", "Modified so we can also visit selectors in linters\n\n @param node [Sass::Tree::Node, Sass::Script::Tree::Node,\n Sass::Script::Value::Base]", "Redefine so we can set the `node_parent` of each node\n\n @param parent [Sass::Tree::Node, Sass::Script::Tree::Node,\n Sass::Script::Value::Base]", "Since keyword arguments are not guaranteed to be in order, use the source\n range to order arguments so we check them in the order they were declared.", "Find the comma following this argument.\n\n The Sass parser is unpredictable in where it marks the end of the\n source range. Thus we need to start at the indicated range, and check\n left and right of that range, gradually moving further outward until\n we find the comma.", "For stubbing in tests.", "Returns a key identifying the bucket this property and value correspond to\n for purposes of uniqueness.", "Check if, starting from the end of a string\n and moving backwards, towards the beginning,\n we find a new line before any non-whitespace characters", "Checks if an individual sequence is split over multiple lines", "Checks if a property value's units are allowed.\n\n @param node [Sass::Tree::Node]\n @param property [String]\n @param units [String]", "Find the child that is out of place", "Return nth-ancestor of a node, where 1 is the parent, 2 is grandparent,\n etc.\n\n @param node [Sass::Tree::Node, Sass::Script::Tree::Node]\n @param level [Integer]\n @return [Sass::Tree::Node, Sass::Script::Tree::Node, nil]", "Return whether to ignore a property in the sort order.\n\n This includes:\n - properties containing interpolation\n - properties not explicitly defined in the sort order (if ignore_unspecified is set)", "Matches the block or conditions hash", "Check if the user has permission to perform a given action on an object.\n\n can? :destroy, @project\n\n You can also pass the class instead of an instance (if you don't have one handy).\n\n can? :create, Project\n\n Nested resources can be passed through a hash, this way conditions which are\n dependent upon the association will work when using a class.\n\n can? :create, @category => Project\n\n You can also pass multiple objects to check. You only need to pass a hash\n following the pattern { :any => [many subjects] }. The behaviour is check if\n there is a permission on any of the given objects.\n\n can? :create, {:any => [Project, Rule]}\n\n\n Any additional arguments will be passed into the \"can\" block definition. This\n can be used to pass more information about the user's request for example.\n\n can? :create, Project, request.remote_ip\n\n can :create, Project do |project, remote_ip|\n # ...\n end\n\n Not only can you use the can? method in the controller and view (see ControllerAdditions),\n but you can also call it directly on an ability instance.\n\n ability.can? :destroy, @project\n\n This makes testing a user's abilities very easy.\n\n def test \"user can only destroy projects which he owns\"\n user = User.new\n ability = Ability.new(user)\n assert ability.can?(:destroy, Project.new(:user => user))\n assert ability.cannot?(:destroy, Project.new)\n end\n\n Also see the RSpec Matchers to aid in testing.", "Defines which abilities are allowed using two arguments. The first one is the action\n you're setting the permission for, the second one is the class of object you're setting it on.\n\n can :update, Article\n\n You can pass an array for either of these parameters to match any one.\n Here the user has the ability to update or destroy both articles and comments.\n\n can [:update, :destroy], [Article, Comment]\n\n You can pass :all to match any object and :manage to match any action. Here are some examples.\n\n can :manage, :all\n can :update, :all\n can :manage, Project\n\n You can pass a hash of conditions as the third argument. Here the user can only see active projects which he owns.\n\n can :read, Project, :active => true, :user_id => user.id\n\n See ActiveRecordAdditions#accessible_by for how to use this in database queries. These conditions\n are also used for initial attributes when building a record in ControllerAdditions#load_resource.\n\n If the conditions hash does not give you enough control over defining abilities, you can use a block\n along with any Ruby code you want.\n\n can :update, Project do |project|\n project.groups.include?(user.group)\n end\n\n If the block returns true then the user has that :update ability for that project, otherwise he\n will be denied access. The downside to using a block is that it cannot be used to generate\n conditions for database queries.\n\n You can pass custom objects into this \"can\" method, this is usually done with a symbol\n and is useful if a class isn't available to define permissions on.\n\n can :read, :stats\n can? :read, :stats # => true\n\n IMPORTANT: Neither a hash of conditions nor a block will be used when checking permission on a class.\n\n can :update, Project, :priority => 3\n can? :update, Project # => true\n\n If you pass no arguments to +can+, the action, class, and object will be passed to the block and the\n block will always be executed. This allows you to override the full behavior if the permissions are\n defined in an external source such as the database.\n\n can do |action, object_class, object|\n # check the database and return true/false\n end", "Defines an ability which cannot be done. Accepts the same arguments as \"can\".\n\n can :read, :all\n cannot :read, Comment\n\n A block can be passed just like \"can\", however if the logic is complex it is recommended\n to use the \"can\" method.\n\n cannot :read, Product do |product|\n product.invisible?\n end", "User shouldn't specify targets with names of real actions or it will cause Seg fault", "Adds a new Archive to a Backup Model.\n\n Backup::Model.new(:my_backup, 'My Backup') do\n archive :my_archive do |archive|\n archive.add 'path/to/archive'\n archive.add '/another/path/to/archive'\n archive.exclude 'path/to/exclude'\n archive.exclude '/another/path/to/exclude'\n end\n end\n\n All paths added using `add` or `exclude` will be expanded to their\n full paths from the root of the filesystem. Files will be added to\n the tar archive using these full paths, and their leading `/` will\n be preserved (using tar's `-P` option).\n\n /path/to/pwd/path/to/archive/...\n /another/path/to/archive/...\n\n When a `root` path is given, paths to add/exclude are taken as\n relative to the `root` path, unless given as absolute paths.\n\n Backup::Model.new(:my_backup, 'My Backup') do\n archive :my_archive do |archive|\n archive.root '~/my_data'\n archive.add 'path/to/archive'\n archive.add '/another/path/to/archive'\n archive.exclude 'path/to/exclude'\n archive.exclude '/another/path/to/exclude'\n end\n end\n\n This directs `tar` to change directories to the `root` path to create\n the archive. Unless paths were given as absolute, the paths within the\n archive will be relative to the `root` path.\n\n path/to/archive/...\n /another/path/to/archive/...\n\n For absolute paths added to this archive, the leading `/` will be\n preserved. Take note that when archives are extracted, leading `/` are\n stripped by default, so care must be taken when extracting archives with\n mixed relative/absolute paths.", "Adds an Database. Multiple Databases may be added to the model.", "Adds an Storage. Multiple Storages may be added to the model.", "Adds an Syncer. Multiple Syncers may be added to the model.", "Adds a Splitter to split the final backup package into multiple files.\n\n +chunk_size+ is specified in MiB and must be given as an Integer.\n +suffix_length+ controls the number of characters used in the suffix\n (and the maximum number of chunks possible).\n ie. 1 (-a, -b), 2 (-aa, -ab), 3 (-aaa, -aab)", "Performs the backup process\n\n Once complete, #exit_status will indicate the result of this process.\n\n If any errors occur during the backup process, all temporary files will\n be left in place. If the error occurs before Packaging, then the\n temporary folder (tmp_path/trigger) will remain and may contain all or\n some of the configured Archives and/or Database dumps. If the error\n occurs after Packaging, but before the Storages complete, then the final\n packaged files (located in the root of tmp_path) will remain.\n\n *** Important ***\n If an error occurs and any of the above mentioned temporary files remain,\n those files *** will be removed *** before the next scheduled backup for\n the same trigger.", "Returns an array of procedures that will be performed if any\n Archives or Databases are configured for the model.", "Attempts to use all configured Storages, even if some of them result in exceptions.\n Returns true or raises first encountered exception.", "Logs messages when the model starts and finishes.\n\n #exception will be set here if #exit_status is > 1,\n since log(:finished) is called before the +after+ hook.", "Finds the resulting files from the packaging procedure\n and stores an Array of suffixes used in @package.chunk_suffixes.\n If the @chunk_size was never reached and only one file\n was written, that file will be suffixed with '-aa' (or -a; -aaa; etc\n depending upon suffix_length). In which case, it will simply\n remove the suffix from the filename.", "includes required submodules into the model class,\n which usually is called User.", "add virtual password accessor and ORM callbacks.", "Comparation with other query or collection\n If other is collection - search request is executed and\n result is used for comparation\n\n @example\n UsersIndex.filter(term: {name: 'Johny'}) == UsersIndex.filter(term: {name: 'Johny'}) # => true\n UsersIndex.filter(term: {name: 'Johny'}) == UsersIndex.filter(term: {name: 'Johny'}).to_a # => true\n UsersIndex.filter(term: {name: 'Johny'}) == UsersIndex.filter(term: {name: 'Winnie'}) # => false\n\n Adds `explain` parameter to search request.\n\n @example\n UsersIndex.filter(term: {name: 'Johny'}).explain\n UsersIndex.filter(term: {name: 'Johny'}).explain(true)\n UsersIndex.filter(term: {name: 'Johny'}).explain(false)\n\n Calling explain without any arguments sets explanation flag to true.\n With `explain: true`, every result object has `_explanation`\n method\n\n @example\n UsersIndex::User.filter(term: {name: 'Johny'}).explain.first._explanation # => {...}", "Sets elasticsearch `size` search request param\n Default value is set in the elasticsearch and is 10.\n\n @example\n UsersIndex.filter{ name == 'Johny' }.limit(100)\n # => {body: {\n query: {...},\n size: 100\n }}", "Sets elasticsearch `from` search request param\n\n @example\n UsersIndex.filter{ name == 'Johny' }.offset(300)\n # => {body: {\n query: {...},\n from: 300\n }}", "Adds facets section to the search request.\n All the chained facets a merged and added to the\n search request\n\n @example\n UsersIndex.facets(tags: {terms: {field: 'tags'}}).facets(ages: {terms: {field: 'age'}})\n # => {body: {\n query: {...},\n facets: {tags: {terms: {field: 'tags'}}, ages: {terms: {field: 'age'}}}\n }}\n\n If called parameterless - returns result facets from ES performing request.\n Returns empty hash if no facets was requested or resulted.", "Adds a script function to score the search request. All scores are\n added to the search request and combinded according to\n `boost_mode` and `score_mode`\n\n @example\n UsersIndex.script_score(\"doc['boost'].value\", params: { modifier: 2 })\n # => {body:\n query: {\n function_score: {\n query: { ...},\n functions: [{\n script_score: {\n script: \"doc['boost'].value * modifier\",\n params: { modifier: 2 }\n }\n }\n }]\n } } }", "Adds a boost factor to the search request. All scores are\n added to the search request and combinded according to\n `boost_mode` and `score_mode`\n\n This probably only makes sense if you specify a filter\n for the boost factor as well\n\n @example\n UsersIndex.boost_factor(23, filter: { term: { foo: :bar} })\n # => {body:\n query: {\n function_score: {\n query: { ...},\n functions: [{\n boost_factor: 23,\n filter: { term: { foo: :bar } }\n }]\n } } }", "Adds a random score to the search request. All scores are\n added to the search request and combinded according to\n `boost_mode` and `score_mode`\n\n This probably only makes sense if you specify a filter\n for the random score as well.\n\n If you do not pass in a seed value, Time.now will be used\n\n @example\n UsersIndex.random_score(23, filter: { foo: :bar})\n # => {body:\n query: {\n function_score: {\n query: { ...},\n functions: [{\n random_score: { seed: 23 },\n filter: { foo: :bar }\n }]\n } } }", "Add a field value scoring to the search. All scores are\n added to the search request and combinded according to\n `boost_mode` and `score_mode`\n\n This function is only available in Elasticsearch 1.2 and\n greater\n\n @example\n UsersIndex.field_value_factor(\n {\n field: :boost,\n factor: 1.2,\n modifier: :sqrt\n }, filter: { foo: :bar})\n # => {body:\n query: {\n function_score: {\n query: { ...},\n functions: [{\n field_value_factor: {\n field: :boost,\n factor: 1.2,\n modifier: :sqrt\n },\n filter: { foo: :bar }\n }]\n } } }", "Add a decay scoring to the search. All scores are\n added to the search request and combinded according to\n `boost_mode` and `score_mode`\n\n The parameters have default values, but those may not\n be very useful for most applications.\n\n @example\n UsersIndex.decay(\n :gauss,\n :field,\n origin: '11, 12',\n scale: '2km',\n offset: '5km',\n decay: 0.4,\n filter: { foo: :bar})\n # => {body:\n query: {\n gauss: {\n query: { ...},\n functions: [{\n gauss: {\n field: {\n origin: '11, 12',\n scale: '2km',\n offset: '5km',\n decay: 0.4\n }\n },\n filter: { foo: :bar }\n }]\n } } }", "Sets elasticsearch `aggregations` search request param\n\n @example\n UsersIndex.filter{ name == 'Johny' }.aggregations(category_id: {terms: {field: 'category_ids'}})\n # => {body: {\n query: {...},\n aggregations: {\n terms: {\n field: 'category_ids'\n }\n }\n }}", "In this simplest of implementations each named aggregation must be uniquely named", "Deletes all documents matching a query.\n\n @example\n UsersIndex.delete_all\n UsersIndex.filter{ age <= 42 }.delete_all\n UsersIndex::User.delete_all\n UsersIndex::User.filter{ age <= 42 }.delete_all", "Find all documents matching a query.\n\n @example\n UsersIndex.find(42)\n UsersIndex.filter{ age <= 42 }.find(42)\n UsersIndex::User.find(42)\n UsersIndex::User.filter{ age <= 42 }.find(42)\n\n In all the previous examples find will return a single object.\n To get a collection - pass an array of ids.\n\n @example\n UsersIndex::User.find(42, 7, 3) # array of objects with ids in [42, 7, 3]\n UsersIndex::User.find([8, 13]) # array of objects with ids in [8, 13]\n UsersIndex::User.find([42]) # array of the object with id == 42", "A helper to build a bolt command used in acceptance testing\n @param [Beaker::Host] host the host to execute the command on\n @param [String] command the command to execute on the bolt SUT\n @param [Hash] flags the command flags to append to the command\n @option flags [String] '--nodes' the nodes to run on\n @option flags [String] '--user' the user to run the command as\n @option flags [String] '--password' the password for the user\n @option flags [nil] '--no-host-key-check' specify nil to use\n @option flags [nil] '--no-ssl' specify nil to use\n @param [Hash] opts the options hash for this method", "Count the number of top-level statements in the AST.", "Create a cache dir if necessary and update it's last write time. Returns the dir.\n Acquires @cache_dir_mutex to ensure we don't try to purge the directory at the same time.\n Uses the directory mtime because it's simpler to ensure the directory exists and update\n mtime in a single place than with a file in a directory that may not exist.", "If the file doesn't exist or is invalid redownload it\n This downloads, validates and moves into place", "This handles running the job, catching errors, and turning the result\n into a result set", "Starts executing the given block on a list of nodes in parallel, one thread per \"batch\".\n\n This is the main driver of execution on a list of targets. It first\n groups targets by transport, then divides each group into batches as\n defined by the transport. Yields each batch, along with the corresponding\n transport, to the block in turn and returns an array of result promises.", "Parses a snippet of Puppet manifest code and returns the AST represented\n in JSON.", "This converts a plan signature object into a format used by the outputter.\n Must be called from within bolt compiler to pickup type aliases used in the plan signature.", "Returns a mapping of all modules available to the Bolt compiler\n\n @return [Hash{String => Array String,nil}>}]\n A hash that associates each directory on the module path with an array\n containing a hash of information for each module in that directory.\n The information hash provides the name, version, and a string\n indicating whether the module belongs to an internal module group.", "URI can be passes as nil", "Override in your tests", "Convert an r10k log level to a bolt log level. These correspond 1-to-1\n except that r10k has debug, debug1, and debug2. The log event has the log\n level as an integer that we need to look up.", "Pass a target to get_targets for a public version of this\n Should this reconfigure configured targets?", "Prints all information associated to the breakpoint", "Main byebug's REPL", "Run permanent commands.", "Executes the received input\n\n Instantiates a command matching the input and runs it. If a matching\n command is not found, it evaluates the unknown input.", "Restores history from disk.", "Saves history to disk.", "Prints the requested numbers of history entries.", "Whether a specific command should not be stored in history.\n\n For now, empty lines and consecutive duplicates.", "Delegates to subcommands or prints help if no subcommand specified.", "Gets local variables for the frame.", "Builds a string containing all available args in the frame number, in a\n verbose or non verbose way according to the value of the +callstyle+\n setting", "Context's stack size", "Line range to be printed by `list`.\n\n If is set, range is parsed from it.\n\n Otherwise it's automatically chosen.", "Set line range to be printed by list\n\n @return first line number to list\n @return last line number to list", "Show a range of lines in the current file.\n\n @param min [Integer] Lower bound\n @param max [Integer] Upper bound", "Starts byebug to debug a program.", "Processes options passed from the command line.", "Reads a new line from the interface's input stream, parses it into\n commands and saves it to history.\n\n @return [String] Representing something to be run by the debugger.", "Raw content of license file, including YAML front matter", "Given another license or project file, calculates the similarity\n as a percentage of words in common", "Content with the title and version removed\n The first time should normally be the attribution line\n Used to dry up `content_normalized` but we need the case sensitive\n content with attribution first to detect attribuion in LicenseFile", "this is where users arrive after visiting the password reset confirmation link", "this action is responsible for generating unlock tokens and\n sending emails", "intermediary route for successful omniauth authentication. omniauth does\n not support multiple models, so we must resort to this terrible hack.", "this will be determined differently depending on the action that calls\n it. redirect_callbacks is called upon returning from successful omniauth\n authentication, and the target params live in an omniauth-specific\n request.env variable. this variable is then persisted thru the redirect\n using our own dta.omniauth.params session var. the omniauth_success\n method will access that session var and then destroy it immediately\n after use. In the failure case, finally, the omniauth params\n are added as query params in our monkey patch to OmniAuth in engine.rb", "break out provider attribute assignment for easy method extension", "derive allowed params from the standard devise parameter sanitizer", "This is a little hacky, because Bitbucket doesn't provide us a PR id", "The paths are relative to dir.", "Could we determine that the CI source is inside a PR?", "Prints a summary of the errors and warnings.", "Rules that apply to a class", "Rules that apply to individual methods, and attributes", "Generates a link to see an example of said rule", "Takes an array of files, gems or nothing, then resolves them into\n paths that should be sent into the documentation parser\n When given existing paths, map to absolute & existing paths\n When given a list of gems, resolve for list of gems\n When empty, imply you want to test the current lib folder as a plugin", "Determine if there's a PR attached to this commit,\n and return the url if so", "Ask the API if the commit is inside a PR", "Make the API call, and parse the JSON", "Raises an error when the given block does not register a plugin.", "Iterates through the DSL's attributes, and table's the output", "The message of the exception reports the content of podspec for the\n line that generated the original exception.\n\n @example Output\n\n Invalid podspec at `RestKit.podspec` - undefined method\n `exclude_header_search_paths=' for #\n\n from spec-repos/master/RestKit/0.9.3/RestKit.podspec:36\n -------------------------------------------\n # because it would break: #import \n > ns.exclude_header_search_paths = 'Code/RestKit.h'\n end\n -------------------------------------------\n\n @return [String] the message of the exception.", "start all the watchers and enable haproxy configuration", "if we don't have a visit, let's try to create one first", "can't use keyword arguments here", "replace % \\ to \\% \\\\", "This method is both a getter and a setter", "added for rails < 3.0.3 compatibility", "this is the entry point for all state and event definitions", "a neutered version of fire - it doesn't actually fire the event, it just\n executes the transition guards to determine if a transition is even\n an option given current conditions.", "Load the Encryption Configuration from a YAML file.\n\n See: `.load!` for parameters.\n Returns [Hash] the configuration for the supplied environment.", "Encrypt data before writing to the supplied stream\n Close the IO Stream.\n\n Notes:\n * Flushes any unwritten data.\n * Once an EncryptionWriter has been closed a new instance must be\n created before writing again.\n * Closes the passed in io stream or file.\n * `close` must be called _before_ the supplied stream is closed.\n\n It is recommended to call Symmetric::EncryptedStream.open\n rather than creating an instance of Symmetric::Writer directly to\n ensure that the encrypted stream is closed before the stream itself is closed.", "Encrypt and then encode a string\n\n Returns data encrypted and then encoded according to the encoding setting\n of this cipher\n Returns nil if str is nil\n Returns \"\" str is empty\n\n Parameters\n\n str [String]\n String to be encrypted. If str is not a string, #to_s will be called on it\n to convert it to a string\n\n random_iv [true|false]\n Whether the encypted value should use a random IV every time the\n field is encrypted.\n Notes:\n * Setting random_iv to true will result in a different encrypted output for\n the same input string.\n * It is recommended to set this to true, except if it will be used as a lookup key.\n * Only set to true if the field will never be used as a lookup key, since\n the encrypted value needs to be same every time in this case.\n * When random_iv is true it adds the random IV string to the header.\n Default: false\n Highly Recommended where feasible: true\n\n compress [true|false]\n Whether to compress str before encryption.\n Default: false\n Notes:\n * Should only be used for large strings since compression overhead and\n the overhead of adding the encryption header may exceed any benefits of\n compression", "Decode and Decrypt string\n Returns a decrypted string after decoding it first according to the\n encoding setting of this cipher\n Returns nil if encrypted_string is nil\n Returns '' if encrypted_string == ''\n\n Parameters\n encrypted_string [String]\n Binary encrypted string to decrypt\n\n Reads the header if present for key, iv, cipher_name and compression\n\n encrypted_string must be in raw binary form when calling this method\n\n Creates a new OpenSSL::Cipher with every call so that this call\n is thread-safe and can be called concurrently by multiple threads with\n the same instance of Cipher", "Advanced use only\n\n Returns a Binary encrypted string without applying Base64, or any other encoding.\n\n str [String]\n String to be encrypted. If str is not a string, #to_s will be called on it\n to convert it to a string\n\n random_iv [true|false]\n Whether the encypted value should use a random IV every time the\n field is encrypted.\n Notes:\n * Setting random_iv to true will result in a different encrypted output for\n the same input string.\n * It is recommended to set this to true, except if it will be used as a lookup key.\n * Only set to true if the field will never be used as a lookup key, since\n the encrypted value needs to be same every time in this case.\n * When random_iv is true it adds the random IV string to the header.\n Default: false\n Highly Recommended where feasible: true\n\n compress [true|false]\n Whether to compress str before encryption.\n Default: false\n Notes:\n * Should only be used for large strings since compression overhead and\n the overhead of adding the encryption header may exceed any benefits of\n compression\n\n header [true|false]\n Whether to add a header to the encrypted string.\n Default: `always_add_header`\n\n See #encrypt to encrypt and encode the result as a string.", "Extracts a string from the supplied buffer.\n The buffer starts with a 2 byte length indicator in little endian format.\n\n Parameters\n buffer [String]\n offset [Integer]\n Start position within the buffer.\n\n Returns [string, offset]\n string [String]\n The string copied from the buffer.\n offset [Integer]\n The new offset within the buffer.", "Reads a single decrypted line from the file up to and including the optional sep_string.\n A sep_string of nil reads the entire contents of the file\n Returns nil on eof\n The stream must be opened for reading or an IOError will be raised.", "Read the header from the file if present", "Yields each item", "Return an instance of what the object looked like at this revision. If\n the object has been destroyed, this will be a new record.", "Returns a hash of the changed attributes with the new values", "Returns a hash of the changed attributes with the old values", "Allows user to undo changes", "Allows user to be set to either a string or an ActiveRecord object\n @private", "Renders an existing named table or builds and renders a custom table if a block is provided.\n\n name - The (optional) name of the table to render (as a Symbol), or the actual Trestle::Table instance itself.\n options - Hash of options that will be passed to the table builder (default: {}):\n :collection - The collection that should be rendered within the table. It should be an\n Array-like object, but will most likely be an ActiveRecord scope. It can\n also be a callable object (i.e. a Proc) in which case the result of calling\n the block will be used as the collection.\n See Trestle::Table::Builder for additional options.\n block - An optional block that is passed to Trestle::Table::Builder to define a custom table.\n One of either the name or block must be provided, but not both.\n\n Examples\n\n <%= table collection: -> { Account.all }, admin: :accounts do %>\n <% column(:name) %>\n <% column(:balance) { |account| account.balance.format } %>\n <% column(:created_at, align: :center)\n <% end %>\n\n <%= table :accounts %>\n\n Returns the HTML representation of the table as a HTML-safe String.", "Custom version of Kaminari's page_entries_info helper to use a\n Trestle-scoped I18n key and add a delimiter to the total count.", "Register an extension hook", "Rolls the stack back to this deploy", "Go from a full Swift version like 4.2.1 to\n something valid for SWIFT_VERSION.", "Gets the related Resource Id Tree for a relationship, and creates it first if it does not exist\n\n @param relationship [JSONAPI::Relationship]\n\n @return [JSONAPI::RelatedResourceIdTree] the new or existing resource id tree for the requested relationship", "Adds a Resource Fragment to the Resources hash\n\n @param fragment [JSONAPI::ResourceFragment]\n @param include_related [Hash]\n\n @return [null]", "Adds a Resource Fragment to the fragments hash\n\n @param fragment [JSONAPI::ResourceFragment]\n @param include_related [Hash]\n\n @return [null]", "Create a new object for connecting to the Stackdriver Error Reporting\n service. Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/cloud-platform`\n\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. Optional.\n\n @return [Google::Cloud::ErrorReporting::Project]\n\n @example\n require \"google/cloud/error_reporting\"\n\n gcloud = Google::Cloud.new \"GCP_Project_ID\",\n \"/path/to/gcp/secretkey.json\"\n error_reporting = gcloud.error_reporting\n\n error_event = error_reporting.error_event \"Error with Backtrace\",\n event_time: Time.now,\n service_name: \"my_app_name\",\n service_version: \"v8\"\n error_reporting.report error_event", "Creates a new object for connecting to the DNS service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/ndev.clouddns.readwrite`\n @param [Integer] retries Number of times to retry requests on server\n error. The default value is `3`. Optional.\n @param [Integer] timeout Default timeout to use in requests. Optional.\n\n @return [Google::Cloud::Dns::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n dns = gcloud.dns\n zone = dns.zone \"example-com\"\n zone.records.each do |record|\n puts record.name\n end\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n dns_readonly = \"https://www.googleapis.com/auth/ndev.clouddns.readonly\"\n dns = gcloud.dns scope: dns_readonly", "Creates a new object for connecting to the Spanner service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scopes are:\n\n * `https://www.googleapis.com/auth/spanner`\n * `https://www.googleapis.com/auth/spanner.data`\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. Optional.\n\n @return [Google::Cloud::Spanner::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n spanner = gcloud.spanner\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n spanner = gcloud.spanner scope: platform_scope", "Creates a new object for connecting to the Stackdriver Logging service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/logging.admin`\n\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. Optional.\n\n @return [Google::Cloud::Logging::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n logging = gcloud.logging\n\n entries = logging.entries\n entries.each do |e|\n puts \"[#{e.timestamp}] #{e.log_name} #{e.payload.inspect}\"\n end\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n logging = gcloud.logging scope: platform_scope", "Creates a new object for connecting to the BigQuery service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/bigquery`\n @param [Integer] retries Number of times to retry requests on server\n error. The default value is `5`. Optional.\n @param [Integer] timeout Default request timeout in seconds. Optional.\n\n @return [Google::Cloud::Bigquery::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n bigquery = gcloud.bigquery\n dataset = bigquery.dataset \"my_dataset\"\n table = dataset.table \"my_table\"\n table.data.each do |row|\n puts row\n end\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n bigquery = gcloud.bigquery scope: platform_scope", "Creates a new debugger object for instrumenting Stackdriver Debugger for\n an application. Each call creates a new debugger agent with independent\n connection service.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String] service_name Name for the debuggee application. Optional.\n @param [String] service_version Version identifier for the debuggee\n application. Optional.\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/cloud_debugger`\n * `https://www.googleapis.com/auth/logging.admin`\n\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. Optional.\n\n @return [Google::Cloud::Debugger::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n debugger = gcloud.debugger\n\n debugger.start\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n debugger = gcloud.debugger scope: platform_scope", "Creates a new object for connecting to the Datastore service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/datastore`\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. See Google::Gax::CallSettings. Optional.\n\n @return [Google::Cloud::Datastore::Dataset]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n datastore = gcloud.datastore\n\n task = datastore.entity \"Task\" do |t|\n t[\"type\"] = \"Personal\"\n t[\"done\"] = false\n t[\"priority\"] = 4\n t[\"description\"] = \"Learn Cloud Datastore\"\n end\n\n datastore.save task\n\n @example You shouldn't need to override the default scope, but you can:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n datastore = gcloud.datastore scope: platform_scope", "Creates a new object for connecting to the Resource Manager service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/cloud-platform`\n @param [Integer] retries Number of times to retry requests on server\n error. The default value is `3`. Optional.\n @param [Integer] timeout Default timeout to use in requests. Optional.\n\n @return [Google::Cloud::ResourceManager::Manager]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n resource_manager = gcloud.resource_manager\n resource_manager.projects.each do |project|\n puts projects.project_id\n end\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n readonly_scope = \\\n \"https://www.googleapis.com/auth/cloudresourcemanager.readonly\"\n resource_manager = gcloud.resource_manager scope: readonly_scope", "Creates a new object for connecting to the Storage service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @see https://cloud.google.com/storage/docs/authentication#oauth Storage\n OAuth 2.0 Authentication\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/devstorage.full_control`\n @param [Integer] retries Number of times to retry requests on server\n error. The default value is `3`. Optional.\n @param [Integer] timeout Default timeout to use in requests. Optional.\n\n @return [Google::Cloud::Storage::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n storage = gcloud.storage\n bucket = storage.bucket \"my-bucket\"\n file = bucket.file \"path/to/my-file.ext\"\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n readonly_scope = \"https://www.googleapis.com/auth/devstorage.read_only\"\n readonly_storage = gcloud.storage scope: readonly_scope", "Creates a new object for connecting to the Cloud Translation API. Each\n call creates a new connection.\n\n Like other Cloud Platform services, Google Cloud Translation API supports\n authentication using a project ID and OAuth 2.0 credentials. In addition,\n it supports authentication using a public API access key. (If both the API\n key and the project and OAuth 2.0 credentials are provided, the API key\n will be used.) Instructions and configuration options are covered in the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String] key a public API access key (not an OAuth 2.0 token)\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/cloud-platform`\n @param [Integer] retries Number of times to retry requests on server\n error. The default value is `3`. Optional.\n @param [Integer] timeout Default timeout to use in requests. Optional.\n\n @return [Google::Cloud::Translate::Api]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n translate = gcloud.translate \"api-key-abc123XYZ789\"\n\n translation = translate.translate \"Hello world!\", to: \"la\"\n translation.text #=> \"Salve mundi!\"\n\n @example Using API Key from the environment variable.\n require \"google/cloud\"\n\n ENV[\"TRANSLATE_KEY\"] = \"api-key-abc123XYZ789\"\n\n gcloud = Google::Cloud.new\n translate = gcloud.translate\n\n translation = translate.translate \"Hello world!\", to: \"la\"\n translation.text #=> \"Salve mundi!\"", "Creates a new object for connecting to the Firestore service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/datastore`\n @param [Integer] timeout Default timeout to use in requests. Optional.\n @param [Hash] client_config A hash of values to override the default\n behavior of the API client. Optional.\n\n @return [Google::Cloud::Firestore::Client]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n firestore = gcloud.firestore\n\n @example The default scope can be overridden with the `scope` option:\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n platform_scope = \"https://www.googleapis.com/auth/cloud-platform\"\n firestore = gcloud.firestore scope: platform_scope", "Creates a new object for connecting to the Stackdriver Trace service.\n Each call creates a new connection.\n\n For more information on connecting to Google Cloud see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param [String, Array] scope The OAuth 2.0 scopes controlling the\n set of resources and operations that the connection can access. See\n [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n\n The default scope is:\n\n * `https://www.googleapis.com/auth/cloud-platform`\n\n @param [Integer] timeout Default timeout to use in requests. Optional.\n\n @return [Google::Cloud::Trace::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n trace_client = gcloud.trace\n\n traces = trace_client.list_traces Time.now - 3600, Time.now\n traces.each do |trace|\n puts \"Retrieved trace ID: #{trace.trace_id}\"\n end", "Creates a new object for connecting to the Cloud Bigtable service.\n\n For more information on connecting to Google Cloud Platform, see the\n {file:AUTHENTICATION.md Authentication Guide}.\n\n @param scope [Array]\n The OAuth 2.0 scopes controlling the set of resources and operations\n that the connection can access. See [Using OAuth 2.0 to Access Google\n APIs](https://developers.google.com/identity/protocols/OAuth2).\n The OAuth scopes for this service. This parameter is ignored if an\n updater_proc is supplied.\n @param timeout [Integer]\n The default timeout, in seconds, for calls made through this client.\n @param credentials [Google::Auth::Credentials, String, Hash, GRPC::Core::Channel, GRPC::Core::ChannelCredentials, Proc]\n Provides the means for authenticating requests made by the client. This parameter can\n be one of the following types.\n `Google::Auth::Credentials` uses the properties of its represented keyfile for\n authenticating requests made by this client.\n `String` will be treated as the path to the keyfile to use to construct\n credentials for this client.\n `Hash` will be treated as the contents of a keyfile to use to construct\n credentials for this client.\n `GRPC::Core::Channel` will be used to make calls through.\n `GRPC::Core::ChannelCredentials` will be used to set up the gRPC client. The channel credentials\n should already be composed with a `GRPC::Core::CallCredentials` object.\n `Proc` will be used as an updater_proc for the gRPC channel. The proc transforms the\n metadata for requests, generally, to give OAuth credentials.\n @param client_config [Hash]\n A hash for call options for each method.\n See Google::Gax#construct_settings for the structure of\n this data. Falls back to the default config if not specified\n or the specified config is missing data points.\n @return [Google::Cloud::Bigtable::Project]\n\n @example\n require \"google/cloud\"\n\n gcloud = Google::Cloud.new\n\n bigtable = gcloud.bigtable", "Compare two hashes for equality\n\n For two hashes to match they must have the same length and all\n values must match when compared using `#===`.\n\n The following hashes are examples of matches:\n\n {a: /\\d+/} and {a: '123'}\n\n {a: '123'} and {a: '123'}\n\n {a: {b: /\\d+/}} and {a: {b: '123'}}\n\n {a: {b: 'wow'}} and {a: {b: 'wow'}}\n\n @param [Hash] query_parameters typically the result of parsing\n JSON, XML or URL encoded parameters.\n\n @param [Hash] pattern which contains keys with a string, hash or\n regular expression value to use for comparison.\n\n @return [Boolean] true if the paramaters match the comparison\n hash, false if not.", "Apply all filters in the pipeline to the given HTML.\n\n html - A String containing HTML or a DocumentFragment object.\n context - The context hash passed to each filter. See the Filter docs\n for more info on possible values. This object MUST NOT be modified\n in place by filters. Use the Result for passing state back.\n result - The result Hash passed to each filter for modification. This\n is where Filters store extracted information from the content.\n\n Returns the result Hash after being filtered by this Pipeline. Contains an\n :output key with the DocumentFragment or String HTML markup based on the\n output of the last filter in the pipeline.", "Like call but guarantee the value returned is a DocumentFragment.\n Pipelines may return a DocumentFragment or a String. Callers that need a\n DocumentFragment should use this method.", "Like call but guarantee the value returned is a string of HTML markup.", "Total number of pages", "Current page number", "Used for page_entry_info", "Executes a watcher action.\n\n @param [String, MatchData] matches the matched path or the match from the\n Regex\n @return [String] the final paths", "Start Guard by initializing the defined Guard plugins and watch the file\n system.\n\n This is the default task, so calling `guard` is the same as calling\n `guard start`.\n\n @see Guard.start", "List the Notifiers for use in your system.\n\n @see Guard::DslDescriber.notifiers", "Initializes the templates of all installed Guard plugins and adds them\n to the `Guardfile` when no Guard name is passed. When passing\n Guard plugin names it does the same but only for those Guard plugins.\n\n @see Guard::Guardfile.initialize_template\n @see Guard::Guardfile.initialize_all_templates\n\n @param [Array] plugin_names the name of the Guard plugins to\n initialize", "Shows all Guard plugins and their options that are defined in\n the `Guardfile`\n\n @see Guard::DslDescriber.show", "Adds a plugin's template to the Guardfile.", "Returns the constant for the current plugin.\n\n @example Returns the constant for a plugin\n > Guard::PluginUtil.new('rspec').send(:_plugin_constant)\n => Guard::RSpec", "Sets the interactor options or disable the interactor.\n\n @example Pass options to the interactor\n interactor option1: 'value1', option2: 'value2'\n\n @example Turn off interactions\n interactor :off\n\n @param [Symbol, Hash] options either `:off` or a Hash with interactor\n options", "Declares a Guard plugin to be used when running `guard start`.\n\n The name parameter is usually the name of the gem without\n the 'guard-' prefix.\n\n The available options are different for each Guard implementation.\n\n @example Declare a Guard without `watch` patterns\n guard :rspec\n\n @example Declare a Guard with a `watch` pattern\n guard :rspec do\n watch %r{.*_spec.rb}\n end\n\n @param [String] name the Guard plugin name\n @param [Hash] options the options accepted by the Guard plugin\n @yield a block where you can declare several watch patterns and actions\n\n @see Plugin\n @see Guard.add_plugin\n @see #watch\n @see #group", "Defines a pattern to be watched in order to run actions on file\n modification.\n\n @example Declare watchers for a Guard\n guard :rspec do\n watch('spec/spec_helper.rb')\n watch(%r{^.+_spec.rb})\n watch(%r{^app/controllers/(.+).rb}) do |m|\n 'spec/acceptance/#{m[1]}s_spec.rb'\n end\n end\n\n @example Declare global watchers outside of a Guard\n watch(%r{^(.+)$}) { |m| puts \"#{m[1]} changed.\" }\n\n @param [String, Regexp] pattern the pattern that Guard must watch for\n modification\n\n @yield a block to be run when the pattern is matched\n @yieldparam [MatchData] m matches of the pattern\n @yieldreturn a directory, a filename, an array of\n directories / filenames, or nothing (can be an arbitrary command)\n\n @see Guard::Watcher\n @see #guard", "Defines a callback to execute arbitrary code before or after any of\n the `start`, `stop`, `reload`, `run_all`, `run_on_changes`,\n `run_on_additions`, `run_on_modifications` and `run_on_removals` plugin\n method.\n\n @example Add callback before the `reload` action.\n callback(:reload_begin) { puts \"Let's reload!\" }\n\n @example Add callback before the `start` and `stop` actions.\n\n my_lambda = lambda do |plugin, event, *args|\n puts \"Let's #{event} #{plugin} with #{args}!\"\n end\n\n callback(my_lambda, [:start_begin, :start_end])\n\n @param [Array] args the callback arguments\n @yield a callback block", "Configures the Guard logger.\n\n * Log level must be either `:debug`, `:info`, `:warn` or `:error`.\n * Template supports the following placeholders: `:time`, `:severity`,\n `:progname`, `:pid`, `:unit_of_work_id` and `:message`.\n * Time format directives are the same as `Time#strftime` or\n `:milliseconds`.\n * The `:only` and `:except` options must be a `RegExp`.\n\n @example Set the log level\n logger level: :warn\n\n @example Set a custom log template\n logger template: '[Guard - :severity - :progname - :time] :message'\n\n @example Set a custom time format\n logger time_format: '%h'\n\n @example Limit logging to a Guard plugin\n logger only: :jasmine\n\n @example Log all but not the messages from a specific Guard plugin\n logger except: :jasmine\n\n @param [Hash] options the log options\n @option options [String, Symbol] level the log level\n @option options [String] template the logger template\n @option options [String, Symbol] time_format the time format\n @option options [Regexp] only show only messages from the matching Guard\n plugin\n @option options [Regexp] except does not show messages from the matching\n Guard plugin", "Sets the directories to pass to Listen\n\n @example watch only given directories\n directories %w(lib specs)\n\n @param [Array] directories directories for Listen to watch", "Start Guard by evaluating the `Guardfile`, initializing declared Guard\n plugins and starting the available file change listener.\n Main method for Guard that is called from the CLI when Guard starts.\n\n - Setup Guard internals\n - Evaluate the `Guardfile`\n - Configure Notifiers\n - Initialize the declared Guard plugins\n - Start the available file change listener\n\n @option options [Boolean] clear if auto clear the UI should be done\n @option options [Boolean] notify if system notifications should be shown\n @option options [Boolean] debug if debug output should be shown\n @option options [Array] group the list of groups to start\n @option options [String] watchdir the director to watch\n @option options [String] guardfile the path to the Guardfile\n @see CLI#start", "Trigger `run_all` on all Guard plugins currently enabled.\n\n @param [Hash] scopes hash with a Guard plugin or a group scope", "Pause Guard listening to file changes.", "Shows all Guard plugins and their options that are defined in\n the `Guardfile`.\n\n @see CLI#show", "Shows all notifiers and their options that are defined in\n the `Guardfile`.\n\n @see CLI#show", "Runs a Guard-task on all registered plugins.\n\n @param [Symbol] task the task to run\n\n @param [Hash] scope_hash either the Guard plugin or the group to run the task\n on", "Runs the appropriate tasks on all registered plugins\n based on the passed changes.\n\n @param [Array] modified the modified paths.\n @param [Array] added the added paths.\n @param [Array] removed the removed paths.", "Run a Guard plugin task, but remove the Guard plugin when his work leads\n to a system failure.\n\n When the Group has `:halt_on_fail` disabled, we've to catch\n `:task_has_failed` here in order to avoid an uncaught throw error.\n\n @param [Guard::Plugin] plugin guard the Guard to execute\n @param [Symbol] task the task to run\n @param [Array] args the arguments for the task\n @raise [:task_has_failed] when task has failed", "Value of the Content-Length header.\n\n @return [nil] if Content-Length was not given, or it's value was invalid\n (not an integer, e.g. empty string or string with non-digits).\n @return [Integer] otherwise", "Read a chunk of the body\n\n @return [String] data chunk\n @return [nil] when no more data left", "Sets up SSL context and starts TLS if needed.\n @param (see #initialize)\n @return [void]", "Open tunnel through proxy", "Store whether the connection should be kept alive.\n Once we reset the parser, we lose all of this state.\n @return [void]", "Feeds some more data into parser\n @return [void]", "Make a request through an HTTP proxy\n @param [Array] proxy\n @raise [Request::Error] if HTTP proxy is invalid", "Make a request with the given Basic authorization header\n @see http://tools.ietf.org/html/rfc2617\n @param [#fetch] opts\n @option opts [#to_s] :user\n @option opts [#to_s] :pass", "Make an HTTP request", "Prepare an HTTP request", "Verify our request isn't going to be made against another URI", "Merges query params if needed\n\n @param [#to_s] uri\n @return [URI]", "Create the request body object to send", "Removes header.\n\n @param [#to_s] name header name\n @return [void]", "Appends header.\n\n @param [#to_s] name header name\n @param [Array<#to_s>, #to_s] value header value(s) to be appended\n @return [void]", "Returns list of header values if any.\n\n @return [Array]", "Tells whenever header with given `name` is set or not.\n\n @return [Boolean]", "Merges `other` headers into `self`.\n\n @see #merge\n @return [void]", "Transforms `name` to canonical HTTP header capitalization\n\n @param [String] name\n @raise [HeaderError] if normalized name does not\n match {HEADER_NAME_RE}\n @return [String] canonical HTTP header name", "Ensures there is no new line character in the header value\n\n @param [String] value\n @raise [HeaderError] if value includes new line character\n @return [String] stringified header value", "Redirect policy for follow\n @return [Request]", "Stream the request to a socket", "Headers to send with proxy connect request", "returns all values in this column as an array\n column numbers are 1,2,3,... like in the spreadsheet", "returns the internal format of an excel cell", "Extracts all needed files from the zip file", "If the ODS file has an encryption-data element, then try to decrypt.\n If successful, the temporary content.xml will be overwritten with\n decrypted contents.", "Process the ODS encryption manifest and perform the decryption", "Create a cipher key based on an ODS algorithm string from manifest.xml", "Block decrypt raw bytes from the zip file based on the cipher", "helper function to set the internal representation of cells", "Compute upper bound for cells in a given cell range.", "Catalog a bundle.\n\n @param bundle [Bundle]\n @return [self]", "Get a clip by filename and position.\n\n @param filename [String]\n @param position [Position, Array(Integer, Integer)]\n @return [SourceMap::Clip]", "Get suggestions for constants in the specified namespace. The result\n may contain both constant and namespace pins.\n\n @param namespace [String] The namespace\n @param context [String] The context\n @return [Array]", "Get a fully qualified namespace name. This method will start the search\n in the specified context until it finds a match for the name.\n\n @param namespace [String, nil] The namespace to match\n @param context [String] The context to search\n @return [String]", "Get an array of instance variable pins defined in specified namespace\n and scope.\n\n @param namespace [String] A fully qualified namespace\n @param scope [Symbol] :instance or :class\n @return [Array]", "Get an array of methods available in a particular context.\n\n @param fqns [String] The fully qualified namespace to search for methods\n @param scope [Symbol] :class or :instance\n @param visibility [Array] :public, :protected, and/or :private\n @param deep [Boolean] True to include superclasses, mixins, etc.\n @return [Array]", "Get an array of method pins for a complex type.\n\n The type's namespace and the context should be fully qualified. If the\n context matches the namespace type or is a subclass of the type,\n protected methods are included in the results. If protected methods are\n included and internal is true, private methods are also included.\n\n @example\n api_map = Solargraph::ApiMap.new\n type = Solargraph::ComplexType.parse('String')\n api_map.get_complex_type_methods(type)\n\n @param type [Solargraph::ComplexType] The complex type of the namespace\n @param context [String] The context from which the type is referenced\n @param internal [Boolean] True to include private methods\n @return [Array]", "Get a stack of method pins for a method name in a namespace. The order\n of the pins corresponds to the ancestry chain, with highest precedence\n first.\n\n @example\n api_map.get_method_stack('Subclass', 'method_name')\n #=> [ , ]\n\n @param fqns [String]\n @param name [String]\n @param scope [Symbol] :instance or :class\n @return [Array]", "Get an array of all suggestions that match the specified path.\n\n @deprecated Use #get_path_pins instead.\n\n @param path [String] The path to find\n @return [Array]", "Get a list of documented paths that match the query.\n\n @example\n api_map.query('str') # Results will include `String` and `Struct`\n\n @param query [String] The text to match\n @return [Array]", "Get YARD documentation for the specified path.\n\n @example\n api_map.document('String#split')\n\n @param path [String] The path to find\n @return [Array]", "Get an array of all symbols in the workspace that match the query.\n\n @param query [String]\n @return [Array]", "Require extensions for the experimental plugin architecture. Any\n installed gem with a name that starts with \"solargraph-\" is considered\n an extension.\n\n @return [void]", "Sort an array of pins to put nil or undefined variables last.\n\n @param pins [Array]\n @return [Array]", "Check if a class is a superclass of another class.\n\n @param sup [String] The superclass\n @param sub [String] The subclass\n @return [Boolean]", "True if the specified position is inside the range.\n\n @param position [Position, Array(Integer, Integer)]\n @return [Boolean]", "True if the range contains the specified position and the position does not precede it.\n\n @param position [Position, Array(Integer, Integer)]\n @return [Boolean]", "Get an array of nodes containing the specified index, starting with the\n nearest node and ending with the root.\n\n @param line [Integer]\n @param column [Integer]\n @return [Array]", "Synchronize the Source with an update. This method applies changes to the\n code, parses the new code's AST, and returns the resulting Source object.\n\n @param updater [Source::Updater]\n @return [Source]", "A location representing the file in its entirety.\n\n @return [Location]", "Get a hash of comments grouped by the line numbers of the associated code.\n\n @return [Hash{Integer => Array}]", "Get a string representation of an array of comments.\n\n @param comments [Array]\n @return [String]", "Get an array of foldable comment block ranges. Blocks are excluded if\n they are less than 3 lines long.\n\n @return [Array]", "Merge the source. A merge will update the existing source for the file\n or add it to the sources if the workspace is configured to include it.\n The source is ignored if the configuration excludes it.\n\n @param source [Solargraph::Source]\n @return [Boolean] True if the source was added to the workspace", "Determine whether a file would be merged into the workspace.\n\n @param filename [String]\n @return [Boolean]", "Remove a source from the workspace. The source will not be removed if\n its file exists and the workspace is configured to include it.\n\n @param filename [String]\n @return [Boolean] True if the source was removed from the workspace", "True if the path resolves to a file in the workspace's require paths.\n\n @param path [String]\n @return [Boolean]", "Synchronize the workspace from the provided updater.\n\n @param updater [Source::Updater]\n @return [void]", "Generate require paths from gemspecs if they exist or assume the default\n lib directory.\n\n @return [Array]", "Get additional require paths defined in the configuration.\n\n @return [Array]", "Create a source to be added to the workspace. The file is ignored if it is\n neither open in the library nor included in the workspace.\n\n @param filename [String]\n @param text [String] The contents of the file\n @return [Boolean] True if the file was added to the workspace.", "Create a file source from a file on disk. The file is ignored if it is\n neither open in the library nor included in the workspace.\n\n @param filename [String]\n @return [Boolean] True if the file was added to the workspace.", "Delete a file from the library. Deleting a file will make it unavailable\n for checkout and optionally remove it from the workspace unless the\n workspace configuration determines that it should still exist.\n\n @param filename [String]\n @return [Boolean] True if the file was deleted", "Get completion suggestions at the specified file and location.\n\n @param filename [String] The file to analyze\n @param line [Integer] The zero-based line number\n @param column [Integer] The zero-based column number\n @return [SourceMap::Completion]\n @todo Take a Location instead of filename/line/column", "Get definition suggestions for the expression at the specified file and\n location.\n\n @param filename [String] The file to analyze\n @param line [Integer] The zero-based line number\n @param column [Integer] The zero-based column number\n @return [Array]\n @todo Take filename/position instead of filename/line/column", "Get signature suggestions for the method at the specified file and\n location.\n\n @param filename [String] The file to analyze\n @param line [Integer] The zero-based line number\n @param column [Integer] The zero-based column number\n @return [Array]\n @todo Take filename/position instead of filename/line/column", "Get diagnostics about a file.\n\n @param filename [String]\n @return [Array]", "Update the ApiMap from the library's workspace and open files.\n\n @return [void]", "Try to merge a source into the library's workspace. If the workspace is\n not configured to include the source, it gets ignored.\n\n @param source [Source]\n @return [Boolean] True if the source was merged into the workspace.", "Get the source for an open file or create a new source if the file\n exists on disk. Sources created from disk are not added to the open\n workspace files, i.e., the version on disk remains the authoritative\n version.\n\n @raise [FileNotFoundError] if the file does not exist\n @param filename [String]\n @return [Solargraph::Source]", "Removes the given header fields from options and returns the result. This\n modifies the given options in place.\n\n @param [Hash] options\n\n @return [Hash]", "Unseal the vault with the given shard.\n\n @example\n Vault.sys.unseal(\"abcd-1234\") #=> #\n\n @param [String] shard\n the key to use\n\n @return [SealStatus]", "List the secrets at the given path, if the path supports listing. If the\n the path does not exist, an exception will be raised.\n\n @example\n Vault.logical.list(\"secret\") #=> [#, #, ...]\n\n @param [String] path\n the path to list\n\n @return [Array]", "Read the secret at the given path. If the secret does not exist, +nil+\n will be returned.\n\n @example\n Vault.logical.read(\"secret/password\") #=> #\n\n @param [String] path\n the path to read\n\n @return [Secret, nil]", "Unwrap the data stored against the given token. If the secret does not\n exist, `nil` will be returned.\n\n @example\n Vault.logical.unwrap(\"f363dba8-25a7-08c5-430c-00b2367124e6\") #=> #\n\n @param [String] wrapper\n the token to use when unwrapping the value\n\n @return [Secret, nil]", "Unwrap a token in a wrapped response given the temporary token.\n\n @example\n Vault.logical.unwrap(\"f363dba8-25a7-08c5-430c-00b2367124e6\") #=> \"0f0f40fd-06ce-4af1-61cb-cdc12796f42b\"\n\n @param [String, Secret] wrapper\n the token to unwrap\n\n @return [String, nil]", "List all auths in Vault.\n\n @example\n Vault.sys.auths #=> {:token => #}\n\n @return [Hash]", "Enable a particular authentication at the given path.\n\n @example\n Vault.sys.enable_auth(\"github\", \"github\") #=> true\n\n @param [String] path\n the path to mount the auth\n @param [String] type\n the type of authentication\n @param [String] description\n a human-friendly description (optional)\n\n @return [true]", "Read the given auth path's configuration.\n\n @example\n Vault.sys.auth_tune(\"github\") #=> #\n\n @param [String] path\n the path to retrieve configuration for\n\n @return [AuthConfig]\n configuration of the given auth path", "Write the given auth path's configuration.\n\n @example\n Vault.sys.auth_tune(\"github\", \"default_lease_ttl\" => 600, \"max_lease_ttl\" => 1200 ) #=> true\n\n @param [String] path\n the path to retrieve configuration for\n\n @return [AuthConfig]\n configuration of the given auth path", "Returns true if the connection should be reset due to an idle timeout, or\n maximum request count, false otherwise.", "Is +req+ idempotent according to RFC 2616?", "Pipelines +requests+ to the HTTP server at +uri+ yielding responses if a\n block is given. Returns all responses recieved.\n\n See\n Net::HTTP::Pipeline[http://docs.seattlerb.org/net-http-pipeline/Net/HTTP/Pipeline.html]\n for further details.\n\n Only if net-http-pipeline was required before\n net-http-persistent #pipeline will be present.", "Creates a URI for an HTTP proxy server from ENV variables.\n\n If +HTTP_PROXY+ is set a proxy will be returned.\n\n If +HTTP_PROXY_USER+ or +HTTP_PROXY_PASS+ are set the URI is given the\n indicated user and password unless HTTP_PROXY contains either of these in\n the URI.\n\n The +NO_PROXY+ ENV variable can be used to specify hosts which shouldn't\n be reached via proxy; if set it should be a comma separated list of\n hostname suffixes, optionally with +:port+ appended, for example\n example.com,some.host:8080 . When set to * no proxy will\n be returned.\n\n For Windows users, lowercase ENV variables are preferred over uppercase ENV\n variables.", "Returns true when proxy should by bypassed for host.", "Raises an Error for +exception+ which resulted from attempting the request\n +req+ on the +connection+.\n\n Finishes the +connection+.", "Creates a GET request if +req_or_uri+ is a URI and adds headers to the\n request.\n\n Returns the request.", "Authenticate via the \"token\" authentication method. This authentication\n method is a bit bizarre because you already have a token, but hey,\n whatever floats your boat.\n\n This method hits the `/v1/auth/token/lookup-self` endpoint after setting\n the Vault client's token to the given token parameter. If the self lookup\n succeeds, the token is persisted onto the client for future requests. If\n the lookup fails, the old token (which could be unset) is restored on the\n client.\n\n @example\n Vault.auth.token(\"6440e1bd-ba22-716a-887d-e133944d22bd\") #=> #\n Vault.token #=> \"6440e1bd-ba22-716a-887d-e133944d22bd\"\n\n @param [String] new_token\n the new token to try to authenticate and store on the client\n\n @return [Secret]", "Authenticate via the \"app-id\" authentication method. If authentication is\n successful, the resulting token will be stored on the client and used for\n future requests.\n\n @example\n Vault.auth.app_id(\n \"aeece56e-3f9b-40c3-8f85-781d3e9a8f68\",\n \"3b87be76-95cf-493a-a61b-7d5fc70870ad\",\n ) #=> #\n\n @example with a custom mount point\n Vault.auth.app_id(\n \"aeece56e-3f9b-40c3-8f85-781d3e9a8f68\",\n \"3b87be76-95cf-493a-a61b-7d5fc70870ad\",\n mount: \"new-app-id\",\n )\n\n @param [String] app_id\n @param [String] user_id\n @param [Hash] options\n additional options to pass to the authentication call, such as a custom\n mount point\n\n @return [Secret]", "Authenticate via the \"approle\" authentication method. If authentication is\n successful, the resulting token will be stored on the client and used for\n future requests.\n\n @example\n Vault.auth.approle(\n \"db02de05-fa39-4855-059b-67221c5c2f63\",\n \"6a174c20-f6de-a53c-74d2-6018fcceff64\",\n ) #=> #\n\n @param [String] role_id\n @param [String] secret_id (default: nil)\n It is required when `bind_secret_id` is enabled for the specified role_id\n\n @return [Secret]", "Authenticate via the \"userpass\" authentication method. If authentication\n is successful, the resulting token will be stored on the client and used\n for future requests.\n\n @example\n Vault.auth.userpass(\"sethvargo\", \"s3kr3t\") #=> #\n\n @example with a custom mount point\n Vault.auth.userpass(\"sethvargo\", \"s3kr3t\", mount: \"admin-login\") #=> #\n\n @param [String] username\n @param [String] password\n @param [Hash] options\n additional options to pass to the authentication call, such as a custom\n mount point\n\n @return [Secret]", "Authenticate via the GitHub authentication method. If authentication is\n successful, the resulting token will be stored on the client and used\n for future requests.\n\n @example\n Vault.auth.github(\"mypersonalgithubtoken\") #=> #\n\n @param [String] github_token\n\n @return [Secret]", "Authenticate via the AWS EC2 authentication method. If authentication is\n successful, the resulting token will be stored on the client and used\n for future requests.\n\n @example\n Vault.auth.aws_ec2(\"read-only\", \"pkcs7\", \"vault-nonce\") #=> #\n\n @param [String] role\n @param [String] pkcs7\n pkcs7 returned by the instance identity document (with line breaks removed)\n @param [String] nonce optional\n @param [String] route optional\n\n @return [Secret]", "Authenticate via the GCP authentication method. If authentication is\n successful, the resulting token will be stored on the client and used\n for future requests.\n\n @example\n Vault.auth.gcp(\"read-only\", \"jwt\", \"gcp\") #=> #\n\n @param [String] role\n @param [String] jwt\n jwt returned by the instance identity metadata, or iam api\n @param [String] path optional\n the path were the gcp auth backend is mounted\n\n @return [Secret]", "Authenticate via a TLS authentication method. If authentication is\n successful, the resulting token will be stored on the client and used\n for future requests.\n\n @example Sending raw pem contents\n Vault.auth.tls(pem_contents) #=> #\n\n @example Reading a pem from disk\n Vault.auth.tls(File.read(\"/path/to/my/certificate.pem\")) #=> #\n\n @example Sending to a cert authentication backend mounted at a custom location\n Vault.auth.tls(pem_contents, 'custom/location') #=> #\n\n @param [String] pem (default: the configured SSL pem file or contents)\n The raw pem contents to use for the login procedure.\n\n @param [String] path (default: 'cert')\n The path to the auth backend to use for the login procedure.\n\n @return [Secret]", "Get the policy by the given name. If a policy does not exist by that name,\n +nil+ is returned.\n\n @example\n Vault.sys.policy(\"root\") #=> #\n\n @return [Policy, nil]", "Create a new policy with the given name and rules.\n\n @example\n policy = <<-EOH\n path \"sys\" {\n policy = \"deny\"\n }\n EOH\n Vault.sys.put_policy(\"dev\", policy) #=> true\n\n It is recommend that you load policy rules from a file:\n\n @example\n policy = File.read(\"/path/to/my/policy.hcl\")\n Vault.sys.put_policy(\"dev\", policy)\n\n @param [String] name\n the name of the policy\n @param [String] rules\n the policy rules\n\n @return [true]", "List all audits for the vault.\n\n @example\n Vault.sys.audits #=> { :file => # }\n\n @return [Hash]", "Generates a HMAC verifier for a given input.\n\n @example\n Vault.sys.audit_hash(\"file-audit\", \"my input\") #=> \"hmac-sha256:30aa7de18a5e90bbc1063db91e7c387b32b9fa895977eb8c177bbc91e7d7c542\"\n\n @param [String] path\n the path of the audit backend\n @param [String] input\n the input to generate a HMAC for\n\n @return [String]", "Lists all token accessors.\n\n @example Listing token accessors\n result = Vault.auth_token.accessors #=> #\n result.data[:keys] #=> [\"476ea048-ded5-4d07-eeea-938c6b4e43ec\", \"bb00c093-b7d3-b0e9-69cc-c4d85081165b\"]\n\n @return [Array]", "Create an authentication token. Note that the parameters specified below\n are not validated and passed directly to the Vault server. Depending on\n the version of Vault in operation, some of these options may not work, and\n newer options may be available that are not listed here.\n\n @example Creating a token\n Vault.auth_token.create #=> #\n\n @example Creating a token assigned to policies with a wrap TTL\n Vault.auth_token.create(\n policies: [\"myapp\"],\n wrap_ttl: 500,\n )\n\n @param [Hash] options\n @option options [String] :id\n The ID of the client token - this can only be specified for root tokens\n @option options [Array] :policies\n List of policies to apply to the token\n @option options [Fixnum, String] :wrap_ttl\n The number of seconds or a golang-formatted timestamp like \"5s\" or \"10m\"\n for the TTL on the wrapped response\n @option options [Hash] :meta\n A map of metadata that is passed to audit backends\n @option options [Boolean] :no_parent\n Create a token without a parent - see also {#create_orphan}\n @option options [Boolean] :no_default_policy\n Create a token without the default policy attached\n @option options [Boolean] :renewable\n Set whether this token is renewable or not\n @option options [String] :display_name\n Name of the token\n @option options [Fixnum] :num_uses\n Maximum number of uses for the token\n\n @return [Secret]", "Create an orphaned authentication token.\n\n @example\n Vault.auth_token.create_with_role(\"developer\") #=> #\n\n @param [Hash] options\n\n @return [Secret]", "Lookup information about the current token.\n\n @example\n Vault.auth_token.lookup(\"abcd-...\") #=> #\n\n @param [String] token\n @param [Hash] options\n\n @return [Secret]", "Lookup information about the given token accessor.\n\n @example\n Vault.auth_token.lookup_accessor(\"acbd-...\") #=> #\n\n @param [String] accessor\n @param [Hash] options", "Renew the given authentication token.\n\n @example\n Vault.auth_token.renew(\"abcd-1234\") #=> #\n\n @param [String] token\n the auth token\n @param [Fixnum] increment\n\n @return [Secret]", "Renews a lease associated with the calling token.\n\n @example\n Vault.auth_token.renew_self #=> #\n\n @param [Fixnum] increment\n\n @return [Secret]", "Create a new Client with the given options. Any options given take\n precedence over the default options.\n\n @return [Vault::Client]", "Perform a LIST request.\n @see Client#request", "Renew a lease with the given ID.\n\n @example\n Vault.sys.renew(\"aws/username\") #=> #\n\n @param [String] id\n the lease ID\n @param [Fixnum] increment\n\n @return [Secret]", "Create a hash-bashed representation of this response.\n\n @return [Hash]", "Initialize a new vault.\n\n @example\n Vault.sys.init #=> #\n\n @param [Hash] options\n the list of init options\n\n @option options [String] :root_token_pgp_key\n optional base64-encoded PGP public key used to encrypt the initial root\n token.\n @option options [Fixnum] :secret_shares\n the number of shares\n @option options [Fixnum] :secret_threshold\n the number of keys needed to unlock\n @option options [Array] :pgp_keys\n an optional Array of base64-encoded PGP public keys to encrypt sharees\n @option options [Fixnum] :stored_shares\n the number of shares that should be encrypted by the HSM for\n auto-unsealing\n @option options [Fixnum] :recovery_shares\n the number of shares to split the recovery key into\n @option options [Fixnum] :recovery_threshold\n the number of shares required to reconstruct the recovery key\n @option options [Array] :recovery_pgp_keys\n an array of PGP public keys used to encrypt the output for the recovery\n keys\n\n @return [InitResponse]", "Creates a new AppRole or update an existing AppRole with the given name\n and attributes.\n\n @example\n Vault.approle.set_role(\"testrole\", {\n secret_id_ttl: \"10m\",\n token_ttl: \"20m\",\n policies: \"default\",\n period: 3600,\n }) #=> true\n\n @param [String] name\n The name of the AppRole\n @param [Hash] options\n @option options [Boolean] :bind_secret_id\n Require secret_id to be presented when logging in using this AppRole.\n @option options [String] :bound_cidr_list\n Comma-separated list of CIDR blocks. Specifies blocks of IP addresses\n which can perform the login operation.\n @option options [String] :policies\n Comma-separated list of policies set on tokens issued via this AppRole.\n @option options [String] :secret_id_num_uses\n Number of times any particular SecretID can be used to fetch a token\n from this AppRole, after which the SecretID will expire.\n @option options [Fixnum, String] :secret_id_ttl\n The number of seconds or a golang-formatted timestamp like \"60m\" after\n which any SecretID expires.\n @option options [Fixnum, String] :token_ttl\n The number of seconds or a golang-formatted timestamp like \"60m\" to set\n as the TTL for issued tokens and at renewal time.\n @option options [Fixnum, String] :token_max_ttl\n The number of seconds or a golang-formatted timestamp like \"60m\" after\n which the issued token can no longer be renewed.\n @option options [Fixnum, String] :period\n The number of seconds or a golang-formatted timestamp like \"60m\".\n If set, the token generated using this AppRole is a periodic token.\n So long as it is renewed it never expires, but the TTL set on the token\n at each renewal is fixed to the value specified here. If this value is\n modified, the token will pick up the new value at its next renewal.\n\n @return [true]", "Gets the AppRole by the given name. If an AppRole does not exist by that\n name, +nil+ is returned.\n\n @example\n Vault.approle.role(\"testrole\") #=> #\n\n @return [Secret, nil]", "Reads the RoleID of an existing AppRole. If an AppRole does not exist by\n that name, +nil+ is returned.\n\n @example\n Vault.approle.role_id(\"testrole\") #=> #\n\n @return [Secret, nil]", "Updates the RoleID of an existing AppRole to a custom value.\n\n @example\n Vault.approle.set_role_id(\"testrole\") #=> true\n\n @return [true]", "Generates and issues a new SecretID on an existing AppRole.\n\n @example Generate a new SecretID\n result = Vault.approle.create_secret_id(\"testrole\") #=> #\n result.data[:secret_id] #=> \"841771dc-11c9-bbc7-bcac-6a3945a69cd9\"\n\n @example Assign a custom SecretID\n result = Vault.approle.create_secret_id(\"testrole\", {\n secret_id: \"testsecretid\"\n }) #=> #\n result.data[:secret_id] #=> \"testsecretid\"\n\n @param [String] role_name\n The name of the AppRole\n @param [Hash] options\n @option options [String] :secret_id\n SecretID to be attached to the Role. If not set, then the new SecretID\n will be generated\n @option options [Hash] :metadata\n Metadata to be tied to the SecretID. This should be a JSON-formatted\n string containing the metadata in key-value pairs. It will be set on\n tokens issued with this SecretID, and is logged in audit logs in\n plaintext.\n\n @return [true]", "Reads out the properties of a SecretID assigned to an AppRole.\n If the specified SecretID don't exist, +nil+ is returned.\n\n @example\n Vault.approle.role(\"testrole\", \"841771dc-11c9-...\") #=> #\n\n @param [String] role_name\n The name of the AppRole\n @param [String] secret_id\n SecretID belonging to AppRole\n\n @return [Secret, nil]", "Lists the accessors of all the SecretIDs issued against the AppRole.\n This includes the accessors for \"custom\" SecretIDs as well. If there are\n no SecretIDs against this role, an empty array will be returned.\n\n @example\n Vault.approle.secret_ids(\"testrole\") #=> [\"ce102d2a-...\", \"a1c8dee4-...\"]\n\n @return [Array]", "Encodes a string according to the rules for URL paths. This is\n used as opposed to CGI.escape because in a URL path, space\n needs to be escaped as %20 and CGI.escapes a space as +.\n\n @param [String]\n\n @return [String]", "List all mounts in the vault.\n\n @example\n Vault.sys.mounts #=> { :secret => # }\n\n @return [Hash]", "Tune a mount at the given path.\n\n @example\n Vault.sys.mount_tune(\"pki\", max_lease_ttl: '87600h') #=> true\n\n @param [String] path\n the path to write\n @param [Hash] data\n the data to write", "Change the name of the mount\n\n @example\n Vault.sys.remount(\"pg\", \"postgres\") #=> true\n\n @param [String] from\n the origin mount path\n @param [String] to\n the new mount path\n\n @return [true]", "Returns the full path to the output directory using SimpleCov.root\n and SimpleCov.coverage_dir, so you can adjust this by configuring those\n values. Will create the directory if it's missing", "Gets or sets the behavior to process coverage results.\n\n By default, it will call SimpleCov.result.format!\n\n Configure with:\n\n SimpleCov.at_exit do\n puts \"Coverage done\"\n SimpleCov.result.format!\n end", "Returns the project name - currently assuming the last dirname in\n the SimpleCov.root is this.", "The actual filter processor. Not meant for direct use", "Merges two Coverage.result hashes", "Applies the profile of given name on SimpleCov.configure", "Build link to the documentation about the given subject for the current\n version of Reek. The subject can be either a smell type like\n 'FeatureEnvy' or a general subject like 'Rake Task'.\n\n @param subject [String]\n @return [String] the full URL for the relevant documentation", "Attempts to load pre-generated code returning true if it succeeds.", "Registers C type-casts +r2c+ and +c2r+ for +type+.", "Adds a C function to the source, including performing automatic\n type conversion to arguments and the return value. The Ruby\n method name can be overridden by providing method_name. Unknown\n type conversions can be extended by using +add_type_converter+.", "Same as +c+, but adds a class function.", "Same as +c_raw+, but adds a class function.", "Checks the target source code for instances of \"smell type\"\n and returns true only if it can find one of them that matches.\n\n You can pass the smell type you want to check for as String or as Symbol:\n\n - :UtilityFunction\n - \"UtilityFunction\"\n\n It is recommended to pass this as a symbol like :UtilityFunction. However we don't\n enforce this.\n\n Additionally you can be more specific and pass in \"smell_details\" you\n want to check for as well e.g. \"name\" or \"count\" (see the examples below).\n The parameters you can check for are depending on the smell you are checking for.\n For instance \"count\" doesn't make sense everywhere whereas \"name\" does in most cases.\n If you pass in a parameter that doesn't exist (e.g. you make a typo like \"namme\") Reek will\n raise an ArgumentError to give you a hint that you passed something that doesn't make\n much sense.\n\n @param smell_type [Symbol, String] The \"smell type\" to check for.\n @param smell_details [Hash] A hash containing \"smell warning\" parameters\n\n @example Without smell_details\n\n reek_of(:FeatureEnvy)\n reek_of(:UtilityFunction)\n\n @example With smell_details\n\n reek_of(:UncommunicativeParameterName, name: 'x2')\n reek_of(:DataClump, count: 3)\n\n @example From a real spec\n\n expect(src).to reek_of(:DuplicateMethodCall, name: '@other.thing')\n\n @public\n\n @quality :reek:UtilityFunction", "See the documentaton for \"reek_of\".\n\n Notable differences to reek_of:\n 1.) \"reek_of\" doesn't mind if there are other smells of a different type.\n \"reek_only_of\" will fail in that case.\n 2.) \"reek_only_of\" doesn't support the additional smell_details hash.\n\n @param smell_type [Symbol, String] The \"smell type\" to check for.\n\n @public\n\n @quality :reek:UtilityFunction", "Processes the given AST, memoizes it and returns a tree of nested\n contexts.\n\n For example this ruby code:\n\n class Car; def drive; end; end\n\n would get compiled into this AST:\n\n (class\n (const nil :Car) nil\n (def :drive\n (args) nil))\n\n Processing this AST would result in a context tree where each node\n contains the outer context, the AST and the child contexts. The top\n node is always Reek::Context::RootContext. Using the example above,\n the tree would look like this:\n\n RootContext -> children: 1 ModuleContext -> children: 1 MethodContext\n\n @return [Reek::Context::RootContext] tree of nested contexts", "Handles every node for which we have no context_processor.", "Handles `def` nodes.\n\n An input example that would trigger this method would be:\n\n def call_me; foo = 2; bar = 5; end\n\n Given the above example we would count 2 statements overall.", "Handles `send` nodes a.k.a. method calls.\n\n An input example that would trigger this method would be:\n\n call_me()\n\n Besides checking if it's a visibility modifier or an attribute writer\n we also record to what the method call is referring to\n which we later use for smell detectors like FeatureEnvy.", "Handles `if` nodes.\n\n An input example that would trigger this method would be:\n\n if a > 5 && b < 3\n puts 'bingo'\n else\n 3\n end\n\n Counts the `if` body as one statement and the `else` body as another statement.\n\n At the end we subtract one statement because the surrounding context was already counted\n as one (e.g. via `process_def`).\n\n `children[1]` refers to the `if` body (so `puts 'bingo'` from above) and\n `children[2]` to the `else` body (so `3` from above), which might be nil.", "Handles `rescue` nodes.\n\n An input example that would trigger this method would be:\n\n def simple\n raise ArgumentError, 'raising...'\n rescue => e\n puts 'rescued!'\n end\n\n Counts everything before the `rescue` body as one statement.\n\n At the end we subtract one statement because the surrounding context was already counted\n as one (e.g. via `process_def`).\n\n `exp.children.first` below refers to everything before the actual `rescue`\n which would be the\n\n raise ArgumentError, 'raising...'\n\n in the example above.\n `exp` would be the whole method body wrapped under a `rescue` node.\n See `process_resbody` for additional reference.", "Stores a reference to the current context, creates a nested new one,\n yields to the given block and then restores the previous context.\n\n @param klass [Context::*Context] context class\n @param args arguments for the class initializer\n @yield block", "Appends a new child context to the current context but does not change\n the current context.\n\n @param klass [Context::*Context] context class\n @param args arguments for the class initializer\n\n @return [Context::*Context] the context that was appended", "Retrieves the value, if any, for the given +key+ in the given +context+.\n\n Raises an error if neither the context nor this config have a value for\n the key.", "Find any overrides that match the supplied context", "Recursively enhance an AST with type-dependent mixins, and comments.\n\n See {file:docs/How-reek-works-internally.md} for the big picture of how this works.\n Example:\n This\n class Klazz; def meth(argument); argument.call_me; end; end\n corresponds to this sexp:\n (class\n (const nil :Klazz) nil\n (def :meth\n (args\n (arg :argument))\n (send\n (lvar :argument) :call_me)))\n where every node is of type Parser::AST::Node.\n Passing this into `dress` will return the exact same structure, but this\n time the nodes will contain type-dependent mixins, e.g. this:\n (const nil :Klazz)\n will be of type Reek::AST::Node with Reek::AST::SexpExtensions::ConstNode mixed in.\n\n @param sexp [Parser::AST::Node] the given sexp\n @param comment_map [Hash] see the documentation for SourceCode#syntax_tree\n\n @return an instance of Reek::AST::Node with type-dependent sexp extensions mixed in.\n\n @quality :reek:FeatureEnvy\n @quality :reek:TooManyStatements { max_statements: 6 }", "append_record_to_messages adds a record to the bulk message\n payload to be submitted to Elasticsearch. Records that do\n not include '_id' field are skipped when 'write_operation'\n is configured for 'create' or 'update'\n\n returns 'true' if record was appended to the bulk message\n and 'false' otherwise", "send_bulk given a specific bulk request, the original tag,\n chunk, and bulk_message_count", "Adds the given responders to the current controller's responder, allowing you to cherry-pick\n which responders you want per controller.\n\n class InvitationsController < ApplicationController\n responders :flash, :http_cache\n end\n\n Takes symbols and strings and translates them to VariableResponder (eg. :flash becomes FlashResponder).\n Also allows passing in the responders modules in directly, so you could do:\n\n responders FlashResponder, HttpCacheResponder\n\n Or a mix of both methods:\n\n responders :flash, MyCustomResponder", "For a given controller action, respond_with generates an appropriate\n response based on the mime-type requested by the client.\n\n If the method is called with just a resource, as in this example -\n\n class PeopleController < ApplicationController\n respond_to :html, :xml, :json\n\n def index\n @people = Person.all\n respond_with @people\n end\n end\n\n then the mime-type of the response is typically selected based on the\n request's Accept header and the set of available formats declared\n by previous calls to the controller's class method +respond_to+. Alternatively\n the mime-type can be selected by explicitly setting request.format in\n the controller.\n\n If an acceptable format is not identified, the application returns a\n '406 - not acceptable' status. Otherwise, the default response is to render\n a template named after the current action and the selected format,\n e.g. index.html.erb . If no template is available, the behavior\n depends on the selected format:\n\n * for an html response - if the request method is +get+, an exception\n is raised but for other requests such as +post+ the response\n depends on whether the resource has any validation errors (i.e.\n assuming that an attempt has been made to save the resource,\n e.g. by a +create+ action) -\n 1. If there are no errors, i.e. the resource\n was saved successfully, the response +redirect+'s to the resource\n i.e. its +show+ action.\n 2. If there are validation errors, the response\n renders a default action, which is :new for a\n +post+ request or :edit for +patch+ or +put+.\n Thus an example like this -\n\n respond_to :html, :xml\n\n def create\n @user = User.new(params[:user])\n flash[:notice] = 'User was successfully created.' if @user.save\n respond_with(@user)\n end\n\n is equivalent, in the absence of create.html.erb , to -\n\n def create\n @user = User.new(params[:user])\n respond_to do |format|\n if @user.save\n flash[:notice] = 'User was successfully created.'\n format.html { redirect_to(@user) }\n format.xml { render xml: @user }\n else\n format.html { render action: \"new\" }\n format.xml { render xml: @user }\n end\n end\n end\n\n * for a JavaScript request - if the template isn't found, an exception is\n raised.\n * for other requests - i.e. data formats such as xml, json, csv etc, if\n the resource passed to +respond_with+ responds to to_
,\n the method attempts to render the resource in the requested format\n directly, e.g. for an xml request, the response is equivalent to calling\n render xml: resource
.\n\n === Nested resources\n\n As outlined above, the +resources+ argument passed to +respond_with+\n can play two roles. It can be used to generate the redirect url\n for successful html requests (e.g. for +create+ actions when\n no template exists), while for formats other than html and JavaScript\n it is the object that gets rendered, by being converted directly to the\n required format (again assuming no template exists).\n\n For redirecting successful html requests, +respond_with+ also supports\n the use of nested resources, which are supplied in the same way as\n in form_for
and polymorphic_url
. For example -\n\n def create\n @project = Project.find(params[:project_id])\n @task = @project.comments.build(params[:task])\n flash[:notice] = 'Task was successfully created.' if @task.save\n respond_with(@project, @task)\n end\n\n This would cause +respond_with+ to redirect to project_task_url
\n instead of task_url
. For request formats other than html or\n JavaScript, if multiple resources are passed in this way, it is the last\n one specified that is rendered.\n\n === Customizing response behavior\n\n Like +respond_to+, +respond_with+ may also be called with a block that\n can be used to overwrite any of the default responses, e.g. -\n\n def create\n @user = User.new(params[:user])\n flash[:notice] = \"User was successfully created.\" if @user.save\n\n respond_with(@user) do |format|\n format.html { render }\n end\n end\n\n The argument passed to the block is an ActionController::MimeResponds::Collector\n object which stores the responses for the formats defined within the\n block. Note that formats with responses defined explicitly in this way\n do not have to first be declared using the class method +respond_to+.\n\n Also, a hash passed to +respond_with+ immediately after the specified\n resource(s) is interpreted as a set of options relevant to all\n formats. Any option accepted by +render+ can be used, e.g.\n\n respond_with @people, status: 200\n\n However, note that these options are ignored after an unsuccessful attempt\n to save a resource, e.g. when automatically rendering :new \n after a post request.\n\n Three additional options are relevant specifically to +respond_with+ -\n 1. :location - overwrites the default redirect location used after\n a successful html +post+ request.\n 2. :action - overwrites the default render action used after an\n unsuccessful html +post+ request.\n 3. :render - allows to pass any options directly to the :render \n call after unsuccessful html +post+ request. Usefull if for example you\n need to render a template which is outside of controller's path or you\n want to override the default http :status code, e.g.\n\n respond_with(resource, render: { template: 'path/to/template', status: 422 })", "Collect mimes declared in the class method respond_to valid for the\n current action.", "reindex whole database using a extra temporary index + move operation", "special handling of get_settings to avoid raising errors on 404", "Defines attr accessors for each available_filter on self and assigns\n values based on fp.\n @param fp [Hash] filterrific_params with stringified keys", "Computes filterrific params using a number of strategies. Limits params\n to 'available_filters' if given via opts.\n @param model_class [ActiveRecord::Base]\n @param filterrific_params [ActionController::Params, Hash]\n @param opts [Hash]\n @option opts [Boolean, optional] \"sanitize_params\"\n if true, sanitizes all filterrific params to prevent reflected (or stored) XSS attacks.\n Defaults to true.\n @param persistence_id [String, nil]", "Sets all options on form_for to defaults that work with Filterrific\n @param record [Filterrific] the @filterrific object\n @param options [Hash] standard options for form_for\n @param block [Proc] the form body", "Renders HTML to reverse sort order on currently sorted column.\n @param filterrific [Filterrific::ParamSet]\n @param new_sort_key [String]\n @param opts [Hash]\n @return [String] an HTML fragment", "explicit hash, to get symbols in hash keys", "Executes a task on a specific VM.\n\n @param vm [Vagrant::VM]\n @param options [Hash] Parsed options from the command line", "shows a link that will allow to dynamically add a new associated object.\n\n - *name* : the text to show in the link\n - *f* : the form this should come in (the formtastic form)\n - *association* : the associated objects, e.g. :tasks, this should be the name of the has_many relation.\n - *html_options*: html options to be passed to link_to (see link_to )\n - *:render_options* : options passed to `simple_fields_for, semantic_fields_for or fields_for`\n - *:locals* : the locals hash in the :render_options is handed to the partial\n - *:partial* : explicitly override the default partial name\n - *:wrap_object* : a proc that will allow to wrap your object, especially suited when using\n decorators, or if you want special initialisation\n - *:form_name* : the parameter for the form in the nested form partial. Default `f`.\n - *:count* : Count of how many objects will be added on a single click. Default `1`.\n - *&block*: see link_to ", "Capture and process any exceptions from the given block.\n\n @example\n Raven.capture do\n MyApp.run\n end", "Provides extra context to the exception prior to it being handled by\n Raven. An exception can have multiple annotations, which are merged\n together.\n\n The options (annotation) is treated the same as the ``options``\n parameter to ``capture_exception`` or ``Event.from_exception``, and\n can contain the same ``:user``, ``:tags``, etc. options as these\n methods.\n\n These will be merged with the ``options`` parameter to\n ``Event.from_exception`` at the top of execution.\n\n @example\n begin\n raise \"Hello\"\n rescue => exc\n Raven.annotate_exception(exc, :user => { 'id' => 1,\n 'email' => 'foo@example.com' })\n end", "Once an ActiveJob is queued, ActiveRecord references get serialized into\n some internal reserved keys, such as _aj_globalid.\n\n The problem is, if this job in turn gets queued back into ActiveJob with\n these magic reserved keys, ActiveJob will throw up and error. We want to\n capture these and mutate the keys so we can sanely report it.", "run all plugins or those that match the attribute filter is provided\n\n @param safe [Boolean]\n @param [Array] attribute_filter the attributes to run. All will be run if not specified\n\n @return [Mash]", "Pretty Print this object as JSON", "gather plugins providing exactly the attributes listed", "This function is used to fetch the plugins for the attributes specified\n in the CLI options to Ohai.\n It first attempts to find the plugins for the attributes\n or the sub attributes given.\n If it can't find any, it looks for plugins that might\n provide the parents of a given attribute and returns the\n first parent found.", "This function is used to fetch the plugins from\n 'depends \"languages\"' statements in plugins.\n It gathers plugins providing each of the attributes listed, or the\n plugins providing the closest parent attribute", "Takes a section of the map, recursively searches for a `_plugins` key\n to find all the plugins in that section of the map. If given the whole\n map, it will find all of the plugins that have at least one provided\n attribute.", "Searches all plugin paths and returns an Array of file paths to plugins\n\n @param dir [Array, String] directory/directories to load plugins from\n @return [Array]", "load additional plugins classes from a given directory\n @param from [String] path to a directory with additional plugins to load", "Load a specified file as an ohai plugin and creates an instance of it.\n Not used by ohai itself, but is used in the specs to load plugins for testing\n\n @private\n @param plugin_path [String]", "Given a list of plugins and the first plugin in the cycle,\n returns the list of plugin source files responsible for the\n cycle. Does not include plugins that aren't a part of the cycle", "A point is inside a triangle if the area of 3 triangles, constructed from\n triangle sides and the given point, is equal to the area of triangle.", "Play an animation", "Set the position of the clipping retangle based on the current frame", "Calculate the distance between two points", "Set a window attribute", "Add an object to the window", "Remove an object from the window", "Set an event handler", "Key callback method, called by the native and web extentions", "Mouse callback method, called by the native and web extentions", "Controller callback method, called by the native and web extentions", "Update callback method, called by the native and web extentions", "An an object to the window, used by the public `add` method", "Create a new database view.\n\n @param name [String, Symbol] The name of the database view.\n @param version [Fixnum] The version number of the view, used to find the\n definition file in `db/views`. This defaults to `1` if not provided.\n @param sql_definition [String] The SQL query for the view schema. An error\n will be raised if `sql_definition` and `version` are both set,\n as they are mutually exclusive.\n @param materialized [Boolean, Hash] Set to true to create a materialized\n view. Set to { no_data: true } to create materialized view without\n loading data. Defaults to false.\n @return The database response from executing the create statement.\n\n @example Create from `db/views/searches_v02.sql`\n create_view(:searches, version: 2)\n\n @example Create from provided SQL string\n create_view(:active_users, sql_definition: <<-SQL)\n SELECT * FROM users WHERE users.active = 't'\n SQL", "Drop a database view by name.\n\n @param name [String, Symbol] The name of the database view.\n @param revert_to_version [Fixnum] Used to reverse the `drop_view` command\n on `rake db:rollback`. The provided version will be passed as the\n `version` argument to {#create_view}.\n @param materialized [Boolean] Set to true if dropping a meterialized view.\n defaults to false.\n @return The database response from executing the drop statement.\n\n @example Drop a view, rolling back to version 3 on rollback\n drop_view(:users_who_recently_logged_in, revert_to_version: 3)", "Update a database view to a new version.\n\n The existing view is dropped and recreated using the supplied `version`\n parameter.\n\n @param name [String, Symbol] The name of the database view.\n @param version [Fixnum] The version number of the view.\n @param sql_definition [String] The SQL query for the view schema. An error\n will be raised if `sql_definition` and `version` are both set,\n as they are mutually exclusive.\n @param revert_to_version [Fixnum] The version number to rollback to on\n `rake db rollback`\n @param materialized [Boolean, Hash] True if updating a materialized view.\n Set to { no_data: true } to update materialized view without loading\n data. Defaults to false.\n @return The database response from executing the create statement.\n\n @example\n update_view :engagement_reports, version: 3, revert_to_version: 2", "Update a database view to a new version using `CREATE OR REPLACE VIEW`.\n\n The existing view is replaced using the supplied `version`\n parameter.\n\n Does not work with materialized views due to lack of database support.\n\n @param name [String, Symbol] The name of the database view.\n @param version [Fixnum] The version number of the view.\n @param revert_to_version [Fixnum] The version number to rollback to on\n `rake db rollback`\n @return The database response from executing the create statement.\n\n @example\n replace_view :engagement_reports, version: 3, revert_to_version: 2", "Returns a hash representation of the event.\n\n Metadata is converted to hash as well\n\n @return [Hash] with :event_id, :metadata, :data, :type keys", "Persists events and notifies subscribed handlers about them\n\n @param events [Array, Event, Proto] event(s)\n @param stream_name [String] name of the stream for persisting events.\n @param expected_version [:any, :auto, :none, Integer] controls optimistic locking strategy. {http://railseventstore.org/docs/expected_version/ Read more}\n @return [self]", "merges the hash of headers into the current header set.", "disable Secure cookies for non-https requests", "when configuring with booleans, only one enforcement is permitted", "validate exclusive use of only or except but not both at the same time", "validate exclusivity of only and except members within strict and lax", "Discard any 'none' values if more directives are supplied since none may override values.", "Removes duplicates and sources that already match an existing wild card.\n\n e.g. *.github.com asdf.github.com becomes *.github.com", "Invisible reCAPTCHA implementation", "Your private API can be specified in the +options+ hash or preferably\n using the Configuration.", "Compares this configuration with another.\n\n @param other [HamlLint::Configuration]\n @return [true,false] whether the given configuration is equivalent\n Returns a non-modifiable configuration for the specified linter.\n\n @param linter [HamlLint::Linter,Class]", "Merge two hashes such that nested hashes are merged rather than replaced.\n\n @param parent [Hash]\n @param child [Hash]\n @return [Hash]", "Prints the standard progress reporter output and writes the new config file.\n\n @param report [HamlLint::Report]\n @return [void]", "Prints the standard progress report marks and tracks files with lint.\n\n @param file [String]\n @param lints [Array]\n @return [void]", "The contents of the generated configuration file based on captured lint.\n\n @return [String] a Yaml-formatted configuration file's contents", "Constructs the configuration for excluding a linter in some files.\n\n @param linter [String] the name of the linter to exclude\n @param files [Array] the files in which the linter is excluded\n @return [String] a Yaml-formatted configuration", "Returns the class of the specified Reporter.\n\n @param reporter_name [String]\n @raise [HamlLint::Exceptions::InvalidCLIOption] if reporter doesn't exist\n @return [Class]", "Enables the linter if the tree is for the right file type.\n\n @param [HamlLint::Tree::RootNode] the root of a syntax tree\n @return [true, false] whether the linter is enabled for the tree", "Checks for instance variables in tag nodes when the linter is enabled.\n\n @param [HamlLint::Tree:TagNode]\n @return [void]", "Runs the appropriate linters against the desired files given the specified\n options.\n\n @param [Hash] options\n @option options :config_file [String] path of configuration file to load\n @option options :config [HamlLint::Configuration] configuration to use\n @option options :excluded_files [Array]\n @option options :included_linters [Array]\n @option options :excluded_linters [Array]\n @option options :fail_fast [true, false] flag for failing after first failure\n @option options :fail_level\n @option options :reporter [HamlLint::Reporter]\n @return [HamlLint::Report] a summary of all lints found", "Runs all provided linters using the specified config against the given\n file.\n\n @param file [String] path to file to lint\n @param linter_selector [HamlLint::LinterSelector]\n @param config [HamlLint::Configuration]", "Returns the list of files that should be linted given the specified\n configuration and options.\n\n @param config [HamlLint::Configuration]\n @param options [Hash]\n @return [Array]", "Process the files and add them to the given report.\n\n @param report [HamlLint::Report]\n @return [void]", "Process a file and add it to the given report.\n\n @param file [String] the name of the file to process\n @param report [HamlLint::Report]\n @return [void]", "Generates a report based on the given options.\n\n @param options [Hash]\n @option options :reporter [HamlLint::Reporter] the reporter to report with\n @return [HamlLint::Report]", "Create a file finder using the specified configuration.\n\n @param config [HamlLint::Configuration]\n Return list of files to lint given the specified set of paths and glob\n patterns.\n @param patterns [Array]\n @param excluded_patterns [Array]\n @raise [HamlLint::Exceptions::InvalidFilePath]\n @return [Array] list of actual files", "Extract the list of matching files given the list of glob patterns, file\n paths, and directories.\n\n @param patterns [Array]\n @return [Array]", "Whether the given file should be treated as a Haml file.\n\n @param file [String]\n @return [Boolean]", "Returns whether a string starts with a character that would otherwise be\n given special treatment, thus making enclosing it in a string necessary.", "Initializes a linter with the specified configuration.\n\n @param config [Hash] configuration for this linter\n Runs the linter against the given Haml document.\n\n @param document [HamlLint::Document]", "Returns whether the inline content for a node is a string.\n\n For example, the following node has a literal string:\n\n %tag= \"A literal #{string}\"\n\n whereas this one does not:\n\n %tag A literal #{string}\n\n @param node [HamlLint::Tree::Node]\n @return [true,false]", "Get the inline content for this node.\n\n Inline content is the content that appears inline right after the\n tag/script. For example, in the code below...\n\n %tag Some inline content\n\n ...\"Some inline content\" would be the inline content.\n\n @param node [HamlLint::Tree::Node]\n @return [String]", "Gets the next node following this node, ascending up the ancestor chain\n recursively if this node has no siblings.\n\n @param node [HamlLint::Tree::Node]\n @return [HamlLint::Tree::Node,nil]", "Creates a reusable parser.\n Parse the given Ruby source into an abstract syntax tree.\n\n @param source [String] Ruby source code\n @return [Array] syntax tree in the form returned by Parser gem", "Given the provided options, execute the appropriate command.\n\n @return [Integer] exit status code", "Given the provided options, configure the logger.\n\n @return [void]", "Outputs a message and returns an appropriate error code for the specified\n exception.", "Instantiates a new reporter based on the options.\n\n @param options [HamlLint::Configuration]\n @option options [true, nil] :auto_gen_config whether to use the config\n generating reporter\n @option options [Class] :reporter the class of reporter to use\n @return [HamlLint::Reporter]", "Scans the files specified by the given options for lints.\n\n @return [Integer] exit status code", "Outputs a list of all currently available linters.", "Outputs a list of currently available reporters.", "Outputs the application name and version.", "Outputs the backtrace of an exception with instructions on how to report\n the issue.", "Removes YAML frontmatter", "Checks whether a visitor is disabled due to comment configuration.\n\n @param [HamlLint::HamlVisitor]\n @return [true, false]", "Implements the Enumerable interface to walk through an entire tree.\n\n @return [Enumerator, HamlLint::Tree::Node]", "The line numbers that are contained within the node.\n\n @api public\n @return [Range]", "Discovers the end line of the node when there are no lines.\n\n @return [Integer] the end line of the node", "Gets the node of the syntax tree for a given line number.\n\n @param line [Integer] the line number of the node\n @return [HamlLint::Node]", "Returns a list of linters that are enabled given the specified\n configuration and additional options.\n\n @param config [HamlLint::Configuration]\n @param options [Hash]\n @return [Array]", "Whether to run the given linter against the specified file.\n\n @param config [HamlLint::Configuration]\n @param linter [HamlLint::Linter]\n @param file [String]\n @return [Boolean]", "Returns the source code for the static and dynamic attributes\n of a tag.\n\n @example For `%tag.class{ id: 'hello' }(lang=en)`, this returns:\n { :static => '.class', :hash => \" id: 'hello' \", :html => \"lang=en\" }\n\n @return [Hash]", "Executes RuboCop against the given Ruby code and records the offenses as\n lints.\n\n @param ruby [String] Ruby code\n @param source_map [Hash] map of Ruby code line numbers to original line\n numbers in the template", "Overrides the global stdin to allow RuboCop to read Ruby code from it.\n\n @param ruby [String] the Ruby code to write to the overridden stdin\n @param _block [Block] the block to perform with the overridden stdin\n @return [void]", "Returns an array of two items, the first being the absolute path, the second\n the relative path.\n\n The relative path is relative to the current working dir. The path passed can\n be either relative or absolute.\n\n @param path [String] Path to get absolute and relative path of\n @return [Array] Absolute and relative path", "Yields interpolated values within a block of text.\n\n @param text [String]\n @yield Passes interpolated code and line number that code appears on in\n the text.\n @yieldparam interpolated_code [String] code that was interpolated\n @yieldparam line [Integer] line number code appears on in text", "Find all consecutive items satisfying the given block of a minimum size,\n yielding each group of consecutive items to the provided block.\n\n @param items [Array]\n @param satisfies [Proc] function that takes an item and returns true/false\n @param min_consecutive [Fixnum] minimum number of consecutive items before\n yielding the group\n @yield Passes list of consecutive items all matching the criteria defined\n by the `satisfies` {Proc} to the provided block\n @yieldparam group [Array] List of consecutive items\n @yieldreturn [Boolean] block should return whether item matches criteria\n for inclusion", "Calls a block of code with a modified set of environment variables,\n restoring them once the code has executed.\n\n @param env [Hash] environment variables to set", "Executes the CLI given the specified task arguments.\n\n @param task_args [Rake::TaskArguments]", "Returns the list of files that should be linted given the specified task\n arguments.\n\n @param task_args [Rake::TaskArguments]", "Log setting or extension loading notices, sensitive information\n is redacted.\n\n @param notices [Array] to be logged.\n @param level [Symbol] to log the notices at.", "Set up Sensu spawn, creating a worker to create, control, and\n limit spawned child processes. This method adjusts the\n EventMachine thread pool size to accommodate the concurrent\n process spawn limit and other Sensu process operations.\n\n https://github.com/sensu/sensu-spawn", "Retry a code block until it retures true. The first attempt and\n following retries are delayed.\n\n @param wait [Numeric] time to delay block calls.\n @param block [Proc] to call that needs to return true.", "Deep merge two hashes. Nested hashes are deep merged, arrays are\n concatenated and duplicate array items are removed.\n\n @param hash_one [Hash]\n @param hash_two [Hash]\n @return [Hash] deep merged hash.", "Creates a deep dup of basic ruby objects with support for walking\n hashes and arrays.\n\n @param obj [Object]\n @return [obj] a dup of the original object.", "Retrieve the system IP address. If a valid non-loopback\n IPv4 address cannot be found and an error is thrown,\n `nil` will be returned.\n\n @return [String] system ip address", "Traverse a hash for an attribute value, with a fallback default\n value if nil.\n\n @param tree [Hash] to traverse.\n @param path [Array] of attribute keys.\n @param default [Object] value if attribute value is nil.\n @return [Object] attribute or fallback default value.", "Determine the next check cron time.\n\n @param check [Hash] definition.", "Execute the given block, and retry the current restartable transaction if a\n MySQL deadlock occurs.", "Get the current or historic balance of an account.\n\n @param account [DoubleEntry::Account:Instance]\n @option args :from [Time]\n @option args :to [Time]\n @option args :at [Time]\n @option args :code [Symbol]\n @option args :codes [Array]\n @return [Money]", "This method will populate all matched page TextFields,\n TextAreas, SelectLists, FileFields, Checkboxes, and Radio Buttons from the\n Hash passed as an argument. The way it find an element is by\n matching the Hash key to the name you provided when declaring\n the element on your page.\n\n Checkbox and Radio Button values must be true or false.\n\n @example\n class ExamplePage\n include PageObject\n\n text_field(:username, :id => 'username_id')\n checkbox(:active, :id => 'active_id')\n end\n\n ...\n\n @browser = Watir::Browser.new :firefox\n example_page = ExamplePage.new(@browser)\n example_page.populate_page_with :username => 'a name', :active => true\n\n @param data [Hash] the data to use to populate this page. The key\n can be either a string or a symbol. The value must be a string\n for TextField, TextArea, SelectList, and FileField and must be true or\n false for a Checkbox or RadioButton.", "Specify the url for the page. A call to this method will generate a\n 'goto' method to take you to the page.\n\n @param [String] the url for the page.\n @param [Symbol] a method name to call to get the url", "Identify an element as existing within a frame . A frame parameter\n is passed to the block and must be passed to the other calls to PageObject.\n You can nest calls to in_frame by passing the frame to the next level.\n\n @example\n in_frame(:id => 'frame_id') do |frame|\n text_field(:first_name, :id => 'fname', :frame => frame)\n end\n\n @param [Hash] identifier how we find the frame. The valid keys are:\n * :id\n * :index\n * :name\n * :regexp\n @param frame passed from a previous call to in_frame. Used to nest calls\n @param block that contains the calls to elements that exist inside the frame.", "Identify an element as existing within an iframe. A frame parameter\n is passed to the block and must be passed to the other calls to PageObject.\n You can nest calls to in_frame by passing the frame to the next level.\n\n @example\n in_iframe(:id => 'frame_id') do |frame|\n text_field(:first_name, :id => 'fname', :frame => frame)\n end\n\n @param [Hash] identifier how we find the frame. The valid keys are:\n * :id\n * :index\n * :name\n * :regexp\n @param frame passed from a previous call to in_iframe. Used to nest calls\n @param block that contains the calls to elements that exist inside the iframe.", "adds four methods to the page object - one to set text in a text field,\n another to retrieve text from a text field, another to return the text\n field element, another to check the text field's existence.\n\n @example\n text_field(:first_name, :id => \"first_name\")\n # will generate 'first_name', 'first_name=', 'first_name_element',\n # 'first_name?' methods\n\n @param [String] the name used for the generated methods\n @param [Hash] identifier how we find a text field.\n @param optional block to be invoked when element method is called", "adds three methods to the page object - one to get the text from a hidden field,\n another to retrieve the hidden field element, and another to check the hidden\n field's existence.\n\n @example\n hidden_field(:user_id, :id => \"user_identity\")\n # will generate 'user_id', 'user_id_element' and 'user_id?' methods\n\n @param [String] the name used for the generated methods\n @param [Hash] identifier how we find a hidden field.\n @param optional block to be invoked when element method is called", "adds four methods to the page object - one to set text in a text area,\n another to retrieve text from a text area, another to return the text\n area element, and another to check the text area's existence.\n\n @example\n text_area(:address, :id => \"address\")\n # will generate 'address', 'address=', 'address_element',\n # 'address?' methods\n\n @param [String] the name used for the generated methods\n @param [Hash] identifier how we find a text area.\n @param optional block to be invoked when element method is called", "adds five methods - one to select an item in a drop-down,\n another to fetch the currently selected item text, another\n to retrieve the select list element, another to check the\n drop down's existence and another to get all the available options\n to select from.\n\n @example\n select_list(:state, :id => \"state\")\n # will generate 'state', 'state=', 'state_element', 'state?', \"state_options\" methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a select list.\n @param optional block to be invoked when element method is called", "adds three methods - one to click a button, another to\n return the button element, and another to check the button's existence.\n\n @example\n button(:purchase, :id => 'purchase')\n # will generate 'purchase', 'purchase_element', and 'purchase?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a button.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a div,\n another to return the div element, and another to check the div's existence.\n\n @example\n div(:message, :id => 'message')\n # will generate 'message', 'message_element', and 'message?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a div.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a span,\n another to return the span element, and another to check the span's existence.\n\n @example\n span(:alert, :id => 'alert')\n # will generate 'alert', 'alert_element', and 'alert?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a span.\n @param optional block to be invoked when element method is called", "adds three methods - one to return the text for the table, one\n to retrieve the table element, and another to\n check the table's existence.\n\n @example\n table(:cart, :id => 'shopping_cart')\n # will generate a 'cart', 'cart_element' and 'cart?' method\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a table.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a table cell,\n another to return the table cell element, and another to check the cell's\n existence.\n\n @example\n cell(:total, :id => 'total_cell')\n # will generate 'total', 'total_element', and 'total?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a cell.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a table row,\n another to return the table row element, and another to check the row's\n existence.\n\n @example\n row(:sums, :id => 'sum_row')\n # will generate 'sums', 'sums_element', and 'sums?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a cell.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the image element, another to\n check the load status of the image, and another to check the\n image's existence.\n\n @example\n image(:logo, :id => 'logo')\n # will generate 'logo_element', 'logo_loaded?', and 'logo?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find an image.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a list item,\n another to return the list item element, and another to check the list item's\n existence.\n\n @example\n list_item(:item_one, :id => 'one')\n # will generate 'item_one', 'item_one_element', and 'item_one?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a list item.\n @param optional block to be invoked when element method is called", "adds three methods - one to return the text within the unordered\n list, one to retrieve the unordered list element, and another to\n check it's existence.\n\n @example\n unordered_list(:menu, :id => 'main_menu')\n # will generate 'menu', 'menu_element' and 'menu?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find an unordered list.\n @param optional block to be invoked when element method is called", "adds three methods - one to return the text within the ordered\n list, one to retrieve the ordered list element, and another to\n test it's existence.\n\n @example\n ordered_list(:top_five, :id => 'top')\n # will generate 'top_five', 'top_five_element' and 'top_five?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find an ordered list.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h1 element, another to\n retrieve a h1 element, and another to check for it's existence.\n\n @example\n h1(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H1. You can use a multiple parameters\n by combining of any of the following except xpath.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h2 element, another\n to retrieve a h2 element, and another to check for it's existence.\n\n @example\n h2(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H2.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h3 element,\n another to return a h3 element, and another to check for it's existence.\n\n @example\n h3(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H3.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h4 element,\n another to return a h4 element, and another to check for it's existence.\n\n @example\n h4(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H4.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h5 element,\n another to return a h5 element, and another to check for it's existence.\n\n @example\n h5(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H5.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a h6 element,\n another to return a h6 element, and another to check for it's existence.\n\n @example\n h6(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a H6.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a paragraph, another\n to retrieve a paragraph element, and another to check the paragraph's existence.\n\n @example\n paragraph(:title, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a paragraph.\n @param optional block to be invoked when element method is called", "adds three methods - one to set the file for a file field, another to retrieve\n the file field element, and another to check it's existence.\n\n @example\n file_field(:the_file, :id => 'file_to_upload')\n # will generate 'the_file=', 'the_file_element', and 'the_file?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a file_field.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text from a label,\n another to return the label element, and another to check the label's existence.\n\n @example\n label(:message, :id => 'message')\n # will generate 'message', 'message_element', and 'message?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a label.\n @param optional block to be invoked when element method is called", "adds three methods - one to click the area,\n another to return the area element, and another to check the area's existence.\n\n @example\n area(:message, :id => 'message')\n # will generate 'message', 'message_element', and 'message?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find an area.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a b element, another to\n retrieve a b element, and another to check for it's existence.\n\n @example\n b(:bold, :id => 'title')\n # will generate 'bold', 'bold_element', and 'bold?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a b.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of a i element, another to\n retrieve a i element, and another to check for it's existence.\n\n @example\n i(:italic, :id => 'title')\n # will generate 'italic', 'italic_element', and 'italic?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Hash] identifier how we find a i.\n @param optional block to be invoked when element method is called", "adds three methods - one to retrieve the text of an element, another\n to retrieve an element, and another to check the element's existence.\n\n @example\n element(:title, :header, :id => 'title')\n # will generate 'title', 'title_element', and 'title?' methods\n\n @param [Symbol] the name used for the generated methods\n @param [Symbol] the name of the tag for the element\n @param [Hash] identifier how we find an element.\n @param optional block to be invoked when element method is called", "adds a method to return a collection of generic Element objects\n for a specific tag.\n\n @example\n elements(:title, :header, :id => 'title')\n # will generate ''title_elements'\n\n @param [Symbol] the name used for the generated methods\n @param [Symbol] the name of the tag for the element\n @param [Hash] identifier how we find an element.\n @param optional block to be invoked when element method is called", "adds a method to return a page object rooted at an element\n\n @example\n page_section(:navigation_bar, NavigationBar, :id => 'nav-bar')\n # will generate 'navigation_bar'\n\n @param [Symbol] the name used for the generated methods\n @param [Class] the class to instantiate for the element\n @param [Hash] identifier how we find an element.", "adds a method to return a collection of page objects rooted at elements\n\n @example\n page_sections(:articles, Article, :class => 'article')\n # will generate 'articles'\n\n @param [Symbol] the name used for the generated method\n @param [Class] the class to instantiate for each element\n @param [Hash] identifier how we find an element.", "Create a page object.\n\n @param [PageObject, String] a class that has included the PageObject module or a string containing the name of the class\n @param Hash values that is pass through to page class a\n available in the @params instance variable.\n @param [Boolean] a boolean indicating if the page should be visited? default is false.\n @param [block] an optional block to be called\n @return [PageObject] the newly created page object", "Create a page object if and only if the current page is the same page to be created\n\n @param [PageObject, String] a class that has included the PageObject module or a string containing the name of the class\n @param Hash values that is pass through to page class a\n available in the @params instance variable.\n @param [block] an optional block to be called\n @return [PageObject] the newly created page object", "Handles requests for Hash values. Others cause an Exception to be raised.\n @param [Symbol|String] m method symbol\n @return [Boolean] the value of the specified instance variable.\n @raise [ArgumentError] if an argument is given. Zero arguments expected.\n @raise [NoMethodError] if the instance variable is not defined.", "Process `css` and return result.\n\n Options can be:\n * `from` with input CSS file name. Will be used in error messages.\n * `to` with output CSS file name.\n * `map` with true to generate new source map or with previous map.", "Parse Browserslist config", "Convert ruby_options to jsOptions", "Try to find Browserslist config", "Lazy load for JS library", "Cache autoprefixer.js content", "Construct a new record\n\n licenses - a string, or array of strings, representing the content of each license\n notices - a string, or array of strings, representing the content of each legal notice\n metadata - a Hash of the metadata for the package\n Save the metadata and text to a file\n\n filename - The destination file to save record contents at", "Returns the license text content from all matched sources\n except the package file, which doesn't contain license text.", "Returns legal notices found at the dependency path", "Returns the sources for a group of license file contents\n\n Sources are returned as a single string with sources separated by \", \"", "Returns an array of enabled app sources", "Returns whether a source type is enabled", "Authenticate a record using cookies. Looks for a cookie corresponding to\n the _authenticatable_class_. If found try to find it in the database.\n @param authenticatable_class [ActiveRecord::Base] any Model connected to\n passwordless. (e.g - _User_ or _Admin_).\n @return [ActiveRecord::Base|nil] an instance of Model found by id stored\n in cookies.encrypted or nil if nothing is found.\n @see ModelHelpers#passwordless_with", "Signs in user by assigning their id to a permanent cookie.\n @param authenticatable [ActiveRecord::Base] Instance of Model to sign in\n (e.g - @user when @user = User.find(id: some_id)).\n @return [ActiveRecord::Base] the record that is passed in.", "Signs out user by deleting their encrypted cookie.\n @param (see #authenticate_by_cookie)\n @return [boolean] Always true", "Sends an arbitrary count for the given stat to the statsd server.\n\n @param [String] stat stat name\n @param [Integer] count count\n @param [Hash] opts the options to create the metric with\n @option opts [Numeric] :sample_rate sample rate, 1 for always\n @option opts [Array] :tags An array of tags", "Sends an arbitary gauge value for the given stat to the statsd server.\n\n This is useful for recording things like available disk space,\n memory usage, and the like, which have different semantics than\n counters.\n\n @param [String] stat stat name.\n @param [Numeric] value gauge value.\n @param [Hash] opts the options to create the metric with\n @option opts [Numeric] :sample_rate sample rate, 1 for always\n @option opts [Array] :tags An array of tags\n @example Report the current user count:\n $statsd.gauge('user.count', User.count)", "Sends a value to be tracked as a histogram to the statsd server.\n\n @param [String] stat stat name.\n @param [Numeric] value histogram value.\n @param [Hash] opts the options to create the metric with\n @option opts [Numeric] :sample_rate sample rate, 1 for always\n @option opts [Array] :tags An array of tags\n @example Report the current user count:\n $statsd.histogram('user.count', User.count)", "Sends a value to be tracked as a set to the statsd server.\n\n @param [String] stat stat name.\n @param [Numeric] value set value.\n @param [Hash] opts the options to create the metric with\n @option opts [Numeric] :sample_rate sample rate, 1 for always\n @option opts [Array] :tags An array of tags\n @example Record a unique visitory by id:\n $statsd.set('visitors.uniques', User.id)", "This method allows you to send custom service check statuses.\n\n @param [String] name Service check name\n @param [String] status Service check status.\n @param [Hash] opts the additional data about the service check\n @option opts [Integer, nil] :timestamp (nil) Assign a timestamp to the event. Default is now when none\n @option opts [String, nil] :hostname (nil) Assign a hostname to the event.\n @option opts [Array, nil] :tags (nil) An array of tags\n @option opts [String, nil] :message (nil) A message to associate with this service check status\n @example Report a critical service check status\n $statsd.service_check('my.service.check', Statsd::CRITICAL, :tags=>['urgent'])", "This end point allows you to post events to the stream. You can tag them, set priority and even aggregate them with other events.\n\n Aggregation in the stream is made on hostname/event_type/source_type/aggregation_key.\n If there's no event type, for example, then that won't matter;\n it will be grouped with other events that don't have an event type.\n\n @param [String] title Event title\n @param [String] text Event text. Supports newlines (+\\n+)\n @param [Hash] opts the additional data about the event\n @option opts [Integer, nil] :date_happened (nil) Assign a timestamp to the event. Default is now when none\n @option opts [String, nil] :hostname (nil) Assign a hostname to the event.\n @option opts [String, nil] :aggregation_key (nil) Assign an aggregation key to the event, to group it with some others\n @option opts [String, nil] :priority ('normal') Can be \"normal\" or \"low\"\n @option opts [String, nil] :source_type_name (nil) Assign a source type to the event\n @option opts [String, nil] :alert_type ('info') Can be \"error\", \"warning\", \"info\" or \"success\".\n @option opts [Array] :tags tags to be added to every metric\n @example Report an awful event:\n $statsd.event('Something terrible happened', 'The end is near if we do nothing', :alert_type=>'warning', :tags=>['end_of_times','urgent'])", "For every `redirect_from` entry, generate a redirect page", "Helper function to set the appropriate path metadata\n\n from - the relative path to the redirect page\n to - the relative path or absolute URL to the redirect target", "Compile some ruby code to a string.\n\n @return [String] javascript code", "Used to generate a unique id name per file. These are used\n mainly to name method bodies for methods that use blocks.", "Process the given sexp by creating a node instance, based on its type,\n and compiling it to fragments.", "The last sexps in method bodies, for example, need to be returned\n in the compiled javascript. Due to syntax differences between\n javascript any ruby, some sexps need to be handled specially. For\n example, `if` statemented cannot be returned in javascript, so\n instead the \"truthy\" and \"falsy\" parts of the if statement both\n need to be returned instead.\n\n Sexps that need to be returned are passed to this method, and the\n alterned/new sexps are returned and should be used instead. Most\n sexps can just be added into a `s(:return) sexp`, so that is the\n default action if no special case is required.", "This method is called when a parse error is found.\n\n ERROR_TOKEN_ID is an internal ID of token which caused error.\n You can get string representation of this ID by calling\n #token_to_str.\n\n ERROR_VALUE is a value of error token.\n\n value_stack is a stack of symbol values.\n DO NOT MODIFY this object.\n\n This method raises ParseError by default.\n\n If this method returns, parsers enter \"error recovering mode\".", "For debugging output", "Returns a new Tms object obtained by memberwise operation +op+\n of the individual times for this Tms object with those of the other\n Tms object.\n\n +op+ can be a mathematical operation such as + , - ,\n * , / ", "Defines a new configuration option\n\n @param [String] name the option name\n @param [Object] default_value the option's default value\n @!macro [attach] property\n @!attribute [rw] $1", "Reads and returns Float from an input stream\n\n @example\n 123.456\n Is encoded as\n 'f', '123.456'", "Reads and returns Bignum from an input stream", "Reads and returns Regexp from an input stream\n\n @example\n r = /regexp/mix\n is encoded as\n '/', 'regexp', r.options.chr", "Reads and returns a Struct from an input stream\n\n @example\n Point = Struct.new(:x, :y)\n Point.new(100, 200)\n is encoded as\n 'S', :Point, {:x => 100, :y => 200}", "Reads and returns a Class from an input stream\n\n @example\n String\n is encoded as\n 'c', 'String'", "Reads and returns a Module from an input stream\n\n @example\n Kernel\n is encoded as\n 'm', 'Kernel'", "Reads and returns an abstract object from an input stream\n\n @example\n obj = Object.new\n obj.instance_variable_set(:@ivar, 100)\n obj\n is encoded as\n 'o', :Object, {:@ivar => 100}\n\n The only exception is a Range class (and its subclasses)\n For some reason in MRI isntances of this class have instance variables\n - begin\n - end\n - excl\n without '@' perfix.", "Reads an object that was dynamically extended before marshaling like\n\n @example\n M1 = Module.new\n M2 = Module.new\n obj = Object.new\n obj.extend(M1)\n obj.extend(M2)\n obj\n is encoded as\n 'e', :M2, :M1, obj", "Collects object allocation and memory of ruby code inside of passed block.", "Iterates through objects in memory of a given generation.\n Stores results along with meta data of objects collected.", "Output the results of the report\n @param [Hash] options the options for output\n @option opts [String] :to_file a path to your log file\n @option opts [Boolean] :color_output a flag for whether to colorize output\n @option opts [Integer] :retained_strings how many retained strings to print\n @option opts [Integer] :allocated_strings how many allocated strings to print\n @option opts [Boolean] :detailed_report should report include detailed information\n @option opts [Boolean] :scale_bytes calculates unit prefixes for the numbers of bytes", "Copy from origin to destination in chunks of size `stride`.\n Use the `throttler` class to sleep between each stride.", "Rename an existing column.\n\n @example\n\n Lhm.change_table(:users) do |m|\n m.rename_column(:login, :username)\n end\n\n @param [String] old Name of the column to change\n @param [String] nu New name to use for the column", "Remove an index from a table\n\n @example\n\n Lhm.change_table(:users) do |m|\n m.remove_index(:comment)\n m.remove_index([:username, :created_at])\n end\n\n @param [String, Symbol, Array] columns\n A column name given as String or Symbol. An Array of Strings or Symbols\n for compound indexes.\n @param [String, Symbol] index_name\n Optional name of the index to be removed", "Set up the queues for each of the worker's consumers.", "Bind a consumer's routing keys to its queue, and set up a subscription to\n receive messages sent to the queue.", "Called internally when a new messages comes in from RabbitMQ. Responsible\n for wrapping up the message and passing it to the consumer.", "Set up the connection to the RabbitMQ management API. Unfortunately, this\n is necessary to do a few things that are impossible over AMQP. E.g.\n listing queues and bindings.", "Return a mapping of queue names to the routing keys they're bound to.", "Find the existing bindings, and unbind any redundant bindings", "Bind a queue to the broker's exchange on the routing keys provided. Any\n existing bindings on the queue that aren't present in the array of\n routing keys will be unbound.", "Run a Hutch worker with the command line interface.", "Returns true if the bounds contain the passed point.\n allows for bounds which cross the meridian", "Returns a comma-delimited string consisting of the street address, city,\n state, zip, and country code. Only includes those attributes that are\n non-blank.", "Builds nested hash structure using the scope returned from the passed in scope", "Find or create a descendant node whose +ancestry_path+ will be ```self.ancestry_path + path```", "Uses Rails auto_link to add links to fields\n\n @param field [String,Hash] string to format and escape, or a hash as per helper_method\n @option field [SolrDocument] :document\n @option field [String] :field name of the solr field\n @option field [Blacklight::Configuration::IndexField, Blacklight::Configuration::ShowField] :config\n @option field [Array] :value array of values for the field\n @param show_link [Boolean]\n @return [ActiveSupport::SafeBuffer]\n @todo stop being a helper_method, start being part of the Blacklight render stack?", "Returns an array of users sorted by the date of their last stats update. Users that have not been recently updated\n will be at the top of the array.", "This method never fails. It tries multiple times and finally logs the exception", "Removes a single lease", "Compute the sum of each file in the collection using Solr to\n avoid having to access Fedora\n\n @return [Fixnum] size of collection in bytes\n @raise [RuntimeError] unsaved record does not exist in solr", "Calculate the size of all the files in the work\n @param work_id [String] identifer for a work\n @return [Integer] the size in bytes", "This performs a two pass query, first getting the AdminSets\n and then getting the work and file counts\n @param [Symbol] access :read or :edit\n @param join_field [String] how are we joining the admin_set ids (by default \"isPartOf_ssim\")\n @return [Array] a list with document, then work and file count", "Count number of files from admin set works\n @param [Array] AdminSets to count files in\n @return [Hash] admin set id keys and file count values", "Registers the given curation concern model in the configuration\n @param [Array,Symbol] curation_concern_types", "Return AdminSet selectbox options based on access type\n @param [Symbol] access :deposit, :read, or :edit", "Create a hash of HTML5 'data' attributes. These attributes are added to select_options and\n later utilized by Javascript to limit new Work options based on AdminSet selected", "Does the workflow for the currently selected permission template allow sharing?", "Handle the HTTP show request", "render an HTTP Range response", "Creates an admin set, setting the creator and the default access controls.\n @return [TrueClass, FalseClass] true if it was successful", "Gives deposit access to registered users to default AdminSet", "Given a deeply nested hash, return a single hash", "These are the file sets that belong to this work, but not necessarily\n in order.\n Arbitrarily maxed at 10 thousand; had to specify rows due to solr's default of 10", "Namespaces routes appropriately\n @example namespaced_resources(\"hyrax/my_work\") is equivalent to\n namespace \"hyrax\", path: :concern do\n resources \"my_work\", except: [:index]\n end", "IIIF metadata for inclusion in the manifest\n Called by the `iiif_manifest` gem to add metadata\n\n @return [Array] array of metadata hashes", "list of item ids to display is based on ordered_ids", "Uses kaminari to paginate an array to avoid need for solr documents for items here", "add hidden fields to a form for performing an action on a single document on a collection", "Finds a solr document matching the id and sets @presenter\n @raise CanCan::AccessDenied if the document is not found or the user doesn't have access to it.", "Only returns unsuppressed documents the user has read access to", "Add uploaded_files to the parameters received by the actor.", "Build a rendering hash\n\n @return [Hash] rendering", "For use with javascript user selector that allows for searching for an existing user\n and granting them permission to an object.\n @param [User] user to select\n @param [String] role granting the user permission (e.g. 'Manager' | 'Depositor' | 'Viewer')", "For use with javascript collection selector that allows for searching for an existing collection from works relationship tab.\n Adds the collection and validates that the collection is listed in the Collection Relationship table once added.\n @param [Collection] collection to select", "For use with javascript collection selector that allows for searching for an existing collection from add to collection modal.\n Does not save the selection. The calling test is expected to click Save and validate the collection membership was added to the work.\n @param [Collection] collection to select", "Creates a display image only where FileSet is an image.\n\n @return [IIIFManifest::DisplayImage] the display image required by the manifest builder.", "Retrieve or generate the fixity check for a specific version of a file\n @param [String] file_id used to find the file within its parent object (usually \"original_file\")\n @param [String] version_uri the version to be fixity checked (or the file uri for non-versioned files)", "Check if time since the last fixity check is greater than the maximum days allowed between fixity checks\n @param [ChecksumAuditLog] latest_fixity_check the most recent fixity check", "Removes a single embargo", "Updates a batch of embargos", "Write the workflow roles and state so one can see where the document moves to next\n @param [Hash] solr_document the solr document to add the field to", "Give workflow responsibilites to the provided agents for the given role\n @param [Sipity::Role] role\n @param [Array] agents", "Find any workflow_responsibilities held by agents not in the allowed_agents\n and remove them\n @param [Sipity::Role] role\n @param [Array] allowed_agents", "Present the attribute as an HTML table row or dl row.\n\n @param [Hash] options\n @option options [Symbol] :render_as use an alternate renderer\n (e.g., :linked or :linked_attribute to use LinkedAttributeRenderer)\n @option options [String] :search_field If the method_name of the attribute is different than\n how the attribute name should appear on the search URL,\n you can explicitly set the URL's search field name\n @option options [String] :label The default label for the field if no translation is found\n @option options [TrueClass, FalseClass] :include_empty should we display a row if there are no values?\n @option options [String] :work_type name of work type class (e.g., \"GenericWork\")", "We're overiding the default indexer in order to index the RDF labels. In order\n for this to be called, you must specify at least one default indexer on the property.\n @param [Hash] solr_doc\n @param [String] solr_field_key\n @param [Hash] field_info\n @param [ActiveTriples::Resource, String] val", "Grab the labels for controlled properties from the remote sources", "Use this method to append a string value from a controlled vocabulary field\n to the solr document. It just puts a copy into the corresponding label field\n @param [Hash] solr_doc\n @param [String] solr_field_key\n @param [Hash] field_info\n @param [String] val", "includes the depositor_facet to get information on deposits.\n use caution when combining this with other searches as it sets the rows to\n zero to just get the facet information\n @param solr_parameters the current solr parameters", "Display user profile", "Query solr using POST so that the query doesn't get too large for a URI", "Adds a value to the end of a list identified by key", "Roll up messages for an operation and all of its children", "Mark this operation as a FAILURE. If this is a child operation, roll up to\n the parent any failures.\n\n @param [String, nil] message record any failure message\n @see Hyrax::Operation::FAILURE\n @see #rollup_status\n @note This will run any registered :failure callbacks\n @todo Where are these callbacks defined? Document this", "Sets the operation status to PENDING\n @param [#class, #job_id] job - The job associated with this operation\n @see Hyrax::Operation::PENDING", "Renders a JSON response with a list of files in this admin set.\n This is used by the edit form to populate the thumbnail_id dropdown", "In the context of a Valkyrie resource, prefer to use the id if it\n is provided and fallback to the first of the alternate_ids. If all else fails\n then the id hasn't been minted and shouldn't yet be set.\n @return [String]", "Add attributes from resource which aren't AF properties into af_object", "For the Managed Collections tab, determine the label to use for the level of access the user has for this admin set.\n Checks from most permissive to most restrictive.\n @return String the access label (e.g. Manage, Deposit, View)", "Return the Global Identifier for this collection type.\n @return [String] Global Identifier (gid) for this collection_type (e.g. gid://internal/hyrax-collectiontype/3)", "Override release_date getter to return a dynamically calculated date of release\n based one release requirements. Returns embargo date when release_max_embargo?==true.\n Returns today's date when release_no_delay?==true.\n @see Hyrax::AdminSetService for usage", "Grant all users with read or edit access permission to download", "We check based on the depositor, because the depositor may not have edit\n access to the work if it went through a mediated deposit workflow that\n removes edit access for the depositor.", "Returns true if the current user is the depositor of the specified work\n @param document_id [String] the id of the document.", "Returns an array of characterization values truncated to 250 characters limited\n to the maximum number of configured values.\n @param [Symbol] term found in the characterization_metadata hash\n @return [Array] of truncated values", "Returns an array of characterization values truncated to 250 characters that are in\n excess of the maximum number of configured values.\n @param [Symbol] term found in the characterization_metadata hash\n @return [Array] of truncated values", "Retrieve search results of the given object type\n\n Permissions: (for people search only) r_network\n\n @note People Search API is a part of the Vetted API Access Program. You\n must apply and get approval before using this API\n\n @see http://developer.linkedin.com/documents/people-search-api People Search\n @see http://developer.linkedin.com/documents/job-search-api Job Search\n @see http://developer.linkedin.com/documents/company-search Company Search\n\n @param [Hash] options search input fields\n @param [String] type type of object to return ('people', 'job' or 'company')\n @return [LinkedIn::Mash]", "Convert the 'timestamp' field from a string to a Time object\n\n @return [Time]", "this skips manifests sometimes because it doesn't look at file\n contents and can't establish from only regexes that the thing\n is a manifest. We exclude rather than include ambiguous filenames\n because this API is used by libraries.io and we don't want to\n download all .xml files from GitHub.", "Returns the object in the form of hash\n @return [Hash] Returns the object in the form of hash", "Outputs non-array value in the form of hash\n For object, use to_hash. Otherwise, just return the value\n @param [Object] value Any valid value\n @return [Hash] Returns the value in the form of hash", "Extract batch_token from Link header if present\n @param [Hash] headers hash with response headers\n @return [String] batch_token or nil if no token is present", "ListCashDrawerShifts\n Provides the details for all of a location's cash drawer shifts during a date range. The date range you specify cannot exceed 90 days.\n @param location_id The ID of the location to list cash drawer shifts for.\n @param [Hash] opts the optional parameters\n @option opts [String] :order The order in which cash drawer shifts are listed in the response, based on their created_at field. Default value: ASC\n @option opts [String] :begin_time The beginning of the requested reporting period, in ISO 8601 format. Default value: The current time minus 90 days.\n @option opts [String] :end_time The beginning of the requested reporting period, in ISO 8601 format. Default value: The current time.\n @return [Array]", "RetrieveCashDrawerShift\n Provides the details for a single cash drawer shift, including all events that occurred during the shift.\n @param location_id The ID of the location to list cash drawer shifts for.\n @param shift_id The shift's ID.\n @param [Hash] opts the optional parameters\n @return [V1CashDrawerShift]", "RetrieveEmployee\n Provides the details for a single employee.\n @param employee_id The employee's ID.\n @param [Hash] opts the optional parameters\n @return [V1Employee]", "RetrieveEmployeeRole\n Provides the details for a single employee role.\n @param role_id The role's ID.\n @param [Hash] opts the optional parameters\n @return [V1EmployeeRole]", "UpdateEmployeeRole\n Modifies the details of an employee role.\n @param role_id The ID of the role to modify.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1EmployeeRole]", "UpdateTimecard\n Modifies the details of a timecard with an `API_EDIT` event for the timecard. Updating an active timecard with a `clockout_time` clocks the employee out.\n @param timecard_id TThe ID of the timecard to modify.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Timecard]", "CreateCustomerCard\n Adds a card on file to an existing customer. As with charges, calls to `CreateCustomerCard` are idempotent. Multiple calls with the same card nonce return the same card record that was created with the provided nonce during the _first_ call. Cards on file are automatically updated on a monthly basis to confirm they are still valid and can be charged.\n @param customer_id The ID of the customer to link the card on file to.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [CreateCustomerCardResponse]", "DeleteCustomer\n Deletes a customer from a business, along with any linked cards on file. When two profiles are merged into a single profile, that profile is assigned a new `customer_id`. You must use the new `customer_id` to delete merged profiles.\n @param customer_id The ID of the customer to delete.\n @param [Hash] opts the optional parameters\n @return [DeleteCustomerResponse]", "DeleteCustomerCard\n Removes a card on file from a customer.\n @param customer_id The ID of the customer that the card on file belongs to.\n @param card_id The ID of the card on file to delete.\n @param [Hash] opts the optional parameters\n @return [DeleteCustomerCardResponse]", "RetrieveCustomer\n Returns details for a single customer.\n @param customer_id The ID of the customer to retrieve.\n @param [Hash] opts the optional parameters\n @return [RetrieveCustomerResponse]", "SearchCustomers\n Searches the customer profiles associated with a Square account. Calling SearchCustomers without an explicit query parameter returns all customer profiles ordered alphabetically based on `given_name` and `family_name`.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [SearchCustomersResponse]", "AdjustInventory\n Adjusts an item variation's current available inventory.\n @param location_id The ID of the item's associated location.\n @param variation_id The ID of the variation to adjust inventory information for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1InventoryEntry]", "ApplyFee\n Associates a fee with an item, meaning the fee is automatically applied to the item in Square Register.\n @param location_id The ID of the fee's associated location.\n @param item_id The ID of the item to add the fee to.\n @param fee_id The ID of the fee to apply.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "ApplyModifierList\n Associates a modifier list with an item, meaning modifier options from the list can be applied to the item.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The ID of the modifier list to apply.\n @param item_id The ID of the item to add the modifier list to.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "CreateCategory\n Creates an item category.\n @param location_id The ID of the location to create an item for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Category]", "CreateDiscount\n Creates a discount.\n @param location_id The ID of the location to create an item for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Discount]", "CreateItem\n Creates an item and at least one variation for it. Item-related entities include fields you can use to associate them with entities in a non-Square system. When you create an item-related entity, you can optionally specify its `id`. This value must be unique among all IDs ever specified for the account, including those specified by other applications. You can never reuse an entity ID. If you do not specify an ID, Square generates one for the entity. Item variations have a `user_data` string that lets you associate arbitrary metadata with the variation. The string cannot exceed 255 characters.\n @param location_id The ID of the location to create an item for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "CreateModifierList\n Creates an item modifier list and at least one modifier option for it.\n @param location_id The ID of the location to create a modifier list for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1ModifierList]", "CreateModifierOption\n Creates an item modifier option and adds it to a modifier list.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The ID of the modifier list to edit.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1ModifierOption]", "CreatePage\n Creates a Favorites page in Square Register.\n @param location_id The ID of the location to create an item for.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Page]", "CreateVariation\n Creates an item variation for an existing item.\n @param location_id The ID of the item's associated location.\n @param item_id The item's ID.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Variation]", "ListCategories\n Lists all of a location's item categories.\n @param location_id The ID of the location to list categories for.\n @param [Hash] opts the optional parameters\n @return [Array]", "ListDiscounts\n Lists all of a location's discounts.\n @param location_id The ID of the location to list categories for.\n @param [Hash] opts the optional parameters\n @return [Array]", "ListInventory\n Provides inventory information for all of a merchant's inventory-enabled item variations.\n @param location_id The ID of the item's associated location.\n @param [Hash] opts the optional parameters\n @option opts [Integer] :limit The maximum number of inventory entries to return in a single response. This value cannot exceed 1000.\n @option opts [String] :batch_token A pagination cursor to retrieve the next set of results for your original query to the endpoint.\n @return [Array]", "ListItems\n Provides summary information for all of a location's items.\n @param location_id The ID of the location to list items for.\n @param [Hash] opts the optional parameters\n @option opts [String] :batch_token A pagination cursor to retrieve the next set of results for your original query to the endpoint.\n @return [Array]", "ListModifierLists\n Lists all of a location's modifier lists.\n @param location_id The ID of the location to list modifier lists for.\n @param [Hash] opts the optional parameters\n @return [Array]", "ListPages\n Lists all of a location's Favorites pages in Square Register.\n @param location_id The ID of the location to list Favorites pages for.\n @param [Hash] opts the optional parameters\n @return [Array]", "RemoveFee\n Removes a fee assocation from an item, meaning the fee is no longer automatically applied to the item in Square Register.\n @param location_id The ID of the fee's associated location.\n @param item_id The ID of the item to add the fee to.\n @param fee_id The ID of the fee to apply.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "RemoveModifierList\n Removes a modifier list association from an item, meaning modifier options from the list can no longer be applied to the item.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The ID of the modifier list to remove.\n @param item_id The ID of the item to remove the modifier list from.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "RetrieveItem\n Provides the details for a single item, including associated modifier lists and fees.\n @param location_id The ID of the item's associated location.\n @param item_id The item's ID.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "RetrieveModifierList\n Provides the details for a single modifier list.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The modifier list's ID.\n @param [Hash] opts the optional parameters\n @return [V1ModifierList]", "UpdateCategory\n Modifies the details of an existing item category.\n @param location_id The ID of the category's associated location.\n @param category_id The ID of the category to edit.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Category]", "UpdateDiscount\n Modifies the details of an existing discount.\n @param location_id The ID of the category's associated location.\n @param discount_id The ID of the discount to edit.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Discount]", "UpdateItem\n Modifies the core details of an existing item.\n @param location_id The ID of the item's associated location.\n @param item_id The ID of the item to modify.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Item]", "UpdateModifierList\n Modifies the details of an existing item modifier list.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The ID of the modifier list to edit.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1ModifierList]", "UpdateModifierOption\n Modifies the details of an existing item modifier option.\n @param location_id The ID of the item's associated location.\n @param modifier_list_id The ID of the modifier list to edit.\n @param modifier_option_id The ID of the modifier list to edit.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1ModifierOption]", "UpdatePage\n Modifies the details of a Favorites page in Square Register.\n @param location_id The ID of the Favorites page's associated location\n @param page_id The ID of the page to modify.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Page]", "UpdatePageCell\n Modifies a cell of a Favorites page in Square Register.\n @param location_id The ID of the Favorites page's associated location.\n @param page_id The ID of the page the cell belongs to.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Page]", "UpdateVariation\n Modifies the details of an existing item variation.\n @param location_id The ID of the item's associated location.\n @param item_id The ID of the item to modify.\n @param variation_id The ID of the variation to modify.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [V1Variation]", "DeleteBreakType\n Deletes an existing `BreakType`. A `BreakType` can be deleted even if it is referenced from a `Shift`.\n @param id UUID for the `BreakType` being deleted.\n @param [Hash] opts the optional parameters\n @return [DeleteBreakTypeResponse]", "DeleteShift\n Deletes a `Shift`.\n @param id UUID for the `Shift` being deleted.\n @param [Hash] opts the optional parameters\n @return [DeleteShiftResponse]", "GetBreakType\n Returns a single `BreakType` specified by id.\n @param id UUID for the `BreakType` being retrieved.\n @param [Hash] opts the optional parameters\n @return [GetBreakTypeResponse]", "GetEmployeeWage\n Returns a single `EmployeeWage` specified by id.\n @param id UUID for the `EmployeeWage` being retrieved.\n @param [Hash] opts the optional parameters\n @return [GetEmployeeWageResponse]", "GetShift\n Returns a single `Shift` specified by id.\n @param id UUID for the `Shift` being retrieved.\n @param [Hash] opts the optional parameters\n @return [GetShiftResponse]", "UpdateBreakType\n Updates an existing `BreakType`.\n @param id UUID for the `BreakType` being updated.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [UpdateBreakTypeResponse]", "UpdateShift\n Updates an existing `Shift`. When adding a `Break` to a `Shift`, any earlier `Breaks` in the `Shift` have the `end_at` property set to a valid RFC-3339 datetime string. When closing a `Shift`, all `Break` instances in the shift must be complete with `end_at` set on each `Break`.\n @param id ID of the object being updated.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [UpdateShiftResponse]", "UpdateWorkweekConfig\n Updates a `WorkweekConfig`.\n @param id UUID for the `WorkweekConfig` object being updated.\n @param body An object containing the fields to POST for the request. See the corresponding object definition for field details.\n @param [Hash] opts the optional parameters\n @return [UpdateWorkweekConfigResponse]", "RetrieveTransaction\n Retrieves details for a single transaction.\n @param location_id The ID of the transaction's associated location.\n @param transaction_id The ID of the transaction to retrieve.\n @param [Hash] opts the optional parameters\n @return [RetrieveTransactionResponse]", "ListBankAccounts\n Provides non-confidential details for all of a location's associated bank accounts. This endpoint does not provide full bank account numbers, and there is no way to obtain a full bank account number with the Connect API.\n @param location_id The ID of the location to list bank accounts for.\n @param [Hash] opts the optional parameters\n @return [Array]", "ListOrders\n Provides summary information for a merchant's online store orders.\n @param location_id The ID of the location to list online store orders for.\n @param [Hash] opts the optional parameters\n @option opts [String] :order TThe order in which payments are listed in the response.\n @option opts [Integer] :limit The maximum number of payments to return in a single response. This value cannot exceed 200.\n @option opts [String] :batch_token A pagination cursor to retrieve the next set of results for your original query to the endpoint.\n @return [Array]", "RetrieveBankAccount\n Provides non-confidential details for a merchant's associated bank account. This endpoint does not provide full bank account numbers, and there is no way to obtain a full bank account number with the Connect API.\n @param location_id The ID of the bank account's associated location.\n @param bank_account_id The bank account's Square-issued ID. You obtain this value from Settlement objects returned.\n @param [Hash] opts the optional parameters\n @return [V1BankAccount]", "RetrieveOrder\n Provides comprehensive information for a single online store order, including the order's history.\n @param location_id The ID of the order's associated location.\n @param order_id The order's Square-issued ID. You obtain this value from Order objects returned by the List Orders endpoint\n @param [Hash] opts the optional parameters\n @return [V1Order]", "RetrievePayment\n Provides comprehensive information for a single payment.\n @param location_id The ID of the payment's associated location.\n @param payment_id The Square-issued payment ID. payment_id comes from Payment objects returned by the List Payments endpoint, Settlement objects returned by the List Settlements endpoint, or Refund objects returned by the List Refunds endpoint.\n @param [Hash] opts the optional parameters\n @return [V1Payment]", "View helper for rendering many activities", "Adds or redefines a parameter\n @param [Symbol] name\n @param [#call, nil] type (nil)\n @option opts [Proc] :default\n @option opts [Boolean] :optional\n @option opts [Symbol] :as\n @option opts [true, false, :protected, :public, :private] :reader\n @return [self] itself", "Human-readable representation of configured params and options\n @return [String]", "Returns a version of the module with custom settings\n @option settings [Boolean] :undefined\n If unassigned params and options should be treated different from nil\n @return [Dry::Initializer]", "Returns mixin module to be included to target class by hand\n @return [Module]\n @yield proc defining params and options", "class AndroidElements\n Android only.\n Returns a string containing interesting elements.\n The text, content description, and id are returned.\n @param class_name [String] the class name to filter on.\n if false (default) then all classes will be inspected\n @return [String]", "Intended for use with console.\n Inspects and prints the current page.\n Will return XHTML for Web contexts because of a quirk with Nokogiri.\n @option class [Symbol] the class name to filter on. case insensitive include match.\n if nil (default) then all classes will be inspected\n @return [void]", "Find the element of type class_name at matching index.\n @param class_name [String] the class name to find\n @param index [Integer] the index\n @return [Element] the found element of type class_name", "Returns a hash of the driver attributes", "Returns the server's version info\n\n @example\n {\n \"build\" => {\n \"version\" => \"0.18.1\",\n \"revision\" => \"d242ebcfd92046a974347ccc3a28f0e898595198\"\n }\n }\n\n @return [Hash]", "Creates a new global driver and quits the old one if it exists.\n You can customise http_client as the following\n\n Read http://www.rubydoc.info/github/appium/ruby_lib_core/Appium/Core/Device to understand more what the driver\n can call instance methods.\n\n @example\n\n require 'rubygems'\n require 'appium_lib'\n\n # platformName takes a string or a symbol.\n # Start iOS driver\n opts = {\n caps: {\n platformName: :ios,\n app: '/path/to/MyiOS.app'\n },\n appium_lib: {\n wait_timeout: 30\n }\n }\n appium_driver = Appium::Driver.new(opts) #=> return an Appium::Driver instance\n appium_driver.start_driver #=> return an Appium::Core::Base::Driver\n\n @option http_client_ops [Hash] :http_client Custom HTTP Client\n @option http_client_ops [Hash] :open_timeout Custom open timeout for http client.\n @option http_client_ops [Hash] :read_timeout Custom read timeout for http client.\n @return [Selenium::WebDriver] the new global driver", "To ignore error for Espresso Driver", "Returns existence of element.\n\n Example:\n\n exists { button('sign in') } ? puts('true') : puts('false')\n\n @param [Integer] pre_check The amount in seconds to set the\n wait to before checking existence\n @param [Integer] post_check The amount in seconds to set the\n wait to after checking existence\n @yield The block to call\n @return [Boolean]", "Find the last TextField.\n @return [TextField]", "Converts pixel values to window relative values\n\n @example\n\n px_to_window_rel x: 50, y: 150 #=> #", "Search strings.xml's values for target.\n @param target [String] the target to search for in strings.xml values\n @return [Array]", "Search strings.xml's keys for target.\n @param target [String] the target to search for in strings.xml keys\n @return [Array]", "backward compatibility\n Find the first button that contains value or by index.\n @param value [String, Integer] the value to exactly match.\n If int then the button at that index is returned.\n @return [BUTTON]", "Find the last button.\n @return [BUTTON]", "Find the first UIAStaticText|XCUIElementTypeStaticText that contains value or by index.\n @param value [String, Integer] the value to find.\n If int then the UIAStaticText|XCUIElementTypeStaticText at that index is returned.\n @return [UIA_STATIC_TEXT|XCUIELEMENT_TYPE_STATIC_TEXT]", "Scroll to the first element containing target text or description.\n @param text [String] the text or resourceId to search for in the text value and content description\n @param scrollable_index [Integer] the index for scrollable views.\n @return [Element] the element scrolled to", "Prints a string of interesting elements to the console.\n\n @example\n ```ruby\n page class: :UIAButton # filter on buttons\n page class: :UIAButton, window: 1\n ```\n\n @option visible [Symbol] visible value to filter on\n @option class [Symbol] class name to filter on\n\n @return [void]", "Get the element of type class_name at matching index.\n @param class_name [String] the class name to find\n @param index [Integer] the index\n @return [Element]", "predicate - the predicate to evaluate on the main app\n\n visible - if true, only visible elements are returned. default true", "Check every interval seconds to see if yield returns a truthy value.\n Note this isn't a strict boolean true, any truthy value is accepted.\n false and nil are considered failures.\n Give up after timeout seconds.\n\n Wait code from the selenium Ruby gem\n https://github.com/SeleniumHQ/selenium/blob/cf501dda3f0ed12233de51ce8170c0e8090f0c20/rb/lib/selenium/webdriver/common/wait.rb\n\n If only a number is provided then it's treated as the timeout value.\n\n @param [Hash|Numeric] opts Options. If the value is _Numeric_, the value is set as `{ timeout: value }`\n @option opts [Numeric] :timeout Seconds to wait before timing out. Set default by `appium_wait_timeout` (30).\n @option opts [Numeric] :interval Seconds to sleep between polls. Set default by `appium_wait_interval` (0.5).\n @option opts [String] :message Exception message if timed out.\n @option opts [Array, Exception] :ignore Exceptions to ignore while polling (default: Exception)\n\n @example\n\n wait_true(timeout: 20, interval: 0.2, message: 'custom message') { button_exact('Back') }.click\n wait_true(20) { button_exact('Back') }.click", "Find the first EditText that contains value or by index.\n @param value [String, Integer] the text to match exactly.\n If int then the EditText at that index is returned.\n @return [EDIT_TEXT]", "Find the first TextView that contains value or by index.\n @param value [String, Integer] the value to find.\n If int then the TextView at that index is returned.\n @return [TextView]", "Find the first UIAButton|XCUIElementTypeButton that contains value or by index.\n @param value [String, Integer] the value to exactly match.\n If int then the UIAButton|XCUIElementTypeButton at that index is returned.\n @return [UIA_BUTTON|XCUIELEMENT_TYPE_BUTTON]", "Handles extracting elements from the entry", "specifically handles extracting the preconditions for the population criteria", "extracts out any measure observation definitons, creating from them the proper criteria to generate a precondition", "generates the value given in an expression based on the number of criteria it references.", "Get the conjunction code, ALL_TRUE or AT_LEAST_ONE_TRUE\n @return [String] conjunction code", "Check whether the temporal reference should be marked as inclusive", "Check whether the length of stay should be inclusive.", "Check if are only AnyValue elements for low and high", "If a precondition references a population, remove it", "Extracts the measure observations, will return true if one exists", "Builds populations based an a predfined set of expected populations", "Generate the stratifications of populations, if any exist", "Method to generate the criteria defining a population", "if the data criteria is derived from another criteria, then we want to grab the properties from the derived criteria\n this is typically the case with Occurrence A, Occurrence B type data criteria", "source are things like exceptions or exclusions, target are IPP, or denom\n we want to find any denoms or IPPs that do not have exceptions or exclusions", "create a copy of each submeasre adding on the new values of the given type\n skip the unpaired values. Unpaired values are denominators without exclusions or populations without exceptions", "Handles setup of the base values of the document, defined here as ones that are either\n obtained from the xml directly or with limited parsing", "Extracts the code used by a particular attribute", "Extracts the value used by a particular attribute", "For specific occurrence data criteria, make sure the source data criteria reference points\n to the correct source data criteria.", "Set the value and code_list_xpath using the template mapping held in the ValueSetHelper class", "Apply some elements from the reference_criteria to the derived specific occurrence", "grouping data criteria are used to allow a single reference off of a temporal reference or subset operator\n grouping data criteria can reference either regular data criteria as children, or other grouping data criteria", "pull the children data criteria out of a set of preconditions", "this method creates V1 data criteria for the measurement period. These data criteria can be\n referenced properly within the restrictions", "Generate a list of child criterias", "Extracts all subset operators contained in the entry xml", "Preconditions can have nil conjunctions as part of a DATEDIFF, we want to remove these and warn", "Get the source data criteria that are specific occurrences\n @return [Array] an array of HQMF::DataCriteria describing the data elements used by the measure that are specific occurrences", "Get specific attributes by code.\n @param [String] code the attribute code\n @param [String] code_system the attribute code system\n @return [Array#Attribute] the matching attributes, raises an Exception if not found", "patient characteristics data criteria such as GENDER require looking at the codes to determine if the\n measure is interested in Males or Females. This process is awkward, and thus is done as a separate\n step after the document has been converted.", "Given a template id, modify the variables inside this data criteria to reflect the template", "Extracts information from a reference for a specific", "Apply additional information to a specific occurrence's elements from the criteria it references.", "If there is no entry type, extract the entry type from what it references, and extract additional information for\n specific occurrences. If there are no outbound references, print an error and mark it as variable.", "Create grouper data criteria for encapsulating variable data criteria\n and update document data criteria list and references map", "Check elements that do not already exist; else, if they do, check if those elements are the same\n in a different, potentially matching, data criteria", "Handle setting the specific and source instance variables with a given occurrence identifier", "Handles elments that can be extracted directly from the xml. Utilises the \"BaseExtractions\" class.", "Duplicates information from a child element to this data criteria if none exits.\n If the duplication requires that come values should be overwritten, do so only in the function calling this.", "Generate the models of the field values", "Generate the title and description used when producing the model", "class << self", "The URL for this Chef Zero server. If the given host is an IPV6 address,\n it is escaped in brackets according to RFC-2732.\n\n @see http://www.ietf.org/rfc/rfc2732.txt RFC-2732\n\n @return [String]", "Start a Chef Zero server in a forked process. This method returns the PID\n to the forked process.\n\n @param [Fixnum] wait\n the number of seconds to wait for the server to start\n\n @return [Thread]\n the thread the background process is running in", "Gracefully stop the Chef Zero server.\n\n @param [Fixnum] wait\n the number of seconds to wait before raising force-terminating the\n server", "Serializes `data` to JSON and returns an Array with the\n response code, HTTP headers and JSON body.\n\n @param [Fixnum] response_code HTTP response code\n @param [Hash] data The data for the response body as a Hash\n @param [Hash] options\n @option options [Hash] :headers (see #already_json_response)\n @option options [Boolean] :pretty (true) Pretty-format the JSON\n @option options [Fixnum] :request_version (see #already_json_response)\n @option options [Fixnum] :response_version (see #already_json_response)\n\n @return (see #already_json_response)", "Returns an Array with the response code, HTTP headers, and JSON body.\n\n @param [Fixnum] response_code The HTTP response code\n @param [String] json_text The JSON body for the response\n @param [Hash] options\n @option options [Hash] :headers ({}) HTTP headers (may override default headers)\n @option options [Fixnum] :request_version (0) Request API version\n @option options [Fixnum] :response_version (0) Response API version\n\n @return [Array(Fixnum, Hash{String => String}, String)]", "To be called from inside rest endpoints", "Processes SASL connection params and returns a hash with symbol keys or a nil", "Map states to symbols", "Async fetch results from an async execute", "Pull rows from the query result", "Raises an exception if given operation result is a failure", "this will clean up when we officially deprecate", "produces a printf formatter line for an array of items\n if an individual line item is an array, it will create columns\n that are lined-up\n\n line_formatter([\"foo\", \"barbaz\"]) # => \"%-6s\"\n line_formatter([\"foo\", \"barbaz\"], [\"bar\", \"qux\"]) # => \"%-3s %-6s\"", "creates a new StrVal object\n @option options [Array] :data\n @option options [String] :tag_name\n Creates the val objects for this data set. I am not overly confident this is going to play nicely with time and data types.\n @param [Array] values An array of cells or values.", "The relationships for this pivot table.\n @return [Relationships]", "Sets the color for the data bars.\n @param [Color|String] v The color object, or rgb string value to apply", "Serialize this object to an xml string\n @param [String] str\n @return [String]", "Serialize your workbook to disk as an xlsx document.\n\n @param [String] output The name of the file you want to serialize your package to\n @param [Boolean] confirm_valid Validate the package prior to serialization.\n @return [Boolean] False if confirm_valid and validation errors exist. True if the package was serialized\n @note A tremendous amount of effort has gone into ensuring that you cannot create invalid xlsx documents.\n confirm_valid should be used in the rare case that you cannot open the serialized file.\n @see Package#validate\n @example\n # This is how easy it is to create a valid xlsx file. Of course you might want to add a sheet or two, and maybe some data, styles and charts.\n # Take a look at the README for an example of how to do it!\n\n #serialize to a file\n p = Axlsx::Package.new\n # ......add cool stuff to your workbook......\n p.serialize(\"example.xlsx\")\n\n # Serialize to a stream\n s = p.to_stream()\n File.open('example_streamed.xlsx', 'w') { |f| f.write(s.read) }", "Serialize your workbook to a StringIO instance\n @param [Boolean] confirm_valid Validate the package prior to serialization.\n @return [StringIO|Boolean] False if confirm_valid and validation errors exist. rewound string IO if not.", "Writes the package parts to a zip archive.\n @param [Zip::OutputStream] zip\n @return [Zip::OutputStream]", "The parts of a package\n @return [Array] An array of hashes that define the entry, document and schema for each part of the package.\n @private", "Performs xsd validation for a signle document\n\n @param [String] schema path to the xsd schema to be used in validation.\n @param [String] doc The xml text to be validated\n @return [Array] An array of all validation errors encountered.\n @private", "Appends override objects for drawings, charts, and sheets as they exist in your workbook to the default content types.\n @return [ContentType]\n @private", "Creates the minimum content types for generating a valid xlsx document.\n @return [ContentType]\n @private", "Creates the relationships required for a valid xlsx document\n @return [Relationships]\n @private", "sets or updates a hyperlink for this image.\n @param [String] v The href value for the hyper link\n @option options @see Hyperlink#initialize All options available to the Hyperlink class apply - however href will be overridden with the v parameter value.", "noop if not using a two cell anchor\n @param [Integer] x The column\n @param [Integer] y The row\n @return [Marker]", "Changes the anchor to a one cell anchor.", "changes the anchor type to a two cell anchor", "refactoring of swapping code, law of demeter be damned!", "creates a new ColorScale object.\n @see Cfvo\n @see Color\n @example\n color_scale = Axlsx::ColorScale.new({:type => :num, :val => 0.55, :color => 'fff7696c'})\n adds a new cfvo / color pair to the color scale and returns a hash containing\n a reference to the newly created cfvo and color objects so you can alter the default properties.\n @return [Hash] a hash with :cfvo and :color keys referencing the newly added objects.\n @param [Hash] options options for the new cfvo and color objects\n @option [Symbol] type The type of cfvo you to add\n @option [Any] val The value of the cfvo to add\n @option [String] The rgb color for the cfvo", "Serialize this color_scale object data to an xml string\n @param [String] str\n @return [String]", "There has got to be cleaner way of merging these arrays.", "Adds an axis to the collection\n @param [Symbol] name The name of the axis\n @param [Axis] axis_class The axis class to generate", "Creates a new Shared Strings Table agains an array of cells\n @param [Array] cells This is an array of all of the cells in the workbook\n @param [Symbol] xml_space The xml:space behavior for the shared string table.\n Serializes the object\n @param [String] str\n @return [String]", "Interate over all of the cells in the array.\n if our unique cells array does not contain a sharable cell,\n add the cell to our unique cells array and set the ssti attribute on the index of this cell in the shared strings table\n if a sharable cell already exists in our unique_cells array, set the ssti attribute of the cell and move on.\n @return [Array] unique cells", "seralize the collection of hyperlinks\n @return [String]", "A quick helper to retrive a worksheet by name\n @param [String] name The name of the sheet you are looking for\n @return [Worksheet] The sheet found, or nil", "inserts a worksheet into this workbook at the position specified.\n It the index specified is out of range, the worksheet will be added to the end of the\n worksheets collection\n @return [Worksheet]\n @param index The zero based position to insert the newly created worksheet\n @param [Hash] options Options to pass into the worksheed during initialization.\n @option options [String] name The name of the worksheet\n @option options [Hash] page_margins The page margins for the worksheet", "The workbook relationships. This is managed automatically by the workbook\n @return [Relationships]", "returns a range of cells in a worksheet\n @param [String] cell_def The excel style reference defining the worksheet and cells. The range must specify the sheet to\n retrieve the cells from. e.g. range('Sheet1!A1:B2') will return an array of four cells [A1, A2, B1, B2] while range('Sheet1!A1') will return a single Cell.\n @return [Cell, Array]", "Serialize the workbook\n @param [String] str\n @return [String]", "Set some or all margins at once.\n @param [Hash] margins the margins to set (possible keys are :left, :right, :top, :bottom, :header and :footer).", "shortcut to set the column, row position for this marker\n @param col the column for the marker, a Cell object or a string reference like \"B7\"\n or an Array.\n @param row the row of the marker. This is ignored if the col parameter is a Cell or\n String or Array.", "handles multiple inputs for setting the position of a marker\n @see Chart#start_at", "Creates a new Comments object\n @param [Worksheet] worksheet The sheet that these comments belong to.\n Adds a new comment to the worksheet that owns these comments.\n @note the author, text and ref options are required\n @option options [String] author The name of the author for this comment\n @option options [String] text The text for this comment\n @option options [Stirng|Cell] ref The cell that this comment is attached to.", "Tries to work out the width of the longest line in the run\n @param [Array] widtharray this array is populated with the widths of each line in the run.\n @return [Array]", "Serializes the RichTextRun\n @param [String] str\n @return [String]", "Returns the width of a string according to the current style\n This is still not perfect...\n - scaling is not linear as font sizes increase", "we scale the font size if bold style is applied to either the style font or\n the cell itself. Yes, it is a bit of a hack, but it is much better than using\n imagemagick and loading metrics for every character.", "validates that the value provided is between 0.0 and 1.0", "Serialize the contenty type to xml", "serialize the conditional formattings", "Initalize the simple typed list of value objects\n I am keeping this private for now as I am not sure what impact changes to the required two cfvo objects will do.", "Creates a byte string for this storage\n @return [String]", "Sets the col_id attribute for this filter column.\n @param [Integer | Cell] column_index The zero based index of the column to which this filter applies.\n When you specify a cell, the column index will be read off the cell\n @return [Integer]", "Apply the filters for this column\n @param [Array] row A row from a worksheet that needs to be\n filtered.", "Serialize the sheet data\n @param [String] str the string this objects serializaton will be concacted to.\n @return [String]", "creates the DefinedNames object\n Serialize to xml\n @param [String] str\n @return [String]", "Add a ConditionalFormattingRule. If a hash of options is passed\n in create a rule on the fly.\n @param [ConditionalFormattingRule|Hash] rule A rule to use, or the options necessary to create one.\n @see ConditionalFormattingRule#initialize", "Serializes the conditional formatting element\n @example Conditional Formatting XML looks like:\n \n \n 0.5 \n \n \n @param [String] str\n @return [String]", "Specify the degree of label rotation to apply to labels\n default true", "The title object for the chart.\n @param [String, Cell] v\n @return [Title]", "Initalizes page margin, setup and print options\n @param [Hash] options Options passed in from the initializer", "Add conditional formatting to this worksheet.\n\n @param [String] cells The range to apply the formatting to\n @param [Array|Hash] rules An array of hashes (or just one) to create Conditional formatting rules from.\n @example This would format column A whenever it is FALSE.\n # for a longer example, see examples/example_conditional_formatting.rb (link below)\n worksheet.add_conditional_formatting( \"A1:A1048576\", { :type => :cellIs, :operator => :equal, :formula => \"FALSE\", :dxfId => 1, :priority => 1 }\n\n @see ConditionalFormattingRule#initialize\n @see file:examples/example_conditional_formatting.rb", "Add data validation to this worksheet.\n\n @param [String] cells The cells the validation will apply to.\n @param [hash] data_validation options defining the validation to apply.\n @see examples/data_validation.rb for an example", "Adds a chart to this worksheets drawing. This is the recommended way to create charts for your worksheet. This method wraps the complexity of dealing with ooxml drawing, anchors, markers graphic frames chart objects and all the other dirty details.\n @param [Class] chart_type\n @option options [Array] start_at\n @option options [Array] end_at\n @option options [Cell, String] title\n @option options [Boolean] show_legend\n @option options [Integer] style\n @note each chart type also specifies additional options\n @see Chart\n @see Pie3DChart\n @see Bar3DChart\n @see Line3DChart\n @see README for examples", "This is a helper method that Lets you specify a fixed width for multiple columns in a worksheet in one go.\n Note that you must call column_widths AFTER adding data, otherwise the width will not be set successfully.\n Setting a fixed column width to nil will revert the behaviour back to calculating the width for you on the next call to add_row.\n @example This would set the first and third column widhts but leave the second column in autofit state.\n ws.column_widths 7.2, nil, 3\n @note For updating only a single column it is probably easier to just set the width of the ws.column_info[col_index].width directly\n @param [Integer|Float|nil] widths", "Set the style for cells in a specific column\n @param [Integer] index the index of the column\n @param [Integer] style the cellXfs index\n @param [Hash] options\n @option [Integer] :row_offset only cells after this column will be updated.\n @note You can also specify the style for specific columns in the call to add_row by using an array for the :styles option\n @see Worksheet#add_row\n @see README.md for an example", "Set the style for cells in a specific row\n @param [Integer] index or range of indexes in the table\n @param [Integer] style the cellXfs index\n @param [Hash] options the options used when applying the style\n @option [Integer] :col_offset only cells after this column will be updated.\n @note You can also specify the style in the add_row call\n @see Worksheet#add_row\n @see README.md for an example", "Returns a sheet node serialization for this sheet in the workbook.", "Serializes the worksheet object to an xml string\n This intentionally does not use nokogiri for performance reasons\n @return [String]", "The worksheet relationships. This is managed automatically by the worksheet\n @return [Relationships]", "returns the column and row index for a named based cell\n @param [String] name The cell or cell range to return. \"A1\" will return the first cell of the first row.\n @return [Cell]", "shortcut level to specify the outline level for a series of rows\n Oulining is what lets you add collapse and expand to a data set.\n @param [Integer] start_index The zero based index of the first row of outlining.\n @param [Integer] end_index The zero based index of the last row to be outlined\n @param [integer] level The level of outline to apply\n @param [Integer] collapsed The initial collapsed state of the outline group", "shortcut level to specify the outline level for a series of columns\n Oulining is what lets you add collapse and expand to a data set.\n @param [Integer] start_index The zero based index of the first column of outlining.\n @param [Integer] end_index The zero based index of the last column to be outlined\n @param [integer] level The level of outline to apply\n @param [Integer] collapsed The initial collapsed state of the outline group", "Serializes the row\n @param [Integer] r_index The row index, 0 based.\n @param [String] str The string this rows xml will be appended to.\n @return [String]", "Adds a single cell to the row based on the data provided and updates the worksheet's autofit data.\n @return [Cell]", "sets the color for every cell in this row", "sets the style for every cell in this row", "Converts values, types, and style options into cells and associates them with this row.\n A new cell is created for each item in the values array.\n If value option is defined and is a symbol it is applied to all the cells created.\n If the value option is an array, cell types are applied by index for each cell\n If the style option is defined and is an Integer, it is applied to all cells created.\n If the style option is an array, style is applied by index for each cell.\n @option options [Array] values\n @option options [Array, Symbol] types\n @option options [Array, Integer] style", "Creates a new Drawing object\n @param [Worksheet] worksheet The worksheet that owns this drawing\n Adds an image to the chart If th end_at option is specified we create a two cell anchor. By default we use a one cell anchor.\n @note The recommended way to manage images is to use Worksheet.add_image. Please refer to that method for documentation.\n @see Worksheet#add_image\n @return [Pic]", "Adds a chart to the drawing.\n @note The recommended way to manage charts is to use Worksheet.add_chart. Please refer to that method for documentation.\n @see Worksheet#add_chart", "An array of charts that are associated with this drawing's anchors\n @return [Array]", "An array of hyperlink objects associated with this drawings images\n @return [Array]", "An array of image objects that are associated with this drawing's anchors\n @return [Array]", "The drawing's relationships.\n @return [Relationships]", "Serialize the object\n @param [String] str serialized output will be appended to this object if provided.\n @return [String]", "Creates a new pie chart object\n @param [GraphicFrame] frame The workbook that owns this chart.\n @option options [Cell, String] title\n @option options [Boolean] show_legend\n @option options [Symbol] grouping\n @option options [String] gap_depth\n @option options [Integer] rot_x\n @option options [String] h_percent\n @option options [Integer] rot_y\n @option options [String] depth_percent\n @option options [Boolean] r_ang_ax\n @option options [Integer] perspective\n @see Chart\n @see View3D\n Serializes the object\n @param [String] str\n @return [String]", "creates the book views object\n Serialize to xml\n @param [String] str\n @return [String]", "updates the width for this col based on the cells autowidth and\n an optionally specified fixed width\n @param [Cell] cell The cell to use in updating this col's width\n @param [Integer] fixed_width If this is specified the width is set\n to this value and the cell's attributes are ignored.\n @param [Boolean] use_autowidth If this is false, the cell's\n autowidth value will be ignored.", "parse convert and assign node text to symbol", "parse, convert and assign note text to integer", "parse, convert and assign node text to float", "return node text based on xpath", "adds a chart to the drawing object\n @param [Class] chart_type The type of chart to add\n @param [Hash] options Options to pass on to the drawing and chart\n @see Worksheet#add_chart", "Adds a protected range\n @param [Array|String] cells A string range reference or array of cells that will be protected", "Serializes the protected ranges\n @param [String] str\n @return [String]", "Adds a filter column. This is the recommended way to create and manage filter columns for your autofilter.\n In addition to the require id and type parameters, options will be passed to the filter column during instantiation.\n @param [String] col_id Zero-based index indicating the AutoFilter column to which this filter information applies.\n @param [Symbol] filter_type A symbol representing one of the supported filter types.\n @param [Hash] options a hash of options to pass into the generated filter\n @return [FilterColumn]", "actually performs the filtering of rows who's cells do not\n match the filter.", "delete the item from the list\n @param [Any] v The item to be deleted.\n @raise [ArgumentError] if the item's index is protected by locking\n @return [Any] The item deleted", "positional assignment. Adds the item at the index specified\n @param [Integer] index\n @param [Any] v\n @raise [ArgumentError] if the index is protected by locking\n @raise [ArgumentError] if the item is not one of the allowed types", "creates a XML tag with serialized attributes\n @see SerializedAttributes#serialized_attributes", "serializes the instance values of the defining object based on the\n list of serializable attributes.\n @param [String] str The string instance to append this\n serialization to.\n @param [Hash] additional_attributes An option key value hash for\n defining values that are not serializable attributes list.", "A hash of instance variables that have been declared with\n seraialized_attributes and are not nil.\n This requires ruby 1.9.3 or higher", "serialized instance values at text nodes on a camelized element of the\n attribute name. You may pass in a block for evaluation against non nil\n values. We use an array for element attributes becuase misordering will\n break the xml and 1.8.7 does not support ordered hashes.\n @param [String] str The string instance to which serialized data is appended\n @param [Array] additional_attributes An array of additional attribute names.\n @return [String] The serialized output.", "serializes the data labels\n @return [String]", "The node name to use in serialization. As LineChart is used as the\n base class for Liine3DChart we need to be sure to serialize the\n chart based on the actual class type and not a fixed node name.\n @return [String]", "Serialize the app.xml document\n @return [String]", "Merges all the cells in a range created between this cell and the cell or string name for a cell provided\n @see worksheet.merge_cells\n @param [Cell, String] target The last cell, or str ref for the cell in the merge range", "Attempts to determine the correct width for this cell's content\n @return [Float]", "Determines the cell type based on the cell value.\n @note This is only used when a cell is created but no :type option is specified, the following rules apply:\n 1. If the value is an instance of Date, the type is set to :date\n 2. If the value is an instance of Time, the type is set to :time\n 3. If the value is an instance of TrueClass or FalseClass, the type is set to :boolean\n 4. :float and :integer types are determined by regular expression matching.\n 5. Anything that does not meet either of the above is determined to be :string.\n @return [Symbol] The determined type", "Cast the value into this cells data type.\n @note\n About Time - Time in OOXML is *different* from what you might expect. The history as to why is interesting, but you can safely assume that if you are generating docs on a mac, you will want to specify Workbook.1904 as true when using time typed values.\n @see Axlsx#date1904", "Tells us if the row of the cell provided should be filterd as it\n does not meet any of the specified filter_items or\n date_group_items restrictions.\n @param [Cell] cell The cell to test against items\n TODO implement this for date filters as well!", "Serialize the object to xml", "Date group items are date group filter items where you specify the\n date_group and a value for that option as part of the auto_filter\n @note This can be specified, but will not be applied to the date\n values in your workbook at this time.", "Creates a password hash for a given password\n @return [String]", "Creates the val objects for this data set. I am not overly confident this is going to play nicely with time and data types.\n @param [Array] values An array of cells or values.", "The name of the Table.\n @param [String, Cell] v\n @return [Title]", "Serializes the conditional formatting rule\n @param [String] str\n @return [String]", "Sets the cell location of this hyperlink in the worksheet\n @param [String|Cell] cell_reference The string reference or cell that defines where this hyperlink shows in the worksheet.", "serializes the core.xml document\n @return [String]", "creates a new MergedCells object\n @param [Worksheet] worksheet\n adds cells to the merged cells collection\n @param [Array||String] cells The cells to add to the merged cells\n collection. This can be an array of actual cells or a string style\n range like 'A1:C1'", "SEARCH GEOCODING PARAMS \n\n :q => required, full text search param)\n :limit => force limit number of results returned by raw API\n (default = 5) note : only first result is taken\n in account in geocoder\n\n :autocomplete => pass 0 to disable autocomplete treatment of :q\n (default = 1)\n\n :lat => force filter results around specific lat/lon\n\n :lon => force filter results around specific lat/lon\n\n :type => force filter the returned result type\n (check results for a list of accepted types)\n\n :postcode => force filter results on a specific city post code\n\n :citycode => force filter results on a specific city UUID INSEE code\n\n For up to date doc (in french only) : https://adresse.data.gouv.fr/api/", "REVERSE GEOCODING PARAMS \n\n :lat => required\n\n :lon => required\n\n :type => force returned results type\n (check results for a list of accepted types)", "Convert an \"underscore\" version of a name into a \"class\" version.", "Return the name of the configured service, or raise an exception.", "Read from the Cache.", "Write to the Cache.", "Return the error but also considering its name. This is used\n when errors for a hidden field need to be shown.\n\n == Examples\n\n f.full_error :token #=> Token is invalid ", "Extract the model names from the object_name mess, ignoring numeric and\n explicit child indexes.\n\n Example:\n\n route[blocks_attributes][0][blocks_learning_object_attributes][1][foo_attributes]\n [\"route\", \"blocks\", \"blocks_learning_object\", \"foo\"]", "The action to be used in lookup.", "Find an input based on the attribute name.", "Checks if the file of given path is a valid ELF file.\n\n @param [String] path Path to target file.\n @return [Boolean] If the file is an ELF or not.\n @example\n Helper.valid_elf_file?('/etc/passwd')\n #=> false\n Helper.valid_elf_file?('/lib64/ld-linux-x86-64.so.2')\n #=> true", "Get the Build ID of target ELF.\n @param [String] path Absolute file path.\n @return [String] Target build id.\n @example\n Helper.build_id_of('/lib/x86_64-linux-gnu/libc-2.23.so')\n #=> '60131540dadc6796cab33388349e6e4e68692053'", "Wrap string with color codes for pretty inspect.\n @param [String] str Contents to colorize.\n @param [Symbol] sev Specify which kind of color to use, valid symbols are defined in {.COLOR_CODE}.\n @return [String] String wrapped with color codes.", "Get request.\n @param [String] url The url.\n @return [String]\n The request response body.\n If the response is +302 Found+, returns the location in header.", "Fetch the ELF archiecture of +file+.\n @param [String] file The target ELF filename.\n @return [Symbol]\n Currently supports amd64, i386, arm, aarch64, and mips.\n @example\n Helper.architecture('/bin/cat')\n #=> :amd64", "Find objdump that supports architecture +arch+.\n @param [String] arch\n @return [String?]\n @example\n Helper.find_objdump(:amd64)\n #=> '/usr/bin/objdump'\n Helper.find_objdump(:aarch64)\n #=> '/usr/bin/aarch64-linux-gnu-objdump'", "Checks if the register is a stack-related pointer.\n @param [String] reg\n Register's name.\n @return [Boolean]", "Show the message of ask user to update gem.\n @return [void]", "Main method of CLI.\n @param [Array] argv\n Command line arguments.\n @return [Boolean]\n Whether the command execute successfully.\n @example\n CLI.work(%w[--help])\n # usage message\n #=> true\n CLI.work(%w[--version])\n # version message\n #=> true\n @example\n CLI.work([])\n # usage message\n #=> false\n @example\n CLI.work(%w[-b b417c0ba7cc5cf06d1d1bed6652cedb9253c60d0 -r])\n # 324293 324386 1090444\n #=> true", "Decides how to display fetched gadgets according to options.\n @param [Array] gadgets\n @param [String] libc_file\n @return [Boolean]", "Displays libc information given BuildID.\n @param [String] id\n @return [Boolean]\n +false+ is returned if no information found.\n @example\n CLI.info_build_id('b417c')\n # [OneGadget] Information of b417c:\n # spec/data/libc-2.27-b417c0ba7cc5cf06d1d1bed6652cedb9253c60d0.so\n \n # Advanced Micro Devices X86-64\n \n # GNU C Library (Ubuntu GLIBC 2.27-3ubuntu1) stable release version 2.27.\n # Copyright (C) 2018 Free Software Foundation, Inc.\n # This is free software; see the source for copying conditions.\n # There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A\n # PARTICULAR PURPOSE.\n # Compiled by GNU CC version 7.3.0.\n # libc ABIs: UNIQUE IFUNC\n # For bug reporting instructions, please see:\n # .\n #=> true", "The option parser.\n @return [OptionParser]", "Writes gadgets to stdout.\n @param [Array] gadgets\n @param [Boolean] raw\n In raw mode, only the offset of gadgets are printed.\n @return [true]", "Turns on logging\n\n class Foo\n include HTTParty\n logger Logger.new('http_logger'), :info, :apache\n end", "Allows setting http proxy information to be used\n\n class Foo\n include HTTParty\n http_proxy 'http://foo.com', 80, 'user', 'pass'\n end", "Allows setting default parameters to be appended to each request.\n Great for api keys and such.\n\n class Foo\n include HTTParty\n default_params api_key: 'secret', another: 'foo'\n end", "Allows setting HTTP headers to be used for each request.\n\n class Foo\n include HTTParty\n headers 'Accept' => 'text/html'\n end", "Allows setting a custom connection_adapter for the http connections\n\n @example\n class Foo\n include HTTParty\n connection_adapter Proc.new {|uri, options| ... }\n end\n\n @example provide optional configuration for your connection_adapter\n class Foo\n include HTTParty\n connection_adapter Proc.new {|uri, options| ... }, {foo: :bar}\n end\n\n @see HTTParty::ConnectionAdapter", "Allows making a get request to a url.\n\n class Foo\n include HTTParty\n end\n\n # Simple get with full url\n Foo.get('http://foo.com/resource.json')\n\n # Simple get with full url and query parameters\n # ie: http://foo.com/resource.json?limit=10\n Foo.get('http://foo.com/resource.json', query: {limit: 10})", "Allows making a post request to a url.\n\n class Foo\n include HTTParty\n end\n\n # Simple post with full url and setting the body\n Foo.post('http://foo.com/resources', body: {bar: 'baz'})\n\n # Simple post with full url using :query option,\n # which appends the parameters to the URI.\n Foo.post('http://foo.com/resources', query: {bar: 'baz'})", "Perform a PATCH request to a path", "Perform a PUT request to a path", "Perform a DELETE request to a path", "Perform a MOVE request to a path", "Perform a COPY request to a path", "Perform a HEAD request to a path", "Perform an OPTIONS request to a path", "Perform a MKCOL request to a path", "Returns a new array with the concatenated results of running block once for every element in enumerable.\n If no block is given, an enumerator is returned instead.\n\n @param enumerable [Enumerable]\n @return [Array, Enumerator]", "Returns a new array with the results of running block once for every element in enumerable.\n If no block is given, an enumerator is returned instead.\n\n @param enumerable [Enumerable]\n @return [Array, Enumerator]", "Converts query string to a hash\n\n @param query_string [String] The query string of a URL.\n @return [Hash] The query string converted to a hash (with symbol keys).\n @example Convert query string to a hash\n query_string_to_hash(\"foo=bar&baz=qux\") #=> {:foo=>\"bar\", :baz=>\"qux\"}", "Time when the object was created on Twitter\n\n @return [Time]", "JSON representation of the Access Token instance.\n\n @return [Hash] hash with token data", "Check whether the given plain text secret matches our stored secret\n\n @param input [#to_s] Plain secret provided by user\n (any object that responds to `#to_s`)\n\n @return [true] Whether the given secret matches the stored secret\n of this application.", "Determine whether +reuse_access_token+ and a non-restorable\n +token_secret_strategy+ have both been activated.\n\n In that case, disable reuse_access_token value and warn the user.", "Allow SSL context to be configured via settings, for Ruby >= 1.9\n Just returns openssl verify mode for Ruby 1.8.x", "Returns the attachment by filename or at index.\n\n mail.attachments['test.png'] = File.read('test.png')\n mail.attachments['test.jpg'] = File.read('test.jpg')\n\n mail.attachments['test.png'].filename #=> 'test.png'\n mail.attachments[1].filename #=> 'test.jpg'", "Find emails in a POP3 mailbox. Without any options, the 5 last received emails are returned.\n\n Possible options:\n what: last or first emails. The default is :first.\n order: order of emails returned. Possible values are :asc or :desc. Default value is :asc.\n count: number of emails to retrieve. The default value is 10. A value of 1 returns an\n instance of Message, not an array of Message instances.\n delete_after_find: flag for whether to delete each retreived email after find. Default\n is false. Use #find_and_delete if you would like this to default to true.", "Delete all emails from a POP3 server", "Returns the address string of all the addresses in the address list", "Returns the formatted string of all the addresses in the address list", "Returns the display name of all the addresses in the address list", "Returns a list of decoded group addresses", "Returns a list of encoded group addresses", "Send the message via SMTP.\n The from and to attributes are optional. If not set, they are retrieve from the Message.", "Various special cases from random emails found that I am not going to change\n the parser for", "If the string supplied has PHRASE unsafe characters in it, will return the string quoted\n in double quotes, otherwise returns the string unmodified", "If the string supplied has TOKEN unsafe characters in it, will return the string quoted\n in double quotes, otherwise returns the string unmodified", "Capitalizes a string that is joined by hyphens correctly.\n\n Example:\n\n string = 'resent-from-field'\n capitalize_field( string ) #=> 'Resent-From-Field'", "Takes an underscored word and turns it into a class name\n\n Example:\n\n constantize(\"hello\") #=> \"Hello\"\n constantize(\"hello-there\") #=> \"HelloThere\"\n constantize(\"hello-there-mate\") #=> \"HelloThereMate\"", "Returns true if the object is considered blank.\n A blank includes things like '', ' ', nil,\n and arrays and hashes that have nothing in them.\n\n This logic is mostly shared with ActiveSupport's blank?", "Find emails in a IMAP mailbox. Without any options, the 10 last received emails are returned.\n\n Possible options:\n mailbox: mailbox to search the email(s) in. The default is 'INBOX'.\n what: last or first emails. The default is :first.\n order: order of emails returned. Possible values are :asc or :desc. Default value is :asc.\n count: number of emails to retrieve. The default value is 10. A value of 1 returns an\n instance of Message, not an array of Message instances.\n read_only: will ensure that no writes are made to the inbox during the session. Specifically, if this is\n set to true, the code will use the EXAMINE command to retrieve the mail. If set to false, which\n is the default, a SELECT command will be used to retrieve the mail\n This is helpful when you don't want your messages to be set to read automatically. Default is false.\n delete_after_find: flag for whether to delete each retreived email after find. Default\n is false. Use #find_and_delete if you would like this to default to true.\n keys: are passed as criteria to the SEARCH command. They can either be a string holding the entire search string,\n or a single-dimension array of search keywords and arguments. Refer to [IMAP] section 6.4.4 for a full list\n The default is 'ALL'\n search_charset: charset to pass to IMAP server search. Omitted by default. Example: 'UTF-8' or 'ASCII'.", "Delete all emails from a IMAP mailbox", "Start an IMAP session and ensures that it will be closed in any case.", "3.6. Field definitions\n\n It is important to note that the header fields are not guaranteed to\n be in a particular order. They may appear in any order, and they\n have been known to be reordered occasionally when transported over\n the Internet. However, for the purposes of this standard, header\n fields SHOULD NOT be reordered when a message is transported or\n transformed. More importantly, the trace header fields and resent\n header fields MUST NOT be reordered, and SHOULD be kept in blocks\n prepended to the message. See sections 3.6.6 and 3.6.7 for more\n information.\n\n Populates the fields container with Field objects in the order it\n receives them in.\n\n Acceps an array of field string values, for example:\n\n h = Header.new\n h.fields = ['From: mikel@me.com', 'To: bob@you.com']", "Sets the FIRST matching field in the header to passed value, or deletes\n the FIRST field matched from the header if passed nil\n\n Example:\n\n h = Header.new\n h.fields = ['To: mikel@me.com', 'X-Mail-SPAM: 15', 'X-Mail-SPAM: 20']\n h['To'] = 'bob@you.com'\n h['To'] #=> 'bob@you.com'\n h['X-Mail-SPAM'] = '10000'\n h['X-Mail-SPAM'] # => ['15', '20', '10000']\n h['X-Mail-SPAM'] = nil\n h['X-Mail-SPAM'] # => nil", "Returns the default value of the field requested as a symbol.\n\n Each header field has a :default method which returns the most common use case for\n that field, for example, the date field types will return a DateTime object when\n sent :default, the subject, or unstructured fields will return a decoded string of\n their value, the address field types will return a single addr_spec or an array of\n addr_specs if there is more than one.", "Allows you to add an arbitrary header\n\n Example:\n\n mail['foo'] = '1234'\n mail['foo'].to_s #=> '1234'", "Method Missing in this implementation allows you to set any of the\n standard fields directly as you would the \"to\", \"subject\" etc.\n\n Those fields used most often (to, subject et al) are given their\n own method for ease of documentation and also to avoid the hook\n call to method missing.\n\n This will only catch the known fields listed in:\n\n Mail::Field::KNOWN_FIELDS\n\n as per RFC 2822, any ruby string or method name could pretty much\n be a field name, so we don't want to just catch ANYTHING sent to\n a message object and interpret it as a header.\n\n This method provides all three types of header call to set, read\n and explicitly set with the = operator\n\n Examples:\n\n mail.comments = 'These are some comments'\n mail.comments #=> 'These are some comments'\n\n mail.comments 'These are other comments'\n mail.comments #=> 'These are other comments'\n\n\n mail.date = 'Tue, 1 Jul 2003 10:52:37 +0200'\n mail.date.to_s #=> 'Tue, 1 Jul 2003 10:52:37 +0200'\n\n mail.date 'Tue, 1 Jul 2003 10:52:37 +0200'\n mail.date.to_s #=> 'Tue, 1 Jul 2003 10:52:37 +0200'\n\n\n mail.resent_msg_id = '<1234@resent_msg_id.lindsaar.net>'\n mail.resent_msg_id #=> '<1234@resent_msg_id.lindsaar.net>'\n\n mail.resent_msg_id '<4567@resent_msg_id.lindsaar.net>'\n mail.resent_msg_id #=> '<4567@resent_msg_id.lindsaar.net>'", "Adds a content type and charset if the body is US-ASCII\n\n Otherwise raises a warning", "Adds a part to the parts list or creates the part list", "Allows you to add a part in block form to an existing mail message object\n\n Example:\n\n mail = Mail.new do\n part :content_type => \"multipart/alternative\", :content_disposition => \"inline\" do |p|\n p.part :content_type => \"text/plain\", :body => \"test text\\nline #2\"\n p.part :content_type => \"text/html\", :body => \"test HTML \\nline #2\"\n end\n end", "Adds a file to the message. You have two options with this method, you can\n just pass in the absolute path to the file you want and Mail will read the file,\n get the filename from the path you pass in and guess the MIME media type, or you\n can pass in the filename as a string, and pass in the file content as a blob.\n\n Example:\n\n m = Mail.new\n m.add_file('/path/to/filename.png')\n\n m = Mail.new\n m.add_file(:filename => 'filename.png', :content => File.read('/path/to/file.jpg'))\n\n Note also that if you add a file to an existing message, Mail will convert that message\n to a MIME multipart email, moving whatever plain text body you had into its own text\n plain part.\n\n Example:\n\n m = Mail.new do\n body 'this is some text'\n end\n m.multipart? #=> false\n m.add_file('/path/to/filename.png')\n m.multipart? #=> true\n m.parts.first.content_type.content_type #=> 'text/plain'\n m.parts.last.content_type.content_type #=> 'image/png'\n\n See also #attachments", "Encodes the message, calls encode on all its parts, gets an email message\n ready to send", "Outputs an encoded string representation of the mail message including\n all headers, attachments, etc. This is an encoded email in US-ASCII,\n so it is able to be directly sent to an email server.", "see comments to body=. We take data and process it lazily", "Returns an array of comments that are in the email, or nil if there\n are no comments\n\n a = Address.new('Mikel Lindsaar (My email address) ')\n a.comments #=> ['My email address']\n\n b = Address.new('Mikel Lindsaar ')\n b.comments #=> nil", "Get all emails.\n\n Possible options:\n order: order of emails returned. Possible values are :asc or :desc. Default value is :asc.", "Find emails in the mailbox, and then deletes them. Without any options, the\n five last received emails are returned.\n\n Possible options:\n what: last or first emails. The default is :first.\n order: order of emails returned. Possible values are :asc or :desc. Default value is :asc.\n count: number of emails to retrieve. The default value is 10. A value of 1 returns an\n instance of Message, not an array of Message instances.\n delete_after_find: flag for whether to delete each retreived email after find. Default\n is true. Call #find if you would like this to default to false.", "Insert the field in sorted order.\n\n Heavily based on bisect.insort from Python, which is:\n Copyright (C) 2001-2013 Python Software Foundation.\n Licensed under \n From ", "Updates all of the template catalogs and returns their filepaths.\n If there is a Rambafile in the current directory, it also updates all of the catalogs specified there.\n\n @return [Array] An array of filepaths to downloaded catalogs", "Clones a template catalog from a remote repository\n\n @param name [String] The name of the template catalog\n @param url [String] The url of the repository\n\n @return [Pathname] A filepath to the downloaded catalog", "Provides the appropriate strategy for a given template type", "Browses a given catalog and returns a template path\n\n @param catalog_path [Pathname] A path to a catalog\n @param template_name [String] A name of the template\n\n @return [Pathname] A path to a template, if found", "This method parses Rambafile, serializes templates hashes into model objects and install them", "Clears all of the currently installed templates", "Clones remote template catalogs to the local directory", "Create a XCScheme either from scratch or using an existing file\n\n @param [String] file_path\n The path of the existing .xcscheme file. If nil will create an empty scheme\n\n Convenience method to quickly add app and test targets to a new scheme.\n\n It will add the runnable_target to the Build, Launch and Profile actions\n and the test_target to the Build and Test actions\n\n @param [Xcodeproj::Project::Object::PBXAbstractTarget] runnable_target\n The target to use for the 'Run', 'Profile' and 'Analyze' actions\n\n @param [Xcodeproj::Project::Object::PBXAbstractTarget] test_target\n The target to use for the 'Test' action\n\n @param [Boolean] launch_target\n Determines if the runnable_target is launchable.", "Sets a runnable target to be the target of the launch action of the scheme.\n\n @param [Xcodeproj::Project::Object::AbstractTarget] build_target\n A target used by scheme in the launch step.", "Serializes the current state of the object to a \".xcscheme\" file.\n\n @param [String, Pathname] project_path\n The path where the \".xcscheme\" file should be stored.\n\n @param [String] name\n The name of the scheme, to have \".xcscheme\" appended.\n\n @param [Boolean] shared\n true => if the scheme must be a shared scheme (default value)\n false => if the scheme must be a user scheme\n\n @return [void]\n\n @example Saving a scheme\n scheme.save_as('path/to/Project.xcodeproj') #=> true", "Initializes the instance with the project stored in the `path` attribute.", "Converts the objects tree to a hash substituting the hash\n of the referenced to their UUID reference. As a consequence the hash of\n an object might appear multiple times and the information about their\n uniqueness is lost.\n\n This method is designed to work in conjunction with {Hash#recursive_diff}\n to provide a complete, yet readable, diff of two projects *not* affected\n by differences in UUIDs.\n\n @return [Hash] a hash representation of the project different from the\n plist one.", "Pre-generates the given number of UUIDs. Useful for optimizing\n performance when the rough number of objects that will be created is\n known in advance.\n\n @param [Integer] count\n the number of UUIDs that should be generated.\n\n @note This method might generated a minor number of uniques UUIDs than\n the given count, because some might be duplicated a thus will be\n discarded.\n\n @return [void]", "Returns the file reference for the given absolute path.\n\n @param [#to_s] absolute_path\n The absolute path of the file whose reference is needed.\n\n @return [PBXFileReference] The file reference.\n @return [Nil] If no file reference could be found.", "Checks the native target for any targets in the project\n that are dependent on the native target and would be\n embedded in it at build time\n\n @param [PBXNativeTarget] native target to check for\n embedded targets\n\n\n @return [Array] A list of all targets that\n are embedded in the passed in target", "Returns the native targets, in which the embedded target is\n embedded. This works by traversing the targets to find those\n where the target is a dependency.\n\n @param [PBXNativeTarget] native target that might be embedded\n in another target\n\n @return [Array] the native targets that host the\n embedded target", "Creates a new resource bundles target and adds it to the project.\n\n The target is configured for the given platform and its file reference it\n is added to the {products_group}.\n\n The target is pre-populated with common build settings\n\n @param [String] name\n the name of the resources bundle.\n\n @param [Symbol] platform\n the platform of the resources bundle. Can be `:ios` or `:osx`.\n\n @return [PBXNativeTarget] the target.", "Adds a new build configuration to the project and populates its with\n default settings according to the provided type.\n\n @param [String] name\n The name of the build configuration.\n\n @param [Symbol] type\n The type of the build configuration used to populate the build\n settings, must be :debug or :release.\n\n @return [XCBuildConfiguration] The new build configuration.", "Writes the serialized representation of the internal data to the given\n path.\n\n @param [Pathname] pathname\n The file where the data should be written to.\n\n @return [void]", "Returns a hash from the string representation of an Xcconfig file.\n\n @param [String] string\n The string representation of an xcconfig file.\n\n @return [Hash] the hash containing the xcconfig data.", "Merges the given attributes hash while ensuring values are not duplicated.\n\n @param [Hash] attributes\n The attributes hash to merge into @attributes.\n\n @return [void]", "Returns the key and the value described by the given line of an xcconfig.\n\n @param [String] line\n the line to process.\n\n @return [Array] A tuple where the first entry is the key and the second\n entry is the value.", "Generates test cases to compare two settings hashes.\n\n @param [Hash{String => String}] produced\n the produced build settings.\n\n @param [Hash{String => String}] expected\n the expected build settings.\n\n @param [#to_s] params\n the parameters used to construct the produced build settings.", "Load settings from fixtures\n\n @param [String] path\n the directory, where the fixture set is located.\n\n @param [Symbol] type\n the type, where the specific\n\n @param [Hash{String => String}]\n the build settings", "Saves the workspace at the given `xcworkspace` path.\n\n @param [String] path\n the path where to save the project.\n\n @return [void]", "Load all schemes from project\n\n @param [String] project_full_path\n project full path\n\n @return [void]", "Return container content.", "Return own toc content.", "called from strategy", "Take YAML +file+ and update parameter hash.", "Update parameters by merging from new parameter hash +config+.", "Write mimetype file to IO object +wobj+.", "Write opf file to IO object +wobj+.", "Write ncx file to IO object +wobj+. +indentarray+ defines prefix\n string for each level.", "Write container file to IO object +wobj+.", "Write colophon file to IO object +wobj+.", "Write own toc file to IO object +wobj+.", "Return ncx content. +indentarray+ has prefix marks for each level.", "Produce EPUB file +epubfile+.\n +basedir+ points the directory has contents.\n +tmpdir+ defines temporary directory.", "index -> italic", "load YAML files\n\n `inherit: [3.yml, 6.yml]` in 7.yml; `inherit: [1.yml, 2.yml]` in 3.yml; `inherit: [4.yml, 5.yml]` in 6.yml\n => 7.yml > 6.yml > 5.yml > 4.yml > 3.yml > 2.yml > 1.yml", "Complement other parameters by using file parameter.", "Choose an alternative, add a participant, and save the alternative choice on the user. This\n method is guaranteed to only run once, and will skip the alternative choosing process if run\n a second time.", "Set default program_name in performance_schema.session_connect_attrs\n and performance_schema.session_account_connect_attrs", "In MySQL 5.5+ error messages are always constructed server-side as UTF-8\n then returned in the encoding set by the `character_set_results` system\n variable.\n\n See http://dev.mysql.com/doc/refman/5.5/en/charset-errors.html for\n more context.\n\n Before MySQL 5.5 error message template strings are in whatever encoding\n is associated with the error message language.\n See http://dev.mysql.com/doc/refman/5.1/en/error-message-language.html\n for more information.\n\n The issue is that the user-data inserted in the message could potentially\n be in any encoding MySQL supports and is insert into the latin1, euckr or\n koi8r string raw. Meaning there's a high probability the string will be\n corrupt encoding-wise.\n\n See http://dev.mysql.com/doc/refman/5.1/en/charset-errors.html for\n more information.\n\n So in an attempt to make sure the error message string is always in a valid\n encoding, we'll assume UTF-8 and clean the string of anything that's not a\n valid UTF-8 character.\n\n Returns a valid UTF-8 string.", "Custom describe block that sets metadata to enable the rest of RAD\n\n resource \"Orders\", :meta => :data do\n # ...\n end\n\n Params:\n +args+:: Glob of RSpec's `describe` arguments\n +block+:: Block to pass into describe", "Defines a new sub configuration\n\n Automatically sets the `filter` to the group name, and the `docs_dir` to\n a subfolder of the parent's `doc_dir` named the group name.\n\n RspecApiDocumentation.configure do |config|\n config.docs_dir = \"doc/api\"\n config.define_group(:public) do |config|\n # Default values\n config.docs_dir = \"doc/api/public\"\n config.filter = :public\n end\n end\n\n Params:\n +name+:: String name of the group\n +block+:: Block configuration block", "Must be called after the backtrace cleaner.", "Rails relies on backtrace cleaner to set the application root directory\n filter. The problem is that the backtrace cleaner is initialized before\n this gem. This ensures that the value of `root` used by the filter\n is correct.", "Mass assigns attributes on the model.\n\n This is a version of +update_attributes+ that takes some extra options\n for internal use.\n\n ==== Attributes\n\n * +values+ - Hash of values to use to update the current attributes of\n the object.\n * +opts+ - Options for +StripeObject+ like an API key that will be reused\n on subsequent API calls.\n\n ==== Options\n\n * +:dirty+ - Whether values should be initiated as \"dirty\" (unsaved) and\n which applies only to new StripeObjects being initiated under this\n StripeObject. Defaults to true.", "Returns a hash of empty values for all the values that are in the given\n StripeObject.", "Iterates through each resource in all pages, making additional fetches to\n the API as necessary.\n\n Note that this method will make as many API calls as necessary to fetch\n all resources. For more granular control, please see +each+ and\n +next_page+.", "Formats a plugin \"app info\" hash into a string that we can tack onto the\n end of a User-Agent string where it'll be fairly prominent in places like\n the Dashboard. Note that this formatting has been implemented to match\n other libraries, and shouldn't be changed without universal consensus.", "Attempts to look at a response's error code and return an OAuth error if\n one matches. Will return `nil` if the code isn't recognized.", "Format ActiveRecord instance object.\n\n NOTE: by default only instance attributes (i.e. columns) are shown. To format\n ActiveRecord instance as regular object showing its instance variables and\n accessors use :raw => true option:\n\n ap record, :raw => true\n\n------------------------------------------------------------------------------", "Format Ripple instance object.\n\n NOTE: by default only instance attributes are shown. To format a Ripple document instance\n as a regular object showing its instance variables and accessors use :raw => true option:\n\n ap document, :raw => true\n\n------------------------------------------------------------------------------", "Format MongoMapper instance object.\n\n NOTE: by default only instance attributes (i.e. keys) are shown. To format\n MongoMapper instance as regular object showing its instance variables and\n accessors use :raw => true option:\n\n ap record, :raw => true\n\n------------------------------------------------------------------------------", "Use HTML colors and add default \"debug_dump\" class to the resulting HTML.", "Returns list of ancestors, starting from parent until root.\n\n subchild1.ancestors # => [child1, root]", "Returns all children and children of children", "if passed nil will use default seed classes", "Writing to the seed file. Takes in file handler and array of hashes with\n `header` and `content` keys", "Collecting fragment data and writing attachment files to disk", "Importing translations for given page. They look like `content.locale.html`", "Constructing frag attributes hash that can be assigned to page or translation\n also returning list of frag identifiers so we can destroy old ones", "Preparing fragment attachments. Returns hashes with file data for\n ActiveStorage and a list of ids of old attachements to destroy", "Same as cms_fragment_content but with cms tags expanded and rendered. Use\n it only if you know you got more stuff in the fragment content other than\n text because this is a potentially expensive call.", "Same as cms_snippet_content but cms tags will be expanded. Note that there\n is no page context, so snippet cannot contain fragment tags.", "Wrapper to deal with Kaminari vs WillPaginate", "HTTP methods with a body", "Checks if method_name is set in the attributes hash\n and returns true when found, otherwise proxies the\n call to the superclass.", "Overrides method_missing to check the attribute hash\n for resources matching method_name and proxies the call\n to the superclass if no match is found.", "Fetches the attributes for the specified resource from JIRA unless\n the resource is already expanded and the optional force reload flag\n is not set", "Sets the attributes hash from a HTTPResponse object from JIRA if it is\n not nil or is not a json response.", "Set the current attributes from a hash. If clobber is true, any existing\n hash values will be clobbered by the new hash, otherwise the hash will\n be deeply merged into attrs. The target paramater is for internal use only\n and should not be used.", "Note that we delegate almost all methods to the result of the que_target\n method, which could be one of a few things, depending on the circumstance.\n Run the job with error handling and cleanup logic. Optionally support\n overriding the args, because it's necessary when jobs are invoked from\n ActiveJob.", "To be overridden in subclasses.", "Explicitly check for the job id in these helpers, because it won't exist\n if we're running synchronously.", "Since we use a mutex, which is not reentrant, we have to be a little\n careful to not call a method that locks the mutex when we've already\n locked it. So, as a general rule, public methods handle locking the mutex\n when necessary, while private methods handle the actual underlying data\n changes. This lets us reuse those private methods without running into\n locking issues.", "Get ips for given name\n\n First the local resolver is used. On POSIX-systems /etc/hosts is used. On\n Windows C:\\Windows\\System32\\drivers\\etc\\hosts is used.\n\n @param [String] name\n The name which should be resolved.", "Add a new mime-type for a specific extension\n\n @param [Symbol] type File extension\n @param [String] value Mime type\n @return [void]", "Activate an extension, optionally passing in options.\n This method is typically used from a project's `config.rb`.\n\n @example Activate an extension with no options\n activate :lorem\n\n @example Activate an extension, with options\n activate :minify_javascript, inline: true\n\n @example Use a block to configure extension options\n activate :minify_javascript do |opts|\n opts.ignore += ['*-test.js']\n end\n\n @param [Symbol] ext_name The name of thed extension to activate\n @param [Hash] options Options to pass to the extension\n @yield [Middleman::Configuration::ConfigurationManager] Extension options that can be modified before the extension is initialized.\n @return [void]", "Initialize the Middleman project", "Clean up missing Tilt exts", "The extension task", "Extensions are instantiated when they are activated.\n @param [Middleman::Application] app The Middleman::Application instance\n @param [Hash] options_hash The raw options hash. Subclasses should not manipulate this directly - it will be turned into {#options}.\n @yield An optional block that can be used to customize options before the extension is activated.\n @yieldparam [Middleman::Configuration::ConfigurationManager] options Extension options\n @!method before_configuration\n Respond to the `before_configuration` event.\n If a `before_configuration` method is implemented, that method will be run before `config.rb` is run.\n @note Because most extensions are activated from within `config.rb`, they *will not run* any `before_configuration` hook.\n @!method after_configuration\n Respond to the `after_configuration` event.\n If an `after_configuration` method is implemented, that method will be run before `config.rb` is run.\n @!method before_build\n Respond to the `before_build` event.\n If an `before_build` method is implemented, that method will be run before the builder runs.\n @!method after_build\n Respond to the `after_build` event.\n If an `after_build` method is implemented, that method will be run after the builder runs.\n @!method ready\n Respond to the `ready` event.\n If an `ready` method is implemented, that method will be run after the app has finished booting up.\n @!method manipulate_resource_list(resources)\n Manipulate the resource list by transforming or adding {Sitemap::Resource}s.\n Sitemap manipulation is a powerful way of interacting with a project, since it can modify each {Sitemap::Resource} or generate new {Sitemap::Resources}. This method is used in a pipeline where each sitemap manipulator is run in turn, with each one being fed the output of the previous manipulator. See the source of built-in Middleman extensions like {Middleman::Extensions::DirectoryIndexes} and {Middleman::Extensions::AssetHash} for examples of how to use this.\n @note This method *must* return the full set of resources, because its return value will be used as the new sitemap.\n @see http://middlemanapp.com/advanced/sitemap/ Sitemap Documentation\n @see Sitemap::Store\n @see Sitemap::Resource\n @param [Array] resources A list of all the resources known to the sitemap.\n @return [Array] The transformed list of resources.", "The init task", "Copied from Bundler", "Core build Thor command\n @return [void]", "Handles incoming events from the builder.\n @param [Symbol] event_type The type of event.\n @param [String] target The event contents.\n @param [String] extra The extra information.\n @return [void]", "Find empty directories in the build folder and remove them.\n @return [Boolean]", "Core response method. We process the request, check with\n the sitemap, and return the correct file, response or status\n message.\n\n @param env\n @param [Rack::Request] req\n @param [Rack::Response] res", "Halt request and return 404", "Immediately send static file", "Start the server", "Allow layouts to be wrapped in the contents of other layouts.\n\n @param [String, Symbol] layout_name\n @return [void]", "Render a path with locs, opts and contents block.\n\n @api private\n @param [Middleman::SourceFile] file The file.\n @param [Hash] locs Template locals.\n @param [Hash] opts Template options.\n @param [Proc] block A block will be evaluated to return internal contents.\n @return [String] The resulting content string.\n Contract IsA['Middleman::SourceFile'], Hash, Hash, Maybe[Proc] => String", "Glob a directory and try to keep path encoding consistent.\n\n @param [String] path The glob path.\n @return [Array]", "Recursively builds entity instances\n out of all hashes in the response object", "Decrypts a value for the attribute specified using options evaluated in the current object's scope\n\n Example\n\n class User\n attr_accessor :secret_key\n attr_encrypted :email, key: :secret_key\n\n def initialize(secret_key)\n self.secret_key = secret_key\n end\n end\n\n @user = User.new('some-secret-key')\n @user.decrypt(:email, 'SOME_ENCRYPTED_EMAIL_STRING')", "Encrypts a value for the attribute specified using options evaluated in the current object's scope\n\n Example\n\n class User\n attr_accessor :secret_key\n attr_encrypted :email, key: :secret_key\n\n def initialize(secret_key)\n self.secret_key = secret_key\n end\n end\n\n @user = User.new('some-secret-key')\n @user.encrypt(:email, 'test@example.com')", "Copies the class level hash of encrypted attributes with virtual attribute names as keys\n and their corresponding options as values to the instance", "Change color of string\n\n Examples:\n\n puts \"This is blue\".colorize(:blue)\n puts \"This is light blue\".colorize(:light_blue)\n puts \"This is also blue\".colorize(:color => :blue)\n puts \"This is light blue with red background\".colorize(:color => :light_blue, :background => :red)\n puts \"This is light blue with red background\".colorize(:light_blue ).colorize( :background => :red)\n puts \"This is blue text on red\".blue.on_red\n puts \"This is red on blue\".colorize(:red).on_blue\n puts \"This is red on blue and underline\".colorize(:red).on_blue.underline\n puts \"This is blue text on red\".blue.on_red.blink\n puts \"This is uncolorized\".blue.on_red.uncolorize", "Return true if string is colorized", "Set color from params", "Set colors from params hash", "Generate color and on_color methods", "User Code Block", "consuming a terminal may set off a series of reduces before the terminal\n is shifted", "Sequence of state transitions which would be taken when starting\n from 'state', then following the RHS of 'rule' right to the end", "traverse a directed graph\n each entry in 'bitmap' corresponds to a graph node\n after the traversal, the bitmap for each node will be the union of its\n original value, and ALL the values for all the nodes which are reachable\n from it", "Like `transition_graph`, but rather than vectors labeled with NTs, we\n have vectors labeled with the shortest series of terminals and reduce\n operations which could take us through the same transition", "sometimes a Rule is instantiated before the target is actually known\n it may be given a \"placeholder\" target first, which is later replaced\n with the real one", "If an instance of this NT comes next, then what rules could we be\n starting?", "Generates an image tag for the given attachment, adding appropriate\n classes and optionally falling back to the given fallback image if there\n is no file attached.\n\n Returns `nil` if there is no file attached and no fallback specified.\n\n @param [String] fallback The path to an image asset to be used as a fallback\n @param [Hash] options Additional options for the image tag\n @see #attachment_url\n @return [ActiveSupport::SafeBuffer, nil] The generated image tag", "Generates a hidden form field which tracks the id of the file in the cache\n before it is permanently stored.\n\n @param object_name The name of the object to generate a field for\n @param method The name of the field\n @param [Hash] options\n @option options [Object] object Set by the form builder\n @return [ActiveSupport::SafeBuffer] The generated hidden form field", "Macro which generates accessors in pure Ruby classes for assigning\n multiple attachments at once. This is primarily useful together with\n multiple file uploads. There is also an Active Record version of\n this macro.\n\n The name of the generated accessors will be the name of the association\n (represented by an attribute accessor) and the name of the attachment in\n the associated class. So if a `Post` accepts attachments for `images`, and\n the attachment in the `Image` class is named `file`, then the accessors will\n be named `images_files`.\n\n @example in associated class\n class Document\n extend Refile::Attachment\n attr_accessor :file_id\n\n attachment :file\n\n def initialize(attributes = {})\n self.file = attributes[:file]\n end\n end\n\n @example in class\n class Post\n extend Refile::Attachment\n include ActiveModel::Model\n\n attr_accessor :documents\n\n accepts_attachments_for :documents, accessor_prefix: 'documents_files', collection_class: Document\n\n def initialize(attributes = {})\n @documents = attributes[:documents] || []\n end\n end\n\n @example in form\n <%= form_for @post do |form| %>\n <%= form.attachment_field :documents_files, multiple: true %>\n <% end %>\n\n @param [Symbol] collection_name Name of the association\n @param [Class] collection_class Associated class\n @param [String] accessor_prefix Name of the generated accessors\n @param [Symbol] attachment Name of the attachment in the associated class\n @param [Boolean] append If true, new files are appended instead of replacing the entire list of associated classes.\n @return [void]", "Downloads the file to a Tempfile on disk and returns this tempfile.\n\n @example\n file = backend.upload(StringIO.new(\"hello\"))\n tempfile = file.download\n File.read(tempfile.path) # => \"hello\"\n\n @return [Tempfile] a tempfile with the file's content", "Builds a serializable hash from the response data.\n\n @return [Hash] hash that represents this response\n and can be easily serialized.\n @see Response.from_hash", "Adds a callback that will be executed around each HTTP request.\n\n @example\n VCR.configure do |c|\n c.around_http_request(lambda {|r| r.uri =~ /api.geocoder.com/}) do |request|\n # extract an address like \"1700 E Pine St, Seattle, WA\"\n # from a query like \"address=1700+E+Pine+St%2C+Seattle%2C+WA\"\n address = CGI.unescape(URI(request.uri).query.split('=').last)\n VCR.use_cassette(\"geocoding/#{address}\", &request)\n end\n end\n\n @yield the callback\n @yieldparam request [VCR::Request::FiberAware] the request that is being made\n @raise [VCR::Errors::NotSupportedError] if the fiber library cannot be loaded.\n @param filters [optional splat of #to_proc] one or more filters to apply.\n The objects provided will be converted to procs using `#to_proc`. If provided,\n the callback will only be invoked if these procs all return `true`.\n @note This method can only be used on ruby interpreters that support\n fibers (i.e. 1.9+). On 1.8 you can use separate `before_http_request` and\n `after_http_request` hooks.\n @note You _must_ call `request.proceed` or pass the request as a proc on to a\n method that yields to a block (i.e. `some_method(&request)`).\n @see #before_http_request\n @see #after_http_request", "Define a country's rules.\n\n Use the other DSL methods to define the country's rules.\n\n @param [String] country_code The country code of the country.\n @param [Phony::CountryCodes] definition Rules for this country.\n\n @return Undefined.\n\n @example Add a country with country code 27.\n country '27', # CC, followed by rules, for example fixed(2) >> ...", "National matcher & splitters.\n\n By default, a fixed length NDC\n uses a zero prefix when formatted\n with format :national.\n\n @param [Fixnum] length The length of the fixed length NDC.\n @param [Hash] options An options hash (set zero: false to not add a zero on format :national).\n\n @return NationalSplitters::Fixed A fixed length national splitter.\n\n @example France. Uses a fixed NDC of size 1.\n country '33', fixed(1) >> split(2,2,2,2)", "Add the given country to the mapping under the\n given country code.", "Splits this number into cc, ndc and locally split number parts.", "Format the number.", "Is this number plausible?", "Is the given number a vanity number?", "Split off the country and the cc, and also return the national number part.", "A number is split with the code handlers as given in the initializer.\n\n Note: If the ndc is nil, it will not return it.\n\n @return [Trunk, String (ndc), Array (national pieces)]", "Format the number, given the national part of it.", "Removes 0s from partially normalized numbers\n such as 410443643533.\n\n Example:\n 410443643533 -> 41443643533\n\n In some cases it doesn't, like Italy.", "Tests for plausibility of this national number.", "Merge the other criteria into this one.\n\n @example Merge another criteria into this criteria.\n criteria.merge(Person.where(name: \"bob\"))\n\n @param [ Criteria ] other The criteria to merge in.\n\n @return [ Criteria ] The merged criteria.\n\n @since 3.0.0", "Overriden to include _type in the fields.\n\n @example Limit the fields returned from the database.\n Band.only(:name)\n\n @param [ Array ] args The names of the fields.\n\n @return [ Criteria ] The cloned criteria.\n\n @since 1.0.0", "Set the read preference for the criteria.\n\n @example Set the read preference.\n criteria.read(mode: :primary_preferred)\n\n @param [ Hash ] value The mode preference.\n\n @return [ Criteria ] The cloned criteria.\n\n @since 5.0.0", "Returns true if criteria responds to the given method.\n\n @example Does the criteria respond to the method?\n crtiteria.respond_to?(:each)\n\n @param [ Symbol ] name The name of the class method on the +Document+.\n @param [ true, false ] include_private Whether to include privates.\n\n @return [ true, false ] If the criteria responds to the method.", "Are documents in the query missing, and are we configured to raise an\n error?\n\n @api private\n\n @example Check for missing documents.\n criteria.check_for_missing_documents!([], [ 1 ])\n\n @param [ Array ] result The result.\n @param [ Array ] ids The ids.\n\n @raise [ Errors::DocumentNotFound ] If none are found and raising an\n error.\n\n @since 3.0.0", "Clone or dup the current +Criteria+. This will return a new criteria with\n the selector, options, klass, embedded options, etc intact.\n\n @api private\n\n @example Clone a criteria.\n criteria.clone\n\n @example Dup a criteria.\n criteria.dup\n\n @param [ Criteria ] other The criteria getting cloned.\n\n @return [ nil ] nil.\n\n @since 1.0.0", "Get the selector for type selection.\n\n @api private\n\n @example Get a type selection hash.\n criteria.type_selection\n\n @return [ Hash ] The type selection.\n\n @since 3.0.3", "Takes the provided selector and atomic operations and replaces the\n indexes of the embedded documents with the positional operator when\n needed.\n\n @note The only time we can accurately know when to use the positional\n operator is at the exact time we are going to persist something. So\n we can tell by the selector that we are sending if it is actually\n possible to use the positional operator at all. For example, if the\n selector is: { \"_id\" => 1 }, then we could not use the positional\n operator for updating embedded documents since there would never be a\n match - we base whether we can based on the number of levels deep the\n selector goes, and if the id values are not nil.\n\n @example Process the operations.\n positionally(\n { \"_id\" => 1, \"addresses._id\" => 2 },\n { \"$set\" => { \"addresses.0.street\" => \"hobrecht\" }}\n )\n\n @param [ Hash ] selector The selector.\n @param [ Hash ] operations The update operations.\n @param [ Hash ] processed The processed update operations.\n\n @return [ Hash ] The new operations.\n\n @since 3.1.0", "Add the association to the touchable associations if the touch option was\n provided.\n\n @example Add the touchable.\n Model.define_touchable!(assoc)\n\n @param [ Association ] association The association metadata.\n\n @return [ Class ] The model class.\n\n @since 3.0.0", "Gets the default Mongoid logger - stdout.\n\n @api private\n\n @example Get the default logger.\n Loggable.default_logger\n\n @return [ Logger ] The default logger.\n\n @since 3.0.0", "When cloning, if the document has localized fields we need to ensure they\n are properly processed in the clone.\n\n @api private\n\n @example Process localized attributes.\n model.process_localized_attributes(attributes)\n\n @param [ Hash ] attrs The attributes.\n\n @since 3.0.20", "Get the document selector with the defined shard keys.\n\n @example Get the selector for the shard keys.\n person.shard_key_selector\n\n @return [ Hash ] The shard key selector.\n\n @since 2.0.0", "Reloads the +Document+ attributes from the database. If the document has\n not been saved then an error will get raised if the configuration option\n was set. This can reload root documents or embedded documents.\n\n @example Reload the document.\n person.reload\n\n @raise [ Errors::DocumentNotFound ] If the document was deleted.\n\n @return [ Document ] The document, reloaded.\n\n @since 1.0.0", "Reload the root document.\n\n @example Reload the document.\n document.reload_root_document\n\n @return [ Hash ] The reloaded attributes.\n\n @since 2.3.2", "Reload the embedded document.\n\n @example Reload the document.\n document.reload_embedded_document\n\n @return [ Hash ] The reloaded attributes.\n\n @since 2.3.2", "Extract only the desired embedded document from the attributes.\n\n @example Extract the embedded document.\n document.extract_embedded_attributes(attributes)\n\n @param [ Hash ] attributes The document in the db.\n\n @return [ Hash ] The document's extracted attributes.\n\n @since 2.3.2", "Determine if an attribute is present.\n\n @example Is the attribute present?\n person.attribute_present?(\"title\")\n\n @param [ String, Symbol ] name The name of the attribute.\n\n @return [ true, false ] True if present, false if not.\n\n @since 1.0.0", "Read a value from the document attributes. If the value does not exist\n it will return nil.\n\n @example Read an attribute.\n person.read_attribute(:title)\n\n @example Read an attribute (alternate syntax.)\n person[:title]\n\n @param [ String, Symbol ] name The name of the attribute to get.\n\n @return [ Object ] The value of the attribute.\n\n @since 1.0.0", "Read a value from the attributes before type cast. If the value has not\n yet been assigned then this will return the attribute's existing value\n using read_raw_attribute.\n\n @example Read an attribute before type cast.\n person.read_attribute_before_type_cast(:price)\n\n @param [ String, Symbol ] name The name of the attribute to get.\n\n @return [ Object ] The value of the attribute before type cast, if\n available. Otherwise, the value of the attribute.\n\n @since 3.1.0", "Remove a value from the +Document+ attributes. If the value does not exist\n it will fail gracefully.\n\n @example Remove the attribute.\n person.remove_attribute(:title)\n\n @param [ String, Symbol ] name The name of the attribute to remove.\n\n @raise [ Errors::ReadonlyAttribute ] If the field cannot be removed due\n to being flagged as reaodnly.\n\n @since 1.0.0", "Write a single attribute to the document attribute hash. This will\n also fire the before and after update callbacks, and perform any\n necessary typecasting.\n\n @example Write the attribute.\n person.write_attribute(:title, \"Mr.\")\n\n @example Write the attribute (alternate syntax.)\n person[:title] = \"Mr.\"\n\n @param [ String, Symbol ] name The name of the attribute to update.\n @param [ Object ] value The value to set for the attribute.\n\n @since 1.0.0", "Determine if the attribute is missing from the document, due to loading\n it from the database with missing fields.\n\n @example Is the attribute missing?\n document.attribute_missing?(\"test\")\n\n @param [ String ] name The name of the attribute.\n\n @return [ true, false ] If the attribute is missing.\n\n @since 4.0.0", "Return the typecasted value for a field.\n\n @example Get the value typecasted.\n person.typed_value_for(:title, :sir)\n\n @param [ String, Symbol ] key The field name.\n @param [ Object ] value The uncast value.\n\n @return [ Object ] The cast value.\n\n @since 1.0.0", "Validates an attribute value. This provides validation checking if\n the value is valid for given a field.\n For now, only Hash and Array fields are validated.\n\n @param [ String, Symbol ] access The name of the attribute to validate.\n @param [ Object ] value The to be validated.\n\n @since 3.0.10", "Builds a new +Document+ from the supplied attributes.\n\n @example Build the document.\n Mongoid::Factory.build(Person, { \"name\" => \"Durran\" })\n\n @param [ Class ] klass The class to instantiate from if _type is not present.\n @param [ Hash ] attributes The document attributes.\n\n @return [ Document ] The instantiated document.", "Builds a new +Document+ from the supplied attributes loaded from the\n database.\n\n If a criteria object is given, it is used in two ways:\n 1. If the criteria has a list of fields specified via #only,\n only those fields are populated in the returned document.\n 2. If the criteria has a referencing association (i.e., this document\n is being instantiated as an association of another document),\n the other document is also populated in the returned document's\n reverse association, if one exists.\n\n @example Build the document.\n Mongoid::Factory.from_db(Person, { \"name\" => \"Durran\" })\n\n @param [ Class ] klass The class to instantiate from if _type is not present.\n @param [ Hash ] attributes The document attributes.\n @param [ Criteria ] criteria Optional criteria object.\n @param [ Hash ] selected_fields Fields which were retrieved via\n #only. If selected_fields are specified, fields not listed in it\n will not be accessible in the returned document.\n\n @return [ Document ] The instantiated document.", "Add the document as an atomic pull.\n\n @example Add the atomic pull.\n person.add_atomic_pull(address)\n\n @param [ Document ] document The embedded document to pull.\n\n @since 2.2.0", "Add an atomic unset for the document.\n\n @example Add an atomic unset.\n document.add_atomic_unset(doc)\n\n @param [ Document ] document The child document.\n\n @return [ Array ] The children.\n\n @since 3.0.0", "Get all the atomic updates that need to happen for the current\n +Document+. This includes all changes that need to happen in the\n entire hierarchy that exists below where the save call was made.\n\n @note MongoDB does not allow \"conflicting modifications\" to be\n performed in a single operation. Conflicting modifications are\n detected by the 'haveConflictingMod' function in MongoDB.\n Examination of the code suggests that two modifications (a $set\n and a $push with $each, for example) conflict if:\n (1) the key paths being modified are equal.\n (2) one key path is a prefix of the other.\n So a $set of 'addresses.0.street' will conflict with a $push and $each\n to 'addresses', and we will need to split our update into two\n pieces. We do not, however, attempt to match MongoDB's logic\n exactly. Instead, we assume that two updates conflict if the\n first component of the two key paths matches.\n\n @example Get the updates that need to occur.\n person.atomic_updates(children)\n\n @return [ Hash ] The updates and their modifiers.\n\n @since 2.1.0", "Get all the attributes that need to be pulled.\n\n @example Get the pulls.\n person.atomic_pulls\n\n @return [ Array ] The $pullAll operations.\n\n @since 2.2.0", "Get all the attributes that need to be unset.\n\n @example Get the unsets.\n person.atomic_unsets\n\n @return [ Array ] The $unset operations.\n\n @since 2.2.0", "Generates the atomic updates in the correct order.\n\n @example Generate the updates.\n model.generate_atomic_updates(mods, doc)\n\n @param [ Modifiers ] mods The atomic modifications.\n @param [ Document ] doc The document to update for.\n\n @since 2.2.0", "Initialize the persistence context object.\n\n @example Create a new persistence context.\n PersistenceContext.new(model, collection: 'other')\n\n @param [ Object ] object The class or model instance for which a persistence context\n should be created.\n @param [ Hash ] opts The persistence context options.\n\n @since 6.0.0\n Get the collection for this persistence context.\n\n @example Get the collection for this persistence context.\n context.collection\n\n @param [ Object ] parent The parent object whose collection name is used\n instead of this persistence context's collection name.\n\n @return [ Mongo::Collection ] The collection for this persistence\n context.\n\n @since 6.0.0", "Get the client for this persistence context.\n\n @example Get the client for this persistence context.\n context.client\n\n @return [ Mongo::Client ] The client for this persistence\n context.\n\n @since 6.0.0", "Get all the changes for the document.\n\n @example Get all the changes.\n model.changes\n\n @return [ Hash ] The changes.\n\n @since 2.4.0", "Call this method after save, so the changes can be properly switched.\n\n This will unset the memoized children array, set new record to\n false, set the document as validated, and move the dirty changes.\n\n @example Move the changes to previous.\n person.move_changes\n\n @since 2.1.0", "Get the old and new value for the provided attribute.\n\n @example Get the attribute change.\n model.attribute_change(\"name\")\n\n @param [ String ] attr The name of the attribute.\n\n @return [ Array ] The old and new values.\n\n @since 2.1.0", "Determine if a specific attribute has changed.\n\n @example Has the attribute changed?\n model.attribute_changed?(\"name\")\n\n @param [ String ] attr The name of the attribute.\n\n @return [ true, false ] Whether the attribute has changed.\n\n @since 2.1.6", "Get whether or not the field has a different value from the default.\n\n @example Is the field different from the default?\n model.attribute_changed_from_default?\n\n @param [ String ] attr The name of the attribute.\n\n @return [ true, false ] If the attribute differs.\n\n @since 3.0.0", "Get the previous value for the attribute.\n\n @example Get the previous value.\n model.attribute_was(\"name\")\n\n @param [ String ] attr The attribute name.\n\n @since 2.4.0", "Flag an attribute as going to change.\n\n @example Flag the attribute.\n model.attribute_will_change!(\"name\")\n\n @param [ String ] attr The name of the attribute.\n\n @return [ Object ] The old value.\n\n @since 2.3.0", "Set the attribute back to its old value.\n\n @example Reset the attribute.\n model.reset_attribute!(\"name\")\n\n @param [ String ] attr The name of the attribute.\n\n @return [ Object ] The old value.\n\n @since 2.4.0", "Use the application configuration to get every model and require it, so\n that indexing and inheritance work in both development and production\n with the same results.\n\n @example Load all the application models.\n Rails::Mongoid.load_models(app)\n\n @param [ Application ] app The rails application.", "I don't want to mock out kernel for unit testing purposes, so added this\n method as a convenience.\n\n @example Load the model.\n Mongoid.load_model(\"/mongoid/behavior\")\n\n @param [ String ] file The base filename.\n\n @since 2.0.0.rc.3", "Applies a single default value for the given name.\n\n @example Apply a single default.\n model.apply_default(\"name\")\n\n @param [ String ] name The name of the field.\n\n @since 2.4.0", "Post process the persistence operation.\n\n @api private\n\n @example Post process the persistence operation.\n document.post_process_persist(true)\n\n @param [ Object ] result The result of the operation.\n @param [ Hash ] options The options.\n\n @return [ true ] true.\n\n @since 4.0.0", "Process the atomic operations - this handles the common behavior of\n iterating through each op, getting the aliased field name, and removing\n appropriate dirty changes.\n\n @api private\n\n @example Process the atomic operations.\n document.process_atomic_operations(pulls) do |field, value|\n ...\n end\n\n @param [ Hash ] operations The atomic operations.\n\n @return [ Hash ] The operations.\n\n @since 4.0.0", "If we are in an atomically block, add the operations to the delayed group,\n otherwise persist immediately.\n\n @api private\n\n @example Persist immediately or delay the operations.\n document.persist_or_delay_atomic_operation(ops)\n\n @param [ Hash ] operation The operation.\n\n @since 4.0.0", "Persist the atomic operations.\n\n @api private\n\n @example Persist the atomic operations.\n persist_atomic_operations(ops)\n\n @param [ Hash ] operations The atomic operations.\n\n @since 4.0.0", "Gets the document as a serializable hash, used by ActiveModel's JSON\n serializer.\n\n @example Get the serializable hash.\n document.serializable_hash\n\n @example Get the serializable hash with options.\n document.serializable_hash(:include => :addresses)\n\n @param [ Hash ] options The options to pass.\n\n @option options [ Symbol ] :include What associations to include.\n @option options [ Symbol ] :only Limit the fields to only these.\n @option options [ Symbol ] :except Dont include these fields.\n @option options [ Symbol ] :methods What methods to include.\n\n @return [ Hash ] The document, ready to be serialized.\n\n @since 2.0.0.rc.6", "Get the names of all fields that will be serialized.\n\n @api private\n\n @example Get all the field names.\n document.send(:field_names)\n\n @return [ Array ] The names of the fields.\n\n @since 3.0.0", "Serialize a single attribute. Handles associations, fields, and dynamic\n attributes.\n\n @api private\n\n @example Serialize the attribute.\n document.serialize_attribute({}, \"id\" , [ \"id\" ])\n\n @param [ Hash ] attrs The attributes.\n @param [ String ] name The attribute name.\n @param [ Array ] names The names of all attributes.\n @param [ Hash ] options The options.\n\n @return [ Object ] The attribute.\n\n @since 3.0.0", "For each of the provided include options, get the association needed and\n provide it in the hash.\n\n @example Serialize the included associations.\n document.serialize_relations({}, :include => :addresses)\n\n @param [ Hash ] attributes The attributes to serialize.\n @param [ Hash ] options The serialization options.\n\n @option options [ Symbol ] :include What associations to include\n @option options [ Symbol ] :only Limit the fields to only these.\n @option options [ Symbol ] :except Dont include these fields.\n\n @since 2.0.0.rc.6", "Since the inclusions can be a hash, symbol, or array of symbols, this is\n provided as a convenience to parse out the names.\n\n @example Get the association names.\n document.relation_names(:include => [ :addresses ])\n\n @param [ Hash, Symbol, Array ] inclusions The inclusions.\n\n @return [ Array ] The names of the included associations.\n\n @since 2.0.0.rc.6", "Since the inclusions can be a hash, symbol, or array of symbols, this is\n provided as a convenience to parse out the options.\n\n @example Get the association options.\n document.relation_names(:include => [ :addresses ])\n\n @param [ Hash, Symbol, Array ] inclusions The inclusions.\n @param [ Hash ] options The options.\n @param [ Symbol ] name The name of the association.\n\n @return [ Hash ] The options for the association.\n\n @since 2.0.0.rc.6", "Get the current Mongoid scope.\n\n @example Get the scope.\n Threaded.current_scope(klass)\n Threaded.current_scope\n\n @param [ Klass ] klass The class type of the scope.\n\n @return [ Criteria ] The scope.\n\n @since 5.0.0", "Set the current Mongoid scope. Safe for multi-model scope chaining.\n\n @example Set the scope.\n Threaded.current_scope(scope, klass)\n\n @param [ Criteria ] scope The current scope.\n @param [ Class ] klass The current model class.\n\n @return [ Criteria ] The scope.\n\n @since 5.0.1", "Apply the default scoping to the attributes of the document, as long as\n they are not complex queries.\n\n @api private\n\n @example Apply the default scoping.\n document.apply_default_scoping\n\n @return [ true, false ] If default scoping was applied.\n\n @since 4.0.0", "Overrides the default ActiveModel behavior since we need to handle\n validations of associations slightly different than just calling the\n getter.\n\n @example Read the value.\n person.read_attribute_for_validation(:addresses)\n\n @param [ Symbol ] attr The name of the field or association.\n\n @return [ Object ] The value of the field or the association.\n\n @since 2.0.0.rc.1", "Collect all the children of this document.\n\n @example Collect all the children.\n document.collect_children\n\n @return [ Array ] The children.\n\n @since 2.4.0", "Remove a child document from this parent. If an embeds one then set to\n nil, otherwise remove from the embeds many.\n\n This is called from the +RemoveEmbedded+ persistence command.\n\n @example Remove the child.\n document.remove_child(child)\n\n @param [ Document ] child The child (embedded) document to remove.\n\n @since 2.0.0.beta.1", "After children are persisted we can call this to move all their changes\n and flag them as persisted in one call.\n\n @example Reset the children.\n document.reset_persisted_children\n\n @return [ Array ] The children.\n\n @since 2.1.0", "Returns an instance of the specified class with the attributes,\n errors, and embedded documents of the current document.\n\n @example Return a subclass document as a superclass instance.\n manager.becomes(Person)\n\n @raise [ ArgumentError ] If the class doesn't include Mongoid::Document\n\n @param [ Class ] klass The class to become.\n\n @return [ Document ] An instance of the specified class.\n\n @since 2.0.0", "Convenience method for iterating through the loaded associations and\n reloading them.\n\n @example Reload the associations.\n document.reload_relations\n\n @return [ Hash ] The association metadata.\n\n @since 2.1.6", "Get an array of inspected fields for the document.\n\n @api private\n\n @example Inspect the defined fields.\n document.inspect_fields\n\n @return [ String ] An array of pretty printed field values.\n\n @since 1.0.0", "Run the callbacks for the document. This overrides active support's\n functionality to cascade callbacks to embedded documents that have been\n flagged as such.\n\n @example Run the callbacks.\n run_callbacks :save do\n save!\n end\n\n @param [ Symbol ] kind The type of callback to execute.\n @param [ Array ] args Any options.\n\n @return [ Document ] The document\n\n @since 2.3.0", "Get all the child embedded documents that are flagged as cascadable.\n\n @example Get all the cascading children.\n document.cascadable_children(:update)\n\n @param [ Symbol ] kind The type of callback.\n\n @return [ Array ] The children.\n\n @since 2.3.0", "Determine if the child should fire the callback.\n\n @example Should the child fire the callback?\n document.cascadable_child?(:update, doc)\n\n @param [ Symbol ] kind The type of callback.\n @param [ Document ] child The child document.\n\n @return [ true, false ] If the child should fire the callback.\n\n @since 2.3.0", "Connect to the provided database name on the default client.\n\n @note Use only in development or test environments for convenience.\n\n @example Set the database to connect to.\n config.connect_to(\"mongoid_test\")\n\n @param [ String ] name The database name.\n\n @since 3.0.0", "Load the settings from a compliant mongoid.yml file. This can be used for\n easy setup with frameworks other than Rails.\n\n @example Configure Mongoid.\n Mongoid.load!(\"/path/to/mongoid.yml\")\n\n @param [ String ] path The path to the file.\n @param [ String, Symbol ] environment The environment to load.\n\n @since 2.0.1", "Register a model in the application with Mongoid.\n\n @example Register a model.\n config.register_model(Band)\n\n @param [ Class ] klass The model to register.\n\n @since 3.1.0", "From a hash of settings, load all the configuration.\n\n @example Load the configuration.\n config.load_configuration(settings)\n\n @param [ Hash ] settings The configuration settings.\n\n @since 3.1.0", "Truncate all data in all collections, but not the indexes.\n\n @example Truncate all collection data.\n Mongoid::Config.truncate!\n\n @note This will be slower than purge!\n\n @return [ true ] true.\n\n @since 2.0.2", "Set the configuration options. Will validate each one individually.\n\n @example Set the options.\n config.options = { raise_not_found_error: true }\n\n @param [ Hash ] options The configuration options.\n\n @since 3.0.0", "Responds to unauthorized requests in a manner fitting the request format.\n `js`, `json`, and `xml` requests will receive a 401 with no body. All\n other formats will be redirected appropriately and can optionally have the\n flash message set.\n\n When redirecting, the originally requested url will be stored in the\n session (`session[:return_to]`), allowing it to be used as a redirect url\n once the user has successfully signed in.\n\n If there is a signed in user, the request will be redirected according to\n the value returned from {#url_after_denied_access_when_signed_in}.\n\n If there is no signed in user, the request will be redirected according to\n the value returned from {#url_after_denied_access_when_signed_out}.\n For the exact redirect behavior, see {#redirect_request}.\n\n @param [String] flash_message", "Reads previously existing sessions from a cookie and maintains the cookie\n on each response.", "Send the user a file.\n @param file [File] The file to send to the user\n @param caption [String] The caption of the file being sent\n @param filename [String] Overrides the filename of the uploaded file\n @param spoiler [true, false] Whether or not this file should appear as a spoiler.\n @return [Message] the message sent to this user.\n @example Send a file from disk\n user.send_file(File.open('rubytaco.png', 'r'))", "Set the user's presence data\n @note for internal use only\n @!visibility private", "Checks whether this user can do the particular action, regardless of whether it has the permission defined,\n through for example being the server owner or having the Manage Roles permission\n @param action [Symbol] The permission that should be checked. See also {Permissions::FLAGS} for a list.\n @param channel [Channel, nil] If channel overrides should be checked too, this channel specifies where the overrides should be checked.\n @example Check if the bot can send messages to a specific channel in a server.\n bot_profile = bot.profile.on(event.server)\n can_send_messages = bot_profile.permission?(:send_messages, channel)\n @return [true, false] whether or not this user has the permission.", "Sets this channels parent category\n @param channel [Channel, #resolve_id] the target category channel\n @raise [ArgumentError] if the target channel isn't a category", "Sorts this channel's position to follow another channel.\n @param other [Channel, #resolve_id, nil] The channel below which this channel should be sorted. If the given\n channel is a category, this channel will be sorted at the top of that category. If it is `nil`, the channel will\n be sorted at the top of the channel list.\n @param lock_permissions [true, false] Whether the channel's permissions should be synced to the category's", "Sets whether this channel is NSFW\n @param nsfw [true, false]\n @raise [ArguementError] if value isn't one of true, false", "Sends a temporary message to this channel.\n @param content [String] The content to send. Should not be longer than 2000 characters or it will result in an error.\n @param timeout [Float] The amount of time in seconds after which the message sent will be deleted.\n @param tts [true, false] Whether or not this message should be sent using Discord text-to-speech.\n @param embed [Hash, Discordrb::Webhooks::Embed, nil] The rich embed to append to this message.", "Convenience method to send a message with an embed.\n @example Send a message with an embed\n channel.send_embed do |embed|\n embed.title = 'The Ruby logo'\n embed.image = Discordrb::Webhooks::EmbedImage.new(url: 'https://www.ruby-lang.org/images/header-ruby-logo.png')\n end\n @param message [String] The message that should be sent along with the embed. If this is the empty string, only the embed will be shown.\n @param embed [Discordrb::Webhooks::Embed, nil] The embed to start the building process with, or nil if one should be created anew.\n @yield [embed] Yields the embed to allow for easy building inside a block.\n @yieldparam embed [Discordrb::Webhooks::Embed] The embed from the parameters, or a new one.\n @return [Message] The resulting message.", "Sends a file to this channel. If it is an image, it will be embedded.\n @param file [File] The file to send. There's no clear size limit for this, you'll have to attempt it for yourself (most non-image files are fine, large images may fail to embed)\n @param caption [string] The caption for the file.\n @param tts [true, false] Whether or not this file's caption should be sent using Discord text-to-speech.\n @param filename [String] Overrides the filename of the uploaded file\n @param spoiler [true, false] Whether or not this file should appear as a spoiler.\n @example Send a file from disk\n channel.send_file(File.open('rubytaco.png', 'r'))", "Deletes a permission overwrite for this channel\n @param target [Member, User, Role, Profile, Recipient, #resolve_id] What permission overwrite to delete\n @param reason [String] The reason the for the overwrite deletion.", "Updates the cached data from another channel.\n @note For internal use only\n @!visibility private", "The list of users currently in this channel. For a voice channel, it will return all the members currently\n in that channel. For a text channel, it will return all online members that have permission to read it.\n @return [Array] the users in this channel", "Retrieves some of this channel's message history.\n @param amount [Integer] How many messages to retrieve. This must be less than or equal to 100, if it is higher\n than 100 it will be treated as 100 on Discord's side.\n @param before_id [Integer] The ID of the most recent message the retrieval should start at, or nil if it should\n start at the current message.\n @param after_id [Integer] The ID of the oldest message the retrieval should start at, or nil if it should start\n as soon as possible with the specified amount.\n @param around_id [Integer] The ID of the message retrieval should start from, reading in both directions\n @example Count the number of messages in the last 50 messages that contain the letter 'e'.\n message_count = channel.history(50).count {|message| message.content.include? \"e\"}\n @example Get the last 10 messages before the provided message.\n last_ten_messages = channel.history(10, message.id)\n @return [Array] the retrieved messages.", "Retrieves message history, but only message IDs for use with prune.\n @note For internal use only\n @!visibility private", "Returns a single message from this channel's history by ID.\n @param message_id [Integer] The ID of the message to retrieve.\n @return [Message, nil] the retrieved message, or `nil` if it couldn't be found.", "Requests all pinned messages in a channel.\n @return [Array] the received messages.", "Delete the last N messages on this channel.\n @param amount [Integer] The amount of message history to consider for pruning. Must be a value between 2 and 100 (Discord limitation)\n @param strict [true, false] Whether an error should be raised when a message is reached that is too old to be bulk\n deleted. If this is false only a warning message will be output to the console.\n @raise [ArgumentError] if the amount of messages is not a value between 2 and 100\n @yield [message] Yields each message in this channels history for filtering the messages to delete\n @example Pruning messages from a specific user ID\n channel.prune(100) { |m| m.author.id == 83283213010599936 }\n @return [Integer] The amount of messages that were successfully deleted", "Deletes a collection of messages\n @param messages [Array] the messages (or message IDs) to delete. Total must be an amount between 2 and 100 (Discord limitation)\n @param strict [true, false] Whether an error should be raised when a message is reached that is too old to be bulk\n deleted. If this is false only a warning message will be output to the console.\n @raise [ArgumentError] if the amount of messages is not a value between 2 and 100\n @return [Integer] The amount of messages that were successfully deleted", "Creates a new invite to this channel.\n @param max_age [Integer] How many seconds this invite should last.\n @param max_uses [Integer] How many times this invite should be able to be used.\n @param temporary [true, false] Whether membership should be temporary (kicked after going offline).\n @param unique [true, false] If true, Discord will always send a unique invite instead of possibly re-using a similar one\n @param reason [String] The reason the for the creation of this invite.\n @return [Invite] the created invite.", "Creates a Group channel\n @param user_ids [Array] Array of user IDs to add to the new group channel (Excluding\n the recipient of the PM channel).\n @return [Channel] the created channel.", "Adds a user to a group channel.\n @param user_ids [Array<#resolve_id>, #resolve_id] User ID or array of user IDs to add to the group channel.\n @return [Channel] the group channel.", "Removes a user from a group channel.\n @param user_ids [Array<#resolve_id>, #resolve_id] User ID or array of user IDs to remove from the group channel.\n @return [Channel] the group channel.", "Requests a list of Webhooks on the channel.\n @return [Array] webhooks on the channel.", "Requests a list of Invites to the channel.\n @return [Array] invites to the channel.", "Adds a recipient to a group channel.\n @param recipient [Recipient] the recipient to add to the group\n @raise [ArgumentError] if tried to add a non-recipient\n @note For internal use only\n @!visibility private", "Removes a recipient from a group channel.\n @param recipient [Recipient] the recipient to remove from the group\n @raise [ArgumentError] if tried to remove a non-recipient\n @note For internal use only\n @!visibility private", "Deletes a list of messages on this channel using bulk delete.", "Adds all event handlers from another container into this one. Existing event handlers will be overwritten.\n @param container [Module] A module that `extend`s {EventContainer} from which the handlers will be added.", "Updates the webhook if you need to edit more than 1 attribute.\n @param data [Hash] the data to update.\n @option data [String, #read, nil] :avatar The new avatar, in base64-encoded JPG format, or nil to delete the avatar.\n @option data [Channel, String, Integer, #resolve_id] :channel The channel the webhook should use.\n @option data [String] :name The webhook's new name.\n @option data [String] :reason The reason for the webhook changes.", "Deletes the webhook.\n @param reason [String] The reason the invite is being deleted.", "Sets the colour of the bar to the side of the embed to something new.\n @param value [Integer, String, {Integer, Integer, Integer}, #to_i, nil] The colour in decimal, hexadecimal, R/G/B decimal, or nil to clear the embeds colour\n form.", "Convenience method to add a field to the embed without having to create one manually.\n @see EmbedField\n @example Add a field to an embed, conveniently\n embed.add_field(name: 'A field', value: \"The field's content\")\n @param name [String] The field's name\n @param value [String] The field's value\n @param inline [true, false] Whether the field should be inlined", "Create a new LightBot. This does no networking yet, all networking is done by the methods on this class.\n @param token [String] The token that should be used to authenticate to Discord. Can be an OAuth token or a regular\n user account token.\n @return [LightProfile] the details of the user this bot is connected to.", "Gets the connections associated with this account.\n @return [Array] this account's connections.", "Finds an emoji by its name.\n @param name [String] The emoji name that should be resolved.\n @return [GlobalEmoji, nil] the emoji identified by the name, or `nil` if it couldn't be found.", "The bot's OAuth application.\n @return [Application, nil] The bot's application info. Returns `nil` if bot is not a bot account.", "Makes the bot join an invite to a server.\n @param invite [String, Invite] The invite to join. For possible formats see {#resolve_invite_code}.", "Sends a text message to a channel given its ID and the message's content.\n @param channel [Channel, Integer, #resolve_id] The channel to send something to.\n @param content [String] The text that should be sent as a message. It is limited to 2000 characters (Discord imposed).\n @param tts [true, false] Whether or not this message should be sent using Discord text-to-speech.\n @param embed [Hash, Discordrb::Webhooks::Embed, nil] The rich embed to append to this message.\n @return [Message] The message that was sent.", "Sends a text message to a channel given its ID and the message's content,\n then deletes it after the specified timeout in seconds.\n @param channel [Channel, Integer, #resolve_id] The channel to send something to.\n @param content [String] The text that should be sent as a message. It is limited to 2000 characters (Discord imposed).\n @param timeout [Float] The amount of time in seconds after which the message sent will be deleted.\n @param tts [true, false] Whether or not this message should be sent using Discord text-to-speech.\n @param embed [Hash, Discordrb::Webhooks::Embed, nil] The rich embed to append to this message.", "Sends a file to a channel. If it is an image, it will automatically be embedded.\n @note This executes in a blocking way, so if you're sending long files, be wary of delays.\n @param channel [Channel, Integer, #resolve_id] The channel to send something to.\n @param file [File] The file that should be sent.\n @param caption [string] The caption for the file.\n @param tts [true, false] Whether or not this file's caption should be sent using Discord text-to-speech.\n @param filename [String] Overrides the filename of the uploaded file\n @param spoiler [true, false] Whether or not this file should appear as a spoiler.\n @example Send a file from disk\n bot.send_file(83281822225530880, File.open('rubytaco.png', 'r'))", "Creates a server on Discord with a specified name and a region.\n @note Discord's API doesn't directly return the server when creating it, so this method\n waits until the data has been received via the websocket. This may make the execution take a while.\n @param name [String] The name the new server should have. Doesn't have to be alphanumeric.\n @param region [Symbol] The region where the server should be created, for example 'eu-central' or 'hongkong'.\n @return [Server] The server that was created.", "Changes information about your OAuth application\n @param name [String] What your application should be called.\n @param redirect_uris [Array] URIs that Discord should redirect your users to after authorizing.\n @param description [String] A string that describes what your application does.\n @param icon [String, nil] A data URI for your icon image (for example a base 64 encoded image), or nil if no icon\n should be set or changed.", "Gets the users, channels, roles and emoji from a string.\n @param mentions [String] The mentions, which should look like `<@12314873129>`, `<#123456789>`, `<@&123456789>` or `<:name:126328:>`.\n @param server [Server, nil] The server of the associated mentions. (recommended for role parsing, to speed things up)\n @return [Array] The array of users, channels, roles and emoji identified by the mentions, or `nil` if none exists.", "Updates presence status.\n @param status [String] The status the bot should show up as. Can be `online`, `dnd`, `idle`, or `invisible`\n @param activity [String, nil] The name of the activity to be played/watched/listened to/stream name on the stream.\n @param url [String, nil] The Twitch URL to display as a stream. nil for no stream.\n @param since [Integer] When this status was set.\n @param afk [true, false] Whether the bot is AFK.\n @param activity_type [Integer] The type of activity status to display. Can be 0 (Playing), 1 (Streaming), 2 (Listening), 3 (Watching)\n @see Gateway#send_status_update", "Awaits an event, blocking the current thread until a response is received.\n @param type [Class] The event class that should be listened for.\n @option attributes [Numeric] :timeout the amount of time to wait for a response before returning `nil`. Waits forever if omitted.\n @return [Event, nil] The event object that was triggered, or `nil` if a `timeout` was set and no event was raised in time.\n @raise [ArgumentError] if `timeout` is given and is not a positive numeric value", "Makes the bot leave any groups with no recipients remaining", "Internal handler for VOICE_STATE_UPDATE", "Internal handler for VOICE_SERVER_UPDATE", "Internal handler for CHANNEL_CREATE", "Internal handler for CHANNEL_UPDATE", "Internal handler for CHANNEL_DELETE", "Internal handler for CHANNEL_RECIPIENT_ADD", "Internal handler for GUILD_MEMBER_ADD", "Internal handler for GUILD_MEMBER_UPDATE", "Internal handler for GUILD_MEMBER_DELETE", "Internal handler for GUILD_ROLE_UPDATE", "Internal handler for GUILD_ROLE_CREATE", "Internal handler for GUILD_ROLE_DELETE", "Internal handler for GUILD_EMOJIS_UPDATE", "Returns or caches the available voice regions", "Gets a channel given its ID. This queries the internal channel cache, and if the channel doesn't\n exist in there, it will get the data from Discord.\n @param id [Integer] The channel ID for which to search for.\n @param server [Server] The server for which to search the channel for. If this isn't specified, it will be\n inferred using the API\n @return [Channel] The channel identified by the ID.", "Gets a user by its ID.\n @note This can only resolve users known by the bot (i.e. that share a server with the bot).\n @param id [Integer] The user ID that should be resolved.\n @return [User, nil] The user identified by the ID, or `nil` if it couldn't be found.", "Gets a server by its ID.\n @note This can only resolve servers the bot is currently in.\n @param id [Integer] The server ID that should be resolved.\n @return [Server, nil] The server identified by the ID, or `nil` if it couldn't be found.", "Gets a member by both IDs, or `Server` and user ID.\n @param server_or_id [Server, Integer] The `Server` or server ID for which a member should be resolved\n @param user_id [Integer] The ID of the user that should be resolved\n @return [Member, nil] The member identified by the IDs, or `nil` if none could be found", "Ensures a given user object is cached and if not, cache it from the given data hash.\n @param data [Hash] A data hash representing a user.\n @return [User] the user represented by the data hash.", "Ensures a given server object is cached and if not, cache it from the given data hash.\n @param data [Hash] A data hash representing a server.\n @return [Server] the server represented by the data hash.", "Ensures a given channel object is cached and if not, cache it from the given data hash.\n @param data [Hash] A data hash representing a channel.\n @param server [Server, nil] The server the channel is on, if known.\n @return [Channel] the channel represented by the data hash.", "Gets information about an invite.\n @param invite [String, Invite] The invite to join. For possible formats see {#resolve_invite_code}.\n @return [Invite] The invite with information about the given invite URL.", "Finds a channel given its name and optionally the name of the server it is in.\n @param channel_name [String] The channel to search for.\n @param server_name [String] The server to search for, or `nil` if only the channel should be searched for.\n @param type [Integer, nil] The type of channel to search for (0: text, 1: private, 2: voice, 3: group), or `nil` if any type of\n channel should be searched for\n @return [Array] The array of channels that were found. May be empty if none were found.", "Finds a user given its username or username & discriminator.\n @overload find_user(username)\n Find all cached users with a certain username.\n @param username [String] The username to look for.\n @return [Array] The array of users that were found. May be empty if none were found.\n @overload find_user(username, discrim)\n Find a cached user with a certain username and discriminator.\n Find a user by name and discriminator\n @param username [String] The username to look for.\n @param discrim [String] The user's discriminator\n @return [User, nil] The user that was found, or `nil` if none was found\n @note This method only searches through users that have been cached. Users that have not yet been cached\n by the bot but still share a connection with the user (mutual server) will not be found.\n @example Find users by name\n bot.find_user('z64') #=> Array\n @example Find a user by name and discriminator\n bot.find_user('z64', '2639') #=> User", "Edits this message to have the specified content instead.\n You can only edit your own messages.\n @param new_content [String] the new content the message should have.\n @param new_embed [Hash, Discordrb::Webhooks::Embed, nil] The new embed the message should have. If `nil` the message will be changed to have no embed.\n @return [Message] the resulting message.", "Reacts to a message.\n @param reaction [String, #to_reaction] the unicode emoji or {Emoji}", "Returns the list of users who reacted with a certain reaction.\n @param reaction [String, #to_reaction] the unicode emoji or {Emoji}\n @param limit [Integer] the limit of how many users to retrieve. `nil` will return all users\n @example Get all the users that reacted with a thumbsup.\n thumbs_up_reactions = message.reacted_with(\"\\u{1F44D}\")\n @return [Array] the users who used this reaction", "Deletes a reaction made by a user on this message.\n @param user [User, #resolve_id] the user who used this reaction\n @param reaction [String, #to_reaction] the reaction to remove", "Deletes this client's reaction on this message.\n @param reaction [String, #to_reaction] the reaction to remove", "Process user objects given by the request\n @note For internal use only\n @!visibility private", "Process webhook objects given by the request\n @note For internal use only\n @!visibility private", "Divides the command chain into chain arguments and command chain, then executes them both.\n @param event [CommandEvent] The event to execute the command with.\n @return [String] the result of the command chain execution.", "Updates the data cache from another Role object\n @note For internal use only\n @!visibility private", "Updates the data cache from a hash containing data\n @note For internal use only\n @!visibility private", "Changes this role's permissions to a fixed bitfield. This allows setting multiple permissions at once with just\n one API call.\n\n Information on how this bitfield is structured can be found at\n https://discordapp.com/developers/docs/topics/permissions.\n @example Remove all permissions from a role\n role.packed = 0\n @param packed [Integer] A bitfield with the desired permissions value.\n @param update_perms [true, false] Whether the internal data should also be updated. This should always be true\n when calling externally.", "Moves this role above another role in the list.\n @param other [Role, #resolve_id, nil] The role above which this role should be moved. If it is `nil`,\n the role will be moved above the @everyone role.\n @return [Integer] the new position of this role", "Bulk sets a member's roles.\n @param role [Role, Array] The role(s) to set.\n @param reason [String] The reason the user's roles are being changed.", "Adds and removes roles from a member.\n @param add [Role, Array] The role(s) to add.\n @param remove [Role, Array] The role(s) to remove.\n @param reason [String] The reason the user's roles are being changed.\n @example Remove the 'Member' role from a user, and add the 'Muted' role to them.\n to_add = server.roles.find {|role| role.name == 'Muted'}\n to_remove = server.roles.find {|role| role.name == 'Member'}\n member.modify_roles(to_add, to_remove)", "Adds one or more roles to this member.\n @param role [Role, Array, #resolve_id] The role(s) to add.\n @param reason [String] The reason the user's roles are being changed.", "Removes one or more roles from this member.\n @param role [Role, Array] The role(s) to remove.\n @param reason [String] The reason the user's roles are being changed.", "Sets or resets this member's nickname. Requires the Change Nickname permission for the bot itself and Manage\n Nicknames for other users.\n @param nick [String, nil] The string to set the nickname to, or nil if it should be reset.\n @param reason [String] The reason the user's nickname is being changed.", "Update this member's roles\n @note For internal use only.\n @!visibility private", "Executes a particular command on the bot. Mostly useful for internal stuff, but one can never know.\n @param name [Symbol] The command to execute.\n @param event [CommandEvent] The event to pass to the command.\n @param arguments [Array] The arguments to pass to the command.\n @param chained [true, false] Whether or not it should be executed as part of a command chain. If this is false,\n commands that have chain_usable set to false will not work.\n @param check_permissions [true, false] Whether permission parameters such as `required_permission` or\n `permission_level` should be checked.\n @return [String, nil] the command's result, if there is any.", "Executes a command in a simple manner, without command chains or permissions.\n @param chain [String] The command with its arguments separated by spaces.\n @param event [CommandEvent] The event to pass to the command.\n @return [String, nil] the command's result, if there is any.", "Check if a user has permission to do something\n @param user [User] The user to check\n @param level [Integer] The minimum permission level the user should have (inclusive)\n @param server [Server] The server on which to check\n @return [true, false] whether or not the user has the given permission", "Internal handler for MESSAGE_CREATE that is overwritten to allow for command handling", "Check whether a message should trigger command execution, and if it does, return the raw chain", "Stops the current playback entirely.\n @param wait_for_confirmation [true, false] Whether the method should wait for confirmation from the playback\n method that the playback has actually stopped.", "Plays a stream of audio data in the DCA format. This format has the advantage that no recoding has to be\n done - the file contains the data exactly as Discord needs it.\n @note DCA playback will not be affected by the volume modifier ({#volume}) because the modifier operates on raw\n PCM, not opus data. Modifying the volume of DCA data would involve decoding it, multiplying the samples and\n re-encoding it, which defeats its entire purpose (no recoding).\n @see https://github.com/bwmarrin/dca\n @see #play", "Plays the data from the @io stream as Discord requires it", "Create a new webhook\n @param url [String] The URL to post messages to.\n @param id [Integer] The webhook's ID. Will only be used if `url` is not\n set.\n @param token [String] The webhook's authorisation token. Will only be used\n if `url` is not set.\n Executes the webhook this client points to with the given data.\n @param builder [Builder, nil] The builder to start out with, or nil if one should be created anew.\n @param wait [true, false] Whether Discord should wait for the message to be successfully received by clients, or\n whether it should return immediately after sending the message.\n @yield [builder] Gives the builder to the block to add additional steps, or to do the entire building process.\n @yieldparam builder [Builder] The builder given as a parameter which is used as the initial step to start from.\n @example Execute the webhook with an already existing builder\n builder = Discordrb::Webhooks::Builder.new # ...\n client.execute(builder)\n @example Execute the webhook by building a new message\n client.execute do |builder|\n builder.content = 'Testing'\n builder.username = 'discordrb'\n builder.add_embed do |embed|\n embed.timestamp = Time.now\n embed.title = 'Testing'\n embed.image = Discordrb::Webhooks::EmbedImage.new(url: 'https://i.imgur.com/PcMltU7.jpg')\n end\n end\n @return [RestClient::Response] the response returned by Discord.", "Makes a new await. For internal use only.\n @!visibility private\n Checks whether the await can be triggered by the given event, and if it can, execute the block\n and return its result along with this await's key.\n @param event [Event] An event to check for.\n @return [Array] This await's key and whether or not it should be deleted. If there was no match, both are nil.", "Drains the currently saved message into a result string. This prepends it before that string, clears the saved\n message and returns the concatenation.\n @param result [String] The result string to drain into.\n @return [String] a string formed by concatenating the saved message and the argument.", "Attaches a file to the message event and converts the message into\n a caption.\n @param file [File] The file to be attached\n @param filename [String] Overrides the filename of the uploaded file\n @param spoiler [true, false] Whether or not this file should appear as a spoiler.", "Gets a role on this server based on its ID.\n @param id [Integer, String, #resolve_id] The role ID to look for.", "Gets a member on this server based on user ID\n @param id [Integer] The user ID to look for\n @param request [true, false] Whether the member should be requested from Discord if it's not cached", "Returns the amount of members that are candidates for pruning\n @param days [Integer] the number of days to consider for inactivity\n @return [Integer] number of members to be removed\n @raise [ArgumentError] if days is not between 1 and 30 (inclusive)", "Removes a role from the role cache\n @note For internal use only\n @!visibility private", "Updates the positions of all roles on the server\n @note For internal use only\n @!visibility private", "Updates a member's voice state\n @note For internal use only\n @!visibility private", "Creates a role on this server which can then be modified. It will be initialized\n with the regular role defaults the client uses unless specified, i.e. name is \"new role\",\n permissions are the default, colour is the default etc.\n @param name [String] Name of the role to create\n @param colour [Integer, ColourRGB, #combined] The roles colour\n @param hoist [true, false]\n @param mentionable [true, false]\n @param permissions [Integer, Array, Permissions, #bits] The permissions to write to the new role.\n @param reason [String] The reason the for the creation of this role.\n @return [Role] the created role.", "Adds a new custom emoji on this server.\n @param name [String] The name of emoji to create.\n @param image [String, #read] A base64 encoded string with the image data, or an object that responds to `#read`, such as `File`.\n @param roles [Array] An array of roles, or role IDs to be whitelisted for this emoji.\n @param reason [String] The reason the for the creation of this emoji.\n @return [Emoji] The emoji that has been added.", "Delete a custom emoji on this server\n @param emoji [Emoji, Integer, String] The emoji or emoji ID to be deleted.\n @param reason [String] The reason the for the deletion of this emoji.", "Bans a user from this server.\n @param user [User, #resolve_id] The user to ban.\n @param message_days [Integer] How many days worth of messages sent by the user should be deleted.\n @param reason [String] The reason the user is being banned.", "Unbans a previously banned user from this server.\n @param user [User, #resolve_id] The user to unban.\n @param reason [String] The reason the user is being unbanned.", "Kicks a user from this server.\n @param user [User, #resolve_id] The user to kick.\n @param reason [String] The reason the user is being kicked.", "Forcibly moves a user into a different voice channel. Only works if the bot has the permission needed.\n @param user [User, #resolve_id] The user to move.\n @param channel [Channel, #resolve_id] The voice channel to move into.", "Sets the server's icon.\n @param icon [String, #read] The new icon, in base64-encoded JPG format.", "Sets the verification level of the server\n @param level [Integer, Symbol] The verification level from 0-4 or Symbol (see {VERIFICATION_LEVELS})", "Sets the default message notification level\n @param notification_level [Integer, Symbol] The default message notificiation 0-1 or Symbol (see {NOTIFICATION_LEVELS})", "Sets the server content filter.\n @param filter_level [Integer, Symbol] The content filter from 0-2 or Symbol (see {FILTER_LEVELS})", "Requests a list of Webhooks on the server.\n @return [Array] webhooks on the server.", "Requests a list of Invites to the server.\n @return [Array] invites to the server.", "Processes a GUILD_MEMBERS_CHUNK packet, specifically the members field\n @note For internal use only\n @!visibility private", "Adjusts the volume of a given buffer of s16le PCM data.\n @param buf [String] An unencoded PCM (s16le) buffer.\n @param mult [Float] The volume multiplier, 1 for same volume.\n @return [String] The buffer with adjusted volume, s16le again", "Adds a new command to the container.\n @param name [Symbol, Array] The name of the command to add, or an array of multiple names for the command\n @param attributes [Hash] The attributes to initialize the command with.\n @option attributes [Integer] :permission_level The minimum permission level that can use this command, inclusive.\n See {CommandBot#set_user_permission} and {CommandBot#set_role_permission}.\n @option attributes [String, false] :permission_message Message to display when a user does not have sufficient\n permissions to execute a command. %name% in the message will be replaced with the name of the command. Disable\n the message by setting this option to false.\n @option attributes [Array] :required_permissions Discord action permissions (e.g. `:kick_members`) that\n should be required to use this command. See {Discordrb::Permissions::FLAGS} for a list.\n @option attributes [Array, Array<#resolve_id>] :required_roles Roles that user must have to use this command\n (user must have all of them).\n @option attributes [Array, Array<#resolve_id>] :allowed_roles Roles that user should have to use this command\n (user should have at least one of them).\n @option attributes [Array] :channels The channels that this command can be used on. An\n empty array indicates it can be used on any channel. Supersedes the command bot attribute.\n @option attributes [true, false] :chain_usable Whether this command is able to be used inside of a command chain\n or sub-chain. Typically used for administrative commands that shouldn't be done carelessly.\n @option attributes [true, false] :help_available Whether this command is visible in the help command. See the\n :help_command attribute of {CommandBot#initialize}.\n @option attributes [String] :description A short description of what this command does. Will be shown in the help\n command if the user asks for it.\n @option attributes [String] :usage A short description of how this command should be used. Will be displayed in\n the help command or if the user uses it wrong.\n @option attributes [Array] :arg_types An array of argument classes which will be used for type-checking.\n Hard-coded for some native classes, but can be used with any class that implements static\n method `from_argument`.\n @option attributes [Integer] :min_args The minimum number of arguments this command should have. If a user\n attempts to call the command with fewer arguments, the usage information will be displayed, if it exists.\n @option attributes [Integer] :max_args The maximum number of arguments the command should have.\n @option attributes [String] :rate_limit_message The message that should be displayed if the command hits a rate\n limit. None if unspecified or nil. %time% in the message will be replaced with the time in seconds when the\n command will be available again.\n @option attributes [Symbol] :bucket The rate limit bucket that should be used for rate limiting. No rate limiting\n will be done if unspecified or nil.\n @option attributes [String, #call] :rescue A string to respond with, or a block to be called in the event an exception\n is raised internally. If given a String, `%exception%` will be substituted with the exception's `#message`. If given\n a `Proc`, it will be passed the `CommandEvent` along with the `Exception`.\n @yield The block is executed when the command is executed.\n @yieldparam event [CommandEvent] The event of the message that contained the command.\n @note `LocalJumpError`s are rescued from internally, giving bots the opportunity to use `return` or `break` in\n their blocks without propagating an exception.\n @return [Command] The command that was added.\n @deprecated The command name argument will no longer support arrays in the next release.\n Use the `aliases` attribute instead.", "Changes the bot's avatar.\n @param avatar [String, #read] A JPG file to be used as the avatar, either\n something readable (e.g. File Object) or as a data URL.", "Creates a new UDP connection. Only creates a socket as the discovery reply may come before the data is\n initialized.\n Initializes the UDP socket with data obtained from opcode 2.\n @param endpoint [String] The voice endpoint to connect to.\n @param port [Integer] The port to connect to.\n @param ssrc [Integer] The Super Secret Relay Code (SSRC). Discord uses this to identify different voice users\n on the same endpoint.", "Waits for a UDP discovery reply, and returns the sent data.\n @return [Array(String, Integer)] the IP and port received from the discovery reply.", "Makes an audio packet from a buffer and sends it to Discord.\n @param buf [String] The audio data to send, must be exactly one Opus frame\n @param sequence [Integer] The packet sequence number, incremented by one for subsequent packets\n @param time [Integer] When this packet should be played back, in no particular unit (essentially just the\n sequence number multiplied by 960)", "Encrypts audio data using RbNaCl\n @param header [String] The header of the packet, to be used as the nonce\n @param buf [String] The encoded audio data to be encrypted\n @return [String] the audio data, encrypted", "Performs a rate limit request.\n @param key [Symbol] Which bucket to perform the request for.\n @param thing [#resolve_id, Integer, Symbol] What should be rate-limited.\n @param increment (see Bucket#rate_limited?)\n @see Bucket#rate_limited?\n @return [Integer, false] How much time to wait or false if the request succeeded.", "Makes a new bucket\n @param limit [Integer, nil] How many requests the user may perform in the given time_span, or nil if there should be no limit.\n @param time_span [Integer, nil] The time span after which the request count is reset, in seconds, or nil if the bucket should never be reset. (If this is nil, limit should be nil too)\n @param delay [Integer, nil] The delay for which the user has to wait after performing a request, in seconds, or nil if the user shouldn't have to wait.\n Cleans the bucket, removing all elements that aren't necessary anymore\n @param rate_limit_time [Time] The time to base the cleaning on, only useful for testing.", "Performs a rate limiting request\n @param thing [#resolve_id, Integer, Symbol] The particular thing that should be rate-limited (usually a user/channel, but you can also choose arbitrary integers or symbols)\n @param rate_limit_time [Time] The time to base the rate limiting on, only useful for testing.\n @param increment [Integer] How much to increment the rate-limit counter. Default is 1.\n @return [Integer, false] the waiting time until the next request, in seconds, or false if the request succeeded", "Connect to the gateway server in a separate thread", "Sends a custom packet over the connection. This can be useful to implement future yet unimplemented functionality\n or for testing. You probably shouldn't use this unless you know what you're doing.\n @param opcode [Integer] The opcode the packet should be sent as. Can be one of {Opcodes} or a custom value if\n necessary.\n @param packet [Object] Some arbitrary JSON-serialisable data that should be sent as the `d` field.", "Create and connect a socket using a URI", "Gets the target schema of a link. This is normally just the standard\n response schema, but we allow some legacy behavior for hyper-schema links\n tagged with rel=instances to instead use the schema of their parent\n resource.", "A single name according to gender parameter", "Mobile prefixes are in the 015x, 016x, 017x ranges", "Runs `identify` on the current image, and raises an error if it doesn't\n pass.\n\n @raise [MiniMagick::Invalid]", "This is used to change the format of the image. That is, from \"tiff to\n jpg\" or something like that. Once you run it, the instance is pointing to\n a new file with a new extension!\n\n *DANGER*: This renames the file that the instance is pointing to. So, if\n you manually opened the file with Image.new(file_path)... Then that file\n is DELETED! If you used Image.open(file) then you are OK. The original\n file will still be there. But, any changes to it might not be...\n\n Formatting an animation into a non-animated type will result in\n ImageMagick creating multiple pages (starting with 0). You can choose\n which page you want to manipulate. We default to the first page.\n\n If you would like to convert between animated formats, pass nil as your\n page and ImageMagick will copy all of the pages.\n\n @param format [String] The target format... Like 'jpg', 'gif', 'tiff' etc.\n @param page [Integer] If this is an animated gif, say which 'page' you\n want with an integer. Default 0 will convert only the first page; 'nil'\n will convert all pages.\n @param read_opts [Hash] Any read options to be passed to ImageMagick\n for example: image.format('jpg', page, {density: '300'})\n @yield [MiniMagick::Tool::Convert] It optionally yields the command,\n if you want to add something.\n @return [self]", "Runs `identify` on itself. Accepts an optional block for adding more\n options to `identify`.\n\n @example\n image = MiniMagick::Image.open(\"image.jpg\")\n image.identify do |b|\n b.verbose\n end # runs `identify -verbose image.jpg`\n @return [String] Output from `identify`\n @yield [MiniMagick::Tool::Identify]", "Redact sensitive info from provided data", "Splits a header value +str+ according to HTTP specification.", "Escapes HTTP reserved and unwise characters in +str+", "Unescapes HTTP reserved and unwise characters in +str+", "Unescape form encoded values in +str+", "Sends the supplied request to the destination host.\n @yield [chunk] @see Response#self.parse\n @param [Hash] params One or more optional params, override defaults set in Connection.new\n @option params [String] :body text to be sent over a socket\n @option params [Hash] :headers The default headers to supply in a request\n @option params [String] :path appears after 'scheme://host:port/'\n @option params [Hash] :query appended to the 'scheme://host:port/path/' in the form of '?key=value'", "Sends the supplied requests to the destination host using pipelining.\n @pipeline_params [Array] pipeline_params An array of one or more optional params, override defaults set in Connection.new, see #request for details", "Sends the supplied requests to the destination host using pipelining in\n batches of @limit [Numeric] requests. This is your soft file descriptor\n limit by default, typically 256.\n @pipeline_params [Array] pipeline_params An array of one or more optional params, override defaults set in Connection.new, see #request for details", "Start the aruba console\n\n rubocop:disable Metrics/MethodLength", "Make deep dup copy of configuration", "Define or run before-hook\n\n @param [Symbol, String] name\n The name of the hook\n\n @param [Proc] context\n The context a hook should run in. This is a runtime only option.\n\n @param [Array] args\n Arguments for the run of hook. This is a runtime only option.\n\n @yield\n The code block which should be run. This is a configure time only option", "Broadcast an event\n\n @param [Object] event\n An object of registered event class. This object is passed to the event\n handler.", "The path to the directory which contains fixtures\n You might want to overwrite this method to place your data else where.\n\n @return [ArubaPath]\n The directory to where your fixtures are stored", "Create files etc.", "Create store\n Add new hook\n\n @param [String, Symbol] label\n The name of the hook\n\n @param [Proc] block\n The block which should be run for the hook", "Find all files for which the block yields.", "Find unique keys in redis\n\n @param [String] pattern a pattern to scan for in redis\n @param [Integer] count the maximum number of keys to delete\n @return [Array