¿Qué tan viable es portar una aplicación C ++ a bytecode Java usando LLVM (supongo que LLJVM)?
La cuestión es que actualmente tenemos un proceso escrito en C ++, pero un nuevo cliente ha hecho obligatorio poder ejecutar el programa de una manera multiplataforma, utilizando la máquina virtual Java sin obviamente código nativo (sin JNI). La idea es poder tomar el jar generado y copiarlo a diferentes sistemas (Linux, Win, 32 bits - 64 bits) y debería funcionar.
Mirar alrededor parece que es posible compilar C ++ a LLVM IR code y luego ese código a java bytecode. No es necesario que el código generado sea legible.
He probado un poco con cosas similares usando emscripten, esto toma el código C ++ y lo compila en JavaScript. El resultado es JS válido pero totalmente ilegible (parece un asaltante).
- ¿Alguien ha hecho un puerto de una aplicación de C ++ a Java bytecode utilizando esta técnica?
- ¿Qué problemas podríamos enfrentar?
- ¿Es un enfoque válido para el código de producción?
Para dejar más claro mi punto después de algunos comentarios, tal vez el puerto no se usa bien, no espero un código fuente legible como resultado, solo el bytecode de Java, por lo que no es un 'puerto' que se desarrollará para más, solo que el La plataforma objetivo debe ser la JVM de Java, no el asaltante nativo.
Nota: Soy consciente de que actualmente tenemos algunas bibliotecas de código cerrado y C ++ no estándar, estamos tratando de eliminar este código no estándar y todas las bibliotecas de código cerrado y usar el software libre de código abierto, así que supongamos que todo el código es código C ++ estándar con Todo el código disponible en tiempo de compilación.
Nota 2: No es una opción escribir código C ++ portátil y luego compilarlo en la plataforma de destino deseada, el programa compilado debe ser multiplataforma, por lo tanto, el uso de JVM.
Nota 3: En este momento no estamos buscando soluciones similares aplicadas a Python u otra base de lenguaje, pero también me gustaría escuchar sobre eso. Con esto quiero decir que nuestro ejecutable de destino debe ser un bytecode de Java, pero si hay opciones para compilar C ++ a un código compilado válido de Python, también me gustaría saber sobre ellos.