mirror of
https://github.com/esiur/esiur-js.git
synced 2026-04-03 21:48:21 +00:00
Cleanup
This commit is contained in:
@@ -30,7 +30,6 @@ import IEventHandler from '../Core/IEventHandler.js';
|
||||
import IPermissionsManager from '../Security/Permissions/IPermissionsManager.js';
|
||||
import AutoList from '../Data/AutoList.js';
|
||||
import KeyList from '../Data/KeyList.js';
|
||||
import Structure from '../Data/Structure.js';
|
||||
import PropertyValue from '../Data/PropertyValue.js';
|
||||
import CustomResourceEvent from './CustomResourceEvent.js';
|
||||
import Warehouse from './Warehouse.js';
|
||||
@@ -293,7 +292,7 @@ export default class Instance extends IEventHandler
|
||||
|
||||
getAttributes(attributes = null)
|
||||
{
|
||||
var st = new Structure();
|
||||
var st = new (TypedMap.of(String, Object))();
|
||||
|
||||
if (attributes == null)
|
||||
{
|
||||
@@ -306,7 +305,7 @@ export default class Instance extends IEventHandler
|
||||
var attr = attributes[i];
|
||||
|
||||
if (attr == "name")
|
||||
st["name"] = this.name;
|
||||
st.set("name", this.name);
|
||||
|
||||
else if (attr == "managers")
|
||||
{
|
||||
@@ -322,11 +321,11 @@ export default class Instance extends IEventHandler
|
||||
mngrs.push(sm);
|
||||
}
|
||||
|
||||
st["managers"] = mngrs;
|
||||
st.set("managers", mngrs);
|
||||
|
||||
}
|
||||
else
|
||||
st[attr] = this.attributes.item(attr);
|
||||
st.set(attr, this.attributes.item(attr));
|
||||
}
|
||||
|
||||
return st;
|
||||
|
||||
@@ -1,137 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2017 Ahmed Kh. Zamil
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
* of this software and associated documentation files (the "Software"), to deal
|
||||
* in the Software without restriction, including without limitation the rights
|
||||
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
* copies of the Software, and to permit persons to whom the Software is
|
||||
* furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in all
|
||||
* copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
* SOFTWARE.
|
||||
*/
|
||||
|
||||
"use strict";
|
||||
|
||||
import {DC, BL} from '../../Data/DC.js';
|
||||
import DataType from "../../Data/DataType.js";
|
||||
import Structure from '../../Data/Structure.js';
|
||||
import IResource from '../IResource.js';
|
||||
import TypeTemplate from './TypeTemplate.js';
|
||||
import IRecord from '../../Data/IRecord.js';
|
||||
|
||||
export default class TemplateDataType
|
||||
{
|
||||
|
||||
static typesDefinitions = [
|
||||
"var",
|
||||
"bool",
|
||||
"sbyte",
|
||||
"byte",
|
||||
"char",
|
||||
"short",
|
||||
"ushort",
|
||||
"int",
|
||||
"uint",
|
||||
"long",
|
||||
"ulong",
|
||||
"float",
|
||||
"double",
|
||||
"decimal",
|
||||
"date",
|
||||
"resource",
|
||||
"DistributedResource",
|
||||
"ResourceLink",
|
||||
"string",
|
||||
"structure"
|
||||
];
|
||||
|
||||
get typeTemplate() {
|
||||
return this.typeGuid == null ? null : Warehouse.getTemplateByType(this.typeGuid);
|
||||
}
|
||||
|
||||
//@TODO: implement this
|
||||
static fromType(type)
|
||||
{
|
||||
var isArray = type instanceof Array;
|
||||
if (isArray)
|
||||
type = type[0]
|
||||
|
||||
var dataType = 0;
|
||||
var typeGuid = null;
|
||||
|
||||
|
||||
if (!isNaN(type))
|
||||
dataType = type;
|
||||
else if (type == Structure)
|
||||
dataType = DataType.Structure;
|
||||
else if (typeof type == "string")
|
||||
{
|
||||
var tIndex = this.typesDefinitions.indexOf(type);
|
||||
dataType = tIndex > -1 ? tIndex : 0;
|
||||
}
|
||||
else if (type?.prototype instanceof IResource)
|
||||
{
|
||||
dataType = DataType.Resource;
|
||||
typeGuid = TypeTemplate.getTypeGuid(type);
|
||||
}
|
||||
else if (type?.prototype instanceof IRecord)
|
||||
{
|
||||
dataType = DataType.Record;
|
||||
typeGuid = TypeTemplate.getTypeGuid(type);
|
||||
}
|
||||
|
||||
if (isArray)
|
||||
dataType |= DataType.VarArray;
|
||||
|
||||
return new TemplateDataType(DataType.StructureArray);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
compose()
|
||||
{
|
||||
if (this.type == DataType.Resource ||
|
||||
this.type == DataType.ResourceArray ||
|
||||
this.type == DataType.Record ||
|
||||
this.type == DataType.RecordArray)
|
||||
{
|
||||
return BL()
|
||||
.addUint8(this.type)
|
||||
.addUint8Array(this.typeGuid)
|
||||
.toDC();
|
||||
}
|
||||
else
|
||||
return DC.from([this.type]);
|
||||
}
|
||||
|
||||
constructor(type, guid){
|
||||
this.type = type;
|
||||
this.typeGuid = guid;
|
||||
}
|
||||
|
||||
static parse(data, offset)
|
||||
{
|
||||
var type = data.getUint8(offset++);
|
||||
if (type == DataType.Resource ||
|
||||
type == DataType.ResourceArray ||
|
||||
type == DataType.Record ||
|
||||
type == DataType.RecordArray)
|
||||
{
|
||||
var guid = data.getGuid(offset);
|
||||
return {size: 17, value: new TemplateDataType(type, guid)};
|
||||
}
|
||||
else
|
||||
return {size: 1, value: new TemplateDataType(type)};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user