diff --git a/Cargo.lock b/Cargo.lock index e96ad5dbb..e5c6d048d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -544,9 +544,9 @@ checksum = "c1db59621ec70f09c5e9b597b220c7a2b43611f4710dc03ceb8748637775692c" [[package]] name = "cbindgen" -version = "0.24.3" +version = "0.26.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a6358dedf60f4d9b8db43ad187391afe959746101346fe51bb978126bec61dfb" +checksum = "da6bc11b07529f16944307272d5bd9b22530bc7d05751717c9d416586cedab49" dependencies = [ "clap 3.2.22", "heck", diff --git a/crates/voicevox_core_c_api/cbindgen.toml b/crates/voicevox_core_c_api/cbindgen.toml index 7615280f6..a0fef4f76 100644 --- a/crates/voicevox_core_c_api/cbindgen.toml +++ b/crates/voicevox_core_c_api/cbindgen.toml @@ -55,7 +55,21 @@ after_includes = """ #else // __cplusplus #include #include -#endif // __cplusplus""" +#endif // __cplusplus + +#if defined(__cplusplus) +#define DEPRECATED [[deprecated]] +#define DEPRECATED_WITH_NOTE(msg) [[deprecated(msg)]] +#elif defined(_MSC_VER) +#define DEPRECATED __declspec(deprecated) +#define DEPRECATED_WITH_NOTE(msg) __declspec(deprecated(msg)) +#elif defined(__GNUC__) +#define DEPRECATED __attribute__((deprecated)) +#define DEPRECATED_WITH_NOTE(msg) __attribute__((deprecated(msg))) +#else +#define DEPRECATED +#define DEPRECATED_WITH_NOTE(msg) +#endif""" # Code Style Options @@ -69,9 +83,17 @@ prefix = """ __declspec(dllimport) #endif""" args = "vertical" +deprecated = "DEPRECATED" +deprecated_with_note = "DEPRECATED_WITH_NOTE({})" + +[struct] +deprecated = "DEPRECATED" +deprecated_with_note = "DEPRECATED_WITH_NOTE({})" [enum] rename_variants = "ScreamingSnakeCase" +deprecated = "DEPRECATED" +deprecated_with_note = "DEPRECATED_WITH_NOTE({})" # Options for how your Rust library should be parsed diff --git a/crates/voicevox_core_c_api/include/voicevox_core.h b/crates/voicevox_core_c_api/include/voicevox_core.h index 394137d50..f8a934a35 100644 --- a/crates/voicevox_core_c_api/include/voicevox_core.h +++ b/crates/voicevox_core_c_api/include/voicevox_core.h @@ -44,7 +44,7 @@ #ifndef VOICEVOX_CORE_INCLUDE_GUARD #define VOICEVOX_CORE_INCLUDE_GUARD -/* Generated with cbindgen:0.24.3 */ +/* Generated with cbindgen:0.26.0 */ #ifdef __cplusplus #include @@ -53,6 +53,20 @@ #include #endif // __cplusplus +#if defined(__cplusplus) +#define DEPRECATED [[deprecated]] +#define DEPRECATED_WITH_NOTE(msg) [[deprecated(msg)]] +#elif defined(_MSC_VER) +#define DEPRECATED __declspec(deprecated) +#define DEPRECATED_WITH_NOTE(msg) __declspec(deprecated(msg)) +#elif defined(__GNUC__) +#define DEPRECATED __attribute__((deprecated)) +#define DEPRECATED_WITH_NOTE(msg) __attribute__((deprecated(msg))) +#else +#define DEPRECATED +#define DEPRECATED_WITH_NOTE(msg) +#endif + /** * ハードウェアアクセラレーションモードを設定する設定値。 */ @@ -258,7 +272,7 @@ typedef struct VoicevoxVoiceModel VoicevoxVoiceModel; /** * ::voicevox_synthesizer_new_with_initialize のオプション。 */ -typedef struct VoicevoxInitializeOptions { +typedef struct VoicevoxInitializeSynthesizerOptions { /** * ハードウェアアクセラレーションモード */ @@ -268,7 +282,7 @@ typedef struct VoicevoxInitializeOptions { * 0を指定すると環境に合わせたCPUが利用される */ uint16_t cpu_num_threads; -} VoicevoxInitializeOptions; +} VoicevoxInitializeSynthesizerOptions; /** * 音声モデルID。 @@ -328,6 +342,29 @@ typedef struct VoicevoxUserDictWord { uint32_t priority; } VoicevoxUserDictWord; +/** + * ::voicevox_initialize のオプション。 + */ +typedef struct DEPRECATED_WITH_NOTE("VoicevoxInitializeSynthesizerOptions を使ってください。") VoicevoxInitializeOptions { + /** + * ハードウェアアクセラレーションモード + */ + VoicevoxAccelerationMode acceleration_mode; + /** + * CPU利用数を指定 + * 0を指定すると環境に合わせたCPUが利用される + */ + uint16_t cpu_num_threads; + /** + * 全てのモデルを読み込む + */ + bool load_all_models; + /** + * open_jtalkの辞書ディレクトリ + */ + const char *open_jtalk_dict_dir; +} VoicevoxInitializeOptions; + #ifdef __cplusplus extern "C" { #endif // __cplusplus @@ -407,7 +444,7 @@ void voicevox_open_jtalk_rc_delete(struct OpenJtalkRc *open_jtalk); #ifdef _WIN32 __declspec(dllimport) #endif -struct VoicevoxInitializeOptions voicevox_make_default_initialize_options(void); +struct VoicevoxInitializeSynthesizerOptions voicevox_make_default_initialize_synthesizer_options(void); /** * voicevoxのバージョンを取得する。 @@ -503,7 +540,7 @@ void voicevox_voice_model_delete(struct VoicevoxVoiceModel *model); __declspec(dllimport) #endif VoicevoxResultCode voicevox_synthesizer_new_with_initialize(const struct OpenJtalkRc *open_jtalk, - struct VoicevoxInitializeOptions options, + struct VoicevoxInitializeSynthesizerOptions options, struct VoicevoxSynthesizer **out_synthesizer); /** @@ -1211,6 +1248,12 @@ __declspec(dllimport) #endif void voicevox_user_dict_delete(struct VoicevoxUserDict *user_dict); +#ifdef _WIN32 +__declspec(dllimport) +#endif +DEPRECATED_WITH_NOTE("voicevox_synthesizer_new_with_initialize を使ってください。") +bool voicevox_initialize(struct VoicevoxInitializeOptions options); + #ifdef __cplusplus } // extern "C" #endif // __cplusplus diff --git a/crates/voicevox_core_c_api/src/helpers.rs b/crates/voicevox_core_c_api/src/helpers.rs index 698e89b45..001a7b930 100644 --- a/crates/voicevox_core_c_api/src/helpers.rs +++ b/crates/voicevox_core_c_api/src/helpers.rs @@ -114,7 +114,7 @@ impl From for voicevox_core::AccelerationMode { } } -impl Default for VoicevoxInitializeOptions { +impl Default for VoicevoxInitializeSynthesizerOptions { fn default() -> Self { let options = voicevox_core::InitializeOptions::default(); Self { @@ -124,8 +124,8 @@ impl Default for VoicevoxInitializeOptions { } } -impl From for voicevox_core::InitializeOptions { - fn from(value: VoicevoxInitializeOptions) -> Self { +impl From for voicevox_core::InitializeOptions { + fn from(value: VoicevoxInitializeSynthesizerOptions) -> Self { voicevox_core::InitializeOptions { acceleration_mode: value.acceleration_mode.into(), cpu_num_threads: value.cpu_num_threads, diff --git a/crates/voicevox_core_c_api/src/lib.rs b/crates/voicevox_core_c_api/src/lib.rs index 9bc6698b4..a3930de1c 100644 --- a/crates/voicevox_core_c_api/src/lib.rs +++ b/crates/voicevox_core_c_api/src/lib.rs @@ -9,6 +9,7 @@ mod drop_check; mod helpers; mod result_code; mod slice_owner; +mod v014_compatible_engine; use self::drop_check::C_STRING_DROP_CHECKER; use self::helpers::*; use self::result_code::VoicevoxResultCode; @@ -200,7 +201,7 @@ pub enum VoicevoxAccelerationMode { /// ::voicevox_synthesizer_new_with_initialize のオプション。 #[repr(C)] -pub struct VoicevoxInitializeOptions { +pub struct VoicevoxInitializeSynthesizerOptions { /// ハードウェアアクセラレーションモード acceleration_mode: VoicevoxAccelerationMode, /// CPU利用数を指定 @@ -211,8 +212,9 @@ pub struct VoicevoxInitializeOptions { /// デフォルトの初期化オプションを生成する /// @return デフォルト値が設定された初期化オプション #[no_mangle] -pub extern "C" fn voicevox_make_default_initialize_options() -> VoicevoxInitializeOptions { - VoicevoxInitializeOptions::default() +pub extern "C" fn voicevox_make_default_initialize_synthesizer_options( +) -> VoicevoxInitializeSynthesizerOptions { + VoicevoxInitializeSynthesizerOptions::default() } /// voicevoxのバージョンを取得する。 @@ -337,7 +339,7 @@ pub struct VoicevoxSynthesizer { #[no_mangle] pub unsafe extern "C" fn voicevox_synthesizer_new_with_initialize( open_jtalk: &OpenJtalkRc, - options: VoicevoxInitializeOptions, + options: VoicevoxInitializeSynthesizerOptions, out_synthesizer: NonNull>, ) -> VoicevoxResultCode { into_result_code_with_error((|| { diff --git a/crates/voicevox_core_c_api/src/v014_compatible_engine.rs b/crates/voicevox_core_c_api/src/v014_compatible_engine.rs new file mode 100644 index 000000000..a58500d51 --- /dev/null +++ b/crates/voicevox_core_c_api/src/v014_compatible_engine.rs @@ -0,0 +1,26 @@ +use super::*; + +/// ::voicevox_initialize のオプション。 +#[deprecated(note = "VoicevoxInitializeSynthesizerOptions を使ってください。")] +#[repr(C)] +pub struct VoicevoxInitializeOptions { + /// ハードウェアアクセラレーションモード + acceleration_mode: VoicevoxAccelerationMode, + /// CPU利用数を指定 + /// 0を指定すると環境に合わせたCPUが利用される + cpu_num_threads: u16, + /// 全てのモデルを読み込む + load_all_models: bool, + /// open_jtalkの辞書ディレクトリ + open_jtalk_dict_dir: *const c_char, +} + +#[no_mangle] +#[deprecated(note = "voicevox_synthesizer_new_with_initialize を使ってください。")] +/// 初期化する。 +/// +/// @param [in] options オプション +/// @returns 結果コード +pub extern "C" fn voicevox_initialize(options: VoicevoxInitializeOptions) -> VoicevoxResultCode { + todo!() +} diff --git a/crates/xtask/Cargo.toml b/crates/xtask/Cargo.toml index 11420d2ff..695962753 100644 --- a/crates/xtask/Cargo.toml +++ b/crates/xtask/Cargo.toml @@ -5,7 +5,7 @@ edition.workspace = true publish.workspace = true [dependencies] -cbindgen = "0.24.3" +cbindgen = "0.26.0" clap.workspace = true color-eyre = "0.6.2" eyre = "0.6.8" diff --git a/docs/0.14_to_0.15.md b/docs/0.14_to_0.15.md new file mode 100644 index 000000000..a7faede3e --- /dev/null +++ b/docs/0.14_to_0.15.md @@ -0,0 +1,3 @@ +# 0.14 から 0.15 への移行 + +TODO