Skip to content

Commit

Permalink
Naming + void* to struct* changes based on sky review, removed redund…
Browse files Browse the repository at this point in the history
…ant code, array handling fix
  • Loading branch information
HaseenaSainul committed Jul 10, 2023
1 parent e44476c commit 49f8975
Show file tree
Hide file tree
Showing 35 changed files with 403 additions and 266 deletions.
59 changes: 26 additions & 33 deletions languages/c/Types.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import deepmerge from 'deepmerge'
import { getPath } from '../../src/shared/json-schema.mjs'
import { getTypeName, getModuleName, description, getObjectHandleManagement, getNativeType, getPropertyAccessors, capitalize, isOptional, generateEnum, getMapAccessors, getArrayAccessors, getArrayElementSchema, getPropertyGetterSignature, getPropertyEventCallbackSignature, getPropertyEventRegisterSignature, getPropertyEventUnregisterSignature, getPropertySetterSignature, getFireboltStringType } from './src/types/NativeHelpers.mjs'
import { getArrayAccessorsImpl, getMapAccessorsImpl, getObjectHandleManagementImpl, getParameterInstantiation, getPropertyAccessorsImpl, getResultInstantiation, getCallbackParametersInstantiation, getCallbackResultInstantiation, getCallbackResponseInstantiation } from './src/types/ImplHelpers.mjs'
import { getJsonContainerDefinition, getJsonDataStructName } from './src/types/JSONHelpers.mjs'
import { getJsonContainerDefinition, getJsonDataStructName, getJsonDataPrefix } from './src/types/JSONHelpers.mjs'

