"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getDeserializeResult = exports.getDependUUIDList = exports.generateEffectAsset = void 0; const path_1 = require("path"); module.paths.push((0, path_1.join)(Editor.App.path, 'node_modules')); const { AssetDB, forEach, Asset } = require('@editor/asset-db'); const effect_utils_1 = require("../effect-utils"); async function loadTexture(assetId) { return new Promise((resolve) => { cc.assetManager.loadAny(assetId, (error, asset) => { if (!error) { resolve(asset); } else { resolve(null); } }); }); } /** * 在 library 里生成对应的 effectAsset 对象 * @param asset 资源数据 * @param code */ // @ts-expect-error async function generateEffectAsset(asset, code) { const name = (0, path_1.basename)(asset.source, (0, path_1.extname)(asset.source)); const effect = await (0, effect_utils_1.buildEffect)(name, code); // 记录 effect 的头文件依赖 // @ts-expect-error forEach((db) => { for (const header of effect.dependencies) { asset.depend((0, path_1.resolve)(db.options.target, 'chunks', header + '.chunk')); } }); const result = new cc.EffectAsset(); Object.assign(result, effect); // 引擎数据结构不变,保留 hideInEditor 属性 if (effect.editor && effect.editor.hide) { result.hideInEditor = true; } for (let n = 0; n < result.techniques.length; n++) { const technique = result.techniques[n]; for (let i = 0; i < technique.passes.length; i++) { const pass = technique.passes[i]; for (const key in pass.properties) { const propInfo = pass.properties[key]; if (typeof propInfo.value === 'string') { const assetId = propInfo.value; if (Editor.Utils.UUID.isUUID(assetId)) { const asset = await loadTexture(assetId); if (asset) { propInfo.value = asset; } } } } } } // 添加 meta 文件中的 combinations if (asset.userData) { if (asset.userData.combinations) { result.combinations = asset.userData.combinations; } if (effect.editor) { asset.userData.editor = effect.editor; } else { // 已存在的需要清空 asset.userData.editor = undefined; } } const serializeJSON = EditorExtends.serialize(result); await asset.saveToLibrary('.json', serializeJSON); const depends = getDependUUIDList(serializeJSON); asset.setData('depends', depends); } exports.generateEffectAsset = generateEffectAsset; function getDependUUIDList(content, uuid) { if (typeof content === 'string') { // 注意:此方法无法匹配出脚本引用的 uuid let arr = content.match(/[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}(@[a-z0-9]+){0,}/g); if (arr) { // https://stackoverflow.com/questions/32813720/nodejs-profiling-parent-in-sliced-string arr = JSON.parse(JSON.stringify(Array.from(new Set(arr)).filter((id) => id !== uuid))); } // const arr = content.match(/"__uuid__":( )?"[^"]+/g); return arr || []; } // console.warn('Unable to extract dependencies properly'); return getDeserializeResult(content).uuids; } exports.getDependUUIDList = getDependUUIDList; function getDeserializeResult(json) { const deserializeDetails = new cc.deserialize.Details(); deserializeDetails.reset(); const MissingClass = EditorExtends.MissingReporter.classInstance; MissingClass.reset(); MissingClass.hasMissingClass = false; const dependScriptID = new Set(); function classFinder(classId) { if (Editor.Utils.UUID.isUUID(classId)) { dependScriptID.add(Editor.Utils.UUID.decompressUUID(classId)); } return MissingClass.classFinder(classId); } const deserializedAsset = cc.deserialize(json, deserializeDetails, { classFinder, }); deserializeDetails.assignAssetsBy(function (uuid, options) { return EditorExtends.serialize.asAsset(uuid); }); return { instance: deserializedAsset, uuids: deserializeDetails.uuidList, dependScriptUuids: Array.from(dependScriptID), classFinder: MissingClass.classFinder, }; } exports.getDeserializeResult = getDeserializeResult; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils-3.8.js","sourceRoot":"","sources":["../../src/importer/utils-3.8.ts"],"names":[],"mappings":"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","sourcesContent":["import { basename, extname, join, resolve } from 'path';\n\nmodule.paths.push(join(Editor.App.path, 'node_modules'));\n\nconst { AssetDB, forEach, Asset } = require('@editor/asset-db');\n\n// @ts-ignore\nimport { CCON } from 'cc/editor/serialization';\nimport { buildEffect } from '../effect-utils';\n\ndeclare const EditorExtends: any;\ndeclare const cc: any;\n\nasync function loadTexture(assetId: string): Promise<any | null> {\n    return new Promise((resolve) => {\n        cc.assetManager.loadAny(assetId, (error: any, asset: any) => {\n            if (!error) {\n                resolve(asset);\n            } else {\n                resolve(null);\n            }\n        });\n    });\n}\n\n/**\n * 在 library 里生成对应的 effectAsset 对象\n * @param asset 资源数据\n * @param code\n */\n// @ts-expect-error\nexport async function generateEffectAsset(asset: Asset, code: string){\n    const name = basename(asset.source, extname(asset.source));\n\n    const effect = await buildEffect(name, code);\n\n    // 记录 effect 的头文件依赖\n    // @ts-expect-error\n    forEach((db: AssetDB) => {\n        for (const header of effect.dependencies) {\n            asset.depend(resolve(db.options.target, 'chunks', header + '.chunk'));\n        }\n    });\n\n    const result = new cc.EffectAsset();\n    Object.assign(result, effect);\n\n    // 引擎数据结构不变，保留 hideInEditor 属性\n    if (effect.editor && effect.editor.hide) {\n        result.hideInEditor = true;\n    }\n\n    for (let n = 0; n < result.techniques.length; n++) {\n        const technique = result.techniques[n];\n        for (let i = 0; i < technique.passes.length; i++) {\n            const pass = technique.passes[i];\n            for (const key in pass.properties) {\n                const propInfo = pass.properties[key];\n                if (typeof propInfo.value === 'string') {\n                    const assetId = propInfo.value as string;\n                    if (Editor.Utils.UUID.isUUID(assetId)) {\n                        const asset = await loadTexture(assetId);\n                        if (asset) {\n                            propInfo.value = asset;\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    // 添加 meta 文件中的 combinations\n    if (asset.userData) {\n        if (asset.userData.combinations) {\n            result.combinations = asset.userData.combinations;\n        }\n\n        if (effect.editor) {\n            asset.userData.editor = effect.editor;\n        } else {\n            // 已存在的需要清空\n            asset.userData.editor = undefined;\n        }\n    }\n\n    const serializeJSON = EditorExtends.serialize(result);\n    await asset.saveToLibrary('.json', serializeJSON);\n\n    const depends = getDependUUIDList(serializeJSON);\n    asset.setData('depends', depends);\n}\n\nexport function getDependUUIDList(content: string | CCON | Object, uuid?: string) {\n    if (typeof content === 'string') {\n        // 注意：此方法无法匹配出脚本引用的 uuid\n        let arr = content.match(/[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}(@[a-z0-9]+){0,}/g);\n        if (arr) {\n            // https://stackoverflow.com/questions/32813720/nodejs-profiling-parent-in-sliced-string\n            arr = JSON.parse(JSON.stringify(Array.from(new Set(arr)).filter((id) => id !== uuid)));\n        }\n        // const arr = content.match(/\"__uuid__\":( )?\"[^\"]+/g);\n        return arr || [];\n    }\n    // console.warn('Unable to extract dependencies properly');\n\n    return getDeserializeResult(content).uuids;\n}\n\nexport function getDeserializeResult(json: CCON | Object) {\n    const deserializeDetails = new cc.deserialize.Details();\n    deserializeDetails.reset();\n    const MissingClass = EditorExtends.MissingReporter.classInstance;\n    MissingClass.reset();\n    MissingClass.hasMissingClass = false;\n    const dependScriptID = new Set();\n    function classFinder(classId: string) {\n        if (Editor.Utils.UUID.isUUID(classId)) {\n            dependScriptID.add(Editor.Utils.UUID.decompressUUID(classId));\n        }\n        return MissingClass.classFinder(classId);\n    }\n    const deserializedAsset = cc.deserialize(json, deserializeDetails, {\n        classFinder,\n    });\n    deserializeDetails.assignAssetsBy(function(uuid: string, options: { owner: object; prop: string; type: Function }) {\n        return EditorExtends.serialize.asAsset(uuid);\n    });\n    return {\n        instance: deserializedAsset,\n        uuids: deserializeDetails.uuidList,\n        dependScriptUuids: Array.from(dependScriptID),\n        classFinder: MissingClass.classFinder,\n    };\n}\n"]}