Scratchbox 2: Difference between revisions
m improve link: C (programming language) |
Overhaul |
||
Line 1: | Line 1: | ||
{{Multiple issues| |
|||
{{unreferenced|date=March 2012}} |
|||
{{Notability|Products|date=March 2012}} |
|||
}} |
|||
{{Infobox software |
{{Infobox software |
||
| name = Scratchbox |
| name = Scratchbox 2 |
||
| logo = |
| logo = |
||
| screenshot = |
| screenshot = |
||
Line 37: | Line 32: | ||
}} |
}} |
||
''' |
'''Scratchbox 2''' (often abbreviated to "'''sb2'''" or "'''sbox2'''") is a cross-compilation toolkit designed to make embedded Linux application development easier. It also provides a full set of tools to integrate and [[Cross compiler|cross-compile]] an entire [[Linux distribution]]. |
||
In the Linux world, when building software, many parameters are auto-detected |
In the Linux world, when [[Software build|building software]], many parameters are auto-detected on the host system (like installed libraries and system configuration), for example through [[GNU Autotools|Autotools]]' [[Configure script|<code>./configure</code> scripts]]. When one wants to build software for an embedded target by cross-compilation, most auto-detected parameters are incorrect: I.e., host configuration is not the same as the [[Embedded system|embedded target]]'s configuration. |
||
Without |
Without Scratchbox 2, one has to manually set many parameters and "hack" the "configure" process to be able to generate code for the embedded target. |
||
Scratchbox 2 allows one to set up a [Virtualization|"virtual"]] environment that will trick the Autotools and executables into thinking that they are directly running on the embedded target with its configuration. |
|||
Moreover, |
Moreover, Scratchbox 2 provides a technology called CPU-transparency that goes further: With CPU-transparency, executables built for the host CPU or for the target CPU could be executed directly on the host with sb2 handling the task to emulate a different [[Instruction set architecture|CPU-architecture]] if necessary to run software components compiled for the target CPU. Hence a build process can mix using programs built for different CPU architectures. That is especially useful when a build process requires building a software component X first as a build dependency for building software component Y: For example, a [[Lexical analysis|"Lexer"]] has to by built first in order to generate code for / of another software component. |
||
==Projects using |
==Projects using Scratchbox 2== |
||
* [[Tizen]] |
* [[Tizen]] |
||
* [[Maemo]] |
* [[Maemo]] |
||
* [[MeeGo]] / [[Mer (operating system)|Mer]] |
* [[MeeGo]] / [[Mer (operating system)|Mer]] |
||
* [[WIDK]] webOS Internals Development Kit |
|||
⚫ | |||
* [[Sailfish OS]] |
* [[Sailfish OS]] |
||
* WIDK − [https://www.webos-internals.org/wiki/WebOS_Internals_PDK WebOS Internals Development Kit] |
|||
⚫ | |||
==External links== |
==External links== |
||
* [https://github.com/sailfishos/scratchbox2/tree/master/docs Scratchbox |
* [https://github.com/sailfishos/scratchbox2/tree/master/docs Scratchbox 2 documentation] |
||
* [https://web.archive.org/web/20130602210814/http://maemo.gitorious.org/scratchbox2 Archive of the original Scratchbox |
* [https://web.archive.org/web/20130602210814/http://maemo.gitorious.org/scratchbox2 Archive of the original Scratchbox 2 website] |
||
{{Mobile operating systems}} |
{{Mobile operating systems}} |
Revision as of 20:35, 28 January 2023
Original author(s) | Nokia |
---|---|
Developer(s) | Jolla |
Initial release | 2009-04-01 |
Stable release(s) | |
2.2.4[1]
/ 2012-04-01 | |
Preview release(s) | |
2.3.62[2]
/ 2012-06-05 | |
Written in | C |
Operating system | Linux |
Platform | Cross-platform |
Type | Build automation |
License | LGPL 2.1 |
Website | https://github.com/sailfishos/scratchbox2 |
Scratchbox 2 (often abbreviated to "sb2" or "sbox2") is a cross-compilation toolkit designed to make embedded Linux application development easier. It also provides a full set of tools to integrate and cross-compile an entire Linux distribution.
In the Linux world, when building software, many parameters are auto-detected on the host system (like installed libraries and system configuration), for example through Autotools' ./configure
scripts. When one wants to build software for an embedded target by cross-compilation, most auto-detected parameters are incorrect: I.e., host configuration is not the same as the embedded target's configuration.
Without Scratchbox 2, one has to manually set many parameters and "hack" the "configure" process to be able to generate code for the embedded target.
Scratchbox 2 allows one to set up a [Virtualization|"virtual"]] environment that will trick the Autotools and executables into thinking that they are directly running on the embedded target with its configuration.
Moreover, Scratchbox 2 provides a technology called CPU-transparency that goes further: With CPU-transparency, executables built for the host CPU or for the target CPU could be executed directly on the host with sb2 handling the task to emulate a different CPU-architecture if necessary to run software components compiled for the target CPU. Hence a build process can mix using programs built for different CPU architectures. That is especially useful when a build process requires building a software component X first as a build dependency for building software component Y: For example, a "Lexer" has to by built first in order to generate code for / of another software component.
Projects using Scratchbox 2
- Tizen
- Maemo
- MeeGo / Mer
- Sailfish OS
- WIDK − WebOS Internals Development Kit
- Raspberry Pi (used to build binaries for the Raspberry Pi alpha board)
External links
- ^ "Scratchbox 2.2.4". Scratchbox 2 (sb2). 2012-04-01. Retrieved 2023-01-27.
- ^ "Scratchbox 2.3.63". Scratchbox 2 (sb2). 2012-06-05. Retrieved 2023-01-27.