GNUnet  0.11.x
Data Structures | Functions
testing_api_cmd_hello_world_birth.c File Reference
#include "platform.h"
#include "gnunet_util_lib.h"
#include "gnunet_testing_ng_lib.h"
Include dependency graph for testing_api_cmd_hello_world_birth.c:

Go to the source code of this file.

Data Structures

struct  HelloWorldBirthState
 

Functions

static void hello_world_birth_cleanup (void *cls, const struct GNUNET_TESTING_Command *cmd)
 
static int hello_world_birth_traits (void *cls, const void **ret, const char *trait, unsigned int index)
 
static void hello_world_birth_run (void *cls, const struct GNUNET_TESTING_Command *cmd, struct GNUNET_TESTING_Interpreter *is)
 Run the "hello world" CMD. More...
 
int GNUNET_TESTING_get_trait_what_am_i (const struct GNUNET_TESTING_Command *cmd, char **what_am_i)
 Offer data from trait. More...
 
struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_hello_world_birth (const char *label, struct GNUNET_TIME_Absolute *now)
 Create command. More...
 

Function Documentation

◆ hello_world_birth_cleanup()

static void hello_world_birth_cleanup ( void *  cls,
const struct GNUNET_TESTING_Command cmd 
)
static
Parameters
clsclosure
cmdcurrent CMD being cleaned up.

Definition at line 43 of file testing_api_cmd_hello_world_birth.c.

References GNUNET_ERROR_TYPE_INFO, GNUNET_log, and HelloWorldBirthState::what_am_i.

Referenced by GNUNET_TESTING_cmd_hello_world_birth().

45 {
46  struct HelloWorldBirthState *hbs = cls;
48  "Finished birth of %s\n",
49  hbs->what_am_i);
50 }
#define GNUNET_log(kind,...)
Here is the caller graph for this function:

◆ hello_world_birth_traits()

static int hello_world_birth_traits ( void *  cls,
const void **  ret,
const char *  trait,
unsigned int  index 
)
static
Parameters
clsclosure.
[out]retresult
traitname of the trait.
indexindex number of the object to offer.
Returns
GNUNET_OK on success.

Definition at line 62 of file testing_api_cmd_hello_world_birth.c.

References GNUNET_TESTING_get_trait(), GNUNET_TESTING_trait_end(), GNUNET_TESTING_Trait::index, and HelloWorldBirthState::what_am_i.

Referenced by GNUNET_TESTING_cmd_hello_world_birth().

66 {
67  struct HelloWorldBirthState *hbs = cls;
68  const char *what_am_i = hbs->what_am_i;
69 
70  struct GNUNET_TESTING_Trait traits[] = {
71  {
72  .index = 0,
73  .trait_name = "what_am_i",
74  .ptr = (const void *) what_am_i,
75  },
77  };
78 
79  return GNUNET_TESTING_get_trait (traits,
80  ret,
81  trait,
82  index);
83 }
static int ret
Return value of the commandline.
Definition: gnunet-abd.c:81
unsigned int index
Index number associated with the trait.
int GNUNET_TESTING_get_trait(const struct GNUNET_TESTING_Trait *traits, const void **ret, const char *trait, unsigned int index)
Extract a trait.
struct GNUNET_TESTING_Trait GNUNET_TESTING_trait_end(void)
"end" trait.
Here is the call graph for this function:
Here is the caller graph for this function:

◆ hello_world_birth_run()

static void hello_world_birth_run ( void *  cls,
const struct GNUNET_TESTING_Command cmd,
struct GNUNET_TESTING_Interpreter is 
)
static

Run the "hello world" CMD.

Parameters
clsclosure.
cmdCMD being run.
isinterpreter state.

Definition at line 93 of file testing_api_cmd_hello_world_birth.c.

References HelloWorldBirthState::date, GNUNET_TIME_absolute_get(), GNUNET_TIME_absolute_get_difference(), and HelloWorldBirthState::what_am_i.

Referenced by GNUNET_TESTING_cmd_hello_world_birth().

96 {
97  struct HelloWorldBirthState *hbs = cls;
98  struct GNUNET_TIME_Relative relative;
99 
100  relative = GNUNET_TIME_absolute_get_difference (*hbs->date,
102 
103  if (0 == relative.rel_value_us % 10)
104  {
105  hbs->what_am_i = "creature!";
106  }
107  else if (0 == relative.rel_value_us % 2)
108  {
109  hbs->what_am_i = "girl!";
110  }
111  else
112  {
113  hbs->what_am_i = "boy!";
114  }
115 }
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get(void)
Get the current time.
Definition: time.c:86
struct GNUNET_TIME_Relative GNUNET_TIME_absolute_get_difference(struct GNUNET_TIME_Absolute start, struct GNUNET_TIME_Absolute end)
Compute the time difference between the given start and end times.
Definition: time.c:248
Time for relative time used by GNUnet, in microseconds.
struct GNUNET_TIME_Absolute * date
Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_TESTING_get_trait_what_am_i()

int GNUNET_TESTING_get_trait_what_am_i ( const struct GNUNET_TESTING_Command cmd,
char **  what_am_i 
)

Offer data from trait.

Parameters
cmdcommand to extract the message from.
ptpointer to message.
Returns
GNUNET_OK on success.

Definition at line 125 of file testing_api_cmd_hello_world_birth.c.

References GNUNET_TESTING_Command::cls, and GNUNET_TESTING_Command::traits.

Referenced by hello_world_run().

127 {
128  return cmd->traits (cmd->cls,
129  (const void **) what_am_i,
130  "what_am_i",
131  (unsigned int) 0);
132 }
int(* traits)(void *cls, const void **ret, const char *trait, unsigned int index)
Extract information from a command that is useful for other commands.
void * cls
Closure for all commands with command-specific context information.
Here is the caller graph for this function:

◆ GNUNET_TESTING_cmd_hello_world_birth()

struct GNUNET_TESTING_Command GNUNET_TESTING_cmd_hello_world_birth ( const char *  label,
struct GNUNET_TIME_Absolute now 
)

Create command.

Parameters
labelname for command.
nowwhen the command was started.
Returns
command.

Definition at line 142 of file testing_api_cmd_hello_world_birth.c.

References GNUNET_TESTING_Command::cls, HelloWorldBirthState::date, GNUNET_new, hello_world_birth_cleanup(), hello_world_birth_run(), hello_world_birth_traits(), and GNUNET_TESTING_Command::label.

144 {
145  struct HelloWorldBirthState *hbs;
146 
147  hbs = GNUNET_new (struct HelloWorldBirthState);
148  hbs->date = now;
149 
150  struct GNUNET_TESTING_Command cmd = {
151  .cls = hbs,
152  .label = label,
153  .run = &hello_world_birth_run,
154  .cleanup = &hello_world_birth_cleanup,
155  .traits = &hello_world_birth_traits
156  };
157 
158  return cmd;
159 }
const char * label
Label for the command.
A command to be run by the interpreter.
#define GNUNET_new(type)
Allocate a struct or union of the given type.
static void hello_world_birth_run(void *cls, const struct GNUNET_TESTING_Command *cmd, struct GNUNET_TESTING_Interpreter *is)
Run the "hello world" CMD.
static void hello_world_birth_cleanup(void *cls, const struct GNUNET_TESTING_Command *cmd)
static int hello_world_birth_traits(void *cls, const void **ret, const char *trait, unsigned int index)
void * cls
Closure for all commands with command-specific context information.
struct GNUNET_TIME_Absolute * date
Here is the call graph for this function: