All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.sayayi.lib.message.part.parameter.value.ConfigValueString Maven / Gradle / Ivy

Go to download

Highly configurable message format library supporting message definition through annotations

The newest version!
/*
 * Copyright 2020 Jeroen Gremmen
 *
 * Licensed 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
 *
 *   https://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.
 */
package de.sayayi.lib.message.part.parameter.value;

import de.sayayi.lib.message.Message;
import de.sayayi.lib.message.MessageFactory;
import de.sayayi.lib.message.pack.PackInputStream;
import de.sayayi.lib.message.pack.PackOutputStream;
import org.jetbrains.annotations.Contract;
import org.jetbrains.annotations.NotNull;

import java.io.IOException;

import static java.util.Objects.requireNonNull;


/**
 * @author Jeroen Gremmen
 * @since 0.4.0 (renamed in 0.8.0)
 */
public final class ConfigValueString implements ConfigValue
{
  /** Configuration value string. */
  private final @NotNull String string;

  private transient Message.WithSpaces message;


  public ConfigValueString(@NotNull String string) {
    this.string = requireNonNull(string, "string must not be null");
  }


  /**
   * {@inheritDoc}
   *
   * @return  always {@link Type#STRING Type#STRING}
   */
  @Override
  public @NotNull Type getType() {
    return Type.STRING;
  }


  /**
   * Return the string value.
   *
   * @return  string, never {@code null}
   *
   * @since 0.8.0
   */
  public @NotNull String stringValue() {
    return string;
  }


  /**
   * Returns the string value.
   *
   * @return  string, never {@code null}
   */
  @Override
  @Contract(pure = true)
  public @NotNull String asObject() {
    return string;
  }


  @NotNull
  public synchronized Message.WithSpaces asMessage(@NotNull MessageFactory messageFactory)
  {
    if (message == null)
    {
      //noinspection LanguageMismatch
      message = messageFactory.parseMessage(string);
    }

    return message;
  }


  @Override
  public boolean equals(Object o) {
    return o instanceof ConfigValueString && string.equals(((ConfigValueString)o).string);
  }


  @Override
  public int hashCode() {
    return 59 + string.hashCode();
  }


  @Override
  @Contract(pure = true)
  public @NotNull String toString() {
    return '\'' + string.replace("'", "\\'") + '\'';
  }


  /**
   * @param packStream  data output pack target
   *
   * @throws IOException  if an I/O error occurs
   *
   * @since 0.8.0
   *
   * @hidden
   */
  @SuppressWarnings("JavadocDeclaration")
  public void pack(@NotNull PackOutputStream packStream) throws IOException {
    packStream.writeString(string);
  }


  /**
   * @param packStream  source data input, not {@code null}
   *
   * @return  unpacked string map value, never {@code null}
   *
   * @throws IOException  if an I/O error occurs
   *
   * @since 0.8.0
   *
   * @hidden
   */
  @SuppressWarnings("JavadocDeclaration")
  public static @NotNull ConfigValueString unpack(@NotNull PackInputStream packStream) throws IOException {
    return new ConfigValueString(requireNonNull(packStream.readString()));
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy