Blame ServerFunction.h

Packit a4aae4
// -*- mode: c++; c-basic-offset:4 -*-
Packit a4aae4
Packit a4aae4
// This file is part of libdap, A C++ implementation of the OPeNDAP Data
Packit a4aae4
// Access Protocol.
Packit a4aae4
Packit a4aae4
// Copyright (c) 2013 OPeNDAP, Inc.
Packit a4aae4
// Author: Nathan Potter <npotter@opendap.org>
Packit a4aae4
//
Packit a4aae4
// This library is free software; you can redistribute it and/or
Packit a4aae4
// modify it under the terms of the GNU Lesser General Public
Packit a4aae4
// License as published by the Free Software Foundation; either
Packit a4aae4
// version 2.1 of the License, or (at your option) any later version.
Packit a4aae4
//
Packit a4aae4
// This library is distributed in the hope that it will be useful,
Packit a4aae4
// but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit a4aae4
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit a4aae4
// Lesser General Public License for more details.
Packit a4aae4
//
Packit a4aae4
// You should have received a copy of the GNU Lesser General Public
Packit a4aae4
// License along with this library; if not, write to the Free Software
Packit a4aae4
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
Packit a4aae4
//
Packit a4aae4
// You can contact OPeNDAP, Inc. at PO Box 112, Saunderstown, RI. 02874-0112.
Packit a4aae4
Packit a4aae4
/*
Packit a4aae4
 * ServerFunction.h
Packit a4aae4
 *
Packit a4aae4
 *  Created on: Feb 2, 2013
Packit a4aae4
 *      Author: ndp
Packit a4aae4
 */
