Monday, November 08, 2010 at 12:03 AM.

system.verbs.builtins.Frontier.tools.uninstallSubMenu

on uninstallSubMenu (menuName) {
	<<Uninstall a Tool's sub-menu from the Tools menu.
		<<Changes:
			<<10/04/00; 5:25:14 PM by PBS
				<<Do a case-insensitive comparison on the name
			<<10/06/00; 10:05:37 PM by PBS
				<<Make sure the target gets restored no matter what path is taken.
			<<11/08/00; 6:35:40 PM by PBS
				<<Protect the Tools menu with a semaphore.
			<<11/28//00; 10:10:27 PM by JES
				<<Unlock the semaphore after the submenu is deleted, but before returning.
			<<11/30/00; 1:55:24 AM by JES
				<<Deal properly with removal of submenus which contain space characters.
	local (lowerMenuName = string.lower (menuName));
	local (adrToolsMenu = @Frontier.tools.menu);
	local (oldTarget = target.set (adrToolsMenu));
	try {
		semaphore.lock (adrToolsMenu, 7200)}
	else {
		semaphore.unlock (adrToolsMenu)};
	op.firstSummit ();
	op.expand (1);
	local (dir = right, linetext = op.getLineText (), flNewMenu = true);
	while linetext != "-" {
		if string.lower (string.innerCaseName (linetext)) == lowerMenuName { //PBS 10/04/00: case-insensitive comparison
			op.deleteLine ();
			try {target.set (oldTarget)};
			semaphore.unlock (adrToolsMenu);
			return (true)};
		op.go (dir, 1);
		if dir == right {
			dir = down};
		linetext = op.getLineText ()};
	semaphore.unlock (adrToolsMenu);
	try {target.set (oldTarget)};
	return (false)}



This listing is for code that runs in the OPML Editor environment. I created these listings because I wanted the search engines to index it, so that when I want to look up something in my codebase I don't have to use the much slower search functionality in my object database. Dave Winer.