file: example.c
This is a C source file used to test cdoc.
license: 0BSD
function: swap
Exchange two objects of equal size.
param: p1
Pointer to the first object.
param: p2
Pointer to the second object.
param: size
The sizeof both objects.
note:
Objects p1 and p2 may point to overlapping memory.
E.g swap(&foo, &foo, sizeof(foo)) is valid.
void swap(void* p1, void* p2, size_t size);
struct: string
POD type representing an array-of-char with a known size.
struct string
{
char* data;
size_t size;
};
union: foobar
A data packet sent over the wire from FooBar Inc.
union foobar
{
uint32_t foo;
float bar;
};
enum: color
todo:
Add more colors.
typedef enum
{
RED = 0,
BLUE = 1,
GREEN = 2
} color;
typedef: colour
Convenient typedef for non-American software engineers.
typedef color colour;
function: get_color
Cdoc should be lenient with whitespace.
Any amount of indenting should be allowed.
Even with tabs.
return:
My favorite color.
color get_color(void)
{
/* function definition... */
macro: M_PER_KM
#define M_PER_KM 1000
macro: KM
Convert meters into kilometers.
#define KM(meters) \
(meters * M_PER_KM)
macro: NUM_FOOBAR
256 is a computer-ish number, right?
#define NUM_FOOBAR 256
variable: foobars
union foobar foobars[NUM_FOOBAR];