This repository has been archived by the owner on Oct 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathpragma_plugin.c
60 lines (51 loc) · 1.48 KB
/
pragma_plugin.c
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/* Demonstrates how to add custom pragmas */
#include "gcc-plugin.h"
#include <stdlib.h>
#include "config.h"
#include "system.h"
#include "coretypes.h"
#include "tm.h"
#include "rtl.h"
#include "tree.h"
#include "function.h"
#include "c-pragma.h"
#include "cpplib.h"
#include "tree-pass.h"
#include "intl.h"
int plugin_is_GPL_compatible;
/* handler of #pragma GCCPLUGIN sayhello "message" is quite similar to
handler of #pragma GCC message...*/
static void
handle_pragma_sayhello (cpp_reader *dummy)
{
tree message = 0;
if (pragma_lex (&message) != CPP_STRING)
{
warning (OPT_Wpragmas, "%<#pragma GCCPLUGIN sayhello%> is not a string");
return;
}
if (TREE_STRING_LENGTH (message) > 1)
if (cfun)
warning (OPT_Wpragmas,
"%<pragma GCCPLUGIN sayhello%> from function %qE: %s",
cfun->decl, TREE_STRING_POINTER (message));
else
warning (OPT_Wpragmas,
"%<pragma GCCPLUGIN sayhello%> outside of function: %s",
TREE_STRING_POINTER (message));
}
/* Plugin callback called during pragma registration */
static void
register_my_pragma (void *event_data, void *data)
{
warning (0, G_("Callback to register pragmas"));
c_register_pragma ("GCCPLUGIN", "sayhello", handle_pragma_sayhello);
}
int
plugin_init (struct plugin_name_args *plugin_info,
struct plugin_gcc_version *version)
{
const char *plugin_name = plugin_info->base_name;
register_callback (plugin_name, PLUGIN_PRAGMAS, register_my_pragma, NULL);
return 0;
}