aboutsummaryrefslogtreecommitdiff
path: root/julia/CrystFEL/src/reflists.jl
diff options
context:
space:
mode:
Diffstat (limited to 'julia/CrystFEL/src/reflists.jl')
-rw-r--r--julia/CrystFEL/src/reflists.jl15
1 files changed, 14 insertions, 1 deletions
diff --git a/julia/CrystFEL/src/reflists.jl b/julia/CrystFEL/src/reflists.jl
index c5edb794..e1766f83 100644
--- a/julia/CrystFEL/src/reflists.jl
+++ b/julia/CrystFEL/src/reflists.jl
@@ -3,7 +3,7 @@ module RefLists
using Printf
import ..CrystFEL: libcrystfel
import ..CrystFEL.Symmetry: SymOpList, InternalSymOpList, symmetry_name
-export RefList, loadreflist
+export RefList, loadreflist, savereflist!
export Reflection, UnmergedReflection, MergedReflection
export InternalRefList
@@ -123,6 +123,19 @@ function loadreflist(filename::AbstractString)
end
+function savereflist!(reflist::RefList{MergedReflection}, filename::AbstractString)
+
+ r = @ccall libcrystfel.write_reflist_2(filename::Cstring,
+ reflist.internalptr::Ptr{InternalRefList},
+ reflist.symmetry.internalptr::Ptr{InternalSymOpList})::Cint
+
+ if r != 0
+ throw(ErrorException("Failed to save reflection list"))
+ end
+
+end
+
+
function Base.show(io::IO, ::MIME"text/plain", reflist::RefList{MergedReflection})
println(io, "Merged reflection list in point group ", symmetry_name(reflist.symmetry))
print(io, " h k l intensity σ(intens) nmeas")