Skip to content

Commit

Permalink
feat: Add a generator for all fields on a block. (#8667)
Browse files Browse the repository at this point in the history
* feat: Add a generator for all fields on a block.

* chore: Add docstring.
  • Loading branch information
gonfunko authored Jan 6, 2025
1 parent 503cd00 commit 956f272
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 58 deletions.
78 changes: 39 additions & 39 deletions core/block.ts
Original file line number Diff line number Diff line change
Expand Up @@ -937,10 +937,8 @@ export class Block implements IASTNodeLocation {
*/
setEditable(editable: boolean) {
this.editable = editable;
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
field.updateEditable();
}
for (const field of this.getFields()) {
field.updateEditable();
}
}

Expand Down Expand Up @@ -1107,29 +1105,37 @@ export class Block implements IASTNodeLocation {
' instead',
);
}
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
if (field.name === name) {
return field;
}
for (const field of this.getFields()) {
if (field.name === name) {
return field;
}
}
return null;
}

/**
* Returns a generator that provides every field on the block.
*
* @yields A generator that can be used to iterate the fields on the block.
*/
*getFields(): Generator<Field> {
for (const input of this.inputList) {
for (const field of input.fieldRow) {
yield field;
}
}
}

/**
* Return all variables referenced by this block.
*
* @returns List of variable ids.
*/
getVars(): string[] {
const vars: string[] = [];
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
if (field.referencesVariables()) {
// NOTE: This only applies to `FieldVariable`, a `Field<string>`
vars.push(field.getValue() as string);
}
for (const field of this.getFields()) {
if (field.referencesVariables()) {
vars.push(field.getValue());
}
}
return vars;
Expand All @@ -1143,17 +1149,15 @@ export class Block implements IASTNodeLocation {
*/
getVarModels(): IVariableModel<IVariableState>[] {
const vars = [];
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
if (field.referencesVariables()) {
const model = this.workspace.getVariableById(
field.getValue() as string,
);
// Check if the variable actually exists (and isn't just a potential
// variable).
if (model) {
vars.push(model);
}
for (const field of this.getFields()) {
if (field.referencesVariables()) {
const model = this.workspace.getVariableById(
field.getValue() as string,
);
// Check if the variable actually exists (and isn't just a potential
// variable).
if (model) {
vars.push(model);
}
}
}
Expand All @@ -1168,14 +1172,12 @@ export class Block implements IASTNodeLocation {
* @internal
*/
updateVarName(variable: IVariableModel<IVariableState>) {
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
if (
field.referencesVariables() &&
variable.getId() === field.getValue()
) {
field.refreshVariableName();
}
for (const field of this.getFields()) {
if (
field.referencesVariables() &&
variable.getId() === field.getValue()
) {
field.refreshVariableName();
}
}
}
Expand All @@ -1189,11 +1191,9 @@ export class Block implements IASTNodeLocation {
* updated name.
*/
renameVarById(oldId: string, newId: string) {
for (let i = 0, input; (input = this.inputList[i]); i++) {
for (let j = 0, field; (field = input.fieldRow[j]); j++) {
if (field.referencesVariables() && oldId === field.getValue()) {
field.setValue(newId);
}
for (const field of this.getFields()) {
if (field.referencesVariables() && oldId === field.getValue()) {
field.setValue(newId);
}
}
}
Expand Down
6 changes: 2 additions & 4 deletions core/block_svg.ts
Original file line number Diff line number Diff line change
Expand Up @@ -911,10 +911,8 @@ export class BlockSvg
icons[i].applyColour();
}

for (let x = 0, input; (input = this.inputList[x]); x++) {
for (let y = 0, field; (field = input.fieldRow[y]); y++) {
field.applyColour();
}
for (const field of this.getFields()) {
field.applyColour();
}
}

Expand Down
10 changes: 3 additions & 7 deletions core/serialization/blocks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -261,13 +261,9 @@ function saveIcons(block: Block, state: State, doFullSerialization: boolean) {
*/
function saveFields(block: Block, state: State, doFullSerialization: boolean) {
const fields = Object.create(null);
for (let i = 0; i < block.inputList.length; i++) {
const input = block.inputList[i];
for (let j = 0; j < input.fieldRow.length; j++) {
const field = input.fieldRow[j];
if (field.isSerializable()) {
fields[field.name!] = field.saveState(doFullSerialization);
}
for (const field of block.getFields()) {
if (field.isSerializable()) {
fields[field.name!] = field.saveState(doFullSerialization);
}
}
if (Object.keys(fields).length) {
Expand Down
12 changes: 4 additions & 8 deletions core/xml.ts
Original file line number Diff line number Diff line change
Expand Up @@ -168,14 +168,10 @@ function fieldToDom(field: Field): Element | null {
* @param element The XML element to which the field DOM should be attached.
*/
function allFieldsToDom(block: Block, element: Element) {
for (let i = 0; i < block.inputList.length; i++) {
const input = block.inputList[i];
for (let j = 0; j < input.fieldRow.length; j++) {
const field = input.fieldRow[j];
const fieldDom = fieldToDom(field);
if (fieldDom) {
element.appendChild(fieldDom);
}
for (const field of block.getFields()) {
const fieldDom = fieldToDom(field);
if (fieldDom) {
element.appendChild(fieldDom);
}
}
}
Expand Down

0 comments on commit 956f272

Please sign in to comment.