diff --git a/ChangeLog b/ChangeLog
index 2258d3b1ed6753b5c728902322e4dca75854f4a4..33f4e35c2614faa7fa3fc3ccdef52c35db9e51c5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -97,11 +97,12 @@ CVS code -
 	  control_mbrep(), control_wrep(), mbwidth(), mb_cur_max(), and
 	  make_mbchar(); changes to is_blank_char() (moved to chars.c),
 	  is_cntrl_char() (moved to chars.c), parse_char() (renamed
-	  parse_mbchar() and moved to chars.c), do_verbatim_input(),
-	  do_delete(), do_tab(), do_input(), do_output(), get_buffer(),
-	  unget_input(), unget_kbinput(), get_input(), parse_kbinput(),
-	  unparse_kbinput(), parse_verbatim_kbinput(),
-	  do_statusbar_input(), do_statusbar_verbatim_kbinput(),
+	  parse_mbchar() and moved to chars.c), do_home(),
+	  do_verbatim_input(), do_delete(), do_tab(), do_input(),
+	  do_output(), get_buffer(), unget_input(), unget_kbinput(),
+	  get_input(), parse_kbinput(), unparse_kbinput(),
+	  parse_verbatim_kbinput(), do_statusbar_input(),
+	  do_statusbar_home(), do_statusbar_verbatim_kbinput(),
 	  do_statusbar_output(), and display_string(); removal of
 	  buffer_to_keys() and keys_to_buffer(). (DLR)
 - cut.c:
diff --git a/src/move.c b/src/move.c
index 73729030a6e24b8bc87f1c3be0a5deee168917d8..3a81159248a92c0aa2433fb4c80fd9ac77c1d8e5 100644
--- a/src/move.c
+++ b/src/move.c
@@ -57,10 +57,26 @@ void do_home(void)
 #ifndef NANO_SMALL
     if (ISSET(SMART_HOME)) {
 	size_t current_x_save = current_x;
+	char *blank_mb = charalloc(mb_cur_max());
+	int blank_mb_len;
 
-	for (current_x = 0; is_blank_char(current->data[current_x]) &&
-		current->data[current_x] != '\0'; current_x++)
-	    ;
+	current_x = 0;
+
+	while (current->data[current_x] != '\0') {
+	    blank_mb_len = parse_mbchar(current->data + current_x,
+		blank_mb
+#ifdef NANO_WIDE
+		, NULL
+#endif
+		, NULL);
+
+	    if (!is_blank_mbchar(blank_mb))
+		break;
+
+	    current_x += blank_mb_len;
+	}
+
+	free(blank_mb);
 
 	if (current_x == current_x_save ||
 		current->data[current_x] == '\0')
diff --git a/src/winio.c b/src/winio.c
index 328fafc3f9acb18f4f2d19fc7d91c8250710c6b1..f670e33f3ed9b45dd04db1c843eee96d6e20bc9e 100644
--- a/src/winio.c
+++ b/src/winio.c
@@ -1803,9 +1803,27 @@ void do_statusbar_home(void)
 #ifndef NANO_SMALL
     if (ISSET(SMART_HOME)) {
 	size_t statusbar_x_save = statusbar_x;
-	for (statusbar_x = 0; is_blank_char(answer[statusbar_x]) &&
-		statusbar_x < statusbar_xend; statusbar_x++)
-	    ;
+	char *blank_mb = charalloc(mb_cur_max());
+	int blank_mb_len;
+
+	statusbar_x = 0;
+
+	while (statusbar_x < statusbar_xend) {
+	    blank_mb_len = parse_mbchar(answer + statusbar_x,
+		blank_mb
+#ifdef NANO_WIDE
+		, NULL
+#endif
+		, NULL);
+
+	    if (!is_blank_mbchar(blank_mb))
+		break;
+
+	    statusbar_x += blank_mb_len;
+	}
+
+	free(blank_mb);
+
 	if (statusbar_x == statusbar_x_save ||
 		statusbar_x == statusbar_xend)
 	    statusbar_x = 0;