Switch rgba_to_i420_converter to ABSL_FLAG.

Bug: webrtc:10616
Change-Id: I45f94e0f43e84b041c72b1bdc5b35ee0e970397e
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/143179
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Commit-Queue: Mirko Bonadei <mbonadei@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#28362}
diff --git a/rtc_tools/BUILD.gn b/rtc_tools/BUILD.gn
index e3b9eb1..9df3843 100644
--- a/rtc_tools/BUILD.gn
+++ b/rtc_tools/BUILD.gn
@@ -242,6 +242,7 @@
 
   rtc_executable("rgba_to_i420_converter") {
     visibility = [ "*" ]
+    testonly = true
     sources = [
       "converter/converter.cc",
       "converter/converter.h",
@@ -249,8 +250,9 @@
     ]
 
     deps = [
-      ":command_line_parser",
       "../common_video",
+      "//third_party/abseil-cpp/absl/flags:flag",
+      "//third_party/abseil-cpp/absl/flags:parse",
       "//third_party/libyuv",
     ]
   }
diff --git a/rtc_tools/converter/rgba_to_i420_converter.cc b/rtc_tools/converter/rgba_to_i420_converter.cc
index 89fbf95..cf352e6 100644
--- a/rtc_tools/converter/rgba_to_i420_converter.cc
+++ b/rtc_tools/converter/rgba_to_i420_converter.cc
@@ -12,8 +12,24 @@
 #include <stdlib.h>
 #include <string>
 
+#include "absl/flags/flag.h"
+#include "absl/flags/parse.h"
 #include "rtc_tools/converter/converter.h"
-#include "rtc_tools/simple_command_line_parser.h"
+
+ABSL_FLAG(int, width, -1, "Width in pixels of the frames in the input file");
+ABSL_FLAG(int, height, -1, "Height in pixels of the frames in the input file");
+ABSL_FLAG(std::string,
+          frames_dir,
+          ".",
+          "The path to the directory where the frames reside");
+ABSL_FLAG(std::string,
+          output_file,
+          "output.yuv",
+          " The output file to which frames are written");
+ABSL_FLAG(bool,
+          delete_frames,
+          false,
+          " Whether or not to delete the input frames after the conversion");
 
 /*
  * A command-line tool based on libyuv to convert a set of RGBA files to a YUV
@@ -24,60 +40,39 @@
  * --height=<height_of_input_frames>
  */
 int main(int argc, char* argv[]) {
-  std::string program_name = argv[0];
-  std::string usage =
-      "Converts RGBA raw image files to I420 frames for YUV.\n"
-      "Example usage:\n" +
-      program_name +
-      " --frames_dir=. --output_file=output.yuv --width=320 --height=240\n"
-      "IMPORTANT: If you pass the --delete_frames command line parameter, the "
-      "tool will delete the input frames after conversion.\n"
-      "Command line flags:\n"
-      "  - width(int): Width in pixels of the frames in the input file."
-      " Default: -1\n"
-      "  - height(int): Height in pixels of the frames in the input file."
-      " Default: -1\n"
-      "  - frames_dir(string): The path to the directory where the frames "
-      "reside."
-      " Default: .\n"
-      "  - output_file(string): The output file to which frames are written."
-      " Default: output.yuv\n"
-      "  - delete_frames(bool): Whether or not to delete the input frames after"
-      " the conversion. Default: false.\n";
+  absl::ParseCommandLine(argc, argv);
+  // TODO(bugs.webrtc.org/10616): Add program usage message when Abseil
+  // flags supports it.
+  // std::string usage =
+  //     "Converts RGBA raw image files to I420 frames for YUV.\n"
+  //     "Example usage:\n" +
+  //     program_name +
+  //     " --frames_dir=. --output_file=output.yuv --width=320 --height=240\n"
+  //     "IMPORTANT: If you pass the --delete_frames command line parameter, the
+  //     " "tool will delete the input frames after conversion.\n" "Command line
+  //     flags:\n" "  - width(int): Width in pixels of the frames in the input
+  //     file." " Default: -1\n" "  - height(int): Height in pixels of the
+  //     frames in the input file." " Default: -1\n" "  - frames_dir(string):
+  //     The path to the directory where the frames " "reside." " Default: .\n"
+  //     "  - output_file(string): The output file to which frames are written."
+  //     " Default: output.yuv\n"
+  //     "  - delete_frames(bool): Whether or not to delete the input frames
+  //     after" " the conversion. Default: false.\n";
 
-  webrtc::test::CommandLineParser parser;
-
-  // Init the parser and set the usage message
-  parser.Init(argc, argv);
-  parser.SetUsageMessage(usage);
-
-  parser.SetFlag("width", "-1");
-  parser.SetFlag("height", "-1");
-  parser.SetFlag("frames_dir", ".");
-  parser.SetFlag("output_file", "output.yuv");
-  parser.SetFlag("delete_frames", "false");
-  parser.SetFlag("help", "false");
-
-  parser.ProcessFlags();
-  if (parser.GetFlag("help") == "true") {
-    parser.PrintUsageMessage();
-    exit(EXIT_SUCCESS);
-  }
-  parser.PrintEnteredFlags();
-
-  int width = strtol((parser.GetFlag("width")).c_str(), NULL, 10);
-  int height = strtol((parser.GetFlag("height")).c_str(), NULL, 10);
+  int width = absl::GetFlag(FLAGS_width);
+  int height = absl::GetFlag(FLAGS_height);
 
   if (width <= 0 || height <= 0) {
     fprintf(stderr, "Error: width or height cannot be <= 0!\n");
     return -1;
   }
 
-  bool del_frames = (parser.GetFlag("delete_frames") == "true") ? true : false;
+  bool del_frames = absl::GetFlag(FLAGS_delete_frames);
 
   webrtc::test::Converter converter(width, height);
   bool success = converter.ConvertRGBAToI420Video(
-      parser.GetFlag("frames_dir"), parser.GetFlag("output_file"), del_frames);
+      absl::GetFlag(FLAGS_frames_dir), absl::GetFlag(FLAGS_output_file),
+      del_frames);
 
   if (success) {
     fprintf(stdout, "Successful conversion of RGBA frames to YUV video!\n");