diff --git a/js/ui/cordova/plugins/cordova-plugin-file/www/blackberry10/getDirectory.js b/js/ui/cordova/plugins/cordova-plugin-file/www/blackberry10/getDirectory.js new file mode 100644 index 0000000..265818c --- /dev/null +++ b/js/ui/cordova/plugins/cordova-plugin-file/www/blackberry10/getDirectory.js @@ -0,0 +1,72 @@ +/* + * + * 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. + * +*/ + +/* + * getDirectory + * + * IN: + * args + * 0 - local filesytem URI for the base directory to search + * 1 - directory to be created/returned; may be absolute path or relative path + * 2 - options object + * OUT: + * success - DirectoryEntry + * fail - FileError code + */ + +var resolve = cordova.require('cordova-plugin-file.resolveLocalFileSystemURIProxy'), + requestAnimationFrame = cordova.require('cordova-plugin-file.bb10RequestAnimationFrame'); + +module.exports = function (success, fail, args) { + var uri = args[0] === "/" ? "" : args[0], + dir = args[1], + options = args[2], + onSuccess = function (entry) { + if (typeof(success) === 'function') { + success(entry); + } + }, + onFail = function (error) { + if (typeof(fail) === 'function') { + if (error && error.code) { + //set error codes expected by mobile-spec tests + if (error.code === FileError.INVALID_MODIFICATION_ERR && options.exclusive) { + fail(FileError.PATH_EXISTS_ERR); + } else if ( error.code === FileError.NOT_FOUND_ERR && dir.indexOf(':') > 0) { + fail(FileError.ENCODING_ERR); + } else { + fail(error.code); + } + } else { + fail(error); + } + } + }; + resolve(function (entry) { + requestAnimationFrame(function () { + entry.nativeEntry.getDirectory(dir, options, function (nativeEntry) { + resolve(function (entry) { + onSuccess(entry); + }, onFail, [uri + "/" + dir]); + }, onFail); + }); + }, onFail, [uri]); +};