我正在将公司的一个应用程序移动到64位环境中,这样就不能再访问FSSpec功能了。
我们有一些文件格式的数据结构,可以将vRefNum和dirID从旧的FSSpec格式保存到文件中.在过去,我们能够使用碳例程,从FSSpec到FSRef,最后再到CFURL,但FSSpec例程在64位中根本没有可用,甚至在10.9时也不再推荐使用FSRef例程。
在内部,我们正在使用CFURL/NSURL,但仍然希望支持与这些旧的文件格式之间的转换。有任何方法,使用非推荐(或至少64位友好)例程,我可以在vRefNum和dirID之间的CFURL?
非常感谢。
发布于 2014-08-01 01:35:47
苹果不支持这一点,但您可以使用volfs文件系统来完成这一任务,而碳在内部就是这样做的。请参阅来自Apple的以下文档:
http://developer.apple.com/legacy/library/qa/qa2001/qa1113.html
下面是一个从卷ID和目录ID创建CFURLRef的函数:
CFURLRef CreateURLFromVolumeIDandDirectoryID(dev_t volumeID, SInt32 directoryID)
{
CFStringRef thePath = CFStringCreateWithFormat(kCFAllocatorDefault, NULL,
CFSTR("/.vol/%d/%d"), volumeID, (int) directoryID);
CFURLRef theURL = CFURLCreateWithFileSystemPath(kCFAllocatorDefault, thePath,
kCFURLPOSIXPathStyle, false);
CFRelease(thePath);
return theURL;
}要使用volfs,还需要将卷引用号转换为卷ID。
dev_t ConvertVolumeRefNumtoVolumeID(FSVolumeRefNum refNum)
{
FSRef root;
OSErr error = FSGetVolumeInfo(refNum, 0, NULL, kFSVolInfoNone, NULL, NULL, &root);
if(error != noErr)
return 0;
UInt8 path[500];
OSStatus status = FSRefMakePath(&root, path, 500);
if(status != noErr)
return 0;
struct stat volStats;
int err = stat((const char*)path, &volStats);
if(err != 0)
return 0;
return volStats.st_dev;
}根据链接文档,应用程序不应该这样做,这可能会停止在任何未来版本的OS X,但你问.
此外,当卷被卸载然后重新挂载时,卷引用号不能保证保持不变,所以如果将它们写入磁盘,则会有另一个问题。
发布于 2014-07-31 20:44:50
我觉得你们留得太久了。FSRef在2001年就在那里。FSSpec是预碳.我想说,您需要一个32位助手应用程序,它将FSSpecs转换为路径,然后通过分布式对象调用它。
无论你看到什么地方都要替换FSSpec。只有在需要时才启动助手应用程序,因此过一段时间,用户就不会再看到它了。
https://stackoverflow.com/questions/25067954
复制相似问题