mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 17:01:56 +01:00
parent
06a831d477
commit
5d201168ef
1 changed files with 10 additions and 20 deletions
|
@ -15,14 +15,11 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
package net.minecraft.server.dedicated;
|
package net.minecraft.server.dedicated;
|
||||||
|
|
||||||
import com.google.common.base.MoreObjects;
|
import com.google.common.base.MoreObjects;
|
||||||
+import java.io.BufferedWriter; // Paper
|
+
|
||||||
|
+import java.io.BufferedOutputStream; // Paper
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
+import java.io.OutputStreamWriter; // Paper
|
|
||||||
import java.nio.file.Files;
|
|
||||||
import java.nio.file.Path;
|
|
||||||
import java.util.Objects;
|
|
||||||
@@ -0,0 +0,0 @@ import org.apache.logging.log4j.Logger;
|
@@ -0,0 +0,0 @@ import org.apache.logging.log4j.Logger;
|
||||||
|
|
||||||
import joptsimple.OptionSet; // CraftBukkit
|
import joptsimple.OptionSet; // CraftBukkit
|
||||||
|
@ -42,27 +39,20 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
OutputStream outputstream = Files.newOutputStream(path);
|
OutputStream outputstream = Files.newOutputStream(path);
|
||||||
+ // Paper start - disable writing comments to properties file
|
+ // Paper start - disable writing comments to properties file
|
||||||
+ OutputStreamWriter outputStreamWriter = new OutputStreamWriter(outputstream);
|
+ BufferedOutputStream bufferedOutputStream = !skipComments ? new BufferedOutputStream(outputstream) : new BufferedOutputStream(outputstream) {
|
||||||
+ BufferedWriter bufferedwriter = !skipComments ? new BufferedWriter(outputStreamWriter) : new BufferedWriter(outputStreamWriter) {
|
|
||||||
+ private boolean isRightAfterNewline = true; // If last written char was newline
|
+ private boolean isRightAfterNewline = true; // If last written char was newline
|
||||||
+ private boolean isComment = false; // Are we writing comment currently?
|
+ private boolean isComment = false; // Are we writing comment currently?
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public void write(@NotNull String str) throws IOException {
|
+ public void write(@NotNull byte[] b) throws IOException {
|
||||||
+ char[] ch = str.toCharArray();
|
+ this.write(b, 0, b.length);
|
||||||
+ this.write(ch);
|
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ @Override
|
+ @Override
|
||||||
+ public void write(@NotNull char[] cbuf) throws IOException {
|
+ public void write(@NotNull byte[] bbuf, int off, int len) throws IOException {
|
||||||
+ this.write(cbuf, 0, cbuf.length);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ @Override
|
|
||||||
+ public void write(@NotNull char[] cbuf, int off, int len) throws IOException {
|
|
||||||
+ int latest_offset = off; // The latest offset, updated when comment ends
|
+ int latest_offset = off; // The latest offset, updated when comment ends
|
||||||
+ for (int index = off; index < off + len; ++index ) {
|
+ for (int index = off; index < off + len; ++index ) {
|
||||||
+ char c = cbuf[index];
|
+ byte c = bbuf[index];
|
||||||
+ boolean isNewline = (c == '\n' || c == '\r');
|
+ boolean isNewline = (c == '\n' || c == '\r');
|
||||||
+ if (isNewline && isComment) {
|
+ if (isNewline && isComment) {
|
||||||
+ // Comment has ended
|
+ // Comment has ended
|
||||||
|
@ -73,7 +63,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ isComment = true;
|
+ isComment = true;
|
||||||
+ if (index != latest_offset) {
|
+ if (index != latest_offset) {
|
||||||
+ // We got some non-comment data earlier
|
+ // We got some non-comment data earlier
|
||||||
+ super.write(cbuf, latest_offset, index-latest_offset);
|
+ super.write(bbuf, latest_offset, index-latest_offset);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ isRightAfterNewline = isNewline; // Store for next iteration
|
+ isRightAfterNewline = isNewline; // Store for next iteration
|
||||||
|
@ -81,7 +71,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ }
|
+ }
|
||||||
+ if (latest_offset < off+len && !isComment) {
|
+ if (latest_offset < off+len && !isComment) {
|
||||||
+ // We have some unwritten data, that isn't part of a comment
|
+ // We have some unwritten data, that isn't part of a comment
|
||||||
+ super.write(cbuf, latest_offset, (off + len) - latest_offset);
|
+ super.write(bbuf, latest_offset, (off + len) - latest_offset);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ };
|
+ };
|
||||||
|
@ -89,7 +79,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
|
|
||||||
try {
|
try {
|
||||||
- this.properties.store(outputstream, "Minecraft server properties");
|
- this.properties.store(outputstream, "Minecraft server properties");
|
||||||
+ this.properties.store(bufferedwriter, "Minecraft server properties"); // Paper - use bufferedwriter
|
+ this.properties.store(bufferedOutputStream, "Minecraft server properties"); // Paper - use bufferedOutputStream
|
||||||
} catch (Throwable throwable) {
|
} catch (Throwable throwable) {
|
||||||
if (outputstream != null) {
|
if (outputstream != null) {
|
||||||
try {
|
try {
|
||||||
|
|
Loading…
Reference in a new issue