OutputCharsetEncoder.java

/*
 * Copyright 2015 The Closure Compiler Authors.
 *
 * 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
 *
 *     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.
 */

package com.google.javascript.jscomp;

import static java.nio.charset.StandardCharsets.US_ASCII;

import com.google.common.annotations.GwtIncompatible;

import java.nio.charset.Charset;
import java.nio.charset.CharsetEncoder;

/**
 * Output charset encoder for {@code CodeGenerator} that delegates to a CharsetEncoder.
 *
 * TODO(moz): Add GWT compatible super-source replacement
 *
 */
@GwtIncompatible("java.nio.charset")
final class OutputCharsetEncoder {

  private final CharsetEncoder encoder;

  OutputCharsetEncoder(Charset outputCharset) {
    if (outputCharset == null || outputCharset == US_ASCII) {
      // If we want our default (pretending to be UTF-8, but escaping anything
      // outside of straight ASCII), then don't use the encoder, but
      // just special-case the code.  This keeps the normal path through
      // the code identical to how it's been for years.
      this.encoder = null;
    } else {
      this.encoder = outputCharset.newEncoder();
    }
  }

  boolean canEncode(char c) {
    return encoder != null && encoder.canEncode(c);
  }
}