Rename --no-mirror to --no-playback
This option impacts video and audio _playback_. For example, if we use
V4L2, the device is still "mirrored" (via V4L2), even if playback is
disabled. Therefore, "playback" is more approriate than "mirror".
The initial option --no-display option was renamed to --no-mirror by
commit 6928acdeac, but this has never been
released, so it is ok to rename it one more time.
Refs #3978 <https://github.com/Genymobile/scrcpy/pull/3978#issuecomment-1549420103>
PR #4033 <https://github.com/Genymobile/scrcpy/pull/4033>
This commit is contained in:
@@ -382,9 +382,8 @@ static const struct sc_option options[] = {
|
||||
},
|
||||
{
|
||||
.shortopt = 'N',
|
||||
.longopt = "no-mirror",
|
||||
.text = "Do not mirror device video or audio on the computer (only "
|
||||
"when recording or V4L2 sink is enabled).",
|
||||
.longopt = "no-playback",
|
||||
.text = "Disable video and audio playback on the computer.",
|
||||
},
|
||||
{
|
||||
// deprecated
|
||||
@@ -1671,10 +1670,10 @@ parse_args_with_getopt(struct scrcpy_cli_args *args, int argc, char *argv[],
|
||||
opts->control = false;
|
||||
break;
|
||||
case OPT_NO_DISPLAY:
|
||||
LOGW("--no-display is deprecated, use --no-mirror instead.");
|
||||
LOGW("--no-display is deprecated, use --no-playback instead.");
|
||||
// fall through
|
||||
case 'N':
|
||||
opts->mirror = false;
|
||||
opts->playback = false;
|
||||
break;
|
||||
case 'p':
|
||||
if (!parse_port_range(optarg, &opts->port_range)) {
|
||||
@@ -1924,8 +1923,8 @@ parse_args_with_getopt(struct scrcpy_cli_args *args, int argc, char *argv[],
|
||||
}
|
||||
|
||||
#ifdef HAVE_V4L2
|
||||
if (!opts->mirror && !opts->record_filename && !opts->v4l2_device) {
|
||||
LOGE("-N/--no-mirror requires either screen recording (-r/--record)"
|
||||
if (!opts->playback && !opts->record_filename && !opts->v4l2_device) {
|
||||
LOGE("-N/--no-playback requires either screen recording (-r/--record)"
|
||||
" or sink to v4l2loopback device (--v4l2-sink)");
|
||||
return false;
|
||||
}
|
||||
@@ -1949,14 +1948,14 @@ parse_args_with_getopt(struct scrcpy_cli_args *args, int argc, char *argv[],
|
||||
return false;
|
||||
}
|
||||
#else
|
||||
if (!opts->mirror && !opts->record_filename) {
|
||||
LOGE("-N/--no-mirror requires screen recording (-r/--record)");
|
||||
if (!opts->playback && !opts->record_filename) {
|
||||
LOGE("-N/--no-playback requires screen recording (-r/--record)");
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
|
||||
if (opts->audio && !opts->mirror && !opts->record_filename) {
|
||||
LOGI("No mirror and no recording: audio disabled");
|
||||
if (opts->audio && !opts->playback && !opts->record_filename) {
|
||||
LOGI("No playback and no recording: audio disabled");
|
||||
opts->audio = false;
|
||||
}
|
||||
|
||||
@@ -2089,11 +2088,11 @@ parse_args_with_getopt(struct scrcpy_cli_args *args, int argc, char *argv[],
|
||||
#endif
|
||||
|
||||
#ifdef HAVE_USB
|
||||
if (!(opts->mirror && opts->video) && !opts->otg) {
|
||||
if (!(opts->playback && opts->video) && !opts->otg) {
|
||||
#else
|
||||
if (!(opts->mirror && opts->video)) {
|
||||
if (!(opts->playback && opts->video)) {
|
||||
#endif
|
||||
// If video mirroring is disabled and OTG are disabled, then there is
|
||||
// If video playback is disabled and OTG are disabled, then there is
|
||||
// no way to control the device.
|
||||
opts->control = false;
|
||||
}
|
||||
|
||||
@@ -52,7 +52,7 @@ const struct scrcpy_options scrcpy_options_default = {
|
||||
.fullscreen = false,
|
||||
.always_on_top = false,
|
||||
.control = true,
|
||||
.mirror = true,
|
||||
.playback = true,
|
||||
.turn_screen_off = false,
|
||||
.key_inject_mode = SC_KEY_INJECT_MODE_MIXED,
|
||||
.window_borderless = false,
|
||||
|
||||
@@ -147,7 +147,7 @@ struct scrcpy_options {
|
||||
bool fullscreen;
|
||||
bool always_on_top;
|
||||
bool control;
|
||||
bool mirror;
|
||||
bool playback;
|
||||
bool turn_screen_off;
|
||||
enum sc_key_inject_mode key_inject_mode;
|
||||
bool window_borderless;
|
||||
|
||||
@@ -137,7 +137,7 @@ sdl_set_hints(const char *render_driver) {
|
||||
}
|
||||
|
||||
static void
|
||||
sdl_configure(bool mirror, bool disable_screensaver) {
|
||||
sdl_configure(bool playback, bool disable_screensaver) {
|
||||
#ifdef _WIN32
|
||||
// Clean up properly on Ctrl+C on Windows
|
||||
bool ok = SetConsoleCtrlHandler(windows_ctrl_handler, TRUE);
|
||||
@@ -146,7 +146,7 @@ sdl_configure(bool mirror, bool disable_screensaver) {
|
||||
}
|
||||
#endif // _WIN32
|
||||
|
||||
if (!mirror) {
|
||||
if (!playback) {
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -386,10 +386,10 @@ scrcpy(struct scrcpy_options *options) {
|
||||
goto end;
|
||||
}
|
||||
|
||||
if (options->mirror) {
|
||||
if (options->playback) {
|
||||
sdl_set_hints(options->render_driver);
|
||||
|
||||
// Initialize SDL video and audio in addition if mirroring is enabled
|
||||
// Initialize SDL video and audio in addition if playback is enabled
|
||||
if (options->video && SDL_Init(SDL_INIT_VIDEO)) {
|
||||
LOGE("Could not initialize SDL video: %s", SDL_GetError());
|
||||
goto end;
|
||||
@@ -401,7 +401,7 @@ scrcpy(struct scrcpy_options *options) {
|
||||
}
|
||||
}
|
||||
|
||||
sdl_configure(options->mirror, options->disable_screensaver);
|
||||
sdl_configure(options->playback, options->disable_screensaver);
|
||||
|
||||
// Await for server without blocking Ctrl+C handling
|
||||
bool connected;
|
||||
@@ -427,7 +427,7 @@ scrcpy(struct scrcpy_options *options) {
|
||||
|
||||
struct sc_file_pusher *fp = NULL;
|
||||
|
||||
assert(!options->control || options->mirror); // control implies mirror
|
||||
assert(!options->control || options->playback); // control implies playback
|
||||
if (options->control) {
|
||||
if (!sc_file_pusher_init(&s->file_pusher, serial,
|
||||
options->push_target)) {
|
||||
@@ -453,8 +453,8 @@ scrcpy(struct scrcpy_options *options) {
|
||||
&audio_demuxer_cbs, options);
|
||||
}
|
||||
|
||||
bool needs_video_decoder = options->mirror && options->video;
|
||||
bool needs_audio_decoder = options->mirror && options->audio;
|
||||
bool needs_video_decoder = options->playback && options->video;
|
||||
bool needs_audio_decoder = options->playback && options->audio;
|
||||
#ifdef HAVE_V4L2
|
||||
needs_video_decoder |= !!options->v4l2_device;
|
||||
#endif
|
||||
@@ -650,7 +650,7 @@ aoa_hid_end:
|
||||
// There is a controller if and only if control is enabled
|
||||
assert(options->control == !!controller);
|
||||
|
||||
if (options->mirror) {
|
||||
if (options->playback) {
|
||||
const char *window_title =
|
||||
options->window_title ? options->window_title : info->device_name;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user