#ifndef __SCIP_OBJSEPA_H__
#define __SCIP_OBJSEPA_H__
#include <cstring>
#include <utility>
#include "scip/scip.h"
#include "objscip/objcloneable.h"
namespace scip
{
class ObjSepa : public ObjCloneable
{
public:
SCIP* scip_;
char* scip_name_;
char* scip_desc_;
const int scip_priority_;
const int scip_freq_;
const SCIP_Real scip_maxbounddist_;
const SCIP_Bool scip_usessubscip_;
const SCIP_Bool scip_delay_;
ObjSepa(
SCIP* scip,
const char* name,
const char* desc,
int priority,
int freq,
SCIP_Real maxbounddist,
SCIP_Bool usessubscip,
SCIP_Bool delay
)
: scip_(scip),
scip_name_(0),
scip_desc_(0),
scip_priority_(priority),
scip_freq_(freq),
scip_maxbounddist_(maxbounddist),
scip_usessubscip_(usessubscip),
scip_delay_(delay)
{
SCIP_CALL_ABORT( SCIPduplicateMemoryArray(scip_, &scip_name_, name, std::strlen(name)+1) );
SCIP_CALL_ABORT( SCIPduplicateMemoryArray(scip_, &scip_desc_, desc, std::strlen(desc)+1) );
}
ObjSepa(const ObjSepa& o)
: ObjSepa(o.scip_, o.scip_name_, o.scip_desc_, o.scip_priority_, o.scip_freq_, o.scip_maxbounddist_,
o.scip_usessubscip_, o.scip_delay_)
{
}
ObjSepa(ObjSepa&& o)
: scip_(o.scip_),
scip_name_(0),
scip_desc_(0),
scip_priority_(o.scip_priority_),
scip_freq_(o.scip_freq_),
scip_maxbounddist_(o.scip_maxbounddist_),
scip_usessubscip_(o.scip_usessubscip_),
scip_delay_(o.scip_delay_)
{
std::swap(scip_name_, o.scip_name_);
std::swap(scip_desc_, o.scip_desc_);
}
virtual ~ObjSepa()
{
SCIPfreeMemoryArray(scip_, &scip_name_);
SCIPfreeMemoryArray(scip_, &scip_desc_);
}
ObjSepa& operator=(const ObjSepa& o) = delete;
ObjSepa& operator=(ObjSepa&& o) = delete;
virtual SCIP_DECL_SEPAFREE(scip_free)
{
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAINIT(scip_init)
{
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAEXIT(scip_exit)
{
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAINITSOL(scip_initsol)
{
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAEXITSOL(scip_exitsol)
{
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAEXECLP(scip_execlp)
{
assert(result != NULL);
*result = SCIP_DIDNOTRUN;
return SCIP_OKAY;
}
virtual SCIP_DECL_SEPAEXECSOL(scip_execsol)
{
assert(result != NULL);
*result = SCIP_DIDNOTRUN;
return SCIP_OKAY;
}
};
}
SCIP_EXPORT
SCIP_RETCODE SCIPincludeObjSepa(
SCIP* scip,
scip::ObjSepa* objsepa,
SCIP_Bool deleteobject
);
SCIP_EXPORT
scip::ObjSepa* SCIPfindObjSepa(
SCIP* scip,
const char* name
);
SCIP_EXPORT
scip::ObjSepa* SCIPgetObjSepa(
SCIP* scip,
SCIP_SEPA* sepa
);
#endif