(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i 0) { setTimeout(deferredDelete, self.deleteInterval); } else { cleaning = false; } } setTimeout(deferredDelete, self.deleteInterval); }); }, removeCache: function removeCache(url) { if (this.cachedFiles.has(url)) { var self = this; var path = this.cachedFiles.remove(url).url; this.writeCacheFile(function () { if (self._isZipFile(url)) { rmdirSync(path, true); self._deleteFileCB(); } else { deleteFile(path, self._deleteFileCB.bind(self)); } }); } }, _deleteFileCB: function _deleteFileCB(err) { if (!err) this.outOfStorage = false; }, makeBundleFolder: function makeBundleFolder(bundleName) { makeDirSync(this.cacheDir + '/' + bundleName, true); }, unzipAndCacheBundle: function unzipAndCacheBundle(id, zipFilePath, cacheBundleRoot, onComplete) { var time = Date.now().toString(); var targetPath = "".concat(this.cacheDir, "/").concat(cacheBundleRoot, "/").concat(time).concat(suffix++); var self = this; makeDirSync(targetPath, true); unzip(zipFilePath, targetPath, function (err) { if (err) { rmdirSync(targetPath, true); if (isOutOfStorage(err.message)) { self.outOfStorage = true; self.autoClear && self.clearLRU(); } onComplete && onComplete(err); return; } self.cachedFiles.add(id, { bundle: cacheBundleRoot, url: targetPath, lastTime: time }); self.writeCacheFile(); onComplete && onComplete(null, targetPath); }); }, _isZipFile: function _isZipFile(url) { return url.slice(-4) === '.zip'; } }; cc.assetManager.cacheManager = module.exports = cacheManager; },{}],3:[function(require,module,exports){ "use strict"; var cacheManager = require('../cache-manager'); var _window$fsUtils = window.fsUtils, fs = _window$fsUtils.fs, downloadFile = _window$fsUtils.downloadFile, readText = _window$fsUtils.readText, readArrayBuffer = _window$fsUtils.readArrayBuffer, readJson = _window$fsUtils.readJson, loadSubpackage = _window$fsUtils.loadSubpackage, getUserDataPath = _window$fsUtils.getUserDataPath, exists = _window$fsUtils.exists; var REGEX = /^https?:\/\/.*/; var cachedSubpackageList = {}; var downloader = cc.assetManager.downloader; var parser = cc.assetManager.parser; var presets = cc.assetManager.presets; var isSubDomain = __globalAdapter.isSubContext; downloader.maxConcurrency = 8; downloader.maxRequestsPerFrame = 64; presets['scene'].maxConcurrency = 10; presets['scene'].maxRequestsPerFrame = 64; var SUBCONTEXT_ROOT, REMOTE_SERVER_ROOT; var subpackages = {}, remoteBundles = {}; function downloadScript(url, options, onComplete) { if (typeof options === 'function') { onComplete = options; options = null; } if (REGEX.test(url)) { onComplete && onComplete(new Error('Can not load remote scripts')); } else { __cocos_require__(url); onComplete && onComplete(null); } } function handleZip(url, options, onComplete) { var cachedUnzip = cacheManager.cachedFiles.get(url); if (cachedUnzip) { cacheManager.updateLastTime(url); onComplete && onComplete(null, cachedUnzip.url); } else if (REGEX.test(url)) { downloadFile(url, null, options.header, options.onFileProgress, function (err, downloadedZipPath) { if (err) { onComplete && onComplete(err); return; } cacheManager.unzipAndCacheBundle(url, downloadedZipPath, options.__cacheBundleRoot__, onComplete); }); } else { cacheManager.unzipAndCacheBundle(url, url, options.__cacheBundleRoot__, onComplete); } } function downloadDomAudio(url, options, onComplete) { if (typeof options === 'function') { onComplete = options; options = null; } var dom; var sys = cc.sys; if (sys.platform === sys.TAOBAO) { dom = window.document.createElement('audio'); } else { dom = document.createElement('audio'); } dom.src = url; // HACK: wechat does not callback when load large number of assets onComplete && onComplete(null, dom); } function download(url, func, options, onFileProgress, onComplete) { var result = transformUrl(url, options); if (result.inLocal) { func(result.url, options, onComplete); } else if (result.inCache) { cacheManager.updateLastTime(url); func(result.url, options, function (err, data) { if (err) { cacheManager.removeCache(url); } onComplete(err, data); }); } else { downloadFile(url, null, options.header, onFileProgress, function (err, path) { if (err) { onComplete(err, null); return; } func(path, options, function (err, data) { if (!err) { cacheManager.tempFiles.add(url, path); cacheManager.cacheFile(url, path, options.cacheEnabled, options.__cacheBundleRoot__, true); } onComplete(err, data); }); }); } } function parseArrayBuffer(url, options, onComplete) { readArrayBuffer(url, onComplete); } function parseText(url, options, onComplete) { readText(url, onComplete); } function parseJson(url, options, onComplete) { readJson(url, onComplete); } function downloadText(url, options, onComplete) { download(url, parseText, options, options.onFileProgress, onComplete); } var downloadJson = !isSubDomain ? function (url, options, onComplete) { download(url, parseJson, options, options.onFileProgress, onComplete); } : function (url, options, onComplete) { var _transformUrl = transformUrl(url, options), url = _transformUrl.url; url = url.slice(SUBCONTEXT_ROOT.length + 1); // remove subcontext root in url var content = __cocos_require__(cc.path.changeExtname(url, '.js')); onComplete && onComplete(null, content); }; var loadFont = !isSubDomain ? function (url, options, onComplete) { var fontFamily = __globalAdapter.loadFont(url); onComplete(null, fontFamily || 'Arial'); } : function (url, options, onComplete) { onComplete(null, 'Arial'); }; function doNothing(content, options, onComplete) { exists(content, function (existence) { if (existence) { onComplete(null, content); } else { onComplete(new Error("file ".concat(content, " does not exist!"))); } }); } function downloadAsset(url, options, onComplete) { download(url, doNothing, options, options.onFileProgress, onComplete); } function subdomainTransformUrl(url, options, onComplete) { var _transformUrl2 = transformUrl(url, options), url = _transformUrl2.url; onComplete(null, url); } function downloadBundle(nameOrUrl, options, onComplete) { var bundleName = cc.path.basename(nameOrUrl); var version = options.version || cc.assetManager.downloader.bundleVers[bundleName]; if (subpackages[bundleName]) { var config = "subpackages/".concat(bundleName, "/config.").concat(version ? version + '.' : '', "json"); var loadedCb = function loadedCb() { downloadJson(config, options, function (err, data) { data && (data.base = "subpackages/".concat(bundleName, "/")); onComplete(err, data); }); }; if (cachedSubpackageList[bundleName]) { return loadedCb(); } loadSubpackage(bundleName, options.onFileProgress, function (err) { if (err) { onComplete(err, null); return; } cachedSubpackageList[bundleName] = true; loadedCb(); }); } else { var js, url; if (REGEX.test(nameOrUrl) || !isSubDomain && nameOrUrl.startsWith(getUserDataPath())) { url = nameOrUrl; js = "src/scripts/".concat(bundleName, "/index.js"); cacheManager.makeBundleFolder(bundleName); } else { if (remoteBundles[bundleName]) { url = "".concat(REMOTE_SERVER_ROOT, "remote/").concat(bundleName); js = "src/scripts/".concat(bundleName, "/index.js"); cacheManager.makeBundleFolder(bundleName); } else { url = "assets/".concat(bundleName); js = "assets/".concat(bundleName, "/index.js"); } } __cocos_require__(js); options.__cacheBundleRoot__ = bundleName; var config = "".concat(url, "/config.").concat(version ? version + '.' : '', "json"); downloadJson(config, options, function (err, data) { if (err) { onComplete && onComplete(err); return; } if (data.isZip) { var zipVersion = data.zipVersion; var zipUrl = "".concat(url, "/res.").concat(zipVersion ? zipVersion + '.' : '', "zip"); handleZip(zipUrl, options, function (err, unzipPath) { if (err) { onComplete && onComplete(err); return; } data.base = unzipPath + '/res/'; // PATCH: for android alipay version before v10.1.95 (v10.1.95 included) // to remove in the future var sys = cc.sys; if (sys.platform === sys.ALIPAY_GAME && sys.os === sys.OS_ANDROID) { var resPath = unzipPath + 'res/'; if (fs.accessSync({ path: resPath })) { data.base = resPath; } } onComplete && onComplete(null, data); }); } else { data.base = url + '/'; onComplete && onComplete(null, data); } }); } } ; var originParsePVRTex = parser.parsePVRTex; var parsePVRTex = function parsePVRTex(file, options, onComplete) { readArrayBuffer(file, function (err, data) { if (err) return onComplete(err); originParsePVRTex(data, options, onComplete); }); }; var originParsePKMTex = parser.parsePKMTex; var parsePKMTex = function parsePKMTex(file, options, onComplete) { readArrayBuffer(file, function (err, data) { if (err) return onComplete(err); originParsePKMTex(data, options, onComplete); }); }; function parsePlist(url, options, onComplete) { readText(url, function (err, file) { var result = null; if (!err) { result = cc.plistParser.parse(file); if (!result) err = new Error('parse failed'); } onComplete && onComplete(err, result); }); } var downloadImage = isSubDomain ? subdomainTransformUrl : downloadAsset; downloader.downloadDomAudio = downloadDomAudio; downloader.downloadScript = downloadScript; parser.parsePVRTex = parsePVRTex; parser.parsePKMTex = parsePKMTex; downloader.register({ '.js': downloadScript, // Audio '.mp3': downloadAsset, '.ogg': downloadAsset, '.wav': downloadAsset, '.m4a': downloadAsset, // Image '.png': downloadImage, '.jpg': downloadImage, '.bmp': downloadImage, '.jpeg': downloadImage, '.gif': downloadImage, '.ico': downloadImage, '.tiff': downloadImage, '.image': downloadImage, '.webp': downloadImage, '.pvr': downloadAsset, '.pkm': downloadAsset, '.font': downloadAsset, '.eot': downloadAsset, '.ttf': downloadAsset, '.woff': downloadAsset, '.svg': downloadAsset, '.ttc': downloadAsset, // Txt '.txt': downloadAsset, '.xml': downloadAsset, '.vsh': downloadAsset, '.fsh': downloadAsset, '.atlas': downloadAsset, '.tmx': downloadAsset, '.tsx': downloadAsset, '.plist': downloadAsset, '.fnt': downloadAsset, '.json': downloadJson, '.ExportJson': downloadAsset, '.binary': downloadAsset, '.bin': downloadAsset, '.dbbin': downloadAsset, '.skel': downloadAsset, '.mp4': downloadAsset, '.avi': downloadAsset, '.mov': downloadAsset, '.mpg': downloadAsset, '.mpeg': downloadAsset, '.rm': downloadAsset, '.rmvb': downloadAsset, 'bundle': downloadBundle, 'default': downloadText }); parser.register({ '.png': downloader.downloadDomImage, '.jpg': downloader.downloadDomImage, '.bmp': downloader.downloadDomImage, '.jpeg': downloader.downloadDomImage, '.gif': downloader.downloadDomImage, '.ico': downloader.downloadDomImage, '.tiff': downloader.downloadDomImage, '.image': downloader.downloadDomImage, '.webp': downloader.downloadDomImage, '.pvr': parsePVRTex, '.pkm': parsePKMTex, '.font': loadFont, '.eot': loadFont, '.ttf': loadFont, '.woff': loadFont, '.svg': loadFont, '.ttc': loadFont, // Audio '.mp3': downloadDomAudio, '.ogg': downloadDomAudio, '.wav': downloadDomAudio, '.m4a': downloadDomAudio, // Txt '.txt': parseText, '.xml': parseText, '.vsh': parseText, '.fsh': parseText, '.atlas': parseText, '.tmx': parseText, '.tsx': parseText, '.fnt': parseText, '.plist': parsePlist, '.binary': parseArrayBuffer, '.bin': parseArrayBuffer, '.dbbin': parseArrayBuffer, '.skel': parseArrayBuffer, '.ExportJson': parseJson }); var transformUrl = !isSubDomain ? function (url, options) { var inLocal = false; var inCache = false; var isInUserDataPath = url.startsWith(getUserDataPath()); if (isInUserDataPath) { inLocal = true; } else if (REGEX.test(url)) { if (!options.reload) { var cache = cacheManager.cachedFiles.get(url); if (cache) { inCache = true; url = cache.url; } else { var tempUrl = cacheManager.tempFiles.get(url); if (tempUrl) { inLocal = true; url = tempUrl; } } } } else { inLocal = true; } return { url: url, inLocal: inLocal, inCache: inCache }; } : function (url, options) { if (!REGEX.test(url)) { url = SUBCONTEXT_ROOT + '/' + url; } return { url: url }; }; if (!isSubDomain) { cc.assetManager.transformPipeline.append(function (task) { var input = task.output = task.input; for (var i = 0, l = input.length; i < l; i++) { var item = input[i]; var options = item.options; if (!item.config) { if (item.ext === 'bundle') continue; options.cacheEnabled = options.cacheEnabled !== undefined ? options.cacheEnabled : false; } else { options.__cacheBundleRoot__ = item.config.name; } } }); var originInit = cc.assetManager.init; cc.assetManager.init = function (options) { originInit.call(cc.assetManager, options); options.subpackages && options.subpackages.forEach(function (x) { return subpackages[x] = 'subpackages/' + x; }); options.remoteBundles && options.remoteBundles.forEach(function (x) { return remoteBundles[x] = true; }); REMOTE_SERVER_ROOT = options.server || ''; if (REMOTE_SERVER_ROOT && !REMOTE_SERVER_ROOT.endsWith('/')) REMOTE_SERVER_ROOT += '/'; cacheManager.init(); }; } else { var originInit = cc.assetManager.init; cc.assetManager.init = function (options) { originInit.call(cc.assetManager, options); SUBCONTEXT_ROOT = options.subContextRoot || ''; }; } },{"../cache-manager":2}],4:[function(require,module,exports){ "use strict"; var Audio = cc._Audio; if (Audio) { var originGetDuration = Audio.prototype.getDuration; Object.assign(Audio.prototype, { _createElement: function _createElement() { var elem = this._src._nativeAsset; // Reuse dom audio element if (!this._element) { this._element = __globalAdapter.createInnerAudioContext(); } this._element.src = elem.src; }, destroy: function destroy() { if (this._element) { this._element.destroy(); this._element = null; } }, setCurrentTime: function setCurrentTime(num) { var self = this; this._src && this._src._ensureLoaded(function () { self._element.seek(num); }); }, stop: function stop() { var self = this; this._src && this._src._ensureLoaded(function () { // HACK: some platforms won't set currentTime to 0 when stop audio self._element.seek(0); self._element.stop(); self._unbindEnded(); self.emit('stop'); self._state = Audio.State.STOPPED; }); }, _bindEnded: function _bindEnded() { var elem = this._element; if (elem && elem.onEnded && !this._onended._binded) { this._onended._binded = true; elem.onEnded(this._onended); } }, _unbindEnded: function _unbindEnded() { var elem = this._element; if (elem && elem.offEnded && this._onended._binded) { this._onended._binded = false; elem.offEnded && elem.offEnded(this._onended); } }, getDuration: function getDuration() { var duration = originGetDuration.call(this); // HACK: in mini game, if dynamicly load audio, can't get duration from audioClip // because duration is not coming from audio deserialization duration = duration || (this._element ? this._element.duration : 0); return duration; }, // adapt some special operations on web platform _touchToPlay: function _touchToPlay() {}, _forceUpdatingState: function _forceUpdatingState() {} }); } },{}],5:[function(require,module,exports){ "use strict"; if (cc && cc.audioEngine) { cc.audioEngine._maxAudioInstance = 10; } },{}],6:[function(require,module,exports){ "use strict"; var inputManager = cc.internal.inputManager; var globalAdapter = window.__globalAdapter; Object.assign(inputManager, { setAccelerometerEnabled: function setAccelerometerEnabled(isEnable) { var scheduler = cc.director.getScheduler(); scheduler.enableForTarget(this); if (isEnable) { this._registerAccelerometerEvent(); scheduler.scheduleUpdate(this); } else { this._unregisterAccelerometerEvent(); scheduler.unscheduleUpdate(this); } }, // No need to adapt // setAccelerometerInterval (interval) { }, _registerAccelerometerEvent: function _registerAccelerometerEvent() { this._accelCurTime = 0; var self = this; this._acceleration = new cc.Acceleration(); globalAdapter.startAccelerometer(function (res) { self._acceleration.x = res.x; self._acceleration.y = res.y; self._acceleration.z = res.y; }); }, _unregisterAccelerometerEvent: function _unregisterAccelerometerEvent() { this._accelCurTime = 0; globalAdapter.stopAccelerometer(); } }); },{}],7:[function(require,module,exports){ "use strict"; (function () { if (!(cc && cc.EditBox)) { return; } var EditBox = cc.EditBox; var js = cc.js; var KeyboardReturnType = EditBox.KeyboardReturnType; var MAX_VALUE = 65535; var KEYBOARD_HIDE_TIME = 600; var _hideKeyboardTimeout = null; var _currentEditBoxImpl = null; function getKeyboardReturnType(type) { switch (type) { case KeyboardReturnType.DEFAULT: case KeyboardReturnType.DONE: return 'done'; case KeyboardReturnType.SEND: return 'send'; case KeyboardReturnType.SEARCH: return 'search'; case KeyboardReturnType.GO: return 'go'; case KeyboardReturnType.NEXT: return 'next'; } return 'done'; } var BaseClass = EditBox._ImplClass; function MiniGameEditBoxImpl() { BaseClass.call(this); this._eventListeners = { onKeyboardInput: null, onKeyboardConfirm: null, onKeyboardComplete: null }; } js.extend(MiniGameEditBoxImpl, BaseClass); EditBox._ImplClass = MiniGameEditBoxImpl; Object.assign(MiniGameEditBoxImpl.prototype, { init: function init(delegate) { if (!delegate) { cc.error('EditBox init failed'); return; } this._delegate = delegate; }, beginEditing: function beginEditing() { var _this = this; // In case multiply register events if (this._editing) { return; } this._ensureKeyboardHide(function () { var delegate = _this._delegate; _this._showKeyboard(); _this._registerKeyboardEvent(); _this._editing = true; _currentEditBoxImpl = _this; delegate.editBoxEditingDidBegan(); }); }, endEditing: function endEditing() { this._hideKeyboard(); var cbs = this._eventListeners; cbs.onKeyboardComplete && cbs.onKeyboardComplete(); }, _registerKeyboardEvent: function _registerKeyboardEvent() { var self = this; var delegate = this._delegate; var cbs = this._eventListeners; cbs.onKeyboardInput = function (res) { if (delegate._string !== res.value) { delegate.editBoxTextChanged(res.value); } }; cbs.onKeyboardConfirm = function (res) { delegate.editBoxEditingReturn(); var cbs = self._eventListeners; cbs.onKeyboardComplete && cbs.onKeyboardComplete(); }; cbs.onKeyboardComplete = function () { self._editing = false; _currentEditBoxImpl = null; self._unregisterKeyboardEvent(); delegate.editBoxEditingDidEnded(); }; __globalAdapter.onKeyboardInput(cbs.onKeyboardInput); __globalAdapter.onKeyboardConfirm(cbs.onKeyboardConfirm); __globalAdapter.onKeyboardComplete(cbs.onKeyboardComplete); }, _unregisterKeyboardEvent: function _unregisterKeyboardEvent() { var cbs = this._eventListeners; if (cbs.onKeyboardInput) { __globalAdapter.offKeyboardInput(cbs.onKeyboardInput); cbs.onKeyboardInput = null; } if (cbs.onKeyboardConfirm) { __globalAdapter.offKeyboardConfirm(cbs.onKeyboardConfirm); cbs.onKeyboardConfirm = null; } if (cbs.onKeyboardComplete) { __globalAdapter.offKeyboardComplete(cbs.onKeyboardComplete); cbs.onKeyboardComplete = null; } }, _otherEditing: function _otherEditing() { return !!_currentEditBoxImpl && _currentEditBoxImpl !== this && _currentEditBoxImpl._editing; }, _ensureKeyboardHide: function _ensureKeyboardHide(cb) { var otherEditing = this._otherEditing(); if (!otherEditing && !_hideKeyboardTimeout) { return cb(); } if (_hideKeyboardTimeout) { clearTimeout(_hideKeyboardTimeout); } if (otherEditing) { _currentEditBoxImpl.endEditing(); } _hideKeyboardTimeout = setTimeout(function () { _hideKeyboardTimeout = null; cb(); }, KEYBOARD_HIDE_TIME); }, _showKeyboard: function _showKeyboard() { var delegate = this._delegate; var multiline = delegate.inputMode === EditBox.InputMode.ANY; var maxLength = delegate.maxLength < 0 ? MAX_VALUE : delegate.maxLength; __globalAdapter.showKeyboard({ defaultValue: delegate._string, maxLength: maxLength, multiple: multiline, confirmHold: false, confirmType: getKeyboardReturnType(delegate.returnType), success: function success(res) {}, fail: function fail(res) { cc.warn(res.errMsg); } }); }, _hideKeyboard: function _hideKeyboard() { __globalAdapter.hideKeyboard({ success: function success(res) {}, fail: function fail(res) { cc.warn(res.errMsg); } }); } }); })(); },{}],8:[function(require,module,exports){ "use strict"; var inputManager = cc.internal.inputManager; var renderer = cc.renderer; var game = cc.game; var dynamicAtlasManager = cc.dynamicAtlasManager; var originRun = game.run; Object.assign(game, { _banRunningMainLoop: __globalAdapter.isSubContext, _firstSceneLaunched: false, run: function run() { var _this = this; cc.director.once(cc.Director.EVENT_AFTER_SCENE_LAUNCH, function () { _this._firstSceneLaunched = true; }); originRun.apply(this, arguments); }, setFrameRate: function setFrameRate(frameRate) { this.config.frameRate = frameRate; if (__globalAdapter.setPreferredFramesPerSecond) { __globalAdapter.setPreferredFramesPerSecond(frameRate); } else { if (this._intervalId) { window.cancelAnimFrame(this._intervalId); } this._intervalId = 0; this._paused = true; this._setAnimFrame(); this._runMainLoop(); } }, _runMainLoop: function _runMainLoop() { if (this._banRunningMainLoop) { return; } var self = this, _callback, config = self.config, director = cc.director, skip = true, frameRate = config.frameRate; cc.debug.setDisplayStats(config.showFPS); _callback = function callback() { if (!self._paused) { self._intervalId = window.requestAnimFrame(_callback); if (frameRate === 30 && !__globalAdapter.setPreferredFramesPerSecond) { skip = !skip; if (skip) { return; } } director.mainLoop(); } }; self._intervalId = window.requestAnimFrame(_callback); self._paused = false; }, _initRenderer: function _initRenderer() { // Avoid setup to be called twice. if (this._rendererInitialized) return; // frame and container are useless on minigame platform var sys = cc.sys; if (sys.platform === sys.TAOBAO) { this.frame = this.container = window.document.createElement("DIV"); } else { this.frame = this.container = document.createElement("DIV"); } var localCanvas; if (__globalAdapter.isSubContext) { localCanvas = window.sharedCanvas || __globalAdapter.getSharedCanvas(); } else if (sys.platform === sys.TAOBAO) { localCanvas = window.canvas; } else { localCanvas = canvas; } this.canvas = localCanvas; this._determineRenderType(); // WebGL context created successfully if (this.renderType === this.RENDER_TYPE_WEBGL) { var opts = { 'stencil': true, // MSAA is causing serious performance dropdown on some browsers. 'antialias': cc.macro.ENABLE_WEBGL_ANTIALIAS, 'alpha': cc.macro.ENABLE_TRANSPARENT_CANVAS, 'preserveDrawingBuffer': false }; renderer.initWebGL(localCanvas, opts); this._renderContext = renderer.device._gl; // Enable dynamic atlas manager by default if (!cc.macro.CLEANUP_IMAGE_CACHE && dynamicAtlasManager) { dynamicAtlasManager.enabled = true; } } if (!this._renderContext) { this.renderType = this.RENDER_TYPE_CANVAS; // Could be ignored by module settings renderer.initCanvas(localCanvas); this._renderContext = renderer.device._ctx; } this._rendererInitialized = true; }, _initEvents: function _initEvents() { // register system events if (this.config.registerSystemEvent) { inputManager.registerSystemEvent(this.canvas); } var hidden = false; function onHidden() { if (!hidden) { hidden = true; game.emit(game.EVENT_HIDE); } } function onShown(res) { if (hidden) { hidden = false; if (game.renderType === game.RENDER_TYPE_WEBGL) { game._renderContext.finish(); } game.emit(game.EVENT_SHOW, res); } } __globalAdapter.onAudioInterruptionEnd && __globalAdapter.onAudioInterruptionEnd(function () { if (cc.audioEngine) cc.audioEngine._restore(); }); __globalAdapter.onAudioInterruptionBegin && __globalAdapter.onAudioInterruptionBegin(function () { if (cc.audioEngine) cc.audioEngine._break(); }); // Maybe not support in open data context __globalAdapter.onShow && __globalAdapter.onShow(onShown); __globalAdapter.onHide && __globalAdapter.onHide(onHidden); this.on(game.EVENT_HIDE, function () { game.pause(); }); this.on(game.EVENT_SHOW, function () { game.resume(); }); }, end: function end() {} // mini game platform not support this api }); },{}],9:[function(require,module,exports){ "use strict"; var mgr = cc.internal.inputManager; var canvasPosition = { left: 0, top: 0, width: window.innerWidth, height: window.innerHeight }; if (mgr) { Object.assign(mgr, { _updateCanvasBoundingRect: function _updateCanvasBoundingRect() {}, registerSystemEvent: function registerSystemEvent(element) { if (this._isRegisterEvent) return; this._glView = cc.view; var self = this; //register touch event var _touchEventsMap = { onTouchStart: this.handleTouchesBegin, onTouchMove: this.handleTouchesMove, onTouchEnd: this.handleTouchesEnd, onTouchCancel: this.handleTouchesCancel }; var registerTouchEvent = function registerTouchEvent(eventName) { var handler = _touchEventsMap[eventName]; __globalAdapter[eventName](function (event) { if (!event.changedTouches) return; handler.call(self, self.getTouchesByEvent(event, canvasPosition)); }); }; for (var eventName in _touchEventsMap) { registerTouchEvent(eventName); } this._isRegisterEvent = true; } }); } },{}],10:[function(require,module,exports){ "use strict"; Object.assign(cc.screen, { autoFullScreen: function autoFullScreen(element, onFullScreenChange) {// Not support on mini game } }); },{}],11:[function(require,module,exports){ "use strict"; var Texture2D = cc.Texture2D; if (Texture2D) { Object.assign(Texture2D.prototype, { initWithElement: function initWithElement(element) { if (!element) return; this._image = element; this.handleLoadedTexture(); } }); } },{}],12:[function(require,module,exports){ "use strict"; function adaptSys(sys, env) { if (!env) { env = __globalAdapter.getSystemInfoSync(); } var language = env.language || ''; var system = env.system || 'iOS'; var platform = env.platform || 'iOS'; sys.isNative = false; sys.isBrowser = false; sys.isMobile = true; sys.language = language.substr(0, 2); sys.languageCode = language.toLowerCase(); platform = platform.toLowerCase(); if (platform === "android") { sys.os = sys.OS_ANDROID; } else if (platform === "ios") { sys.os = sys.OS_IOS; } system = system.toLowerCase(); // Adaptation to Android P if (system === 'android p') { system = 'android p 9.0'; } var version = /[\d\.]+/.exec(system); sys.osVersion = version ? version[0] : system; sys.osMainVersion = parseInt(sys.osVersion); sys.browserType = null; sys.browserVersion = null; var w = env.windowWidth; var h = env.windowHeight; var ratio = env.pixelRatio || 1; sys.windowPixelResolution = { width: ratio * w, height: ratio * h }; sys.localStorage = window.localStorage; var _supportWebGL = __globalAdapter.isSubContext ? false : true; ; var _supportWebp = false; try { var _canvas = document.createElement("canvas"); _supportWebp = _canvas.toDataURL('image/webp').startsWith('data:image/webp'); } catch (err) {} sys.capabilities = { "canvas": true, "opengl": !!_supportWebGL, "webp": _supportWebp }; sys.__audioSupport = { ONLY_ONE: false, WEB_AUDIO: false, DELAY_CREATE_CTX: false, format: ['.mp3'] }; } module.exports = adaptSys; },{}],13:[function(require,module,exports){ "use strict"; function adaptContainerStrategy(containerStrategyProto) { containerStrategyProto._setupContainer = function (view, width, height) { // Setup pixel ratio for retina display var devicePixelRatio = view._devicePixelRatio = 1; if (view.isRetinaEnabled()) { devicePixelRatio = view._devicePixelRatio = Math.min(view._maxPixelRatio, window.devicePixelRatio || 1); } // size of sharedCanvas is readonly in subContext if (__globalAdapter.isSubContext) { return; } var locCanvas = cc.game.canvas; // Setup canvas width *= devicePixelRatio; height *= devicePixelRatio; // FIX: black screen on Baidu platform // reset canvas size may call gl.clear(), especially when you call cc.director.loadScene() if (locCanvas.width !== width || locCanvas.height !== height) { locCanvas.width = width; locCanvas.height = height; } }; } module.exports = adaptContainerStrategy; },{}],14:[function(require,module,exports){ "use strict"; function adaptView(viewProto) { Object.assign(viewProto, { _adjustViewportMeta: function _adjustViewportMeta() {// minigame not support }, setRealPixelResolution: function setRealPixelResolution(width, height, resolutionPolicy) { // Reset the resolution size and policy this.setDesignResolutionSize(width, height, resolutionPolicy); }, enableAutoFullScreen: function enableAutoFullScreen(enabled) { cc.warn('cc.view.enableAutoFullScreen() is not supported on minigame platform.'); }, isAutoFullScreenEnabled: function isAutoFullScreenEnabled() { return false; }, setCanvasSize: function setCanvasSize() { cc.warn('cc.view.setCanvasSize() is not supported on minigame platform.'); }, setFrameSize: function setFrameSize() { cc.warn('frame size is readonly on minigame platform.'); }, _initFrameSize: function _initFrameSize() { var locFrameSize = this._frameSize; if (__globalAdapter.isSubContext) { var sharedCanvas = window.sharedCanvas || __globalAdapter.getSharedCanvas(); locFrameSize.width = sharedCanvas.width; locFrameSize.height = sharedCanvas.height; } else { locFrameSize.width = window.innerWidth; locFrameSize.height = window.innerHeight; } } }); } module.exports = adaptView; },{}],15:[function(require,module,exports){ "use strict"; var adapter = window.__globalAdapter; Object.assign(adapter, { adaptSys: require('./BaseSystemInfo'), adaptView: require('./View'), adaptContainerStrategy: require('./ContainerStrategy') }); },{"./BaseSystemInfo":12,"./ContainerStrategy":13,"./View":14}],16:[function(require,module,exports){ "use strict"; require('./Audio'); require('./AudioEngine'); require('./DeviceMotionEvent'); require('./Editbox'); require('./Game'); require('./InputManager'); require('./AssetManager'); require('./Screen'); require('./Texture2D'); require('./misc'); },{"./AssetManager":3,"./Audio":4,"./AudioEngine":5,"./DeviceMotionEvent":6,"./Editbox":7,"./Game":8,"./InputManager":9,"./Screen":10,"./Texture2D":11,"./misc":17}],17:[function(require,module,exports){ "use strict"; cc.macro.DOWNLOAD_MAX_CONCURRENT = 10; },{}],18:[function(require,module,exports){ "use strict"; var utils = { /** * @param {Object} target * @param {Object} origin * @param {String} methodName * @param {String} targetMethodName */ cloneMethod: function cloneMethod(target, origin, methodName, targetMethodName) { if (origin[methodName]) { targetMethodName = targetMethodName || methodName; target[targetMethodName] = origin[methodName].bind(origin); } } }; module.exports = utils; },{}],19:[function(require,module,exports){ "use strict"; function DOMParser(options) { this.options = options || { locator: {} }; } DOMParser.prototype.parseFromString = function (source, mimeType) { var options = this.options; var sax = new XMLReader(); var domBuilder = options.domBuilder || new DOMHandler(); //contentHandler and LexicalHandler var errorHandler = options.errorHandler; var locator = options.locator; var defaultNSMap = options.xmlns || {}; var isHTML = /\/x?html?$/.test(mimeType); //mimeType.toLowerCase().indexOf('html') > -1; var entityMap = isHTML ? htmlEntity.entityMap : { 'lt': '<', 'gt': '>', 'amp': '&', 'quot': '"', 'apos': "'" }; if (locator) { domBuilder.setDocumentLocator(locator); } sax.errorHandler = buildErrorHandler(errorHandler, domBuilder, locator); sax.domBuilder = options.domBuilder || domBuilder; if (isHTML) { defaultNSMap[''] = 'http://www.w3.org/1999/xhtml'; } defaultNSMap.xml = defaultNSMap.xml || 'http://www.w3.org/XML/1998/namespace'; if (source) { sax.parse(source, defaultNSMap, entityMap); } else { sax.errorHandler.error("invalid doc source"); } return domBuilder.doc; }; function buildErrorHandler(errorImpl, domBuilder, locator) { if (!errorImpl) { if (domBuilder instanceof DOMHandler) { return domBuilder; } errorImpl = domBuilder; } var errorHandler = {}; var isCallback = errorImpl instanceof Function; locator = locator || {}; function build(key) { var fn = errorImpl[key]; if (!fn && isCallback) { fn = errorImpl.length == 2 ? function (msg) { errorImpl(key, msg); } : errorImpl; } errorHandler[key] = fn && function (msg) { fn('[xmldom ' + key + ']\t' + msg + _locator(locator)); } || function () {}; } build('warning'); build('error'); build('fatalError'); return errorHandler; } //console.log('#\n\n\n\n\n\n\n####') /** * +ContentHandler+ErrorHandler * +LexicalHandler+EntityResolver2 * -DeclHandler-DTDHandler * * DefaultHandler:EntityResolver, DTDHandler, ContentHandler, ErrorHandler * DefaultHandler2:DefaultHandler,LexicalHandler, DeclHandler, EntityResolver2 * @link http://www.saxproject.org/apidoc/org/xml/sax/helpers/DefaultHandler.html */ function DOMHandler() { this.cdata = false; } function position(locator, node) { node.lineNumber = locator.lineNumber; node.columnNumber = locator.columnNumber; } /** * @see org.xml.sax.ContentHandler#startDocument * @link http://www.saxproject.org/apidoc/org/xml/sax/ContentHandler.html */ DOMHandler.prototype = { startDocument: function startDocument() { this.doc = new DOMImplementation().createDocument(null, null, null); if (this.locator) { this.doc.documentURI = this.locator.systemId; } }, startElement: function startElement(namespaceURI, localName, qName, attrs) { var doc = this.doc; var el = doc.createElementNS(namespaceURI, qName || localName); var len = attrs.length; appendElement(this, el); this.currentElement = el; this.locator && position(this.locator, el); for (var i = 0; i < len; i++) { var namespaceURI = attrs.getURI(i); var value = attrs.getValue(i); var qName = attrs.getQName(i); var attr = doc.createAttributeNS(namespaceURI, qName); this.locator && position(attrs.getLocator(i), attr); attr.value = attr.nodeValue = value; el.setAttributeNode(attr); } }, endElement: function endElement(namespaceURI, localName, qName) { var current = this.currentElement; var tagName = current.tagName; this.currentElement = current.parentNode; }, startPrefixMapping: function startPrefixMapping(prefix, uri) {}, endPrefixMapping: function endPrefixMapping(prefix) {}, processingInstruction: function processingInstruction(target, data) { var ins = this.doc.createProcessingInstruction(target, data); this.locator && position(this.locator, ins); appendElement(this, ins); }, ignorableWhitespace: function ignorableWhitespace(ch, start, length) {}, characters: function characters(chars, start, length) { chars = _toString.apply(this, arguments); //console.log(chars) if (chars) { if (this.cdata) { var charNode = this.doc.createCDATASection(chars); } else { var charNode = this.doc.createTextNode(chars); } if (this.currentElement) { this.currentElement.appendChild(charNode); } else if (/^\s*$/.test(chars)) { this.doc.appendChild(charNode); //process xml } this.locator && position(this.locator, charNode); } }, skippedEntity: function skippedEntity(name) {}, endDocument: function endDocument() { this.doc.normalize(); }, setDocumentLocator: function setDocumentLocator(locator) { if (this.locator = locator) { // && !('lineNumber' in locator)){ locator.lineNumber = 0; } }, //LexicalHandler comment: function comment(chars, start, length) { chars = _toString.apply(this, arguments); var comm = this.doc.createComment(chars); this.locator && position(this.locator, comm); appendElement(this, comm); }, startCDATA: function startCDATA() { //used in characters() methods this.cdata = true; }, endCDATA: function endCDATA() { this.cdata = false; }, startDTD: function startDTD(name, publicId, systemId) { var impl = this.doc.implementation; if (impl && impl.createDocumentType) { var dt = impl.createDocumentType(name, publicId, systemId); this.locator && position(this.locator, dt); appendElement(this, dt); } }, /** * @see org.xml.sax.ErrorHandler * @link http://www.saxproject.org/apidoc/org/xml/sax/ErrorHandler.html */ warning: function warning(error) { console.warn('[xmldom warning]\t' + error, _locator(this.locator)); }, error: function error(_error) { console.error('[xmldom error]\t' + _error, _locator(this.locator)); }, fatalError: function fatalError(error) { console.error('[xmldom fatalError]\t' + error, _locator(this.locator)); throw error; } }; function _locator(l) { if (l) { return '\n@' + (l.systemId || '') + '#[line:' + l.lineNumber + ',col:' + l.columnNumber + ']'; } } function _toString(chars, start, length) { if (typeof chars == 'string') { return chars.substr(start, length); } else { //java sax connect width xmldom on rhino(what about: "? && !(chars instanceof String)") if (chars.length >= start + length || start) { return new java.lang.String(chars, start, length) + ''; } return chars; } } /* * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/LexicalHandler.html * used method of org.xml.sax.ext.LexicalHandler: * #comment(chars, start, length) * #startCDATA() * #endCDATA() * #startDTD(name, publicId, systemId) * * * IGNORED method of org.xml.sax.ext.LexicalHandler: * #endDTD() * #startEntity(name) * #endEntity(name) * * * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/DeclHandler.html * IGNORED method of org.xml.sax.ext.DeclHandler * #attributeDecl(eName, aName, type, mode, value) * #elementDecl(name, model) * #externalEntityDecl(name, publicId, systemId) * #internalEntityDecl(name, value) * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/EntityResolver2.html * IGNORED method of org.xml.sax.EntityResolver2 * #resolveEntity(String name,String publicId,String baseURI,String systemId) * #resolveEntity(publicId, systemId) * #getExternalSubset(name, baseURI) * @link http://www.saxproject.org/apidoc/org/xml/sax/DTDHandler.html * IGNORED method of org.xml.sax.DTDHandler * #notationDecl(name, publicId, systemId) {}; * #unparsedEntityDecl(name, publicId, systemId, notationName) {}; */ "endDTD,startEntity,endEntity,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,resolveEntity,getExternalSubset,notationDecl,unparsedEntityDecl".replace(/\w+/g, function (key) { DOMHandler.prototype[key] = function () { return null; }; }); /* Private static helpers treated below as private instance methods, so don't need to add these to the public API; we might use a Relator to also get rid of non-standard public properties */ function appendElement(hander, node) { if (!hander.currentElement) { hander.doc.appendChild(node); } else { hander.currentElement.appendChild(node); } } //appendChild and setAttributeNS are preformance key //if(typeof require == 'function'){ var htmlEntity = require('./entities'); var XMLReader = require('./sax').XMLReader; var DOMImplementation = exports.DOMImplementation = require('./dom').DOMImplementation; exports.XMLSerializer = require('./dom').XMLSerializer; exports.DOMParser = DOMParser; //} },{"./dom":20,"./entities":21,"./sax":22}],20:[function(require,module,exports){ "use strict"; function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } /* * DOM Level 2 * Object DOMException * @see http://www.w3.org/TR/REC-DOM-Level-1/ecma-script-language-binding.html * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/ecma-script-binding.html */ function copy(src, dest) { for (var p in src) { dest[p] = src[p]; } } /** ^\w+\.prototype\.([_\w]+)\s*=\s*((?:.*\{\s*?[\r\n][\s\S]*?^})|\S.*?(?=[;\r\n]));? ^\w+\.prototype\.([_\w]+)\s*=\s*(\S.*?(?=[;\r\n]));? */ function _extends(Class, Super) { var pt = Class.prototype; if (!(pt instanceof Super)) { var t = function t() {}; ; t.prototype = Super.prototype; t = new t(); // copy(pt,t); for (var p in pt) { t[p] = pt[p]; } Class.prototype = pt = t; } if (pt.constructor != Class) { if (typeof Class != 'function') { console.error("unknow Class:" + Class); } pt.constructor = Class; } } var htmlns = 'http://www.w3.org/1999/xhtml'; // Node Types var NodeType = {}; var ELEMENT_NODE = NodeType.ELEMENT_NODE = 1; var ATTRIBUTE_NODE = NodeType.ATTRIBUTE_NODE = 2; var TEXT_NODE = NodeType.TEXT_NODE = 3; var CDATA_SECTION_NODE = NodeType.CDATA_SECTION_NODE = 4; var ENTITY_REFERENCE_NODE = NodeType.ENTITY_REFERENCE_NODE = 5; var ENTITY_NODE = NodeType.ENTITY_NODE = 6; var PROCESSING_INSTRUCTION_NODE = NodeType.PROCESSING_INSTRUCTION_NODE = 7; var COMMENT_NODE = NodeType.COMMENT_NODE = 8; var DOCUMENT_NODE = NodeType.DOCUMENT_NODE = 9; var DOCUMENT_TYPE_NODE = NodeType.DOCUMENT_TYPE_NODE = 10; var DOCUMENT_FRAGMENT_NODE = NodeType.DOCUMENT_FRAGMENT_NODE = 11; var NOTATION_NODE = NodeType.NOTATION_NODE = 12; // ExceptionCode var ExceptionCode = {}; var ExceptionMessage = {}; var INDEX_SIZE_ERR = ExceptionCode.INDEX_SIZE_ERR = (ExceptionMessage[1] = "Index size error", 1); var DOMSTRING_SIZE_ERR = ExceptionCode.DOMSTRING_SIZE_ERR = (ExceptionMessage[2] = "DOMString size error", 2); var HIERARCHY_REQUEST_ERR = ExceptionCode.HIERARCHY_REQUEST_ERR = (ExceptionMessage[3] = "Hierarchy request error", 3); var WRONG_DOCUMENT_ERR = ExceptionCode.WRONG_DOCUMENT_ERR = (ExceptionMessage[4] = "Wrong document", 4); var INVALID_CHARACTER_ERR = ExceptionCode.INVALID_CHARACTER_ERR = (ExceptionMessage[5] = "Invalid character", 5); var NO_DATA_ALLOWED_ERR = ExceptionCode.NO_DATA_ALLOWED_ERR = (ExceptionMessage[6] = "No data allowed", 6); var NO_MODIFICATION_ALLOWED_ERR = ExceptionCode.NO_MODIFICATION_ALLOWED_ERR = (ExceptionMessage[7] = "No modification allowed", 7); var NOT_FOUND_ERR = ExceptionCode.NOT_FOUND_ERR = (ExceptionMessage[8] = "Not found", 8); var NOT_SUPPORTED_ERR = ExceptionCode.NOT_SUPPORTED_ERR = (ExceptionMessage[9] = "Not supported", 9); var INUSE_ATTRIBUTE_ERR = ExceptionCode.INUSE_ATTRIBUTE_ERR = (ExceptionMessage[10] = "Attribute in use", 10); //level2 var INVALID_STATE_ERR = ExceptionCode.INVALID_STATE_ERR = (ExceptionMessage[11] = "Invalid state", 11); var SYNTAX_ERR = ExceptionCode.SYNTAX_ERR = (ExceptionMessage[12] = "Syntax error", 12); var INVALID_MODIFICATION_ERR = ExceptionCode.INVALID_MODIFICATION_ERR = (ExceptionMessage[13] = "Invalid modification", 13); var NAMESPACE_ERR = ExceptionCode.NAMESPACE_ERR = (ExceptionMessage[14] = "Invalid namespace", 14); var INVALID_ACCESS_ERR = ExceptionCode.INVALID_ACCESS_ERR = (ExceptionMessage[15] = "Invalid access", 15); function DOMException(code, message) { if (message instanceof Error) { var error = message; } else { error = this; Error.call(this, ExceptionMessage[code]); this.message = ExceptionMessage[code]; if (Error.captureStackTrace) Error.captureStackTrace(this, DOMException); } error.code = code; if (message) this.message = this.message + ": " + message; return error; } ; DOMException.prototype = Error.prototype; copy(ExceptionCode, DOMException); /** * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-536297177 * The NodeList interface provides the abstraction of an ordered collection of nodes, without defining or constraining how this collection is implemented. NodeList objects in the DOM are live. * The items in the NodeList are accessible via an integral index, starting from 0. */ function NodeList() {} ; NodeList.prototype = { /** * The number of nodes in the list. The range of valid child node indices is 0 to length-1 inclusive. * @standard level1 */ length: 0, /** * Returns the indexth item in the collection. If index is greater than or equal to the number of nodes in the list, this returns null. * @standard level1 * @param index unsigned long * Index into the collection. * @return Node * The node at the indexth position in the NodeList, or null if that is not a valid index. */ item: function item(index) { return this[index] || null; }, toString: function toString(isHTML, nodeFilter) { for (var buf = [], i = 0; i < this.length; i++) { serializeToString(this[i], buf, isHTML, nodeFilter); } return buf.join(''); } }; function LiveNodeList(node, refresh) { this._node = node; this._refresh = refresh; _updateLiveList(this); } function _updateLiveList(list) { var inc = list._node._inc || list._node.ownerDocument._inc; if (list._inc != inc) { var ls = list._refresh(list._node); //console.log(ls.length) __set__(list, 'length', ls.length); //copy(ls,list); for (var p in ls) { list[p] = ls[p]; } list._inc = inc; } } LiveNodeList.prototype.item = function (i) { _updateLiveList(this); return this[i]; }; _extends(LiveNodeList, NodeList); /** * * Objects implementing the NamedNodeMap interface are used to represent collections of nodes that can be accessed by name. Note that NamedNodeMap does not inherit from NodeList; NamedNodeMaps are not maintained in any particular order. Objects contained in an object implementing NamedNodeMap may also be accessed by an ordinal index, but this is simply to allow convenient enumeration of the contents of a NamedNodeMap, and does not imply that the DOM specifies an order to these Nodes. * NamedNodeMap objects in the DOM are live. * used for attributes or DocumentType entities */ function NamedNodeMap() {} ; function _findNodeIndex(list, node) { var i = list.length; while (i--) { if (list[i] === node) { return i; } } } function _addNamedNode(el, list, newAttr, oldAttr) { if (oldAttr) { list[_findNodeIndex(list, oldAttr)] = newAttr; } else { list[list.length++] = newAttr; } if (el) { newAttr.ownerElement = el; var doc = el.ownerDocument; if (doc) { oldAttr && _onRemoveAttribute(doc, el, oldAttr); _onAddAttribute(doc, el, newAttr); } } } function _removeNamedNode(el, list, attr) { //console.log('remove attr:'+attr) var i = _findNodeIndex(list, attr); if (i >= 0) { var lastIndex = list.length - 1; while (i < lastIndex) { list[i] = list[++i]; } list.length = lastIndex; if (el) { var doc = el.ownerDocument; if (doc) { _onRemoveAttribute(doc, el, attr); attr.ownerElement = null; } } } else { throw DOMException(NOT_FOUND_ERR, new Error(el.tagName + '@' + attr)); } } NamedNodeMap.prototype = { length: 0, item: NodeList.prototype.item, getNamedItem: function getNamedItem(key) { // if(key.indexOf(':')>0 || key == 'xmlns'){ // return null; // } //console.log() var i = this.length; while (i--) { var attr = this[i]; //console.log(attr.nodeName,key) if (attr.nodeName == key) { return attr; } } }, setNamedItem: function setNamedItem(attr) { var el = attr.ownerElement; if (el && el != this._ownerElement) { throw new DOMException(INUSE_ATTRIBUTE_ERR); } var oldAttr = this.getNamedItem(attr.nodeName); _addNamedNode(this._ownerElement, this, attr, oldAttr); return oldAttr; }, /* returns Node */ setNamedItemNS: function setNamedItemNS(attr) { // raises: WRONG_DOCUMENT_ERR,NO_MODIFICATION_ALLOWED_ERR,INUSE_ATTRIBUTE_ERR var el = attr.ownerElement, oldAttr; if (el && el != this._ownerElement) { throw new DOMException(INUSE_ATTRIBUTE_ERR); } oldAttr = this.getNamedItemNS(attr.namespaceURI, attr.localName); _addNamedNode(this._ownerElement, this, attr, oldAttr); return oldAttr; }, /* returns Node */ removeNamedItem: function removeNamedItem(key) { var attr = this.getNamedItem(key); _removeNamedNode(this._ownerElement, this, attr); return attr; }, // raises: NOT_FOUND_ERR,NO_MODIFICATION_ALLOWED_ERR //for level2 removeNamedItemNS: function removeNamedItemNS(namespaceURI, localName) { var attr = this.getNamedItemNS(namespaceURI, localName); _removeNamedNode(this._ownerElement, this, attr); return attr; }, getNamedItemNS: function getNamedItemNS(namespaceURI, localName) { var i = this.length; while (i--) { var node = this[i]; if (node.localName == localName && node.namespaceURI == namespaceURI) { return node; } } return null; } }; /** * @see http://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-102161490 */ function DOMImplementation( /* Object */ features) { this._features = {}; if (features) { for (var feature in features) { this._features = features[feature]; } } } ; DOMImplementation.prototype = { hasFeature: function hasFeature( /* string */ feature, /* string */ version) { var versions = this._features[feature.toLowerCase()]; if (versions && (!version || version in versions)) { return true; } else { return false; } }, // Introduced in DOM Level 2: createDocument: function createDocument(namespaceURI, qualifiedName, doctype) { // raises:INVALID_CHARACTER_ERR,NAMESPACE_ERR,WRONG_DOCUMENT_ERR var doc = new Document(); doc.implementation = this; doc.childNodes = new NodeList(); doc.doctype = doctype; if (doctype) { doc.appendChild(doctype); } if (qualifiedName) { var root = doc.createElementNS(namespaceURI, qualifiedName); doc.appendChild(root); } return doc; }, // Introduced in DOM Level 2: createDocumentType: function createDocumentType(qualifiedName, publicId, systemId) { // raises:INVALID_CHARACTER_ERR,NAMESPACE_ERR var node = new DocumentType(); node.name = qualifiedName; node.nodeName = qualifiedName; node.publicId = publicId; node.systemId = systemId; // Introduced in DOM Level 2: //readonly attribute DOMString internalSubset; //TODO:.. // readonly attribute NamedNodeMap entities; // readonly attribute NamedNodeMap notations; return node; } }; /** * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-1950641247 */ function Node() {} ; Node.prototype = { firstChild: null, lastChild: null, previousSibling: null, nextSibling: null, attributes: null, parentNode: null, childNodes: null, ownerDocument: null, nodeValue: null, namespaceURI: null, prefix: null, localName: null, // Modified in DOM Level 2: insertBefore: function insertBefore(newChild, refChild) { //raises return _insertBefore(this, newChild, refChild); }, replaceChild: function replaceChild(newChild, oldChild) { //raises this.insertBefore(newChild, oldChild); if (oldChild) { this.removeChild(oldChild); } }, removeChild: function removeChild(oldChild) { return _removeChild(this, oldChild); }, appendChild: function appendChild(newChild) { return this.insertBefore(newChild, null); }, hasChildNodes: function hasChildNodes() { return this.firstChild != null; }, cloneNode: function cloneNode(deep) { return _cloneNode(this.ownerDocument || this, this, deep); }, // Modified in DOM Level 2: normalize: function normalize() { var child = this.firstChild; while (child) { var next = child.nextSibling; if (next && next.nodeType == TEXT_NODE && child.nodeType == TEXT_NODE) { this.removeChild(next); child.appendData(next.data); } else { child.normalize(); child = next; } } }, // Introduced in DOM Level 2: isSupported: function isSupported(feature, version) { return this.ownerDocument.implementation.hasFeature(feature, version); }, // Introduced in DOM Level 2: hasAttributes: function hasAttributes() { return this.attributes.length > 0; }, lookupPrefix: function lookupPrefix(namespaceURI) { var el = this; while (el) { var map = el._nsMap; //console.dir(map) if (map) { for (var n in map) { if (map[n] == namespaceURI) { return n; } } } el = el.nodeType == ATTRIBUTE_NODE ? el.ownerDocument : el.parentNode; } return null; }, // Introduced in DOM Level 3: lookupNamespaceURI: function lookupNamespaceURI(prefix) { var el = this; while (el) { var map = el._nsMap; //console.dir(map) if (map) { if (prefix in map) { return map[prefix]; } } el = el.nodeType == ATTRIBUTE_NODE ? el.ownerDocument : el.parentNode; } return null; }, // Introduced in DOM Level 3: isDefaultNamespace: function isDefaultNamespace(namespaceURI) { var prefix = this.lookupPrefix(namespaceURI); return prefix == null; } }; function _xmlEncoder(c) { return c == '<' && '<' || c == '>' && '>' || c == '&' && '&' || c == '"' && '"' || '&#' + c.charCodeAt() + ';'; } copy(NodeType, Node); copy(NodeType, Node.prototype); /** * @param callback return true for continue,false for break * @return boolean true: break visit; */ function _visitNode(node, callback) { if (callback(node)) { return true; } if (node = node.firstChild) { do { if (_visitNode(node, callback)) { return true; } } while (node = node.nextSibling); } } function Document() {} function _onAddAttribute(doc, el, newAttr) { doc && doc._inc++; var ns = newAttr.namespaceURI; if (ns == 'http://www.w3.org/2000/xmlns/') { //update namespace el._nsMap[newAttr.prefix ? newAttr.localName : ''] = newAttr.value; } } function _onRemoveAttribute(doc, el, newAttr, remove) { doc && doc._inc++; var ns = newAttr.namespaceURI; if (ns == 'http://www.w3.org/2000/xmlns/') { //update namespace delete el._nsMap[newAttr.prefix ? newAttr.localName : '']; } } function _onUpdateChild(doc, el, newChild) { if (doc && doc._inc) { doc._inc++; //update childNodes var cs = el.childNodes; if (newChild) { cs[cs.length++] = newChild; } else { //console.log(1) var child = el.firstChild; var i = 0; while (child) { cs[i++] = child; child = child.nextSibling; } cs.length = i; } } } /** * attributes; * children; * * writeable properties: * nodeValue,Attr:value,CharacterData:data * prefix */ function _removeChild(parentNode, child) { var previous = child.previousSibling; var next = child.nextSibling; if (previous) { previous.nextSibling = next; } else { parentNode.firstChild = next; } if (next) { next.previousSibling = previous; } else { parentNode.lastChild = previous; } _onUpdateChild(parentNode.ownerDocument, parentNode); return child; } /** * preformance key(refChild == null) */ function _insertBefore(parentNode, newChild, nextChild) { var cp = newChild.parentNode; if (cp) { cp.removeChild(newChild); //remove and update } if (newChild.nodeType === DOCUMENT_FRAGMENT_NODE) { var newFirst = newChild.firstChild; if (newFirst == null) { return newChild; } var newLast = newChild.lastChild; } else { newFirst = newLast = newChild; } var pre = nextChild ? nextChild.previousSibling : parentNode.lastChild; newFirst.previousSibling = pre; newLast.nextSibling = nextChild; if (pre) { pre.nextSibling = newFirst; } else { parentNode.firstChild = newFirst; } if (nextChild == null) { parentNode.lastChild = newLast; } else { nextChild.previousSibling = newLast; } do { newFirst.parentNode = parentNode; } while (newFirst !== newLast && (newFirst = newFirst.nextSibling)); _onUpdateChild(parentNode.ownerDocument || parentNode, parentNode); //console.log(parentNode.lastChild.nextSibling == null) if (newChild.nodeType == DOCUMENT_FRAGMENT_NODE) { newChild.firstChild = newChild.lastChild = null; } return newChild; } function _appendSingleChild(parentNode, newChild) { var cp = newChild.parentNode; if (cp) { var pre = parentNode.lastChild; cp.removeChild(newChild); //remove and update var pre = parentNode.lastChild; } var pre = parentNode.lastChild; newChild.parentNode = parentNode; newChild.previousSibling = pre; newChild.nextSibling = null; if (pre) { pre.nextSibling = newChild; } else { parentNode.firstChild = newChild; } parentNode.lastChild = newChild; _onUpdateChild(parentNode.ownerDocument, parentNode, newChild); return newChild; //console.log("__aa",parentNode.lastChild.nextSibling == null) } Document.prototype = { //implementation : null, nodeName: '#document', nodeType: DOCUMENT_NODE, doctype: null, documentElement: null, _inc: 1, insertBefore: function insertBefore(newChild, refChild) { //raises if (newChild.nodeType == DOCUMENT_FRAGMENT_NODE) { var child = newChild.firstChild; while (child) { var next = child.nextSibling; this.insertBefore(child, refChild); child = next; } return newChild; } if (this.documentElement == null && newChild.nodeType == ELEMENT_NODE) { this.documentElement = newChild; } return _insertBefore(this, newChild, refChild), newChild.ownerDocument = this, newChild; }, removeChild: function removeChild(oldChild) { if (this.documentElement == oldChild) { this.documentElement = null; } return _removeChild(this, oldChild); }, // Introduced in DOM Level 2: importNode: function importNode(importedNode, deep) { return _importNode(this, importedNode, deep); }, // Introduced in DOM Level 2: getElementById: function getElementById(id) { var rtv = null; _visitNode(this.documentElement, function (node) { if (node.nodeType == ELEMENT_NODE) { if (node.getAttribute('id') == id) { rtv = node; return true; } } }); return rtv; }, //document factory method: createElement: function createElement(tagName) { var node = new Element(); node.ownerDocument = this; node.nodeName = tagName; node.tagName = tagName; node.childNodes = new NodeList(); var attrs = node.attributes = new NamedNodeMap(); attrs._ownerElement = node; return node; }, createDocumentFragment: function createDocumentFragment() { var node = new DocumentFragment(); node.ownerDocument = this; node.childNodes = new NodeList(); return node; }, createTextNode: function createTextNode(data) { var node = new Text(); node.ownerDocument = this; node.appendData(data); return node; }, createComment: function createComment(data) { var node = new Comment(); node.ownerDocument = this; node.appendData(data); return node; }, createCDATASection: function createCDATASection(data) { var node = new CDATASection(); node.ownerDocument = this; node.appendData(data); return node; }, createProcessingInstruction: function createProcessingInstruction(target, data) { var node = new ProcessingInstruction(); node.ownerDocument = this; node.tagName = node.target = target; node.nodeValue = node.data = data; return node; }, createAttribute: function createAttribute(name) { var node = new Attr(); node.ownerDocument = this; node.name = name; node.nodeName = name; node.localName = name; node.specified = true; return node; }, createEntityReference: function createEntityReference(name) { var node = new EntityReference(); node.ownerDocument = this; node.nodeName = name; return node; }, // Introduced in DOM Level 2: createElementNS: function createElementNS(namespaceURI, qualifiedName) { var node = new Element(); var pl = qualifiedName.split(':'); var attrs = node.attributes = new NamedNodeMap(); node.childNodes = new NodeList(); node.ownerDocument = this; node.nodeName = qualifiedName; node.tagName = qualifiedName; node.namespaceURI = namespaceURI; if (pl.length == 2) { node.prefix = pl[0]; node.localName = pl[1]; } else { //el.prefix = null; node.localName = qualifiedName; } attrs._ownerElement = node; return node; }, // Introduced in DOM Level 2: createAttributeNS: function createAttributeNS(namespaceURI, qualifiedName) { var node = new Attr(); var pl = qualifiedName.split(':'); node.ownerDocument = this; node.nodeName = qualifiedName; node.name = qualifiedName; node.namespaceURI = namespaceURI; node.specified = true; if (pl.length == 2) { node.prefix = pl[0]; node.localName = pl[1]; } else { //el.prefix = null; node.localName = qualifiedName; } return node; } }; _extends(Document, Node); function Element() { this._nsMap = {}; } ; Element.prototype = { nodeType: ELEMENT_NODE, hasAttribute: function hasAttribute(name) { return this.getAttributeNode(name) != null; }, getAttribute: function getAttribute(name) { var attr = this.getAttributeNode(name); return attr && attr.value || ''; }, getAttributeNode: function getAttributeNode(name) { return this.attributes.getNamedItem(name); }, setAttribute: function setAttribute(name, value) { var attr = this.ownerDocument.createAttribute(name); attr.value = attr.nodeValue = "" + value; this.setAttributeNode(attr); }, removeAttribute: function removeAttribute(name) { var attr = this.getAttributeNode(name); attr && this.removeAttributeNode(attr); }, //four real opeartion method appendChild: function appendChild(newChild) { if (newChild.nodeType === DOCUMENT_FRAGMENT_NODE) { return this.insertBefore(newChild, null); } else { return _appendSingleChild(this, newChild); } }, setAttributeNode: function setAttributeNode(newAttr) { return this.attributes.setNamedItem(newAttr); }, setAttributeNodeNS: function setAttributeNodeNS(newAttr) { return this.attributes.setNamedItemNS(newAttr); }, removeAttributeNode: function removeAttributeNode(oldAttr) { //console.log(this == oldAttr.ownerElement) return this.attributes.removeNamedItem(oldAttr.nodeName); }, //get real attribute name,and remove it by removeAttributeNode removeAttributeNS: function removeAttributeNS(namespaceURI, localName) { var old = this.getAttributeNodeNS(namespaceURI, localName); old && this.removeAttributeNode(old); }, hasAttributeNS: function hasAttributeNS(namespaceURI, localName) { return this.getAttributeNodeNS(namespaceURI, localName) != null; }, getAttributeNS: function getAttributeNS(namespaceURI, localName) { var attr = this.getAttributeNodeNS(namespaceURI, localName); return attr && attr.value || ''; }, setAttributeNS: function setAttributeNS(namespaceURI, qualifiedName, value) { var attr = this.ownerDocument.createAttributeNS(namespaceURI, qualifiedName); attr.value = attr.nodeValue = "" + value; this.setAttributeNode(attr); }, getAttributeNodeNS: function getAttributeNodeNS(namespaceURI, localName) { return this.attributes.getNamedItemNS(namespaceURI, localName); }, getElementsByTagName: function getElementsByTagName(tagName) { return new LiveNodeList(this, function (base) { var ls = []; _visitNode(base, function (node) { if (node !== base && node.nodeType == ELEMENT_NODE && (tagName === '*' || node.tagName == tagName)) { ls.push(node); } }); return ls; }); }, getElementsByTagNameNS: function getElementsByTagNameNS(namespaceURI, localName) { return new LiveNodeList(this, function (base) { var ls = []; _visitNode(base, function (node) { if (node !== base && node.nodeType === ELEMENT_NODE && (namespaceURI === '*' || node.namespaceURI === namespaceURI) && (localName === '*' || node.localName == localName)) { ls.push(node); } }); return ls; }); } }; Document.prototype.getElementsByTagName = Element.prototype.getElementsByTagName; Document.prototype.getElementsByTagNameNS = Element.prototype.getElementsByTagNameNS; _extends(Element, Node); function Attr() {} ; Attr.prototype.nodeType = ATTRIBUTE_NODE; _extends(Attr, Node); function CharacterData() {} ; CharacterData.prototype = { data: '', substringData: function substringData(offset, count) { return this.data.substring(offset, offset + count); }, appendData: function appendData(text) { text = this.data + text; this.nodeValue = this.data = text; this.length = text.length; }, insertData: function insertData(offset, text) { this.replaceData(offset, 0, text); }, appendChild: function appendChild(newChild) { throw new Error(ExceptionMessage[HIERARCHY_REQUEST_ERR]); }, deleteData: function deleteData(offset, count) { this.replaceData(offset, count, ""); }, replaceData: function replaceData(offset, count, text) { var start = this.data.substring(0, offset); var end = this.data.substring(offset + count); text = start + text + end; this.nodeValue = this.data = text; this.length = text.length; } }; _extends(CharacterData, Node); function Text() {} ; Text.prototype = { nodeName: "#text", nodeType: TEXT_NODE, splitText: function splitText(offset) { var text = this.data; var newText = text.substring(offset); text = text.substring(0, offset); this.data = this.nodeValue = text; this.length = text.length; var newNode = this.ownerDocument.createTextNode(newText); if (this.parentNode) { this.parentNode.insertBefore(newNode, this.nextSibling); } return newNode; } }; _extends(Text, CharacterData); function Comment() {} ; Comment.prototype = { nodeName: "#comment", nodeType: COMMENT_NODE }; _extends(Comment, CharacterData); function CDATASection() {} ; CDATASection.prototype = { nodeName: "#cdata-section", nodeType: CDATA_SECTION_NODE }; _extends(CDATASection, CharacterData); function DocumentType() {} ; DocumentType.prototype.nodeType = DOCUMENT_TYPE_NODE; _extends(DocumentType, Node); function Notation() {} ; Notation.prototype.nodeType = NOTATION_NODE; _extends(Notation, Node); function Entity() {} ; Entity.prototype.nodeType = ENTITY_NODE; _extends(Entity, Node); function EntityReference() {} ; EntityReference.prototype.nodeType = ENTITY_REFERENCE_NODE; _extends(EntityReference, Node); function DocumentFragment() {} ; DocumentFragment.prototype.nodeName = "#document-fragment"; DocumentFragment.prototype.nodeType = DOCUMENT_FRAGMENT_NODE; _extends(DocumentFragment, Node); function ProcessingInstruction() {} ProcessingInstruction.prototype.nodeType = PROCESSING_INSTRUCTION_NODE; _extends(ProcessingInstruction, Node); function XMLSerializer() {} XMLSerializer.prototype.serializeToString = function (node, isHtml, nodeFilter) { return nodeSerializeToString.call(node, isHtml, nodeFilter); }; Node.prototype.toString = nodeSerializeToString; function nodeSerializeToString(isHtml, nodeFilter) { var buf = []; var refNode = this.nodeType == 9 && this.documentElement || this; var prefix = refNode.prefix; var uri = refNode.namespaceURI; if (uri && prefix == null) { //console.log(prefix) var prefix = refNode.lookupPrefix(uri); if (prefix == null) { //isHTML = true; var visibleNamespaces = [{ namespace: uri, prefix: null } //{namespace:uri,prefix:''} ]; } } serializeToString(this, buf, isHtml, nodeFilter, visibleNamespaces); //console.log('###',this.nodeType,uri,prefix,buf.join('')) return buf.join(''); } function needNamespaceDefine(node, isHTML, visibleNamespaces) { var prefix = node.prefix || ''; var uri = node.namespaceURI; if (!prefix && !uri) { return false; } if (prefix === "xml" && uri === "http://www.w3.org/XML/1998/namespace" || uri == 'http://www.w3.org/2000/xmlns/') { return false; } var i = visibleNamespaces.length; //console.log('@@@@',node.tagName,prefix,uri,visibleNamespaces) while (i--) { var ns = visibleNamespaces[i]; // get namespace prefix //console.log(node.nodeType,node.tagName,ns.prefix,prefix) if (ns.prefix == prefix) { return ns.namespace != uri; } } //console.log(isHTML,uri,prefix=='') //if(isHTML && prefix ==null && uri == 'http://www.w3.org/1999/xhtml'){ // return false; //} //node.flag = '11111' //console.error(3,true,node.flag,node.prefix,node.namespaceURI) return true; } function serializeToString(node, buf, isHTML, nodeFilter, visibleNamespaces) { if (nodeFilter) { node = nodeFilter(node); if (node) { if (typeof node == 'string') { buf.push(node); return; } } else { return; } //buf.sort.apply(attrs, attributeSorter); } switch (node.nodeType) { case ELEMENT_NODE: if (!visibleNamespaces) visibleNamespaces = []; var startVisibleNamespaces = visibleNamespaces.length; var attrs = node.attributes; var len = attrs.length; var child = node.firstChild; var nodeName = node.tagName; isHTML = htmlns === node.namespaceURI || isHTML; buf.push('<', nodeName); for (var i = 0; i < len; i++) { // add namespaces for attributes var attr = attrs.item(i); if (attr.prefix == 'xmlns') { visibleNamespaces.push({ prefix: attr.localName, namespace: attr.value }); } else if (attr.nodeName == 'xmlns') { visibleNamespaces.push({ prefix: '', namespace: attr.value }); } } for (var i = 0; i < len; i++) { var attr = attrs.item(i); if (needNamespaceDefine(attr, isHTML, visibleNamespaces)) { var prefix = attr.prefix || ''; var uri = attr.namespaceURI; var ns = prefix ? ' xmlns:' + prefix : " xmlns"; buf.push(ns, '="', uri, '"'); visibleNamespaces.push({ prefix: prefix, namespace: uri }); } serializeToString(attr, buf, isHTML, nodeFilter, visibleNamespaces); } // add namespace for current node if (needNamespaceDefine(node, isHTML, visibleNamespaces)) { var prefix = node.prefix || ''; var uri = node.namespaceURI; var ns = prefix ? ' xmlns:' + prefix : " xmlns"; buf.push(ns, '="', uri, '"'); visibleNamespaces.push({ prefix: prefix, namespace: uri }); } if (child || isHTML && !/^(?:meta|link|img|br|hr|input)$/i.test(nodeName)) { buf.push('>'); //if is cdata child node if (isHTML && /^script$/i.test(nodeName)) { while (child) { if (child.data) { buf.push(child.data); } else { serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces); } child = child.nextSibling; } } else { while (child) { serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces); child = child.nextSibling; } } buf.push(''); } else { buf.push('/>'); } // remove added visible namespaces //visibleNamespaces.length = startVisibleNamespaces; return; case DOCUMENT_NODE: case DOCUMENT_FRAGMENT_NODE: var child = node.firstChild; while (child) { serializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces); child = child.nextSibling; } return; case ATTRIBUTE_NODE: return buf.push(' ', node.name, '="', node.value.replace(/[<&"]/g, _xmlEncoder), '"'); case TEXT_NODE: return buf.push(node.data.replace(/[<&]/g, _xmlEncoder)); case CDATA_SECTION_NODE: return buf.push(''); case COMMENT_NODE: return buf.push(""); case DOCUMENT_TYPE_NODE: var pubid = node.publicId; var sysid = node.systemId; buf.push(''); } else if (sysid && sysid != '.') { buf.push(' SYSTEM "', sysid, '">'); } else { var sub = node.internalSubset; if (sub) { buf.push(" [", sub, "]"); } buf.push(">"); } return; case PROCESSING_INSTRUCTION_NODE: return buf.push(""); case ENTITY_REFERENCE_NODE: return buf.push('&', node.nodeName, ';'); //case ENTITY_NODE: //case NOTATION_NODE: default: buf.push('??', node.nodeName); } } function _importNode(doc, node, deep) { var node2; switch (node.nodeType) { case ELEMENT_NODE: node2 = node.cloneNode(false); node2.ownerDocument = doc; //var attrs = node2.attributes; //var len = attrs.length; //for(var i=0;i', amp: '&', quot: '"', apos: "'", Agrave: "À", Aacute: "Á", Acirc: "Â", Atilde: "Ã", Auml: "Ä", Aring: "Å", AElig: "Æ", Ccedil: "Ç", Egrave: "È", Eacute: "É", Ecirc: "Ê", Euml: "Ë", Igrave: "Ì", Iacute: "Í", Icirc: "Î", Iuml: "Ï", ETH: "Ð", Ntilde: "Ñ", Ograve: "Ò", Oacute: "Ó", Ocirc: "Ô", Otilde: "Õ", Ouml: "Ö", Oslash: "Ø", Ugrave: "Ù", Uacute: "Ú", Ucirc: "Û", Uuml: "Ü", Yacute: "Ý", THORN: "Þ", szlig: "ß", agrave: "à", aacute: "á", acirc: "â", atilde: "ã", auml: "ä", aring: "å", aelig: "æ", ccedil: "ç", egrave: "è", eacute: "é", ecirc: "ê", euml: "ë", igrave: "ì", iacute: "í", icirc: "î", iuml: "ï", eth: "ð", ntilde: "ñ", ograve: "ò", oacute: "ó", ocirc: "ô", otilde: "õ", ouml: "ö", oslash: "ø", ugrave: "ù", uacute: "ú", ucirc: "û", uuml: "ü", yacute: "ý", thorn: "þ", yuml: "ÿ", nbsp: " ", iexcl: "¡", cent: "¢", pound: "£", curren: "¤", yen: "¥", brvbar: "¦", sect: "§", uml: "¨", copy: "©", ordf: "ª", laquo: "«", not: "¬", shy: "­­", reg: "®", macr: "¯", deg: "°", plusmn: "±", sup2: "²", sup3: "³", acute: "´", micro: "µ", para: "¶", middot: "·", cedil: "¸", sup1: "¹", ordm: "º", raquo: "»", frac14: "¼", frac12: "½", frac34: "¾", iquest: "¿", times: "×", divide: "÷", forall: "∀", part: "∂", exist: "∃", empty: "∅", nabla: "∇", isin: "∈", notin: "∉", ni: "∋", prod: "∏", sum: "∑", minus: "−", lowast: "∗", radic: "√", prop: "∝", infin: "∞", ang: "∠", and: "∧", or: "∨", cap: "∩", cup: "∪", 'int': "∫", there4: "∴", sim: "∼", cong: "≅", asymp: "≈", ne: "≠", equiv: "≡", le: "≤", ge: "≥", sub: "⊂", sup: "⊃", nsub: "⊄", sube: "⊆", supe: "⊇", oplus: "⊕", otimes: "⊗", perp: "⊥", sdot: "⋅", Alpha: "Α", Beta: "Β", Gamma: "Γ", Delta: "Δ", Epsilon: "Ε", Zeta: "Ζ", Eta: "Η", Theta: "Θ", Iota: "Ι", Kappa: "Κ", Lambda: "Λ", Mu: "Μ", Nu: "Ν", Xi: "Ξ", Omicron: "Ο", Pi: "Π", Rho: "Ρ", Sigma: "Σ", Tau: "Τ", Upsilon: "Υ", Phi: "Φ", Chi: "Χ", Psi: "Ψ", Omega: "Ω", alpha: "α", beta: "β", gamma: "γ", delta: "δ", epsilon: "ε", zeta: "ζ", eta: "η", theta: "θ", iota: "ι", kappa: "κ", lambda: "λ", mu: "μ", nu: "ν", xi: "ξ", omicron: "ο", pi: "π", rho: "ρ", sigmaf: "ς", sigma: "σ", tau: "τ", upsilon: "υ", phi: "φ", chi: "χ", psi: "ψ", omega: "ω", thetasym: "ϑ", upsih: "ϒ", piv: "ϖ", OElig: "Œ", oelig: "œ", Scaron: "Š", scaron: "š", Yuml: "Ÿ", fnof: "ƒ", circ: "ˆ", tilde: "˜", ensp: " ", emsp: " ", thinsp: " ", zwnj: "‌", zwj: "‍", lrm: "‎", rlm: "‏", ndash: "–", mdash: "—", lsquo: "‘", rsquo: "’", sbquo: "‚", ldquo: "“", rdquo: "”", bdquo: "„", dagger: "†", Dagger: "‡", bull: "•", hellip: "…", permil: "‰", prime: "′", Prime: "″", lsaquo: "‹", rsaquo: "›", oline: "‾", euro: "€", trade: "™", larr: "←", uarr: "↑", rarr: "→", darr: "↓", harr: "↔", crarr: "↵", lceil: "⌈", rceil: "⌉", lfloor: "⌊", rfloor: "⌋", loz: "◊", spades: "♠", clubs: "♣", hearts: "♥", diams: "♦" }; //for(var n in exports.entityMap){console.log(exports.entityMap[n].charCodeAt())} },{}],22:[function(require,module,exports){ "use strict"; //[4] NameStartChar ::= ":" | [A-Z] | "_" | [a-z] | [#xC0-#xD6] | [#xD8-#xF6] | [#xF8-#x2FF] | [#x370-#x37D] | [#x37F-#x1FFF] | [#x200C-#x200D] | [#x2070-#x218F] | [#x2C00-#x2FEF] | [#x3001-#xD7FF] | [#xF900-#xFDCF] | [#xFDF0-#xFFFD] | [#x10000-#xEFFFF] //[4a] NameChar ::= NameStartChar | "-" | "." | [0-9] | #xB7 | [#x0300-#x036F] | [#x203F-#x2040] //[5] Name ::= NameStartChar (NameChar)* var nameStartChar = /[A-Z_a-z\xC0-\xD6\xD8-\xF6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD]/; //\u10000-\uEFFFF var nameChar = new RegExp("[\\-\\.0-9" + nameStartChar.source.slice(1, -1) + "\\u00B7\\u0300-\\u036F\\u203F-\\u2040]"); var tagNamePattern = new RegExp('^' + nameStartChar.source + nameChar.source + '*(?:\:' + nameStartChar.source + nameChar.source + '*)?$'); //var tagNamePattern = /^[a-zA-Z_][\w\-\.]*(?:\:[a-zA-Z_][\w\-\.]*)?$/ //var handlers = 'resolveEntity,getExternalSubset,characters,endDocument,endElement,endPrefixMapping,ignorableWhitespace,processingInstruction,setDocumentLocator,skippedEntity,startDocument,startElement,startPrefixMapping,notationDecl,unparsedEntityDecl,error,fatalError,warning,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,comment,endCDATA,endDTD,endEntity,startCDATA,startDTD,startEntity'.split(',') //S_TAG, S_ATTR, S_EQ, S_ATTR_NOQUOT_VALUE //S_ATTR_SPACE, S_ATTR_END, S_TAG_SPACE, S_TAG_CLOSE var S_TAG = 0; //tag name offerring var S_ATTR = 1; //attr name offerring var S_ATTR_SPACE = 2; //attr name end and space offer var S_EQ = 3; //=space? var S_ATTR_NOQUOT_VALUE = 4; //attr value(no quot value only) var S_ATTR_END = 5; //attr value end and no space(quot end) var S_TAG_SPACE = 6; //(attr value end || tag end ) && (space offer) var S_TAG_CLOSE = 7; //closed el function XMLReader() {} XMLReader.prototype = { parse: function parse(source, defaultNSMap, entityMap) { var domBuilder = this.domBuilder; domBuilder.startDocument(); _copy(defaultNSMap, defaultNSMap = {}); _parse(source, defaultNSMap, entityMap, domBuilder, this.errorHandler); domBuilder.endDocument(); } }; function _parse(source, defaultNSMapCopy, entityMap, domBuilder, errorHandler) { function fixedFromCharCode(code) { // String.prototype.fromCharCode does not supports // > 2 bytes unicode chars directly if (code > 0xffff) { code -= 0x10000; var surrogate1 = 0xd800 + (code >> 10), surrogate2 = 0xdc00 + (code & 0x3ff); return String.fromCharCode(surrogate1, surrogate2); } else { return String.fromCharCode(code); } } function entityReplacer(a) { var k = a.slice(1, -1); if (k in entityMap) { return entityMap[k]; } else if (k.charAt(0) === '#') { return fixedFromCharCode(parseInt(k.substr(1).replace('x', '0x'))); } else { errorHandler.error('entity not found:' + a); return a; } } function appendText(end) { //has some bugs if (end > start) { var xt = source.substring(start, end).replace(/&#?\w+;/g, entityReplacer); locator && position(start); domBuilder.characters(xt, 0, end - start); start = end; } } function position(p, m) { while (p >= lineEnd && (m = linePattern.exec(source))) { lineStart = m.index; lineEnd = lineStart + m[0].length; locator.lineNumber++; //console.log('line++:',locator,startPos,endPos) } locator.columnNumber = p - lineStart + 1; } var lineStart = 0; var lineEnd = 0; var linePattern = /.*(?:\r\n?|\n)|.*$/g; var locator = domBuilder.locator; var parseStack = [{ currentNSMap: defaultNSMapCopy }]; var closeMap = {}; var start = 0; while (true) { try { var tagStart = source.indexOf('<', start); if (tagStart < 0) { if (!source.substr(start).match(/^\s*$/)) { var doc = domBuilder.doc; var text = doc.createTextNode(source.substr(start)); doc.appendChild(text); domBuilder.currentElement = text; } return; } if (tagStart > start) { appendText(tagStart); } switch (source.charAt(tagStart + 1)) { case '/': var end = source.indexOf('>', tagStart + 3); var tagName = source.substring(tagStart + 2, end); var config = parseStack.pop(); if (end < 0) { tagName = source.substring(tagStart + 2).replace(/[\s<].*/, ''); //console.error('#@@@@@@'+tagName) errorHandler.error("end tag name: " + tagName + ' is not complete:' + config.tagName); end = tagStart + 1 + tagName.length; } else if (tagName.match(/\s locator && position(tagStart); end = parseInstruction(source, tagStart, domBuilder); break; case '!': // start) { start = end; } else { //TODO: 这里有可能sax回退,有位置错误风险 appendText(Math.max(tagStart, start) + 1); } } } function copyLocator(f, t) { t.lineNumber = f.lineNumber; t.columnNumber = f.columnNumber; return t; } /** * @see #appendElement(source,elStartEnd,el,selfClosed,entityReplacer,domBuilder,parseStack); * @return end of the elementStartPart(end of elementEndPart for selfClosed el) */ function parseElementStartPart(source, start, el, currentNSMap, entityReplacer, errorHandler) { var attrName; var value; var p = ++start; var s = S_TAG; //status while (true) { var c = source.charAt(p); switch (c) { case '=': if (s === S_ATTR) { //attrName attrName = source.slice(start, p); s = S_EQ; } else if (s === S_ATTR_SPACE) { s = S_EQ; } else { //fatalError: equal must after attrName or space after attrName throw new Error('attribute equal must after attrName'); } break; case '\'': case '"': if (s === S_EQ || s === S_ATTR //|| s == S_ATTR_SPACE ) { //equal if (s === S_ATTR) { errorHandler.warning('attribute value must after "="'); attrName = source.slice(start, p); } start = p + 1; p = source.indexOf(c, start); if (p > 0) { value = source.slice(start, p).replace(/&#?\w+;/g, entityReplacer); el.add(attrName, value, start - 1); s = S_ATTR_END; } else { //fatalError: no end quot match throw new Error('attribute value no end \'' + c + '\' match'); } } else if (s == S_ATTR_NOQUOT_VALUE) { value = source.slice(start, p).replace(/&#?\w+;/g, entityReplacer); //console.log(attrName,value,start,p) el.add(attrName, value, start); //console.dir(el) errorHandler.warning('attribute "' + attrName + '" missed start quot(' + c + ')!!'); start = p + 1; s = S_ATTR_END; } else { //fatalError: no equal before throw new Error('attribute value must after "="'); } break; case '/': switch (s) { case S_TAG: el.setTagName(source.slice(start, p)); case S_ATTR_END: case S_TAG_SPACE: case S_TAG_CLOSE: s = S_TAG_CLOSE; el.closed = true; case S_ATTR_NOQUOT_VALUE: case S_ATTR: case S_ATTR_SPACE: break; //case S_EQ: default: throw new Error("attribute invalid close char('/')"); } break; case '': //end document //throw new Error('unexpected end of input') errorHandler.error('unexpected end of input'); if (s == S_TAG) { el.setTagName(source.slice(start, p)); } return p; case '>': switch (s) { case S_TAG: el.setTagName(source.slice(start, p)); case S_ATTR_END: case S_TAG_SPACE: case S_TAG_CLOSE: break; //normal case S_ATTR_NOQUOT_VALUE: //Compatible state case S_ATTR: value = source.slice(start, p); if (value.slice(-1) === '/') { el.closed = true; value = value.slice(0, -1); } case S_ATTR_SPACE: if (s === S_ATTR_SPACE) { value = attrName; } if (s == S_ATTR_NOQUOT_VALUE) { errorHandler.warning('attribute "' + value + '" missed quot(")!!'); el.add(attrName, value.replace(/&#?\w+;/g, entityReplacer), start); } else { if (currentNSMap[''] !== 'http://www.w3.org/1999/xhtml' || !value.match(/^(?:disabled|checked|selected)$/i)) { errorHandler.warning('attribute "' + value + '" missed value!! "' + value + '" instead!!'); } el.add(value, value, start); } break; case S_EQ: throw new Error('attribute value missed!!'); } // console.log(tagName,tagNamePattern,tagNamePattern.test(tagName)) return p; /*xml space '\x20' | #x9 | #xD | #xA; */ case "\x80": c = ' '; default: if (c <= ' ') { //space switch (s) { case S_TAG: el.setTagName(source.slice(start, p)); //tagName s = S_TAG_SPACE; break; case S_ATTR: attrName = source.slice(start, p); s = S_ATTR_SPACE; break; case S_ATTR_NOQUOT_VALUE: var value = source.slice(start, p).replace(/&#?\w+;/g, entityReplacer); errorHandler.warning('attribute "' + value + '" missed quot(")!!'); el.add(attrName, value, start); case S_ATTR_END: s = S_TAG_SPACE; break; //case S_TAG_SPACE: //case S_EQ: //case S_ATTR_SPACE: // void();break; //case S_TAG_CLOSE: //ignore warning } } else { //not space //S_TAG, S_ATTR, S_EQ, S_ATTR_NOQUOT_VALUE //S_ATTR_SPACE, S_ATTR_END, S_TAG_SPACE, S_TAG_CLOSE switch (s) { //case S_TAG:void();break; //case S_ATTR:void();break; //case S_ATTR_NOQUOT_VALUE:void();break; case S_ATTR_SPACE: var tagName = el.tagName; if (currentNSMap[''] !== 'http://www.w3.org/1999/xhtml' || !attrName.match(/^(?:disabled|checked|selected)$/i)) { errorHandler.warning('attribute "' + attrName + '" missed value!! "' + attrName + '" instead2!!'); } el.add(attrName, attrName, start); start = p; s = S_ATTR; break; case S_ATTR_END: errorHandler.warning('attribute space is required"' + attrName + '"!!'); case S_TAG_SPACE: s = S_ATTR; start = p; break; case S_EQ: s = S_ATTR_NOQUOT_VALUE; start = p; break; case S_TAG_CLOSE: throw new Error("elements closed character '/' and '>' must be connected to"); } } } //end outer switch //console.log('p++',p) p++; } } /** * @return true if has new namespace define */ function appendElement(el, domBuilder, currentNSMap) { var tagName = el.tagName; var localNSMap = null; //var currentNSMap = parseStack[parseStack.length-1].currentNSMap; var i = el.length; while (i--) { var a = el[i]; var qName = a.qName; var value = a.value; var nsp = qName.indexOf(':'); if (nsp > 0) { var prefix = a.prefix = qName.slice(0, nsp); var localName = qName.slice(nsp + 1); var nsPrefix = prefix === 'xmlns' && localName; } else { localName = qName; prefix = null; nsPrefix = qName === 'xmlns' && ''; } //can not set prefix,because prefix !== '' a.localName = localName; //prefix == null for no ns prefix attribute if (nsPrefix !== false) { //hack!! if (localNSMap == null) { localNSMap = {}; //console.log(currentNSMap,0) _copy(currentNSMap, currentNSMap = {}); //console.log(currentNSMap,1) } currentNSMap[nsPrefix] = localNSMap[nsPrefix] = value; a.uri = 'http://www.w3.org/2000/xmlns/'; domBuilder.startPrefixMapping(nsPrefix, value); } } var i = el.length; while (i--) { a = el[i]; var prefix = a.prefix; if (prefix) { //no prefix attribute has no namespace if (prefix === 'xml') { a.uri = 'http://www.w3.org/XML/1998/namespace'; } if (prefix !== 'xmlns') { a.uri = currentNSMap[prefix || '']; //{console.log('###'+a.qName,domBuilder.locator.systemId+'',currentNSMap,a.uri)} } } } var nsp = tagName.indexOf(':'); if (nsp > 0) { prefix = el.prefix = tagName.slice(0, nsp); localName = el.localName = tagName.slice(nsp + 1); } else { prefix = null; //important!! localName = el.localName = tagName; } //no prefix element has default namespace var ns = el.uri = currentNSMap[prefix || '']; domBuilder.startElement(ns, localName, tagName, el); //endPrefixMapping and startPrefixMapping have not any help for dom builder //localNSMap = null if (el.closed) { domBuilder.endElement(ns, localName, tagName); if (localNSMap) { for (prefix in localNSMap) { domBuilder.endPrefixMapping(prefix); } } } else { el.currentNSMap = currentNSMap; el.localNSMap = localNSMap; //parseStack.push(el); return true; } } function parseHtmlSpecialContent(source, elStartEnd, tagName, entityReplacer, domBuilder) { if (/^(?:script|textarea)$/i.test(tagName)) { var elEndStart = source.indexOf('', elStartEnd); var text = source.substring(elStartEnd + 1, elEndStart); if (/[&<]/.test(text)) { if (/^script$/i.test(tagName)) { //if(!/\]\]>/.test(text)){ //lexHandler.startCDATA(); domBuilder.characters(text, 0, text.length); //lexHandler.endCDATA(); return elEndStart; //} } //}else{//text area text = text.replace(/&#?\w+;/g, entityReplacer); domBuilder.characters(text, 0, text.length); return elEndStart; //} } } return elStartEnd + 1; } function fixSelfClosed(source, elStartEnd, tagName, closeMap) { //if(tagName in closeMap){ var pos = closeMap[tagName]; if (pos == null) { //console.log(tagName) pos = source.lastIndexOf(''); if (pos < elStartEnd) { //忘记闭合 pos = source.lastIndexOf('', start + 4); //append comment source.substring(4,end)//