Skip to content

Commit

Permalink
reapi: add C++ API functionality
Browse files Browse the repository at this point in the history
  • Loading branch information
milroy committed Dec 4, 2024
1 parent 1f812d4 commit 9c1eb40
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 0 deletions.
15 changes: 15 additions & 0 deletions resource/reapi/bindings/c++/reapi.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -190,6 +190,21 @@ class reapi_t {
return -1;
}

/*! Update the resource state with R.
*
* \param h Opaque handle. How it is used is an implementation
* detail. However, when it is used within a Flux's
* service module, it is expected to be a pointer
* to a flux_t object.
* \param R_subgraph R string of std::string.
* \return 0 on success; -1 on error.
*/
static int grow (void *h,
const std::string &R_subgraph)
{
return -1;
}

/*! Cancel the allocation or reservation corresponding to jobid.
*
* \param h Opaque handle. How it is used is an implementation
Expand Down
2 changes: 2 additions & 0 deletions resource/reapi/bindings/c++/reapi_cli.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ class resource_query_t {
void set_job (const uint64_t jobid, const std::shared_ptr<job_info_t> &job);
int remove_job (const uint64_t jobid);
int remove_job (const uint64_t jobid, const std::string &R, bool &full_removal);
int grow (const std::string &R_subgraph);
void incr_job_counter ();

/* Run the traverser to match the jobspec */
Expand Down Expand Up @@ -148,6 +149,7 @@ class reapi_cli_t : public reapi_t {
int64_t &at,
double &ov,
std::string &R_out);
static int grow (void *h, const std::string &R_subgraph);
static int cancel (void *h, const uint64_t jobid, bool noent_ok);
static int cancel (void *h,
const uint64_t jobid,
Expand Down
50 changes: 50 additions & 0 deletions resource/reapi/bindings/c++/reapi_cli_impl.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -165,6 +165,20 @@ int reapi_cli_t::update_allocate (void *h,
return NOT_YET_IMPLEMENTED;
}

int reapi_cli_t::grow (void *h,

Check warning on line 168 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L168

Added line #L168 was not covered by tests
const std::string &R_subgraph)
{
resource_query_t *rq = static_cast<resource_query_t *> (h);
int rc = -1;

Check warning on line 172 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L171-L172

Added lines #L171 - L172 were not covered by tests

if ((rc = rq->grow (R_subgraph)) != 0) {
m_err_msg += __FUNCTION__;
m_err_msg += ": ERROR: grow error: " + std::string (strerror (errno)) + "\n";

Check warning on line 176 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L174-L176

Added lines #L174 - L176 were not covered by tests
}

return rc;

Check warning on line 179 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L179

Added line #L179 was not covered by tests
}

int reapi_cli_t::match_allocate_multi (void *h,
bool orelse_reserve,
const char *jobs,
Expand Down Expand Up @@ -722,6 +736,42 @@ int resource_query_t::remove_job (const uint64_t jobid, const std::string &R, bo
return rc;
}

int resource_query_t::grow (const std::string &R_subgraph)

Check warning on line 739 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L739

Added line #L739 was not covered by tests
{
int rc = -1;
std::shared_ptr<resource_reader_base_t> reader;
vtx_t v = boost::graph_traits<resource_graph_t>::null_vertex ();

Check warning on line 743 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L741-L743

Added lines #L741 - L743 were not covered by tests

if (R_subgraph == "") {
errno = EINVAL;
return rc;

Check warning on line 747 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L745-L747

Added lines #L745 - L747 were not covered by tests
}
if (params.load_format != "jgf") {
m_err_msg = __FUNCTION__;
m_err_msg += ": ERROR: growing a resource graph not ";
m_err_msg += " initialized with JGF is unsupported\n";
errno = ENOTSUP;
return rc;

Check warning on line 754 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L749-L754

Added lines #L749 - L754 were not covered by tests
}
if ((reader = create_resource_reader ("jgf")) == nullptr) {
m_err_msg = __FUNCTION__;
m_err_msg += ": ERROR: can't create JGF reader\n";

Check warning on line 758 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L756-L758

Added lines #L756 - L758 were not covered by tests
return rc;
}
if ((rc = reader->unpack_at (db->resource_graph, db->metadata, v, R_subgraph, -1)) != 0) {
m_err_msg = __FUNCTION__;
m_err_msg += ": ERROR: reader returned error: ";
m_err_msg += reader->err_message () + "\n";
return rc;

Check warning on line 765 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L761-L765

Added lines #L761 - L765 were not covered by tests
}
if ((rc = traverser->initialize (db, matcher)) != 0) {
m_err_msg = __FUNCTION__;
m_err_msg += ": ERROR: reinitialize traverser after grow. ";
m_err_msg += reader->err_message () + "\n";

Check warning on line 770 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L767-L770

Added lines #L767 - L770 were not covered by tests
}
return rc;
}

Check warning on line 773 in resource/reapi/bindings/c++/reapi_cli_impl.hpp

View check run for this annotation

Codecov / codecov/patch

resource/reapi/bindings/c++/reapi_cli_impl.hpp#L773

Added line #L773 was not covered by tests

void resource_query_t::incr_job_counter ()
{
jobid_counter++;
Expand Down

0 comments on commit 9c1eb40

Please sign in to comment.