Interfacing with structs and anonymous unions with c2hs

HaskellC2hs

Haskell Problem Overview


How would one go about encoding this chunk of C code in a .chs file so that c2hs can transform it to something relatively nice?

typedef enum {
	MONOME_BUTTON_UP        = 0x00,
	MONOME_BUTTON_DOWN      = 0x01,
	MONOME_ENCODER_DELTA    = 0x02,
	MONOME_ENCODER_KEY_UP   = 0x03,
	MONOME_ENCODER_KEY_DOWN = 0x04,
	MONOME_TILT             = 0x05,

	/* update this if you add event types */
	MONOME_EVENT_MAX        = 0x06
} monome_event_type_t;

typedef struct monome monome_t; /* opaque data type */
typedef struct monome_event monome_event_t;

typedef void (*monome_event_callback_t)
	(const monome_event_t *event, void *data);

struct monome_event {
	monome_t *monome;
	monome_event_type_t event_type;

	/* __extension__ for anonymous unions in gcc */
	__extension__ union {
		struct {
			unsigned int x;
			unsigned int y;
		} grid;

		struct {
			unsigned int number;
			int delta;
		} encoder;

		struct {
			unsigned int sensor;
			int x;
			int y;
			int z;
		} tilt;
	};
};

Haskell Solutions


Solution 1 - Haskell

How about this: change the code so that you name the members. The layout in memory is the same so that it will be binary compatible. You would have to do this patch for each version of the lib.

struct monome_event {
	monome_t *monome;
	monome_event_type_t event_type;

	/* __extension__ for anonymous unions in gcc */
	__extension__ union {
		struct me_grid {
			unsigned int x;
			unsigned int y;
		} grid;

		struct me_encoder {
			unsigned int number;
			int delta;
		} encoder;

		struct me_tilt {
			unsigned int sensor;
			int x;
			int y;
			int z;
		} tilt;
	};
};

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser1908597View Question on Stackoverflow
Solution 1 - Haskellh4ck3rm1k3View Answer on Stackoverflow