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

org.apache.poi.ss.formula.CollaboratingWorkbooksEnvironment Maven / Gradle / Ivy

There is a newer version: 5.2.5
Show newest version
/* ====================================================================
   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.
==================================================================== */
package org.apache.poi.ss.formula;

import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.IdentityHashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

import org.apache.poi.ss.usermodel.FormulaEvaluator;
import org.apache.poi.util.Internal;

/**
 * Manages a collection of {@link WorkbookEvaluator}s, in order to support 
 * evaluation of formulas across spreadsheets.
 *
 * 

For POI internal use only - use

*/ @Internal public final class CollaboratingWorkbooksEnvironment { public static final class WorkbookNotFoundException extends Exception { private static final long serialVersionUID = 8787784539811167941L; WorkbookNotFoundException(String msg) { super(msg); } } public static final CollaboratingWorkbooksEnvironment EMPTY = new CollaboratingWorkbooksEnvironment(); private final Map _evaluatorsByName; private final WorkbookEvaluator[] _evaluators; private boolean _unhooked; private CollaboratingWorkbooksEnvironment() { _evaluatorsByName = Collections.emptyMap(); _evaluators = new WorkbookEvaluator[0]; } public static void setup(String[] workbookNames, WorkbookEvaluator[] evaluators) { int nItems = workbookNames.length; if (evaluators.length != nItems) { throw new IllegalArgumentException("Number of workbook names is " + nItems + " but number of evaluators is " + evaluators.length); } if (nItems < 1) { throw new IllegalArgumentException("Must provide at least one collaborating worbook"); } new CollaboratingWorkbooksEnvironment(workbookNames, evaluators, nItems); } public static void setup(Map evaluatorsByName) { if (evaluatorsByName.size() < 1) { throw new IllegalArgumentException("Must provide at least one collaborating worbook"); } WorkbookEvaluator[] evaluators = evaluatorsByName.values().toArray(new WorkbookEvaluator[evaluatorsByName.size()]); new CollaboratingWorkbooksEnvironment(evaluatorsByName, evaluators); } public static void setupFormulaEvaluator(Map evaluators) { Map evaluatorsByName = new HashMap<>(evaluators.size()); for (Map.Entry swb : evaluators.entrySet()) { String wbName = swb.getKey(); FormulaEvaluator eval = swb.getValue(); if (eval instanceof WorkbookEvaluatorProvider) { evaluatorsByName.put(wbName, ((WorkbookEvaluatorProvider)eval)._getWorkbookEvaluator()); } else { throw new IllegalArgumentException("Formula Evaluator " + eval + " provides no WorkbookEvaluator access"); } } setup(evaluatorsByName); } private CollaboratingWorkbooksEnvironment(String[] workbookNames, WorkbookEvaluator[] evaluators, int nItems) { this(toUniqueMap(workbookNames, evaluators, nItems), evaluators); } private static Map toUniqueMap(String[] workbookNames, WorkbookEvaluator[] evaluators, int nItems) { Map evaluatorsByName = new HashMap<>(nItems * 3 / 2); for(int i=0; i evaluatorsByName, WorkbookEvaluator[] evaluators) { IdentityHashMap uniqueEvals = new IdentityHashMap<>(evaluators.length); for (Map.Entry me : evaluatorsByName.entrySet()) { String uniEval = uniqueEvals.put(me.getValue(), me.getKey()); if (uniEval != null) { String msg = "Attempted to register same workbook under names '" + uniEval + "' and '" + me.getKey() + "'"; throw new IllegalArgumentException(msg); } } unhookOldEnvironments(evaluators); hookNewEnvironment(evaluators, this); _unhooked = false; _evaluators = evaluators.clone(); _evaluatorsByName = evaluatorsByName; } private static void hookNewEnvironment(WorkbookEvaluator[] evaluators, CollaboratingWorkbooksEnvironment env) { // All evaluators will need to share the same cache. // but the cache takes an optional evaluation listener. int nItems = evaluators.length; IEvaluationListener evalListener = evaluators[0].getEvaluationListener(); // make sure that all evaluators have the same listener for(int i=0; i oldEnvs = new HashSet<>(); for(int i=0; i i = _evaluatorsByName.keySet().iterator(); int count=0; while(i.hasNext()) { if (count++>0) { sb.append(", "); } sb.append("'").append(i.next()).append("'"); } sb.append(")"); } throw new WorkbookNotFoundException(sb.toString()); } return result; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy