应用程序根目录
指 aardio 工程目录。
应用程序根目录
指启动 EXE 文件所在目录。应用程序根目录
。fiber.create(func,appDir)
创建纤程时,可选用 appDir 参数自定义该纤程的应用程序根目录
。除了在创建线程或纤程时有一次指定应用程序根目录
的机会,aardio 不允许以其他方式变更应用程序根目录
。正因如此,相对可以随意变更的当前目录(以 ./
表示 )而言,aardio 的 应用程序根目录
总是表示确定的位置,更加可靠。
\
或 /
作为首字符表示 aardio 应用程序根目录
。~
开始表示当前启动 EXE 文件所在目录。aardio 中基本有用到文件路径参数的函数或功能都支持以上路径语法与规则。例如在窗体中设置图片的路径,$
包含操作符跟随的文件路径,以及 string.load ,string.save 等标准库函数的文件的路径参数都支持上述路径语法规则。
~
开头的路径自动切换为 \
开头的路径:对于 $
包含操作符,以及 raw.loadDll(path)
string.load(path)
string.loadBuffer(path)
函数,如果 path 参数指定的文件路径是以 ~
开头但是在 EXE 目录下并不存在匹配的实际路径,则会自动切换为 \
开头的路径并尝试重新在应用程序根目录
下查找匹配的路径并读取文件。
不是 aardio 实现的外部接口函数(例如 DLL 导入的 API,COM 控件对象接口)的文件路径参数则应当提前进行转换使用了 aardio 特殊格式的路径,有两种转换方法:
io.fullpath(path)
函数将 path 参数转换为绝对路径。io.localpath(path) || path
则仅在 path 参数是以单个 \
、 /
或 ~
字符开始的文件路径才转换为绝对路径,否则直接返回。函数原型:
绝对路径 = io.fullpath( 相对路径 )
函数说明:
io.fullpath 将输入参数指定的相对路径转换为绝对路径。
转换规则如下:
\\
开始,不作转换直接返回,路径前加 \\?\
可避免转换并支持畸形路径。//
开始,移除第一个斜杠后返回,不作其他转换,可用于表示系统分区根目录,\
或/
字符开始,作为 aardio 应用程序根目录下的相对路径转换并返回完整路径。~
开始,作为当前运行的 EXE 根目录下的相对路径转换并返回完整路径。此函数并不会检测路径是否存在,但会检测参数是否正确的路径名,并纠正错误的写法,例如将正斜杠修正为反斜杠。
aardio 自带的文件操作函数基本都会自动调用 io.fullpath 转换参数传入的文件路径。
但是要注意在文件路径开始以 ~
表示 EXE 启动目录以及以单个 \
或 /
作为首字符表示 aardio 应用程序根目录的写法仅适用于 aardio,其他外部组件或外部接口并不支持,我们需要调用 io.fullpath 将 aardio 路径转换为其他外部程序可以识别的绝对路径。
调用示例:
var path = io.fullpath( "/res/test.jpg" )
函数原型:
绝对路径 = io.localpath( 相对路径 )
函数说明:
如果参数指定的文件路径使用了 aardio 专用格式则转换为系统支持的完整路径,否则返回空值。
转换规则如下:
\\
开始,不作转换直接返回 null 空值。//
开始,移除第一个斜杠后返回,不作其他转换,可用于表示系统分区根目录。\
/
字符开始,将参数作为 aardio 应用程序根目录下的相对路径转换并返回完整路径。~
开始,将参数作为当前启动 EXE 根目录下的相对路径转换并返回完整路径。函数原型:
fullpath = io.exist( path,mode )
函数说明:
指定的文件路径参数 @path 如果不是字符串、不是一个合法的路径、或是一个空字符串时该函数返回 null 值。否则,此函数调用 io.fullpath 将文件路径转换为绝对路径,如果文件存在返回绝对路径,否则返 回 null 。
参数 @mode 用于添加检测条件,可选值如下:
传入错误的参数 @path 时,io.exist 不会抛出异常,而是返回 null 值。
null 在条件表达式中可以转换为 false , 表示条件假值。
调用示例:
var fullpath = io.exist( "/res/test.jpg" );
if(!fullpath){
error("文件不存在")
}
函数原型:
var pathInfo = io.splitpath( filepath )
函数说明:
该函数拆分参数 filepath 指定的文件路径为多个部分,并返回包含这些拆分部分的对象 pathInfo 。
pathInfo 有以下成员:
pathInfo.dir ++ pathInfo.file
等于完整的文件路径。调用示例:
//新建一个控制台程序,main.aardio 代码如下
//将参数去掉引号
var path = string.trim( _CMDLINE ,'"');
//拆分为目录名,文件名,后缀名,分区号
var pathInfo = io.splitpath(path)
//重命名
io.rename( path,pathInfo.dir ++ pathInfo.ext )
//发布该程序为 exe 文件,将需要去掉文件名字的文件 - 往该 exe 上一拖即可.
只读属性,返回启动主程序的exe文件路径,开发环境中此属性返回 aardio.exe 的完整文件路径。
只读属性,返回启动主程序的 exe 文件所在的目录路径,开发环境中此属性返回 aardio.exe 所在的目录路径。
只读属性,返回启动主程序的 exe 文件名