EditSession.setSelectedBufferRanges destroys folds

It also clears all existing selections and makes new ones.
This commit is contained in:
Nathan Sobo 2012-07-12 18:40:34 -06:00
parent f02e724606
commit f99146b42f
2 changed files with 37 additions and 13 deletions

View File

@ -523,6 +523,31 @@ describe "EditSession", ->
editSession.selectWord() editSession.selectWord()
expect(editSession.getSelectedText()).toBe '' expect(editSession.getSelectedText()).toBe ''
describe ".setSelectedBufferRanges(ranges)", ->
it "clears existing selections and creates selections for each of the given ranges", ->
editSession.setSelectedBufferRanges([[[2, 2], [3, 3]], [[4, 4], [5, 5]]])
expect(editSession.getSelectedBufferRanges()).toEqual [[[2, 2], [3, 3]], [[4, 4], [5, 5]]]
editSession.setSelectedBufferRanges([[[5, 5], [6, 6]]])
expect(editSession.getSelectedBufferRanges()).toEqual [[[5, 5], [6, 6]]]
it "merges intersecting selections", ->
editSession.setSelectedBufferRanges([[[2, 2], [3, 3]], [[3, 0], [5, 5]]])
expect(editSession.getSelectedBufferRanges()).toEqual [[[2, 2], [5, 5]]]
it "removes folds that contain the selections", ->
editSession.setSelectedBufferRange([[0,0], [0,0]])
editSession.createFold(1, 4)
editSession.createFold(2, 3)
editSession.createFold(6, 8)
editSession.createFold(10, 11)
editSession.setSelectedBufferRanges([[[2, 2], [3, 3]], [[6, 6], [7, 7]]])
expect(editSession.lineForScreenRow(1).fold).toBeUndefined()
expect(editSession.lineForScreenRow(2).fold).toBeUndefined()
expect(editSession.lineForScreenRow(6).fold).toBeUndefined()
expect(editSession.lineForScreenRow(10).fold).toBeDefined()
describe "when the cursor is moved while there is a selection", -> describe "when the cursor is moved while there is a selection", ->
makeSelection = -> selection.setBufferRange [[1, 2], [1, 5]] makeSelection = -> selection.setBufferRange [[1, 2], [1, 5]]
@ -1243,20 +1268,17 @@ describe "EditSession", ->
selections = editSession.getSelections() selections = editSession.getSelections()
expect(buffer.lineForRow(1)).toBe ' var = function( {' expect(buffer.lineForRow(1)).toBe ' var = function( {'
expect(selections[0].getBufferRange()).toEqual [[1, 6], [1, 6]]
expect(selections[1].getBufferRange()).toEqual [[1, 17], [1, 17]] expect(editSession.getSelectedBufferRanges()).toEqual [[[1, 6], [1, 6]], [[1, 17], [1, 17]]]
editSession.undo() editSession.undo()
expect(selections[0].getBufferRange()).toEqual [[1, 6], [1, 6]] expect(editSession.getSelectedBufferRanges()).toEqual [[[1, 6], [1, 6]], [[1, 18], [1, 18]]]
expect(selections[1].getBufferRange()).toEqual [[1, 18], [1, 18]]
editSession.undo() editSession.undo()
expect(selections[0].getBufferRange()).toEqual [[1, 6], [1, 10]] expect(editSession.getSelectedBufferRanges()).toEqual [[[1, 6], [1, 10]], [[1, 22], [1, 27]]]
expect(selections[1].getBufferRange()).toEqual [[1, 22], [1, 27]]
editSession.redo() editSession.redo()
expect(selections[0].getBufferRange()).toEqual [[1, 6], [1, 6]] expect(editSession.getSelectedBufferRanges()).toEqual [[[1, 6], [1, 6]], [[1, 18], [1, 18]]]
expect(selections[1].getBufferRange()).toEqual [[1, 18], [1, 18]]
it "restores selected ranges even when the change occurred in another edit session", -> it "restores selected ranges even when the change occurred in another edit session", ->
otherEditSession = fixturesProject.open(editSession.getPath()) otherEditSession = fixturesProject.open(editSession.getPath())

View File

@ -5,6 +5,7 @@ DisplayBuffer = require 'display-buffer'
Cursor = require 'cursor' Cursor = require 'cursor'
Selection = require 'selection' Selection = require 'selection'
EventEmitter = require 'event-emitter' EventEmitter = require 'event-emitter'
Range = require 'range'
AnchorRange = require 'anchor-range' AnchorRange = require 'anchor-range'
_ = require 'underscore' _ = require 'underscore'
@ -309,13 +310,14 @@ class EditSession
@getLastSelection().setBufferRange(bufferRange, options) @getLastSelection().setBufferRange(bufferRange, options)
setSelectedBufferRanges: (bufferRanges, options) -> setSelectedBufferRanges: (bufferRanges, options) ->
selections = @getSelections() throw new Error("Passed an empty array to setSelectedBufferRanges") unless bufferRanges.length
selection.destroy() for selection in @getSelections()
for bufferRange, i in bufferRanges for bufferRange, i in bufferRanges
if selections[i] bufferRange = Range.fromObject(bufferRange)
selections[i].setBufferRange(bufferRange, options) for row in [bufferRange.start.row..bufferRange.end.row]
else @destroyFoldsContainingBufferRow(row)
@addSelectionForBufferRange(bufferRange, options) @addSelectionForBufferRange(bufferRange, options)
@mergeIntersectingSelections() @mergeIntersectingSelections(options)
removeSelection: (selection) -> removeSelection: (selection) ->
_.remove(@selections, selection) _.remove(@selections, selection)