Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove Merge-Tree and SharedString ISegment Deprecations #23328

Closed
anthony-murphy opened this issue Dec 13, 2024 · 2 comments · Fixed by #23448
Closed

Remove Merge-Tree and SharedString ISegment Deprecations #23328

anthony-murphy opened this issue Dec 13, 2024 · 2 comments · Fixed by #23448
Assignees
Labels
api deprecation Changes to a deprecated API triage

Comments

@anthony-murphy
Copy link
Contributor

anthony-murphy commented Dec 13, 2024


"@fluidframework/merge-tree": minor
"@fluidframework/sequence": minor


"section": legacy

Remove Merge-Tree and SharedString ISegment Deprecations

The current ISegment interface over-exposes a number of properties which do not have an external use case, and any external usage could result in damage to the underlying merge-tree including data corruption.
In Fluid Framework release 2.12.0 these properties and associated types were deprecated.

The only use case that will continue to be supported is determining if a segment is removed. For this purpose we've added the free function segmentIsRemoved(segment: ISegment): boolean.

For example, checking if a segment is not removed would change as follows:

- if(segment.removedSeq === undefined){
+ if(!segmentIsRemoved(segment)){

The following properties are removed from ISegment and its implementations:

  • clientId
  • index
  • localMovedSeq
  • localRefs
  • localRemovedSeq
  • localSeq
  • movedClientsIds
  • movedSeq
  • movedSeqs
  • ordinal
  • removedClientIds
  • removedSeq
  • seq
  • wasMovedOnInsert

Additionally, the following types are also removed:

  • IMergeNodeCommon
  • IMoveInfo
  • IRemovalInfo
  • LocalReferenceCollection
@anthony-murphy anthony-murphy added the api deprecation Changes to a deprecated API label Dec 13, 2024
@anthony-murphy anthony-murphy changed the title Merge-Tree and SharedString ISegment Deprecations Remove Merge-Tree and SharedString ISegment Deprecations Dec 13, 2024
@anthony-murphy
Copy link
Contributor Author

#23323

@anthony-murphy anthony-murphy self-assigned this Dec 13, 2024
@anthony-murphy
Copy link
Contributor Author

Removal PR #23448

anthony-murphy added a commit that referenced this issue Jan 7, 2025
The current ISegment interface over-exposes a number of properties which
do not have an external use case, and any external usage could result in
damage to the underlying merge-tree including data corruption.
[In Fluid Framework release 2.12.0 these properties and associated types
were
deprecated.](https://github.com/microsoft/FluidFramework/blob/main/RELEASE_NOTES/2.12.0.md#merge-tree-and-sharedstring-isegment-deprecations-23323)

The only use case that will continue to be supported is determining if a
segment is removed. For this purpose we've added the free function
`segmentIsRemoved(segment: ISegment): boolean`.

For example, checking if a segment is not removed would change as
follows:

```diff
- if(segment.removedSeq === undefined){
+ if(!segmentIsRemoved(segment)){
```

The following properties are removed from ISegment and its
implementations:

- clientId
- index
- localMovedSeq
- localRefs
- localRemovedSeq
- localSeq
- movedClientsIds
- movedSeq
- movedSeqs
- ordinal
- removedClientIds
- removedSeq
- seq
- wasMovedOnInsert

Additionally, the following types are also removed:

- IMergeNodeCommon
- IMoveInfo
- IRemovalInfo
- LocalReferenceCollection

fixes #23328

---------

Co-authored-by: Joshua Smithrud <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api deprecation Changes to a deprecated API triage
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant