Ccmmutty logo
Commutty IT
10 min read

rust初心者ですがcargo buildでハマった話

https://cdn.magicode.io/media/notebox/a2e4d736-bbfb-4ea9-a82c-8f88257fea22.jpeg

Hello World!できない

どの言語でもそうですが、勉強し初めはとりあえずコンソールでHello World!を出力してみるものですが、いろいろやっていたらHello Worldできなくなってしまったので、その時の対処法を備忘録として記録します。。
fn main() {
    println!("Hello, world!");
}

起こったこと

cargo new で新規プロジェクトを作成した場合、main.rsにはすでに"Hello World!"が出力されるような記述がされており、ターミナルからcargo runを実行すればコンソールに出力されますよ。というのがいろいろなサイトに書いてあるかと思います。
ですがいざ実行してみると
 % cargo run

    Finished dev [unoptimized + debuginfo] target(s) in 0.08s
     Running `target/wasm32-unknown-unknown/debug/my_project.wasm`
target/wasm32-unknown-unknown/debug/my_project.wasm: target/wasm32-unknown-unknown/debug/my_project.wasm: cannot execute binary file
あれ、Hello Worldできない。。。

状況整理

プロジェクト名をmy_projectとして、現在の状況を整理。 本来、cargo runした場合は以下のようなtreeとなり、./target/debug/my_projectが実行される模様
my_project
 ├──src
 │    └─main.rs
 └──target
      └─debug
            └─my_project
                    (省略)
しかし実際にできたものは以下
my_project
 ├──src
 │    └─main.rs
 ├──target
 │     └─debug
 │          └─my_project
 │                   (省略)
  └──wasm32-unknown-unkown
      └─debug
            └─my_project.wasm
思い当たるのは以前にWebAssemblyのtutorialを行なっていたときにwasm-packを入れたことでした。

config.toml

cargo run した時のメッセージからおそらくbuildする時のtargetが違うのだろう推測でtargetがどこで設定されているかを調べたら"config.toml"ファイルに書いてあるとのことでした。 ファイルの中身を確認すると、
[build]
 target=wasm32-unknown-unknown
おそらくこれでしょう。

targetの値をどうするのか

わからないので適当な値にしてcargo runしてみたところ
% cargo run
error: failed to run `rustc` to learn about target-specific information

Caused by:
  process didn't exit successfully: `rustc - --crate-name ___ --print=file-names --target target --crate-type bin --crate-type rlib --crate-type dylib --crate-type cdylib --crate-type staticlib --crate-type proc-macro --print=sysroot --print=cfg` (exit status: 1)
  --- stderr
  error: Error loading target specification: Could not find specification for target "target". Run `rustc --print target-list` for a list of built-in targets
案の定エラーとなりましたが、rustc --print target-listでtaraget-listが観れるということでした。 実行してみる。
% rustc --print target-list
aarch64-apple-darwin
aarch64-apple-ios
aarch64-apple-ios-macabi
aarch64-apple-ios-sim
aarch64-apple-tvos
aarch64-fuchsia
aarch64-kmc-solid_asp3
aarch64-linux-android
aarch64-pc-windows-msvc
aarch64-unknown-freebsd
aarch64-unknown-hermit
aarch64-unknown-linux-gnu
aarch64-unknown-linux-gnu_ilp32
aarch64-unknown-linux-musl
aarch64-unknown-netbsd
aarch64-unknown-none
aarch64-unknown-none-hermitkernel
aarch64-unknown-none-softfloat
aarch64-unknown-openbsd
aarch64-unknown-redox
aarch64-unknown-uefi
aarch64-uwp-windows-msvc
aarch64-wrs-vxworks
aarch64_be-unknown-linux-gnu
aarch64_be-unknown-linux-gnu_ilp32
arm-linux-androideabi
arm-unknown-linux-gnueabi
arm-unknown-linux-gnueabihf
arm-unknown-linux-musleabi
arm-unknown-linux-musleabihf
armebv7r-none-eabi
armebv7r-none-eabihf
armv4t-unknown-linux-gnueabi
armv5te-unknown-linux-gnueabi
armv5te-unknown-linux-musleabi
armv5te-unknown-linux-uclibceabi
armv6-unknown-freebsd
armv6-unknown-netbsd-eabihf
armv6k-nintendo-3ds
armv7-apple-ios
armv7-linux-androideabi
armv7-unknown-freebsd
armv7-unknown-linux-gnueabi
armv7-unknown-linux-gnueabihf
armv7-unknown-linux-musleabi
armv7-unknown-linux-musleabihf
armv7-unknown-linux-uclibceabi
armv7-unknown-linux-uclibceabihf
armv7-unknown-netbsd-eabihf
armv7-wrs-vxworks-eabihf
armv7a-kmc-solid_asp3-eabi
armv7a-kmc-solid_asp3-eabihf
armv7a-none-eabi
armv7a-none-eabihf
armv7r-none-eabi
armv7r-none-eabihf
armv7s-apple-ios
asmjs-unknown-emscripten
avr-unknown-gnu-atmega328
bpfeb-unknown-none
bpfel-unknown-none
hexagon-unknown-linux-musl
i386-apple-ios
i586-pc-windows-msvc
i586-unknown-linux-gnu
i586-unknown-linux-musl
i686-apple-darwin
i686-linux-android
i686-pc-windows-gnu
i686-pc-windows-msvc
i686-unknown-freebsd
i686-unknown-haiku
i686-unknown-linux-gnu
i686-unknown-linux-musl
i686-unknown-netbsd
i686-unknown-openbsd
i686-unknown-uefi
i686-uwp-windows-gnu
i686-uwp-windows-msvc
i686-wrs-vxworks
m68k-unknown-linux-gnu
mips-unknown-linux-gnu
mips-unknown-linux-musl
mips-unknown-linux-uclibc
mips64-openwrt-linux-musl
mips64-unknown-linux-gnuabi64
mips64-unknown-linux-muslabi64
mips64el-unknown-linux-gnuabi64
mips64el-unknown-linux-muslabi64
mipsel-sony-psp
mipsel-unknown-linux-gnu
mipsel-unknown-linux-musl
mipsel-unknown-linux-uclibc
mipsel-unknown-none
mipsisa32r6-unknown-linux-gnu
mipsisa32r6el-unknown-linux-gnu
mipsisa64r6-unknown-linux-gnuabi64
mipsisa64r6el-unknown-linux-gnuabi64
msp430-none-elf
nvptx64-nvidia-cuda
powerpc-unknown-freebsd
powerpc-unknown-linux-gnu
powerpc-unknown-linux-gnuspe
powerpc-unknown-linux-musl
powerpc-unknown-netbsd
powerpc-unknown-openbsd
powerpc-wrs-vxworks
powerpc-wrs-vxworks-spe
powerpc64-unknown-freebsd
powerpc64-unknown-linux-gnu
powerpc64-unknown-linux-musl
powerpc64-wrs-vxworks
powerpc64le-unknown-freebsd
powerpc64le-unknown-linux-gnu
powerpc64le-unknown-linux-musl
riscv32gc-unknown-linux-gnu
riscv32gc-unknown-linux-musl
riscv32i-unknown-none-elf
riscv32imac-unknown-none-elf
riscv32imc-esp-espidf
riscv32imc-unknown-none-elf
riscv64gc-unknown-freebsd
riscv64gc-unknown-linux-gnu
riscv64gc-unknown-linux-musl
riscv64gc-unknown-none-elf
riscv64imac-unknown-none-elf
s390x-unknown-linux-gnu
s390x-unknown-linux-musl
sparc-unknown-linux-gnu
sparc64-unknown-linux-gnu
sparc64-unknown-netbsd
sparc64-unknown-openbsd
sparcv9-sun-solaris
thumbv4t-none-eabi
thumbv6m-none-eabi
thumbv7a-pc-windows-msvc
thumbv7a-uwp-windows-msvc
thumbv7em-none-eabi
thumbv7em-none-eabihf
thumbv7m-none-eabi
thumbv7neon-linux-androideabi
thumbv7neon-unknown-linux-gnueabihf
thumbv7neon-unknown-linux-musleabihf
thumbv8m.base-none-eabi
thumbv8m.main-none-eabi
thumbv8m.main-none-eabihf
wasm32-unknown-emscripten
wasm32-unknown-unknown
wasm32-wasi
wasm64-unknown-unknown
x86_64-apple-darwin
x86_64-apple-ios
x86_64-apple-ios-macabi
x86_64-apple-tvos
x86_64-fortanix-unknown-sgx
x86_64-fuchsia
x86_64-linux-android
x86_64-pc-solaris
x86_64-pc-windows-gnu
x86_64-pc-windows-msvc
x86_64-sun-solaris
x86_64-unknown-dragonfly
x86_64-unknown-freebsd
x86_64-unknown-haiku
x86_64-unknown-hermit
x86_64-unknown-illumos
x86_64-unknown-l4re-uclibc
x86_64-unknown-linux-gnu
x86_64-unknown-linux-gnux32
x86_64-unknown-linux-musl
x86_64-unknown-netbsd
x86_64-unknown-none
x86_64-unknown-none-hermitkernel
x86_64-unknown-none-linuxkernel
x86_64-unknown-openbsd
x86_64-unknown-redox
x86_64-unknown-uefi
x86_64-uwp-windows-gnu
x86_64-uwp-windows-msvc
x86_64-wrs-vxworks
たくさん出てきてよくわかりませんが、rustup showのコマンドでtargetが書いてあった気がしたので実行してみる。
% rustup show
Default host: x86_64-apple-darwin
rustup home:  /Users/hoge/.rustup

installed toolchains
--------------------

stable-x86_64-apple-darwin (default)
nightly-x86_64-apple-darwin
1.60.0-x86_64-apple-darwin

installed targets for active toolchain
--------------------------------------

wasm32-unknown-unknown
x86_64-apple-darwin

active toolchain
----------------

stable-x86_64-apple-darwin (default)
rustc 1.60.0 

installed targets for active toolchainのところにx86_64-apple-darwinと書いてあるので "config.toml"をtarget=x86_64-apple-darwinに書き換えてみました。
% cargo run                
   Compiling my_project v0.1.0 (/Users/hoge/rust/my_project)
    Finished dev [unoptimized + debuginfo] target(s) in 2.20s
     Running `target/x86_64-apple-darwin/debug/my_project`
Hello, world!
無事にHello World!できました。

まとめ

rustは触り始めたばかりなので果たしてこれが正解なのかわかりませんが、とりあえずtutorialは先に進めそうです。 もっと理解を深めなければ。。

Discussion

コメントにはログインが必要です。