// file      : oracle/custom/test.hxx
// copyright : Copyright (c) 2009-2017 Code Synthesis Tools CC
// license   : GNU GPL v2; see accompanying LICENSE file

#ifndef TEST_HXX
#define TEST_HXX

#include <vector>

#include <odb/core.hxx>

// Map Numbers VARRAY Oracle type to std::vector<int>. This type is defined
// in the custom.sql file along with two helper functions that convert
// between Numbers and its string representation. The other half of this
// mapping is in traits.hxx (value_traits<std::vector<int>, id_string>).
//
#pragma db map type("Numbers")                               \
               as("VARCHAR2(1500)")                          \
               to("CAST(string_to_numbers((?)) AS Numbers)") \
               from("numbers_to_string((?))")

#pragma db object
struct object
{
  object () {}
  object (unsigned long id_) : id (id_) {}

  #pragma db id
  unsigned long id;

  #pragma db type("Numbers")
  std::vector<int> iv;

  bool
  operator== (const object& y) const
  {
    return id == y.id && iv == y.iv;
  }
};

#endif // TEST_HXX