diff options
author | dan <dan.abramov@gmail.com> | 2024-11-21 22:32:49 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-11-21 22:32:49 +0000 |
commit | 84724bb940a827a7020da6ccbd6fa80f7209a455 (patch) | |
tree | b39dfb34a6c32e43e6180be4e9c4527a9c142e4d /patches | |
parent | 9f1e648686498ad6ec68a7c4487b1090f8e74f89 (diff) | |
download | voidsky-84724bb940a827a7020da6ccbd6fa80f7209a455.tar.zst |
[Android] Patch react-native-svg to cache parsed paths (#6583)
Diffstat (limited to 'patches')
-rw-r--r-- | patches/react-native-svg+15.3.0.patch | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/patches/react-native-svg+15.3.0.patch b/patches/react-native-svg+15.3.0.patch new file mode 100644 index 000000000..54540023f --- /dev/null +++ b/patches/react-native-svg+15.3.0.patch @@ -0,0 +1,57 @@ +diff --git a/node_modules/react-native-svg/android/src/main/java/com/horcrux/svg/PathView.java b/node_modules/react-native-svg/android/src/main/java/com/horcrux/svg/PathView.java +index 06829bd..1b15818 100644 +--- a/node_modules/react-native-svg/android/src/main/java/com/horcrux/svg/PathView.java ++++ b/node_modules/react-native-svg/android/src/main/java/com/horcrux/svg/PathView.java +@@ -14,17 +14,33 @@ import android.graphics.Paint; + import android.graphics.Path; + import com.facebook.react.bridge.ReactContext; + ++import java.util.ArrayList; ++import java.util.HashMap; ++ ++class ParsedPath { ++ final Path path; ++ final ArrayList<PathElement> elements; ++ ++ ParsedPath(Path path, ArrayList<PathElement> elements) { ++ this.path = path; ++ this.elements = elements; ++ } ++} ++ + @SuppressLint("ViewConstructor") + class PathView extends RenderableView { + private Path mPath; + ++ // This grows forever but for our use case (static icons) it's ok. ++ private static final HashMap<String, ParsedPath> sPathCache = new HashMap<>(); ++ + public PathView(ReactContext reactContext) { + super(reactContext); + PathParser.mScale = mScale; + mPath = new Path(); + } + +- public void setD(String d) { ++ void setDByParsing(String d) { + mPath = PathParser.parse(d); + elements = PathParser.elements; + for (PathElement elem : elements) { +@@ -33,6 +49,17 @@ class PathView extends RenderableView { + point.y *= mScale; + } + } ++ } ++ ++ public void setD(String d) { ++ ParsedPath cached = sPathCache.get(d); ++ if (cached != null) { ++ mPath = cached.path; ++ elements = cached.elements; ++ } else { ++ setDByParsing(d); ++ sPathCache.put(d, new ParsedPath(mPath, elements)); ++ } + invalidate(); + } + |