0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-11-06 05:48:54 +01:00
construct/include/ircd/line.h
2016-09-21 16:28:51 -07:00

65 lines
2.7 KiB
C++

/*
* Copyright (C) 2016 Charybdis Development Team
* Copyright (C) 2016 Jason Volk <jason@zemos.net>
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice is present in all copies.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#define HAVE_IRCD_LINE_H
#ifdef __cplusplus
namespace ircd {
struct line
:rfc1459::line
{
using rfc1459::line::line;
auto &operator[](const size_t &pos) const;
auto &operator[](const size_t &pos);
};
inline auto &pfx(const line &line) { return line.pfx; }
inline auto &pfx(line &line) { return line.pfx; }
inline auto &nick(const line &line) { return pfx(line).nick; }
inline auto &nick(line &line) { return pfx(line).nick; }
inline auto &user(const line &line) { return pfx(line).user; }
inline auto &user(line &line) { return pfx(line).user; }
inline auto &host(const line &line) { return pfx(line).host; }
inline auto &host(line &line) { return pfx(line).host; }
inline auto &command(const line &line) { return line.cmd; }
inline auto &command(line &line) { return line.cmd; }
inline auto &parv(const line &line) { return line.parv; }
inline auto &parv(line &line) { return line.parv; }
inline auto parc(const line &line) { return parv(line).size(); }
inline auto &
line::operator[](const size_t &pos)
{
return parv.at(pos);
}
inline auto &
line::operator[](const size_t &pos)
const
{
return parv.at(pos);
}
} // namespace ircd
#endif