Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
| 5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
| 6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 33 DEFINE_string(level_file, "level.int32", "The name of the level file."); | 33 DEFINE_string(level_file, "level.int32", "The name of the level file."); |
| 34 DEFINE_string(keypress_file, "keypress.bool", "The name of the keypress file."); | 34 DEFINE_string(keypress_file, "keypress.bool", "The name of the keypress file."); |
| 35 DEFINE_string(settings_file, "settings.txt", "The name of the settings file."); | 35 DEFINE_string(settings_file, "settings.txt", "The name of the settings file."); |
| 36 DEFINE_bool(full, false, | 36 DEFINE_bool(full, false, |
| 37 "Unpack the full set of files (normally not needed)."); | 37 "Unpack the full set of files (normally not needed)."); |
| 38 DEFINE_bool(raw, false, "Write raw data instead of a WAV file."); | 38 DEFINE_bool(raw, false, "Write raw data instead of a WAV file."); |
| 39 DEFINE_bool(text, | 39 DEFINE_bool(text, |
| 40 false, | 40 false, |
| 41 "Write non-audio files as text files instead of binary files."); | 41 "Write non-audio files as text files instead of binary files."); |
| 42 | 42 |
| 43 inline void print_config(FILE* settings_file, | |
|
peah-webrtc
2015/10/02 08:34:28
Is this really a proper filename according to the
minyue-webrtc
2015/10/02 09:01:42
This part has been changed back to Andrew's early
peah-webrtc
2015/10/02 09:18:29
Acknowledged.
| |
| 44 bool config_exist, | |
| 45 int config_value, | |
| 46 const std::string& config_descriptor) { | |
| 47 if (config_exist) { | |
| 48 fprintf(settings_file, " %s: %d\n", config_descriptor.c_str(), | |
| 49 config_value); | |
| 50 } | |
| 51 } | |
| 52 | |
| 43 namespace webrtc { | 53 namespace webrtc { |
| 44 | 54 |
| 45 using audioproc::Event; | 55 using audioproc::Event; |
| 46 using audioproc::ReverseStream; | 56 using audioproc::ReverseStream; |
| 47 using audioproc::Stream; | 57 using audioproc::Stream; |
| 48 using audioproc::Init; | 58 using audioproc::Init; |
| 49 | 59 |
| 50 void WriteData(const void* data, size_t size, FILE* file, | 60 void WriteData(const void* data, size_t size, FILE* file, |
| 51 const std::string& filename) { | 61 const std::string& filename) { |
| 52 if (fwrite(data, size, 1, file) != 1) { | 62 if (fwrite(data, size, 1, file) != 1) { |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 76 int output_samples_per_channel = 0; | 86 int output_samples_per_channel = 0; |
| 77 int num_reverse_channels = 0; | 87 int num_reverse_channels = 0; |
| 78 int num_input_channels = 0; | 88 int num_input_channels = 0; |
| 79 int num_output_channels = 0; | 89 int num_output_channels = 0; |
| 80 rtc::scoped_ptr<WavWriter> reverse_wav_file; | 90 rtc::scoped_ptr<WavWriter> reverse_wav_file; |
| 81 rtc::scoped_ptr<WavWriter> input_wav_file; | 91 rtc::scoped_ptr<WavWriter> input_wav_file; |
| 82 rtc::scoped_ptr<WavWriter> output_wav_file; | 92 rtc::scoped_ptr<WavWriter> output_wav_file; |
| 83 rtc::scoped_ptr<RawFile> reverse_raw_file; | 93 rtc::scoped_ptr<RawFile> reverse_raw_file; |
| 84 rtc::scoped_ptr<RawFile> input_raw_file; | 94 rtc::scoped_ptr<RawFile> input_raw_file; |
| 85 rtc::scoped_ptr<RawFile> output_raw_file; | 95 rtc::scoped_ptr<RawFile> output_raw_file; |
| 96 | |
| 97 FILE* settings_file = OpenFile(FLAGS_settings_file, "wb"); | |
|
peah-webrtc
2015/10/02 08:34:27
This is something that holds for the version curre
minyue-webrtc
2015/10/02 09:01:42
Yes, could you help me find a place to add a close
peah-webrtc
2015/10/02 09:18:29
I'd just add a close of the settings_file and debu
| |
| 98 | |
| 86 while (ReadMessageFromFile(debug_file, &event_msg)) { | 99 while (ReadMessageFromFile(debug_file, &event_msg)) { |
| 87 if (event_msg.type() == Event::REVERSE_STREAM) { | 100 if (event_msg.type() == Event::REVERSE_STREAM) { |
| 88 if (!event_msg.has_reverse_stream()) { | 101 if (!event_msg.has_reverse_stream()) { |
| 89 printf("Corrupt input file: ReverseStream missing.\n"); | 102 printf("Corrupt input file: ReverseStream missing.\n"); |
| 90 return 1; | 103 return 1; |
| 91 } | 104 } |
| 92 | 105 |
| 93 const ReverseStream msg = event_msg.reverse_stream(); | 106 const ReverseStream msg = event_msg.reverse_stream(); |
| 94 if (msg.has_data()) { | 107 if (msg.has_data()) { |
| 95 if (FLAGS_raw && !reverse_raw_file) { | 108 if (FLAGS_raw && !reverse_raw_file) { |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 210 static FILE* keypress_file = OpenFile(FLAGS_keypress_file, "wb"); | 223 static FILE* keypress_file = OpenFile(FLAGS_keypress_file, "wb"); |
| 211 bool keypress = msg.keypress(); | 224 bool keypress = msg.keypress(); |
| 212 if (FLAGS_text) { | 225 if (FLAGS_text) { |
| 213 fprintf(keypress_file, "%d\n", keypress); | 226 fprintf(keypress_file, "%d\n", keypress); |
| 214 } else { | 227 } else { |
| 215 WriteData(&keypress, sizeof(keypress), keypress_file, | 228 WriteData(&keypress, sizeof(keypress), keypress_file, |
| 216 FLAGS_keypress_file); | 229 FLAGS_keypress_file); |
| 217 } | 230 } |
| 218 } | 231 } |
| 219 } | 232 } |
| 233 } else if (event_msg.type() == Event::CONFIG) { | |
| 234 if (!event_msg.has_config()) { | |
| 235 printf("Corrupt input file: Config missing.\n"); | |
| 236 return 1; | |
| 237 } | |
| 238 const audioproc::Config msg = event_msg.config(); | |
| 239 | |
| 240 fprintf(settings_file, "APM re-config at frame: %d\n", frame_count); | |
| 241 // AEC. | |
| 242 print_config(settings_file, msg.has_aec_enabled(), msg.aec_enabled(), | |
| 243 "AEC enabled"); | |
| 244 print_config(settings_file, msg.has_aec_delay_agnostic(), | |
| 245 msg.aec_delay_agnostic(), "AEC delay agnostic enabled"); | |
| 246 print_config(settings_file, msg.has_aec_drift_compensation(), | |
| 247 msg.aec_drift_compensation(), | |
| 248 "AEC drift compensation enabled"); | |
| 249 print_config(settings_file, msg.has_aec_extended_filter(), | |
| 250 msg.aec_extended_filter(), "AEC extended filter enabled"); | |
| 251 print_config(settings_file, msg.has_aec_suppression_level(), | |
| 252 msg.aec_suppression_level(), "AEC suppression level"); | |
| 253 // AECM. | |
| 254 print_config(settings_file, msg.has_aecm_enabled(), msg.aecm_enabled(), | |
| 255 "AECM enabled"); | |
| 256 print_config(settings_file, msg.has_aecm_comfort_noise(), | |
| 257 msg.aecm_comfort_noise(), "AECM comfort noise enabled"); | |
| 258 print_config(settings_file, msg.has_aecm_routing_mode(), | |
| 259 msg.aecm_routing_mode(), "AECM routing mode"); | |
| 260 // AGC. | |
| 261 print_config(settings_file, msg.has_agc_enabled(), msg.agc_enabled(), | |
| 262 "AGC enabled"); | |
| 263 print_config(settings_file, msg.has_agc_experiment(), | |
| 264 msg.agc_experiment(), "AGC experiment enabled"); | |
| 265 print_config(settings_file, msg.has_agc_mode(), msg.agc_mode(), | |
| 266 "AGC mode"); | |
| 267 print_config(settings_file, msg.has_agc_limiter(), msg.agc_limiter(), | |
| 268 "AGC limiter enabled"); | |
| 269 // HPF. | |
| 270 print_config(settings_file, msg.has_hpf_enabled(), msg.hpf_enabled(), | |
| 271 "HPF enabled"); | |
| 272 // NS. | |
| 273 print_config(settings_file, msg.has_ns_enabled(), msg.ns_enabled(), | |
| 274 "NS enabled"); | |
| 275 print_config(settings_file, msg.has_ns_experiment(), msg.ns_experiment(), | |
| 276 "NS experiment enabled"); | |
| 277 print_config(settings_file, msg.has_ns_level(), msg.ns_level(), | |
| 278 "NS Level"); | |
| 220 } else if (event_msg.type() == Event::INIT) { | 279 } else if (event_msg.type() == Event::INIT) { |
| 221 if (!event_msg.has_init()) { | 280 if (!event_msg.has_init()) { |
| 222 printf("Corrupt input file: Init missing.\n"); | 281 printf("Corrupt input file: Init missing.\n"); |
| 223 return 1; | 282 return 1; |
| 224 } | 283 } |
| 225 | 284 |
| 226 static FILE* settings_file = OpenFile(FLAGS_settings_file, "wb"); | |
| 227 const Init msg = event_msg.init(); | 285 const Init msg = event_msg.init(); |
| 228 // These should print out zeros if they're missing. | 286 // These should print out zeros if they're missing. |
| 229 fprintf(settings_file, "Init at frame: %d\n", frame_count); | 287 fprintf(settings_file, "Init at frame: %d\n", frame_count); |
| 230 int input_sample_rate = msg.sample_rate(); | 288 int input_sample_rate = msg.sample_rate(); |
| 231 fprintf(settings_file, " Input sample rate: %d\n", input_sample_rate); | 289 fprintf(settings_file, " Input sample rate: %d\n", input_sample_rate); |
| 232 int output_sample_rate = msg.output_sample_rate(); | 290 int output_sample_rate = msg.output_sample_rate(); |
| 233 fprintf(settings_file, " Output sample rate: %d\n", output_sample_rate); | 291 fprintf(settings_file, " Output sample rate: %d\n", output_sample_rate); |
| 234 int reverse_sample_rate = msg.reverse_sample_rate(); | 292 int reverse_sample_rate = msg.reverse_sample_rate(); |
| 235 fprintf(settings_file, | 293 fprintf(settings_file, |
| 236 " Reverse sample rate: %d\n", | 294 " Reverse sample rate: %d\n", |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 272 } | 330 } |
| 273 | 331 |
| 274 return 0; | 332 return 0; |
| 275 } | 333 } |
| 276 | 334 |
| 277 } // namespace webrtc | 335 } // namespace webrtc |
| 278 | 336 |
| 279 int main(int argc, char* argv[]) { | 337 int main(int argc, char* argv[]) { |
| 280 return webrtc::do_main(argc, argv); | 338 return webrtc::do_main(argc, argv); |
| 281 } | 339 } |
| OLD | NEW |