一直用NPP,很长时间了,最近才学习它的各种插件,这篇文章是根据NppExec的用户指南写的。很多地方是翻译的,但不全是翻译,同时也有些东西没有翻译。

一、何为NppExec

简单的说,这个插件可以让用户在NPP中直接运行一些命令和程序,而不用启动这些命令和程序对应的实际工具或编译器。

1. NppExec是...

  • NppExec是介于Notepad++和外部工具/编译器之间的一个中间件。它允许用户在NPP中直接运行这些工具/编译器。
  • NppExec是一个控制台(Console)窗口,它能展示运行过程的输出结果,并将控制台窗口的输入重新定向(redirect)到运行过程中(有一些限制)。
  • NppExec是其内部命令的一个解释器。通过"Execute..."(执行)对话框,它能逐条执行多条NppExec命令(也称为NppExec脚本),也能从控制台窗口直接执行单条命令。

2. NppExec不是...

  • NppExec并不是一个控制台模拟器(console emulator)。NppExec的Console不是一个“真正”的控制台窗口,它没有提供控制台屏幕缓冲区(console screen buffer)。我的理解是NppExec的Console窗口中只是输出代码在真正的控制台中运行的结果。
  • NppExec并不是一个命令解释器。虽然它能执行NppExec的命令或脚本,但它不能理解诸如'copy'之类的命令。
  • NppExec并不是一个编译器。它能执行外部编译器的代码,但它本身不是编译器,执行这些代码不是它自己的功能。

二、安装

在“插件'菜单下打开插件管理器(Plugin Manager),在可以插件(Available)中找到NppExec,选择后点击下方的"Install"就可以了。安装完成后NPP会提示重启,重启后在插件菜单下就能看到NppExec。

三、基本用法

1. 获取帮助

Plugins -> NppExec -> Help/Manual :打开用户指南。

Plugins -> NppExec -> Help/Docs... :打开NppExec.txt和NppExec_TechInfo.txt文件,前者包括NppExec的所有命令、环境变量的语法和说明,后者包括NppExec的一些高级”隐藏“设置。

help:在Console中输入help可以查看以下内容

  • 控制台快捷键
  • 控制台命令
  • 通用命令(General commands)和环境变量

help <command> :help后加上命令的名字(中间用空格隔开)可以直接查看该命令的帮助文档。

2. 简介

NppExec的主要原理与NPP中的“运行”命令(F5)相同:执行给定的命令。通常就是以给定的参数执行一些程序或工具,参数能够以NPP中环境变量的形式来传递。比如,在IE中启动当前文件或者用某个编译器编译当前文件。NppExec提供了额外功能:

  • 它有一个控制台窗口显示控制台程序的输出
  • 它允许用户逐条执行多条命令
  • 它提供了NPP的所有环境变量,也加入了它自己的若干变量
  • 它有一些额外命令,只有想不到,没有做不到 :)
  • niubility :)

NppExec中执行命令的四种方式: (四种方式)

  • 使用NppExec的控制台窗口:输入命令,按Enter执行
  • 使用NppExec的“Execute...”对话框:可以输入多条命令,保存为NppExec脚本,执行时逐条执行
  • 使用NppExec的"npp_exec <script>"命令:执行脚本
  • 使用NppExec的"npp_exec <file>"命令:执行文本文件保存的脚本

BTW,NppExec的菜单项使用第三种方法执行脚本。

有关内部过程和外部过程在下面“小试牛刀”这一节中。

3. 小试牛刀

3.1 以内部过程的方式执行程序

在控制台窗口或Execute窗口直接输入程序的名字(必要时添加路径)就可以按内部过程的方式运行程序,输入时也可以带参数。

比如:输入cmd可以运行windows的命令提示窗口(cmd.exe程序),由于cmd本身是控制台程序,因此它会在NppExec的Console窗口中运行,也就可以接着在Console窗口中直接输入cmd的命令来运行,用exit命令退出cmd。 又,输入calc则运行windows自带的计算器。由于计算器不是控制台程序,因此它独立运行。

可以看到,以内部过程运行程序,不管是控制台程序还是非控制台程序,开始都打印Process started >>>,结束后打印<<< Process finished.(Exit code 0)。括号中的Exit code值可能会改变,表示不同的退出状态。这是NppExec在等待内部过程执行完毕。

下面是cmd中查看系统时间的一个例子(控制台中):

 ================ READY ================
cmd
cmd
Process started >>>
Microsoft Windows [版本 6.3.9600]
(c) 2013 Microsoft Corporation。保留所有权利。 C:\Users\acton\Desktop>time /t
time /t
00:13 C:\Users\acton\Desktop>exit
exit
<<< Process finished. (Exit code 0)
================ READY ================

也可以在运行程序时带参数,查看时间可以写成:

 ================ READY ================
