92 lines
3.1 KiB
C++
Raw Normal View History

2024-01-08 23:37:00 +08:00
#include "ebyroid.h"
2024-04-02 15:36:52 +08:00
#include "api_adapter.h"
2024-01-08 23:37:00 +08:00
#include "ebyutil.h"
2024-04-02 15:36:52 +08:00
using ebyroid::Ebyroid;
#include "types.h"
int voiceroid2wmain(int argc, wchar_t *wargv[])
{
2024-01-08 23:37:00 +08:00
UINT codepage = GetACP();
2024-04-02 15:36:52 +08:00
char **argv = new char *[argc];
2024-01-08 23:37:00 +08:00
for (int i = 0; i < argc; i++)
{
int length = WideCharToMultiByte(codepage, 0, wargv[i], -1, NULL, 0, NULL, NULL);
argv[i] = new char[length];
WideCharToMultiByte(codepage, 0, wargv[i], -1, argv[i], length, NULL, NULL);
2024-04-02 15:36:52 +08:00
}
2024-01-08 23:37:00 +08:00
2024-04-02 15:36:52 +08:00
HANDLE hPipe = CreateNamedPipeA(argv[7], PIPE_ACCESS_DUPLEX, PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT, PIPE_UNLIMITED_INSTANCES, 65535, 65535, NMPWAIT_WAIT_FOREVER, 0);
2024-01-08 23:37:00 +08:00
2024-04-02 15:36:52 +08:00
Ebyroid *ebyroid;
2024-01-08 23:37:00 +08:00
2024-04-02 15:36:52 +08:00
printf("argc %d \n", argc);
for (int i = 0; i < argc; i++)
{
2024-01-08 23:37:00 +08:00
printf("%d %s\n", i, argv[i]);
}
2024-04-02 15:36:52 +08:00
ebyroid = Ebyroid::Create((const char *)argv[1], //"C:\\dataH\\Yukari2",
(const char *)argv[2],
(const char *)argv[3], //"yukari_emo_44",
2, // <20>̶<EFBFBD><CCB6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
atof((const char *)argv[5])); // 1); //0.1-2,0.5-4
2024-01-08 23:37:00 +08:00
SECURITY_DESCRIPTOR sd = {};
InitializeSecurityDescriptor(&sd, SECURITY_DESCRIPTOR_REVISION);
SetSecurityDescriptorDacl(&sd, TRUE, NULL, FALSE);
2024-04-02 15:36:52 +08:00
SECURITY_ATTRIBUTES allAccess = SECURITY_ATTRIBUTES{sizeof(SECURITY_ATTRIBUTES), &sd, FALSE};
2024-01-08 23:37:00 +08:00
SetEvent(CreateEventA(&allAccess, FALSE, FALSE, argv[8]));
2024-04-02 15:36:52 +08:00
if (ConnectNamedPipe(hPipe, NULL) != NULL)
{
2024-01-08 23:37:00 +08:00
DWORD len = 0;
}
int freq1 = atoi(argv[4]);
printf("pipe connected");
int II = 0;
2024-04-02 15:36:52 +08:00
while (true)
{
2024-01-08 23:37:00 +08:00
II += 1;
2024-04-02 15:36:52 +08:00
unsigned char *out;
2024-01-08 23:37:00 +08:00
size_t output_size;
2024-04-02 15:36:52 +08:00
int16_t *out2;
2024-01-08 23:37:00 +08:00
2024-04-02 15:36:52 +08:00
unsigned char input_j[4096] = {0};
2024-01-08 23:37:00 +08:00
DWORD _;
2024-04-02 15:36:52 +08:00
if (!ReadFile(hPipe, input_j, 4096, &_, NULL))
break;
2024-01-08 23:37:00 +08:00
printf("%s\n", input_j);
2024-04-02 15:36:52 +08:00
// int result = ebyroid->Hiragana((const unsigned char*)UnicodeToShift_jis(input), &out, &output_size);
int result = ebyroid->Hiragana((const unsigned char *)input_j, &out, &output_size);
2024-01-08 23:37:00 +08:00
printf("%s\n", out);
result = ebyroid->Speech(out, &out2, &output_size);
2024-04-02 15:36:52 +08:00
char newname[1024] = {0};
2024-01-08 23:37:00 +08:00
sprintf(newname, "%s%d.wav", argv[6], II);
2024-04-02 15:36:52 +08:00
FILE *F = fopen(newname, "wb");
2024-01-08 23:37:00 +08:00
int fsize = output_size + 44;
fseek(F, 0, SEEK_SET);
fwrite("RIFF", 1, 4, F);
fwrite(&fsize, 4, 1, F);
fwrite("WAVEfmt ", 1, 8, F);
fwrite("\x10\x00\x00\x00\x01\x00\x01\x00", 1, 8, F);
int freq = freq1;
fwrite(&freq, 4, 1, F);
freq = freq * 2;
fwrite(&freq, 4, 1, F);
fwrite("\x02\x00\x10\x00", 1, 4, F);
fwrite("data", 1, 4, F);
int sz = fsize - 44;
fwrite(&sz, 4, 1, F);
printf("%d \n", ftell(F));
2024-04-02 15:36:52 +08:00
fwrite((char *)out2, 1, output_size, F);
2024-01-08 23:37:00 +08:00
fclose(F);
WriteFile(hPipe, newname, strlen(newname), &_, NULL);
free(out);
free(out2);
}
2024-04-02 15:36:52 +08:00
// sndPlaySound((const char*)argv[6], SND_SYNC);
2024-01-08 23:37:00 +08:00
return 0;
}