From 0798adfc0a7cb88aefeed048043e12335bced11a Mon Sep 17 00:00:00 2001 From: Tom White Date: Tue, 13 Aug 2019 10:08:33 +0100 Subject: [PATCH] Make AbstractFastaSequenceFile serializable by Kryo for Spark. See explanation at https://github.com/EsotericSoftware/kryo/issues/469 --- .../samtools/reference/AbstractFastaSequenceFile.java | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/main/java/htsjdk/samtools/reference/AbstractFastaSequenceFile.java b/src/main/java/htsjdk/samtools/reference/AbstractFastaSequenceFile.java index e9013b7731..aa921a53f6 100644 --- a/src/main/java/htsjdk/samtools/reference/AbstractFastaSequenceFile.java +++ b/src/main/java/htsjdk/samtools/reference/AbstractFastaSequenceFile.java @@ -35,8 +35,10 @@ import java.io.File; import java.io.InputStream; +import java.io.Serializable; import java.nio.file.Files; import java.nio.file.Path; +import java.util.function.Supplier; /** * Provide core sequence dictionary functionality required by all fasta file readers. @@ -62,7 +64,8 @@ abstract class AbstractFastaSequenceFile implements ReferenceSequenceFile { AbstractFastaSequenceFile(final Path path) { this.path = path; this.source = path == null ? "unknown" : path.toAbsolutePath().toString(); - this.dictionary = new Lazy<>(() -> findAndLoadSequenceDictionary(path)); + // ensure lambda is serializable (by Kryo, when used with Spark) + this.dictionary = new Lazy<>((Supplier & Serializable) (() -> findAndLoadSequenceDictionary(path))); } /** @@ -74,7 +77,8 @@ abstract class AbstractFastaSequenceFile implements ReferenceSequenceFile { AbstractFastaSequenceFile(final Path path, final String source, final SAMSequenceDictionary sequenceDictionary) { this.path = path; this.source = source; - this.dictionary = new Lazy<>(() -> sequenceDictionary); + // ensure lambda is serializable (by Kryo, when used with Spark) + this.dictionary = new Lazy<>((Supplier & Serializable) (() -> sequenceDictionary)); } /** Attempts to find and load the sequence dictionary if present. */