[
https://issues.apache.org/jira/browse/TIKA-4623?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=18052186#comment-18052186
]
ASF GitHub Bot commented on TIKA-4623:
--------------------------------------
tballison opened a new pull request, #2534:
URL: https://github.com/apache/tika/pull/2534
<!--
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.
-->
Thanks for your contribution to [Apache Tika](https://tika.apache.org/)!
Your help is appreciated!
Before opening the pull request, please verify that
* there is an open issue on the [Tika issue
tracker](https://issues.apache.org/jira/projects/TIKA) which describes the
problem or the improvement. We cannot accept pull requests without an issue
because the change wouldn't be listed in the release notes.
* the issue ID (`TIKA-XXXX`)
- is referenced in the title of the pull request
- and placed in front of your commit messages surrounded by square
brackets (`[TIKA-XXXX] Issue or pull request title`)
* commits are squashed into a single one (or few commits for larger changes)
* Tika is successfully built and unit tests pass by running `mvn clean test`
* there should be no conflicts when merging the pull request branch into the
*recent* `main` branch. If there are conflicts, please try to rebase the pull
request branch on top of a freshly pulled `main` branch
* if you add new module that downstream users will depend upon add it to
relevant group in `tika-bom/pom.xml`.
We will be able to faster integrate your pull request if these conditions
are met. If you have any questions how to fix your problem or about using Tika
in general, please sign up for the [Tika mailing
list](http://tika.apache.org/mail-lists.html). Thanks!
> Improve rewind performance on generic InputStreams in 4.x
> ---------------------------------------------------------
>
> Key: TIKA-4623
> URL: https://issues.apache.org/jira/browse/TIKA-4623
> Project: Tika
> Issue Type: Task
> Reporter: Tim Allison
> Priority: Minor
>
> On TIKA-4619, we made TikaInputStream rewindable. The benefits of
> rewindability:
> * Can go beyond 2gb.
> * Does not interfere with parser/detector needs to mark reset at non-zero
> offsets
> There are now three types of backing inputstream that are used by
> TikaInputStream: file, bytearray, generic. With generic, we buffer to memory
> and then spool to disk at a certain threshold.
> The one downside with this setup is that we're buffering to memory for the
> generic inputstream when mark/reset might be sufficient.
> On this ticket, we'll look into adding an "enableRewind()" call in
> TikaInputStream. This would be a no-op for file and bytearray backed streams
> (because those are already rewindable). But what it would do is allow for
> basic BufferedInputStream for most file formats that require only that and
> for which we do not need rewindability. This would put the responsibility on
> the digester/detector/parser to know when an inputstream needs to be
> rewindable.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)