Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mruby
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Libraries
mruby
Commits
c0b52204
Commit
c0b52204
authored
Mar 28, 2013
by
Masaki Muranaka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Modify mrb_name_error() to use mrb_format().
parent
e265d7c7
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
19 additions
and
22 deletions
+19
-22
src/class.c
src/class.c
+12
-12
src/error.c
src/error.c
+4
-8
src/error.h
src/error.h
+1
-0
src/kernel.c
src/kernel.c
+2
-2
No files found.
src/class.c
View file @
c0b52204
...
...
@@ -1473,7 +1473,7 @@ check_cv_name(mrb_state *mrb, mrb_sym id)
s
=
mrb_sym2name_len
(
mrb
,
id
,
&
len
);
if
(
len
<
3
||
!
(
s
[
0
]
==
'@'
&&
s
[
1
]
==
'@'
))
{
mrb_name_error
(
mrb
,
id
,
"`%
s' is not allowed as a class variable name"
,
s
);
mrb_name_error
(
mrb
,
id
,
"`%
S' is not allowed as a class variable name"
,
mrb_sym2str
(
mrb
,
id
)
);
}
}
...
...
@@ -1595,12 +1595,12 @@ mrb_mod_remove_cvar(mrb_state *mrb, mrb_value mod)
if
(
!
mrb_undef_p
(
val
))
return
val
;
if
(
mrb_cv_defined
(
mrb
,
mod
,
id
)){
mrb_name_error
(
mrb
,
id
,
"cannot remove %
s for %s
"
,
mrb_sym2name
(
mrb
,
id
),
mrb_class_name
(
mrb
,
mrb_class_ptr
(
mod
))
);
mrb_name_error
(
mrb
,
id
,
"cannot remove %
S for %S
"
,
mrb_sym2str
(
mrb
,
id
),
mod
);
}
mrb_name_error
(
mrb
,
id
,
"class variable %
s not defined for %s
"
,
mrb_sym2name
(
mrb
,
id
),
mrb_class_name
(
mrb
,
mrb_class_ptr
(
mod
))
);
mrb_name_error
(
mrb
,
id
,
"class variable %
S not defined for %S
"
,
mrb_sym2str
(
mrb
,
id
),
mod
);
/* not reached */
return
mrb_nil_value
();
...
...
@@ -1645,8 +1645,9 @@ mrb_mod_method_defined(mrb_state *mrb, mrb_value mod)
}
static
void
remove_method
(
mrb_state
*
mrb
,
struct
RClass
*
c
,
mrb_sym
mid
)
remove_method
(
mrb_state
*
mrb
,
mrb_value
mod
,
mrb_sym
mid
)
{
struct
RClass
*
c
=
mrb_class_ptr
(
mod
);
khash_t
(
mt
)
*
h
=
c
->
mt
;
khiter_t
k
;
...
...
@@ -1658,8 +1659,8 @@ remove_method(mrb_state *mrb, struct RClass *c, mrb_sym mid)
}
}
mrb_name_error
(
mrb
,
mid
,
"method `%
s' not defined in %s
"
,
mrb_sym2
name
(
mrb
,
mid
),
mrb_class_name
(
mrb
,
c
)
);
mrb_name_error
(
mrb
,
mid
,
"method `%
S' not defined in %S
"
,
mrb_sym2
str
(
mrb
,
mid
),
mod
);
}
/* 15.2.2.4.41 */
...
...
@@ -1674,13 +1675,12 @@ remove_method(mrb_state *mrb, struct RClass *c, mrb_sym mid)
mrb_value
mrb_mod_remove_method
(
mrb_state
*
mrb
,
mrb_value
mod
)
{
struct
RClass
*
c
=
mrb_class_ptr
(
mod
);
int
argc
;
mrb_value
*
argv
;
mrb_get_args
(
mrb
,
"*"
,
&
argv
,
&
argc
);
while
(
argc
--
)
{
remove_method
(
mrb
,
c
,
mrb_symbol
(
*
argv
));
remove_method
(
mrb
,
mod
,
mrb_symbol
(
*
argv
));
argv
++
;
}
return
mod
;
...
...
@@ -1694,7 +1694,7 @@ check_const_name(mrb_state *mrb, mrb_sym id)
s
=
mrb_sym2name_len
(
mrb
,
id
,
&
len
);
if
(
len
<
1
||
!
ISUPPER
(
*
s
))
{
mrb_name_error
(
mrb
,
id
,
"wrong constant name %
s"
,
s
);
mrb_name_error
(
mrb
,
id
,
"wrong constant name %
S"
,
mrb_sym2str
(
mrb
,
id
)
);
}
}
...
...
@@ -1743,7 +1743,7 @@ mrb_mod_remove_const(mrb_state *mrb, mrb_value mod)
check_const_name
(
mrb
,
id
);
val
=
mrb_iv_remove
(
mrb
,
mod
,
id
);
if
(
mrb_undef_p
(
val
))
{
mrb_name_error
(
mrb
,
id
,
"constant %
s not defined"
,
mrb_sym2name
(
mrb
,
id
));
mrb_name_error
(
mrb
,
id
,
"constant %
S not defined"
,
mrb_sym2str
(
mrb
,
id
));
}
return
val
;
}
...
...
src/error.c
View file @
c0b52204
...
...
@@ -292,18 +292,14 @@ mrb_raisef(mrb_state *mrb, struct RClass *c, const char *fmt, ...)
void
mrb_name_error
(
mrb_state
*
mrb
,
mrb_sym
id
,
const
char
*
fmt
,
...)
{
mrb_value
exc
,
argv
[
2
];
mrb_value
exc
;
mrb_value
argv
[
2
];
va_list
args
;
char
buf
[
256
];
int
n
;
va_start
(
args
,
fmt
);
n
=
vsnprintf
(
buf
,
sizeof
(
buf
)
,
fmt
,
args
);
argv
[
0
]
=
mrb_vformat
(
mrb
,
fmt
,
args
);
va_end
(
args
);
if
(
n
<
0
)
{
n
=
0
;
}
argv
[
0
]
=
mrb_str_new
(
mrb
,
buf
,
n
);
argv
[
1
]
=
mrb_symbol_value
(
id
);
/* ignore now */
exc
=
mrb_class_new_instance
(
mrb
,
1
,
argv
,
E_NAME_ERROR
);
mrb_exc_raise
(
mrb
,
exc
);
...
...
src/error.h
View file @
c0b52204
...
...
@@ -12,6 +12,7 @@ int sysexit_status(mrb_state *mrb, mrb_value err);
mrb_value
mrb_exc_new3
(
mrb_state
*
mrb
,
struct
RClass
*
c
,
mrb_value
str
);
mrb_value
make_exception
(
mrb_state
*
mrb
,
int
argc
,
mrb_value
*
argv
,
int
isstr
);
mrb_value
mrb_make_exception
(
mrb_state
*
mrb
,
int
argc
,
mrb_value
*
argv
);
mrb_value
mrb_format
(
mrb_state
*
mrb
,
const
char
*
format
,
...);
void
mrb_name_error
(
mrb_state
*
mrb
,
mrb_sym
id
,
const
char
*
fmt
,
...);
void
mrb_exc_print
(
mrb_state
*
mrb
,
struct
RObject
*
exc
);
...
...
src/kernel.c
View file @
c0b52204
...
...
@@ -556,7 +556,7 @@ check_iv_name(mrb_state *mrb, mrb_sym id)
s
=
mrb_sym2name_len
(
mrb
,
id
,
&
len
);
if
(
len
<
2
||
!
(
s
[
0
]
==
'@'
&&
s
[
1
]
!=
'@'
))
{
mrb_name_error
(
mrb
,
id
,
"`%
s' is not allowed as an instance variable name"
,
s
);
mrb_name_error
(
mrb
,
id
,
"`%
S' is not allowed as an instance variable name"
,
mrb_sym2str
(
mrb
,
id
)
);
}
}
...
...
@@ -964,7 +964,7 @@ mrb_obj_remove_instance_variable(mrb_state *mrb, mrb_value self)
check_iv_name
(
mrb
,
sym
);
val
=
mrb_iv_remove
(
mrb
,
self
,
sym
);
if
(
mrb_undef_p
(
val
))
{
mrb_name_error
(
mrb
,
sym
,
"instance variable %
s not defined"
,
mrb_sym2name
(
mrb
,
sym
));
mrb_name_error
(
mrb
,
sym
,
"instance variable %
S not defined"
,
mrb_sym2str
(
mrb
,
sym
));
}
return
val
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment