Skip to content

Commit

Permalink
Fix index logic in detecting descriptor kind
Browse files Browse the repository at this point in the history
  • Loading branch information
varungandhi-src committed Sep 18, 2024
1 parent ece1877 commit 58cc58d
Showing 1 changed file with 8 additions and 8 deletions.
16 changes: 8 additions & 8 deletions bindings/go/scip/symbol.go
Original file line number Diff line number Diff line change
Expand Up @@ -512,20 +512,17 @@ func (z *zeroAllocSymbolParser) Advance(nextRune rune, nextRuneByteLength int32)

func (z *zeroAllocSymbolParser) parseDescriptor(out *RawDescriptorList) error {
start := z.byteIndex
nextRune, nextRuneByteLength := z.peekNext()
switch nextRune {
switch z.currentRune {
case '(':
z.Advance('(', nextRuneByteLength)
z.advanceRune()
z.advanceOneByte('(')
name, err := z.acceptIdentifier(parseCtxParameterName)
if err != nil {
return err
}
out.pushDescriptor(name, Descriptor_Parameter)
return z.acceptOneByte(')', parseCtxClosingParameterName)
case '[':
z.Advance('[', nextRuneByteLength)
z.advanceRune()
z.advanceOneByte('[')
name, err := z.acceptIdentifier(parseCtxTypeParameterName)
if err != nil {
return err
Expand Down Expand Up @@ -612,12 +609,15 @@ func isIdentifierCharacter(r rune) bool {
func (z *zeroAllocSymbolParser) advanceOneByte(_ byte) {
// TODO: Add build tag with asserts and check that current byte matches the passed in byte.
nextRune, nextRuneByteLength := z.peekNext()
z.Advance(nextRune, nextRuneByteLength)
// z.byteIndex can become equal to len(z.SymbolString) here
z.byteIndex += 1
z.currentRune = nextRune
z.bytesToNextRune = nextRuneByteLength
}

func (z *zeroAllocSymbolParser) advanceRune() {
nextRune, nextRuneByteLength := z.peekNext()
z.Advance(nextRune, nextRuneByteLength)
z.Advance(nextRune, min(nextRuneByteLength, 1))
}

func (z *zeroAllocSymbolParser) acceptOneByte(b byte, what parseCtx) error {
Expand Down

0 comments on commit 58cc58d

Please sign in to comment.