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
5ef8aa76
Commit
5ef8aa76
authored
Jan 24, 2013
by
Yukihiro Matz Matsumoto
Browse files
Options
Browse Files
Download
Plain Diff
resolve conflict
parents
cc967ebf
dd680b6e
Changes
10
Show whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
38 additions
and
17 deletions
+38
-17
build_config.rb
build_config.rb
+2
-0
doc/compile/README.md
doc/compile/README.md
+2
-0
tasks/libmruby.rake
tasks/libmruby.rake
+3
-0
tasks/mrbgem_spec.rake
tasks/mrbgem_spec.rake
+2
-2
tasks/mruby_build_commands.rake
tasks/mruby_build_commands.rake
+17
-9
tasks/toolchains/gcc.rake
tasks/toolchains/gcc.rake
+1
-1
tasks/toolchains/vs2012.rake
tasks/toolchains/vs2012.rake
+1
-1
test/mrbtest.rake
test/mrbtest.rake
+4
-2
tools/mirb/mirb.rake
tools/mirb/mirb.rake
+3
-1
tools/mruby/mruby.rake
tools/mruby/mruby.rake
+3
-1
No files found.
build_config.rb
View file @
5ef8aa76
...
...
@@ -29,7 +29,9 @@ MRuby::Build.new do |conf|
# conf.linker do |linker|
# linker.command = ENV['LD'] || 'gcc'
# linker.flags = [ENV['LDFLAGS'] || []]
# linker.flags_before_libraries = []
# linker.libraries = %w()
# linker.flags_after_libraries = []
# linker.library_paths = []
# linker.option_library = '-l%s'
# linker.option_library_path = '-L%s'
...
...
doc/compile/README.md
View file @
5ef8aa76
...
...
@@ -118,7 +118,9 @@ Configuration of the Linker binary, flags and library paths.
conf.linker do |linker|
linker.command = ...
linker.flags = ...
linker.flags_before_libraries = ...
linker.libraries = ...
linker.flags_after_libraries = ...
linker.library_paths = ....
linker.option_library = ...
linker.option_library_path = ...
...
...
tasks/libmruby.rake
View file @
5ef8aa76
...
...
@@ -8,6 +8,9 @@ MRuby.each_target do
gem_library_paths
=
gems
.
map
{
|
g
|
g
.
linker
.
library_paths
}
f
.
puts
'MRUBY_LDFLAGS = "%s"'
%
linker
.
all_flags
(
gem_library_paths
,
gem_flags
).
gsub
(
'"'
,
'\\"'
)
gem_flags_before_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_before_libraries
}
f
.
puts
'MRUBY_LDFLAGS_BEFORE_LIBS = "%s"'
%
[
linker
.
flags_before_libraries
,
gem_flags_before_libraries
].
flatten
.
join
(
' '
).
gsub
(
'"'
,
'\\"'
)
gem_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
libraries
}
f
.
puts
'MRUBY_LIBS = "%s"'
%
linker
.
library_flags
(
gem_libraries
).
gsub
(
'"'
,
'\\"'
)
end
...
...
tasks/mrbgem_spec.rake
View file @
5ef8aa76
...
...
@@ -6,7 +6,7 @@ module MRuby
class
<<
self
attr_accessor
:current
end
LinkerConfig
=
Struct
.
new
(
:libraries
,
:library_paths
,
:flags
)
LinkerConfig
=
Struct
.
new
(
:libraries
,
:library_paths
,
:flags
,
:flags_before_libraries
,
:flags_after_libraries
)
class
Specification
include
Rake
::
DSL
...
...
@@ -43,7 +43,7 @@ module MRuby
MRuby
::
Build
::
COMMANDS
.
each
do
|
command
|
instance_variable_set
(
"@
#{
command
}
"
,
@build
.
send
(
command
).
clone
)
end
@linker
=
LinkerConfig
.
new
([],
[],
[])
@linker
=
LinkerConfig
.
new
([],
[],
[]
,
[]
)
@rbfiles
=
Dir
.
glob
(
"
#{
dir
}
/mrblib/*.rb"
)
@objs
=
Dir
.
glob
(
"
#{
dir
}
/src/*.{c,cpp,m,asm,S}"
).
map
do
|
f
|
...
...
tasks/mruby_build_commands.rake
View file @
5ef8aa76
...
...
@@ -48,7 +48,9 @@ module MRuby
def
all_flags
(
_defineds
=
[],
_include_paths
=
[],
_flags
=
[])
define_flags
=
[
defines
,
_defineds
].
flatten
.
map
{
|
d
|
option_define
%
d
}
include_path_flags
=
[
include_paths
,
_include_paths
].
flatten
.
map
{
|
f
|
option_include_path
%
filename
(
f
)
}
include_path_flags
=
[
include_paths
,
_include_paths
].
flatten
.
map
do
|
f
|
option_include_path
%
filename
(
f
)
end
[
flags
,
define_flags
,
include_path_flags
,
_flags
].
flatten
.
join
(
' '
)
end
...
...
@@ -59,7 +61,7 @@ module MRuby
option_include_path
%
filename
(
f
)
end
_pp
"CC"
,
infile
,
outfile
_run
compile_options
,
{
:flags
=>
(
flags
+
define_flags
+
include_path_flags
+
_flags
).
join
(
' '
),
_run
compile_options
,
{
:flags
=>
all_flags
(
_defineds
,
_include_paths
,
_flags
),
:infile
=>
filename
(
infile
),
:outfile
=>
filename
(
outfile
)
}
end
...
...
@@ -104,22 +106,25 @@ module MRuby
end
class
Command::Linker
<
Command
attr_accessor
:flags
,
:librar
ies
,
:library_path
s
attr_accessor
:flags
,
:librar
y_paths
,
:flags_before_libraries
,
:libraries
,
:flags_after_librarie
s
attr_accessor
:link_options
,
:option_library
,
:option_library_path
def
initialize
(
build
)
super
@command
=
ENV
[
'LD'
]
||
'gcc'
@flags
=
(
ENV
[
'LDFLAGS'
]
||
[])
@flags_before_libraries
,
@flags_after_libraries
=
[],
[]
@libraries
=
[]
@library_paths
=
[]
@option_library
=
'-l%s'
@option_library_path
=
'-L%s'
@link_options
=
"%{flags} -o %{outfile} %{objs} %{
lib
s}"
@link_options
=
"%{flags} -o %{outfile} %{objs} %{
flags_before_libraries} %{libs} %{flags_after_librarie
s}"
end
def
all_flags
(
_library_paths
=
[],
_flags
=
[])
library_path_flags
=
[
library_paths
,
_library_paths
].
flatten
.
map
{
|
f
|
option_library_path
%
filename
(
f
)
}
library_path_flags
=
[
library_paths
,
_library_paths
].
flatten
.
map
do
|
f
|
option_library_path
%
filename
(
f
)
end
[
flags
,
library_path_flags
,
_flags
].
flatten
.
join
(
' '
)
end
...
...
@@ -127,13 +132,16 @@ module MRuby
[
libraries
,
_libraries
].
flatten
.
map
{
|
d
|
option_library
%
d
}.
join
(
' '
)
end
def
run
(
outfile
,
objfiles
,
_libraries
=
[],
_library_paths
=
[],
_flags
=
[])
def
run
(
outfile
,
objfiles
,
_libraries
=
[],
_library_paths
=
[],
_flags
=
[]
,
_flags_before_libraries
=
[],
_flags_after_libraries
=
[]
)
FileUtils
.
mkdir_p
File
.
dirname
(
outfile
)
library_flags
=
[
libraries
,
_libraries
].
flatten
.
map
{
|
d
|
option_library
%
d
}
library_path_flags
=
[
library_paths
,
_library_paths
].
flatten
.
map
{
|
f
|
option_library_path
%
filename
(
f
)
}
library_flags
=
[
libraries
,
_libraries
].
flatten
.
map
{
|
d
|
option_library
%
d
}
library_path_flags
=
[
library_paths
,
_library_paths
].
flatten
.
map
{
|
f
|
option_library_path
%
filename
(
f
)
}
_pp
"LD"
,
outfile
_run
link_options
,
{
:flags
=>
(
flags
+
library_path_flags
+
_flags
).
join
(
' '
),
_run
link_options
,
{
:flags
=>
all_flags
(
_library_paths
,
_flags
),
:outfile
=>
filename
(
outfile
)
,
:objs
=>
filename
(
objfiles
).
join
(
' '
),
:flags_before_libraries
=>
[
flags_before_libraries
,
_flags_before_libraries
].
flatten
.
join
(
' '
),
:flags_after_libraries
=>
[
flags_after_libraries
,
_flags_after_libraries
].
flatten
.
join
(
' '
),
:libs
=>
library_flags
.
join
(
' '
)
}
end
end
...
...
tasks/toolchains/gcc.rake
View file @
5ef8aa76
...
...
@@ -16,6 +16,6 @@ MRuby::Toolchain.new(:gcc) do |conf|
linker
.
library_paths
=
[]
linker
.
option_library
=
'-l%s'
linker
.
option_library_path
=
'-L%s'
linker
.
link_options
=
'%{flags} -o %{outfile} %{objs} %{
lib
s}'
linker
.
link_options
=
'%{flags} -o %{outfile} %{objs} %{
flags_before_libraries} %{libs} %{flags_after_librarie
s}'
end
end
tasks/toolchains/vs2012.rake
View file @
5ef8aa76
...
...
@@ -16,7 +16,7 @@ MRuby::Toolchain.new(:vs2012) do |conf|
linker
.
library_paths
=
%w()
linker
.
option_library
=
'%s'
linker
.
option_library_path
=
'/LIBPATH:%s'
linker
.
link_options
=
"%{flags} /OUT:%{outfile} %{objs} %{
lib
s}"
linker
.
link_options
=
"%{flags} /OUT:%{outfile} %{objs} %{
flags_before_libraries} %{libs} %{flags_after_librarie
s}"
end
conf
.
archiver
do
|
archiver
|
...
...
test/mrbtest.rake
View file @
5ef8aa76
...
...
@@ -10,11 +10,13 @@ MRuby.each_target do
objs
=
[
objfile
(
"
#{
build_dir
}
/
#{
dir
}
/driver"
),
mlib
].
flatten
file
exec
=>
objs
+
gems
.
map
(
&
:testlib
)
+
[
libfile
(
"
#{
build_dir
}
/lib/libmruby"
)]
do
|
t
|
file
exec
=>
objs
+
gems
.
map
(
&
:testlib
)
.
flatten
+
[
libfile
(
"
#{
build_dir
}
/lib/libmruby"
)]
do
|
t
|
gem_flags
=
gems
.
map
{
|
g
|
g
.
linker
.
flags
}
gem_flags_before_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_before_libraries
}
gem_flags_after_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_after_libraries
}
gem_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
libraries
}
gem_library_paths
=
gems
.
map
{
|
g
|
g
.
linker
.
library_paths
}
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
,
gem_flags_before_libraries
end
file
mlib
=>
[
clib
]
...
...
tools/mirb/mirb.rake
View file @
5ef8aa76
...
...
@@ -7,9 +7,11 @@ MRuby.each_target do
file
exec
=>
objs
+
[
libfile
(
"
#{
build_dir
}
/lib/libmruby"
)]
do
|
t
|
gem_flags
=
gems
.
map
{
|
g
|
g
.
linker
.
flags
}
gem_flags_before_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_before_libraries
}
gem_flags_after_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_after_libraries
}
gem_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
libraries
}
gem_library_paths
=
gems
.
map
{
|
g
|
g
.
linker
.
library_paths
}
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
,
gem_flags_before_libraries
end
end
end
tools/mruby/mruby.rake
View file @
5ef8aa76
...
...
@@ -7,9 +7,11 @@ MRuby.each_target do
file
exec
=>
objs
+
[
libfile
(
"
#{
build_dir
}
/lib/libmruby"
)]
do
|
t
|
gem_flags
=
gems
.
map
{
|
g
|
g
.
linker
.
flags
}
gem_flags_before_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_before_libraries
}
gem_flags_after_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
flags_after_libraries
}
gem_libraries
=
gems
.
map
{
|
g
|
g
.
linker
.
libraries
}
gem_library_paths
=
gems
.
map
{
|
g
|
g
.
linker
.
library_paths
}
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
linker
.
run
t
.
name
,
t
.
prerequisites
,
gem_libraries
,
gem_library_paths
,
gem_flags
,
gem_flags_before_libraries
end
end
end
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