I work on a project which a hardware product that runs a Linux OS with custom server-side software. Currently, we have a lot of legacy C code base that is glued together either with linker shenanigans or loosely coupled bash scripts. There are several cons of this solution/current architecture:
* There are many small programs written in C that do not reuse each other's code
* Its old C code base which requires a tremendous effort to maintain and God forbid develop a new feature for an existing program
* Because the programs are written in C they can span thousands of lines of code just to do something that would take a maximum of a few hundred in a more high-level programming language. The actions that most of those programs perform are operations on files, system components like drives/partitions, etc, and typical systems programming
I plan to introduce a higher-level language to take care of such programs. Im considering things like Python, Perl, Lua, Go, etc. But I do not have extensive experience with all of them. My team has quite a lot of experience with Python but given that the project itself has to be easily maintainable for a long term (even up to 10 years) we really want to use a language that will not change much in this period which basically already excludes Python as even fairly new language releases are not being supported.
Thus there are several things we would like our perfect language to be able to do:
* Be able to work with/alongside C/C++
* Be testable. Have some built-in or easily added testing framework just like Pythons Pytest, and maybe additionally be able to test C code if that's even a thing
* Be long-term stable and maintainable
* Have good ongoing and future support
* Be easy to learn and pretty generic
* Capable of performing systems programing
* Be as light-weight as possible, we cannot allow ourselves to have a 500meg runtime
* Have a good ecosystem that supplies the developer with tooling during the development e.g. linters, formatters, packaging etc
I would really like to know your advice on which language we should choose?
* There are many small programs written in C that do not reuse each other's code
* Its old C code base which requires a tremendous effort to maintain and God forbid develop a new feature for an existing program
* Because the programs are written in C they can span thousands of lines of code just to do something that would take a maximum of a few hundred in a more high-level programming language. The actions that most of those programs perform are operations on files, system components like drives/partitions, etc, and typical systems programming
I plan to introduce a higher-level language to take care of such programs. Im considering things like Python, Perl, Lua, Go, etc. But I do not have extensive experience with all of them. My team has quite a lot of experience with Python but given that the project itself has to be easily maintainable for a long term (even up to 10 years) we really want to use a language that will not change much in this period which basically already excludes Python as even fairly new language releases are not being supported.
Thus there are several things we would like our perfect language to be able to do:
* Be able to work with/alongside C/C++
* Be testable. Have some built-in or easily added testing framework just like Pythons Pytest, and maybe additionally be able to test C code if that's even a thing
* Be long-term stable and maintainable
* Have good ongoing and future support
* Be easy to learn and pretty generic
* Capable of performing systems programing
* Be as light-weight as possible, we cannot allow ourselves to have a 500meg runtime
* Have a good ecosystem that supplies the developer with tooling during the development e.g. linters, formatters, packaging etc
I would really like to know your advice on which language we should choose?