| using Lucene.Net.Support.IO; |
| using System; |
| using System.IO; |
| using System.Threading; |
| |
| namespace Lucene.Net.Store |
| { |
| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| /// <summary> |
| /// A <see cref="DataOutput"/> wrapping a plain <see cref="Stream"/>. |
| /// </summary> |
| public class OutputStreamDataOutput : DataOutput, IDisposable |
| { |
| private readonly Stream _os; |
| private int disposed; // LUCENENET specific - allow double-dispose |
| private readonly bool leaveOpen; // LUCENENET specific - added to allow the stream to be left open |
| |
| /// <summary> |
| /// Initializes a new instance of <see cref="OutputStreamDataOutput"/> with the specified <paramref name="os"/> (output stream). |
| /// </summary> |
| /// <param name="os">The output stream to write to.</param> |
| /// <exception cref="ArgumentNullException">If <paramref name="os"/> is <c>null</c>.</exception> |
| public OutputStreamDataOutput(Stream os) |
| { |
| this._os = os ?? throw new ArgumentNullException(nameof(os)); // LUCENENET specific - added null guard clause |
| } |
| |
| /// <inheritdoc cref="OutputStreamDataOutput(Stream)"/> |
| /// <summary> |
| /// Initializes a new instance of <see cref="OutputStreamDataOutput"/> with the specified <paramref name="os"/> (output stream) and <paramref name="leaveOpen"/> flag. |
| /// </summary> |
| /// <param name="leaveOpen">If <c>true</c>, the stream will not be disposed when this instance is disposed.</param> |
| /// <remarks> |
| /// LUCENENET specific - added to allow the stream to be left open. |
| /// </remarks> |
| public OutputStreamDataOutput(Stream os, bool leaveOpen) |
| : this(os) |
| { |
| this.leaveOpen = leaveOpen; |
| } |
| |
| public override void WriteByte(byte b) |
| { |
| _os.WriteByte(b); |
| } |
| |
| // LUCENENET: Use ReadOnlySpan<byte> instead of byte[] for better compatibility. |
| public override void WriteBytes(ReadOnlySpan<byte> source) |
| { |
| _os.Write(source); |
| } |
| |
| /// <summary> |
| /// Releases all resources used by the <see cref="OutputStreamDataOutput"/>. |
| /// </summary> |
| public void Dispose() |
| { |
| Dispose(true); |
| GC.SuppressFinalize(this); |
| } |
| |
| /// <summary> |
| /// Releases resources used by the <see cref="OutputStreamDataOutput"/> and |
| /// if overridden in a derived class, optionally releases unmanaged resources. |
| /// </summary> |
| /// <param name="disposing"><c>true</c> to release both managed and unmanaged resources; |
| /// <c>false</c> to release only unmanaged resources.</param> |
| // LUCENENET specific - implemented proper dispose pattern |
| protected virtual void Dispose(bool disposing) |
| { |
| if (0 != Interlocked.CompareExchange(ref this.disposed, 1, 0)) return; // LUCENENET specific - allow double-dispose |
| |
| if (disposing) |
| { |
| if (!leaveOpen) |
| { |
| _os.Dispose(); |
| } |
| } |
| } |
| } |
| } |