diff --git a/src/browser.c b/src/browser.c
index fda71298fb5d3dea1328821069bcc9a27d9f93fe..bae5c96b22e33a5d9e5d0b0055a33b3acb1e5e24 100644
--- a/src/browser.c
+++ b/src/browser.c
@@ -303,6 +303,10 @@ char *do_browser(char *path)
 			/* Try opening and reading the selected directory. */
 			path = mallocstrcpy(path, filelist[selected]);
 			goto read_directory_contents;
+#ifdef ENABLE_NANORC
+		} else if (func == (void *)implant) {
+			implant(first_sc_for(MBROWSER, func)->expansion);
+#endif
 		} else if (func == do_exit) {
 			/* Exit from the file browser. */
 			break;
diff --git a/src/help.c b/src/help.c
index 3067496ba76dce50b04e2cc6fe27dbb82a6eb36a..5bae93eed6ccac941d22d0c4955717e945a94be8 100644
--- a/src/help.c
+++ b/src/help.c
@@ -215,6 +215,10 @@ void do_help(void)
 			do_findprevious();
 		} else if (func == do_findnext) {
 			do_findnext();
+#ifdef ENABLE_NANORC
+		} else if (func == (void *)implant) {
+			implant(first_sc_for(MHELP, func)->expansion);
+#endif
 		} else if (kbinput == KEY_WINCH) {
 			; /* Nothing to do. */
 #endif
diff --git a/src/rcfile.c b/src/rcfile.c
index 362f3c8e187f38b3671c9923f7f09b9e54961bcf..677f4162c29b423d60a76bbe92959aca6d0e7fa7 100644
--- a/src/rcfile.c
+++ b/src/rcfile.c
@@ -458,7 +458,7 @@ void parse_binding(char *ptr, bool dobind)
 
 		/* Now limit the given menu to those where the function exists. */
 		if (is_universal(newsc->func))
-			menu = menu & MMOST;
+			menu = menu & (MMOST | (newsc->func == (void *)implant ? MHELP : 0));
 		else
 			menu = menu & mask;