Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
ea239f6b
Commit
ea239f6b
authored
May 07, 2021
by
Jacek Caban
Committed by
Alexandre Julliard
May 10, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winebuild: Use clang -print-prog-name to find LLVM tools.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
ab017a7c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
68 additions
and
10 deletions
+68
-10
utils.c
tools/winebuild/utils.c
+68
-10
No files found.
tools/winebuild/utils.c
View file @
ea239f6b
...
@@ -360,9 +360,50 @@ void spawn( struct strarray args )
...
@@ -360,9 +360,50 @@ void spawn( struct strarray args )
}
}
}
}
static
const
char
*
find_clang_tool
(
const
struct
strarray
clang
,
const
char
*
tool
)
{
const
char
*
out
=
get_temp_file_name
(
"print_tool"
,
".out"
);
struct
strarray
args
;
int
sout
=
-
1
;
char
*
path
,
*
p
;
struct
stat
st
;
size_t
cnt
;
args
=
strarray_copy
(
clang
);
strarray_add_one
(
&
args
,
strmake
(
"-print-prog-name=%s"
,
tool
)
);
if
(
verbose
)
strarray_add_one
(
&
args
,
"-v"
);
sout
=
dup
(
fileno
(
stdout
)
);
freopen
(
out
,
"w"
,
stdout
);
spawn
(
args
);
if
(
sout
>=
0
)
{
dup2
(
sout
,
fileno
(
stdout
)
);
close
(
sout
);
}
if
(
stat
(
out
,
&
st
)
||
!
st
.
st_size
)
return
NULL
;
path
=
xmalloc
(
st
.
st_size
+
1
);
sout
=
open
(
out
,
O_RDONLY
);
if
(
sout
==
-
1
)
return
NULL
;
cnt
=
read
(
sout
,
path
,
st
.
st_size
);
close
(
sout
);
path
[
cnt
]
=
0
;
if
((
p
=
strchr
(
path
,
'\n'
)))
*
p
=
0
;
/* clang returns passed command instead of full path if the tool could not be found */
if
(
!
strcmp
(
path
,
tool
))
{
free
(
path
);
return
NULL
;
}
return
path
;
}
/* find a build tool in the path, trying the various names */
/* find a build tool in the path, trying the various names */
struct
strarray
find_tool
(
const
char
*
name
,
const
char
*
const
*
names
)
struct
strarray
find_tool
(
const
char
*
name
,
const
char
*
const
*
names
)
{
{
struct
strarray
ret
=
empty_strarray
;
const
char
*
file
;
const
char
*
file
;
const
char
*
alt_names
[
2
];
const
char
*
alt_names
[
2
];
...
@@ -375,25 +416,42 @@ struct strarray find_tool( const char *name, const char * const *names )
...
@@ -375,25 +416,42 @@ struct strarray find_tool( const char *name, const char * const *names )
while
(
*
names
)
while
(
*
names
)
{
{
if
((
file
=
find_binary
(
target_alias
,
*
names
))
if
((
file
=
find_binary
(
target_alias
,
*
names
)))
break
;
||
(
names
==
alt_names
&&
(
file
=
find_binary
(
"llvm"
,
*
names
))))
names
++
;
}
if
(
!
file
&&
names
==
alt_names
+
1
)
{
if
(
cc_command
.
count
)
file
=
find_clang_tool
(
cc_command
,
"lld-link"
);
if
(
!
file
&&
!
(
file
=
find_binary
(
"llvm"
,
name
)))
{
{
struct
strarray
ret
=
empty_strarray
;
struct
strarray
clang
=
empty_strarray
;
strarray_add_one
(
&
ret
,
file
);
strarray_add_one
(
&
clang
,
"clang"
);
return
ret
;
file
=
find_clang_tool
(
clang
,
strmake
(
"llvm-%s"
,
name
))
;
}
}
names
++
;
}
}
fatal_error
(
"cannot find the '%s' tool
\n
"
,
name
);
if
(
!
file
)
fatal_error
(
"cannot find the '%s' tool
\n
"
,
name
);
strarray_add_one
(
&
ret
,
file
);
return
ret
;
}
}
/* find a link tool in the path */
/* find a link tool in the path */
struct
strarray
find_link_tool
(
void
)
struct
strarray
find_link_tool
(
void
)
{
{
struct
strarray
ret
=
empty_strarray
;
struct
strarray
ret
=
empty_strarray
;
const
char
*
file
;
const
char
*
file
=
NULL
;
if
(
!
(
file
=
find_binary
(
NULL
,
"lld-link"
)))
fatal_error
(
"cannot find the 'lld-link tool
\n
"
);
if
(
cc_command
.
count
)
file
=
find_clang_tool
(
cc_command
,
"lld-link"
);
if
(
!
file
)
file
=
find_binary
(
NULL
,
"lld-link"
);
if
(
!
file
)
{
struct
strarray
clang
=
empty_strarray
;
strarray_add_one
(
&
clang
,
"clang"
);
file
=
find_clang_tool
(
clang
,
"lld-link"
);
}
if
(
!
file
)
fatal_error
(
"cannot find the 'lld-link' tool
\n
"
);
strarray_add_one
(
&
ret
,
file
);
strarray_add_one
(
&
ret
,
file
);
return
ret
;
return
ret
;
}
}
...
...
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