1*7836SJohn.Forte@Sun.COM /* 2*7836SJohn.Forte@Sun.COM * CDDL HEADER START 3*7836SJohn.Forte@Sun.COM * 4*7836SJohn.Forte@Sun.COM * The contents of this file are subject to the terms of the 5*7836SJohn.Forte@Sun.COM * Common Development and Distribution License (the "License"). 6*7836SJohn.Forte@Sun.COM * You may not use this file except in compliance with the License. 7*7836SJohn.Forte@Sun.COM * 8*7836SJohn.Forte@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*7836SJohn.Forte@Sun.COM * or http://www.opensolaris.org/os/licensing. 10*7836SJohn.Forte@Sun.COM * See the License for the specific language governing permissions 11*7836SJohn.Forte@Sun.COM * and limitations under the License. 12*7836SJohn.Forte@Sun.COM * 13*7836SJohn.Forte@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each 14*7836SJohn.Forte@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*7836SJohn.Forte@Sun.COM * If applicable, add the following below this CDDL HEADER, with the 16*7836SJohn.Forte@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*7836SJohn.Forte@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*7836SJohn.Forte@Sun.COM * 19*7836SJohn.Forte@Sun.COM * CDDL HEADER END 20*7836SJohn.Forte@Sun.COM */ 21*7836SJohn.Forte@Sun.COM /* 22*7836SJohn.Forte@Sun.COM * Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23*7836SJohn.Forte@Sun.COM * Use is subject to license terms. 24*7836SJohn.Forte@Sun.COM */ 25*7836SJohn.Forte@Sun.COM 26*7836SJohn.Forte@Sun.COM #ifndef _EVENTBRIDGEFACTORY_H 27*7836SJohn.Forte@Sun.COM #define _EVENTBRIDGEFACTORY_H 28*7836SJohn.Forte@Sun.COM 29*7836SJohn.Forte@Sun.COM 30*7836SJohn.Forte@Sun.COM 31*7836SJohn.Forte@Sun.COM #include "AdapterAddEventBridge.h" 32*7836SJohn.Forte@Sun.COM #include "AdapterEventBridge.h" 33*7836SJohn.Forte@Sun.COM #include "AdapterPortEventBridge.h" 34*7836SJohn.Forte@Sun.COM #include "AdapterDeviceEventBridge.h" 35*7836SJohn.Forte@Sun.COM #include "AdapterPortStatEventBridge.h" 36*7836SJohn.Forte@Sun.COM #include "LinkEventBridge.h" 37*7836SJohn.Forte@Sun.COM #include "TargetEventBridge.h" 38*7836SJohn.Forte@Sun.COM 39*7836SJohn.Forte@Sun.COM /* 40*7836SJohn.Forte@Sun.COM * @memo Static routines to build the proper event bridge 41*7836SJohn.Forte@Sun.COM * for the current version of the library. 42*7836SJohn.Forte@Sun.COM * 43*7836SJohn.Forte@Sun.COM * @doc To keep client code isolated from the underlying 44*7836SJohn.Forte@Sun.COM * event infrastructure (eg: sysevent, IOCTLs, etc.) 45*7836SJohn.Forte@Sun.COM * Bridge classes are used for registration. This 46*7836SJohn.Forte@Sun.COM * factory interface allows client code to be compiled 47*7836SJohn.Forte@Sun.COM * once without knowledge of the underlying details. 48*7836SJohn.Forte@Sun.COM * The concrete implementation of this class will 49*7836SJohn.Forte@Sun.COM * define which concrete bridge instance(s) 50*7836SJohn.Forte@Sun.COM * are returned. 51*7836SJohn.Forte@Sun.COM */ 52*7836SJohn.Forte@Sun.COM class EventBridgeFactory { 53*7836SJohn.Forte@Sun.COM public: 54*7836SJohn.Forte@Sun.COM static AdapterAddEventBridge* fetchAdapterAddEventBridge(); 55*7836SJohn.Forte@Sun.COM static AdapterEventBridge* fetchAdapterEventBridge(); 56*7836SJohn.Forte@Sun.COM static AdapterPortEventBridge* fetchAdapterPortEventBridge(); 57*7836SJohn.Forte@Sun.COM static AdapterDeviceEventBridge* fetchAdapterDeviceEventBridge(); 58*7836SJohn.Forte@Sun.COM static AdapterPortStatEventBridge* fetchAdapterPortStatEventBridge(); 59*7836SJohn.Forte@Sun.COM static TargetEventBridge* fetchTargetEventBridge(); 60*7836SJohn.Forte@Sun.COM static LinkEventBridge* fetchLinkEventBridge(); 61*7836SJohn.Forte@Sun.COM }; 62*7836SJohn.Forte@Sun.COM 63*7836SJohn.Forte@Sun.COM #endif /* _EVENTBRIDGEFACTORY_H */ 64