Class LegacyCell
java.lang.Object
org.apache.lucene.spatial.prefix.tree.LegacyCell
- All Implemented Interfaces:
- Cell,- CellCanPrune
- Direct Known Subclasses:
- QuadPrefixTree.QuadCell
The base for the original two SPT's: Geohash and Quad. Don't subclass this for new SPTs.
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected intprotected intprotected byte[]protected booleanprotected org.locationtech.spatial4j.shape.Shapeprotected org.locationtech.spatial4j.shape.SpatialRelationWhen set via getSubCells(filter), it is the relationship between this cell and the given shape filter.
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedLegacyCell(byte[] bytes, int off, int len) Warning: Refers to the same bytes (no copy).
- 
Method SummaryModifier and TypeMethodDescriptionprotected static intcompare(byte[] aBytes, int aUpto, int a_length, byte[] bBytes, int bUpto, int b_length) Copied fromBytesRef.compareTo(BytesRef).intcompareToNoLeaf(Cell fromCell) Equivalent tothis.getTokenBytesNoLeaf(null).compareTo(fromCell.getTokenBytesNoLeaf(null)).booleanprotected abstract SpatialPrefixTreegetGrid()intgetLevel()Level 0 is the world (and has no parent), from then on a higher level means a smaller cell than the level before it.protected abstract intgetNextLevelCells(org.locationtech.spatial4j.shape.Shape shapeFilter) Gets the cells at the next grid cell level underneath this one, optionally filtered byshapeFilter.org.locationtech.spatial4j.shape.SpatialRelationGets the relationship this cell has with the shape from which it was filtered from, assuming it came from aCellIterator.protected abstract LegacyCellgetSubCell(org.locationtech.spatial4j.shape.Point p) Performant implementations are expected to implement this efficiently by considering the current cell's boundary.protected abstract Collection<Cell> Gets the cells at the next grid cell level that covers this cell.getTokenBytesNoLeaf(BytesRef result) Returns the bytes for this cell, without a leaf set.getTokenBytesWithLeaf(BytesRef result) Returns the bytes for this cell, with a leaf byte if this is a leaf cell.inthashCode()booleanisLeaf()Some cells are flagged as leaves, which are indexed as such.booleanisPrefixOf(Cell c) Returns if the target term is within/underneath this cell; not necessarily a direct descendant.protected voidprotected voidvoidsetLeaf()Set this cell to be a leaf.voidsetShapeRel(org.locationtech.spatial4j.shape.SpatialRelation rel) SeeCell.getShapeRel().toString()Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.apache.lucene.spatial.prefix.tree.CellCanPrunegetSubCellsSize
- 
Field Details- 
bytesprotected byte[] bytes
- 
b_offprotected int b_off
- 
b_lenprotected int b_len
- 
isLeafprotected boolean isLeaf
- 
shapeRelprotected org.locationtech.spatial4j.shape.SpatialRelation shapeRelWhen set via getSubCells(filter), it is the relationship between this cell and the given shape filter. Doesn't participate in shape equality.
- 
shapeprotected org.locationtech.spatial4j.shape.Shape shape
 
- 
- 
Constructor Details- 
LegacyCellprotected LegacyCell(byte[] bytes, int off, int len) Warning: Refers to the same bytes (no copy). IfsetLeaf()is subsequently called then it may modify bytes.
 
- 
- 
Method Details- 
readCell
- 
readLeafAdjustprotected void readLeafAdjust()
- 
getGrid
- 
getMaxLevelsprotected abstract int getMaxLevels()
- 
getShapeRelpublic org.locationtech.spatial4j.shape.SpatialRelation getShapeRel()Description copied from interface:CellGets the relationship this cell has with the shape from which it was filtered from, assuming it came from aCellIterator. Arguably it belongs there but it's very convenient here.- Specified by:
- getShapeRelin interface- Cell
 
- 
setShapeRelpublic void setShapeRel(org.locationtech.spatial4j.shape.SpatialRelation rel) Description copied from interface:CellSeeCell.getShapeRel().- Specified by:
- setShapeRelin interface- Cell
 
- 
isLeafpublic boolean isLeaf()Description copied from interface:CellSome cells are flagged as leaves, which are indexed as such. A leaf cell is either within some shape or it both intersects and the cell is at an accuracy threshold such that no smaller cells for the shape will be represented.
- 
setLeafpublic void setLeaf()Description copied from interface:CellSet this cell to be a leaf. Warning: never call on a cell initialized to reference the same bytes from termsEnum, which should be treated as immutable. Note: not supported at level 0.
- 
getTokenBytesWithLeafDescription copied from interface:CellReturns the bytes for this cell, with a leaf byte if this is a leaf cell. The result param is used to save object allocation, though its bytes aren't used.- Specified by:
- getTokenBytesWithLeafin interface- Cell
- Parameters:
- result- where the result goes, or null to create new
 
- 
getTokenBytesNoLeafDescription copied from interface:CellReturns the bytes for this cell, without a leaf set. The bytes should sort beforeCell.getTokenBytesWithLeaf(org.apache.lucene.util.BytesRef). The result param is used to save object allocation, though its bytes aren't used.- Specified by:
- getTokenBytesNoLeafin interface- Cell
- Parameters:
- result- where the result goes, or null to create new
 
- 
getLevelpublic int getLevel()Description copied from interface:CellLevel 0 is the world (and has no parent), from then on a higher level means a smaller cell than the level before it.
- 
getNextLevelCellsDescription copied from interface:CellGets the cells at the next grid cell level underneath this one, optionally filtered byshapeFilter. The returned cells should haveCell.getShapeRel()set to their relation withshapeFilter. In addition, for non-pointsCell.isLeaf()must be true when that relation is WITHIN.IMPORTANT: Cells returned from this iterator can be shared, as well as the bytes. Precondition: Never called when getLevel() == maxLevel. - Specified by:
- getNextLevelCellsin interface- Cell
- Parameters:
- shapeFilter- an optional filter for the returned cells.
- Returns:
- A set of cells (no dups), sorted. Not Modifiable.
 
- 
getSubCellPerformant implementations are expected to implement this efficiently by considering the current cell's boundary.- Precondition: Never called when getLevel() == maxLevel.
- Precondition: this.getShape().relate(p) != DISJOINT.
 
- 
getSubCellsGets the cells at the next grid cell level that covers this cell. Precondition: Never called when getLevel() == maxLevel.- Returns:
- A set of cells (no dups), sorted, modifiable, not empty, not null.
 
- 
isPrefixOfDescription copied from interface:CellReturns if the target term is within/underneath this cell; not necessarily a direct descendant.- Specified by:
- isPrefixOfin interface- Cell
- Parameters:
- c- the term
 
- 
compareToNoLeafDescription copied from interface:CellEquivalent tothis.getTokenBytesNoLeaf(null).compareTo(fromCell.getTokenBytesNoLeaf(null)).- Specified by:
- compareToNoLeafin interface- Cell
 
- 
compareprotected static int compare(byte[] aBytes, int aUpto, int a_length, byte[] bBytes, int bUpto, int b_length) Copied fromBytesRef.compareTo(BytesRef). This is to avoid creating a BytesRef.
- 
equals
- 
hashCodepublic int hashCode()
- 
toString
 
-