001// Copyright (c) FIRST and other WPILib contributors. 002// Open Source Software; you can modify and/or share it under the terms of 003// the WPILib BSD license file in the root directory of this project. 004 005package edu.wpi.first.networktables; 006 007/** 008 * Subscribe to multiple topics based on one or more topic name prefixes. Can be used in combination 009 * with NetworkTableListenerPoller to listen for value changes across all matching topics. 010 */ 011public final class MultiSubscriber implements AutoCloseable { 012 /** 013 * Create a multiple subscriber. 014 * 015 * @param inst instance 016 * @param prefixes topic name prefixes 017 * @param options subscriber options 018 */ 019 public MultiSubscriber(NetworkTableInstance inst, String[] prefixes, PubSubOption... options) { 020 m_inst = inst; 021 m_handle = NetworkTablesJNI.subscribeMultiple(inst.getHandle(), prefixes, options); 022 } 023 024 @Override 025 public synchronized void close() { 026 if (m_handle != 0) { 027 NetworkTablesJNI.unsubscribeMultiple(m_handle); 028 m_handle = 0; 029 } 030 } 031 032 /** 033 * Gets the instance for the subscriber. 034 * 035 * @return Instance 036 */ 037 public NetworkTableInstance getInstance() { 038 return m_inst; 039 } 040 041 /** 042 * Determines if the native handle is valid. 043 * 044 * @return True if the native handle is valid, false otherwise. 045 */ 046 public boolean isValid() { 047 return m_handle != 0; 048 } 049 050 /** 051 * Gets the native handle. 052 * 053 * @return Handle 054 */ 055 public int getHandle() { 056 return m_handle; 057 } 058 059 private final NetworkTableInstance m_inst; 060 private int m_handle; 061}