mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-27 09:35:39 -05:00
Updated to new Aether range info, fixing error line numbers.
This commit is contained in:
parent
912b6140ac
commit
738b791683
9 changed files with 21 additions and 18 deletions
|
@ -28,7 +28,6 @@ module.exports = class WizardSprite extends IndieSprite
|
|||
super thangType, options
|
||||
@isSelf = options.isSelf
|
||||
@targetPos = @thang.pos
|
||||
console.log "have @targetPos", @targetPos
|
||||
if @isSelf
|
||||
@setNameLabel me.displayName()
|
||||
@setColorHue me.get('wizardColor1')
|
||||
|
|
|
@ -24,6 +24,9 @@
|
|||
&:hover, &:focus
|
||||
@include opacity(1)
|
||||
|
||||
.problem-hint
|
||||
font-size: 80%
|
||||
|
||||
//&.alert-error
|
||||
|
||||
&.alert-warning
|
||||
|
|
|
@ -83,7 +83,7 @@
|
|||
.problem-marker-error
|
||||
background-color: rgba(110, 45, 27, 0.25)
|
||||
|
||||
.ace_gutter-cell.executing
|
||||
.ace_gutter-cell.executing:not(.ace_error)
|
||||
margin-left: 1px
|
||||
background-image: url()
|
||||
background-position: 0px center
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
button.close(type="button", data-dismiss="alert") ×
|
||||
span
|
||||
!= message
|
||||
span.problem-message= message
|
||||
if hint
|
||||
br
|
||||
span.problem-hint= hint
|
|
@ -20,8 +20,8 @@ module.exports = class Problem
|
|||
text = @aetherProblem.message.replace /^Line \d+: /, ''
|
||||
start = @aetherProblem.ranges[0][0]
|
||||
@annotation =
|
||||
row: start[0],
|
||||
column: start[1],
|
||||
row: start.row,
|
||||
column: start.col,
|
||||
raw: text,
|
||||
text: text,
|
||||
type: @aetherProblem.level ? "error"
|
||||
|
@ -35,7 +35,7 @@ module.exports = class Problem
|
|||
return unless @aetherProblem.ranges
|
||||
[start, end] = @aetherProblem.ranges[0]
|
||||
clazz = "problem-marker-#{@aetherProblem.level}"
|
||||
@markerRange = new Range(start[0], start[1], end[0], end[1])
|
||||
@markerRange = new Range start.row, start.col, end.row, end.col
|
||||
@markerRange.start = @ace.getSession().getDocument().createAnchor @markerRange.start
|
||||
@markerRange.end = @ace.getSession().getDocument().createAnchor @markerRange.end
|
||||
@markerRange.id = @ace.getSession().addMarker @markerRange, clazz, "text"
|
||||
|
|
|
@ -18,6 +18,7 @@ module.exports = class ProblemAlertView extends View
|
|||
getRenderData: (context={}) =>
|
||||
context = super context
|
||||
context.message = @problem.aetherProblem.message.replace("\n", "<br>")
|
||||
context.hint = @problem.aetherProblem.hint?.replace("\n", "<br>")
|
||||
context
|
||||
|
||||
afterRender: ->
|
||||
|
|
|
@ -65,6 +65,7 @@ module.exports = class Spell
|
|||
aetherOptions =
|
||||
problems:
|
||||
jshint_W040: {level: "ignore"}
|
||||
jshint_W030: {level: "ignore"} # aether_NoEffect instead
|
||||
aether_MissingThis: {level: (if thang.requiresThis then 'error' else 'warning')}
|
||||
functionName: @name
|
||||
functionParameters: @parameters
|
||||
|
|
|
@ -288,10 +288,12 @@ module.exports = class SpellView extends View
|
|||
return unless aether = @spellThang?.aether
|
||||
source = @getSource()
|
||||
codeHasChangedSignificantly = force or @spell.hasChangedSignificantly source, aether.raw
|
||||
return unless codeHasChangedSignificantly or @spellThang isnt @lastUpdatedAetherSpellThang
|
||||
needsUpdate = codeHasChangedSignificantly or @spellThang isnt @lastUpdatedAetherSpellThang
|
||||
return if not needsUpdate and aether is @displayedAether
|
||||
castAether = @spellThang.castAether
|
||||
codeIsAsCast = castAether and not @spell.hasChangedSignificantly source, castAether.raw
|
||||
aether = castAether if codeIsAsCast
|
||||
return if not needsUpdate and aether is @displayedAether
|
||||
|
||||
# Now that that's figured out, perform the update.
|
||||
@clearAetherDisplay()
|
||||
|
@ -307,6 +309,7 @@ module.exports = class SpellView extends View
|
|||
@highlightCurrentLine {} # This'll remove all highlights
|
||||
|
||||
displayAether: (aether) ->
|
||||
@displayedAether = aether
|
||||
isCast = not _.isEmpty(aether.metrics) or _.some aether.problems.errors, {type: 'runtime'}
|
||||
@problems = []
|
||||
annotations = []
|
||||
|
@ -379,7 +382,7 @@ module.exports = class SpellView extends View
|
|||
#console.log thangID, "got new castAether with raw", aether.raw, "problems", aether.problems
|
||||
spellThang.castAether = aether
|
||||
spellThang.aether = @spell.createAether e.world.getThangByID(thangID)
|
||||
console.log thangID, @spell.spellKey, "ran", aether.metrics.callsExecuted, "times over", aether.metrics.statementsExecuted, "statements, with max recursion depth", aether.metrics.maxDepth, "and full flow/metrics", aether.metrics, aether.flow
|
||||
#console.log thangID, @spell.spellKey, "ran", aether.metrics.callsExecuted, "times over", aether.metrics.statementsExecuted, "statements, with max recursion depth", aether.metrics.maxDepth, "and full flow/metrics", aether.metrics, aether.flow
|
||||
@spell.transpile()
|
||||
@updateAether false, false
|
||||
|
||||
|
@ -427,12 +430,6 @@ module.exports = class SpellView extends View
|
|||
#console.log "got call index", currentCallIndex, "for time", @thang.world.age, "out of", states.length
|
||||
|
||||
# TODO: don't redo the markers if they haven't actually changed
|
||||
text = @aceDoc.getValue()
|
||||
offsetToPos = (offset) ->
|
||||
# TODO: use the nice conversion utils David put into Aether
|
||||
rows = text.substr(0, offset).split '\n'
|
||||
{row: rows.length - 1, column: _.last(rows).length}
|
||||
|
||||
for markerRange in (@markerRanges ?= [])
|
||||
markerRange.start.detach()
|
||||
markerRange.end.detach()
|
||||
|
@ -451,7 +448,7 @@ module.exports = class SpellView extends View
|
|||
marked = {}
|
||||
lastExecuted = lastExecuted[0 .. @toolbarView.statementIndex] if @toolbarView?.statementIndex?
|
||||
for state, i in lastExecuted
|
||||
[start, end] = [offsetToPos(state.range[0]), offsetToPos(state.range[1])]
|
||||
[start, end] = state.range
|
||||
clazz = if i is lastExecuted.length - 1 then 'executing' else 'executed'
|
||||
if clazz is 'executed'
|
||||
continue if marked[start.row]
|
||||
|
@ -460,7 +457,7 @@ module.exports = class SpellView extends View
|
|||
else
|
||||
@debugView.setVariableStates state.variables
|
||||
markerType = "text"
|
||||
markerRange = new Range(start.row, start.column, end.row, end.column)
|
||||
markerRange = new Range start.row, start.col, end.row, end.col
|
||||
markerRange.start = @aceDoc.createAnchor markerRange.start
|
||||
markerRange.end = @aceDoc.createAnchor markerRange.end
|
||||
markerRange.id = @aceSession.addMarker markerRange, clazz, markerType
|
||||
|
|
|
@ -32,7 +32,7 @@
|
|||
"firepad": "~0.1.2",
|
||||
"marked": "~0.3.0",
|
||||
"moment": "~2.5.0",
|
||||
"aether": "~0.0.9",
|
||||
"aether": "~0.1.2",
|
||||
"underscore.string": "~2.3.3",
|
||||
"firebase": "~1.0.2"
|
||||
},
|
||||
|
|
Loading…
Reference in a new issue