001 /*
002 * Copyright 2010-2015 JetBrains s.r.o.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017 package org.jetbrains.kotlin.resolve;
018
019 import com.intellij.util.SmartFMap;
020 import org.jetbrains.annotations.NotNull;
021 import org.jetbrains.annotations.Nullable;
022 import org.jetbrains.kotlin.diagnostics.Diagnostic;
023 import org.jetbrains.kotlin.psi.JetExpression;
024 import org.jetbrains.kotlin.types.JetType;
025 import org.jetbrains.kotlin.util.slicedMap.ReadOnlySlice;
026 import org.jetbrains.kotlin.util.slicedMap.WritableSlice;
027
028 import java.util.Collection;
029
030 public class ObservableBindingTrace implements BindingTrace {
031 public interface RecordHandler<K, V> {
032
033 void handleRecord(WritableSlice<K, V> slice, K key, V value);
034 }
035
036 private final BindingTrace originalTrace;
037
038 private SmartFMap<WritableSlice, RecordHandler> handlers = SmartFMap.emptyMap();
039
040 public ObservableBindingTrace(BindingTrace originalTrace) {
041 this.originalTrace = originalTrace;
042 }
043 @Override
044 public void report(@NotNull Diagnostic diagnostic) {
045 originalTrace.report(diagnostic);
046 }
047
048 @NotNull
049 @Override
050 public BindingContext getBindingContext() {
051 return originalTrace.getBindingContext();
052 }
053
054 @Override
055 public <K, V> void record(WritableSlice<K, V> slice, K key, V value) {
056 originalTrace.record(slice, key, value);
057 RecordHandler recordHandler = handlers.get(slice);
058 if (recordHandler != null) {
059 recordHandler.handleRecord(slice, key, value);
060 }
061 }
062
063 @Override
064 public <K> void record(WritableSlice<K, Boolean> slice, K key) {
065 record(slice, key, true);
066 }
067
068 @Override
069 public <K, V> V get(ReadOnlySlice<K, V> slice, K key) {
070 return originalTrace.get(slice, key);
071 }
072
073 @Override
074 @NotNull
075 public <K, V> Collection<K> getKeys(WritableSlice<K, V> slice) {
076 return originalTrace.getKeys(slice);
077 }
078
079 @Nullable
080 @Override
081 public JetType getType(@NotNull JetExpression expression) {
082 return originalTrace.getType(expression);
083 }
084
085 @Override
086 public void recordType(@NotNull JetExpression expression, @Nullable JetType type) {
087 originalTrace.recordType(expression, type);
088 }
089
090 public <K, V> ObservableBindingTrace addHandler(@NotNull WritableSlice<K, V> slice, @NotNull RecordHandler<K, V> handler) {
091 handlers = handlers.plus(slice, handler);
092 return this;
093 }
094
095 }