/// <summary> /// Uses information about position of the cursor and data structures to notify SCI Autocompletion /// </summary> /// <param name="dataStructures"></param> internal static void ProvideSuggestions(List <DataStructure> dataStructures) { IntPtr curScintilla = PluginBase.GetCurrentScintilla(); int curLine = (int)Win32.SendMessage(PluginBase.nppData._nppHandle, NppMsg.NPPM_GETCURRENTLINE, 0, 0); int lineLength = (int)Win32.SendMessage(curScintilla, SciMsg.SCI_LINELENGTH, curLine, 0); if (lineLength <= 0) { return; } StringBuilder sb = new StringBuilder(lineLength); Win32.SendMessage(curScintilla, SciMsg.SCI_GETLINE, curLine, sb); int cursorPosition = (int)Win32.SendMessage(curScintilla, SciMsg.SCI_GETCURRENTPOS, 0, 0); int lineOffsetPosition = (int)Win32.SendMessage(curScintilla, SciMsg.SCI_POSITIONFROMLINE, curLine, 0); int linePosition = cursorPosition - lineOffsetPosition; if (linePosition == 0) { return; } MatchType typeOfMatch; string lookupString = RPGParser.GetVariableAtColumn(sb.ToString(), linePosition, out typeOfMatch); if (lookupString == "") { return; } NotifyAutoCompletion(curScintilla, lookupString, SearchDataStructureDefinitions(lookupString), typeOfMatch); }
/// <summary> /// Executes remote commands on the configured server to collect data on externally /// referenced tables that is then put into both memory and the file cache /// </summary> internal static void LaunchFFDCollection() { Thread thread = new Thread((ThreadStart) delegate { List <SourceLine> src = ParseCurrentFileForExtName(); if (src.Count == 0) { return; } // Generate temporary files to receive data string[] tmp = new string[src.Count]; for (int i = 0; i < src.Count; i++) { tmp[i] = Path.GetTempFileName(); } // Receive record formats via remote command IICDSPFFD IBMi.RunCommands(IBMiCommandRender.RenderFFDCollectionScript(src, tmp)); // Get all record formats to local temp files // Load Context & Cleanup temp files for (int i = 0; i < src.Count; i++) { try { RPGParser.LoadFFD(tmp[i], src[i]); } catch (Exception e) { IBMiUtilities.Log(e.ToString()); // TODO: Show error? } finally { File.Delete(tmp[i]); } } }); thread.Start(); }
internal static void CommandMenuInit() { StringBuilder pluginsConfigDir = new StringBuilder(Win32.MAX_PATH); Win32.SendMessage(PluginBase.nppData._nppHandle, NppMsg.NPPM_GETPLUGINSCONFIGDIR, Win32.MAX_PATH, pluginsConfigDir); ConfigDirectory = $"{ pluginsConfigDir.ToString() }\\{ PluginName }\\"; FileCacheDirectory = $"{ConfigDirectory}cache\\"; if (!Directory.Exists(ConfigDirectory)) { Directory.CreateDirectory(ConfigDirectory); } if (!Directory.Exists(FileCacheDirectory)) { Directory.CreateDirectory(FileCacheDirectory); } IBMiUtilities.CreateLog(ConfigDirectory + PluginName); RPGParser.LoadFileCache(); IBMi.LoadConfig(ConfigDirectory + PluginName); //if (IBMi.GetConfig("localDefintionsInstalled") == "false") //{ // IBMiNPPInstaller.InstallLocalDefinitions(); //} PluginBase.SetCommand(0, "About IBMiCmd", About, new ShortcutKey(false, false, false, Keys.None)); PluginBase.SetCommand(1, "IBM i Remote System Setup", RemoteSetup); PluginBase.SetCommand(2, "IBM i Command Entry", CommandDialog); PluginBase.SetCommand(3, "IBM i Error Listing", ErrorDialog); PluginBase.SetCommand(4, "IBM i Command Bindings", BindsDialog); PluginBase.SetCommand(5, "IBM i RPG Conversion", LaunchConversion, new ShortcutKey(true, false, false, Keys.F4)); PluginBase.SetCommand(6, "IBM i Relic Build", LaunchRBLD, new ShortcutKey(true, false, false, Keys.F5)); PluginBase.SetCommand(7, "IBM i Refresh Definitions", BuildSourceContext, new ShortcutKey(true, false, false, Keys.F6)); PluginBase.SetCommand(8, "IBM i Auto Complete", AutoComplete, new ShortcutKey(false, true, false, Keys.Space)); PluginBase.SetCommand(9, "IBM i Library List", LiblDialog, new ShortcutKey(true, false, false, Keys.F7)); PluginBase.SetCommand(10, "IBM i Remote Install Plugin Server", RemoteInstall); }
internal static void CommandMenuInit() { StringBuilder pluginsConfigDir = new StringBuilder(Win32.MAX_PATH); Win32.SendMessage(PluginBase.nppData._nppHandle, NppMsg.NPPM_GETPLUGINSCONFIGDIR, Win32.MAX_PATH, pluginsConfigDir); ConfigDirectory = $"{ pluginsConfigDir.ToString() }\\{ PluginName }\\"; SystemsDirectory = $"{ConfigDirectory}systems\\"; FileCacheDirectory = $"{ConfigDirectory}cache\\"; if (!Directory.Exists(ConfigDirectory)) { Directory.CreateDirectory(ConfigDirectory); } if (!Directory.Exists(SystemsDirectory)) { Directory.CreateDirectory(SystemsDirectory); } if (!Directory.Exists(FileCacheDirectory)) { Directory.CreateDirectory(FileCacheDirectory); } IBMiUtilities.CreateLog(ConfigDirectory + PluginName); RPGParser.LoadFileCache(); CLParser.LoadFileCache(); if (File.Exists(ConfigDirectory + "dftcfg")) { Config.SwitchToConfig(File.ReadAllText(ConfigDirectory + "dftcfg")); } else { LoadConfigSelect(); if (Config.GetConfigs().Length == 0) { return; } if (IBMi._ConfigFile == "" || IBMi._ConfigFile == null) { string UseConfig = Config.GetConfigs()[0]; MessageBox.Show("No config selected. Defaulted to " + UseConfig + "."); Config.SwitchToConfig(UseConfig); } } //if (IBMi.GetConfig("localDefintionsInstalled") == "false") //{ // IBMiNPPInstaller.InstallLocalDefinitions(); //} bool ExperimentalFeatures = (IBMi.GetConfig("experimental") == "true"); int ItemOrder = 0; PluginBase.SetCommand(ItemOrder++, "About IBMiCmd", About, new ShortcutKey(false, false, false, Keys.None)); PluginBase.SetCommand(ItemOrder++, "-SEPARATOR-", null); PluginBase.SetCommand(ItemOrder++, "Select Remote System", LoadConfigSelect); PluginBase.SetCommand(ItemOrder++, "Remote System Setup", RemoteSetup); PluginBase.SetCommand(ItemOrder++, "Library List", LiblDialog, new ShortcutKey(true, false, false, Keys.F7)); if (ExperimentalFeatures) { PluginBase.SetCommand(ItemOrder++, "Remote Install Plugin Server", RemoteInstall); } PluginBase.SetCommand(ItemOrder++, "-SEPARATOR-", null); PluginBase.SetCommand(ItemOrder++, "Command Entry", CommandDialog); PluginBase.SetCommand(ItemOrder++, "Error Listing", ErrorDialog); PluginBase.SetCommand(ItemOrder++, "Command Bindings", BindsDialog); PluginBase.SetCommand(ItemOrder++, "-SEPARATOR-", null); PluginBase.SetCommand(ItemOrder++, "Member Listing", MemberListing); PluginBase.SetCommand(ItemOrder++, "Open Source Member", OpenMember, new ShortcutKey(true, false, true, Keys.A)); //PluginBase.SetCommand(ItemOrder++, "Upload Source Member", UploadMember, new ShortcutKey(true, false, true, Keys.X)); PluginBase.SetCommand(ItemOrder++, "Open Include/Copy", OpenInclude, new ShortcutKey(true, false, false, Keys.F12)); PluginBase.SetCommand(ItemOrder++, "-SEPARATOR-", null); PluginBase.SetCommand(ItemOrder++, "Format CL file", ManageCL, new ShortcutKey(true, false, false, Keys.F4)); PluginBase.SetCommand(ItemOrder++, "RPG Line Conversion", LaunchConversion, new ShortcutKey(true, false, false, Keys.F5)); PluginBase.SetCommand(ItemOrder++, "RPG File Conversion", LaunchFileConversion, new ShortcutKey(true, false, false, Keys.F6)); PluginBase.SetCommand(ItemOrder++, "-SEPARATOR-", null); PluginBase.SetCommand(ItemOrder++, "Display File Editor", DisplayEdit); if (ExperimentalFeatures) { PluginBase.SetCommand(ItemOrder++, "Refresh Extname Definitions", BuildSourceContext); } if (ExperimentalFeatures) { PluginBase.SetCommand(ItemOrder++, "Extname Content Assist", AutoComplete, new ShortcutKey(false, true, false, Keys.Space)); } if (ExperimentalFeatures) { PluginBase.SetCommand(ItemOrder++, "Prompt CL Command", PromptCommand, new ShortcutKey(true, false, false, Keys.F4)); } }
internal static void BuildSourceContext() { RPGParser.LaunchFFDCollection(); }