diff --git a/app/styles/play/level/tome/spell.sass b/app/styles/play/level/tome/spell.sass index 354c3dcb2..1784f8d83 100644 --- a/app/styles/play/level/tome/spell.sass +++ b/app/styles/play/level/tome/spell.sass @@ -138,35 +138,33 @@ background-image: url() background-position: 0px center - // .ace_gutter-cell.executing:not(.ace_error):not(.ace_warning):not(.ace_info):after - // - // // Experimenting with a larger executing-line-pointer - // content: "\e072" - // position: relative - // left: -39px - // font-family: 'Glyphicons Halflings' - // font-style: normal - // font-weight: normal - // color: white - // text-shadow: 0 0 5px black, 0 0 5px black, 0 0 5px black - // -webkit-font-smoothing: antialiased - // -moz-osx-font-smoothing: grayscale - // - // // Chrome likes these, but Firefox does not - // // TODO: Figure out how to make the executing gutter arrow big, and compatible - // display: inline-block - // top: -31px - // line-height: 1 - // font-size: 39px - .ace_gutter-cell.executed:not(.ace_error):not(.ace_warning):not(.ace_info) margin-left: 1px background-image: url() background-position: 0px center - .ace_gutter-cell.comment-line - background-position: 0px center - background-image: url() + .ace_gutter-cell.entry-point:after + content: attr(data-content) + display: inline-block + position: relative + left: -49px + width: 49px + top: -30px + height: 38px + overflow: visible + + color: white + line-height: 39px + font-size: 16px + text-align: center + text-shadow: -1px 0 2px black, 1px 0 2px black, 0 -1px 2px black, 0 1px 2px black + -webkit-font-smoothing: antialiased + -moz-osx-font-smoothing: grayscale + + background-image: url() + + .ace_gutter-cell.entry-point:not(.next-entry-point):after + opacity: 0.5 .ace_marker-layer .ace_bracket diff --git a/app/views/play/level/tome/SpellView.coffee b/app/views/play/level/tome/SpellView.coffee index 28f40991c..4f225b941 100644 --- a/app/views/play/level/tome/SpellView.coffee +++ b/app/views/play/level/tome/SpellView.coffee @@ -917,7 +917,7 @@ module.exports = class SpellView extends CocoView highlightCurrentLine: (flow) => # TODO: move this whole thing into SpellDebugView or somewhere? - @highlightComments() unless @destroyed + @highlightEntryPoints() unless @destroyed flow ?= @spellThang?.castAether?.flow return unless flow and @thang executed = [] @@ -985,7 +985,7 @@ module.exports = class SpellView extends CocoView markerRange.end = @aceDoc.createAnchor markerRange.end markerRange.id = @aceSession.addMarker markerRange, clazz, markerType @markerRanges.push markerRange - if executedRows[start.row] and @decoratedGutter[start.row] isnt clazz + if false and executedRows[start.row] and @decoratedGutter[start.row] isnt clazz @aceSession.removeGutterDecoration start.row, @decoratedGutter[start.row] if @decoratedGutter[start.row] isnt '' @aceSession.addGutterDecoration start.row, clazz @decoratedGutter[start.row] = clazz @@ -993,17 +993,27 @@ module.exports = class SpellView extends CocoView @debugView?.setVariableStates {} unless gotVariableStates null - highlightComments: -> - return # Slightly buggy and not that great, so let's not do it. - lines = $(@ace.container).find('.ace_text-layer .ace_line_group') + highlightEntryPoints: -> + lines = @aceDoc.$lines session = @aceSession top = Math.floor @ace.renderer.getScrollTopRow() - $(@ace.container).find('.ace_gutter-cell').each (index, el) -> - line = $(lines[index]) - index = index - top - session.removeGutterDecoration index, 'comment-line' - if line.find('.ace_comment').length - session.addGutterDecoration index, 'comment-line' + seenOne = false + entryPointLines = [] + for line, index in lines + session.removeGutterDecoration index, 'entry-point' + session.removeGutterDecoration index, 'next-entry-point' + if line.indexOf('if') isnt -1 + session.addGutterDecoration index, "entry-point" + if not seenOne + session.addGutterDecoration index, 'next-entry-point' + seenOne = true + entryPointLines.push index + scrolledAwayLines = 0 + #while entryPointLines.length and entryPointLines[0] < top + # entryPointLines.shift() + # ++scrolledAwayLines + $(@ace.container).find('.ace_gutter-cell.entry-point').each (index, el) -> + $(el).attr('data-content', scrolledAwayLines + index + 1) onAnnotationClick: -> # @ is the gutter element