// CFG: CRUNCHER-BUFFER-STACKER-CLASS
$cfg->setConfigEntry('cruncher_buffer_stacker_class', 'FiFoStacker');
-// CFG: PRODUCER-OUTGOING-WORK-QUEUE
-$cfg->setConfigEntry('producer_outgoing_work_queue', 'FiFoStacker');
+// CFG: PRODUCER-OUTGOING-QUEUE
+$cfg->setConfigEntry('producer_outgoing_queue', 'FiFoStacker');
+
+// CFG: PRODUCER-INCOMING-QUEUE
+$cfg->setConfigEntry('producer_incoming_queue', 'FiFoStacker');
// CFG: STACKER-ANNOUNCEMENT-MAX-SIZE
$cfg->setConfigEntry('stacker_announcement_max_size', 20);
// CFG: STACKER-OBJECT-REGISTRY-MAX-SIZE
$cfg->setConfigEntry('stacker_object_registry_max_size', 100);
-// CFG: STACKER-WORK-QUEUE-MAX-SIZE
-$cfg->setConfigEntry('stacker_work_queue_max_size', 1000);
+// CFG: STACKER-OUTGOING-QUEUE-MAX-SIZE
+$cfg->setConfigEntry('stacker_outgoing_queue_max_size', 100000);
+
+// CFG: STACKER-INCOMING-QUEUE-MAX-SIZE
+$cfg->setConfigEntry('stacker_incoming_queue_max_size', 100000);
// CFG: NEWS-MAIN-LIMIT
$cfg->setConfigEntry('news_main_limit', 5);
// CFG: TASK-HANDLER-CLASS
$cfg->setConfigEntry('task_handler_class', 'TaskHandler');
-// CFG: TASK-NETWORK-PACKAGE-READER-STARTUP-DELAY
-$cfg->setConfigEntry('task_network_package_reader_startup_delay', 2000);
-
-// CFG: TASK-NETWORK-PACKAGE-READER-INTERVAL-DELAY
-$cfg->setConfigEntry('task_network_package_reader_interval_delay', 10);
-
-// CFG: TASK-NETWORK-PACKAGE-READER-MAX-RUNS
-$cfg->setConfigEntry('task_network_package_reader_max_runs', 0);
-
// CFG: TASK-QUERY-HANDLER-STARTUP-DELAY
$cfg->setConfigEntry('task_query_handler_startup_delay', 1000);
// CFG: HUB-PACKAGE-WRITER-TASK-CLASS
$cfg->setConfigEntry('hub_package_writer_task_class', 'NetworkPackageWriterTask');
+// CFG: HUB-PACKAGE-READER-TASK-CLASS
+$cfg->setConfigEntry('hub_package_reader_task_class', 'NetworkPackageReaderTask');
+
+// CFG: HUB-SOCKET-LISTENER-TASK-CLASS
+$cfg->setConfigEntry('hub_socket_listener_task_class', 'HubSocketListenerTask');
+
// CFG: CRUNCHER-WORK-UNIT-FETCHER-TASK-CLASS
$cfg->setConfigEntry('cruncher_work_unit_fetcher_task_class', 'CruncherWorkUnitFetcherTask');
// CFG: CRUNCHER-TEST-UNIT-PRODUCER-TASK-CLASS
$cfg->setConfigEntry('cruncher_test_unit_producer_task_class', 'CruncherTestUnitProducerTask');
+// CFG: CRUNCHER-KEY-PRODUCER-TASK-CLASS
+$cfg->setConfigEntry('cruncher_key_producer_task_class', 'CruncherKeyProducerTask');
+
// CFG: TASK-NETWORK-PACKAGE-WRITER-STARTUP-DELAY
$cfg->setConfigEntry('task_network_package_writer_startup_delay', 2500);
// CFG: TASK-NETWORK-PACKAGE-WRITER-MAX-RUNS
$cfg->setConfigEntry('task_network_package_writer_max_runs', 0);
+// CFG: TASK-NETWORK-PACKAGE-READER-STARTUP-DELAY
+$cfg->setConfigEntry('task_network_package_reader_startup_delay', 2000);
+
+// CFG: TASK-NETWORK-PACKAGE-READER-INTERVAL-DELAY
+$cfg->setConfigEntry('task_network_package_reader_interval_delay', 10);
+
+// CFG: TASK-NETWORK-PACKAGE-READER-MAX-RUNS
+$cfg->setConfigEntry('task_network_package_reader_max_runs', 0);
+
+// CFG: TASK-SOCKET-LISTENER-STATUP-DELAY
+$cfg->setConfigEntry('task_socket_listener_startup_delay', 2500);
+
+// CFG: TASK-SOCKET-LISTENER-INTERVAL-DELAY
+$cfg->setConfigEntry('task_socket_listener_interval_delay', 10);
+
+// CFG: TASK-SOCKET-LISTENER-MAX-RUNS
+$cfg->setConfigEntry('task_socket_listener_max_runs', 0);
+
// CFG: TASK-CRUNCHER-WORK-UNIT-FETCHER-STARTUP-DELAY
$cfg->setConfigEntry('task_cruncher_work_unit_fetcher_startup_delay', 1000);
// CFG: TASK-CRUNCHER-TEST-UNIT-PRODUCER-MAX-RUNS
$cfg->setConfigEntry('task_cruncher_test_unit_producer_max_runs', 0);
+// CFG: TASK-CRUNCHER-KEY-PRODUCER-STARTUP-DELAY
+$cfg->setConfigEntry('task_cruncher_key_producer_startup_delay', 750);
+
+// CFG: TASK-CRUNCHER-KEY-PRODUCER-INTERVAL-DELAY
+$cfg->setConfigEntry('task_cruncher_key_producer_interval_delay', 5);
+
+// CFG: TASK-CRUNCHER-KEY-PRODUCER-MAX-RUNS
+$cfg->setConfigEntry('task_cruncher_key_producer_max_runs', 0);
+
// CFG: TASK-LIST-CLASS
$cfg->setConfigEntry('task_list_class', 'TaskList');
// CFG: HUB-PING-ITERATOR-CLASS
$cfg->setConfigEntry('hub_ping_iterator_class', 'HubPingIterator');
+// CFG: TEST-UNIT-PRODUCER-KEY-ITERATOR-CLASS
+$cfg->setConfigEntry('test_unit_producer_key_iterator_class', 'TestUnitKeyProducerIterator');
+
+// CFG: WORK-UNIT-PRODUCER-KEY-ITERATOR-CLASS
+$cfg->setConfigEntry('work_unit_producer_key_iterator_class', 'WorkUnitKeyProducerIterator');
+
// CFG: LOCAL-QUERY-LIST-CLASS
$cfg->setConfigEntry('local_query_list_class', 'LocalQueryList');
// CFG: PACKAGE-FRAGMENTER-CLASS
$cfg->setConfigEntry('package_fragmenter_class', 'PackageFragmenter');
+// CFG: PACKAGE-CHUNK-SIZE
+$cfg->setConfigEntry('package_chunk_size', 256*8);
+
+// CFG: NODE-RAW-DATA-OUTPUT-STREAM-CLASS
+$cfg->setConfigEntry('node_raw_data_output_stream_class', 'RawDataOutputStream');
+
+// CFG: NODE-RAW-DATA-INPUT-STREAM-CLASS
+$cfg->setConfigEntry('node_raw_data_input_stream_class', 'RawDataInputStream');
+
+///////////////////////////////////////////////////////////////////////////////
+// Cruncher Configuration
+///////////////////////////////////////////////////////////////////////////////
+
// CFG: CRUNCHER-TEST-UNITS-ENABLED
$cfg->setConfigEntry('cruncher_test_units_enabled', 'Y');
// CFG: CRUNCHER-TEST-UNIT-PRODUCER-CLASS
$cfg->setConfigEntry('cruncher_test_unit_producer_class', 'CruncherTestUnitProducer');
+// CFG: CRUNCHER-KEY-PRODUCER-CLASS
+$cfg->setConfigEntry('cruncher_key_producer_class', 'CruncherKeyProducer');
+
// CFG: CRUNCHER-TEST-UNIT-PRODUCER-TEMPLATE-CLASS
$cfg->setConfigEntry('cruncher_test_unit_producer_template_class', 'XmlCruncherTestUnitTemplateEngine');
// CFG: CRUNCHER-RANDOM-SECRET-MESSAGE-LENGTH
$cfg->setConfigEntry('random_secret_message_length', 100);
-// CFG: CRUNCHER-RANDOM-SECRET-KEY-LENGTH
-$cfg->setConfigEntry('random_secret_key_length', 8);
+// CFG: TEST-UNIT-RANDOM-SECRET-KEY-LENGTH
+$cfg->setConfigEntry('test_unit_random_secret_key_length', 8*4);
// CFG: TEST-UNIT-SOURCE-CLASS
$cfg->setConfigEntry('test_unit_source_class', 'TestUnitSource');
// CFG: CRYPTO-RANDOM-MESSAGE-HELPER-CLASS
-$cfg->setConfigEntry('crypto_random_message_helper_class', 'CryptoRandomMessageHelper');
+$cfg->setConfigEntry('crypto_random_message_helper_class', 'CryptoRandomUnitMessageHelper');
+
+// CFG: CRUNCHER-INIT-STATE-CLASS
+$cfg->setConfigEntry('cruncher_init_state_class', 'CruncherInitState');
+
+// CFG: CRUNCHER-VIRGIN-STATE-CLASS
+$cfg->setConfigEntry('cruncher_virgin_state_class', 'CruncherVirginState');
+
+// CFG: CRUNCHER-PER-UNIT-KEY-LIMIT
+$cfg->setConfigEntry('cruncher_per_unit_key_limit', 10000);
// [EOF]
?>