Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
flow3r firmware
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
GitLab community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
dos
flow3r firmware
Commits
df4b4f31
Commit
df4b4f31
authored
Oct 19, 2013
by
Damien
Browse files
Options
Downloads
Patches
Plain Diff
Make grammar rules const so the go in .text section.
parent
4d7adce9
No related branches found
No related tags found
No related merge requests found
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
py/parse.c
+7
-7
7 additions, 7 deletions
py/parse.c
py/runtime.c
+1
-1
1 addition, 1 deletion
py/runtime.c
py/runtime.h
+1
-1
1 addition, 1 deletion
py/runtime.h
with
9 additions
and
9 deletions
py/parse.c
+
7
−
7
View file @
df4b4f31
...
...
@@ -55,9 +55,9 @@ enum {
#define opt_tok(t) (RULE_ARG_OPT_TOK | PY_TOKEN_##t)
#define opt_rule(r) (RULE_ARG_OPT_RULE | RULE_##r)
#ifdef USE_RULE_NAME
#define DEF_RULE(rule, comp, kind, arg...) static rule_t rule_##rule = { RULE_##rule, kind, #rule, { arg } };
#define DEF_RULE(rule, comp, kind, arg...) static
const
rule_t rule_##rule = { RULE_##rule, kind, #rule, { arg } };
#else
#define DEF_RULE(rule, comp, kind, arg...) static rule_t rule_##rule = { RULE_##rule, kind, { arg } };
#define DEF_RULE(rule, comp, kind, arg...) static
const
rule_t rule_##rule = { RULE_##rule, kind, { arg } };
#endif
#include
"grammar.h"
#undef or
...
...
@@ -71,7 +71,7 @@ enum {
#undef one_or_more
#undef DEF_RULE
static
rule_t
*
rules
[]
=
{
static
const
rule_t
*
rules
[]
=
{
NULL
,
#define DEF_RULE(rule, comp, kind, arg...) &rule_##rule,
#include
"grammar.h"
...
...
@@ -92,7 +92,7 @@ typedef struct _parser_t {
py_parse_node_t
*
result_stack
;
}
parser_t
;
static
void
push_rule
(
parser_t
*
parser
,
rule_t
*
rule
,
int
arg_i
)
{
static
void
push_rule
(
parser_t
*
parser
,
const
rule_t
*
rule
,
int
arg_i
)
{
if
(
parser
->
rule_stack_top
>=
parser
->
rule_stack_alloc
)
{
parser
->
rule_stack_alloc
*=
2
;
parser
->
rule_stack
=
m_renew
(
rule_stack_t
,
parser
->
rule_stack
,
parser
->
rule_stack_alloc
);
...
...
@@ -109,7 +109,7 @@ static void push_rule_from_arg(parser_t *parser, uint arg) {
push_rule
(
parser
,
rules
[
rule_id
],
0
);
}
static
void
pop_rule
(
parser_t
*
parser
,
rule_t
**
rule
,
uint
*
arg_i
)
{
static
void
pop_rule
(
parser_t
*
parser
,
const
rule_t
**
rule
,
uint
*
arg_i
)
{
parser
->
rule_stack_top
-=
1
;
*
rule
=
rules
[
parser
->
rule_stack
[
parser
->
rule_stack_top
].
rule_id
];
*
arg_i
=
parser
->
rule_stack
[
parser
->
rule_stack_top
].
arg_i
;
...
...
@@ -243,7 +243,7 @@ static void push_result_token(parser_t *parser, const py_lexer_t *lex) {
push_result_node
(
parser
,
pn
);
}
static
void
push_result_rule
(
parser_t
*
parser
,
rule_t
*
rule
,
int
num_args
)
{
static
void
push_result_rule
(
parser_t
*
parser
,
const
rule_t
*
rule
,
int
num_args
)
{
py_parse_node_struct_t
*
pn
=
parse_node_new_struct
(
rule
->
rule_id
,
num_args
);
for
(
int
i
=
num_args
;
i
>
0
;
i
--
)
{
pn
->
nodes
[
i
-
1
]
=
pop_result
(
parser
);
...
...
@@ -270,7 +270,7 @@ py_parse_node_t py_parse(py_lexer_t *lex, py_parse_input_kind_t input_kind) {
uint
n
,
i
;
bool
backtrack
=
false
;
rule_t
*
rule
;
const
rule_t
*
rule
;
py_token_kind_t
tok_kind
;
bool
emit_rule
;
bool
had_trailing_sep
;
...
...
This diff is collapsed.
Click to expand it.
py/runtime.c
+
1
−
1
View file @
df4b4f31
...
...
@@ -1546,7 +1546,7 @@ py_obj_t rt_iternext(py_obj_t o_in) {
}
}
const
void
*
const
rt_fun_table
[
RT_F_NUMBER_OF
]
=
{
void
*
const
rt_fun_table
[
RT_F_NUMBER_OF
]
=
{
rt_load_const_str
,
rt_load_name
,
rt_load_global
,
...
...
This diff is collapsed.
Click to expand it.
py/runtime.h
+
1
−
1
View file @
df4b4f31
...
...
@@ -76,7 +76,7 @@ typedef enum {
RT_F_NUMBER_OF
,
}
rt_fun_kind_t
;
extern
const
void
*
const
rt_fun_table
[
RT_F_NUMBER_OF
];
extern
void
*
const
rt_fun_table
[
RT_F_NUMBER_OF
];
typedef
machine_ptr_t
py_obj_t
;
// must be of pointer size
typedef
py_obj_t
(
*
py_fun_0_t
)();
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment