Skip to content
This repository has been archived by the owner on Mar 3, 2023. It is now read-only.

Add event subscription methods for Editor and associated classes #3456

Merged
merged 59 commits into from
Sep 9, 2014
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
b731f7c
Add Editor::onDidChangeTitle
Sep 4, 2014
133f3f4
Add Editor::onDidChangePath
Sep 4, 2014
d15d157
Add Editor::onDidChangeModified
Sep 4, 2014
965afc2
Rename softWrap to softWrapped
Sep 4, 2014
3e260ee
Add Editor::onDidChangeSoftWrapped
Sep 4, 2014
1c95a55
Add ::onDidChangeGrammar to Editor, DisplayBuffer, and TokenizedBuffer
Sep 4, 2014
5a02303
Add Editor::onDidStopChanging which delegates to TextBuffer
Sep 4, 2014
63c9da0
Add Editor::onDidConflict
Sep 4, 2014
05ea381
Add Editor::onWill/DidInsertText
Sep 4, 2014
2a81687
Add Editor::onDidMoveCursor
Sep 4, 2014
161edfd
Remove ‘cursors-moved’ event
Sep 4, 2014
3b6e40f
Add Editor::onDidAddCursor
Sep 4, 2014
e77b4a5
Add Editor::onDidRemoveCursor
Sep 4, 2014
3e77b9b
Eliminate Editor::onDidMoveCursor
Sep 4, 2014
651eb78
Add Editor::onDidAdd/RemoveSelection
Sep 4, 2014
1131b33
Add DisplayBufferMarker::onDidChange and ::onDidDestroy
Sep 4, 2014
c69b5fc
Remove specs for ::onDidMoveCursor, which was removed
Sep 4, 2014
6bd8702
Deprecate DisplayBufferMarker::on
Sep 4, 2014
5668702
Add Cursor::onDidChangePosition and ::onDidDestroy and deprecate ::on
Sep 4, 2014
6ad9531
Add Selection::onDidChangeRange and ::onDidDestroy and deprecate ::on
Sep 4, 2014
569c403
Update the events on decorations
benogle Sep 5, 2014
9435f85
Use new decoration updated event method
benogle Sep 5, 2014
bcc6adf
No longer need this as the event method passes it through
benogle Sep 5, 2014
48a68d8
Add TextBuffer::onDidChange
benogle Sep 5, 2014
a2adbff
Add TokenizedBuffer::onDidTokenize
benogle Sep 5, 2014
53fbfb8
Merge decoration-changed and decoration-updated
benogle Sep 5, 2014
289b22c
Use event methods in TokenizedBuffer spec
benogle Sep 5, 2014
0a920b1
Update TokenizedBUffer::on deprecations
benogle Sep 5, 2014
557562d
Fix linter error
benogle Sep 5, 2014
db84b79
fix another linter error
benogle Sep 5, 2014
21e4d8a
Add DisplayBuffer::onDidChange
benogle Sep 5, 2014
6e8a626
Add ::onDidChangeSoftWrapped to DisplayBuffer and Editor
benogle Sep 5, 2014
f3e8f11
Use DisplayBuffer::onDidChangeSoftWrapped in Editor
benogle Sep 5, 2014
e6e6028
Deprecate decoration events
benogle Sep 5, 2014
7ae25d3
Decoration Params -> Properties
benogle Sep 5, 2014
aeffef3
Directly subscribe to the decorations in EditorComponent
benogle Sep 5, 2014
86e9778
Remove the decoration changed event
benogle Sep 5, 2014
47ef54a
Subscribe directly to the decoration destroy for removal
benogle Sep 5, 2014
e6dbea0
Add onDidCreateMarker and onDidUpdateMarkers
benogle Sep 6, 2014
250c21f
Deprecate all events from ::on
benogle Sep 6, 2014
8aa1784
Add Editor::onDidChangeScreenLines
benogle Sep 8, 2014
efea168
Add deprecation warnings for all the other converted events
benogle Sep 8, 2014
b6a9e1b
Fix deprecation warning
benogle Sep 8, 2014
6f9f087
:lipstick: consistency
benogle Sep 8, 2014
d4835e1
Add Editor:onScrollTopChanged and Editor:onScrollLeftChanged
benogle Sep 8, 2014
601b311
Add Editor::onDidMoveCursor
benogle Sep 8, 2014
1d07317
Add Editor::onDidChangeSelectedScreenRange
benogle Sep 8, 2014
5883e27
Make Editor::onDidChangeGrammar emit from Editor
benogle Sep 8, 2014
aebdfb4
Event docs
benogle Sep 9, 2014
7198a91
onDidMoveCursor -> onDidChangeCursorPosition
benogle Sep 9, 2014
c7525e8
:lipstick: doc strings
benogle Sep 9, 2014
9db804b
Doc events in `Cursor`
benogle Sep 9, 2014
858ac5b
onDidChangeSelectionScreenRange -> onDidChangeSelectionRange
benogle Sep 9, 2014
789d9c8
:memo: Selection event methods
benogle Sep 9, 2014
72be167
isDestroyed -> destroyed
benogle Sep 9, 2014
3e5666f
use getPaneView rather than getPane
benogle Sep 9, 2014
0f83fe5
Add and use Editor::observeSelections() and ::observeCursors()
benogle Sep 9, 2014
e452b88
Add sections for events
benogle Sep 9, 2014
2a02375
Move the Decoration events to an events section
benogle Sep 9, 2014
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Deprecate decoration events
  • Loading branch information
benogle committed Sep 5, 2014
commit e6e60286833f70b720a419bc17c8075fb01ccb1a
2 changes: 1 addition & 1 deletion spec/display-buffer-spec.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -1074,7 +1074,7 @@ describe "DisplayBuffer", ->

describe "when a decoration is updated via Decoration::update()", ->
it "emits an 'updated' event containing the new and old params", ->
decoration.onDidUpdate updatedSpy = jasmine.createSpy()
decoration.onDidChange updatedSpy = jasmine.createSpy()
decoration.update type: 'gutter', class: 'two'

{oldParams, newParams} = updatedSpy.mostRecentCall.args[0]
Expand Down
10 changes: 5 additions & 5 deletions src/decoration.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ class Decoration
# * `event` {Object}
# * `oldParams` {Object} the old parameters the decoration used to have
# * `newParams` {Object} the new parameters the decoration now has
onDidUpdate: (callback) ->
@emitter.on 'did-update', callback
onDidChange: (callback) ->
@emitter.on 'did-change', callback

# Essential: Update the marker with new params. Allows you to change the decoration's class.
#
Expand All @@ -94,9 +94,9 @@ class Decoration
oldParams = @params
@params = newParams
@params.id = @id
@displayBuffer.decorationUpdated(this)
@displayBuffer.decorationChanged(this)
@emit 'updated', {oldParams, newParams}
@emitter.emit 'did-update', {oldParams, newParams}
@emitter.emit 'did-change', {oldParams, newParams}

# Essential: Invoke the given callback when the {Decoration} is destroyed
onDidDestroy: (callback) ->
Expand Down Expand Up @@ -137,7 +137,7 @@ class Decoration
on: (eventName) ->
switch eventName
when 'updated'
Grim.deprecate("Use Decoration::onDidUpdate instead")
Grim.deprecate("Use Decoration::onDidChange instead")
when 'destroyed'
Grim.deprecate("Use Decoration::onDidDestroy instead")
when 'flash'
Expand Down
29 changes: 26 additions & 3 deletions src/display-buffer.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,15 @@ class DisplayBuffer extends Model
onDidChangeCharacterWidths: (callback) ->
@emitter.on 'did-change-character-widths', callback

onDidAddDecoration: (callback) ->
@emitter.on 'did-add-decoration', callback

onDidRemoveDecoration: (callback) ->
@emitter.on 'did-remove-decoration', callback

onDidChangeDecoration: (callback) ->
@emitter.on 'did-change-decoration', callback

on: (eventName) ->
switch eventName
when 'changed'
Expand All @@ -122,6 +131,14 @@ class DisplayBuffer extends Model
Grim.deprecate("Use DisplayBuffer::onDidChangeSoftWrap instead")
when 'character-widths-changed'
Grim.deprecate("Use DisplayBuffer::onDidChangeCharacterWidths instead")
when 'decoration-added'
Grim.deprecate("Use DisplayBuffer::onDidAddDecoration instead")
when 'decoration-removed'
Grim.deprecate("Use DisplayBuffer::onDidRemoveDecoration instead")
when 'decoration-changed'
Grim.deprecate("Use DisplayBuffer::onDidChangeDecoration instead")
when 'decoration-updated'
Grim.deprecate("Use DisplayBuffer::onDidChangeDecoration instead")
# else
# Grim.deprecate("DisplayBuffer::on is deprecated. Use event subscription methods instead.")

Expand Down Expand Up @@ -823,13 +840,15 @@ class DisplayBuffer extends Model
# in the change handler. Bookmarks does this.
if decorations?
for decoration in decorations
@emit 'decoration-updated', decoration
@emit 'decoration-changed', decoration
@emitter.emit 'did-change-decoration', decoration

decoration = new Decoration(marker, this, decorationParams)
@decorationsByMarkerId[marker.id] ?= []
@decorationsByMarkerId[marker.id].push(decoration)
@decorationsById[decoration.id] = decoration
@emit 'decoration-added', decoration
@emitter.emit 'did-add-decoration', decoration
decoration

removeDecoration: (decoration) ->
Expand All @@ -841,12 +860,14 @@ class DisplayBuffer extends Model
decorations.splice(index, 1)
delete @decorationsById[decoration.id]
@emit 'decoration-removed', decoration
@emitter.emit 'did-remove-decoration', decoration
@removedAllMarkerDecorations(marker) if decorations.length is 0

removeAllDecorationsForMarker: (marker) ->
decorations = @decorationsByMarkerId[marker.id].slice()
for decoration in decorations
@emit 'decoration-removed', decoration
@emitter.emit 'did-remove-decoration', decoration
@removedAllMarkerDecorations(marker)

removedAllMarkerDecorations: (marker) ->
Expand All @@ -857,8 +878,10 @@ class DisplayBuffer extends Model
delete @decorationMarkerChangedSubscriptions[marker.id]
delete @decorationMarkerDestroyedSubscriptions[marker.id]

decorationUpdated: (decoration) ->
@emit 'decoration-updated', decoration
# Called by the decoration
decorationChanged: (decoration) ->
@emit 'decoration-changed', decoration
@emitter.emit 'did-change-decoration', decoration

# Retrieves a {DisplayBufferMarker} based on its id.
#
Expand Down
6 changes: 3 additions & 3 deletions src/editor-component.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -347,9 +347,9 @@ EditorComponent = React.createClass
@subscribe editor, 'screen-lines-changed', @onScreenLinesChanged
@subscribe editor.onDidAddCursor(@onCursorAdded)
@subscribe editor.onDidAddSelection(@onSelectionAdded)
@subscribe editor, 'decoration-added', @onDecorationChanged
@subscribe editor, 'decoration-removed', @onDecorationChanged
@subscribe editor, 'decoration-updated', @onDecorationChanged
@subscribe editor.onDidAddDecoration @onDecorationChanged
@subscribe editor.onDidRemoveDecoration @onDecorationChanged
@subscribe editor.onDidChangeDecoration @onDecorationChanged
@subscribe editor.onDidChangeCharacterWidths @onCharacterWidthsChanged
@subscribe editor.$scrollTop.changes, @onScrollTopChanged
@subscribe editor.$scrollLeft.changes, @requestUpdate
Expand Down
19 changes: 15 additions & 4 deletions src/editor.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -266,10 +266,12 @@ class Editor extends Model
@subscribe @displayBuffer, "markers-updated", => @mergeIntersectingSelections()
@subscribe @displayBuffer.onDidChangeGrammar => @handleGrammarChange()
@subscribe @displayBuffer.onDidTokenize => @handleTokenization()
@subscribe @displayBuffer.onDidChangeSoftWrapped (args...) => @emit 'soft-wrap-changed', args...
@subscribe @displayBuffer, "decoration-added", (args...) => @emit 'decoration-added', args...
@subscribe @displayBuffer, "decoration-removed", (args...) => @emit 'decoration-removed', args...
@subscribe @displayBuffer, "decoration-updated", (args...) => @emit 'decoration-updated', args...

# TODO: remove these when we remove the deprecations. Though, no one is likely using them
@subscribe @displayBuffer.onDidChangeSoftWrapped (softWrapped) => @emit 'soft-wrap-changed', softWrapped
@subscribe @displayBuffer.onDidAddDecoration (decoration) => @emit 'decoration-added', decoration
@subscribe @displayBuffer.onDidRemoveDecoration (decoration) => @emit 'decoration-removed', decoration
@subscribe @displayBuffer.onDidChangeDecoration (decoration) => @emit 'decoration-changed', decoration

getViewClass: ->
require './editor-view'
Expand Down Expand Up @@ -323,6 +325,15 @@ class Editor extends Model
onDidRemoveSelection: (callback) ->
@emitter.on 'did-remove-selection', callback

onDidAddDecoration: (callback) ->
@displayBuffer.onDidAddDecoration(callback)

onDidRemoveDecoration: (callback) ->
@displayBuffer.onDidRemoveDecoration(callback)

onDidChangeDecoration: (callback) ->
@displayBuffer.onDidChangeDecoration(callback)

# Retrieves the current {TextBuffer}.
getBuffer: -> @buffer

Expand Down