Skip to content

Commit

Permalink
Fix bad rendering of collapsed function calls.
Browse files Browse the repository at this point in the history
  • Loading branch information
NeilFraser committed Feb 10, 2015
1 parent d05177e commit b36a88f
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 23 deletions.
39 changes: 25 additions & 14 deletions blocks/procedures.js
Original file line number Diff line number Diff line change
Expand Up @@ -273,7 +273,7 @@ Blockly.Blocks['procedures_defnoreturn'] = {
if (change) {
this.updateParams_();
// Update the mutator's variables if the mutator is open.
if (this.mutator.isVisible_()) {
if (this.mutator.isVisible()) {
var blocks = this.mutator.workspace_.getAllBlocks();
for (var i = 0, block; block = blocks[i]; i++) {
if (block.type == 'procedures_mutatorarg' &&
Expand Down Expand Up @@ -428,10 +428,9 @@ Blockly.Blocks['procedures_callnoreturn'] = {
init: function() {
this.setHelpUrl(Blockly.Msg.PROCEDURES_CALLNORETURN_HELPURL);
this.setColour(Blockly.Blocks.procedures.HUE);
this.appendDummyInput()
this.appendDummyInput('TOPROW')
.appendField(Blockly.Msg.PROCEDURES_CALLNORETURN_CALL)
.appendField('', 'NAME')
.appendField(Blockly.Msg.PROCEDURES_CALL_BEFORE_PARAMS, 'WITH');
.appendField('', 'NAME');
this.setPreviousStatement(true);
this.setNextStatement(true);
// Tooltip is set in domToMutation.
Expand Down Expand Up @@ -488,6 +487,12 @@ Blockly.Blocks['procedures_callnoreturn'] = {
this.quarkArguments_ = null;
return;
}
if (goog.array.equals(this.arguments_, paramNames)) {
// No change.
this.quarkArguments_ = paramIds;
return;
}
this.setCollapsed(false);
if (paramIds.length != paramNames.length) {
throw 'Error: paramNames and paramIds must be the same length.';
}
Expand Down Expand Up @@ -536,14 +541,21 @@ Blockly.Blocks['procedures_callnoreturn'] = {
}
}
}
if (savedRendered) {
input.init();
}
input.init();
}
// Add 'with:' if there are parameters.
var withField = this.getField_('WITH');
if (withField) {
withField.setVisible(!!this.arguments_.length);
var input = this.getInput('TOPROW');
if (input) {
if (this.arguments_.length) {
if (!this.getField_('WITH')) {
input.appendField(Blockly.Msg.PROCEDURES_CALL_BEFORE_PARAMS, 'WITH');
input.init();
}
} else {
if (this.getField_('WITH')) {
input.removeField('WITH');
}
}
}
// Restore rendering and show the changes.
this.rendered = savedRendered;
Expand Down Expand Up @@ -578,7 +590,7 @@ Blockly.Blocks['procedures_callnoreturn'] = {
(this.outputConnection ? Blockly.Msg.PROCEDURES_CALLRETURN_TOOLTIP :
Blockly.Msg.PROCEDURES_CALLNORETURN_TOOLTIP).replace('%1', name));
var def = Blockly.Procedures.getDefinition(name, this.workspace);
if (def && def.mutator.isVisible()) {
if (def && def.mutator && def.mutator.isVisible()) {
// Initialize caller with the mutator's IDs.
this.setProcedureParameters(def.arguments_, def.paramIds_);
} else {
Expand Down Expand Up @@ -634,10 +646,9 @@ Blockly.Blocks['procedures_callreturn'] = {
init: function() {
this.setHelpUrl(Blockly.Msg.PROCEDURES_CALLRETURN_HELPURL);
this.setColour(Blockly.Blocks.procedures.HUE);
this.appendDummyInput()
this.appendDummyInput('TOPROW')
.appendField(Blockly.Msg.PROCEDURES_CALLRETURN_CALL)
.appendField('', 'NAME')
.appendField(Blockly.Msg.PROCEDURES_CALL_BEFORE_PARAMS, 'WITH');
.appendField('', 'NAME');
this.setOutput(true);
// Tooltip is set in domToMutation.
this.arguments_ = [];
Expand Down
18 changes: 9 additions & 9 deletions blocks_compressed.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit b36a88f

Please sign in to comment.