---
title: "setFragmentBufferOffset(_:index:)"
framework: metal
role: symbol
role_heading: Instance Method
path: "metal/mtlrendercommandencoder/setfragmentbufferoffset(_:index:)"
---

# setFragmentBufferOffset(_:index:)

Updates an entry in the fragment shader argument table with a new location within the entry’s current buffer.

## Declaration

```swift
func setFragmentBufferOffset(_ offset: Int, index: Int)
```

## Parameters

- `offset`: An integer that represents the location, in bytes, from the start of buffer where the fragment shader argument data begins. See the https://developer.apple.com/metal/Metal-Feature-Set-Tables.pdf to check for offset alignment requirements for buffers in device and constant address space.
- `index`: An integer that represents the entry in the fragment shader argument table for buffers that already stores a record of an doc://com.apple.metal/documentation/Metal/MTLBuffer.

## Discussion

Discussion The command this method encodes changes the offset for a fragment buffer that already has a previous assignment from one of your earlier commands. For more information, see: setFragmentBuffer(_:offset:index:) setFragmentBuffers(_:offsets:range:) (Swift) setFragmentBuffers:offsets:withRange: (Objective-C) The command can also adjust the offset for an entry that you previously set with the setFragmentBytes(_:length:index:) method. tip: If you’re only updating an offset, this method is typically more efficient than rebinding a buffer or byte block with the methods above. By default, the buffer at each index is nil.

## See Also

### Assigning buffers

- [setFragmentBuffer(_:offset:index:)](metal/mtlrendercommandencoder/setfragmentbuffer(_:offset:index:).md)
- [setFragmentBuffers(_:offsets:range:)](metal/mtlrendercommandencoder/setfragmentbuffers(_:offsets:range:).md)
- [setFragmentBytes(_:length:index:)](metal/mtlrendercommandencoder/setfragmentbytes(_:length:index:).md)
