这次要说的是如何支持两个Windows shell的新特性:details expando和find in files。
Details expando,这个东西就是Explorer窗口左边的任务列表中“细节”栏的内容。(打开Explorer,将文件夹和搜索两个按钮置为抬起状态,就可以看到左边一排可以伸展收缩的框,称为expando。)在RarFS 0.0.8之前的版本中,如果选中一个rar里面的文件,在details栏里只能看到文件名。
猜想这和没有实现GetDetailsEx接口有关,于是在那儿加上log。
果然,当taskband显示时,explorer会通过GetDetailsEx来查询当前选中项的数个属性,依次是:
FMTID_WebView
FMTID_FileAttributes (微软没有公开此fmtid)
FMTID_Storage
前两项经实验,不必提供任何信息(如果提供了FMTID_WebView信息,details expando会消失)。FMTID_Storage则必须提供。
Explorer会查询如下三个PROPID:
PID_STG_STORAGETYPE
PID_STG_SIZE
PID_STG_WRITETIME
在MSDN中称,这三个PROPID都是VT_BSTR,这是完全错误的。实际上,只有PID_STG_STORAGETYPE是VT_BSTR类型,而后两个分别是VT_I8和VT_DATE类型。
下面的代码将SYSTEMDATE转换为本地时间的DATE类型:
VARIANT* pv; // passed from parameter
SYSTEMTIME st;
FILETIME ftLocal, ft;
item.GetSystemTime(&st);
SystemTimeToFileTime(&st, &ftLocal);
LocalFileTimeToFileTime(&ftLocal, &ft);
FileTimeToSystemTime(&ft, &st);
SystemTimeToVariantTime(&st, &pv->date);
FILETIME ftLocal, ft;
item.GetSystemTime(&st);
SystemTimeToFileTime(&st, &ftLocal);
LocalFileTimeToFileTime(&ftLocal, &ft);
FileTimeToSystemTime(&ft, &st);
SystemTimeToVariantTime(&st, &pv->date);
正确填写了这三个属性后,details中就会出现文件的正确信息,多选时,Explorer会自动判断哪些信息无法同时显示,并能累加文件的总长度。
支持file in files的in-archive搜索则相对比较简单,首先,在定义自己NSE的各个column时,必须注意,前4项顺序必须是:
0 - Name
1 - Size
2 - Type
3 - Time
这是任何位置上Explorer自己的所有column都有的属性。
之后,只要实现MapColumnToSCID,就可以把我们的column和系统的column一一对应。SHCOLUMNID中的fmtid均为FMTID_Storage,而pid为PID_STG_NAME、PID_STG_SIZE、PID_STG_STORAGETYPE和PID_STG_WRITETIME。