Skip to content

Commit

Permalink
Export mmap from Mmap (#39816)
Browse files Browse the repository at this point in the history
Currently, one needs `Mmap.mmap`, which is unnecessarily redundant.
  • Loading branch information
ararslan authored Mar 10, 2021
1 parent bc14059 commit f8125c0
Show file tree
Hide file tree
Showing 5 changed files with 96 additions and 92 deletions.
2 changes: 2 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,8 @@ Standard library changes

#### Mmap

* `mmap` is now exported ([#39816]).


Deprecated or removed
---------------------
Expand Down
2 changes: 1 addition & 1 deletion stdlib/DelimitedFiles/src/DelimitedFiles.jl
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ function readdlm_auto(input::AbstractString, dlm::AbstractChar, T::Type, eol::Ab
fsz = filesize(input)
if use_mmap && fsz > 0 && fsz < typemax(Int)
a = open(input, "r") do f
Mmap.mmap(f, Vector{UInt8}, (Int(fsz),))
mmap(f, Vector{UInt8}, (Int(fsz),))
end
# TODO: It would be nicer to use String(a) without making a copy,
# but because the mmap'ed array is not NUL-terminated this causes
Expand Down
18 changes: 10 additions & 8 deletions stdlib/Mmap/src/Mmap.jl
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ module Mmap

import Base: OS_HANDLE, INVALID_OS_HANDLE

export mmap

const PAGESIZE = Int(Sys.isunix() ? ccall(:jl_getpagesize, Clong, ()) : ccall(:jl_getallocationgranularity, Clong, ()))

# for mmaps not backed by files
Expand All @@ -20,7 +22,7 @@ end
Mmap.Anonymous(name::AbstractString="", readonly::Bool=false, create::Bool=true)
Create an `IO`-like object for creating zeroed-out mmapped-memory that is not tied to a file
for use in [`Mmap.mmap`](@ref Mmap.mmap). Used by `SharedArray` for creating shared memory arrays.
for use in [`mmap`](@ref mmap). Used by `SharedArray` for creating shared memory arrays.
# Examples
```jldoctest
Expand Down Expand Up @@ -123,8 +125,8 @@ end # os-test
# core implementation of mmap

"""
Mmap.mmap(io::Union{IOStream,AbstractString,Mmap.AnonymousMmap}[, type::Type{Array{T,N}}, dims, offset]; grow::Bool=true, shared::Bool=true)
Mmap.mmap(type::Type{Array{T,N}}, dims)
mmap(io::Union{IOStream,AbstractString,Mmap.AnonymousMmap}[, type::Type{Array{T,N}}, dims, offset]; grow::Bool=true, shared::Bool=true)
mmap(type::Type{Array{T,N}}, dims)
Create an `Array` whose values are linked to a file, using memory-mapping. This provides a
convenient way of working with data too large to fit in the computer's memory.
Expand Down Expand Up @@ -172,7 +174,7 @@ close(s)
s = open("/tmp/mmap.bin") # default is read-only
m = read(s, Int)
n = read(s, Int)
A2 = Mmap.mmap(s, Matrix{Int}, (m,n))
A2 = mmap(s, Matrix{Int}, (m,n))
```
creates a `m`-by-`n` `Matrix{Int}`, linked to the file associated with stream `s`.
Expand Down Expand Up @@ -254,10 +256,10 @@ mmap(::Type{T}, dims::NTuple{N,Integer}; shared::Bool=true) where {T<:Array,N} =
mmap(::Type{T}, i::Integer...; shared::Bool=true) where {T<:Array} = mmap(Anonymous(), T, convert(Tuple{Vararg{Int}},i), Int64(0); shared=shared)

"""
Mmap.mmap(io, BitArray, [dims, offset])
mmap(io, BitArray, [dims, offset])
Create a [`BitArray`](@ref) whose values are linked to a file, using memory-mapping; it has the same
purpose, works in the same way, and has the same arguments, as [`mmap`](@ref Mmap.mmap), but
purpose, works in the same way, and has the same arguments, as [`mmap`](@ref mmap), but
the byte representation is different.
# Examples
Expand All @@ -266,7 +268,7 @@ julia> using Mmap
julia> io = open("mmap.bin", "w+");
julia> B = Mmap.mmap(io, BitArray, (25,30000));
julia> B = mmap(io, BitArray, (25,30000));
julia> B[3, 4000] = true;
Expand All @@ -276,7 +278,7 @@ julia> close(io);
julia> io = open("mmap.bin", "r+");
julia> C = Mmap.mmap(io, BitArray, (25,30000));
julia> C = mmap(io, BitArray, (25,30000));
julia> C[3, 4000]
true
Expand Down
Loading

0 comments on commit f8125c0

Please sign in to comment.