cmd /c time /t
cmd /c time /t
Process started >>>
00:16
<<< Process finished. (Exit code 0)
================ READY ================

.cmd和.bat文件也能这样执行,但不能省略扩展名。

3.2 以外部过程的方式执行程序

使用npp_run <command>,如下,会打开cmd窗口,Console中不会输出Process started和Process finished,NppExec不会等待外部过程的执行。

 ================ READY ================
npp_run cmd
NPP_RUN: cmd
================ READY ================

小结:NppExec能理解的只是它的内部命令和环境变量。

  • 当输入其他命令时,比如"copy", "cmd"或"calc",NppExec尝试将其作为子过程来执行,i.e. 它执行CreateProcess(...)直到子过程结束。
  • 当输入类似"npp_run cmd"或"npp_run calc"时,NppExec尝试以外部过程的方式执行指定的命令,i.e. 它执行ShellExecute(...),且不关心这个过程。

4. NppExec的子菜单

  • Execute...:打开 "Execute..."对话框(默认热键F6)
  • Direct Execute Previous:执行之前的脚本(默认Ctrl+F6)
  • Show Console dialog:打开或隐藏Console窗口(默认Ctrl+~)
  • Toggle Console dialog:激活或取消激活Console窗口(依赖Console的"hide toggled Console"选项,但是找不到这个选项在哪里)
  • Console Commands History:Console命令历史是否可用(可用时上下键自动输入历史命令)
  • Console Output...:打开Console Output/Input encoding对话框,选择输入输出的编码
  • No internal messages:不显示命令确认等内部消息。比较如下,前面没有内部消息,后面有内部消息:
 ================ READY ================
cmd
Microsoft Windows [版本 6.3.9600]
(c) 2013 Microsoft Corporation。保留所有权利。 C:\Users\acton\Desktop>exit
exit
================ READY ================
cmd
cmd
Process started >>>
Microsoft Windows [版本 6.3.9600]
(c) 2013 Microsoft Corporation。保留所有权利。 C:\Users\acton\Desktop>exit
exit
<<< Process finished. (Exit code 0)
================ READY ================
  • Save all files on execute:执行NppExec脚本前始终保存修改过的文件
  • Follow $(CURRENT_DIRECTORY):始终以当前目录执行脚本(当前目录用cd命令查看或更改,请help)
  • Disable command aliases:命令别名不可用(用NPE_CMDALIAS查看别名)
  • Console Output Filters...:显示NppExec Console Filters对话框(Shift + F6)
  • Advanced Options...:高级选项(可以添加菜单项,用于执行脚本)
  • Change Console Font...:字体
  • Help/Manual Help/Docs...
  • Help/About

5. NppExec Console

可以用菜单、快捷键和工具栏图标打开,倒数第二个图标就是(反正我的是哈...)。

高级设置中的ToolbarBtn可以选择在工具栏显示Console/Execute/Execute Previous中的一个或不显示任何图标。

主要作用:

  • 执行命令(Enter键)
  • 当执行内部子过程,且为控制台程序时,显示运行结果(比如Python或cmd的运行结果)
  • 显示内部消息
  • help
  • ...(有一个没看懂)

6. "Execute..."

打开方式:F6、菜单或工具栏(需要设置)。

用于执行脚本。

可以在<temporary script>中执行,也可以点击Save保存脚本。保存后可以在高级选项中设置为NppExec的菜单项,分配热键。 比如以下脚本:

 // save current file
NPP_SAVE
// copy current file to C:\Backup
cmd /c copy "$(FULL_CURRENT_PATH)" "C:\Backup\$(FILE_NAME)" /Y

首先保存当前文件,然后用cmd中的copy命令复制到C:\Backup下,其中//开始的是注释。

7. NppExec脚本

NppExec脚本是一个命令集。

  • 可以是NppExec的内部命令,比如"cls", "npp_save", "npe_debuglog"等
  • 也可以是可执行的一些外部程序或命令,比如"cmd", "calc", "C:\tools\tcc\tcc.exe" 。
  • 每条命令都可以带参数。比如以下几条命令:
 INPUTBOX "Input something:" : something
NPP_EXEC "script name" "param 1" "param 2"
cmd /c copy /?
"C:\tools\tcc\tcc.exe" "$(FULL_CURRENT_PATH)" -run

注意:

  • 一条命令书写在一行中。
  • 注释以//开始。
  • 脚本可以保存为txt文件,用npp_exec执行。
  • 脚本存储在插件配置目录下,该目录存储在环境变量$(PLUGINS_CONFIG_DIR)中。
  • 保存的脚本在npes_saved.txt中,从其中可以查看脚本保存的格式。临时脚本在npes_temp.txt中。

重点是执行脚本的四种方式、两类过程(内部和外部)和脚本基础知识,下次介绍环境变量。

05-08 15:33