Packit a4aae4
Packit a4aae4
#ifndef SERVER_FUNCTION_H_
Packit a4aae4
#define SERVER_FUNCTION_H_
Packit a4aae4
Packit a4aae4
#include <iostream>
Packit a4aae4
Packit a4aae4
#include <expr.h>
Packit a4aae4
#include <D4Function.h>
Packit a4aae4
Packit a4aae4
namespace libdap {
Packit a4aae4
Packit a4aae4
class ServerFunction {
Packit a4aae4
Packit a4aae4
private:
Packit a4aae4
    std::string name;
Packit a4aae4
    std::string description;
Packit a4aae4
    std::string usage;
Packit a4aae4
    std::string doc_url;
Packit a4aae4
    std::string role;
Packit a4aae4
    std::string version;
Packit a4aae4
Packit a4aae4
    // These are typedefs from DAP2 that are used with its CE parser
Packit a4aae4
    // and are found in expr.h. jhrg 3/10/14
Packit a4aae4
    bool_func d_bool_func;
Packit a4aae4
    btp_func  d_btp_func;
Packit a4aae4
    proj_func d_proj_func;
Packit a4aae4
Packit a4aae4
    D4Function d_d4_function;
Packit a4aae4
Packit a4aae4
public:
Packit a4aae4
    ServerFunction();
Packit a4aae4
    ServerFunction(std::string name, std::string version, std::string description, std::string usage,
Packit a4aae4
    		std::string doc_url, std::string role, bool_func f);
Packit a4aae4
    ServerFunction(std::string name, std::string version, std::string description, std::string usage,
Packit a4aae4
    		std::string doc_url, std::string role, btp_func f);
Packit a4aae4
    ServerFunction(std::string name, std::string version, std::string description, std::string usage,
Packit a4aae4
    		std::string doc_url, std::string role, proj_func f);
Packit a4aae4
    ServerFunction(std::string name, std::string version, std::string description, std::string usage,
Packit a4aae4
    		std::string doc_url, std::string role, D4Function f);
Packit a4aae4
Packit a4aae4
    virtual ~ServerFunction() {	}
Packit a4aae4
Packit a4aae4
	std::string getName() { return name; }
Packit a4aae4
	void setName(const std::string &n){ name = n; }
Packit a4aae4
Packit a4aae4
	std::string getUsageString() { return usage; }
Packit a4aae4
	void setUsageString(const std::string &u){ usage = u; }
Packit a4aae4
Packit a4aae4
	std::string getDocUrl() { return doc_url; }
Packit a4aae4
	void setDocUrl(const std::string &url){ doc_url = url; }
Packit a4aae4
Packit a4aae4
	std::string getRole() { return role; }
Packit a4aae4
	void setRole(const std::string &r){ role = r; }
Packit a4aae4
Packit a4aae4
	std::string getDescriptionString(){ return description; }
Packit a4aae4
	void setDescriptionString(const std::string &desc){ description = desc; }
Packit a4aae4
Packit a4aae4
	std::string getVersion(){ return version; }
Packit a4aae4
	void setVersion(const std::string &ver){ version = ver; }
Packit a4aae4
Packit a4aae4
	/**
Packit a4aae4
	 * If you are writing a function that can only operate on a particular kind of data, or one that relies on the presence
Packit a4aae4
	 * of particular metadata, then you might override this method in order to stop the server from
Packit a4aae4
	 * advertising the function in conjunction with datasets to which it cannot be applied.
Packit a4aae4
	 *
Packit a4aae4
	 * @param dds A DDS object for the dataset about which we will ask the question:
Packit a4aae4
	 * Can this function operate on all or some portion of the contents of this dataset?
Packit a4aae4
	 * CAUTION: Any implementation of this should be careful not to read data (or read as little as possible) from the
Packit a4aae4
	 * passed DDS. Reading data in this method may have negative effect on overall performance. Examining metadata and
Packit a4aae4
	 * dataset structure should be the basis for determining the applicability of a function to the dataset.
Packit a4aae4
	 * @return true If this function operate on all or some portion of the contents of this dataset, false otherwise.
Packit a4aae4
	 */
Packit a4aae4
	virtual bool canOperateOn(DDS &) { return true; }
Packit a4aae4
Packit a4aae4
	/**
Packit a4aae4
	 * @see canOperateOn(DDS &)
Packit a4aae4
	 * @param The Dataset's DMR.
Packit a4aae4
	 * @return True if the function can work with the dataset, false otherwise.
Packit a4aae4
	 */
Packit a4aae4
	virtual bool canOperateOn(DMR &) { return true; }
Packit a4aae4
Packit a4aae4
	/**
Packit a4aae4
	 * Set the C function pointer for this function object.
Packit a4aae4
	 * @note This does not alter any of the other function pointers,
Packit a4aae4
	 * so the same name can be used for all four different kinds of
Packit a4aae4
	 * functions without conflict.
Packit a4aae4
	 *
Packit a4aae4
	 * @param bf
Packit a4aae4
	 */
Packit a4aae4
	void setFunction(bool_func bf) {
Packit a4aae4
		d_bool_func = bf;
Packit a4aae4
	}
Packit a4aae4
Packit a4aae4
	void setFunction(btp_func btp) {
Packit a4aae4
		d_btp_func  = btp;
Packit a4aae4
	}
Packit a4aae4
Packit a4aae4
	void setFunction(proj_func pf) {
Packit a4aae4
		d_proj_func = pf;
Packit a4aae4
	}
Packit a4aae4
Packit a4aae4
	void setFunction(D4Function pf) {
Packit a4aae4
		d_d4_function = pf;
Packit a4aae4
	}
Packit a4aae4
Packit a4aae4
	std::string getTypeString() {
Packit a4aae4
		if (d_bool_func) return "boolean";
Packit a4aae4
		if (d_btp_func) return "basetype";
Packit a4aae4
		if (d_proj_func) return "projection";
Packit a4aae4
		if (d_d4_function) return "D4Function";
Packit a4aae4
		return "null";
Packit a4aae4
	}
Packit a4aae4
Packit a4aae4
	bool_func get_bool_func(){ return d_bool_func; }
Packit a4aae4
	btp_func  get_btp_func() { return d_btp_func;  }
Packit a4aae4
	proj_func get_proj_func(){ return d_proj_func; }
Packit a4aae4
	D4Function get_d4_function() { return d_d4_function; }
Packit a4aae4
};
Packit a4aae4
Packit a4aae4
} /* namespace libdap */
Packit a4aae4
#endif /* SERVER_FUNCTION_H_ */