filer/dist/filer.map

1 line
399 KiB
Plaintext

{"version":3,"sources":["../lib/nodash.js","../node_modules/es6-promisify/dist/promisify.js","path.js","errors.js","shared.js","constants.js","../node_modules/base64-js/index.js","../node_modules/ieee754/index.js","../node_modules/isarray/index.js","../node_modules/buffer/index.js","buffer.js","providers/indexeddb.js","../node_modules/base64-arraybuffer/lib/base64-arraybuffer.js","providers/websql.js","../node_modules/process/browser.js","../lib/async.js","providers/memory.js","providers/index.js","shell/environment.js","../node_modules/path-browserify/index.js","../node_modules/concat-map/index.js","../node_modules/balanced-match/index.js","../node_modules/brace-expansion/index.js","../node_modules/minimatch/minimatch.js","shell/shell.js","../lib/eventemitter.js","../lib/intercom.js","fs-watcher.js","encoding.js","directory-entry.js","open-file-description.js","super-node.js","node.js","stats.js","filesystem/implementation.js","filesystem/interface.js","index.js"],"names":["ArrayProto","Array","prototype","nativeForEach","forEach","nativeIndexOf","indexOf","nativeSome","some","ObjProto","Object","hasOwnProperty","nativeKeys","keys","breaker","has","obj","key","call","TypeError","push","size","length","identity","value","each","iterator","context","i","any","result","index","list","contains","target","Wrapped","nodash","isArray","module","exports","normalizeArray","parts","allowAboveRoot","up","last","splice","unshift","splitPathRe","splitPath","filename","exec","resolve","resolvedPath","resolvedAbsolute","arguments","path","charAt","split","filter","p","join","normalize","isAbsolute","paths","slice","relative","from","to","substr","trim","arr","start","end","fromParts","toParts","Math","min","samePartsLength","outputParts","concat","dirname","root","dir","basename","ext","f","extname","isNull","addTrailing","replace","removeTrailing","sep","delimiter","errors","e","errno","errName","defaultMessage","FilerError","msg","Error","name","code","message","stack","create","constructor","toString","pathInfo","Errors","require","guid","c","r","random","v","toUpperCase","nop","u8toArray","u8","array","len","validateInteger","err","EINVAL","captureStackTrace","O_READ","O_WRITE","O_CREATE","O_EXCLUSIVE","O_TRUNCATE","O_APPEND","XATTR_CREATE","XATTR_REPLACE","FILE_SYSTEM_NAME","FILE_STORE_NAME","IDB_RO","IDB_RW","WSQL_VERSION","WSQL_SIZE","WSQL_DESC","NODE_TYPE_FILE","NODE_TYPE_DIRECTORY","NODE_TYPE_SYMBOLIC_LINK","NODE_TYPE_META","S_IFREG","S_IFDIR","S_IFLNK","DEFAULT_DIR_PERMISSIONS","DEFAULT_FILE_PERMISSIONS","FULL_READ_WRITE_EXEC_PERMISSIONS","READ_WRITE_PERMISSIONS","SYMLOOP_MAX","BINARY_MIME_TYPE","JSON_MIME_TYPE","ROOT_DIRECTORY_NAME","FS_FORMAT","FS_NOCTIME","FS_NOMTIME","FS_NODUPEIDCHECK","O_FLAGS","FS_READY","FS_PENDING","FS_ERROR","SUPER_NODE_ID","STDIN","STDOUT","STDERR","FIRST_DESCRIPTOR","ENVIRONMENT","TMP","PATH","fsConstants","O_RDONLY","O_WRONLY","O_RDWR","S_IFMT","S_IFCHR","S_IFBLK","S_IFIFO","S_IFSOCK","O_CREAT","O_EXCL","O_NOCTTY","O_TRUNC","O_DIRECTORY","O_NOFOLLOW","O_SYNC","O_DSYNC","O_SYMLINK","O_NONBLOCK","S_IRWXU","S_IRUSR","S_IWUSR","S_IXUSR","S_IRWXG","S_IRGRP","S_IWGRP","S_IXGRP","S_IRWXO","S_IROTH","S_IWOTH","S_IXOTH","F_OK","R_OK","W_OK","X_OK","UV_FS_COPYFILE_EXCL","COPYFILE_EXCL","FilerBuffer","subject","encoding","nonZero","ArrayBuffer","Uint8Array","Buffer","indexedDB","global","mozIndexedDB","webkitIndexedDB","msIndexedDB","IndexedDBContext","db","mode","_getObjectStore","objectStore","transaction","clear","callback","request","onsuccess","onerror","event","preventDefault","error","_get","get","getObject","getBuffer","arrayBuffer","_put","put","putObject","putBuffer","uint8BackedBuffer","buf","buffer","delete","IndexedDB","isSupported","open","that","openRequest","onupgradeneeded","objectStoreNames","deleteObjectStore","createObjectStore","getReadOnlyContext","getReadWriteContext","chars","lookup","charCodeAt","encode","arraybuffer","bytes","base64","substring","decode","bufferLength","encoded1","encoded2","encoded3","encoded4","base64ArrayBuffer","WebSQLContext","isReadOnly","getTransaction","onError","onSuccess","executeSql","rows","item","data","JSON","parse","json","stringify","WebSQL","openDatabase","createIndex","process","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","setTimeout","clearTimeout","runTimeout","fun","runClearTimeout","marker","queue","draining","currentQueue","queueIndex","cleanUpNextTick","drainQueue","timeout","run","nextTick","args","Item","apply","title","browser","env","argv","version","versions","noop","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","umask","async","setImmediate","fn","eachSeries","completed","iterate","forEachSeries","define","amd","asyncCallback","createDB","pool","getOrCreate","MemoryContext","readOnly","Memory","Default","Fallback","NotSupported","defaults","Environment","set","promisify","Path","minimatch","Shell","fs","options","defineProperty","enumerable","cd","stat","stats","ENOTDIR","type","pwd","promises","methodName","bind","sh","readFile","cmd","Function","touch","createFile","writeFile","updateTimes","now","Date","atime","date","mtime","utimes","updateOnly","cat","files","all","append","ls","pathname","readdir","entries","getDirEntry","entry","recursive","items","contents","rm","remove","unlink","rmdir","ENOTEMPTY","map","tempDir","tmp","mkdir","mkdirp","_mkdirp","isDirectory","isFile","parent","find","next","found","processPath","maybeProcessPath","rawPath","regex","test","walk","removeItem","EventEmitter","createInterface","space","methods","trigger","self","pvt","_on","_off","_trigger","pub","throttle","delay","extend","a","b","localStorage","window","getItem","setItem","Intercom","origin","lastMessage","receivedIDs","previousValues","storageHandler","_onStorageEvent","document","attachEvent","addEventListener","_transaction","TIMEOUT","WAIT","executed","listening","waitTimer","lock","activeLock","INDEX_LOCK","unlock","_cleanup_emit","threshold","THRESHOLD_TTL_EMIT","changed","messages","INDEX_EMIT","timestamp","_cleanup_once","ttl","table","INDEX_ONCE","_once_expired","THRESHOLD_TTL_ONCE","_localStorageChanged","field","currentValue","id","payload","_emit","String","packet","supported","destroy","getInstance","intercom","FSWatcher","recursivePathPrefix","onchange","filename_","persistent_","recursive_","close","string","DirectoryEntry","OpenFileDescription","flags","position","getNode","check_if_node_exists","node","EBADF","Constants","SuperNode","ctime","rnode","getMode","Node","xattrs","nlinks","uid","gid","ensureID","prop","setMode","Stats","fileNode","devName","dev","isSymbolicLink","isSocket","isFIFO","isCharacterDevice","isBlockDevice","_","isAbsolutePath","isNullPath","Encoding","update_node_times","times","update","complete","changes","make_node","parentPath","parentNode","parentNodeData","create_node_in_parent","parentDirectoryNode","find_node","EEXIST","ENOENT","create_node","update_parent_node_data","update_time","followedCount","read_root_directory_node","superNode","EFILESYSTEMERROR","check_root_directory_node","rootDirectoryNode","read_parent_directory_data","get_node_from_parent_directory_data","parentDirectoryData","nodeId","is_symbolic_link","ELOOP","follow_symbolic_link","set_extended_attribute","flag","ENOATTR","ensure_root_directory","directoryNode","directoryData","ensure_super_node","existingNode","write_directory_node","write_directory_data","make_directory","check_if_directory_exists","update_parent_directory_data","remove_directory","EBUSY","check_if_node_is_directory","check_if_directory_is_empty","remove_directory_entry_from_parent_directory_node","remove_directory_node","remove_directory_data","open_file","directoryEntry","fileData","EISDIR","set_file_node","read_directory_data","check_if_file_exists","check_if_symbolic_link","write_file_node","undefined","write_file_data","fill","update_directory_data","handle_update_result","replace_data","ofd","offset","return_nbytes","update_file_node","newData","copy","write_data","update_file_data","EIO","_position","newSize","max","read_file_data","read_data","handle_file_data","stat_file","fstat_file","lstat_file","link_node","oldpath","newpath","oldname","oldParentPath","newname","newParentPath","oldDirectoryNode","oldDirectoryData","newDirectoryNode","newDirectoryData","fileNodeID","read_file_node","check_if_new_file_exists","read_new_directory_data","check_if_old_file_exists","EPERM","read_old_directory_data","unlink_node","delete_file_data","read_directory","handle_directory_data","make_symbolic_link","srcpath","dstpath","symlink_relpath","read_link","check_if_symbolic","truncate_file","truncate_file_data","ftruncate_file","utimes_file","update_times","futimes_file","setxattr_file","setxattr","fsetxattr_file","getxattr_file","get_xattr","fgetxattr_file","removexattr_file","remove_xattr","fremovexattr_file","validate_flags","validate_file_options","enc","fileMode","pathCheck","allowRelative","check_result","openFileDescription","fd","allocDescriptor","openFiles","releaseDescriptor","mknod","validateAndMaskMode","fstat","link","read","wrapped_cb","bytesRead","cleanup","fstatResult","write","appendFile","exists","cb","console","warn","octalReg","isUint32","def","Number","isInteger","parsed","parseInt","chmod_file","update_mode","fchmod_file","chown_file","update_owner","fchown_file","getxattr","fgetxattr","fsetxattr","removexattr","fremovexattr","lseek","whence","update_descriptor_position","currentTime","futimes","chmod","fchmod","chown","fchown","rename","oldName","newName","oldParentDirectory","oldParentData","newParentDirectory","newParentData","read_new_directory","update_old_parent_directory_data","update_new_parent_directory_data","check_if_new_directory_exists","read_new_parent_directory_data","get_new_parent_directory","unlink_old_file","check_node_type","symlink","readlink","lstat","truncate","ftruncate","ensureRootDirectory","providers","defaultGuidFn","impl","maybeCallback","defaultCallback","FileSystem","provider","forceFormatting","readyState","stdin","stdout","stderr","constants","nextDescriptor","queueOrRun","operation","runQueued","watch","listener","watcher","wrappedGuidFn","guidWithCheck","broadcastChanges","change","wrappedContext","openReadWriteContext","openReadOnlyContext","lastArgIndex","missingCallback","fnArgs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AAEA;;;;;;;AAOA,IAAIA,aAAaC,MAAMC,SAAvB;AACA,IAAIC,gBAAgBH,WAAWI,OAA/B;AACA,IAAIC,gBAAgBL,WAAWM,OAA/B;AACA,IAAIC,aAAaP,WAAWQ,IAA5B;;AAEA,IAAIC,WAAWC,OAAOR,SAAtB;AACA,IAAIS,iBAAiBF,SAASE,cAA9B;AACA,IAAIC,aAAaF,OAAOG,IAAxB;;AAEA,IAAIC,UAAU,EAAd;;AAEA,SAASC,GAAT,CAAaC,GAAb,EAAkBC,GAAlB,EAAuB;AACrB,SAAON,eAAeO,IAAf,CAAoBF,GAApB,EAAyBC,GAAzB,CAAP;AACD;;AAED,IAAIJ,OAAOD,cAAc,UAASI,GAAT,EAAc;AACrC,MAAIA,QAAQN,OAAOM,GAAP,CAAZ,EAAyB,MAAM,IAAIG,SAAJ,CAAc,gBAAd,CAAN;AACzB,MAAIN,OAAO,EAAX;AACA,OAAK,IAAII,GAAT,IAAgBD,GAAhB;AAAqB,QAAID,IAAIC,GAAJ,EAASC,GAAT,CAAJ,EAAmBJ,KAAKO,IAAL,CAAUH,GAAV;AAAxC,GACA,OAAOJ,IAAP;AACD,CALD;;AAOA,SAASQ,IAAT,CAAcL,GAAd,EAAmB;AACjB,MAAIA,OAAO,IAAX,EAAiB,OAAO,CAAP;AACjB,SAAQA,IAAIM,MAAJ,KAAe,CAACN,IAAIM,MAArB,GAA+BN,IAAIM,MAAnC,GAA4CT,KAAKG,GAAL,EAAUM,MAA7D;AACD;;AAED,SAASC,QAAT,CAAkBC,KAAlB,EAAyB;AACvB,SAAOA,KAAP;AACD;;AAED,SAASC,IAAT,CAAcT,GAAd,EAAmBU,QAAnB,EAA6BC,OAA7B,EAAsC;AACpC,MAAIC,CAAJ,EAAON,MAAP;AACA,MAAIN,OAAO,IAAX,EAAiB;AACjB,MAAIb,iBAAiBa,IAAIZ,OAAJ,KAAgBD,aAArC,EAAoD;AAClDa,QAAIZ,OAAJ,CAAYsB,QAAZ,EAAsBC,OAAtB;AACD,GAFD,MAEO,IAAIX,IAAIM,MAAJ,KAAe,CAACN,IAAIM,MAAxB,EAAgC;AACrC,SAAKM,IAAI,CAAJ,EAAON,SAASN,IAAIM,MAAzB,EAAiCM,IAAIN,MAArC,EAA6CM,GAA7C,EAAkD;AAChD,UAAIF,SAASR,IAAT,CAAcS,OAAd,EAAuBX,IAAIY,CAAJ,CAAvB,EAA+BA,CAA/B,EAAkCZ,GAAlC,MAA2CF,OAA/C,EAAwD;AACzD;AACF,GAJM,MAIA;AACL,QAAID,OAAOA,KAAKG,GAAL,CAAX;AACA,SAAKY,IAAI,CAAJ,EAAON,SAAST,KAAKS,MAA1B,EAAkCM,IAAIN,MAAtC,EAA8CM,GAA9C,EAAmD;AACjD,UAAIF,SAASR,IAAT,CAAcS,OAAd,EAAuBX,IAAIH,KAAKe,CAAL,CAAJ,CAAvB,EAAqCf,KAAKe,CAAL,CAArC,EAA8CZ,GAA9C,MAAuDF,OAA3D,EAAoE;AACrE;AACF;AACF;;AAED,SAASe,GAAT,CAAab,GAAb,EAAkBU,QAAlB,EAA4BC,OAA5B,EAAqC;AACnCD,eAAaA,WAAWH,QAAxB;AACA,MAAIO,SAAS,KAAb;AACA,MAAId,OAAO,IAAX,EAAiB,OAAOc,MAAP;AACjB,MAAIvB,cAAcS,IAAIR,IAAJ,KAAaD,UAA/B,EAA2C,OAAOS,IAAIR,IAAJ,CAASkB,QAAT,EAAmBC,OAAnB,CAAP;AAC3CF,OAAKT,GAAL,EAAU,UAASQ,KAAT,EAAgBO,KAAhB,EAAuBC,IAAvB,EAA6B;AACrC,QAAIF,WAAWA,SAASJ,SAASR,IAAT,CAAcS,OAAd,EAAuBH,KAAvB,EAA8BO,KAA9B,EAAqCC,IAArC,CAApB,CAAJ,EAAqE,OAAOlB,OAAP;AACtE,GAFD;AAGA,SAAO,CAAC,CAACgB,MAAT;AACD;;AAED,SAASG,QAAT,CAAkBjB,GAAlB,EAAuBkB,MAAvB,EAA+B;AAC7B,MAAIlB,OAAO,IAAX,EAAiB,OAAO,KAAP;AACjB,MAAIX,iBAAiBW,IAAIV,OAAJ,KAAgBD,aAArC,EAAoD,OAAOW,IAAIV,OAAJ,CAAY4B,MAAZ,KAAuB,CAAC,CAA/B;AACpD,SAAOL,IAAIb,GAAJ,EAAS,UAASQ,KAAT,EAAgB;AAC9B,WAAOA,UAAUU,MAAjB;AACD,GAFM,CAAP;AAGD;;AAED,SAASC,OAAT,CAAiBX,KAAjB,EAAwB;AACtB,OAAKA,KAAL,GAAaA,KAAb;AACD;AACDW,QAAQjC,SAAR,CAAkBa,GAAlB,GAAwB,UAASE,GAAT,EAAc;AACpC,SAAOF,IAAI,KAAKS,KAAT,EAAgBP,GAAhB,CAAP;AACD,CAFD;AAGAkB,QAAQjC,SAAR,CAAkB+B,QAAlB,GAA6B,UAASC,MAAT,EAAiB;AAC5C,SAAOD,SAAS,KAAKT,KAAd,EAAqBU,MAArB,CAAP;AACD,CAFD;AAGAC,QAAQjC,SAAR,CAAkBmB,IAAlB,GAAyB,YAAW;AAClC,SAAOA,KAAK,KAAKG,KAAV,CAAP;AACD,CAFD;;AAIA,SAASY,MAAT,CAAgBZ,KAAhB,EAAuB;AACrB;AACA,SAAQA,SAAS,QAAOA,KAAP,yCAAOA,KAAP,MAAgB,QAAzB,IAAqC,CAACvB,MAAMoC,OAAN,CAAcb,KAAd,CAAtC,IAA8Db,eAAeO,IAAf,CAAoBM,KAApB,EAA2B,aAA3B,CAA/D,GACHA,KADG,GAEH,IAAIW,OAAJ,CAAYX,KAAZ,CAFJ;AAGD;;AAEDc,OAAOC,OAAP,GAAiBH,MAAjB;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;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;AAwCXC,mBAAe;AAxCJ;AAjFE,CAAjB;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7vDA,SAASC,WAAT,CAAsBC,OAAtB,EAA+BC,QAA/B,EAAyCC,OAAzC,EAAkD;;AAEhD;AACA;AACA,MAAIF,mBAAmBG,WAAvB,EAAoC;AAClCH,cAAU,IAAII,UAAJ,CAAeJ,OAAf,CAAV;AACD;;AAED,SAAO,IAAIK,MAAJ,CAAWL,OAAX,EAAoBC,QAApB,EAA8BC,OAA9B,CAAP;AACD;;AAED;AACAH,YAAY/M,SAAZ,GAAwBQ,OAAO+F,MAAP,CAAc8G,OAAOrN,SAArB,CAAxB;AACA+M,YAAY/M,SAAZ,CAAsBwG,WAAtB,GAAoCuG,WAApC;;AAEA;AACAvM,OAAOG,IAAP,CAAY0M,MAAZ,EAAoBnN,OAApB,CAA4B,UAAUuD,CAAV,EAAa;AACvC,MAAI4J,OAAO5M,cAAP,CAAsBgD,CAAtB,CAAJ,EAA8B;AAC5BsJ,gBAAYtJ,CAAZ,IAAiB4J,OAAO5J,CAAP,CAAjB;AACD;AACF,CAJD;;AAMArB,OAAOC,OAAP,GAAiB0K,WAAjB;;;ACtBA,IAAI3E,mBAAmBxB,QAAQ,iBAAR,EAA2B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hJ,IAAJ,GAAWgJ,IAAIhJ,IAAJ,IAAYsL,SAAStL,IAAhC;;AAEA,OAAKiE,GAAL,GAAW,UAASvI,IAAT,EAAe;AACxB,WAAOsN,IAAItN,IAAJ,CAAP;AACD,GAFD;;AAIA,OAAK8P,GAAL,GAAW,UAAS9P,IAAT,EAAe7E,KAAf,EAAsB;AAC/BmS,QAAItN,IAAJ,IAAY7E,KAAZ;AACD,GAFD;AAGD,CAZD;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA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","file":"filer.map","sourceRoot":"../src","sourcesContent":["// Cherry-picked bits of underscore.js, lodash.js\n\n/**\n * Lo-Dash 2.4.0 <http://lodash.com/>\n * Copyright 2012-2013 The Dojo Foundation <http://dojofoundation.org/>\n * Based on Underscore.js 1.5.2 <http://underscorejs.org/LICENSE>\n * Copyright 2009-2013 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n * Available under MIT license <http://lodash.com/license>\n */\nvar ArrayProto = Array.prototype;\nvar nativeForEach = ArrayProto.forEach;\nvar nativeIndexOf = ArrayProto.indexOf;\nvar nativeSome = ArrayProto.some;\n\nvar ObjProto = Object.prototype;\nvar hasOwnProperty = ObjProto.hasOwnProperty;\nvar nativeKeys = Object.keys;\n\nvar breaker = {};\n\nfunction has(obj, key) {\n return hasOwnProperty.call(obj, key);\n}\n\nvar keys = nativeKeys || function(obj) {\n if (obj !== Object(obj)) throw new TypeError('Invalid object');\n var keys = [];\n for (var key in obj) if (has(obj, key)) keys.push(key);\n return keys;\n};\n\nfunction size(obj) {\n if (obj == null) return 0;\n return (obj.length === +obj.length) ? obj.length : keys(obj).length;\n}\n\nfunction identity(value) {\n return value;\n}\n\nfunction each(obj, iterator, context) {\n var i, length;\n if (obj == null) return;\n if (nativeForEach && obj.forEach === nativeForEach) {\n obj.forEach(iterator, context);\n } else if (obj.length === +obj.length) {\n for (i = 0, length = obj.length; i < length; i++) {\n if (iterator.call(context, obj[i], i, obj) === breaker) return;\n }\n } else {\n var keys = keys(obj);\n for (i = 0, length = keys.length; i < length; i++) {\n if (iterator.call(context, obj[keys[i]], keys[i], obj) === breaker) return;\n }\n }\n};\n\nfunction any(obj, iterator, context) {\n iterator || (iterator = identity);\n var result = false;\n if (obj == null) return result;\n if (nativeSome && obj.some === nativeSome) return obj.some(iterator, context);\n each(obj, function(value, index, list) {\n if (result || (result = iterator.call(context, value, index, list))) return breaker;\n });\n return !!result;\n};\n\nfunction contains(obj, target) {\n if (obj == null) return false;\n if (nativeIndexOf && obj.indexOf === nativeIndexOf) return obj.indexOf(target) != -1;\n return any(obj, function(value) {\n return value === target;\n });\n};\n\nfunction Wrapped(value) {\n this.value = value;\n}\nWrapped.prototype.has = function(key) {\n return has(this.value, key);\n};\nWrapped.prototype.contains = function(target) {\n return contains(this.value, target);\n};\nWrapped.prototype.size = function() {\n return size(this.value);\n};\n\nfunction nodash(value) {\n // don't wrap if already wrapped, even if wrapped by a different `lodash` constructor\n return (value && typeof value == 'object' && !Array.isArray(value) && hasOwnProperty.call(value, '__wrapped__'))\n ? value\n : new Wrapped(value);\n}\n\nmodule.exports = nodash;\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n// Symbols is a better way to do this, but if we don't have support we'll just\n// have to make do with an unlikely token\nvar customArgumentsToken = Symbol ? Symbol(\"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\") : \"__ES6-PROMISIFY--CUSTOM-ARGUMENTS__\";\n\n/**\n * promisify()\n * Transforms callback-based function -- func(arg1, arg2 .. argN, callback) -- into\n * an ES6-compatible Promise. Promisify provides a default callback of the form (error, result)\n * and rejects when `error` is truthy.\n *\n * @param {function} original - The function to promisify\n * @return {function} A promisified version of `original`\n */\nfunction promisify(original) {\n\n // Ensure the argument is a function\n if (typeof original !== \"function\") {\n throw new TypeError(\"Argument to promisify must be a function\");\n }\n\n // If the user has asked us to decode argument names for them, honour that\n var argumentNames = original[customArgumentsToken];\n\n // If the user has supplied a custom Promise implementation, use it. Otherwise\n // fall back to whatever we can find on the global object.\n var ES6Promise = promisify.Promise || Promise;\n\n // If we can find no Promise implemention, then fail now.\n if (typeof ES6Promise !== \"function\") {\n throw new Error(\"No Promise implementation found; do you need a polyfill?\");\n }\n\n return function () {\n var _this = this;\n\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return new ES6Promise(function (resolve, reject) {\n\n // Append the callback bound to the context\n args.push(function callback(err) {\n\n if (err) {\n return reject(err);\n }\n\n for (var _len2 = arguments.length, values = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n values[_key2 - 1] = arguments[_key2];\n }\n\n if (values.length === 1 || !argumentNames) {\n return resolve(values[0]);\n }\n\n var o = {};\n values.forEach(function (value, index) {\n var name = argumentNames[index];\n if (name) {\n o[name] = value;\n }\n });\n\n resolve(o);\n });\n\n // Call the function.\n original.call.apply(original, [_this].concat(args));\n });\n };\n}\n\n// Attach this symbol to the exported function, so users can use it\npromisify.argumentNames = customArgumentsToken;\npromisify.Promise = undefined;\n\n// Export the public API\nexports.promisify = promisify;","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// Based on https://github.com/joyent/node/blob/41e53e557992a7d552a8e23de035f9463da25c99/lib/path.js\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe =\n /^(\\/?)([\\s\\S]+\\/(?!$)|\\/)?((?:\\.{1,2}$|[\\s\\S]+?)?(\\.[^./]*)?)$/;\nvar splitPath = function(filename) {\n var result = splitPathRe.exec(filename);\n return [result[1] || '', result[2] || '', result[3] || '', result[4] || ''];\n};\n\n// path.resolve([from ...], to)\nfunction resolve() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n // XXXfiler: we don't have process.cwd() so we use '/' as a fallback\n var path = (i >= 0) ? arguments[i] : '/';\n\n // Skip empty and invalid entries\n if (typeof path !== 'string' || !path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(resolvedPath.split('/').filter(function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n}\n\n// path.normalize(path)\nfunction normalize(path) {\n var isAbsolute = path.charAt(0) === '/';\n\n // Normalize the path\n path = normalizeArray(path.split('/').filter(function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n /*\n if (path && trailingSlash) {\n path += '/';\n }\n */\n\n return (isAbsolute ? '/' : '') + path;\n}\n\nfunction join() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return normalize(paths.filter(function(p) {\n return p && typeof p === 'string';\n }).join('/'));\n}\n\n// path.relative(from, to)\nfunction relative(from, to) {\n from = resolve(from).substr(1);\n to = resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n}\n\nfunction dirname(path) {\n var result = splitPath(path),\n root = result[0],\n dir = result[1];\n\n if (!root && !dir) {\n // No dirname whatsoever\n return '.';\n }\n\n if (dir) {\n // It has a dirname, strip trailing slash\n dir = dir.substr(0, dir.length - 1);\n }\n\n return root + dir;\n}\n\nfunction basename(path, ext) {\n var f = splitPath(path)[2];\n // TODO: make this comparison case-insensitive on windows?\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n // XXXfiler: node.js just does `return f`\n return f === '' ? '/' : f;\n}\n\nfunction extname(path) {\n return splitPath(path)[3];\n}\n\nfunction isAbsolute(path) {\n if(path.charAt(0) === '/') {\n return true;\n }\n return false;\n}\n\nfunction isNull(path) {\n if (('' + path).indexOf('\\u0000') !== -1) {\n return true;\n }\n return false;\n}\n\n// Make sure we don't double-add a trailing slash (e.g., '/' -> '//')\nfunction addTrailing(path) {\n return path.replace(/\\/*$/, '/');\n}\n\n// Deal with multiple slashes at the end, one, or none\n// and make sure we don't return the empty string.\nfunction removeTrailing(path) {\n path = path.replace(/\\/*$/, '');\n return path === '' ? '/' : path;\n}\n\n// XXXfiler: we don't support path.exists() or path.existsSync(), which\n// are deprecated, and need a FileSystem instance to work. Use fs.stat().\n\nmodule.exports = {\n normalize: normalize,\n resolve: resolve,\n join: join,\n relative: relative,\n sep: '/',\n delimiter: ':',\n dirname: dirname,\n basename: basename,\n extname: extname,\n isAbsolute: isAbsolute,\n isNull: isNull,\n // Non-node but useful...\n addTrailing: addTrailing,\n removeTrailing: removeTrailing\n};\n","var errors = {};\n[\n /**\n * node.js errors - we only use some of these, add as needed.\n */\n //'-1:UNKNOWN:unknown error',\n //'0:OK:success',\n //'1:EOF:end of file',\n //'2:EADDRINFO:getaddrinfo error',\n //'3:EACCES:permission denied',\n //'4:EAGAIN:resource temporarily unavailable',\n //'5:EADDRINUSE:address already in use',\n //'6:EADDRNOTAVAIL:address not available',\n //'7:EAFNOSUPPORT:address family not supported',\n //'8:EALREADY:connection already in progress',\n '9:EBADF:bad file descriptor',\n '10:EBUSY:resource busy or locked',\n //'11:ECONNABORTED:software caused connection abort',\n //'12:ECONNREFUSED:connection refused',\n //'13:ECONNRESET:connection reset by peer',\n //'14:EDESTADDRREQ:destination address required',\n //'15:EFAULT:bad address in system call argument',\n //'16:EHOSTUNREACH:host is unreachable',\n //'17:EINTR:interrupted system call',\n '18:EINVAL:invalid argument',\n //'19:EISCONN:socket is already connected',\n //'20:EMFILE:too many open files',\n //'21:EMSGSIZE:message too long',\n //'22:ENETDOWN:network is down',\n //'23:ENETUNREACH:network is unreachable',\n //'24:ENFILE:file table overflow',\n //'25:ENOBUFS:no buffer space available',\n //'26:ENOMEM:not enough memory',\n '27:ENOTDIR:not a directory',\n '28:EISDIR:illegal operation on a directory',\n //'29:ENONET:machine is not on the network',\n // errno 30 skipped, as per https://github.com/rvagg/node-errno/blob/master/errno.js\n //'31:ENOTCONN:socket is not connected',\n //'32:ENOTSOCK:socket operation on non-socket',\n //'33:ENOTSUP:operation not supported on socket',\n '34:ENOENT:no such file or directory',\n //'35:ENOSYS:function not implemented',\n //'36:EPIPE:broken pipe',\n //'37:EPROTO:protocol error',\n //'38:EPROTONOSUPPORT:protocol not supported',\n //'39:EPROTOTYPE:protocol wrong type for socket',\n //'40:ETIMEDOUT:connection timed out',\n //'41:ECHARSET:invalid Unicode character',\n //'42:EAIFAMNOSUPPORT:address family for hostname not supported',\n // errno 43 skipped, as per https://github.com/rvagg/node-errno/blob/master/errno.js\n //'44:EAISERVICE:servname not supported for ai_socktype',\n //'45:EAISOCKTYPE:ai_socktype not supported',\n //'46:ESHUTDOWN:cannot send after transport endpoint shutdown',\n '47:EEXIST:file already exists',\n //'48:ESRCH:no such process',\n //'49:ENAMETOOLONG:name too long',\n '50:EPERM:operation not permitted',\n '51:ELOOP:too many symbolic links encountered',\n //'52:EXDEV:cross-device link not permitted',\n '53:ENOTEMPTY:directory not empty',\n //'54:ENOSPC:no space left on device',\n '55:EIO:i/o error',\n //'56:EROFS:read-only file system',\n //'57:ENODEV:no such device',\n //'58:ESPIPE:invalid seek',\n //'59:ECANCELED:operation canceled',\n\n /**\n * Filer specific errors\n */\n '1000:ENOTMOUNTED:not mounted',\n '1001:EFILESYSTEMERROR:missing super node, use \\'FORMAT\\' flag to format filesystem.',\n '1002:ENOATTR:attribute does not exist'\n\n].forEach(function(e) {\n e = e.split(':');\n var errno = +e[0];\n var errName = e[1];\n var defaultMessage = e[2];\n\n function FilerError(msg, path) {\n Error.call(this);\n\n this.name = errName;\n this.code = errName;\n this.errno = errno;\n this.message = msg || defaultMessage;\n if(path) {\n this.path = path;\n }\n this.stack = (new Error(this.message)).stack;\n }\n FilerError.prototype = Object.create(Error.prototype);\n FilerError.prototype.constructor = FilerError;\n FilerError.prototype.toString = function() {\n var pathInfo = this.path ? (', \\'' + this.path + '\\'') : '';\n return this.name + ': ' + this.message + pathInfo;\n };\n\n // We expose the error as both Errors.EINVAL and Errors[18]\n errors[errName] = errors[errno] = FilerError;\n});\n\nmodule.exports = errors;\n","var Errors = require('./errors.js');\n\nfunction guid() {\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {\n var r = Math.random()*16|0, v = c == 'x' ? r : (r&0x3|0x8);\n return v.toString(16);\n }).toUpperCase();\n}\n\nfunction nop() {}\n\n/**\n * Convert a Uint8Array to a regular array\n */\nfunction u8toArray(u8) {\n var array = [];\n var len = u8.length;\n for(var i = 0; i < len; i++) {\n array[i] = u8[i];\n }\n return array;\n}\n\nfunction validateInteger(value, name) {\n let err;\n\n if (typeof value !== 'number')\n err = new Errors.EINVAL(name, 'number', value);\n\n if (err) {\n Error.captureStackTrace(err, validateInteger);\n throw err;\n }\n\n return value;\n}\n\n\nmodule.exports = {\n guid: guid,\n u8toArray: u8toArray,\n nop: nop,\n validateInteger: validateInteger,\n};\n","var O_READ = 'READ';\nvar O_WRITE = 'WRITE';\nvar O_CREATE = 'CREATE';\nvar O_EXCLUSIVE = 'EXCLUSIVE';\nvar O_TRUNCATE = 'TRUNCATE';\nvar O_APPEND = 'APPEND';\nvar XATTR_CREATE = 'CREATE';\nvar XATTR_REPLACE = 'REPLACE';\n\nmodule.exports = {\n FILE_SYSTEM_NAME: 'local',\n\n FILE_STORE_NAME: 'files',\n\n IDB_RO: 'readonly',\n IDB_RW: 'readwrite',\n\n WSQL_VERSION: '1',\n WSQL_SIZE: 5 * 1024 * 1024,\n WSQL_DESC: 'FileSystem Storage',\n\n NODE_TYPE_FILE: 'FILE',\n NODE_TYPE_DIRECTORY: 'DIRECTORY',\n NODE_TYPE_SYMBOLIC_LINK: 'SYMLINK',\n NODE_TYPE_META: 'META',\n\n S_IFREG: 0x8000,\n S_IFDIR: 0x4000,\n S_IFLNK: 0xA000,\n\n DEFAULT_DIR_PERMISSIONS: 0x1ED, // 755\n DEFAULT_FILE_PERMISSIONS: 0x1A4, // 644\n FULL_READ_WRITE_EXEC_PERMISSIONS: 0x1FF, // 777\n READ_WRITE_PERMISSIONS: 0x1B6, /// 666\n \n SYMLOOP_MAX: 10,\n\n BINARY_MIME_TYPE: 'application/octet-stream',\n JSON_MIME_TYPE: 'application/json',\n\n ROOT_DIRECTORY_NAME: '/', // basename(normalize(path))\n\n // FS Mount Flags\n FS_FORMAT: 'FORMAT',\n FS_NOCTIME: 'NOCTIME',\n FS_NOMTIME: 'NOMTIME',\n FS_NODUPEIDCHECK: 'FS_NODUPEIDCHECK',\n\n // FS File Open Flags\n O_READ: O_READ,\n O_WRITE: O_WRITE,\n O_CREATE: O_CREATE,\n O_EXCLUSIVE: O_EXCLUSIVE,\n O_TRUNCATE: O_TRUNCATE,\n O_APPEND: O_APPEND,\n\n O_FLAGS: {\n 'r': [O_READ],\n 'r+': [O_READ, O_WRITE],\n 'w': [O_WRITE, O_CREATE, O_TRUNCATE],\n 'w+': [O_WRITE, O_READ, O_CREATE, O_TRUNCATE],\n 'wx': [O_WRITE, O_CREATE, O_EXCLUSIVE, O_TRUNCATE],\n 'wx+': [O_WRITE, O_READ, O_CREATE, O_EXCLUSIVE, O_TRUNCATE],\n 'a': [O_WRITE, O_CREATE, O_APPEND],\n 'a+': [O_WRITE, O_READ, O_CREATE, O_APPEND],\n 'ax': [O_WRITE, O_CREATE, O_EXCLUSIVE, O_APPEND],\n 'ax+': [O_WRITE, O_READ, O_CREATE, O_EXCLUSIVE, O_APPEND]\n },\n\n XATTR_CREATE: XATTR_CREATE,\n XATTR_REPLACE: XATTR_REPLACE,\n\n FS_READY: 'READY',\n FS_PENDING: 'PENDING',\n FS_ERROR: 'ERROR',\n\n SUPER_NODE_ID: '00000000-0000-0000-0000-000000000000',\n\n // Reserved File Descriptors for streams\n STDIN: 0,\n STDOUT: 1,\n STDERR: 2,\n FIRST_DESCRIPTOR: 3,\n\n ENVIRONMENT: {\n TMP: '/tmp',\n PATH: ''\n },\n\n // Duplicate Node's fs.constants\n fsConstants: {\n O_RDONLY: 0,\n O_WRONLY: 1,\n O_RDWR: 2,\n S_IFMT: 61440,\n S_IFREG: 32768,\n S_IFDIR: 16384,\n S_IFCHR: 8192,\n S_IFBLK: 24576,\n S_IFIFO: 4096,\n S_IFLNK: 40960,\n S_IFSOCK: 49152,\n O_CREAT: 512,\n O_EXCL: 2048,\n O_NOCTTY: 131072,\n O_TRUNC: 1024,\n O_APPEND: 8,\n O_DIRECTORY: 1048576,\n O_NOFOLLOW: 256,\n O_SYNC: 128,\n O_DSYNC: 4194304,\n O_SYMLINK: 2097152,\n O_NONBLOCK: 4,\n S_IRWXU: 448,\n S_IRUSR: 256,\n S_IWUSR: 128,\n S_IXUSR: 64,\n S_IRWXG: 56,\n S_IRGRP: 32,\n S_IWGRP: 16,\n S_IXGRP: 8,\n S_IRWXO: 7,\n S_IROTH: 4,\n S_IWOTH: 2,\n S_IXOTH: 1,\n F_OK: 0,\n R_OK: 4,\n W_OK: 2,\n X_OK: 1,\n UV_FS_COPYFILE_EXCL: 1,\n COPYFILE_EXCL: 1\n }\n};\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n for (var i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length | 0\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (isNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (Buffer.TYPED_ARRAY_SUPPORT &&\n typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset | 0\n if (isFinite(length)) {\n length = length | 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n","function FilerBuffer (subject, encoding, nonZero) {\n\n // Automatically turn ArrayBuffer into Uint8Array so that underlying\n // Buffer code doesn't just throw away and ignore ArrayBuffer data.\n if (subject instanceof ArrayBuffer) {\n subject = new Uint8Array(subject);\n }\n\n return new Buffer(subject, encoding, nonZero);\n}\n\n// Inherit prototype from Buffer\nFilerBuffer.prototype = Object.create(Buffer.prototype);\nFilerBuffer.prototype.constructor = FilerBuffer;\n\n// Also copy static methods onto FilerBuffer ctor\nObject.keys(Buffer).forEach(function (p) {\n if (Buffer.hasOwnProperty(p)) {\n FilerBuffer[p] = Buffer[p];\n }\n});\n\nmodule.exports = FilerBuffer;\n","var FILE_SYSTEM_NAME = require('../constants.js').FILE_SYSTEM_NAME;\nvar FILE_STORE_NAME = require('../constants.js').FILE_STORE_NAME;\nvar IDB_RW = require('../constants.js').IDB_RW;\nvar IDB_RO = require('../constants.js').IDB_RO;\nvar FilerBuffer = require('../buffer.js');\n\nvar indexedDB = global.indexedDB ||\n global.mozIndexedDB ||\n global.webkitIndexedDB ||\n global.msIndexedDB;\n\nfunction IndexedDBContext(db, mode) {\n this.db = db;\n this.mode = mode;\n}\n\nIndexedDBContext.prototype._getObjectStore = function() {\n if(this.objectStore) {\n return this.objectStore;\n }\n\n var transaction = this.db.transaction(FILE_STORE_NAME, this.mode);\n this.objectStore = transaction.objectStore(FILE_STORE_NAME);\n return this.objectStore;\n};\n\nIndexedDBContext.prototype.clear = function(callback) {\n try {\n var objectStore = this._getObjectStore();\n var request = objectStore.clear();\n request.onsuccess = function() {\n callback();\n };\n request.onerror = function(event) {\n event.preventDefault();\n callback(event.error);\n };\n } catch(err) {\n callback(err);\n }\n};\n\nIndexedDBContext.prototype._get = function(key, callback) {\n try {\n var objectStore = this._getObjectStore();\n var request = objectStore.get(key);\n request.onsuccess = function onsuccess(event) {\n var result = event.target.result;\n callback(null, result);\n };\n request.onerror = function(event) {\n event.preventDefault();\n callback(event.error);\n };\n } catch(err) {\n callback(err);\n }\n};\nIndexedDBContext.prototype.getObject = function(key, callback) {\n this._get(key, callback);\n};\nIndexedDBContext.prototype.getBuffer = function(key, callback) {\n this._get(key, function(err, arrayBuffer) {\n if(err) {\n return callback(err);\n }\n callback(null, new FilerBuffer(arrayBuffer));\n });\n};\n\nIndexedDBContext.prototype._put = function(key, value, callback) {\n try {\n var objectStore = this._getObjectStore();\n var request = objectStore.put(value, key);\n request.onsuccess = function onsuccess(event) {\n var result = event.target.result;\n callback(null, result);\n };\n request.onerror = function(event) {\n event.preventDefault();\n callback(event.error);\n };\n } catch(err) {\n callback(err);\n }\n};\nIndexedDBContext.prototype.putObject = function(key, value, callback) {\n this._put(key, value, callback);\n};\nIndexedDBContext.prototype.putBuffer = function(key, uint8BackedBuffer, callback) {\n var buf = uint8BackedBuffer.buffer;\n this._put(key, buf, callback);\n};\n\nIndexedDBContext.prototype.delete = function(key, callback) {\n try {\n var objectStore = this._getObjectStore();\n var request = objectStore.delete(key);\n request.onsuccess = function onsuccess(event) {\n var result = event.target.result;\n callback(null, result);\n };\n request.onerror = function(event) {\n event.preventDefault();\n callback(event.error);\n };\n } catch(err) {\n callback(err);\n }\n};\n\n\nfunction IndexedDB(name) {\n this.name = name || FILE_SYSTEM_NAME;\n this.db = null;\n}\nIndexedDB.isSupported = function() {\n return !!indexedDB;\n};\n\nIndexedDB.prototype.open = function(callback) {\n var that = this;\n\n // Bail if we already have a db open\n if(that.db) {\n return callback();\n }\n\n try {\n // NOTE: we're not using versioned databases.\n var openRequest = indexedDB.open(that.name);\n\n // If the db doesn't exist, we'll create it\n openRequest.onupgradeneeded = function onupgradeneeded(event) {\n var db = event.target.result;\n\n if(db.objectStoreNames.contains(FILE_STORE_NAME)) {\n db.deleteObjectStore(FILE_STORE_NAME);\n }\n db.createObjectStore(FILE_STORE_NAME);\n };\n\n openRequest.onsuccess = function onsuccess(event) {\n that.db = event.target.result;\n callback();\n };\n openRequest.onerror = function onerror(event) {\n event.preventDefault();\n callback(event.error);\n };\n } catch(err) {\n callback(err);\n }\n};\n\nIndexedDB.prototype.getReadOnlyContext = function() {\n return new IndexedDBContext(this.db, IDB_RO);\n};\nIndexedDB.prototype.getReadWriteContext = function() {\n return new IndexedDBContext(this.db, IDB_RW);\n};\n\nmodule.exports = IndexedDB;\n","/*\n * base64-arraybuffer\n * https://github.com/niklasvh/base64-arraybuffer\n *\n * Copyright (c) 2012 Niklas von Hertzen\n * Licensed under the MIT license.\n */\n(function(){\n \"use strict\";\n\n var chars = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\n\n // Use a lookup table to find the index.\n var lookup = new Uint8Array(256);\n for (var i = 0; i < chars.length; i++) {\n lookup[chars.charCodeAt(i)] = i;\n }\n\n exports.encode = function(arraybuffer) {\n var bytes = new Uint8Array(arraybuffer),\n i, len = bytes.length, base64 = \"\";\n\n for (i = 0; i < len; i+=3) {\n base64 += chars[bytes[i] >> 2];\n base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)];\n base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)];\n base64 += chars[bytes[i + 2] & 63];\n }\n\n if ((len % 3) === 2) {\n base64 = base64.substring(0, base64.length - 1) + \"=\";\n } else if (len % 3 === 1) {\n base64 = base64.substring(0, base64.length - 2) + \"==\";\n }\n\n return base64;\n };\n\n exports.decode = function(base64) {\n var bufferLength = base64.length * 0.75,\n len = base64.length, i, p = 0,\n encoded1, encoded2, encoded3, encoded4;\n\n if (base64[base64.length - 1] === \"=\") {\n bufferLength--;\n if (base64[base64.length - 2] === \"=\") {\n bufferLength--;\n }\n }\n\n var arraybuffer = new ArrayBuffer(bufferLength),\n bytes = new Uint8Array(arraybuffer);\n\n for (i = 0; i < len; i+=4) {\n encoded1 = lookup[base64.charCodeAt(i)];\n encoded2 = lookup[base64.charCodeAt(i+1)];\n encoded3 = lookup[base64.charCodeAt(i+2)];\n encoded4 = lookup[base64.charCodeAt(i+3)];\n\n bytes[p++] = (encoded1 << 2) | (encoded2 >> 4);\n bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2);\n bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63);\n }\n\n return arraybuffer;\n };\n})();\n","var FILE_SYSTEM_NAME = require('../constants.js').FILE_SYSTEM_NAME;\nvar FILE_STORE_NAME = require('../constants.js').FILE_STORE_NAME;\nvar WSQL_VERSION = require('../constants.js').WSQL_VERSION;\nvar WSQL_SIZE = require('../constants.js').WSQL_SIZE;\nvar WSQL_DESC = require('../constants.js').WSQL_DESC;\nvar Errors = require('../errors.js');\nvar FilerBuffer = require('../buffer.js');\nvar base64ArrayBuffer = require('base64-arraybuffer');\n\nfunction WebSQLContext(db, isReadOnly) {\n var that = this;\n this.getTransaction = function(callback) {\n if(that.transaction) {\n callback(that.transaction);\n return;\n }\n // Either do readTransaction() (read-only) or transaction() (read/write)\n db[isReadOnly ? 'readTransaction' : 'transaction'](function(transaction) {\n that.transaction = transaction;\n callback(transaction);\n });\n };\n}\n\nWebSQLContext.prototype.clear = function(callback) {\n function onError(transaction, error) {\n callback(error);\n }\n function onSuccess() {\n callback(null);\n }\n this.getTransaction(function(transaction) {\n transaction.executeSql('DELETE FROM ' + FILE_STORE_NAME + ';',\n [], onSuccess, onError);\n });\n};\n\nfunction _get(getTransaction, key, callback) {\n function onSuccess(transaction, result) {\n // If the key isn't found, return null\n var value = result.rows.length === 0 ? null : result.rows.item(0).data;\n callback(null, value);\n }\n function onError(transaction, error) {\n callback(error);\n }\n getTransaction(function(transaction) {\n transaction.executeSql('SELECT data FROM ' + FILE_STORE_NAME + ' WHERE id = ? LIMIT 1;',\n [key], onSuccess, onError);\n });\n}\nWebSQLContext.prototype.getObject = function(key, callback) {\n _get(this.getTransaction, key, function(err, result) {\n if(err) {\n return callback(err);\n }\n\n try {\n if(result) {\n result = JSON.parse(result);\n }\n } catch(e) {\n return callback(e);\n }\n\n callback(null, result);\n });\n};\nWebSQLContext.prototype.getBuffer = function(key, callback) {\n _get(this.getTransaction, key, function(err, result) {\n if(err) {\n return callback(err);\n }\n\n // Deal with zero-length ArrayBuffers, which will be encoded as ''\n if(result || result === '') {\n var arrayBuffer = base64ArrayBuffer.decode(result);\n result = new FilerBuffer(arrayBuffer);\n }\n\n callback(null, result);\n });\n};\n\nfunction _put(getTransaction, key, value, callback) {\n function onSuccess() {\n callback(null);\n }\n function onError(transaction, error) {\n callback(error);\n }\n getTransaction(function(transaction) {\n transaction.executeSql('INSERT OR REPLACE INTO ' + FILE_STORE_NAME + ' (id, data) VALUES (?, ?);',\n [key, value], onSuccess, onError);\n });\n}\nWebSQLContext.prototype.putObject = function(key, value, callback) {\n var json = JSON.stringify(value);\n _put(this.getTransaction, key, json, callback);\n};\nWebSQLContext.prototype.putBuffer = function(key, uint8BackedBuffer, callback) {\n var base64 = base64ArrayBuffer.encode(uint8BackedBuffer.buffer);\n _put(this.getTransaction, key, base64, callback);\n};\n\nWebSQLContext.prototype.delete = function(key, callback) {\n function onSuccess() {\n callback(null);\n }\n function onError(transaction, error) {\n callback(error);\n }\n this.getTransaction(function(transaction) {\n transaction.executeSql('DELETE FROM ' + FILE_STORE_NAME + ' WHERE id = ?;',\n [key], onSuccess, onError);\n });\n};\n\n\nfunction WebSQL(name) {\n this.name = name || FILE_SYSTEM_NAME;\n this.db = null;\n}\nWebSQL.isSupported = function() {\n return !!global.openDatabase;\n};\n\nWebSQL.prototype.open = function(callback) {\n var that = this;\n\n // Bail if we already have a db open\n if(that.db) {\n return callback();\n }\n\n var db = global.openDatabase(that.name, WSQL_VERSION, WSQL_DESC, WSQL_SIZE);\n if(!db) {\n callback('[WebSQL] Unable to open database.');\n return;\n }\n\n function onError(transaction, error) {\n if (error.code === 5) {\n callback(new Errors.EINVAL('WebSQL cannot be accessed. If private browsing is enabled, disable it.'));\n }\n callback(error);\n }\n function onSuccess() {\n that.db = db;\n callback();\n }\n\n // Create the table and index we'll need to store the fs data.\n db.transaction(function(transaction) {\n function createIndex(transaction) {\n transaction.executeSql('CREATE INDEX IF NOT EXISTS idx_' + FILE_STORE_NAME + '_id' +\n ' on ' + FILE_STORE_NAME + ' (id);',\n [], onSuccess, onError);\n }\n transaction.executeSql('CREATE TABLE IF NOT EXISTS ' + FILE_STORE_NAME + ' (id unique, data TEXT);',\n [], createIndex, onError);\n });\n};\nWebSQL.prototype.getReadOnlyContext = function() {\n return new WebSQLContext(this.db, true);\n};\nWebSQL.prototype.getReadWriteContext = function() {\n return new WebSQLContext(this.db, false);\n};\n\nmodule.exports = WebSQL;\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*global setImmediate: false, setTimeout: false, console: false */\n\n/**\n * async.js shim, based on https://raw.github.com/caolan/async/master/lib/async.js Feb 18, 2014\n * Used under MIT - https://github.com/caolan/async/blob/master/LICENSE\n */\n\n(function () {\n\n var async = {};\n\n // async.js functions used in Filer\n\n //// nextTick implementation with browser-compatible fallback ////\n if (typeof process === 'undefined' || !(process.nextTick)) {\n if (typeof setImmediate === 'function') {\n async.nextTick = function (fn) {\n // not a direct alias for IE10 compatibility\n setImmediate(fn);\n };\n async.setImmediate = async.nextTick;\n }\n else {\n async.nextTick = function (fn) {\n setTimeout(fn, 0);\n };\n async.setImmediate = async.nextTick;\n }\n }\n else {\n async.nextTick = process.nextTick;\n if (typeof setImmediate !== 'undefined') {\n async.setImmediate = function (fn) {\n // not a direct alias for IE10 compatibility\n setImmediate(fn);\n };\n }\n else {\n async.setImmediate = async.nextTick;\n }\n }\n\n async.eachSeries = function (arr, iterator, callback) {\n callback = callback || function () {};\n if (!arr.length) {\n return callback();\n }\n var completed = 0;\n var iterate = function () {\n iterator(arr[completed], function (err) {\n if (err) {\n callback(err);\n callback = function () {};\n }\n else {\n completed += 1;\n if (completed >= arr.length) {\n callback();\n }\n else {\n iterate();\n }\n }\n });\n };\n iterate();\n };\n async.forEachSeries = async.eachSeries;\n\n // AMD / RequireJS\n if (typeof define !== 'undefined' && define.amd) {\n define([], function () {\n return async;\n });\n }\n // Node.js\n else if (typeof module !== 'undefined' && module.exports) {\n module.exports = async;\n }\n // included directly via <script> tag\n else {\n root.async = async;\n }\n\n}());\n","var FILE_SYSTEM_NAME = require('../constants.js').FILE_SYSTEM_NAME;\n// NOTE: prefer setImmediate to nextTick for proper recursion yielding.\n// see https://github.com/js-platform/filer/pull/24\nvar asyncCallback = require('../../lib/async.js').setImmediate;\n\n/**\n * Make shared in-memory DBs possible when using the same name.\n */\nvar createDB = (function() {\n var pool = {};\n return function getOrCreate(name) {\n if(!pool.hasOwnProperty(name)) {\n pool[name] = {};\n }\n return pool[name];\n };\n}());\n\nfunction MemoryContext(db, readOnly) {\n this.readOnly = readOnly;\n this.objectStore = db;\n}\n\nMemoryContext.prototype.clear = function(callback) {\n if(this.readOnly) {\n asyncCallback(function() {\n callback('[MemoryContext] Error: write operation on read only context');\n });\n return;\n }\n var objectStore = this.objectStore;\n Object.keys(objectStore).forEach(function(key){\n delete objectStore[key];\n });\n asyncCallback(callback);\n};\n\n// Memory context doesn't care about differences between Object and Buffer\nMemoryContext.prototype.getObject =\nMemoryContext.prototype.getBuffer =\nfunction(key, callback) {\n var that = this;\n asyncCallback(function() {\n callback(null, that.objectStore[key]);\n });\n};\nMemoryContext.prototype.putObject =\nMemoryContext.prototype.putBuffer =\nfunction(key, value, callback) {\n if(this.readOnly) {\n asyncCallback(function() {\n callback('[MemoryContext] Error: write operation on read only context');\n });\n return;\n }\n this.objectStore[key] = value;\n asyncCallback(callback);\n};\n\nMemoryContext.prototype.delete = function(key, callback) {\n if(this.readOnly) {\n asyncCallback(function() {\n callback('[MemoryContext] Error: write operation on read only context');\n });\n return;\n }\n delete this.objectStore[key];\n asyncCallback(callback);\n};\n\n\nfunction Memory(name) {\n this.name = name || FILE_SYSTEM_NAME;\n}\nMemory.isSupported = function() {\n return true;\n};\n\nMemory.prototype.open = function(callback) {\n this.db = createDB(this.name);\n asyncCallback(callback);\n};\nMemory.prototype.getReadOnlyContext = function() {\n return new MemoryContext(this.db, true);\n};\nMemory.prototype.getReadWriteContext = function() {\n return new MemoryContext(this.db, false);\n};\n\nmodule.exports = Memory;\n","var IndexedDB = require('./indexeddb.js');\nvar WebSQL = require('./websql.js');\nvar Memory = require('./memory.js');\n\nmodule.exports = {\n IndexedDB: IndexedDB,\n WebSQL: WebSQL,\n Memory: Memory,\n\n /**\n * Convenience Provider references\n */\n\n // The default provider to use when none is specified\n Default: IndexedDB,\n\n // The Fallback provider does automatic fallback checks\n Fallback: (function() {\n if(IndexedDB.isSupported()) {\n return IndexedDB;\n }\n\n if(WebSQL.isSupported()) {\n return WebSQL;\n }\n\n function NotSupported() {\n throw '[Filer Error] Your browser doesn\\'t support IndexedDB or WebSQL.';\n }\n NotSupported.isSupported = function() {\n return false;\n };\n return NotSupported;\n }())\n};\n","var defaults = require('../constants.js').ENVIRONMENT;\n\nmodule.exports = function Environment(env) {\n env = env || {};\n env.TMP = env.TMP || defaults.TMP;\n env.PATH = env.PATH || defaults.PATH;\n\n this.get = function(name) {\n return env[name];\n };\n\n this.set = function(name, value) {\n env[name] = value;\n };\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe =\n /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nvar splitPath = function(filename) {\n return splitPathRe.exec(filename).slice(1);\n};\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path = (i >= 0) ? arguments[i] : process.cwd();\n\n // Skip empty and invalid entries\n if (typeof path !== 'string') {\n throw new TypeError('Arguments to path.resolve must be strings');\n } else if (!path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n var isAbsolute = exports.isAbsolute(path),\n trailingSlash = substr(path, -1) === '/';\n\n // Normalize the path\n path = normalizeArray(filter(path.split('/'), function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n if (path && trailingSlash) {\n path += '/';\n }\n\n return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return exports.normalize(filter(paths, function(p, index) {\n if (typeof p !== 'string') {\n throw new TypeError('Arguments to path.join must be strings');\n }\n return p;\n }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n from = exports.resolve(from).substr(1);\n to = exports.resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (var i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function(path) {\n var result = splitPath(path),\n root = result[0],\n dir = result[1];\n\n if (!root && !dir) {\n // No dirname whatsoever\n return '.';\n }\n\n if (dir) {\n // It has a dirname, strip trailing slash\n dir = dir.substr(0, dir.length - 1);\n }\n\n return root + dir;\n};\n\n\nexports.basename = function(path, ext) {\n var f = splitPath(path)[2];\n // TODO: make this comparison case-insensitive on windows?\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n return f;\n};\n\n\nexports.extname = function(path) {\n return splitPath(path)[3];\n};\n\nfunction filter (xs, f) {\n if (xs.filter) return xs.filter(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n if (f(xs[i], i, xs)) res.push(xs[i]);\n }\n return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n ? function (str, start, len) { return str.substr(start, len) }\n : function (str, start, len) {\n if (start < 0) start = str.length + start;\n return str.substr(start, len);\n }\n;\n","module.exports = function (xs, fn) {\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n var x = fn(xs[i], i);\n if (isArray(x)) res.push.apply(res, x);\n else res.push(x);\n }\n return res;\n};\n\nvar isArray = Array.isArray || function (xs) {\n return Object.prototype.toString.call(xs) === '[object Array]';\n};\n","'use strict';\nmodule.exports = balanced;\nfunction balanced(a, b, str) {\n if (a instanceof RegExp) a = maybeMatch(a, str);\n if (b instanceof RegExp) b = maybeMatch(b, str);\n\n var r = range(a, b, str);\n\n return r && {\n start: r[0],\n end: r[1],\n pre: str.slice(0, r[0]),\n body: str.slice(r[0] + a.length, r[1]),\n post: str.slice(r[1] + b.length)\n };\n}\n\nfunction maybeMatch(reg, str) {\n var m = str.match(reg);\n return m ? m[0] : null;\n}\n\nbalanced.range = range;\nfunction range(a, b, str) {\n var begs, beg, left, right, result;\n var ai = str.indexOf(a);\n var bi = str.indexOf(b, ai + 1);\n var i = ai;\n\n if (ai >= 0 && bi > 0) {\n begs = [];\n left = str.length;\n\n while (i >= 0 && !result) {\n if (i == ai) {\n begs.push(i);\n ai = str.indexOf(a, i + 1);\n } else if (begs.length == 1) {\n result = [ begs.pop(), bi ];\n } else {\n beg = begs.pop();\n if (beg < left) {\n left = beg;\n right = bi;\n }\n\n bi = str.indexOf(b, i + 1);\n }\n\n i = ai < bi && ai >= 0 ? ai : bi;\n }\n\n if (begs.length) {\n result = [ left, right ];\n }\n }\n\n return result;\n}\n","var concatMap = require('concat-map');\nvar balanced = require('balanced-match');\n\nmodule.exports = expandTop;\n\nvar escSlash = '\\0SLASH'+Math.random()+'\\0';\nvar escOpen = '\\0OPEN'+Math.random()+'\\0';\nvar escClose = '\\0CLOSE'+Math.random()+'\\0';\nvar escComma = '\\0COMMA'+Math.random()+'\\0';\nvar escPeriod = '\\0PERIOD'+Math.random()+'\\0';\n\nfunction numeric(str) {\n return parseInt(str, 10) == str\n ? parseInt(str, 10)\n : str.charCodeAt(0);\n}\n\nfunction escapeBraces(str) {\n return str.split('\\\\\\\\').join(escSlash)\n .split('\\\\{').join(escOpen)\n .split('\\\\}').join(escClose)\n .split('\\\\,').join(escComma)\n .split('\\\\.').join(escPeriod);\n}\n\nfunction unescapeBraces(str) {\n return str.split(escSlash).join('\\\\')\n .split(escOpen).join('{')\n .split(escClose).join('}')\n .split(escComma).join(',')\n .split(escPeriod).join('.');\n}\n\n\n// Basically just str.split(\",\"), but handling cases\n// where we have nested braced sections, which should be\n// treated as individual members, like {a,{b,c},d}\nfunction parseCommaParts(str) {\n if (!str)\n return [''];\n\n var parts = [];\n var m = balanced('{', '}', str);\n\n if (!m)\n return str.split(',');\n\n var pre = m.pre;\n var body = m.body;\n var post = m.post;\n var p = pre.split(',');\n\n p[p.length-1] += '{' + body + '}';\n var postParts = parseCommaParts(post);\n if (post.length) {\n p[p.length-1] += postParts.shift();\n p.push.apply(p, postParts);\n }\n\n parts.push.apply(parts, p);\n\n return parts;\n}\n\nfunction expandTop(str) {\n if (!str)\n return [];\n\n // I don't know why Bash 4.3 does this, but it does.\n // Anything starting with {} will have the first two bytes preserved\n // but *only* at the top level, so {},a}b will not expand to anything,\n // but a{},b}c will be expanded to [a}c,abc].\n // One could argue that this is a bug in Bash, but since the goal of\n // this module is to match Bash's rules, we escape a leading {}\n if (str.substr(0, 2) === '{}') {\n str = '\\\\{\\\\}' + str.substr(2);\n }\n\n return expand(escapeBraces(str), true).map(unescapeBraces);\n}\n\nfunction identity(e) {\n return e;\n}\n\nfunction embrace(str) {\n return '{' + str + '}';\n}\nfunction isPadded(el) {\n return /^-?0\\d/.test(el);\n}\n\nfunction lte(i, y) {\n return i <= y;\n}\nfunction gte(i, y) {\n return i >= y;\n}\n\nfunction expand(str, isTop) {\n var expansions = [];\n\n var m = balanced('{', '}', str);\n if (!m || /\\$$/.test(m.pre)) return [str];\n\n var isNumericSequence = /^-?\\d+\\.\\.-?\\d+(?:\\.\\.-?\\d+)?$/.test(m.body);\n var isAlphaSequence = /^[a-zA-Z]\\.\\.[a-zA-Z](?:\\.\\.-?\\d+)?$/.test(m.body);\n var isSequence = isNumericSequence || isAlphaSequence;\n var isOptions = m.body.indexOf(',') >= 0;\n if (!isSequence && !isOptions) {\n // {a},b}\n if (m.post.match(/,.*\\}/)) {\n str = m.pre + '{' + m.body + escClose + m.post;\n return expand(str);\n }\n return [str];\n }\n\n var n;\n if (isSequence) {\n n = m.body.split(/\\.\\./);\n } else {\n n = parseCommaParts(m.body);\n if (n.length === 1) {\n // x{{a,b}}y ==> x{a}y x{b}y\n n = expand(n[0], false).map(embrace);\n if (n.length === 1) {\n var post = m.post.length\n ? expand(m.post, false)\n : [''];\n return post.map(function(p) {\n return m.pre + n[0] + p;\n });\n }\n }\n }\n\n // at this point, n is the parts, and we know it's not a comma set\n // with a single entry.\n\n // no need to expand pre, since it is guaranteed to be free of brace-sets\n var pre = m.pre;\n var post = m.post.length\n ? expand(m.post, false)\n : [''];\n\n var N;\n\n if (isSequence) {\n var x = numeric(n[0]);\n var y = numeric(n[1]);\n var width = Math.max(n[0].length, n[1].length)\n var incr = n.length == 3\n ? Math.abs(numeric(n[2]))\n : 1;\n var test = lte;\n var reverse = y < x;\n if (reverse) {\n incr *= -1;\n test = gte;\n }\n var pad = n.some(isPadded);\n\n N = [];\n\n for (var i = x; test(i, y); i += incr) {\n var c;\n if (isAlphaSequence) {\n c = String.fromCharCode(i);\n if (c === '\\\\')\n c = '';\n } else {\n c = String(i);\n if (pad) {\n var need = width - c.length;\n if (need > 0) {\n var z = new Array(need + 1).join('0');\n if (i < 0)\n c = '-' + z + c.slice(1);\n else\n c = z + c;\n }\n }\n }\n N.push(c);\n }\n } else {\n N = concatMap(n, function(el) { return expand(el, false) });\n }\n\n for (var j = 0; j < N.length; j++) {\n for (var k = 0; k < post.length; k++) {\n var expansion = pre + N[j] + post[k];\n if (!isTop || isSequence || expansion)\n expansions.push(expansion);\n }\n }\n\n return expansions;\n}\n\n","module.exports = minimatch\nminimatch.Minimatch = Minimatch\n\nvar path = { sep: '/' }\ntry {\n path = require('path')\n} catch (er) {}\n\nvar GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {}\nvar expand = require('brace-expansion')\n\nvar plTypes = {\n '!': { open: '(?:(?!(?:', close: '))[^/]*?)'},\n '?': { open: '(?:', close: ')?' },\n '+': { open: '(?:', close: ')+' },\n '*': { open: '(?:', close: ')*' },\n '@': { open: '(?:', close: ')' }\n}\n\n// any single thing other than /\n// don't need to escape / when using new RegExp()\nvar qmark = '[^/]'\n\n// * => any number of characters\nvar star = qmark + '*?'\n\n// ** when dots are allowed. Anything goes, except .. and .\n// not (^ or / followed by one or two dots followed by $ or /),\n// followed by anything, any number of times.\nvar twoStarDot = '(?:(?!(?:\\\\\\/|^)(?:\\\\.{1,2})($|\\\\\\/)).)*?'\n\n// not a ^ or / followed by a dot,\n// followed by anything, any number of times.\nvar twoStarNoDot = '(?:(?!(?:\\\\\\/|^)\\\\.).)*?'\n\n// characters that need to be escaped in RegExp.\nvar reSpecials = charSet('().*{}+?[]^$\\\\!')\n\n// \"abc\" -> { a:true, b:true, c:true }\nfunction charSet (s) {\n return s.split('').reduce(function (set, c) {\n set[c] = true\n return set\n }, {})\n}\n\n// normalizes slashes.\nvar slashSplit = /\\/+/\n\nminimatch.filter = filter\nfunction filter (pattern, options) {\n options = options || {}\n return function (p, i, list) {\n return minimatch(p, pattern, options)\n }\n}\n\nfunction ext (a, b) {\n a = a || {}\n b = b || {}\n var t = {}\n Object.keys(b).forEach(function (k) {\n t[k] = b[k]\n })\n Object.keys(a).forEach(function (k) {\n t[k] = a[k]\n })\n return t\n}\n\nminimatch.defaults = function (def) {\n if (!def || !Object.keys(def).length) return minimatch\n\n var orig = minimatch\n\n var m = function minimatch (p, pattern, options) {\n return orig.minimatch(p, pattern, ext(def, options))\n }\n\n m.Minimatch = function Minimatch (pattern, options) {\n return new orig.Minimatch(pattern, ext(def, options))\n }\n\n return m\n}\n\nMinimatch.defaults = function (def) {\n if (!def || !Object.keys(def).length) return Minimatch\n return minimatch.defaults(def).Minimatch\n}\n\nfunction minimatch (p, pattern, options) {\n if (typeof pattern !== 'string') {\n throw new TypeError('glob pattern string required')\n }\n\n if (!options) options = {}\n\n // shortcut: comments match nothing.\n if (!options.nocomment && pattern.charAt(0) === '#') {\n return false\n }\n\n // \"\" only matches \"\"\n if (pattern.trim() === '') return p === ''\n\n return new Minimatch(pattern, options).match(p)\n}\n\nfunction Minimatch (pattern, options) {\n if (!(this instanceof Minimatch)) {\n return new Minimatch(pattern, options)\n }\n\n if (typeof pattern !== 'string') {\n throw new TypeError('glob pattern string required')\n }\n\n if (!options) options = {}\n pattern = pattern.trim()\n\n // windows support: need to use /, not \\\n if (path.sep !== '/') {\n pattern = pattern.split(path.sep).join('/')\n }\n\n this.options = options\n this.set = []\n this.pattern = pattern\n this.regexp = null\n this.negate = false\n this.comment = false\n this.empty = false\n\n // make the set of regexps etc.\n this.make()\n}\n\nMinimatch.prototype.debug = function () {}\n\nMinimatch.prototype.make = make\nfunction make () {\n // don't do it more than once.\n if (this._made) return\n\n var pattern = this.pattern\n var options = this.options\n\n // empty patterns and comments match nothing.\n if (!options.nocomment && pattern.charAt(0) === '#') {\n this.comment = true\n return\n }\n if (!pattern) {\n this.empty = true\n return\n }\n\n // step 1: figure out negation, etc.\n this.parseNegate()\n\n // step 2: expand braces\n var set = this.globSet = this.braceExpand()\n\n if (options.debug) this.debug = console.error\n\n this.debug(this.pattern, set)\n\n // step 3: now we have a set, so turn each one into a series of path-portion\n // matching patterns.\n // These will be regexps, except in the case of \"**\", which is\n // set to the GLOBSTAR object for globstar behavior,\n // and will not contain any / characters\n set = this.globParts = set.map(function (s) {\n return s.split(slashSplit)\n })\n\n this.debug(this.pattern, set)\n\n // glob --> regexps\n set = set.map(function (s, si, set) {\n return s.map(this.parse, this)\n }, this)\n\n this.debug(this.pattern, set)\n\n // filter out everything that didn't compile properly.\n set = set.filter(function (s) {\n return s.indexOf(false) === -1\n })\n\n this.debug(this.pattern, set)\n\n this.set = set\n}\n\nMinimatch.prototype.parseNegate = parseNegate\nfunction parseNegate () {\n var pattern = this.pattern\n var negate = false\n var options = this.options\n var negateOffset = 0\n\n if (options.nonegate) return\n\n for (var i = 0, l = pattern.length\n ; i < l && pattern.charAt(i) === '!'\n ; i++) {\n negate = !negate\n negateOffset++\n }\n\n if (negateOffset) this.pattern = pattern.substr(negateOffset)\n this.negate = negate\n}\n\n// Brace expansion:\n// a{b,c}d -> abd acd\n// a{b,}c -> abc ac\n// a{0..3}d -> a0d a1d a2d a3d\n// a{b,c{d,e}f}g -> abg acdfg acefg\n// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg\n//\n// Invalid sets are not expanded.\n// a{2..}b -> a{2..}b\n// a{b}c -> a{b}c\nminimatch.braceExpand = function (pattern, options) {\n return braceExpand(pattern, options)\n}\n\nMinimatch.prototype.braceExpand = braceExpand\n\nfunction braceExpand (pattern, options) {\n if (!options) {\n if (this instanceof Minimatch) {\n options = this.options\n } else {\n options = {}\n }\n }\n\n pattern = typeof pattern === 'undefined'\n ? this.pattern : pattern\n\n if (typeof pattern === 'undefined') {\n throw new TypeError('undefined pattern')\n }\n\n if (options.nobrace ||\n !pattern.match(/\\{.*\\}/)) {\n // shortcut. no need to expand.\n return [pattern]\n }\n\n return expand(pattern)\n}\n\n// parse a component of the expanded set.\n// At this point, no pattern may contain \"/\" in it\n// so we're going to return a 2d array, where each entry is the full\n// pattern, split on '/', and then turned into a regular expression.\n// A regexp is made at the end which joins each array with an\n// escaped /, and another full one which joins each regexp with |.\n//\n// Following the lead of Bash 4.1, note that \"**\" only has special meaning\n// when it is the *only* thing in a path portion. Otherwise, any series\n// of * is equivalent to a single *. Globstar behavior is enabled by\n// default, and can be disabled by setting options.noglobstar.\nMinimatch.prototype.parse = parse\nvar SUBPARSE = {}\nfunction parse (pattern, isSub) {\n if (pattern.length > 1024 * 64) {\n throw new TypeError('pattern is too long')\n }\n\n var options = this.options\n\n // shortcuts\n if (!options.noglobstar && pattern === '**') return GLOBSTAR\n if (pattern === '') return ''\n\n var re = ''\n var hasMagic = !!options.nocase\n var escaping = false\n // ? => one single character\n var patternListStack = []\n var negativeLists = []\n var stateChar\n var inClass = false\n var reClassStart = -1\n var classStart = -1\n // . and .. never match anything that doesn't start with .,\n // even when options.dot is set.\n var patternStart = pattern.charAt(0) === '.' ? '' // anything\n // not (start or / followed by . or .. followed by / or end)\n : options.dot ? '(?!(?:^|\\\\\\/)\\\\.{1,2}(?:$|\\\\\\/))'\n : '(?!\\\\.)'\n var self = this\n\n function clearStateChar () {\n if (stateChar) {\n // we had some state-tracking character\n // that wasn't consumed by this pass.\n switch (stateChar) {\n case '*':\n re += star\n hasMagic = true\n break\n case '?':\n re += qmark\n hasMagic = true\n break\n default:\n re += '\\\\' + stateChar\n break\n }\n self.debug('clearStateChar %j %j', stateChar, re)\n stateChar = false\n }\n }\n\n for (var i = 0, len = pattern.length, c\n ; (i < len) && (c = pattern.charAt(i))\n ; i++) {\n this.debug('%s\\t%s %s %j', pattern, i, re, c)\n\n // skip over any that are escaped.\n if (escaping && reSpecials[c]) {\n re += '\\\\' + c\n escaping = false\n continue\n }\n\n switch (c) {\n case '/':\n // completely not allowed, even escaped.\n // Should already be path-split by now.\n return false\n\n case '\\\\':\n clearStateChar()\n escaping = true\n continue\n\n // the various stateChar values\n // for the \"extglob\" stuff.\n case '?':\n case '*':\n case '+':\n case '@':\n case '!':\n this.debug('%s\\t%s %s %j <-- stateChar', pattern, i, re, c)\n\n // all of those are literals inside a class, except that\n // the glob [!a] means [^a] in regexp\n if (inClass) {\n this.debug(' in class')\n if (c === '!' && i === classStart + 1) c = '^'\n re += c\n continue\n }\n\n // if we already have a stateChar, then it means\n // that there was something like ** or +? in there.\n // Handle the stateChar, then proceed with this one.\n self.debug('call clearStateChar %j', stateChar)\n clearStateChar()\n stateChar = c\n // if extglob is disabled, then +(asdf|foo) isn't a thing.\n // just clear the statechar *now*, rather than even diving into\n // the patternList stuff.\n if (options.noext) clearStateChar()\n continue\n\n case '(':\n if (inClass) {\n re += '('\n continue\n }\n\n if (!stateChar) {\n re += '\\\\('\n continue\n }\n\n patternListStack.push({\n type: stateChar,\n start: i - 1,\n reStart: re.length,\n open: plTypes[stateChar].open,\n close: plTypes[stateChar].close\n })\n // negation is (?:(?!js)[^/]*)\n re += stateChar === '!' ? '(?:(?!(?:' : '(?:'\n this.debug('plType %j %j', stateChar, re)\n stateChar = false\n continue\n\n case ')':\n if (inClass || !patternListStack.length) {\n re += '\\\\)'\n continue\n }\n\n clearStateChar()\n hasMagic = true\n var pl = patternListStack.pop()\n // negation is (?:(?!js)[^/]*)\n // The others are (?:<pattern>)<type>\n re += pl.close\n if (pl.type === '!') {\n negativeLists.push(pl)\n }\n pl.reEnd = re.length\n continue\n\n case '|':\n if (inClass || !patternListStack.length || escaping) {\n re += '\\\\|'\n escaping = false\n continue\n }\n\n clearStateChar()\n re += '|'\n continue\n\n // these are mostly the same in regexp and glob\n case '[':\n // swallow any state-tracking char before the [\n clearStateChar()\n\n if (inClass) {\n re += '\\\\' + c\n continue\n }\n\n inClass = true\n classStart = i\n reClassStart = re.length\n re += c\n continue\n\n case ']':\n // a right bracket shall lose its special\n // meaning and represent itself in\n // a bracket expression if it occurs\n // first in the list. -- POSIX.2 2.8.3.2\n if (i === classStart + 1 || !inClass) {\n re += '\\\\' + c\n escaping = false\n continue\n }\n\n // handle the case where we left a class open.\n // \"[z-a]\" is valid, equivalent to \"\\[z-a\\]\"\n if (inClass) {\n // split where the last [ was, make sure we don't have\n // an invalid re. if so, re-walk the contents of the\n // would-be class to re-translate any characters that\n // were passed through as-is\n // TODO: It would probably be faster to determine this\n // without a try/catch and a new RegExp, but it's tricky\n // to do safely. For now, this is safe and works.\n var cs = pattern.substring(classStart + 1, i)\n try {\n RegExp('[' + cs + ']')\n } catch (er) {\n // not a valid class!\n var sp = this.parse(cs, SUBPARSE)\n re = re.substr(0, reClassStart) + '\\\\[' + sp[0] + '\\\\]'\n hasMagic = hasMagic || sp[1]\n inClass = false\n continue\n }\n }\n\n // finish up the class.\n hasMagic = true\n inClass = false\n re += c\n continue\n\n default:\n // swallow any state char that wasn't consumed\n clearStateChar()\n\n if (escaping) {\n // no need\n escaping = false\n } else if (reSpecials[c]\n && !(c === '^' && inClass)) {\n re += '\\\\'\n }\n\n re += c\n\n } // switch\n } // for\n\n // handle the case where we left a class open.\n // \"[abc\" is valid, equivalent to \"\\[abc\"\n if (inClass) {\n // split where the last [ was, and escape it\n // this is a huge pita. We now have to re-walk\n // the contents of the would-be class to re-translate\n // any characters that were passed through as-is\n cs = pattern.substr(classStart + 1)\n sp = this.parse(cs, SUBPARSE)\n re = re.substr(0, reClassStart) + '\\\\[' + sp[0]\n hasMagic = hasMagic || sp[1]\n }\n\n // handle the case where we had a +( thing at the *end*\n // of the pattern.\n // each pattern list stack adds 3 chars, and we need to go through\n // and escape any | chars that were passed through as-is for the regexp.\n // Go through and escape them, taking care not to double-escape any\n // | chars that were already escaped.\n for (pl = patternListStack.pop(); pl; pl = patternListStack.pop()) {\n var tail = re.slice(pl.reStart + pl.open.length)\n this.debug('setting tail', re, pl)\n // maybe some even number of \\, then maybe 1 \\, followed by a |\n tail = tail.replace(/((?:\\\\{2}){0,64})(\\\\?)\\|/g, function (_, $1, $2) {\n if (!$2) {\n // the | isn't already escaped, so escape it.\n $2 = '\\\\'\n }\n\n // need to escape all those slashes *again*, without escaping the\n // one that we need for escaping the | character. As it works out,\n // escaping an even number of slashes can be done by simply repeating\n // it exactly after itself. That's why this trick works.\n //\n // I am sorry that you have to see this.\n return $1 + $1 + $2 + '|'\n })\n\n this.debug('tail=%j\\n %s', tail, tail, pl, re)\n var t = pl.type === '*' ? star\n : pl.type === '?' ? qmark\n : '\\\\' + pl.type\n\n hasMagic = true\n re = re.slice(0, pl.reStart) + t + '\\\\(' + tail\n }\n\n // handle trailing things that only matter at the very end.\n clearStateChar()\n if (escaping) {\n // trailing \\\\\n re += '\\\\\\\\'\n }\n\n // only need to apply the nodot start if the re starts with\n // something that could conceivably capture a dot\n var addPatternStart = false\n switch (re.charAt(0)) {\n case '.':\n case '[':\n case '(': addPatternStart = true\n }\n\n // Hack to work around lack of negative lookbehind in JS\n // A pattern like: *.!(x).!(y|z) needs to ensure that a name\n // like 'a.xyz.yz' doesn't match. So, the first negative\n // lookahead, has to look ALL the way ahead, to the end of\n // the pattern.\n for (var n = negativeLists.length - 1; n > -1; n--) {\n var nl = negativeLists[n]\n\n var nlBefore = re.slice(0, nl.reStart)\n var nlFirst = re.slice(nl.reStart, nl.reEnd - 8)\n var nlLast = re.slice(nl.reEnd - 8, nl.reEnd)\n var nlAfter = re.slice(nl.reEnd)\n\n nlLast += nlAfter\n\n // Handle nested stuff like *(*.js|!(*.json)), where open parens\n // mean that we should *not* include the ) in the bit that is considered\n // \"after\" the negated section.\n var openParensBefore = nlBefore.split('(').length - 1\n var cleanAfter = nlAfter\n for (i = 0; i < openParensBefore; i++) {\n cleanAfter = cleanAfter.replace(/\\)[+*?]?/, '')\n }\n nlAfter = cleanAfter\n\n var dollar = ''\n if (nlAfter === '' && isSub !== SUBPARSE) {\n dollar = '$'\n }\n var newRe = nlBefore + nlFirst + nlAfter + dollar + nlLast\n re = newRe\n }\n\n // if the re is not \"\" at this point, then we need to make sure\n // it doesn't match against an empty path part.\n // Otherwise a/* will match a/, which it should not.\n if (re !== '' && hasMagic) {\n re = '(?=.)' + re\n }\n\n if (addPatternStart) {\n re = patternStart + re\n }\n\n // parsing just a piece of a larger pattern.\n if (isSub === SUBPARSE) {\n return [re, hasMagic]\n }\n\n // skip the regexp for non-magical patterns\n // unescape anything in it, though, so that it'll be\n // an exact match against a file etc.\n if (!hasMagic) {\n return globUnescape(pattern)\n }\n\n var flags = options.nocase ? 'i' : ''\n try {\n var regExp = new RegExp('^' + re + '$', flags)\n } catch (er) {\n // If it was an invalid regular expression, then it can't match\n // anything. This trick looks for a character after the end of\n // the string, which is of course impossible, except in multi-line\n // mode, but it's not a /m regex.\n return new RegExp('$.')\n }\n\n regExp._glob = pattern\n regExp._src = re\n\n return regExp\n}\n\nminimatch.makeRe = function (pattern, options) {\n return new Minimatch(pattern, options || {}).makeRe()\n}\n\nMinimatch.prototype.makeRe = makeRe\nfunction makeRe () {\n if (this.regexp || this.regexp === false) return this.regexp\n\n // at this point, this.set is a 2d array of partial\n // pattern strings, or \"**\".\n //\n // It's better to use .match(). This function shouldn't\n // be used, really, but it's pretty convenient sometimes,\n // when you just want to work with a regex.\n var set = this.set\n\n if (!set.length) {\n this.regexp = false\n return this.regexp\n }\n var options = this.options\n\n var twoStar = options.noglobstar ? star\n : options.dot ? twoStarDot\n : twoStarNoDot\n var flags = options.nocase ? 'i' : ''\n\n var re = set.map(function (pattern) {\n return pattern.map(function (p) {\n return (p === GLOBSTAR) ? twoStar\n : (typeof p === 'string') ? regExpEscape(p)\n : p._src\n }).join('\\\\\\/')\n }).join('|')\n\n // must match entire pattern\n // ending in a * or ** will make it less strict.\n re = '^(?:' + re + ')$'\n\n // can match anything, as long as it's not this.\n if (this.negate) re = '^(?!' + re + ').*$'\n\n try {\n this.regexp = new RegExp(re, flags)\n } catch (ex) {\n this.regexp = false\n }\n return this.regexp\n}\n\nminimatch.match = function (list, pattern, options) {\n options = options || {}\n var mm = new Minimatch(pattern, options)\n list = list.filter(function (f) {\n return mm.match(f)\n })\n if (mm.options.nonull && !list.length) {\n list.push(pattern)\n }\n return list\n}\n\nMinimatch.prototype.match = match\nfunction match (f, partial) {\n this.debug('match', f, this.pattern)\n // short-circuit in the case of busted things.\n // comments, etc.\n if (this.comment) return false\n if (this.empty) return f === ''\n\n if (f === '/' && partial) return true\n\n var options = this.options\n\n // windows: need to use /, not \\\n if (path.sep !== '/') {\n f = f.split(path.sep).join('/')\n }\n\n // treat the test path as a set of pathparts.\n f = f.split(slashSplit)\n this.debug(this.pattern, 'split', f)\n\n // just ONE of the pattern sets in this.set needs to match\n // in order for it to be valid. If negating, then just one\n // match means that we have failed.\n // Either way, return on the first hit.\n\n var set = this.set\n this.debug(this.pattern, 'set', set)\n\n // Find the basename of the path by looking for the last non-empty segment\n var filename\n var i\n for (i = f.length - 1; i >= 0; i--) {\n filename = f[i]\n if (filename) break\n }\n\n for (i = 0; i < set.length; i++) {\n var pattern = set[i]\n var file = f\n if (options.matchBase && pattern.length === 1) {\n file = [filename]\n }\n var hit = this.matchOne(file, pattern, partial)\n if (hit) {\n if (options.flipNegate) return true\n return !this.negate\n }\n }\n\n // didn't get any hits. this is success if it's a negative\n // pattern, failure otherwise.\n if (options.flipNegate) return false\n return this.negate\n}\n\n// set partial to true to test if, for example,\n// \"/a/b\" matches the start of \"/*/b/*/d\"\n// Partial means, if you run out of file before you run\n// out of pattern, then that's fine, as long as all\n// the parts match.\nMinimatch.prototype.matchOne = function (file, pattern, partial) {\n var options = this.options\n\n this.debug('matchOne',\n { 'this': this, file: file, pattern: pattern })\n\n this.debug('matchOne', file.length, pattern.length)\n\n for (var fi = 0,\n pi = 0,\n fl = file.length,\n pl = pattern.length\n ; (fi < fl) && (pi < pl)\n ; fi++, pi++) {\n this.debug('matchOne loop')\n var p = pattern[pi]\n var f = file[fi]\n\n this.debug(pattern, p, f)\n\n // should be impossible.\n // some invalid regexp stuff in the set.\n if (p === false) return false\n\n if (p === GLOBSTAR) {\n this.debug('GLOBSTAR', [pattern, p, f])\n\n // \"**\"\n // a/**/b/**/c would match the following:\n // a/b/x/y/z/c\n // a/x/y/z/b/c\n // a/b/x/b/x/c\n // a/b/c\n // To do this, take the rest of the pattern after\n // the **, and see if it would match the file remainder.\n // If so, return success.\n // If not, the ** \"swallows\" a segment, and try again.\n // This is recursively awful.\n //\n // a/**/b/**/c matching a/b/x/y/z/c\n // - a matches a\n // - doublestar\n // - matchOne(b/x/y/z/c, b/**/c)\n // - b matches b\n // - doublestar\n // - matchOne(x/y/z/c, c) -> no\n // - matchOne(y/z/c, c) -> no\n // - matchOne(z/c, c) -> no\n // - matchOne(c, c) yes, hit\n var fr = fi\n var pr = pi + 1\n if (pr === pl) {\n this.debug('** at the end')\n // a ** at the end will just swallow the rest.\n // We have found a match.\n // however, it will not swallow /.x, unless\n // options.dot is set.\n // . and .. are *never* matched by **, for explosively\n // exponential reasons.\n for (; fi < fl; fi++) {\n if (file[fi] === '.' || file[fi] === '..' ||\n (!options.dot && file[fi].charAt(0) === '.')) return false\n }\n return true\n }\n\n // ok, let's see if we can swallow whatever we can.\n while (fr < fl) {\n var swallowee = file[fr]\n\n this.debug('\\nglobstar while', file, fr, pattern, pr, swallowee)\n\n // XXX remove this slice. Just pass the start index.\n if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) {\n this.debug('globstar found match!', fr, fl, swallowee)\n // found a match.\n return true\n } else {\n // can't swallow \".\" or \"..\" ever.\n // can only swallow \".foo\" when explicitly asked.\n if (swallowee === '.' || swallowee === '..' ||\n (!options.dot && swallowee.charAt(0) === '.')) {\n this.debug('dot detected!', file, fr, pattern, pr)\n break\n }\n\n // ** swallows a segment, and continue.\n this.debug('globstar swallow a segment, and continue')\n fr++\n }\n }\n\n // no match was found.\n // However, in partial mode, we can't say this is necessarily over.\n // If there's more *pattern* left, then\n if (partial) {\n // ran out of file\n this.debug('\\n>>> no match, partial?', file, fr, pattern, pr)\n if (fr === fl) return true\n }\n return false\n }\n\n // something other than **\n // non-magic patterns just have to match exactly\n // patterns with magic have been turned into regexps.\n var hit\n if (typeof p === 'string') {\n if (options.nocase) {\n hit = f.toLowerCase() === p.toLowerCase()\n } else {\n hit = f === p\n }\n this.debug('string match', p, f, hit)\n } else {\n hit = f.match(p)\n this.debug('pattern match', p, f, hit)\n }\n\n if (!hit) return false\n }\n\n // Note: ending in / means that we'll get a final \"\"\n // at the end of the pattern. This can only match a\n // corresponding \"\" at the end of the file.\n // If the file ends in /, then it can only match a\n // a pattern that ends in /, unless the pattern just\n // doesn't have any more for it. But, a/b/ should *not*\n // match \"a/b/*\", even though \"\" matches against the\n // [^/]*? pattern, except in partial mode, where it might\n // simply not be reached yet.\n // However, a/b/ should still satisfy a/*\n\n // now either we fell off the end of the pattern, or we're done.\n if (fi === fl && pi === pl) {\n // ran out of pattern and filename at the same time.\n // an exact hit!\n return true\n } else if (fi === fl) {\n // ran out of file, but still had pattern left.\n // this is ok if we're doing the match as part of\n // a glob fs traversal.\n return partial\n } else if (pi === pl) {\n // ran out of pattern, still have file left.\n // this is only acceptable if we're on the very last\n // empty segment of a file with a trailing slash.\n // a/* should match a/b/\n var emptyFileEnd = (fi === fl - 1) && (file[fi] === '')\n return emptyFileEnd\n }\n\n // should be unreachable.\n throw new Error('wtf?')\n}\n\n// replace stuff like \\* with *\nfunction globUnescape (s) {\n return s.replace(/\\\\(.)/g, '$1')\n}\n\nfunction regExpEscape (s) {\n return s.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&')\n}\n","var {promisify} = require('es6-promisify');\nvar Path = require('../path.js');\nvar Errors = require('../errors.js');\nvar Environment = require('./environment.js');\nvar async = require('../../lib/async.js');\nvar minimatch = require('minimatch');\n\nfunction Shell(fs, options) {\n options = options || {};\n\n var env = new Environment(options.env);\n var cwd = '/';\n\n /**\n * The bound FileSystem (cannot be changed)\n */\n Object.defineProperty(this, 'fs', {\n get: function() { return fs; },\n enumerable: true\n });\n\n /**\n * The shell's environment (e.g., for things like\n * path, tmp, and other env vars). Use env.get()\n * and env.set() to work with variables.\n */\n Object.defineProperty(this, 'env', {\n get: function() { return env; },\n enumerable: true\n });\n\n /**\n * Change the current working directory. We\n * include `cd` on the `this` vs. proto so that\n * we can access cwd without exposing it externally.\n */\n this.cd = function(path, callback) {\n path = Path.resolve(cwd, path);\n // Make sure the path actually exists, and is a dir\n fs.stat(path, function(err, stats) {\n if(err) {\n callback(new Errors.ENOTDIR(null, path));\n return;\n }\n if(stats.type === 'DIRECTORY') {\n cwd = path;\n callback();\n } else {\n callback(new Errors.ENOTDIR(null, path));\n }\n });\n };\n\n /**\n * Get the current working directory (changed with `cd()`)\n */\n this.pwd = function() {\n return cwd;\n };\n\n this.promises = {};\n /**\n * Public API for Shell converted to Promise based\n */\n [\n 'cd',\n 'exec',\n 'touch',\n 'cat',\n 'ls',\n 'rm',\n 'tempDir',\n 'mkdirp',\n 'find'\n ].forEach((methodName)=>{\n this.promises[methodName] = promisify(this[methodName].bind(this));\n });\n}\n\n/**\n * Execute the .js command located at `path`. Such commands\n * should assume the existence of 3 arguments, which will be\n * defined at runtime:\n *\n * * fs - the current shell's bound filesystem object\n * * args - a list of arguments for the command, or an empty list if none\n * * callback - a callback function(error, result) to call when done.\n *\n * The .js command's contents should be the body of a function\n * that looks like this:\n *\n * function(fs, args, callback) {\n * // .js code here\n * }\n */\nShell.prototype.exec = function(path, args, callback) {\n /* jshint evil:true */\n var sh = this;\n var fs = sh.fs;\n if(typeof args === 'function') {\n callback = args;\n args = [];\n }\n args = args || [];\n callback = callback || function(){};\n path = Path.resolve(sh.pwd(), path);\n\n fs.readFile(path, 'utf8', function(error, data) {\n if(error) {\n callback(error);\n return;\n }\n try {\n var cmd = new Function('fs', 'args', 'callback', data);\n cmd(fs, args, callback);\n } catch(e) {\n callback(e);\n }\n });\n};\n\n/**\n * Create a file if it does not exist, or update access and\n * modified times if it does. Valid options include:\n *\n * * updateOnly - whether to create the file if missing (defaults to false)\n * * date - use the provided Date value instead of current date/time\n */\nShell.prototype.touch = function(path, options, callback) {\n var sh = this;\n var fs = sh.fs;\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n callback = callback || function(){};\n path = Path.resolve(sh.pwd(), path);\n\n function createFile(path) {\n fs.writeFile(path, '', callback);\n }\n\n function updateTimes(path) {\n var now = Date.now();\n var atime = options.date || now;\n var mtime = options.date || now;\n\n fs.utimes(path, atime, mtime, callback);\n }\n\n fs.stat(path, function(error) {\n if(error) {\n if(options.updateOnly === true) {\n callback();\n } else {\n createFile(path);\n }\n } else {\n updateTimes(path);\n }\n });\n};\n\n/**\n * Concatenate multiple files into a single String, with each\n * file separated by a newline. The `files` argument should\n * be a String (path to single file) or an Array of Strings\n * (multiple file paths).\n */\nShell.prototype.cat = function(files, callback) {\n var sh = this;\n var fs = sh.fs;\n var all = '';\n callback = callback || function(){};\n\n if(!files) {\n callback(new Errors.EINVAL('Missing files argument'));\n return;\n }\n\n files = typeof files === 'string' ? [ files ] : files;\n\n function append(item, callback) {\n var filename = Path.resolve(sh.pwd(), item);\n fs.readFile(filename, 'utf8', function(error, data) {\n if(error) {\n callback(error);\n return;\n }\n all += data + '\\n';\n callback();\n });\n }\n\n async.eachSeries(files, append, function(error) {\n if(error) {\n callback(error);\n } else {\n callback(null, all.replace(/\\n$/, ''));\n }\n });\n};\n\n/**\n * Get the listing of a directory, returning an array of\n * file entries in the following form:\n *\n * {\n * path: <String> the basename of the directory entry\n * links: <Number> the number of links to the entry\n * size: <Number> the size in bytes of the entry\n * modified: <Number> the last modified date/time\n * type: <String> the type of the entry\n * contents: <Array> an optional array of child entries\n * }\n *\n * By default ls() gives a shallow listing. If you want\n * to follow directories as they are encountered, use\n * the `recursive=true` option.\n */\nShell.prototype.ls = function(dir, options, callback) {\n var sh = this;\n var fs = sh.fs;\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n callback = callback || function(){};\n\n if(!dir) {\n callback(new Errors.EINVAL('Missing dir argument'));\n return;\n }\n\n function list(path, callback) {\n var pathname = Path.resolve(sh.pwd(), path);\n var result = [];\n\n fs.readdir(pathname, function(error, entries) {\n if(error) {\n callback(error);\n return;\n }\n\n function getDirEntry(name, callback) {\n name = Path.join(pathname, name);\n fs.stat(name, function(error, stats) {\n if(error) {\n callback(error);\n return;\n }\n var entry = stats;\n\n if(options.recursive && stats.type === 'DIRECTORY') {\n list(Path.join(pathname, entry.name), function(error, items) {\n if(error) {\n callback(error);\n return;\n }\n entry.contents = items;\n result.push(entry);\n callback();\n });\n } else {\n result.push(entry);\n callback();\n }\n });\n }\n\n async.eachSeries(entries, getDirEntry, function(error) {\n callback(error, result);\n });\n });\n }\n\n list(dir, callback);\n};\n\n/**\n * Removes the file or directory at `path`. If `path` is a file\n * it will be removed. If `path` is a directory, it will be\n * removed if it is empty, otherwise the callback will receive\n * an error. In order to remove non-empty directories, use the\n * `recursive=true` option.\n */\nShell.prototype.rm = function(path, options, callback) {\n var sh = this;\n var fs = sh.fs;\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n callback = callback || function(){};\n\n if(!path) {\n callback(new Errors.EINVAL('Missing path argument'));\n return;\n }\n\n function remove(pathname, callback) {\n pathname = Path.resolve(sh.pwd(), pathname);\n fs.stat(pathname, function(error, stats) {\n if(error) {\n callback(error);\n return;\n }\n\n // If this is a file, delete it and we're done\n if(stats.type === 'FILE') {\n fs.unlink(pathname, callback);\n return;\n }\n\n // If it's a dir, check if it's empty\n fs.readdir(pathname, function(error, entries) {\n if(error) {\n callback(error);\n return;\n }\n\n // If dir is empty, delete it and we're done\n if(entries.length === 0) {\n fs.rmdir(pathname, callback);\n return;\n }\n\n // If not, see if we're allowed to delete recursively\n if(!options.recursive) {\n callback(new Errors.ENOTEMPTY(null, pathname));\n return;\n }\n\n // Remove each dir entry recursively, then delete the dir.\n entries = entries.map(function(filename) {\n // Root dir entries absolutely\n return Path.join(pathname, filename);\n });\n async.eachSeries(entries, remove, function(error) {\n if(error) {\n callback(error);\n return;\n }\n fs.rmdir(pathname, callback);\n });\n });\n });\n }\n\n remove(path, callback);\n};\n\n/**\n * Gets the path to the temporary directory, creating it if not\n * present. The directory used is the one specified in\n * env.TMP. The callback receives (error, tempDirName).\n */\nShell.prototype.tempDir = function(callback) {\n var sh = this;\n var fs = sh.fs;\n var tmp = sh.env.get('TMP');\n callback = callback || function(){};\n\n // Try and create it, and it will either work or fail\n // but either way it's now there.\n fs.mkdir(tmp, function() {\n callback(null, tmp);\n });\n};\n\n/**\n * Recursively creates the directory at `path`. If the parent\n * of `path` does not exist, it will be created.\n * Based off EnsureDir by Sam X. Xu\n * https://www.npmjs.org/package/ensureDir\n * MIT License\n */\nShell.prototype.mkdirp = function(path, callback) {\n var sh = this;\n var fs = sh.fs;\n callback = callback || function(){};\n\n if(!path) {\n callback(new Errors.EINVAL('Missing path argument'));\n return;\n }\n else if (path === '/') {\n callback();\n return;\n }\n function _mkdirp(path, callback) {\n fs.stat(path, function (err, stat) {\n if(stat) {\n if(stat.isDirectory()) {\n callback();\n return;\n }\n else if (stat.isFile()) {\n callback(new Errors.ENOTDIR(null, path));\n return;\n }\n }\n else if (err && err.code !== 'ENOENT') {\n callback(err);\n return;\n }\n else {\n var parent = Path.dirname(path);\n if(parent === '/') {\n fs.mkdir(path, function (err) {\n if (err && err.code != 'EEXIST') {\n callback(err);\n return;\n }\n callback();\n return;\n });\n }\n else {\n _mkdirp(parent, function (err) {\n if (err) return callback(err);\n fs.mkdir(path, function (err) {\n if (err && err.code != 'EEXIST') {\n callback(err);\n return;\n }\n callback();\n return;\n });\n });\n }\n }\n });\n }\n\n _mkdirp(path, callback);\n};\n\n/**\n * Recursively walk a directory tree, reporting back all paths\n * that were found along the way. The `path` must be a dir.\n * Valid options include a `regex` for pattern matching paths\n * and an `exec` function of the form `function(path, next)` where\n * `path` is the current path that was found (dir paths have an '/'\n * appended) and `next` is a callback to call when done processing\n * the current path, passing any error object back as the first argument.\n * `find` returns a flat array of absolute paths for all matching/found\n * paths as the final argument to the callback.\n */\nShell.prototype.find = function(path, options, callback) {\n var sh = this;\n var fs = sh.fs;\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n callback = callback || function(){};\n\n var exec = options.exec || function(path, next) { next(); };\n var found = [];\n\n if(!path) {\n callback(new Errors.EINVAL('Missing path argument'));\n return;\n }\n\n function processPath(path, callback) {\n exec(path, function(err) {\n if(err) {\n callback(err);\n return;\n }\n\n found.push(path);\n callback();\n });\n }\n\n function maybeProcessPath(path, callback) {\n // Test the path against the user's regex, name, path primaries (if any)\n // and remove any trailing slashes added previously.\n var rawPath = Path.removeTrailing(path);\n\n // Check entire path against provided regex, if any\n if(options.regex && !options.regex.test(rawPath)) {\n callback();\n return;\n }\n\n // Check basename for matches against name primary, if any\n if(options.name && !minimatch(Path.basename(rawPath), options.name)) {\n callback();\n return;\n }\n\n // Check dirname for matches against path primary, if any\n if(options.path && !minimatch(Path.dirname(rawPath), options.path)) {\n callback();\n return;\n }\n\n processPath(path, callback);\n }\n\n function walk(path, callback) {\n path = Path.resolve(sh.pwd(), path);\n\n // The path is either a file or dir, and instead of doing\n // a stat() to determine it first, we just try to readdir()\n // and it will either work or not, and we handle the non-dir error.\n fs.readdir(path, function(err, entries) {\n if(err) {\n if(err.code === 'ENOTDIR' /* file case, ignore error */) {\n maybeProcessPath(path, callback);\n } else {\n callback(err);\n }\n return;\n }\n\n // Path is really a dir, add a trailing / and report it found\n maybeProcessPath(Path.addTrailing(path), function(err) {\n if(err) {\n callback(err);\n return;\n }\n\n entries = entries.map(function(entry) {\n return Path.join(path, entry);\n });\n\n async.eachSeries(entries, walk, function(err) {\n callback(err, found);\n });\n });\n });\n }\n\n // Make sure we are starting with a dir path\n fs.stat(path, function(err, stats) {\n if(err) {\n callback(err);\n return;\n }\n if(!stats.isDirectory()) {\n callback(new Errors.ENOTDIR(null, path));\n return;\n }\n\n walk(path, callback);\n });\n};\n\nmodule.exports = Shell;\n","// Based on https://github.com/diy/intercom.js/blob/master/lib/events.js\n// Copyright 2012 DIY Co Apache License, Version 2.0\n// http://www.apache.org/licenses/LICENSE-2.0\n\nfunction removeItem(item, array) {\n for (var i = array.length - 1; i >= 0; i--) {\n if (array[i] === item) {\n array.splice(i, 1);\n }\n }\n return array;\n}\n\nvar EventEmitter = function() {};\n\nEventEmitter.createInterface = function(space) {\n var methods = {};\n\n methods.on = function(name, fn) {\n if (typeof this[space] === 'undefined') {\n this[space] = {};\n }\n if (!this[space].hasOwnProperty(name)) {\n this[space][name] = [];\n }\n this[space][name].push(fn);\n };\n\n methods.off = function(name, fn) {\n if (typeof this[space] === 'undefined') return;\n if (this[space].hasOwnProperty(name)) {\n removeItem(fn, this[space][name]);\n }\n };\n\n methods.trigger = function(name) {\n if (typeof this[space] !== 'undefined' && this[space].hasOwnProperty(name)) {\n var args = Array.prototype.slice.call(arguments, 1);\n for (var i = 0; i < this[space][name].length; i++) {\n this[space][name][i].apply(this[space][name][i], args);\n }\n }\n };\n\n methods.removeAllListeners = function(name) {\n if (typeof this[space] === 'undefined') return;\n var self = this;\n self[space][name].forEach(function(fn) {\n self.off(name, fn);\n });\n };\n\n return methods;\n};\n\nvar pvt = EventEmitter.createInterface('_handlers');\nEventEmitter.prototype._on = pvt.on;\nEventEmitter.prototype._off = pvt.off;\nEventEmitter.prototype._trigger = pvt.trigger;\n\nvar pub = EventEmitter.createInterface('handlers');\nEventEmitter.prototype.on = function() {\n pub.on.apply(this, arguments);\n Array.prototype.unshift.call(arguments, 'on');\n this._trigger.apply(this, arguments);\n};\nEventEmitter.prototype.off = pub.off;\nEventEmitter.prototype.trigger = pub.trigger;\nEventEmitter.prototype.removeAllListeners = pub.removeAllListeners;\n\nmodule.exports = EventEmitter;\n","// Based on https://github.com/diy/intercom.js/blob/master/lib/intercom.js\n// Copyright 2012 DIY Co Apache License, Version 2.0\n// http://www.apache.org/licenses/LICENSE-2.0\n\nvar EventEmitter = require('./eventemitter.js');\nvar guid = require('../src/shared.js').guid;\n\nfunction throttle(delay, fn) {\n var last = 0;\n return function() {\n var now = Date.now();\n if (now - last > delay) {\n last = now;\n fn.apply(this, arguments);\n }\n };\n}\n\nfunction extend(a, b) {\n if (typeof a === 'undefined' || !a) { a = {}; }\n if (typeof b === 'object') {\n for (var key in b) {\n if (b.hasOwnProperty(key)) {\n a[key] = b[key];\n }\n }\n }\n return a;\n}\n\nvar localStorage = (function(window) {\n if (typeof window === 'undefined' ||\n typeof window.localStorage === 'undefined') {\n return {\n getItem : function() {},\n setItem : function() {},\n removeItem : function() {}\n };\n }\n return window.localStorage;\n}(global));\n\nfunction Intercom() {\n var self = this;\n var now = Date.now();\n\n this.origin = guid();\n this.lastMessage = now;\n this.receivedIDs = {};\n this.previousValues = {};\n\n var storageHandler = function() {\n self._onStorageEvent.apply(self, arguments);\n };\n\n // If we're in node.js, skip event registration\n if (typeof document === 'undefined') {\n return;\n }\n\n if (document.attachEvent) {\n document.attachEvent('onstorage', storageHandler);\n } else {\n global.addEventListener('storage', storageHandler, false);\n }\n}\n\nIntercom.prototype._transaction = function(fn) {\n var TIMEOUT = 1000;\n var WAIT = 20;\n var self = this;\n var executed = false;\n var listening = false;\n var waitTimer = null;\n\n function lock() {\n if (executed) {\n return;\n }\n\n var now = Date.now();\n var activeLock = localStorage.getItem(INDEX_LOCK)|0;\n if (activeLock && now - activeLock < TIMEOUT) {\n if (!listening) {\n self._on('storage', lock);\n listening = true;\n }\n waitTimer = setTimeout(lock, WAIT);\n return;\n }\n executed = true;\n localStorage.setItem(INDEX_LOCK, now);\n\n fn();\n unlock();\n }\n\n function unlock() {\n if (listening) {\n self._off('storage', lock);\n }\n if (waitTimer) {\n clearTimeout(waitTimer);\n }\n localStorage.removeItem(INDEX_LOCK);\n }\n\n lock();\n};\n\nIntercom.prototype._cleanup_emit = throttle(100, function() {\n var self = this;\n\n self._transaction(function() {\n var now = Date.now();\n var threshold = now - THRESHOLD_TTL_EMIT;\n var changed = 0;\n var messages;\n\n try {\n messages = JSON.parse(localStorage.getItem(INDEX_EMIT) || '[]');\n } catch(e) {\n messages = [];\n }\n for (var i = messages.length - 1; i >= 0; i--) {\n if (messages[i].timestamp < threshold) {\n messages.splice(i, 1);\n changed++;\n }\n }\n if (changed > 0) {\n localStorage.setItem(INDEX_EMIT, JSON.stringify(messages));\n }\n });\n});\n\nIntercom.prototype._cleanup_once = throttle(100, function() {\n var self = this;\n\n self._transaction(function() {\n var timestamp, ttl, key;\n var table;\n var now = Date.now();\n var changed = 0;\n\n try {\n table = JSON.parse(localStorage.getItem(INDEX_ONCE) || '{}');\n } catch(e) {\n table = {};\n }\n for (key in table) {\n if (self._once_expired(key, table)) {\n delete table[key];\n changed++;\n }\n }\n\n if (changed > 0) {\n localStorage.setItem(INDEX_ONCE, JSON.stringify(table));\n }\n });\n});\n\nIntercom.prototype._once_expired = function(key, table) {\n if (!table) {\n return true;\n }\n if (!table.hasOwnProperty(key)) {\n return true;\n }\n if (typeof table[key] !== 'object') {\n return true;\n }\n\n var ttl = table[key].ttl || THRESHOLD_TTL_ONCE;\n var now = Date.now();\n var timestamp = table[key].timestamp;\n return timestamp < now - ttl;\n};\n\nIntercom.prototype._localStorageChanged = function(event, field) {\n if (event && event.key) {\n return event.key === field;\n }\n\n var currentValue = localStorage.getItem(field);\n if (currentValue === this.previousValues[field]) {\n return false;\n }\n this.previousValues[field] = currentValue;\n return true;\n};\n\nIntercom.prototype._onStorageEvent = function(event) {\n event = event || global.event;\n var self = this;\n\n if (this._localStorageChanged(event, INDEX_EMIT)) {\n this._transaction(function() {\n var now = Date.now();\n var data = localStorage.getItem(INDEX_EMIT);\n var messages;\n\n try {\n messages = JSON.parse(data || '[]');\n } catch(e) {\n messages = [];\n }\n for (var i = 0; i < messages.length; i++) {\n if (messages[i].origin === self.origin) continue;\n if (messages[i].timestamp < self.lastMessage) continue;\n if (messages[i].id) {\n if (self.receivedIDs.hasOwnProperty(messages[i].id)) continue;\n self.receivedIDs[messages[i].id] = true;\n }\n self.trigger(messages[i].name, messages[i].payload);\n }\n self.lastMessage = now;\n });\n }\n\n this._trigger('storage', event);\n};\n\nIntercom.prototype._emit = function(name, message, id) {\n id = (typeof id === 'string' || typeof id === 'number') ? String(id) : null;\n if (id && id.length) {\n if (this.receivedIDs.hasOwnProperty(id)) return;\n this.receivedIDs[id] = true;\n }\n\n var packet = {\n id : id,\n name : name,\n origin : this.origin,\n timestamp : Date.now(),\n payload : message\n };\n\n var self = this;\n this._transaction(function() {\n var data = localStorage.getItem(INDEX_EMIT) || '[]';\n var delimiter = (data === '[]') ? '' : ',';\n data = [data.substring(0, data.length - 1), delimiter, JSON.stringify(packet), ']'].join('');\n localStorage.setItem(INDEX_EMIT, data);\n self.trigger(name, message);\n\n setTimeout(function() {\n self._cleanup_emit();\n }, 50);\n });\n};\n\nIntercom.prototype.emit = function(name, message) {\n this._emit.apply(this, arguments);\n this._trigger('emit', name, message);\n};\n\nIntercom.prototype.once = function(key, fn, ttl) {\n if (!Intercom.supported) {\n return;\n }\n\n var self = this;\n this._transaction(function() {\n var data;\n try {\n data = JSON.parse(localStorage.getItem(INDEX_ONCE) || '{}');\n } catch(e) {\n data = {};\n }\n if (!self._once_expired(key, data)) {\n return;\n }\n\n data[key] = {};\n data[key].timestamp = Date.now();\n if (typeof ttl === 'number') {\n data[key].ttl = ttl * 1000;\n }\n\n localStorage.setItem(INDEX_ONCE, JSON.stringify(data));\n fn();\n\n setTimeout(function() {\n self._cleanup_once();\n }, 50);\n });\n};\n\nextend(Intercom.prototype, EventEmitter.prototype);\n\nIntercom.supported = (typeof localStorage !== 'undefined');\n\nvar INDEX_EMIT = 'intercom';\nvar INDEX_ONCE = 'intercom_once';\nvar INDEX_LOCK = 'intercom_lock';\n\nvar THRESHOLD_TTL_EMIT = 50000;\nvar THRESHOLD_TTL_ONCE = 1000 * 3600;\n\nIntercom.destroy = function() {\n localStorage.removeItem(INDEX_LOCK);\n localStorage.removeItem(INDEX_EMIT);\n localStorage.removeItem(INDEX_ONCE);\n};\n\nIntercom.getInstance = (function() {\n var intercom;\n return function() {\n if (!intercom) {\n intercom = new Intercom();\n }\n return intercom;\n };\n})();\n\nmodule.exports = Intercom;\n","var EventEmitter = require('../lib/eventemitter.js');\nvar Path = require('./path.js');\nvar Intercom = require('../lib/intercom.js');\n\n/**\n * FSWatcher based on node.js' FSWatcher\n * see https://github.com/joyent/node/blob/master/lib/fs.js\n */\nfunction FSWatcher() {\n EventEmitter.call(this);\n var self = this;\n var recursive = false;\n var recursivePathPrefix;\n var filename;\n\n function onchange(path) {\n // Watch for exact filename, or parent path when recursive is true.\n if(filename === path || (recursive && path.indexOf(recursivePathPrefix) === 0)) {\n self.trigger('change', 'change', path);\n }\n }\n\n // We support, but ignore the second arg, which node.js uses.\n self.start = function(filename_, persistent_, recursive_) {\n // Bail if we've already started (and therefore have a filename);\n if(filename) {\n return;\n }\n\n if(Path.isNull(filename_)) {\n throw new Error('Path must be a string without null bytes.');\n }\n\n // TODO: get realpath for symlinks on filename...\n\n // Filer's Path.normalize strips trailing slashes, which we use here.\n // See https://github.com/js-platform/filer/issues/105\n filename = Path.normalize(filename_);\n\n // Whether to watch beneath this path or not\n recursive = recursive_ === true;\n // If recursive, construct a path prefix portion for comparisons later\n // (i.e., '/path' becomes '/path/' so we can search within a filename for the\n // prefix). We also take care to allow for '/' on its own.\n if(recursive) {\n recursivePathPrefix = filename === '/' ? '/' : filename + '/';\n }\n\n var intercom = Intercom.getInstance();\n intercom.on('change', onchange);\n };\n\n self.close = function() {\n var intercom = Intercom.getInstance();\n intercom.off('change', onchange);\n self.removeAllListeners('change');\n };\n}\nFSWatcher.prototype = new EventEmitter();\nFSWatcher.prototype.constructor = FSWatcher;\n\nmodule.exports = FSWatcher;\n","// Adapt encodings to work with Buffer or Uint8Array, they expect the latter\nfunction decode(buf) {\n return buf.toString('utf8');\n}\n\nfunction encode(string) {\n return new Buffer(string, 'utf8');\n}\n\nmodule.exports = {\n encode: encode,\n decode: decode\n};\n","var NODE_TYPE_FILE = require('./constants.js').NODE_TYPE_FILE;\n\nmodule.exports = function DirectoryEntry(id, type) {\n this.id = id;\n this.type = type || NODE_TYPE_FILE;\n};\n","var Errors = require('./errors.js');\n\nfunction OpenFileDescription(path, id, flags, position) {\n this.path = path;\n this.id = id;\n this.flags = flags;\n this.position = position;\n}\n\n// Tries to find the node associated with an ofd's `id`.\n// If not found, an error is returned on the callback.\nOpenFileDescription.prototype.getNode = function(context, callback) {\n var id = this.id;\n var path = this.path;\n\n function check_if_node_exists(error, node) {\n if(error) {\n return callback(error);\n }\n\n if(!node) {\n return callback(new Errors.EBADF('file descriptor refers to unknown node', path));\n }\n\n callback(null, node);\n }\n\n context.getObject(id, check_if_node_exists);\n};\n\nmodule.exports = OpenFileDescription;\n","var Constants = require('./constants.js');\n\nfunction SuperNode(options) {\n var now = Date.now();\n\n this.id = Constants.SUPER_NODE_ID;\n this.type = Constants.NODE_TYPE_META;\n this.atime = options.atime || now;\n this.ctime = options.ctime || now;\n this.mtime = options.mtime || now;\n // root node id (randomly generated)\n this.rnode = options.rnode;\n}\n\nSuperNode.create = function(options, callback) {\n options.guid(function(err, rnode) {\n if(err) {\n callback(err);\n return;\n }\n options.rnode = options.rnode || rnode;\n callback(null, new SuperNode(options));\n });\n};\n\nmodule.exports = SuperNode;\n","var NODE_TYPE_FILE = require('./constants.js').NODE_TYPE_FILE;\nvar NODE_TYPE_DIRECTORY = require('./constants.js').NODE_TYPE_DIRECTORY;\nvar NODE_TYPE_SYMBOLIC_LINK = require('./constants.js').NODE_TYPE_SYMBOLIC_LINK;\n\nvar S_IFREG = require('./constants.js').S_IFREG;\nvar S_IFDIR = require('./constants.js').S_IFDIR;\nvar S_IFLNK = require('./constants.js').S_IFLNK;\n\nvar DEFAULT_FILE_PERMISSIONS = require('./constants.js').DEFAULT_FILE_PERMISSIONS;\nvar DEFAULT_DIR_PERMISSIONS = require('./constants.js').DEFAULT_DIR_PERMISSIONS;\n\nfunction getMode(type, mode) {\n switch(type) {\n case NODE_TYPE_DIRECTORY:\n return (mode || DEFAULT_DIR_PERMISSIONS) | S_IFDIR;\n case NODE_TYPE_SYMBOLIC_LINK:\n return (mode || DEFAULT_FILE_PERMISSIONS) | S_IFLNK;\n /* jshint -W086 */\n case NODE_TYPE_FILE:\n // falls through\n default:\n return (mode || DEFAULT_FILE_PERMISSIONS) | S_IFREG;\n }\n}\n\nfunction Node(options) {\n var now = Date.now();\n\n this.id = options.id;\n this.type = options.type || NODE_TYPE_FILE; // node type (file, directory, etc)\n this.size = options.size || 0; // size (bytes for files, entries for directories)\n this.atime = options.atime || now; // access time (will mirror ctime after creation)\n this.ctime = options.ctime || now; // creation/change time\n this.mtime = options.mtime || now; // modified time\n this.flags = options.flags || []; // file flags\n this.xattrs = options.xattrs || {}; // extended attributes\n this.nlinks = options.nlinks || 0; // links count\n this.data = options.data; // id for data object\n this.version = options.version || 1;\n\n // permissions and flags\n this.mode = options.mode || (getMode(this.type));\n this.uid = options.uid || 0x0; // owner name\n this.gid = options.gid || 0x0; // group name\n}\n\n// Make sure the options object has an id on property,\n// either from caller or one we generate using supplied guid fn.\nfunction ensureID(options, prop, callback) {\n if(options[prop]) {\n callback(null);\n } else {\n options.guid(function(err, id) {\n options[prop] = id;\n callback(err);\n });\n }\n}\n\nNode.create = function(options, callback) {\n // We expect both options.id and options.data to be provided/generated.\n ensureID(options, 'id', function(err) {\n if(err) {\n callback(err);\n return;\n }\n\n ensureID(options, 'data', function(err) {\n if(err) {\n callback(err);\n return;\n }\n\n callback(null, new Node(options));\n });\n });\n};\n\n// Update the node's mode (permissions), taking file type bits into account.\nNode.setMode = function(mode, node) {\n node.mode = getMode(node.type, mode);\n};\n\nmodule.exports = Node;\n","var Constants = require('./constants.js');\nvar Path = require('./path.js');\n\nfunction Stats(path, fileNode, devName) {\n this.dev = devName;\n this.node = fileNode.id;\n this.type = fileNode.type;\n this.size = fileNode.size;\n this.nlinks = fileNode.nlinks;\n this.atime = fileNode.atime;\n this.mtime = fileNode.mtime;\n this.ctime = fileNode.ctime;\n this.version = fileNode.version;\n this.mode = fileNode.mode;\n this.uid = fileNode.uid;\n this.gid = fileNode.gid;\n this.name = Path.basename(path);\n}\n\nStats.prototype.isFile = function() {\n return this.type === Constants.NODE_TYPE_FILE;\n};\n\nStats.prototype.isDirectory = function() {\n return this.type === Constants.NODE_TYPE_DIRECTORY;\n};\n\nStats.prototype.isSymbolicLink = function() {\n return this.type === Constants.NODE_TYPE_SYMBOLIC_LINK;\n};\n\n// These will always be false in Filer.\nStats.prototype.isSocket =\nStats.prototype.isFIFO =\nStats.prototype.isCharacterDevice =\nStats.prototype.isBlockDevice =\nfunction() {\n return false;\n};\n\nmodule.exports = Stats;\n","var _ = require('../../lib/nodash.js');\n\nvar Path = require('../path.js');\nvar normalize = Path.normalize;\nvar dirname = Path.dirname;\nvar basename = Path.basename;\nvar isAbsolutePath = Path.isAbsolute;\nvar isNullPath = Path.isNull;\n\nvar Constants = require('../constants.js');\nvar NODE_TYPE_FILE = Constants.NODE_TYPE_FILE;\nvar NODE_TYPE_DIRECTORY = Constants.NODE_TYPE_DIRECTORY;\nvar NODE_TYPE_SYMBOLIC_LINK = Constants.NODE_TYPE_SYMBOLIC_LINK;\nvar NODE_TYPE_META = Constants.NODE_TYPE_META;\n\nvar FULL_READ_WRITE_EXEC_PERMISSIONS = Constants.FULL_READ_WRITE_EXEC_PERMISSIONS;\n\nvar ROOT_DIRECTORY_NAME = Constants.ROOT_DIRECTORY_NAME;\nvar SUPER_NODE_ID = Constants.SUPER_NODE_ID;\nvar SYMLOOP_MAX = Constants.SYMLOOP_MAX;\n\nvar O_READ = Constants.O_READ;\nvar O_WRITE = Constants.O_WRITE;\nvar O_CREATE = Constants.O_CREATE;\nvar O_EXCLUSIVE = Constants.O_EXCLUSIVE;\nvar O_APPEND = Constants.O_APPEND;\nvar O_FLAGS = Constants.O_FLAGS;\n\nvar XATTR_CREATE = Constants.XATTR_CREATE;\nvar XATTR_REPLACE = Constants.XATTR_REPLACE;\nvar FS_NOMTIME = Constants.FS_NOMTIME;\nvar FS_NOCTIME = Constants.FS_NOCTIME;\n\nvar Encoding = require('../encoding.js');\nvar Errors = require('../errors.js');\nvar DirectoryEntry = require('../directory-entry.js');\nvar OpenFileDescription = require('../open-file-description.js');\nvar SuperNode = require('../super-node.js');\nvar Node = require('../node.js');\nvar Stats = require('../stats.js');\nvar Buffer = require('../buffer.js');\nconst { validateInteger } = require('../shared.js');\n\n/**\n * Update node times. Only passed times are modified (undefined times are ignored)\n * and filesystem flags are examined in order to override update logic.\n */\nfunction update_node_times(context, path, node, times, callback) {\n // Honour mount flags for how we update times\n var flags = context.flags;\n if(_(flags).contains(FS_NOCTIME)) {\n delete times.ctime;\n }\n if(_(flags).contains(FS_NOMTIME)) {\n delete times.mtime;\n }\n\n // Only do the update if required (i.e., times are still present)\n var update = false;\n if(times.ctime) {\n node.ctime = times.ctime;\n // We don't do atime tracking for perf reasons, but do mirror ctime\n node.atime = times.ctime;\n update = true;\n }\n if(times.atime) {\n // The only time we explicitly pass atime is when utimes(), futimes() is called.\n // Override ctime mirror here if so\n node.atime = times.atime;\n update = true;\n }\n if(times.mtime) {\n node.mtime = times.mtime;\n update = true;\n }\n\n function complete(error) {\n // Queue this change so we can send watch events.\n // Unlike node.js, we send the full path vs. basename/dirname only.\n context.changes.push({ event: 'change', path: path });\n callback(error);\n }\n\n if(update) {\n context.putObject(node.id, node, complete);\n } else {\n complete();\n }\n}\n\n/**\n * make_node()\n */\n// in: file or directory path\n// out: new node representing file/directory\nfunction make_node(context, path, type, callback) {\n if(type !== NODE_TYPE_DIRECTORY && type !== NODE_TYPE_FILE) {\n return callback(new Errors.EINVAL('type must be a directory or file', path));\n }\n\n path = normalize(path);\n\n var name = basename(path);\n var parentPath = dirname(path);\n var parentNode;\n var parentNodeData;\n var node;\n\n // Check if the parent node exists\n function create_node_in_parent(error, parentDirectoryNode) {\n if(error) {\n callback(error);\n } else if(parentDirectoryNode.type !== NODE_TYPE_DIRECTORY) {\n callback(new Errors.ENOTDIR('a component of the path prefix is not a directory', path));\n } else {\n parentNode = parentDirectoryNode;\n find_node(context, path, check_if_node_exists);\n }\n }\n\n // Check if the node to be created already exists\n function check_if_node_exists(error, result) {\n if(!error && result) {\n callback(new Errors.EEXIST('path name already exists', path));\n } else if(error && !(error instanceof Errors.ENOENT)) {\n callback(error);\n } else {\n context.getObject(parentNode.data, create_node);\n }\n }\n\n // Create the new node\n function create_node(error, result) {\n if(error) {\n callback(error);\n } else {\n parentNodeData = result;\n Node.create({\n guid: context.guid,\n type: type\n }, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n node = result;\n node.nlinks += 1;\n context.putObject(node.id, node, update_parent_node_data);\n });\n }\n }\n\n // Update parent node time\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, node, { mtime: now, ctime: now }, callback);\n }\n }\n\n // Update the parent nodes data\n function update_parent_node_data(error) {\n if(error) {\n callback(error);\n } else {\n parentNodeData[name] = new DirectoryEntry(node.id, type);\n context.putObject(parentNode.data, parentNodeData, update_time);\n }\n }\n\n // Find the parent node\n find_node(context, parentPath, create_node_in_parent);\n}\n\n/**\n * find_node\n */\n// in: file or directory path\n// out: node structure, or error\nfunction find_node(context, path, callback) {\n path = normalize(path);\n if(!path) {\n return callback(new Errors.ENOENT('path is an empty string'));\n }\n var name = basename(path);\n var parentPath = dirname(path);\n var followedCount = 0;\n\n function read_root_directory_node(error, superNode) {\n if(error) {\n callback(error);\n } else if(!superNode || superNode.type !== NODE_TYPE_META || !superNode.rnode) {\n callback(new Errors.EFILESYSTEMERROR());\n } else {\n context.getObject(superNode.rnode, check_root_directory_node);\n }\n }\n\n function check_root_directory_node(error, rootDirectoryNode) {\n if(error) {\n callback(error);\n } else if(!rootDirectoryNode) {\n callback(new Errors.ENOENT());\n } else {\n callback(null, rootDirectoryNode);\n }\n }\n\n // in: parent directory node\n // out: parent directory data\n function read_parent_directory_data(error, parentDirectoryNode) {\n if(error) {\n callback(error);\n } else if(parentDirectoryNode.type !== NODE_TYPE_DIRECTORY || !parentDirectoryNode.data) {\n callback(new Errors.ENOTDIR('a component of the path prefix is not a directory', path));\n } else {\n context.getObject(parentDirectoryNode.data, get_node_from_parent_directory_data);\n }\n }\n\n // in: parent directory data\n // out: searched node\n function get_node_from_parent_directory_data(error, parentDirectoryData) {\n if(error) {\n callback(error);\n } else {\n if(!_(parentDirectoryData).has(name)) {\n callback(new Errors.ENOENT(null, path));\n } else {\n var nodeId = parentDirectoryData[name].id;\n context.getObject(nodeId, is_symbolic_link);\n }\n }\n }\n\n function is_symbolic_link(error, node) {\n if(error) {\n callback(error);\n } else {\n if(node.type === NODE_TYPE_SYMBOLIC_LINK) {\n followedCount++;\n if(followedCount > SYMLOOP_MAX){\n callback(new Errors.ELOOP(null, path));\n } else {\n follow_symbolic_link(node.data);\n }\n } else {\n callback(null, node);\n }\n }\n }\n\n function follow_symbolic_link(data) {\n data = normalize(data);\n parentPath = dirname(data);\n name = basename(data);\n if(ROOT_DIRECTORY_NAME === name) {\n context.getObject(SUPER_NODE_ID, read_root_directory_node);\n } else {\n find_node(context, parentPath, read_parent_directory_data);\n }\n }\n\n if(ROOT_DIRECTORY_NAME === name) {\n context.getObject(SUPER_NODE_ID, read_root_directory_node);\n } else {\n find_node(context, parentPath, read_parent_directory_data);\n }\n}\n\n\n/**\n * set extended attribute (refactor)\n */\nfunction set_extended_attribute (context, path, node, name, value, flag, callback) {\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n update_node_times(context, path, node, { ctime: Date.now() }, callback);\n }\n }\n\n var xattrs = node.xattrs;\n\n if (flag === XATTR_CREATE && xattrs.hasOwnProperty(name)) {\n callback(new Errors.EEXIST('attribute already exists', path));\n }\n else if (flag === XATTR_REPLACE && !xattrs.hasOwnProperty(name)) {\n callback(new Errors.ENOATTR(null, path));\n }\n else {\n xattrs[name] = value;\n context.putObject(node.id, node, update_time);\n }\n}\n\n/**\n * ensure_root_directory. Creates a root node if necessary.\n *\n * Note: this should only be invoked when formatting a new file system.\n * Multiple invocations of this by separate instances will still result\n * in only a single super node.\n */\nfunction ensure_root_directory(context, callback) {\n var superNode;\n var directoryNode;\n var directoryData;\n\n function ensure_super_node(error, existingNode) {\n if(!error && existingNode) {\n // Another instance has beat us and already created the super node.\n callback();\n } else if(error && !(error instanceof Errors.ENOENT)) {\n callback(error);\n } else {\n SuperNode.create({guid: context.guid}, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n superNode = result;\n context.putObject(superNode.id, superNode, write_directory_node);\n });\n }\n }\n\n function write_directory_node(error) {\n if(error) {\n callback(error);\n } else {\n Node.create({\n guid: context.guid,\n id: superNode.rnode,\n type: NODE_TYPE_DIRECTORY\n }, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n directoryNode = result;\n directoryNode.nlinks += 1;\n context.putObject(directoryNode.id, directoryNode, write_directory_data);\n });\n }\n }\n\n function write_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n directoryData = {};\n context.putObject(directoryNode.data, directoryData, callback);\n }\n }\n\n context.getObject(SUPER_NODE_ID, ensure_super_node);\n}\n\n/**\n * make_directory\n */\nfunction make_directory(context, path, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n var parentDirectoryNode;\n var parentDirectoryData;\n\n function check_if_directory_exists(error, result) {\n if(!error && result) {\n callback(new Errors.EEXIST(null, path));\n } else if(error && !(error instanceof Errors.ENOENT)) {\n callback(error);\n } else {\n find_node(context, parentPath, read_parent_directory_data);\n }\n }\n\n function read_parent_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n parentDirectoryNode = result;\n context.getObject(parentDirectoryNode.data, write_directory_node);\n }\n }\n\n function write_directory_node(error, result) {\n if(error) {\n callback(error);\n } else {\n parentDirectoryData = result;\n Node.create({\n guid: context.guid,\n type: NODE_TYPE_DIRECTORY\n }, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n directoryNode = result;\n directoryNode.nlinks += 1;\n context.putObject(directoryNode.id, directoryNode, write_directory_data);\n });\n }\n }\n\n function write_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n directoryData = {};\n context.putObject(directoryNode.data, directoryData, update_parent_directory_data);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, parentDirectoryNode, { mtime: now, ctime: now }, callback);\n }\n }\n\n function update_parent_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n parentDirectoryData[name] = new DirectoryEntry(directoryNode.id, NODE_TYPE_DIRECTORY);\n context.putObject(parentDirectoryNode.data, parentDirectoryData, update_time);\n }\n }\n\n find_node(context, path, check_if_directory_exists);\n}\n\n/**\n * remove_directory\n */\nfunction remove_directory(context, path, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n var parentDirectoryNode;\n var parentDirectoryData;\n\n function read_parent_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n parentDirectoryNode = result;\n context.getObject(parentDirectoryNode.data, check_if_node_exists);\n }\n }\n\n function check_if_node_exists(error, result) {\n if(error) {\n callback(error);\n } else if(ROOT_DIRECTORY_NAME === name) {\n callback(new Errors.EBUSY(null, path));\n } else if(!_(result).has(name)) {\n callback(new Errors.ENOENT(null, path));\n } else {\n parentDirectoryData = result;\n directoryNode = parentDirectoryData[name].id;\n context.getObject(directoryNode, check_if_node_is_directory);\n }\n }\n\n function check_if_node_is_directory(error, result) {\n if(error) {\n callback(error);\n } else if(result.type !== NODE_TYPE_DIRECTORY) {\n callback(new Errors.ENOTDIR(null, path));\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_directory_is_empty);\n }\n }\n\n function check_if_directory_is_empty(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(_(directoryData).size() > 0) {\n callback(new Errors.ENOTEMPTY(null, path));\n } else {\n remove_directory_entry_from_parent_directory_node();\n }\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, parentDirectoryNode, { mtime: now, ctime: now }, remove_directory_node);\n }\n }\n\n function remove_directory_entry_from_parent_directory_node() {\n delete parentDirectoryData[name];\n context.putObject(parentDirectoryNode.data, parentDirectoryData, update_time);\n }\n\n function remove_directory_node(error) {\n if(error) {\n callback(error);\n } else {\n context.delete(directoryNode.id, remove_directory_data);\n }\n }\n\n function remove_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n context.delete(directoryNode.data, callback);\n }\n }\n\n find_node(context, parentPath, read_parent_directory_data);\n}\n\nfunction open_file(context, path, flags, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n var directoryEntry;\n var fileNode;\n var fileData;\n\n var followedCount = 0;\n\n if(ROOT_DIRECTORY_NAME === name) {\n if(_(flags).contains(O_WRITE)) {\n callback(new Errors.EISDIR('the named file is a directory and O_WRITE is set', path));\n } else {\n find_node(context, path, set_file_node);\n }\n } else {\n find_node(context, parentPath, read_directory_data);\n }\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else if(result.type !== NODE_TYPE_DIRECTORY) {\n callback(new Errors.ENOENT(null, path));\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_file_exists);\n }\n }\n\n function check_if_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(_(directoryData).has(name)) {\n if(_(flags).contains(O_EXCLUSIVE)) {\n callback(new Errors.ENOENT('O_CREATE and O_EXCLUSIVE are set, and the named file exists', path));\n } else {\n directoryEntry = directoryData[name];\n if(directoryEntry.type === NODE_TYPE_DIRECTORY && _(flags).contains(O_WRITE)) {\n callback(new Errors.EISDIR('the named file is a directory and O_WRITE is set', path));\n } else {\n context.getObject(directoryEntry.id, check_if_symbolic_link);\n }\n }\n } else {\n if(!_(flags).contains(O_CREATE)) {\n callback(new Errors.ENOENT('O_CREATE is not set and the named file does not exist', path));\n } else {\n write_file_node();\n }\n }\n }\n }\n\n function check_if_symbolic_link(error, result) {\n if(error) {\n callback(error);\n } else {\n var node = result;\n if(node.type === NODE_TYPE_SYMBOLIC_LINK) {\n followedCount++;\n if(followedCount > SYMLOOP_MAX){\n callback(new Errors.ELOOP(null, path));\n } else {\n follow_symbolic_link(node.data);\n }\n } else {\n set_file_node(undefined, node);\n }\n }\n }\n\n function follow_symbolic_link(data) {\n data = normalize(data);\n parentPath = dirname(data);\n name = basename(data);\n if(ROOT_DIRECTORY_NAME === name) {\n if(_(flags).contains(O_WRITE)) {\n callback(new Errors.EISDIR('the named file is a directory and O_WRITE is set', path));\n } else {\n find_node(context, path, set_file_node);\n }\n }\n find_node(context, parentPath, read_directory_data);\n }\n\n function set_file_node(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n callback(null, fileNode);\n }\n }\n\n function write_file_node() {\n Node.create({\n guid: context.guid,\n type: NODE_TYPE_FILE\n }, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n fileNode = result;\n fileNode.nlinks += 1;\n context.putObject(fileNode.id, fileNode, write_file_data);\n });\n }\n\n function write_file_data(error) {\n if(error) {\n callback(error);\n } else {\n fileData = new Buffer(0);\n fileData.fill(0);\n context.putBuffer(fileNode.data, fileData, update_directory_data);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, directoryNode, { mtime: now, ctime: now }, handle_update_result);\n }\n }\n\n function update_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n directoryData[name] = new DirectoryEntry(fileNode.id, NODE_TYPE_FILE);\n context.putObject(directoryNode.data, directoryData, update_time);\n }\n }\n\n function handle_update_result(error) {\n if(error) {\n callback(error);\n } else {\n callback(null, fileNode);\n }\n }\n}\n\nfunction replace_data(context, ofd, buffer, offset, length, callback) {\n var fileNode;\n\n function return_nbytes(error) {\n if(error) {\n callback(error);\n } else {\n callback(null, length);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, ofd.path, fileNode, { mtime: now, ctime: now }, return_nbytes);\n }\n }\n\n function update_file_node(error) {\n if(error) {\n callback(error);\n } else {\n context.putObject(fileNode.id, fileNode, update_time);\n }\n }\n\n function write_file_data(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n var newData = new Buffer(length);\n newData.fill(0);\n buffer.copy(newData, 0, offset, offset + length);\n ofd.position = length;\n\n fileNode.size = length;\n fileNode.version += 1;\n\n context.putBuffer(fileNode.data, newData, update_file_node);\n }\n }\n\n context.getObject(ofd.id, write_file_data);\n}\n\nfunction write_data(context, ofd, buffer, offset, length, position, callback) {\n var fileNode;\n var fileData;\n\n function return_nbytes(error) {\n if(error) {\n callback(error);\n } else {\n callback(null, length);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, ofd.path, fileNode, { mtime: now, ctime: now }, return_nbytes);\n }\n }\n\n function update_file_node(error) {\n if(error) {\n callback(error);\n } else {\n context.putObject(fileNode.id, fileNode, update_time);\n }\n }\n\n function update_file_data(error, result) {\n if(error) {\n callback(error);\n } else {\n fileData = result;\n if(!fileData) {\n return callback(new Errors.EIO('Expected Buffer'));\n }\n var _position = (!(undefined === position || null === position)) ? position : ofd.position;\n var newSize = Math.max(fileData.length, _position + length);\n var newData = new Buffer(newSize);\n newData.fill(0);\n if(fileData) {\n fileData.copy(newData);\n }\n buffer.copy(newData, _position, offset, offset + length);\n if(undefined === position) {\n ofd.position += length;\n }\n\n fileNode.size = newSize;\n fileNode.version += 1;\n\n context.putBuffer(fileNode.data, newData, update_file_node);\n }\n }\n\n function read_file_data(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n context.getBuffer(fileNode.data, update_file_data);\n }\n }\n\n context.getObject(ofd.id, read_file_data);\n}\n\nfunction read_data(context, ofd, buffer, offset, length, position, callback) {\n var fileNode;\n var fileData;\n\n function handle_file_data(error, result) {\n if(error) {\n callback(error);\n } else {\n fileData = result;\n if(!fileData) {\n return callback(new Errors.EIO('Expected Buffer'));\n }\n var _position = (!(undefined === position || null === position)) ? position : ofd.position;\n length = (_position + length > buffer.length) ? length - _position : length;\n fileData.copy(buffer, offset, _position, _position + length);\n if(undefined === position) {\n ofd.position += length;\n }\n callback(null, length);\n }\n }\n\n function read_file_data(error, result) {\n if(error) {\n callback(error);\n } else if(result.type === NODE_TYPE_DIRECTORY) {\n callback(new Errors.EISDIR('the named file is a directory', ofd.path));\n } else {\n fileNode = result;\n context.getBuffer(fileNode.data, handle_file_data);\n }\n }\n\n context.getObject(ofd.id, read_file_data);\n}\n\nfunction stat_file(context, path, callback) {\n path = normalize(path);\n find_node(context, path, callback);\n}\n\nfunction fstat_file(context, ofd, callback) {\n ofd.getNode(context, callback);\n}\n\nfunction lstat_file(context, path, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n\n if(ROOT_DIRECTORY_NAME === name) {\n find_node(context, path, callback);\n } else {\n find_node(context, parentPath, read_directory_data);\n }\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_file_exists);\n }\n }\n\n function check_if_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(!_(directoryData).has(name)) {\n callback(new Errors.ENOENT('a component of the path does not name an existing file', path));\n } else {\n context.getObject(directoryData[name].id, callback);\n }\n }\n }\n}\n\nfunction link_node(context, oldpath, newpath, callback) {\n oldpath = normalize(oldpath);\n var oldname = basename(oldpath);\n var oldParentPath = dirname(oldpath);\n\n newpath = normalize(newpath);\n var newname = basename(newpath);\n var newParentPath = dirname(newpath);\n var ctime = Date.now();\n\n var oldDirectoryNode;\n var oldDirectoryData;\n var newDirectoryNode;\n var newDirectoryData;\n var fileNodeID;\n var fileNode;\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n update_node_times(context, newpath, fileNode, { ctime: ctime }, callback);\n }\n }\n\n function update_file_node(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n fileNode.nlinks += 1;\n context.putObject(fileNode.id, fileNode, update_time);\n }\n }\n\n function read_file_node(error) {\n if(error) {\n callback(error);\n } else {\n context.getObject(fileNodeID, update_file_node);\n }\n }\n\n function check_if_new_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n newDirectoryData = result;\n if(_(newDirectoryData).has(newname)) {\n callback(new Errors.EEXIST('newpath resolves to an existing file', newname));\n } else {\n newDirectoryData[newname] = oldDirectoryData[oldname];\n fileNodeID = newDirectoryData[newname].id;\n context.putObject(newDirectoryNode.data, newDirectoryData, read_file_node);\n }\n }\n }\n\n function read_new_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n newDirectoryNode = result;\n context.getObject(newDirectoryNode.data, check_if_new_file_exists);\n }\n }\n\n function check_if_old_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n oldDirectoryData = result;\n if(!_(oldDirectoryData).has(oldname)) {\n callback(new Errors.ENOENT('a component of either path prefix does not exist', oldname));\n } else if(oldDirectoryData[oldname].type === NODE_TYPE_DIRECTORY) {\n callback(new Errors.EPERM('oldpath refers to a directory'));\n } else {\n find_node(context, newParentPath, read_new_directory_data);\n }\n }\n }\n\n function read_old_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n oldDirectoryNode = result;\n context.getObject(oldDirectoryNode.data, check_if_old_file_exists);\n }\n }\n\n find_node(context, oldParentPath, read_old_directory_data);\n}\n\nfunction unlink_node(context, path, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n var fileNode;\n\n function update_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n delete directoryData[name];\n context.putObject(directoryNode.data, directoryData, function(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, directoryNode, { mtime: now, ctime: now }, callback);\n }\n });\n }\n }\n\n function delete_file_data(error) {\n if(error) {\n callback(error);\n } else {\n context.delete(fileNode.data, update_directory_data);\n }\n }\n\n function update_file_node(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n fileNode.nlinks -= 1;\n if(fileNode.nlinks < 1) {\n context.delete(fileNode.id, delete_file_data);\n } else {\n context.putObject(fileNode.id, fileNode, function(error) {\n if(error) {\n callback(error);\n } else { \n update_node_times(context, path, fileNode, { ctime: Date.now() }, update_directory_data);\n }\n });\n }\n }\n }\n\n function check_if_node_is_directory(error, result) {\n if(error) {\n callback(error);\n } else if(result.type === NODE_TYPE_DIRECTORY) {\n callback(new Errors.EPERM('unlink not permitted on directories', name));\n } else {\n update_file_node(null, result);\n }\n }\n\n function check_if_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(!_(directoryData).has(name)) {\n callback(new Errors.ENOENT('a component of the path does not name an existing file', name));\n } else {\n context.getObject(directoryData[name].id, check_if_node_is_directory);\n }\n }\n }\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_file_exists);\n }\n }\n\n find_node(context, parentPath, read_directory_data);\n}\n\nfunction read_directory(context, path, callback) {\n path = normalize(path);\n\n var directoryNode;\n var directoryData;\n\n function handle_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n var files = Object.keys(directoryData);\n callback(null, files);\n }\n }\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else if(result.type !== NODE_TYPE_DIRECTORY) {\n callback(new Errors.ENOTDIR(null, path));\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, handle_directory_data);\n }\n }\n\n find_node(context, path, read_directory_data);\n}\n\nfunction make_symbolic_link(context, srcpath, dstpath, callback) {\n dstpath = normalize(dstpath);\n var name = basename(dstpath);\n var parentPath = dirname(dstpath);\n\n var directoryNode;\n var directoryData;\n var fileNode;\n\n if(ROOT_DIRECTORY_NAME === name) {\n callback(new Errors.EEXIST(null, name));\n } else {\n find_node(context, parentPath, read_directory_data);\n }\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_file_exists);\n }\n }\n\n function check_if_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(_(directoryData).has(name)) {\n callback(new Errors.EEXIST(null, name));\n } else {\n write_file_node();\n }\n }\n }\n\n function write_file_node() {\n Node.create({\n guid: context.guid,\n type: NODE_TYPE_SYMBOLIC_LINK\n }, function(error, result) {\n if(error) {\n callback(error);\n return;\n }\n fileNode = result;\n fileNode.nlinks += 1;\n\n // If the srcpath isn't absolute, resolve it relative to the dstpath\n // but store both versions, since we'll use the relative one in readlink().\n if(!isAbsolutePath(srcpath)) {\n fileNode.symlink_relpath = srcpath;\n srcpath = Path.resolve(parentPath, srcpath); \n }\n\n fileNode.size = srcpath.length;\n fileNode.data = srcpath;\n \n context.putObject(fileNode.id, fileNode, update_directory_data);\n });\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, parentPath, directoryNode, { mtime: now, ctime: now }, callback);\n }\n }\n\n function update_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n directoryData[name] = new DirectoryEntry(fileNode.id, NODE_TYPE_SYMBOLIC_LINK);\n context.putObject(directoryNode.data, directoryData, update_time);\n }\n }\n}\n\nfunction read_link(context, path, callback) {\n path = normalize(path);\n var name = basename(path);\n var parentPath = dirname(path);\n\n var directoryNode;\n var directoryData;\n\n find_node(context, parentPath, read_directory_data);\n\n function read_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryNode = result;\n context.getObject(directoryNode.data, check_if_file_exists);\n }\n }\n\n function check_if_file_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n directoryData = result;\n if(!_(directoryData).has(name)) {\n callback(new Errors.ENOENT('a component of the path does not name an existing file', name));\n } else {\n context.getObject(directoryData[name].id, check_if_symbolic);\n }\n }\n }\n\n function check_if_symbolic(error, fileNode) {\n if(error) {\n callback(error);\n } else {\n if(fileNode.type !== NODE_TYPE_SYMBOLIC_LINK) {\n callback(new Errors.EINVAL('path not a symbolic link', path));\n } else {\n // If we were originally given a relative path, return that now vs. the\n // absolute path we've generated and use elsewhere internally.\n var target = fileNode.symlink_relpath ? fileNode.symlink_relpath : fileNode.data;\n callback(null, target);\n }\n }\n }\n}\n\nfunction truncate_file(context, path, length, callback) {\n path = normalize(path);\n\n var fileNode;\n\n function read_file_data (error, node) {\n if (error) {\n callback(error);\n } else if(node.type === NODE_TYPE_DIRECTORY ) {\n callback(new Errors.EISDIR(null, path));\n } else{\n fileNode = node;\n context.getBuffer(fileNode.data, truncate_file_data);\n }\n }\n\n function truncate_file_data(error, fileData) {\n if (error) {\n callback(error);\n } else {\n if(!fileData) {\n return callback(new Errors.EIO('Expected Buffer'));\n }\n try {\n validateInteger(length, 'len');\n }\n catch (error) {\n return callback(error);\n }\n var data = new Buffer(length);\n data.fill(0);\n if(fileData) {\n fileData.copy(data);\n }\n context.putBuffer(fileNode.data, data, update_file_node);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, path, fileNode, { mtime: now, ctime: now }, callback);\n }\n }\n\n function update_file_node (error) {\n if(error) {\n callback(error);\n } else {\n fileNode.size = length;\n fileNode.version += 1;\n context.putObject(fileNode.id, fileNode, update_time);\n }\n }\n\n if(length < 0) {\n callback(new Errors.EINVAL('length cannot be negative'));\n } else {\n find_node(context, path, read_file_data);\n }\n}\n\nfunction ftruncate_file(context, ofd, length, callback) {\n var fileNode;\n\n function read_file_data (error, node) {\n if (error) {\n callback(error);\n } else if(node.type === NODE_TYPE_DIRECTORY ) {\n callback(new Errors.EISDIR());\n } else{\n fileNode = node;\n context.getBuffer(fileNode.data, truncate_file_data);\n }\n }\n\n function truncate_file_data(error, fileData) {\n if (error) {\n callback(error);\n } else {\n var data;\n if(!fileData) {\n return callback(new Errors.EIO('Expected Buffer'));\n }\n if(fileData) {\n data = fileData.slice(0, length);\n } else {\n data = new Buffer(length);\n data.fill(0);\n }\n context.putBuffer(fileNode.data, data, update_file_node);\n }\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n var now = Date.now();\n update_node_times(context, ofd.path, fileNode, { mtime: now, ctime: now }, callback);\n }\n }\n\n function update_file_node (error) {\n if(error) {\n callback(error);\n } else {\n fileNode.size = length;\n fileNode.version += 1;\n context.putObject(fileNode.id, fileNode, update_time);\n }\n }\n\n if(length < 0) {\n callback(new Errors.EINVAL('length cannot be negative'));\n } else {\n ofd.getNode(context, read_file_data);\n }\n}\n\nfunction utimes_file(context, path, atime, mtime, callback) {\n path = normalize(path);\n\n function update_times(error, node) {\n if (error) {\n callback(error);\n } else {\n update_node_times(context, path, node, { atime: atime, ctime: mtime, mtime: mtime }, callback);\n }\n }\n\n if (typeof atime !== 'number' || typeof mtime !== 'number') {\n callback(new Errors.EINVAL('atime and mtime must be number', path));\n }\n else if (atime < 0 || mtime < 0) {\n callback(new Errors.EINVAL('atime and mtime must be positive integers', path));\n }\n else {\n find_node(context, path, update_times);\n }\n}\n\nfunction futimes_file(context, ofd, atime, mtime, callback) {\n\n function update_times (error, node) {\n if (error) {\n callback(error);\n } else {\n update_node_times(context, ofd.path, node, { atime: atime, ctime: mtime, mtime: mtime }, callback);\n }\n }\n\n if (typeof atime !== 'number' || typeof mtime !== 'number') {\n callback(new Errors.EINVAL('atime and mtime must be a number'));\n }\n else if (atime < 0 || mtime < 0) {\n callback(new Errors.EINVAL('atime and mtime must be positive integers'));\n }\n else {\n ofd.getNode(context, update_times);\n }\n}\n\nfunction setxattr_file(context, path, name, value, flag, callback) {\n path = normalize(path);\n\n function setxattr(error, node) {\n if(error) {\n return callback(error);\n }\n set_extended_attribute(context, path, node, name, value, flag, callback);\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL('attribute name must be a string', path));\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string', path));\n }\n else if (flag !== null &&\n flag !== XATTR_CREATE && flag !== XATTR_REPLACE) {\n callback(new Errors.EINVAL('invalid flag, must be null, XATTR_CREATE or XATTR_REPLACE', path));\n }\n else {\n find_node(context, path, setxattr);\n }\n}\n\nfunction fsetxattr_file (context, ofd, name, value, flag, callback) {\n function setxattr(error, node) {\n if(error) {\n return callback(error);\n }\n set_extended_attribute(context, ofd.path, node, name, value, flag, callback);\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL('attribute name must be a string'));\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string'));\n }\n else if (flag !== null &&\n flag !== XATTR_CREATE && flag !== XATTR_REPLACE) {\n callback(new Errors.EINVAL('invalid flag, must be null, XATTR_CREATE or XATTR_REPLACE'));\n }\n else {\n ofd.getNode(context, setxattr);\n }\n}\n\nfunction getxattr_file (context, path, name, callback) {\n path = normalize(path);\n\n function get_xattr(error, node) {\n if(error) {\n return callback(error);\n }\n\n var xattrs = node.xattrs;\n\n if (!xattrs.hasOwnProperty(name)) {\n callback(new Errors.ENOATTR(null, path));\n }\n else {\n callback(null, xattrs[name]);\n }\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL('attribute name must be a string', path));\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string', path));\n }\n else {\n find_node(context, path, get_xattr);\n }\n}\n\nfunction fgetxattr_file (context, ofd, name, callback) {\n\n function get_xattr (error, node) {\n if (error) {\n return callback(error);\n }\n\n var xattrs = node.xattrs;\n\n if (!xattrs.hasOwnProperty(name)) {\n callback(new Errors.ENOATTR());\n }\n else {\n callback(null, xattrs[name]);\n }\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL());\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string'));\n }\n else {\n ofd.getNode(context, get_xattr);\n }\n}\n\nfunction removexattr_file (context, path, name, callback) {\n path = normalize(path);\n\n function remove_xattr (error, node) {\n if (error) {\n return callback(error);\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n update_node_times(context, path, node, { ctime: Date.now() }, callback);\n }\n }\n\n var xattrs = node.xattrs;\n\n if (!xattrs.hasOwnProperty(name)) {\n callback(new Errors.ENOATTR(null, path));\n }\n else {\n delete xattrs[name];\n context.putObject(node.id, node, update_time);\n }\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL('attribute name must be a string', path));\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string', path));\n }\n else {\n find_node(context, path, remove_xattr);\n }\n}\n\nfunction fremovexattr_file (context, ofd, name, callback) {\n\n function remove_xattr (error, node) {\n if (error) {\n return callback(error);\n }\n\n function update_time(error) {\n if(error) {\n callback(error);\n } else {\n update_node_times(context, ofd.path, node, { ctime: Date.now() }, callback);\n }\n }\n\n var xattrs = node.xattrs;\n\n if (!xattrs.hasOwnProperty(name)) {\n callback(new Errors.ENOATTR());\n }\n else {\n delete xattrs[name];\n context.putObject(node.id, node, update_time);\n }\n }\n\n if (typeof name !== 'string') {\n callback(new Errors.EINVAL('attribute name must be a string'));\n }\n else if (!name) {\n callback(new Errors.EINVAL('attribute name cannot be an empty string'));\n }\n else {\n ofd.getNode(context, remove_xattr);\n }\n}\n\nfunction validate_flags(flags) {\n if(!_(O_FLAGS).has(flags)) {\n return null;\n }\n return O_FLAGS[flags];\n}\n\nfunction validate_file_options(options, enc, fileMode){\n if(!options) {\n options = { encoding: enc, flag: fileMode };\n } else if(typeof options === 'function') {\n options = { encoding: enc, flag: fileMode };\n } else if(typeof options === 'string') {\n options = { encoding: options, flag: fileMode };\n }\n return options;\n}\n\nfunction pathCheck(path, allowRelative, callback) {\n var err;\n\n if(typeof allowRelative === 'function') {\n callback = allowRelative;\n allowRelative = false;\n }\n\n if(!path) {\n err = new Errors.EINVAL('Path must be a string', path);\n } else if(isNullPath(path)) {\n err = new Errors.EINVAL('Path must be a string without null bytes.', path);\n } else if(!allowRelative && !isAbsolutePath(path)) {\n err = new Errors.EINVAL('Path must be absolute.', path);\n }\n\n if(err) {\n callback(err);\n return false;\n }\n return true;\n}\n\n\nfunction open(fs, context, path, flags, mode, callback) {\n /**\n * NOTE: we support the same signature as node with a `mode` arg,\n * but ignore it. We need to add it. Here is what node.js does:\n * function open(path, flags, mode, callback) {\n * path = getPathFromURL(path);\n * validatePath(path);\n * const flagsNumber = stringToFlags(flags);\n * if (arguments.length < 4) {\n * callback = makeCallback(mode);\n * mode = 0o666;\n * } else {\n * mode = validateAndMaskMode(mode, 'mode', 0o666);\n * callback = makeCallback(callback);\n * }\n */\n\n callback = arguments[arguments.length - 1];\n if(!pathCheck(path, callback)) return;\n\n function check_result(error, fileNode) {\n if(error) {\n callback(error);\n } else {\n var position;\n if(_(flags).contains(O_APPEND)) {\n position = fileNode.size;\n } else {\n position = 0;\n }\n var openFileDescription = new OpenFileDescription(path, fileNode.id, flags, position);\n var fd = fs.allocDescriptor(openFileDescription);\n callback(null, fd);\n }\n }\n\n flags = validate_flags(flags);\n if(!flags) {\n callback(new Errors.EINVAL('flags is not valid'), path);\n }\n\n open_file(context, path, flags, check_result);\n}\n\nfunction close(fs, context, fd, callback) {\n if(!_(fs.openFiles).has(fd)) {\n callback(new Errors.EBADF());\n } else {\n fs.releaseDescriptor(fd);\n callback(null);\n }\n}\n\nfunction mknod(fs, context, path, type, callback) {\n if(!pathCheck(path, callback)) return;\n make_node(context, path, type, callback);\n}\n\nfunction mkdir(fs, context, path, mode, callback) {\n if (arguments.length < 5) {\n callback = mode;\n mode = FULL_READ_WRITE_EXEC_PERMISSIONS;\n } else {\n mode = validateAndMaskMode(mode, FULL_READ_WRITE_EXEC_PERMISSIONS, callback);\n if(!mode) return;\n }\n \n if(!pathCheck(path, callback)) return;\n make_directory(context, path, callback);\n}\n\nfunction rmdir(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n remove_directory(context, path, callback);\n}\n\nfunction stat(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n\n function check_result(error, result) {\n if(error) {\n callback(error);\n } else {\n var stats = new Stats(path, result, fs.name);\n callback(null, stats);\n }\n }\n\n stat_file(context, path, check_result);\n}\n\nfunction fstat(fs, context, fd, callback) {\n function check_result(error, result) {\n if(error) {\n callback(error);\n } else {\n var stats = new Stats(ofd.path, result, fs.name);\n callback(null, stats);\n }\n }\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else {\n fstat_file(context, ofd, check_result);\n }\n}\n\nfunction link(fs, context, oldpath, newpath, callback) {\n if(!pathCheck(oldpath, callback)) return;\n if(!pathCheck(newpath, callback)) return;\n link_node(context, oldpath, newpath, callback);\n}\n\nfunction unlink(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n unlink_node(context, path, callback);\n}\n\nfunction read(fs, context, fd, buffer, offset, length, position, callback) {\n // Follow how node.js does this\n function wrapped_cb(err, bytesRead) {\n // Retain a reference to buffer so that it can't be GC'ed too soon.\n callback(err, bytesRead || 0, buffer);\n }\n\n offset = (undefined === offset) ? 0 : offset;\n length = (undefined === length) ? buffer.length - offset : length;\n callback = arguments[arguments.length - 1];\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_READ)) {\n callback(new Errors.EBADF('descriptor does not permit reading'));\n } else {\n read_data(context, ofd, buffer, offset, length, position, wrapped_cb);\n }\n}\n\nfunction readFile(fs, context, path, options, callback) {\n callback = arguments[arguments.length - 1];\n options = validate_file_options(options, null, 'r');\n\n if(!pathCheck(path, callback)) return;\n\n var flags = validate_flags(options.flag || 'r');\n if(!flags) {\n return callback(new Errors.EINVAL('flags is not valid', path));\n }\n\n open_file(context, path, flags, function(err, fileNode) {\n if(err) {\n return callback(err);\n }\n var ofd = new OpenFileDescription(path, fileNode.id, flags, 0);\n var fd = fs.allocDescriptor(ofd);\n\n function cleanup() {\n fs.releaseDescriptor(fd);\n }\n\n fstat_file(context, ofd, function(err, fstatResult) {\n if(err) {\n cleanup();\n return callback(err);\n }\n\n var stats = new Stats(ofd.path, fstatResult, fs.name);\n\n if(stats.isDirectory()) {\n cleanup();\n return callback(new Errors.EISDIR('illegal operation on directory', path));\n }\n\n var size = stats.size;\n var buffer = new Buffer(size);\n buffer.fill(0);\n\n read_data(context, ofd, buffer, 0, size, 0, function(err) {\n cleanup();\n\n if(err) {\n return callback(err);\n }\n\n var data;\n if(options.encoding === 'utf8') {\n data = Encoding.decode(buffer);\n } else {\n data = buffer;\n }\n callback(null, data);\n });\n });\n });\n}\n\nfunction write(fs, context, fd, buffer, offset, length, position, callback) {\n callback = arguments[arguments.length - 1];\n offset = (undefined === offset) ? 0 : offset;\n length = (undefined === length) ? buffer.length - offset : length;\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n } else if(buffer.length - offset < length) {\n callback(new Errors.EIO('intput buffer is too small'));\n } else {\n write_data(context, ofd, buffer, offset, length, position, callback);\n }\n}\n\nfunction writeFile(fs, context, path, data, options, callback) {\n callback = arguments[arguments.length - 1];\n options = validate_file_options(options, 'utf8', 'w');\n\n if(!pathCheck(path, callback)) return;\n\n var flags = validate_flags(options.flag || 'w');\n if(!flags) {\n return callback(new Errors.EINVAL('flags is not valid', path));\n }\n\n data = data || '';\n if(typeof data === 'number') {\n data = '' + data;\n }\n if(typeof data === 'string' && options.encoding === 'utf8') {\n data = Encoding.encode(data);\n }\n\n open_file(context, path, flags, function(err, fileNode) {\n if(err) {\n return callback(err);\n }\n var ofd = new OpenFileDescription(path, fileNode.id, flags, 0);\n var fd = fs.allocDescriptor(ofd);\n\n replace_data(context, ofd, data, 0, data.length, function(err) {\n fs.releaseDescriptor(fd);\n\n if(err) {\n return callback(err);\n }\n callback(null);\n });\n });\n}\n\nfunction appendFile(fs, context, path, data, options, callback) {\n callback = arguments[arguments.length - 1];\n options = validate_file_options(options, 'utf8', 'a');\n\n if(!pathCheck(path, callback)) return;\n\n var flags = validate_flags(options.flag || 'a');\n if(!flags) {\n return callback(new Errors.EINVAL('flags is not valid', path));\n }\n\n data = data || '';\n if(typeof data === 'number') {\n data = '' + data;\n }\n if(typeof data === 'string' && options.encoding === 'utf8') {\n data = Encoding.encode(data);\n }\n\n open_file(context, path, flags, function(err, fileNode) {\n if(err) {\n return callback(err);\n }\n var ofd = new OpenFileDescription(path, fileNode.id, flags, fileNode.size);\n var fd = fs.allocDescriptor(ofd);\n\n write_data(context, ofd, data, 0, data.length, ofd.position, function(err) {\n fs.releaseDescriptor(fd);\n\n if(err) {\n return callback(err);\n }\n callback(null);\n });\n });\n}\n\nfunction exists(fs, context, path, callback) {\n function cb(err) {\n callback(err ? false : true);\n }\n console.warn('This method is deprecated. For more details see https://nodejs.org/api/fs.html#fs_fs_exists_path_callback');// eslint-disable-line no-console\n stat(fs, context, path, cb);\n}\n\n// Based on https://github.com/nodejs/node/blob/c700cc42da9cf73af9fec2098520a6c0a631d901/lib/internal/validators.js#L21\nvar octalReg = /^[0-7]+$/;\nfunction isUint32(value) {\n return value === (value >>> 0);\n}\n// Validator for mode_t (the S_* constants). Valid numbers or octal strings\n// will be masked with 0o777 to be consistent with the behavior in POSIX APIs.\nfunction validateAndMaskMode(value, def, callback) {\n if(typeof def === 'function') {\n callback = def;\n def = undefined;\n }\n\n if (isUint32(value)) {\n return value & FULL_READ_WRITE_EXEC_PERMISSIONS;\n }\n\n if (typeof value === 'number') {\n if (!Number.isInteger(value)) {\n callback(new Errors.EINVAL('mode not a valid an integer value', value));\n return false;\n } else {\n // 2 ** 32 === 4294967296\n callback(new Errors.EINVAL('mode not a valid an integer value', value));\n return false;\n }\n }\n\n if (typeof value === 'string') {\n if (!octalReg.test(value)) {\n callback(new Errors.EINVAL('mode not a valid octal string', value));\n return false;\n }\n var parsed = parseInt(value, 8);\n return parsed & FULL_READ_WRITE_EXEC_PERMISSIONS;\n }\n\n // TODO(BridgeAR): Only return `def` in case `value === null`\n if (def !== undefined) {\n return def;\n }\n\n callback(new Errors.EINVAL('mode not valid', value));\n return false;\n}\n\nfunction chmod_file(context, path, mode, callback) {\n path = normalize(path);\n\n function update_mode(error, node) {\n if (error) {\n callback(error);\n } else {\n Node.setMode(mode, node);\n update_node_times(context, path, node, { mtime: Date.now() }, callback);\n }\n }\n\n if (typeof mode !== 'number') {\n callback(new Errors.EINVAL('mode must be number', path));\n }\n else {\n find_node(context, path, update_mode);\n }\n}\n\nfunction fchmod_file(context, ofd, mode, callback) {\n function update_mode(error, node) {\n if (error) {\n callback(error);\n } else {\n node.mode = mode;\n update_node_times(context, ofd.path, node, { mtime: Date.now() }, callback);\n }\n }\n\n if (typeof mode !== 'number') {\n callback(new Errors.EINVAL('mode must be a number'));\n }\n else {\n ofd.getNode(context, update_mode);\n }\n}\n\nfunction chown_file(context, path, uid, gid, callback) {\n path = normalize(path);\n\n function update_owner(error, node) {\n if (error) {\n callback(error);\n } else {\n node.uid = uid;\n node.gid = gid;\n update_node_times(context, path, node, { mtime: Date.now() }, callback);\n }\n }\n\n find_node(context, path, update_owner);\n}\n\nfunction fchown_file(context, ofd, uid, gid, callback) {\n function update_owner(error, node) {\n if (error) {\n callback(error);\n } else {\n node.uid = uid;\n node.gid = gid;\n update_node_times(context, ofd.path, node, { mtime: Date.now() }, callback);\n }\n }\n\n ofd.getNode(context, update_owner);\n}\n\nfunction getxattr(fs, context, path, name, callback) {\n if (!pathCheck(path, callback)) return;\n getxattr_file(context, path, name, callback);\n}\n\nfunction fgetxattr(fs, context, fd, name, callback) {\n var ofd = fs.openFiles[fd];\n if (!ofd) {\n callback(new Errors.EBADF());\n }\n else {\n fgetxattr_file(context, ofd, name, callback);\n }\n}\n\nfunction setxattr(fs, context, path, name, value, flag, callback) {\n if(typeof flag === 'function') {\n callback = flag;\n flag = null;\n }\n\n if (!pathCheck(path, callback)) return;\n setxattr_file(context, path, name, value, flag, callback);\n}\n\nfunction fsetxattr(fs, context, fd, name, value, flag, callback) {\n if(typeof flag === 'function') {\n callback = flag;\n flag = null;\n }\n\n var ofd = fs.openFiles[fd];\n if (!ofd) {\n callback(new Errors.EBADF());\n }\n else if (!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n }\n else {\n fsetxattr_file(context, ofd, name, value, flag, callback);\n }\n}\n\nfunction removexattr(fs, context, path, name, callback) {\n if (!pathCheck(path, callback)) return;\n removexattr_file(context, path, name, callback);\n}\n\nfunction fremovexattr(fs, context, fd, name, callback) {\n var ofd = fs.openFiles[fd];\n if (!ofd) {\n callback(new Errors.EBADF());\n }\n else if (!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n }\n else {\n fremovexattr_file(context, ofd, name, callback);\n }\n}\n\nfunction lseek(fs, context, fd, offset, whence, callback) {\n function update_descriptor_position(error, stats) {\n if(error) {\n callback(error);\n } else {\n if(stats.size + offset < 0) {\n callback(new Errors.EINVAL('resulting file offset would be negative'));\n } else {\n ofd.position = stats.size + offset;\n callback(null, ofd.position);\n }\n }\n }\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n }\n\n if('SET' === whence) {\n if(offset < 0) {\n callback(new Errors.EINVAL('resulting file offset would be negative'));\n } else {\n ofd.position = offset;\n callback(null, ofd.position);\n }\n } else if('CUR' === whence) {\n if(ofd.position + offset < 0) {\n callback(new Errors.EINVAL('resulting file offset would be negative'));\n } else {\n ofd.position += offset;\n callback(null, ofd.position);\n }\n } else if('END' === whence) {\n fstat_file(context, ofd, update_descriptor_position);\n } else {\n callback(new Errors.EINVAL('whence argument is not a proper value'));\n }\n}\n\nfunction readdir(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n read_directory(context, path, callback);\n}\n\nfunction utimes(fs, context, path, atime, mtime, callback) {\n if(!pathCheck(path, callback)) return;\n\n var currentTime = Date.now();\n atime = (atime) ? atime : currentTime;\n mtime = (mtime) ? mtime : currentTime;\n\n utimes_file(context, path, atime, mtime, callback);\n}\n\nfunction futimes(fs, context, fd, atime, mtime, callback) {\n var currentTime = Date.now();\n atime = (atime) ? atime : currentTime;\n mtime = (mtime) ? mtime : currentTime;\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n } else {\n futimes_file(context, ofd, atime, mtime, callback);\n }\n}\n\nfunction chmod(fs, context, path, mode, callback) {\n if(!pathCheck(path, callback)) return;\n mode = validateAndMaskMode(mode, 'mode');\n if(!mode) return;\n\n chmod_file(context, path, mode, callback);\n}\n\nfunction fchmod(fs, context, fd, mode, callback) {\n mode = validateAndMaskMode(mode, 'mode');\n if(!mode) return;\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n } else {\n fchmod_file(context, ofd, mode, callback);\n }\n}\n\nfunction chown(fs, context, path, uid, gid, callback) {\n if(!pathCheck(path, callback)) return;\n if(!isUint32(uid)) {\n return callback(new Errors.EINVAL('uid must be a valid integer', uid));\n }\n if(!isUint32(gid)) {\n return callback(new Errors.EINVAL('gid must be a valid integer', gid));\n }\n\n chown_file(context, path, uid, gid, callback);\n}\n\nfunction fchown(fs, context, fd, uid, gid, callback) {\n if(!isUint32(uid)) {\n return callback(new Errors.EINVAL('uid must be a valid integer', uid));\n }\n if(!isUint32(gid)) {\n return callback(new Errors.EINVAL('gid must be a valid integer', gid));\n }\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n } else {\n fchown_file(context, ofd, uid, gid, callback);\n }\n}\n\nfunction rename(fs, context, oldpath, newpath, callback) {\n if(!pathCheck(oldpath, callback)) return;\n if(!pathCheck(newpath, callback)) return;\n\n oldpath = normalize(oldpath);\n newpath = normalize(newpath);\n\n var oldParentPath = Path.dirname(oldpath);\n var newParentPath = Path.dirname(oldpath);\n var oldName = Path.basename(oldpath);\n var newName = Path.basename(newpath);\n var oldParentDirectory, oldParentData;\n var newParentDirectory, newParentData;\n var ctime = Date.now();\n var fileNode;\n\n function update_times(error, result) {\n if(error) {\n callback(error);\n } else {\n fileNode = result;\n update_node_times(context, newpath, fileNode, { ctime: ctime }, callback);\n }\n }\n\n function read_new_directory(error) {\n if(error) {\n callback(error);\n } else {\n context.getObject(newParentData[newName].id, update_times);\n }\n }\n\n function update_old_parent_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n if(oldParentDirectory.id === newParentDirectory.id) {\n oldParentData = newParentData;\n }\n delete oldParentData[oldName];\n context.putObject(oldParentDirectory.data, oldParentData, read_new_directory);\n }\n }\n\n function update_new_parent_directory_data(error) {\n if(error) {\n callback(error);\n } else {\n newParentData[newName] = oldParentData[oldName];\n context.putObject(newParentDirectory.data, newParentData, update_old_parent_directory_data);\n }\n }\n\n function check_if_new_directory_exists(error, result) {\n if(error) {\n callback(error);\n } else {\n newParentData = result;\n if(_(newParentData).has(newName)) {\n remove_directory(context, newpath, update_new_parent_directory_data);\n } else {\n update_new_parent_directory_data();\n }\n }\n }\n\n function read_new_parent_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n newParentDirectory = result;\n context.getObject(newParentDirectory.data, check_if_new_directory_exists);\n }\n }\n\n function get_new_parent_directory(error, result) {\n if(error) {\n callback(error);\n } else {\n oldParentData = result;\n find_node(context, newParentPath, read_new_parent_directory_data);\n }\n }\n\n function read_parent_directory_data(error, result) {\n if(error) {\n callback(error);\n } else {\n oldParentDirectory = result;\n context.getObject(result.data, get_new_parent_directory);\n }\n }\n\n function unlink_old_file(error) {\n if(error) {\n callback(error);\n } else {\n unlink_node(context, oldpath, callback);\n }\n }\n\n function check_node_type(error, node) {\n if(error) {\n callback(error);\n } else if(node.type === NODE_TYPE_DIRECTORY) {\n find_node(context, oldParentPath, read_parent_directory_data);\n } else {\n link_node(context, oldpath, newpath, unlink_old_file);\n }\n }\n\n find_node(context, oldpath, check_node_type);\n}\n\nfunction symlink(fs, context, srcpath, dstpath, type, callback) {\n // NOTE: we support passing the `type` arg, but ignore it.\n callback = arguments[arguments.length - 1];\n\n // Special Case: allow srcpath to be relative, which we normally don't permit.\n // If the srcpath is relative, we assume it's relative to the dirpath of \n // dstpath.\n if(!pathCheck(srcpath, true, callback)) return;\n if(!pathCheck(dstpath, callback)) return;\n\n make_symbolic_link(context, srcpath, dstpath, callback);\n}\n\nfunction readlink(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n read_link(context, path, callback);\n}\n\nfunction lstat(fs, context, path, callback) {\n if(!pathCheck(path, callback)) return;\n\n function check_result(error, result) {\n if(error) {\n callback(error);\n } else {\n var stats = new Stats(path, result, fs.name);\n callback(null, stats);\n }\n }\n\n lstat_file(context, path, check_result);\n}\n\nfunction truncate(fs, context, path, length, callback) {\n // NOTE: length is optional\n callback = arguments[arguments.length - 1];\n length = length || 0;\n\n if(!pathCheck(path, callback)) return;\n truncate_file(context, path, length, callback);\n}\n\nfunction ftruncate(fs, context, fd, length, callback) {\n // NOTE: length is optional\n callback = arguments[arguments.length - 1];\n length = length || 0;\n\n var ofd = fs.openFiles[fd];\n if(!ofd) {\n callback(new Errors.EBADF());\n } else if(!_(ofd.flags).contains(O_WRITE)) {\n callback(new Errors.EBADF('descriptor does not permit writing'));\n } else {\n ftruncate_file(context, ofd, length, callback);\n }\n}\n\nmodule.exports = {\n ensureRootDirectory: ensure_root_directory,\n open: open,\n chmod: chmod,\n fchmod: fchmod,\n chown: chown,\n fchown: fchown,\n close: close,\n mknod: mknod,\n mkdir: mkdir,\n rmdir: rmdir,\n unlink: unlink,\n stat: stat,\n fstat: fstat,\n link: link,\n read: read,\n readFile: readFile,\n write: write,\n writeFile: writeFile,\n appendFile: appendFile,\n exists: exists,\n getxattr: getxattr,\n fgetxattr: fgetxattr,\n setxattr: setxattr,\n fsetxattr: fsetxattr,\n removexattr: removexattr,\n fremovexattr: fremovexattr,\n lseek: lseek,\n readdir: readdir,\n utimes: utimes,\n futimes: futimes,\n rename: rename,\n symlink: symlink,\n readlink: readlink,\n lstat: lstat,\n truncate: truncate,\n ftruncate: ftruncate\n};\n","var _ = require('../../lib/nodash.js');\nvar { promisify } = require('es6-promisify');\n\nvar isNullPath = require('../path.js').isNull;\nvar nop = require('../shared.js').nop;\n\nvar Constants = require('../constants.js');\nvar FILE_SYSTEM_NAME = Constants.FILE_SYSTEM_NAME;\nvar FS_FORMAT = Constants.FS_FORMAT;\nvar FS_READY = Constants.FS_READY;\nvar FS_PENDING = Constants.FS_PENDING;\nvar FS_ERROR = Constants.FS_ERROR;\nvar FS_NODUPEIDCHECK = Constants.FS_NODUPEIDCHECK;\n\nvar providers = require('../providers/index.js');\n\nvar Shell = require('../shell/shell.js');\nvar Intercom = require('../../lib/intercom.js');\nvar FSWatcher = require('../fs-watcher.js');\nvar Errors = require('../errors.js');\nvar defaultGuidFn = require('../shared.js').guid;\n\nvar STDIN = Constants.STDIN;\nvar STDOUT = Constants.STDOUT;\nvar STDERR = Constants.STDERR;\nvar FIRST_DESCRIPTOR = Constants.FIRST_DESCRIPTOR;\n\n// The core fs operations live on impl\nvar impl = require('./implementation.js');\n\n// node.js supports a calling pattern that leaves off a callback.\nfunction maybeCallback(callback) {\n if(typeof callback === 'function') {\n return callback;\n }\n return function(err) {\n if(err) {\n throw err;\n }\n };\n}\n\n// Default callback that logs an error if passed in\nfunction defaultCallback(err) {\n if(err) {\n /* eslint no-console: 0 */\n console.error('Filer error: ', err);\n }\n}\n\n/**\n * FileSystem\n *\n * A FileSystem takes an `options` object, which can specify a number of,\n * options. All options are optional, and include:\n *\n * name: the name of the file system, defaults to \"local\"\n *\n * flags: one or more flags to use when creating/opening the file system.\n * For example: \"FORMAT\" will cause the file system to be formatted.\n * No explicit flags are set by default.\n *\n * provider: an explicit storage provider to use for the file\n * system's database context provider. A number of context\n * providers are included (see /src/providers), and users\n * can write one of their own and pass it in to be used.\n * By default an IndexedDB provider is used.\n *\n * guid: a function for generating unique IDs for nodes in the filesystem.\n * Use this to override the built-in UUID generation. (Used mainly for tests).\n *\n * callback: a callback function to be executed when the file system becomes\n * ready for use. Depending on the context provider used, this might\n * be right away, or could take some time. The callback should expect\n * an `error` argument, which will be null if everything worked. Also\n * users should check the file system's `readyState` and `error`\n * properties to make sure it is usable.\n */\nfunction FileSystem(options, callback) {\n options = options || {};\n callback = callback || defaultCallback;\n\n var flags = options.flags;\n var guid = options.guid ? options.guid : defaultGuidFn;\n var provider = options.provider || new providers.Default(options.name || FILE_SYSTEM_NAME);\n // If we're given a provider, match its name unless we get an explicit name\n var name = options.name || provider.name;\n var forceFormatting = _(flags).contains(FS_FORMAT);\n\n var fs = this;\n fs.readyState = FS_PENDING;\n fs.name = name;\n fs.error = null;\n\n fs.stdin = STDIN;\n fs.stdout = STDOUT;\n fs.stderr = STDERR;\n\n // Expose Node's fs.constants to users\n fs.constants = Constants.fsConstants;\n\n // Expose Shell constructor\n this.Shell = Shell.bind(undefined, this);\n\n // Safely expose the list of open files and file\n // descriptor management functions\n var openFiles = {};\n var nextDescriptor = FIRST_DESCRIPTOR;\n Object.defineProperty(this, 'openFiles', {\n get: function() { return openFiles; }\n });\n this.allocDescriptor = function(openFileDescription) {\n var fd = nextDescriptor ++;\n openFiles[fd] = openFileDescription;\n return fd;\n };\n this.releaseDescriptor = function(fd) {\n delete openFiles[fd];\n };\n\n // Safely expose the operation queue\n var queue = [];\n this.queueOrRun = function(operation) {\n var error;\n\n if(FS_READY == fs.readyState) {\n operation.call(fs);\n } else if(FS_ERROR == fs.readyState) {\n error = new Errors.EFILESYSTEMERROR('unknown error');\n } else {\n queue.push(operation);\n }\n\n return error;\n };\n function runQueued() {\n queue.forEach(function(operation) {\n operation.call(this);\n }.bind(fs));\n queue = null;\n }\n\n // We support the optional `options` arg from node, but ignore it\n this.watch = function(filename, options, listener) {\n if(isNullPath(filename)) {\n throw new Error('Path must be a string without null bytes.');\n }\n if(typeof options === 'function') {\n listener = options;\n options = {};\n }\n options = options || {};\n listener = listener || nop;\n\n var watcher = new FSWatcher();\n watcher.start(filename, false, options.recursive);\n watcher.on('change', listener);\n\n return watcher;\n };\n\n // Deal with various approaches to node ID creation\n function wrappedGuidFn(context) {\n return function(callback) {\n // Skip the duplicate ID check if asked to\n if(_(flags).contains(FS_NODUPEIDCHECK)) {\n callback(null, guid());\n return;\n }\n\n // Otherwise (default) make sure this id is unused first\n function guidWithCheck(callback) {\n var id = guid();\n context.getObject(id, function(err, value) {\n if(err) {\n callback(err);\n return;\n }\n\n // If this id is unused, use it, otherwise find another\n if(!value) {\n callback(null, id);\n } else {\n guidWithCheck(callback);\n }\n });\n }\n guidWithCheck(callback);\n };\n }\n\n // Let other instances (in this or other windows) know about\n // any changes to this fs instance.\n function broadcastChanges(changes) {\n if(!changes.length) {\n return;\n }\n var intercom = Intercom.getInstance();\n changes.forEach(function(change) {\n intercom.emit(change.event, change.path);\n });\n }\n\n // Open file system storage provider\n provider.open(function(err) {\n function complete(error) {\n function wrappedContext(methodName) {\n var context = provider[methodName]();\n context.flags = flags;\n context.changes = [];\n context.guid = wrappedGuidFn(context);\n\n // When the context is finished, let the fs deal with any change events\n context.close = function() {\n var changes = context.changes;\n broadcastChanges(changes);\n changes.length = 0;\n };\n\n return context;\n }\n\n // Wrap the provider so we can extend the context with fs flags and\n // an array of changes (e.g., watch event 'change' and 'rename' events\n // for paths updated during the lifetime of the context). From this\n // point forward we won't call open again, so it's safe to drop it.\n fs.provider = {\n openReadWriteContext: function() {\n return wrappedContext('getReadWriteContext');\n },\n openReadOnlyContext: function() {\n return wrappedContext('getReadOnlyContext');\n }\n };\n\n if(error) {\n fs.readyState = FS_ERROR;\n } else {\n fs.readyState = FS_READY;\n }\n runQueued();\n callback(error, fs);\n }\n\n if(err) {\n return complete(err);\n }\n\n var context = provider.getReadWriteContext();\n context.guid = wrappedGuidFn(context);\n\n // Mount the filesystem, formatting if necessary\n if(forceFormatting) {\n // Wipe the storage provider, then write root block\n context.clear(function(err) {\n if(err) {\n return complete(err);\n }\n impl.ensureRootDirectory(context, complete);\n });\n } else {\n // Use existing (or create new) root and mount\n impl.ensureRootDirectory(context, complete);\n }\n });\n FileSystem.prototype.promises = {};\n /**\n * Public API for FileSystem\n */\n [\n 'open',\n 'chmod',\n 'fchmod',\n 'chown',\n 'fchown',\n 'close',\n 'mknod',\n 'mkdir',\n 'rmdir',\n 'stat',\n 'fstat',\n 'link',\n 'unlink',\n 'read',\n 'readFile',\n 'write',\n 'writeFile',\n 'appendFile',\n 'exists',\n 'lseek',\n 'readdir',\n 'rename',\n 'readlink',\n 'symlink',\n 'lstat',\n 'truncate',\n 'ftruncate',\n 'utimes',\n 'futimes',\n 'setxattr',\n 'getxattr',\n 'fsetxattr',\n 'fgetxattr',\n 'removexattr',\n 'fremovexattr'\n ].forEach(function(methodName) {\n FileSystem.prototype[methodName] = function() {\n var fs = this;\n var args = Array.prototype.slice.call(arguments, 0);\n var lastArgIndex = args.length - 1;\n\n // We may or may not get a callback, and since node.js supports\n // fire-and-forget style fs operations, we have to dance a bit here.\n var missingCallback = typeof args[lastArgIndex] !== 'function';\n var callback = maybeCallback(args[lastArgIndex]);\n\n var error = fs.queueOrRun(function() {\n var context = fs.provider.openReadWriteContext();\n\n // Fail early if the filesystem is in an error state (e.g.,\n // provider failed to open.\n if(FS_ERROR === fs.readyState) {\n var err = new Errors.EFILESYSTEMERROR('filesystem unavailable, operation canceled');\n return callback.call(fs, err);\n }\n\n // Wrap the callback so we can explicitly close the context\n function complete() {\n context.close();\n callback.apply(fs, arguments);\n }\n\n // Either add or replace the callback with our wrapper complete()\n if(missingCallback) {\n args.push(complete);\n } else {\n args[lastArgIndex] = complete;\n }\n\n // Forward this call to the impl's version, using the following\n // call signature, with complete() as the callback/last-arg now:\n // fn(fs, context, arg0, arg1, ... , complete);\n var fnArgs = [fs, context].concat(args);\n impl[methodName].apply(null, fnArgs);\n });\n if(error) {\n callback(error);\n }\n };\n \n FileSystem.prototype.promises[methodName] = promisify(FileSystem.prototype[methodName].bind(fs));\n });\n\n}\n\n// Expose storage providers on FileSystem constructor\nFileSystem.providers = providers;\n\nmodule.exports = FileSystem;\n","module.exports = {\n FileSystem: require('./filesystem/interface.js'),\n Buffer: require('./buffer.js'),\n Path: require('./path.js'),\n Errors: require('./errors.js'),\n Shell: require('./shell/shell.js')\n};\n"]}