File: GxB_Context_engage.c

package info (click to toggle)
suitesparse 1%3A7.10.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 254,920 kB
  • sloc: ansic: 1,134,743; cpp: 46,133; makefile: 4,875; fortran: 2,087; java: 1,826; sh: 996; ruby: 725; python: 495; asm: 371; sed: 166; awk: 44
file content (42 lines) | stat: -rw-r--r-- 1,707 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//------------------------------------------------------------------------------
// GxB_Context_engage: engage a Context for this user thread
//------------------------------------------------------------------------------

// SuiteSparse:GraphBLAS, Timothy A. Davis, (c) 2017-2025, All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0

//------------------------------------------------------------------------------

// GxB_Context_engage sets the provided Context object as the Context for this
// user thread.  Multiple user threads can share a single Context.  Any prior
// Context for this user thread is superseded by the new Context (the prior one
// is not freed).  GrB_SUCCESS is returned, and future calls to GraphBLAS by
// this user thread will use the provided Context.

// If the Context on input is the GxB_CONTEXT_WORLD object, then the current
// Context is disengaged.  That is, the following calls have the same effect,
// setting the Context of this user thread to GxB_CONTEXT_WORLD:
//
//      GxB_Context_engage (GxB_CONTEXT_WORLD) ;
//      GxB_Context_disengage (NULL) ;
//
// The result for both cases above is GrB_SUCCESS.

// Error cases:
// If Context is NULL on input, GrB_NULL_POINTER is returned.
// If a non-NULL Context is provided but it is faulty in some way, then an
// error code is returned (GrB_INVALID_OBJECT or GrB_UNINITIALIZED_OBJECT).
// If an error code is returned, the current Context for this user thread is
// unmodified.

#include "GB.h"

GrB_Info GxB_Context_engage         // engage a Context
(
    GxB_Context Context             // Context to engage
)
{ 
    GB_RETURN_IF_NULL_OR_FAULTY (Context) ;
    return (GB_Context_engage (Context)) ;
}