public inbox for cygwin-cvs@sourceware.org help / color / mirror / Atom feed
From: Takashi Yano <tyan0@sourceware.org> To: cygwin-cvs@sourceware.org Subject: [newlib-cygwin] Cygwin: console: Stop to create struct instance which is not needed. Date: Tue, 1 Mar 2022 23:50:11 +0000 (GMT) [thread overview] Message-ID: <20220301235011.1BADC3858D37@sourceware.org> (raw) https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=2b4d4728f23408308dbb3046f6e17d09039f3b50 commit 2b4d4728f23408308dbb3046f6e17d09039f3b50 Author: Takashi Yano <takashi.yano@nifty.ne.jp> Date: Wed Mar 2 08:35:09 2022 +0900 Cygwin: console: Stop to create struct instance which is not needed. - In fhandler_console::cons_master_thread(), a struct which has only a static function is used. In this case, struct instance is not necessary. So with this patch, the static function is invoked without creating instance. Diff: --- winsup/cygwin/fhandler_console.cc | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/winsup/cygwin/fhandler_console.cc b/winsup/cygwin/fhandler_console.cc index 920dd4be0..2a4aa7a70 100644 --- a/winsup/cygwin/fhandler_console.cc +++ b/winsup/cygwin/fhandler_console.cc @@ -192,13 +192,13 @@ fhandler_console::cons_master_thread (handle_set_t *p, tty *ttyp) during the process. Additional space should be left for writeback fix. */ const int inrec_size = INREC_SIZE + additional_space; - struct + struct m { inline static size_t bytes (size_t n) { return sizeof (INPUT_RECORD) * n; } - } m; + }; termios &ti = ttyp->ti; int processed_up_to = -1; while (con.owner == myself->pid) @@ -227,7 +227,7 @@ fhandler_console::cons_master_thread (handle_set_t *p, tty *ttyp) ReadConsoleInputW (p->input_handle, input_rec + total_read, incr, &n); /* Discard oldest n events. */ - memmove (input_rec, input_rec + n, m.bytes (total_read)); + memmove (input_rec, input_rec + n, m::bytes (total_read)); processed_up_to -= n; nowait = true; } @@ -307,7 +307,7 @@ remove_record: { /* Remove corresponding record. */ if (total_read > i + 1) memmove (input_rec + i, input_rec + i + 1, - m.bytes (total_read - i - 1)); + m::bytes (total_read - i - 1)); total_read--; i--; } @@ -325,21 +325,21 @@ remove_record: if (n < total_read) break; /* Someone has read input without acquiring input_mutex. ConEmu cygwin-connector? */ - if (memcmp (input_rec, tmp, m.bytes (total_read)) == 0) + if (memcmp (input_rec, tmp, m::bytes (total_read)) == 0) break; /* OK */ /* Try to fix */ DWORD incr = n - total_read; DWORD ofst; for (ofst = 1; ofst <= incr; ofst++) - if (memcmp (input_rec, tmp + ofst, m.bytes (total_read)) == 0) + if (memcmp (input_rec, tmp + ofst, m::bytes (total_read)) == 0) { ReadConsoleInputW (p->input_handle, tmp, inrec_size, &n); - memcpy (input_rec, tmp + ofst, m.bytes (total_read)); - memcpy (input_rec + total_read, tmp, m.bytes (ofst)); + memcpy (input_rec, tmp + ofst, m::bytes (total_read)); + memcpy (input_rec + total_read, tmp, m::bytes (ofst)); if (n > ofst + total_read) memcpy (input_rec + total_read + ofst, tmp + ofst + total_read, - m.bytes (n - (ofst + total_read))); + m::bytes (n - (ofst + total_read))); total_read = n; break; }
reply other threads:[~2022-03-01 23:50 UTC|newest] Thread overview: [no followups] expand[flat|nested] mbox.gz Atom feed
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20220301235011.1BADC3858D37@sourceware.org \ --to=tyan0@sourceware.org \ --cc=cygwin-cvs@sourceware.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).