/*
 * Copyright (c) 2011-2017 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */

package io.vertx.core.impl;

import io.vertx.core.*;
import io.vertx.core.spi.metrics.Metrics;
import io.vertx.core.spi.metrics.MetricsProvider;
import io.vertx.core.spi.metrics.PoolMetrics;

Author:Julien Viet
/** * @author <a href="mailto:julien@julienviet.com">Julien Viet</a> */
class WorkerExecutorImpl implements MetricsProvider, WorkerExecutorInternal { private final Context ctx; private final VertxImpl.SharedWorkerPool pool; private boolean closed; public WorkerExecutorImpl(Context ctx, VertxImpl.SharedWorkerPool pool) { this.ctx = ctx; this.pool = pool; } @Override public Metrics getMetrics() { return pool.metrics(); } @Override public boolean isMetricsEnabled() { PoolMetrics metrics = pool.metrics(); return metrics != null; } @Override public Vertx vertx() { return ctx.owner(); } @Override public WorkerPool getPool() { return pool; } public synchronized <T> void executeBlocking(Handler<Promise<T>> blockingCodeHandler, boolean ordered, Handler<AsyncResult<T>> asyncResultHandler) { if (closed) { throw new IllegalStateException("Worker executor closed"); } ContextImpl context = (ContextImpl) ctx.owner().getOrCreateContext(); context.executeBlocking(blockingCodeHandler, asyncResultHandler, pool.executor(), ordered ? context.orderedTasks : null, pool.metrics()); } @Override public void close() { synchronized (this) { if (!closed) { closed = true; } else { return; } } ctx.removeCloseHook(this); pool.release(); } @Override public void close(Handler<AsyncResult<Void>> completionHandler) { close(); completionHandler.handle(Future.succeededFuture()); } }