⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 glib-cross-compiling.html

📁 最新gtk中文资料集
💻 HTML
字号:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html><head><meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"><title>Cross-compiling the GLib package</title><meta name="generator" content="DocBook XSL Stylesheets V1.73.2"><link rel="start" href="index.html" title="GLib Reference Manual"><link rel="up" href="glib.html" title="GLib Overview"><link rel="prev" href="glib-building.html" title="Compiling the GLib package"><link rel="next" href="glib-compiling.html" title="Compiling GLib Applications"><meta name="generator" content="GTK-Doc V1.9 (XML mode)"><link rel="stylesheet" href="style.css" type="text/css"><link rel="chapter" href="glib.html" title="GLib Overview"><link rel="chapter" href="glib-fundamentals.html" title="GLib Fundamentals"><link rel="chapter" href="glib-core.html" title="GLib Core Application Support"><link rel="chapter" href="glib-utilities.html" title="GLib Utilities"><link rel="chapter" href="glib-data-types.html" title="GLib Data Types"><link rel="chapter" href="tools.html" title="GLib Tools"><link rel="index" href="ix01.html" title="Index"><link rel="index" href="ix02.html" title="Index of deprecated symbols"><link rel="index" href="ix03.html" title="Index of new symbols in 2.2"><link rel="index" href="ix04.html" title="Index of new symbols in 2.4"><link rel="index" href="ix05.html" title="Index of new symbols in 2.6"><link rel="index" href="ix06.html" title="Index of new symbols in 2.8"><link rel="index" href="ix07.html" title="Index of new symbols in 2.10"><link rel="index" href="ix08.html" title="Index of new symbols in 2.12"><link rel="index" href="ix09.html" title="Index of new symbols in 2.14"><link rel="index" href="ix10.html" title="Index of new symbols in 2.16"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><table class="navigation" id="top" width="100%" summary="Navigation header" cellpadding="2" cellspacing="2"><tr valign="middle"><td><a accesskey="p" href="glib-building.html"><img src="left.png" width="24" height="24" border="0" alt="Prev"></a></td><td><a accesskey="u" href="glib.html"><img src="up.png" width="24" height="24" border="0" alt="Up"></a></td><td><a accesskey="h" href="index.html"><img src="home.png" width="24" height="24" border="0" alt="Home"></a></td><th width="100%" align="center">GLib Reference Manual</th><td><a accesskey="n" href="glib-compiling.html"><img src="right.png" width="24" height="24" border="0" alt="Next"></a></td></tr></table><div class="refentry" lang="en"><a name="glib-cross-compiling"></a><div class="titlepage"></div><div class="refnamediv"><table width="100%"><tr><td valign="top"><h2><span class="refentrytitle">Cross-compiling the GLib package</span></h2><p>Cross-compiling the GLib Package &#8212; How to cross-compile GLib</p></td><td valign="top" align="right"></td></tr></table></div><div class="refsect1" lang="en"><a name="cross"></a><h2>Building the Library for a different architecture</h2><p>        Cross-compilation is the process of compiling a program or        library on a different architecture or operating system then        it will be run upon. GLib is slightly more difficult to         cross-compile than many packages because much of GLib is        about hiding differences between different systems.       </p><p>        These notes cover things specific to cross-compiling GLib;        for general information about cross-compilation, see the        <span class="application">autoconf</span> info pages.      </p><p>        GLib tries to detect as much information as possible about        the target system by compiling and linking programs without        actually running anything; however, some information GLib        needs is not available this way. This information needs        to be provided to the configure script via a "cache file"        or by setting the cache variables in your environment.      </p><p>        As an example of using a cache file, to cross compile for        the "MingW32" Win32 runtine environment on a Linux system,        create a file 'win32.cache' with the following contents:      </p><pre class="programlisting"> glib_cv_long_long_format=I64glib_cv_stack_grows=no      </pre><p>        Then execute the following commands:      </p><pre class="programlisting">PATH=/path/to/mingw32-compiler/bin:$PATHchmod a-w win32.cache   # prevent configure from changing it./configure --cache-file=win32.cache --host=mingw32      </pre><p>        The complete list of cache file variables follows. Most         of these won't need to be set in most cases.      </p></div><div class="refsect1" lang="en"><a name="cache-file-variables"></a><h2>Cache file variables</h2><p><b>glib_cv_long_long_format=[ll/q/I64].&#160;</b>           Format used by <code class="function">printf()</code> and            <code class="function">scanf()</code> for 64 bit integers. "ll" is            the C99 standard, and what is used by the 'trio' library           that GLib builds if your <code class="function">printf()</code> is            insufficiently capable.           Doesn't need to be set if you are compiling using trio.        </p><p><b>glib_cv_stack_grows=[yes/no].&#160;</b>           Whether the stack grows up or down. Most places will want "no",           A few architectures, such as PA-RISC need "yes".        </p><p><b>glib_cv_working_bcopy=[yes/no].&#160;</b>           Whether your <code class="function">bcopy()</code> can handle overlapping            copies. Only needs to be set if you don't have            <code class="function">memmove()</code>. (Very unlikely)	</p><p><b>glib_cv_sane_realloc=[yes/np].&#160;</b>              Whether your <code class="function">realloc()</code> conforms to ANSI C             and can handle <code class="literal">NULL</code> as the first argument.             Defaults to "yes" and probably doesn't need to be set.	</p><p><b>glib_cv_have_strlcpy=[yes/no].&#160;</b>            Whether you have <code class="function">strlcpy()</code> that matches             OpenBSD. Defaults to "no", which is safe, since GLib uses a             built-in version in that case.	</p><p><b>glib_cv_va_val_copy=[yes/no].&#160;</b>            Whether <span class="type">va_list</span> can be copied as a pointer. If set             to "no", then <code class="function">memcopy()</code> will be used. Only             matters if you don't have <code class="function">va_copy()</code> or             <code class="function">__va_copy()</code>. (So, doesn't matter for GCC.)             Defaults to "yes" which is slightly more common than "no".	</p><p><b>glib_cv_rtldglobal_broken=[yes/no].&#160;</b>            Whether you have a bug found in OSF/1 v5.0. Defaults to "no".         </p><p><b>glib_cv_uscore=[yes/no].&#160;</b>            Whether an underscore needs to be prepended to symbols when            looking them up via <code class="function">dlsym()</code>. Only needs to             be set if your system uses	    <code class="function">dlopen()</code>/<code class="function">dlsym()</code>.	 </p><p><b>ac_cv_func_posix_getpwuid_r=[yes/no].&#160;</b>            Whether you have a getpwuid_r function (in your C library,	    not your thread library) that conforms to the POSIX spec.            (Takes a 'struct passwd **' as the final argument)         </p><p><b>ac_cv_func_nonposix_getpwuid_r=[yes/no].&#160;</b>            Whether you have some variant of <code class="function">getpwuid_r()</code>            that doesn't conform to to the POSIX spec, but GLib might be able            to use (or might segfault.) Only needs to be set if 	    <code class="literal">ac_cv_func_posix_getpwuid_r</code> is not set. It's             safest to set this to "no".         </p><p><b>glib_cv_use_pid_surrogate=[yes/no].&#160;</b>            Whether to use a <code class="function">setpriority()</code> on the PID of             the thread as a method for setting the priority of threads. This             only needs to be set when using POSIX threads.         </p><p><b>ac_cv_func_printf_unix98=[yes/no].&#160;</b>           Whether your <code class="function">printf()</code> family supports Unix98            style <code class="literal">%N$</code> positional parameters. Defaults to	"no".         </p><p><b>ac_cv_func_vsnprintf_c99=[yes/no].&#160;</b>            Whether you have a <code class="function">vsnprintf()</code> with C99             semantics. (C99 semantics means returning the number of bytes             that would have been written had the output buffer had enough             space.) Defaults to "no".         </p></div></div></body></html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -