Skip to content

Commit

Permalink
fix: generating structs with correct boolean types
Browse files Browse the repository at this point in the history
  • Loading branch information
dafuga committed Aug 29, 2024
1 parent 6b74e4a commit 29b2501
Show file tree
Hide file tree
Showing 3 changed files with 800 additions and 12 deletions.
19 changes: 10 additions & 9 deletions src/commands/contract/structs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -337,7 +337,7 @@ function findFieldStructType(
): ts.Identifier | ts.StringLiteral {
const fieldTypeString = extractDecorator(findFieldTypeString(typeString, namespace, abi)).type

if (['string', 'string[]', 'boolean', 'boolean[]'].includes(fieldTypeString.toLowerCase())) {
if (['string', 'bool', 'boolean'].includes(fieldTypeString.toLowerCase())) {
return ts.factory.createStringLiteral(formatFieldString(fieldTypeString))
}

Expand All @@ -350,21 +350,22 @@ export function findFieldTypeString(
abi: ABI.Def
): string {
const fieldType = findInternalType(typeString, namespace, abi)
const {type: fieldTypeWithoutDecorator, decorator = ''} = extractDecorator(fieldType)

if (['String', 'Number'].includes(fieldType)) {
return fieldType.toLowerCase()
if (['String', 'Number'].includes(fieldTypeWithoutDecorator)) {
return `${fieldTypeWithoutDecorator.toLowerCase()}${decorator}`
}

if (fieldType === 'Bool') {
return 'boolean'
if (fieldTypeWithoutDecorator === 'Bool') {
return `boolean${decorator}`
}

if (fieldType === 'Symbol') {
return 'Asset.Symbol'
if (fieldTypeWithoutDecorator === 'Symbol') {
return `Asset.Symbol${decorator}`
}

if (fieldType === 'Symbol_code') {
return 'Asset.SymbolCode'
if (fieldTypeWithoutDecorator === 'Symbol_code') {
return `Asset.SymbolCode${decorator}`
}

return parseType(fieldType)
Expand Down
Loading

0 comments on commit 29b2501

Please sign in to comment.