const getSdkNameSpace = () => 'FireboltSDK'
const getJsonNativeTypeForOpaqueString = () => getSdkNameSpace() + '::JSON::String'
Expand Down Expand Up @@ -229,13 +229,13 @@ function getSchemaType(schema, module, { name, prefix = '', destination, resultS
return info.type
}

function getSchemaTypeInfo(module = {}, json = {}, name = '', schemas = {}, prefix = '', options = {level: 0, descriptions: true, title: false, resultSchema: false, event: false}) {
function getSchemaTypeInfo(module = {}, json = {}, name = '', schemas = {}, prefix = '', options = { level: 0, descriptions: true, title: false, resultSchema: false, event: false}) {

if (json.schema) {
json = json.schema
}

let stringAsHandle = options.resultSchema || options.event
let fireboltString = options.resultSchema || options.event

let structure = {}
structure["type"] = ''
Expand All @@ -259,17 +259,14 @@ function getSchemaTypeInfo(module = {}, json = {}, name = '', schemas = {}, pref
structure.json = res.json
structure.name = res.name
structure.namespace = res.namespace
return structure
}
}
else if (json.const) {
structure.type = getNativeType(json, stringAsHandle)
structure.type = getNativeType(json, fireboltString)
structure.json = json
return structure
}
else if (json['x-method']) {
console.log(`WARNING UNHANDLED: x-method in ${name}`)
return structure
//throw "x-methods not supported yet"
}
else if (json.type === 'string' && json.enum) {
Expand All @@ -280,13 +277,12 @@ function getSchemaTypeInfo(module = {}, json = {}, name = '', schemas = {}, pref
structure.json = json
structure.type = typeName
structure.namespace = getModuleName(module)
return structure
}
else if (Array.isArray(json.type)) {
let type = json.type.find(t => t !== 'null')
let sch = JSON.parse(JSON.stringify(json))
sch.type = type
return getSchemaTypeInfo(module, sch, name, schemas, prefix, options)
structure = getSchemaTypeInfo(module, sch, name, schemas, prefix, options)
}
else if (json.type === 'array' && json.items && (validJsonObjectProperties(json) === true)) {
let res = ''
Expand All @@ -303,57 +299,50 @@ function getSchemaTypeInfo(module = {}, json = {}, name = '', schemas = {}, pref
res = getSchemaTypeInfo(module, json.items, json.items.name || name, schemas, prefix)
}

let arrayName = capitalize(res.name) + capitalize(res.json.type)
let n = getTypeName(getModuleName(module), arrayName, prefix)
let n = getTypeName(getModuleName(module), capitalize(res.name), prefix)
structure.name = res.name || name && (capitalize(name))
structure.type = n + 'ArrayHandle'
structure.type = n + 'Array_t'
structure.json = json
structure.namespace = getModuleName(module)
return structure
}
else if (json.allOf) {
let title = json.title ? json.title : name
let union = deepMergeAll(module, title, json, schemas, options)
union['title'] = title

delete union['$ref']
return getSchemaTypeInfo(module, union, '', schemas, '', options)
structure = getSchemaTypeInfo(module, union, '', schemas, '', options)
}
else if (json.oneOf) {
structure.type = 'char*'
structure.type = fireboltString ? getFireboltStringType() : 'char*'
structure.json.type = 'string'
return structure
}
else if (json.anyOf) {
let mergedSchema = getMergedSchema(module, json, name, schemas)
let prefixName = ((prefix.length > 0) && (!name.startsWith(prefix))) ? prefix : capitalize(name)
return getSchemaTypeInfo(module, mergedSchema, '', schemas, prefixName, options)
structure = getSchemaTypeInfo(module, mergedSchema, '', schemas, prefixName, options)
}
else if (json.type === 'object') {
structure.json = json
if (hasProperties(json)) {
structure.type = getTypeName(getModuleName(module), json.title || name, prefix) + 'Handle'
structure.type = getTypeName(getModuleName(module), json.title || name, prefix) + '_t'
structure.name = (json.name ? json.name : (json.title ? json.title : name))
structure.namespace = (json.namespace ? json.namespace : getModuleName(module))
}
else {
structure.type = 'char*'
structure.type = fireboltString ? getFireboltStringType() : 'char*'
}
if (name) {
structure.name = capitalize(name)
}

return structure
}
else if (json.type) {
structure.type = getNativeType(json, stringAsHandle)
structure.type = getNativeType(json, fireboltString)
structure.json = json
if (name || json.title) {
structure.name = capitalize(name || json.title)
}
structure.namespace = getModuleName(module)

return structure
}
return structure
}
Expand All @@ -367,8 +356,9 @@ function getSchemaShapeInfo(json, module, schemas = {}, { name = '', prefix = ''
let shape = ''

if (destination && section) {
const isHeader = (destination.includes("JsonData_") !== true) && destination.endsWith(".h")
const isCPP = ((destination.endsWith(".cpp") || destination.includes("JsonData_")) && (section.includes('accessors') !== true))
const isHeader = (destination.includes(getJsonDataPrefix().toLowerCase()) !== true) && destination.endsWith(".h")
const isCPP = ((destination.endsWith(".cpp") || destination.includes(getJsonDataPrefix().toLowerCase())) && (section.includes('accessors') !== true))

json = JSON.parse(JSON.stringify(json))

name = json.title || name
Expand Down Expand Up @@ -429,14 +419,13 @@ function getSchemaShapeInfo(json, module, schemas = {}, { name = '', prefix = ''
let info = getSchemaTypeInfo(module, items, items.name || pname, schemas, prefix, {level : level, descriptions: descriptions, title: true})
if (info.type && info.type.length > 0) {
let objName = tName + '_' + capitalize(prop.title || pname)
let moduleName = info.namespace
info.json.namespace = info.namespace
let moduleProperty = getJsonTypeInfo(module, json, json.title || name, schemas, prefix)
let prefixName = ((prefix.length > 0) && items['$ref']) ? '' : prefix
let subModuleProperty = getJsonTypeInfo(module, info.json, info.name, schemas, prefix)

let t = description(capitalize(info.name), json.description) + '\n'
t += '\n' + (isHeader ? getArrayAccessors(objName, tName, info.type) : getArrayAccessorsImpl(tName, moduleProperty.type, (tName + 'Handle'), subModuleProperty.type, capitalize(pname || prop.title), info.type, info.json))
t += '\n' + (isHeader ? getArrayAccessors(objName, tName, info.type) : getArrayAccessorsImpl(tName, moduleProperty.type, (tName + '_t'), subModuleProperty.type, capitalize(pname || prop.title), info.type, info.json))
c_shape += '\n' + t
props.push({name: `${pname}`, type: `WPEFramework::Core::JSON::ArrayType<${subModuleProperty.type}>`})
}
Expand Down Expand Up @@ -539,10 +528,14 @@ function getSchemaShapeInfo(json, module, schemas = {}, { name = '', prefix = ''

if (info.type && info.type.length > 0) {
let type = getArrayElementSchema(json, module, schemas, info.name)
let arrayName = capitalize(name) + capitalize(type.type)
let objName = getTypeName(info.namespace, arrayName, prefix)
let arrayName = capitalize(info.name);
let namespace = info.namespace
if (type && type.type === 'object') {
namespace = getModuleName(module)
}
let objName = getTypeName(namespace, arrayName, prefix)
let tName = objName + 'Array'
let moduleName = info.namespace

info.json.namespace = info.namespace
let moduleProperty = getJsonTypeInfo(module, json, json.title || name, schemas, prefix)
let subModuleProperty = getJsonTypeInfo(module, j, j.title, schemas, prefix)
Expand All @@ -551,7 +544,7 @@ function getSchemaShapeInfo(json, module, schemas = {}, { name = '', prefix = ''
t += description(capitalize(info.name), json.description) + '\n'
t += '\n' + (isHeader ? getObjectHandleManagement(tName) : getObjectHandleManagementImpl(tName, moduleProperty.type))
}
t += '\n' + (isHeader ? getArrayAccessors(objName, tName, info.type) : getArrayAccessorsImpl(objName, moduleProperty.type, (tName + 'Handle'), subModuleProperty.type, '', info.type, info.json))
t += '\n' + (isHeader ? getArrayAccessors(objName, tName, info.type) : getArrayAccessorsImpl(objName, moduleProperty.type, (tName + '_t'), subModuleProperty.type, '', info.type, info.json))
shape += '\n' + t
}
}
Expand Down Expand Up @@ -759,7 +752,7 @@ function getSchemaInstantiation(schema, module, name, { instantiationType = '' }
}
else if (instantiationType === 'pull.param.name') {
let resultJsonType = getJsonType(schema, module, { name: name }) || ''
return resultJsonType && resultJsonType[0].split('_')[1] || ''
return resultJsonType.length && resultJsonType[0].split('_')[1] || ''
}

return ''
Expand Down
10 changes: 5 additions & 5 deletions languages/c/language.config.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@
"createModuleDirectories": false,
"extractSubSchemas": true,
"templatesPerModule": [
"/include/Module.h",
"/src/Module.cpp"
"/include/module.h",
"/src/module.cpp"
],
"templatesPerSchema": [
"/include/Common/Module.h",
"/src/Module_Common.cpp",
"/src/JsonData_Module.h"
"/include/common/module.h",
"/src/module_common.cpp",
"/src/jsondata_module.h"
],
"persistPermission": true
}
Loading

0 comments on commit 49f8975

Please sign in to comment.