| /* |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| */ |
| |
| //For browser platform: not all browsers use overrided `resolveLocalFileSystemURL`. |
| function checkBrowser() { |
| if (cordova.platformId === "browser" && require('./isChrome')()) { |
| module.exports.resolveLocalFileSystemURL = window.resolveLocalFileSystemURL || window.webkitResolveLocalFileSystemURL; |
| return true; |
| } |
| return false; |
| } |
| if (checkBrowser()) { |
| return; |
| } |
| |
| var argscheck = require('cordova/argscheck'), |
| DirectoryEntry = require('./DirectoryEntry'), |
| FileEntry = require('./FileEntry'), |
| FileError = require('./FileError'), |
| exec = require('cordova/exec'); |
| var fileSystems = require('./fileSystems'); |
| |
| /** |
| * Look up file system Entry referred to by local URI. |
| * @param {DOMString} uri URI referring to a local file or directory |
| * @param successCallback invoked with Entry object corresponding to URI |
| * @param errorCallback invoked if error occurs retrieving file system entry |
| */ |
| module.exports.resolveLocalFileSystemURL = module.exports.resolveLocalFileSystemURL || function(uri, successCallback, errorCallback) { |
| argscheck.checkArgs('sFF', 'resolveLocalFileSystemURI', arguments); |
| // error callback |
| var fail = function(error) { |
| errorCallback && errorCallback(new FileError(error)); |
| }; |
| // sanity check for 'not:valid:filename' or '/not:valid:filename' |
| // file.spec.12 window.resolveLocalFileSystemURI should error (ENCODING_ERR) when resolving invalid URI with leading /. |
| if(!uri || uri.split(":").length > 2) { |
| setTimeout( function() { |
| fail(FileError.ENCODING_ERR); |
| },0); |
| return; |
| } |
| // if successful, return either a file or directory entry |
| var success = function(entry) { |
| if (entry) { |
| if (successCallback) { |
| // create appropriate Entry object |
| var fsName = entry.filesystemName || (entry.filesystem && entry.filesystem.name) || (entry.filesystem == window.PERSISTENT ? 'persistent' : 'temporary'); |
| fileSystems.getFs(fsName, function(fs) { |
| // This should happen only on platforms that haven't implemented requestAllFileSystems (windows) |
| if (!fs) { |
| fs = new FileSystem(fsName, {name:"", fullPath:"/"}); |
| } |
| var result = (entry.isDirectory) ? new DirectoryEntry(entry.name, entry.fullPath, fs, entry.nativeURL) : new FileEntry(entry.name, entry.fullPath, fs, entry.nativeURL); |
| successCallback(result); |
| }); |
| } |
| } |
| else { |
| // no Entry object returned |
| fail(FileError.NOT_FOUND_ERR); |
| } |
| }; |
| |
| exec(success, fail, "File", "resolveLocalFileSystemURI", [uri]); |
| }; |
| |
| module.exports.resolveLocalFileSystemURI = function() { |
| console.log("resolveLocalFileSystemURI is deprecated. Please call resolveLocalFileSystemURL instead."); |
| module.exports.resolveLocalFileSystemURL.apply(this, arguments); |
| }; |