CINXE.COM

ExtUtils::Liblist - determine libraries to use and how to use them - Perldoc Browser

<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>ExtUtils::Liblist - determine libraries to use and how to use them - Perldoc Browser</title> <link rel="search" href="/opensearch.xml" type="application/opensearchdescription+xml" title="Perldoc Browser"> <link rel="canonical" href="https://perldoc.perl.org/ExtUtils::Liblist"> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" integrity="sha384-JcKb8q3iqJ61gNV9KGb8thSsNjpSL0n8PARn9HuZOnIxN0hoP+VmmDGMN5t9UJ0Z" crossorigin="anonymous"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/10.5.0/styles/stackoverflow-light.min.css" integrity="sha512-cG1IdFxqipi3gqLmksLtuk13C+hBa57a6zpWxMeoY3Q9O6ooFxq50DayCdm0QrDgZjMUn23z/0PMZlgft7Yp5Q==" crossorigin="anonymous" /> <style> body { background: #f4f4f5; color: #020202; } .navbar-dark { background-image: -webkit-linear-gradient(top, #005f85 0, #002e49 100%); background-image: -o-linear-gradient(top, #005f85 0, #002e49 100%); background-image: linear-gradient(to bottom, #005f85 0, #002e49 100%); filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff005f85', endColorstr='#ff002e49', GradientType=0); background-repeat: repeat-x; } .navbar-dark .navbar-nav .nav-link, .navbar-dark .navbar-nav .nav-link:focus { color: #fff } .navbar-dark .navbar-nav .nav-link:hover { color: #ffef68 } #wrapperlicious { margin: 0 auto; font: 0.9em 'Helvetica Neue', Helvetica, sans-serif; font-weight: normal; line-height: 1.5em; margin: 0; padding: 0; } #wrapperlicious h1 { font-size: 1.5em } #wrapperlicious h2 { font-size: 1.3em } #wrapperlicious h3 { font-size: 1.1em } #wrapperlicious h4 { font-size: 0.9em } #wrapperlicious h1, #wrapperlicious h2, #wrapperlicious h3, #wrapperlicious h4, #wrapperlicious dt { color: #020202; margin-top: 1em; margin-bottom: 1em; position: relative; font-weight: bold; } #wrapperlicious a { color: inherit; text-decoration: underline } #wrapperlicious #toc { text-decoration: none } #wrapperlicious a:hover { color: #2a2a2a } #wrapperlicious a img { border: 0 } #wrapperlicious :not(pre) > code { color: inherit; background-color: rgba(0, 0, 0, 0.04); border-radius: 3px; font: 0.9em Consolas, Menlo, Monaco, monospace; padding: 0.3em; } #wrapperlicious dd { margin: 0; margin-left: 2em; } #wrapperlicious dt { color: #2a2a2a; font-weight: bold; margin-left: 0.9em; } #wrapperlicious p { margin-bottom: 1em; margin-top: 1em; } #wrapperlicious li > p { margin-bottom: 0; margin-top: 0; } #wrapperlicious pre { border: 1px solid #c1c1c1; border-radius: 3px; font: 100% Consolas, Menlo, Monaco, monospace; margin-bottom: 1em; margin-top: 1em; } #wrapperlicious pre > code { display: block; background-color: #f6f6f6; font: 0.9em Consolas, Menlo, Monaco, monospace; line-height: 1.5em; text-align: left; white-space: pre; padding: 1em; } #wrapperlicious dl, #wrapperlicious ol, #wrapperlicious ul { margin-bottom: 1em; margin-top: 1em; } #wrapperlicious ul { list-style-type: square; } #wrapperlicious ul ul { margin-bottom: 0px; margin-top: 0px; } #footer { font-size: 0.8em; padding-top: 0.5em; text-align: center; } #more { display: inline; font-size: 0.8em; } #perldocdiv { background-color: #fff; border: 1px solid #c1c1c1; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; margin-left: auto; margin-right: auto; padding: 3em; padding-top: 1em; max-width: 960px; } #moduleversion { float: right } #wrapperlicious .leading-notice { font-style: italic; padding-left: 1em; margin-top: 1em; margin-bottom: 1em; } #wrapperlicious .permalink { display: none; left: -0.75em; position: absolute; padding-right: 0.25em; text-decoration: none; } #wrapperlicious h1:hover .permalink, #wrapperlicious h2:hover .permalink, #wrapperlicious h3:hover .permalink, #wrapperlicious h4:hover .permalink, #wrapperlicious dt:hover .permalink { display: block; } </style> <!-- Global site tag (gtag.js) - Google Analytics --> <script async src="https://www.googletagmanager.com/gtag/js?id=G-KVNWBNT5FB"></script> <script> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-KVNWBNT5FB'); gtag('config', 'UA-50555-3'); </script> </head> <body> <nav class="navbar navbar-expand-md navbar-dark bg-dark justify-content-between"> <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="navbarNav" aria-expanded="false" aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <a class="navbar-brand" href="/"><img src="/images/perl_camel_30.png" width="30" height="30" class="d-inline-block align-top" alt="Perl Camel Logo"> Perldoc Browser</a> <div class="collapse navbar-collapse" id="navbarNav"> <ul class="navbar-nav mr-auto"> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-stable" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">5.32.0</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-stable"> <a class="dropdown-item" href="/ExtUtils::Liblist">Latest</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.40.1/ExtUtils::Liblist">5.40.1</a> <a class="dropdown-item" href="/5.40.0/ExtUtils::Liblist">5.40.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.38.3/ExtUtils::Liblist">5.38.3</a> <a class="dropdown-item" href="/5.38.2/ExtUtils::Liblist">5.38.2</a> <a class="dropdown-item" href="/5.38.1/ExtUtils::Liblist">5.38.1</a> <a class="dropdown-item" href="/5.38.0/ExtUtils::Liblist">5.38.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.36.3/ExtUtils::Liblist">5.36.3</a> <a class="dropdown-item" href="/5.36.2/ExtUtils::Liblist">5.36.2</a> <a class="dropdown-item" href="/5.36.1/ExtUtils::Liblist">5.36.1</a> <a class="dropdown-item" href="/5.36.0/ExtUtils::Liblist">5.36.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.34.3/ExtUtils::Liblist">5.34.3</a> <a class="dropdown-item" href="/5.34.2/ExtUtils::Liblist">5.34.2</a> <a class="dropdown-item" href="/5.34.1/ExtUtils::Liblist">5.34.1</a> <a class="dropdown-item" href="/5.34.0/ExtUtils::Liblist">5.34.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.32.1/ExtUtils::Liblist">5.32.1</a> <a class="dropdown-item active" href="/5.32.0/ExtUtils::Liblist">5.32.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.30.3/ExtUtils::Liblist">5.30.3</a> <a class="dropdown-item" href="/5.30.2/ExtUtils::Liblist">5.30.2</a> <a class="dropdown-item" href="/5.30.1/ExtUtils::Liblist">5.30.1</a> <a class="dropdown-item" href="/5.30.0/ExtUtils::Liblist">5.30.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.28.3/ExtUtils::Liblist">5.28.3</a> <a class="dropdown-item" href="/5.28.2/ExtUtils::Liblist">5.28.2</a> <a class="dropdown-item" href="/5.28.1/ExtUtils::Liblist">5.28.1</a> <a class="dropdown-item" href="/5.28.0/ExtUtils::Liblist">5.28.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.26.3/ExtUtils::Liblist">5.26.3</a> <a class="dropdown-item" href="/5.26.2/ExtUtils::Liblist">5.26.2</a> <a class="dropdown-item" href="/5.26.1/ExtUtils::Liblist">5.26.1</a> <a class="dropdown-item" href="/5.26.0/ExtUtils::Liblist">5.26.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.24.4/ExtUtils::Liblist">5.24.4</a> <a class="dropdown-item" href="/5.24.3/ExtUtils::Liblist">5.24.3</a> <a class="dropdown-item" href="/5.24.2/ExtUtils::Liblist">5.24.2</a> <a class="dropdown-item" href="/5.24.1/ExtUtils::Liblist">5.24.1</a> <a class="dropdown-item" href="/5.24.0/ExtUtils::Liblist">5.24.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.22.4/ExtUtils::Liblist">5.22.4</a> <a class="dropdown-item" href="/5.22.3/ExtUtils::Liblist">5.22.3</a> <a class="dropdown-item" href="/5.22.2/ExtUtils::Liblist">5.22.2</a> <a class="dropdown-item" href="/5.22.1/ExtUtils::Liblist">5.22.1</a> <a class="dropdown-item" href="/5.22.0/ExtUtils::Liblist">5.22.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.20.3/ExtUtils::Liblist">5.20.3</a> <a class="dropdown-item" href="/5.20.2/ExtUtils::Liblist">5.20.2</a> <a class="dropdown-item" href="/5.20.1/ExtUtils::Liblist">5.20.1</a> <a class="dropdown-item" href="/5.20.0/ExtUtils::Liblist">5.20.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.18.4/ExtUtils::Liblist">5.18.4</a> <a class="dropdown-item" href="/5.18.3/ExtUtils::Liblist">5.18.3</a> <a class="dropdown-item" href="/5.18.2/ExtUtils::Liblist">5.18.2</a> <a class="dropdown-item" href="/5.18.1/ExtUtils::Liblist">5.18.1</a> <a class="dropdown-item" href="/5.18.0/ExtUtils::Liblist">5.18.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.16.3/ExtUtils::Liblist">5.16.3</a> <a class="dropdown-item" href="/5.16.2/ExtUtils::Liblist">5.16.2</a> <a class="dropdown-item" href="/5.16.1/ExtUtils::Liblist">5.16.1</a> <a class="dropdown-item" href="/5.16.0/ExtUtils::Liblist">5.16.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.14.4/ExtUtils::Liblist">5.14.4</a> <a class="dropdown-item" href="/5.14.3/ExtUtils::Liblist">5.14.3</a> <a class="dropdown-item" href="/5.14.2/ExtUtils::Liblist">5.14.2</a> <a class="dropdown-item" href="/5.14.1/ExtUtils::Liblist">5.14.1</a> <a class="dropdown-item" href="/5.14.0/ExtUtils::Liblist">5.14.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.12.5/ExtUtils::Liblist">5.12.5</a> <a class="dropdown-item" href="/5.12.4/ExtUtils::Liblist">5.12.4</a> <a class="dropdown-item" href="/5.12.3/ExtUtils::Liblist">5.12.3</a> <a class="dropdown-item" href="/5.12.2/ExtUtils::Liblist">5.12.2</a> <a class="dropdown-item" href="/5.12.1/ExtUtils::Liblist">5.12.1</a> <a class="dropdown-item" href="/5.12.0/ExtUtils::Liblist">5.12.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.10.1/ExtUtils::Liblist">5.10.1</a> <a class="dropdown-item" href="/5.10.0/ExtUtils::Liblist">5.10.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.8.9/ExtUtils::Liblist">5.8.9</a> <a class="dropdown-item" href="/5.8.8/ExtUtils::Liblist">5.8.8</a> <a class="dropdown-item" href="/5.8.7/ExtUtils::Liblist">5.8.7</a> <a class="dropdown-item" href="/5.8.6/ExtUtils::Liblist">5.8.6</a> <a class="dropdown-item" href="/5.8.5/ExtUtils::Liblist">5.8.5</a> <a class="dropdown-item" href="/5.8.4/ExtUtils::Liblist">5.8.4</a> <a class="dropdown-item" href="/5.8.3/ExtUtils::Liblist">5.8.3</a> <a class="dropdown-item" href="/5.8.2/ExtUtils::Liblist">5.8.2</a> <a class="dropdown-item" href="/5.8.1/ExtUtils::Liblist">5.8.1</a> <a class="dropdown-item" href="/5.8.0/ExtUtils::Liblist">5.8.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.6.2/ExtUtils::Liblist">5.6.2</a> <a class="dropdown-item" href="/5.6.1/ExtUtils::Liblist">5.6.1</a> <a class="dropdown-item" href="/5.6.0/ExtUtils::Liblist">5.6.0</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.005_04/ExtUtils::Liblist">5.005_04</a> <a class="dropdown-item" href="/5.005_03/ExtUtils::Liblist">5.005_03</a> <a class="dropdown-item" href="/5.005_02/ExtUtils::Liblist">5.005_02</a> <a class="dropdown-item" href="/5.005_01/ExtUtils::Liblist">5.005_01</a> <a class="dropdown-item" href="/5.005/ExtUtils::Liblist">5.005</a> </div> </li> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-dev" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Dev</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-dev"> <a class="dropdown-item" href="/blead/ExtUtils::Liblist">blead</a> <a class="dropdown-item" href="/5.41.10/ExtUtils::Liblist">5.41.10</a> <a class="dropdown-item" href="/5.41.9/ExtUtils::Liblist">5.41.9</a> <a class="dropdown-item" href="/5.41.8/ExtUtils::Liblist">5.41.8</a> <a class="dropdown-item" href="/5.41.7/ExtUtils::Liblist">5.41.7</a> <a class="dropdown-item" href="/5.41.6/ExtUtils::Liblist">5.41.6</a> <a class="dropdown-item" href="/5.41.5/ExtUtils::Liblist">5.41.5</a> <a class="dropdown-item" href="/5.41.4/ExtUtils::Liblist">5.41.4</a> <a class="dropdown-item" href="/5.41.3/ExtUtils::Liblist">5.41.3</a> <a class="dropdown-item" href="/5.41.2/ExtUtils::Liblist">5.41.2</a> <a class="dropdown-item" href="/5.41.1/ExtUtils::Liblist">5.41.1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.40.1-RC1/ExtUtils::Liblist">5.40.1-RC1</a> <a class="dropdown-item" href="/5.40.0-RC2/ExtUtils::Liblist">5.40.0-RC2</a> <a class="dropdown-item" href="/5.40.0-RC1/ExtUtils::Liblist">5.40.0-RC1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.39.10/ExtUtils::Liblist">5.39.10</a> <a class="dropdown-item" href="/5.39.9/ExtUtils::Liblist">5.39.9</a> <a class="dropdown-item" href="/5.39.8/ExtUtils::Liblist">5.39.8</a> <a class="dropdown-item" href="/5.39.7/ExtUtils::Liblist">5.39.7</a> <a class="dropdown-item" href="/5.39.6/ExtUtils::Liblist">5.39.6</a> <a class="dropdown-item" href="/5.39.5/ExtUtils::Liblist">5.39.5</a> <a class="dropdown-item" href="/5.39.4/ExtUtils::Liblist">5.39.4</a> <a class="dropdown-item" href="/5.39.3/ExtUtils::Liblist">5.39.3</a> <a class="dropdown-item" href="/5.39.2/ExtUtils::Liblist">5.39.2</a> <a class="dropdown-item" href="/5.39.1/ExtUtils::Liblist">5.39.1</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.38.3-RC1/ExtUtils::Liblist">5.38.3-RC1</a> </div> </li> <li class="nav-item dropdown text-nowrap"> <a class="nav-link dropdown-toggle" href="#" id="dropdownlink-nav" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Documentation</a> <div class="dropdown-menu" aria-labelledby="dropdownlink-nav"> <a class="dropdown-item" href="/5.32.0/perl">Perl</a> <a class="dropdown-item" href="/5.32.0/perlintro">Intro</a> <a class="dropdown-item" href="/5.32.0/perl#Tutorials">Tutorials</a> <a class="dropdown-item" href="/5.32.0/perlfaq">FAQs</a> <a class="dropdown-item" href="/5.32.0/perl#Reference-Manual">Reference</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.32.0/perlop">Operators</a> <a class="dropdown-item" href="/5.32.0/functions">Functions</a> <a class="dropdown-item" href="/5.32.0/variables">Variables</a> <a class="dropdown-item" href="/5.32.0/modules">Modules</a> <a class="dropdown-item" href="/5.32.0/perlutil">Utilities</a> <div class="dropdown-divider"></div> <a class="dropdown-item" href="/5.32.0/perldelta">Release Notes</a> <a class="dropdown-item" href="/5.32.0/perlcommunity">Community</a> <a class="dropdown-item" href="/5.32.0/perlhist">History</a> </div> </li> </ul> <ul class="navbar-nav"> <script> function set_expand (expand) { var perldocdiv = document.getElementById('perldocdiv'); var width = window.getComputedStyle(perldocdiv).getPropertyValue('max-width'); var expanded = (width == '' || width == 'none') ? true : false; if (expand === null) { expand = !expanded; } if ((expand && !expanded) || (!expand && expanded)) { perldocdiv.style.setProperty('max-width', expand ? 'none' : '960px'); var button_classlist = document.getElementById('content-expand-button').classList; if (expand) { button_classlist.add('btn-light'); button_classlist.remove('btn-outline-light'); } else { button_classlist.add('btn-outline-light'); button_classlist.remove('btn-light'); } } return expand; } function toggle_expand () { var expand = set_expand(null); document.cookie = 'perldoc_expand=' + (expand ? 1 : 0) + '; path=/; expires=Tue, 19 Jan 2038 03:14:07 UTC'; } function read_expand () { return document.cookie.split(';').some(function (item) { return item.indexOf('perldoc_expand=1') >= 0 }); } if (document.readyState === 'loading') { document.addEventListener('DOMContentLoaded', function () { if (read_expand()) { set_expand(true); } }); } else if (read_expand()) { set_expand(true); } </script> <button id="content-expand-button" type="button" class="btn btn-outline-light d-none d-lg-inline-block mr-4" onclick="toggle_expand()">Expand</button> </ul> <form class="form-inline" method="get" action="/5.32.0/search"> <input class="form-control mr-3" type="search" name="q" placeholder="Search" aria-label="Search" value=""> </form> </div> </nav> <div id="wrapperlicious" class="container-fluid"> <div id="perldocdiv"> <div id="links"> <a href="/5.32.0/ExtUtils::Liblist">ExtUtils::Liblist</a> <div id="more"> (<a href="/5.32.0/ExtUtils::Liblist.txt">source</a>, <a href="https://metacpan.org/pod/ExtUtils::Liblist">CPAN</a>) </div> <div id="moduleversion">version 7.44</div> </div> <div class="leading-notice"> You are viewing the version of this documentation from Perl 5.32.0. <a href="/ExtUtils::Liblist">View the latest version</a> </div> <h1><a id="toc">CONTENTS</a></h1> <ul> <li> <a class="text-decoration-none" href="#NAME">NAME</a> </li> <li> <a class="text-decoration-none" href="#SYNOPSIS">SYNOPSIS</a> </li> <li> <a class="text-decoration-none" href="#DESCRIPTION">DESCRIPTION</a> <ul> <li> <a class="text-decoration-none" href="#EXTRALIBS">EXTRALIBS</a> </li> <li> <a class="text-decoration-none" href="#LDLOADLIBS-and-LD_RUN_PATH">LDLOADLIBS and LD_RUN_PATH</a> </li> <li> <a class="text-decoration-none" href="#BSLOADLIBS">BSLOADLIBS</a> </li> </ul> </li> <li> <a class="text-decoration-none" href="#PORTABILITY">PORTABILITY</a> <ul> <li> <a class="text-decoration-none" href="#VMS-implementation">VMS implementation</a> </li> <li> <a class="text-decoration-none" href="#Win32-implementation">Win32 implementation</a> </li> </ul> </li> <li> <a class="text-decoration-none" href="#SEE-ALSO">SEE ALSO</a> </li> </ul> <h1 id="NAME"><a class="permalink" href="#NAME">#</a>NAME</h1> <p>ExtUtils::Liblist - determine libraries to use and how to use them</p> <h1 id="SYNOPSIS"><a class="permalink" href="#SYNOPSIS">#</a>SYNOPSIS</h1> <pre><code>require ExtUtils::Liblist; $MM-&gt;ext($potential_libs, $verbose, $need_names); # Usually you can get away with: ExtUtils::Liblist-&gt;ext($potential_libs, $verbose, $need_names)</code></pre> <h1 id="DESCRIPTION"><a class="permalink" href="#DESCRIPTION">#</a>DESCRIPTION</h1> <p>This utility takes a list of libraries in the form <code>-llib1 -llib2 -llib3</code> and returns lines suitable for inclusion in an extension Makefile. Extra library paths may be included with the form <code>-L/another/path</code> this will affect the searches for all subsequent libraries.</p> <p>It returns an array of four or five scalar values: EXTRALIBS, BSLOADLIBS, LDLOADLIBS, LD_RUN_PATH, and, optionally, a reference to the array of the filenames of actual libraries. Some of these don&#39;t mean anything unless on Unix. See the details about those platform specifics below. The list of the filenames is returned only if $need_names argument is true.</p> <p>Dependent libraries can be linked in one of three ways:</p> <ul> <li><p>For static extensions</p> <p>by the ld command when the perl binary is linked with the extension library. See EXTRALIBS below.</p> </li> <li><p>For dynamic extensions at build/link time</p> <p>by the ld command when the shared object is built/linked. See LDLOADLIBS below.</p> </li> <li><p>For dynamic extensions at load time</p> <p>by the DynaLoader when the shared object is loaded. See BSLOADLIBS below.</p> </li> </ul> <h2 id="EXTRALIBS"><a class="permalink" href="#EXTRALIBS">#</a>EXTRALIBS</h2> <p>List of libraries that need to be linked with when linking a perl binary which includes this extension. Only those libraries that actually exist are included. These are written to a file and used when linking perl.</p> <h2 id="LDLOADLIBS-and-LD_RUN_PATH"><a class="permalink" href="#LDLOADLIBS-and-LD_RUN_PATH">#</a><a id="LDLOADLIBS"></a>LDLOADLIBS and LD_RUN_PATH</h2> <p>List of those libraries which can or must be linked into the shared library when created using ld. These may be static or dynamic libraries. LD_RUN_PATH is a colon separated list of the directories in LDLOADLIBS. It is passed as an environment variable to the process that links the shared library.</p> <h2 id="BSLOADLIBS"><a class="permalink" href="#BSLOADLIBS">#</a>BSLOADLIBS</h2> <p>List of those libraries that are needed but can be linked in dynamically at run time on this platform. SunOS/Solaris does not need this because ld records the information (from LDLOADLIBS) into the object file. This list is used to create a .bs (bootstrap) file.</p> <h1 id="PORTABILITY"><a class="permalink" href="#PORTABILITY">#</a>PORTABILITY</h1> <p>This module deals with a lot of system dependencies and has quite a few architecture specific <code>if</code>s in the code.</p> <h2 id="VMS-implementation"><a class="permalink" href="#VMS-implementation">#</a><a id="VMS"></a>VMS implementation</h2> <p>The version of ext() which is executed under VMS differs from the Unix-OS/2 version in several respects:</p> <ul> <li><p>Input library and path specifications are accepted with or without the <code>-l</code> and <code>-L</code> prefixes used by Unix linkers. If neither prefix is present, a token is considered a directory to search if it is in fact a directory, and a library to search for otherwise. Authors who wish their extensions to be portable to Unix or OS/2 should use the Unix prefixes, since the Unix-OS/2 version of ext() requires them.</p> </li> <li><p>Wherever possible, shareable images are preferred to object libraries, and object libraries to plain object files. In accordance with VMS naming conventions, ext() looks for files named <i>lib</i>shr and <i>lib</i>rtl; it also looks for <i>lib</i>lib and lib<i>lib</i> to accommodate Unix conventions used in some ported software.</p> </li> <li><p>For each library that is found, an appropriate directive for a linker options file is generated. The return values are space-separated strings of these directives, rather than elements used on the linker command line.</p> </li> <li><p>LDLOADLIBS contains both the libraries found based on <code>$potential_libs</code> and the CRTLs, if any, specified in Config.pm. EXTRALIBS contains just those libraries found based on <code>$potential_libs</code>. BSLOADLIBS and LD_RUN_PATH are always empty.</p> </li> </ul> <p>In addition, an attempt is made to recognize several common Unix library names, and filter them out or convert them to their VMS equivalents, as appropriate.</p> <p>In general, the VMS version of ext() should properly handle input from extensions originally designed for a Unix or VMS environment. If you encounter problems, or discover cases where the search could be improved, please let us know.</p> <h2 id="Win32-implementation"><a class="permalink" href="#Win32-implementation">#</a><a id="Win32"></a>Win32 implementation</h2> <p>The version of ext() which is executed under Win32 differs from the Unix-OS/2 version in several respects:</p> <ul> <li><p>If <code>$potential_libs</code> is empty, the return value will be empty. Otherwise, the libraries specified by <code>$Config{perllibs}</code> (see Config.pm) will be appended to the list of <code>$potential_libs</code>. The libraries will be searched for in the directories specified in <code>$potential_libs</code>, <code>$Config{libpth}</code>, and in <code>$Config{installarchlib}/CORE</code>. For each library that is found, a space-separated list of fully qualified library pathnames is generated.</p> </li> <li><p>Input library and path specifications are accepted with or without the <code>-l</code> and <code>-L</code> prefixes used by Unix linkers.</p> <p>An entry of the form <code>-La:\foo</code> specifies the <code>a:\foo</code> directory to look for the libraries that follow.</p> <p>An entry of the form <code>-lfoo</code> specifies the library <code>foo</code>, which may be spelled differently depending on what kind of compiler you are using. If you are using GCC, it gets translated to <code>libfoo.a</code>, but for other win32 compilers, it becomes <code>foo.lib</code>. If no files are found by those translated names, one more attempt is made to find them using either <code>foo.a</code> or <code>libfoo.lib</code>, depending on whether GCC or some other win32 compiler is being used, respectively.</p> <p>If neither the <code>-L</code> or <code>-l</code> prefix is present in an entry, the entry is considered a directory to search if it is in fact a directory, and a library to search for otherwise. The <code>$Config{lib_ext}</code> suffix will be appended to any entries that are not directories and don&#39;t already have the suffix.</p> <p>Note that the <code>-L</code> and <code>-l</code> prefixes are <b>not required</b>, but authors who wish their extensions to be portable to Unix or OS/2 should use the prefixes, since the Unix-OS/2 version of ext() requires them.</p> </li> <li><p>Entries cannot be plain object files, as many Win32 compilers will not handle object files in the place of libraries.</p> </li> <li><p>Entries in <code>$potential_libs</code> beginning with a colon and followed by alphanumeric characters are treated as flags. Unknown flags will be ignored.</p> <p>An entry that matches <code>/:nodefault/i</code> disables the appending of default libraries found in <code>$Config{perllibs}</code> (this should be only needed very rarely).</p> <p>An entry that matches <code>/:nosearch/i</code> disables all searching for the libraries specified after it. Translation of <code>-Lfoo</code> and <code>-lfoo</code> still happens as appropriate (depending on compiler being used, as reflected by <code>$Config{cc}</code>), but the entries are not verified to be valid files or directories.</p> <p>An entry that matches <code>/:search/i</code> reenables searching for the libraries specified after it. You can put it at the end to enable searching for default libraries specified by <code>$Config{perllibs}</code>.</p> </li> <li><p>The libraries specified may be a mixture of static libraries and import libraries (to link with DLLs). Since both kinds are used pretty transparently on the Win32 platform, we do not attempt to distinguish between them.</p> </li> <li><p>LDLOADLIBS and EXTRALIBS are always identical under Win32, and BSLOADLIBS and LD_RUN_PATH are always empty (this may change in future).</p> </li> <li><p>You must make sure that any paths and path components are properly surrounded with double-quotes if they contain spaces. For example, <code>$potential_libs</code> could be (literally):</p> <pre><code class="plaintext">&quot;-Lc:\Program Files\vc\lib&quot; msvcrt.lib &quot;la test\foo bar.lib&quot;</code></pre> <p>Note how the first and last entries are protected by quotes in order to protect the spaces.</p> </li> <li><p>Since this module is most often used only indirectly from extension <code>Makefile.PL</code> files, here is an example <code>Makefile.PL</code> entry to add a library to the build process for an extension:</p> <pre><code class="plaintext">LIBS =&gt; [&#39;-lgl&#39;]</code></pre> <p>When using GCC, that entry specifies that MakeMaker should first look for <code>libgl.a</code> (followed by <code>gl.a</code>) in all the locations specified by <code>$Config{libpth}</code>.</p> <p>When using a compiler other than GCC, the above entry will search for <code>gl.lib</code> (followed by <code>libgl.lib</code>).</p> <p>If the library happens to be in a location not in <code>$Config{libpth}</code>, you need:</p> <pre><code class="plaintext">LIBS =&gt; [&#39;-Lc:\gllibs -lgl&#39;]</code></pre> <p>Here is a less often used example:</p> <pre><code class="plaintext">LIBS =&gt; [&#39;-lgl&#39;, &#39;:nosearch -Ld:\mesalibs -lmesa -luser32&#39;]</code></pre> <p>This specifies a search for library <code>gl</code> as before. If that search fails to find the library, it looks at the next item in the list. The <code>:nosearch</code> flag will prevent searching for the libraries that follow, so it simply returns the value as <code>-Ld:\mesalibs -lmesa -luser32</code>, since GCC can use that value as is with its linker.</p> <p>When using the Visual C compiler, the second item is returned as <code>-libpath:d:\mesalibs mesa.lib user32.lib</code>.</p> <p>When using the Borland compiler, the second item is returned as <code>-Ld:\mesalibs mesa.lib user32.lib</code>, and MakeMaker takes care of moving the <code>-Ld:\mesalibs</code> to the correct place in the linker command line.</p> </li> </ul> <h1 id="SEE-ALSO"><a class="permalink" href="#SEE-ALSO">#</a><a id="SEE"></a>SEE ALSO</h1> <p><a href="/5.32.0/ExtUtils::MakeMaker">ExtUtils::MakeMaker</a></p> </div> <div id="footer"> <p>Perldoc Browser is maintained by Dan Book (<a href="https://metacpan.org/author/DBOOK">DBOOK</a>). Please contact him via the <a href="https://github.com/Grinnz/perldoc-browser/issues">GitHub issue tracker</a> or <a href="mailto:dbook@cpan.org">email</a> regarding any issues with the site itself, search, or rendering of documentation.</p> <p>The Perl documentation is maintained by the Perl 5 Porters in the development of Perl. Please contact them via the <a href="https://github.com/Perl/perl5/issues">Perl issue tracker</a>, the <a href="https://lists.perl.org/list/perl5-porters.html">mailing list</a>, or <a href="https://kiwiirc.com/client/irc.perl.org/p5p">IRC</a> to report any issues with the contents or format of the documentation.</p> </div> </div> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.slim.min.js" integrity="sha512-/DXTXr6nQodMUiq+IUJYCt2PPOUjrHJ9wFrqpJ3XkgPNOZVfMok7cRw6CSxyCQxXn6ozlESsSh1/sMCTF1rL/g==" crossorigin="anonymous"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.1/umd/popper.min.js" integrity="sha512-ubuT8Z88WxezgSqf3RLuNi5lmjstiJcyezx34yIU2gAHonIi27Na7atqzUZCOoY4CExaoFumzOsFQ2Ch+I/HCw==" crossorigin="anonymous"></script> <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/js/bootstrap.min.js" integrity="sha384-B4gt1jrGC7Jh4AgTPSdUtOBvfO8shuf57BaghqFfPlYxofvL8/KUEfYiJOMMV+rV" crossorigin="anonymous"></script> <script src="/js/highlight.pack.js"></script> <script>hljs.highlightAll();</script> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10