blob: 6725cb5fe8c65a918e27ea704a4ce0d68b3caa61 [file] [log] [blame]
Andrey Andreevc5769952019-01-16 17:49:35 +02001
2
3<!DOCTYPE html>
4<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
5<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
6<head>
7 <meta charset="utf-8">
8 <meta name="viewport" content="width=device-width, initial-scale=1.0">
9
10 <title>Loader Class &mdash; CodeIgniter 3.1.10 documentation</title>
11
12
13
14
15 <link rel="shortcut icon" href="../_static/ci-icon.ico"/>
16
17
18
19 <link href='https://fonts.googleapis.com/css?family=Lato:400,700,400italic,700italic|Roboto+Slab:400,700|Inconsolata:400,700&subset=latin,cyrillic' rel='stylesheet' type='text/css'>
20
21
22
23
24
25
26
27
28
29 <link rel="stylesheet" href="../_static/css/citheme.css" type="text/css" />
30
31
32
33 <link rel="index" title="Index"
34 href="../genindex.html"/>
35 <link rel="search" title="Search" href="../search.html"/>
36 <link rel="top" title="CodeIgniter 3.1.10 documentation" href="../index.html"/>
37 <link rel="up" title="Libraries" href="index.html"/>
38 <link rel="next" title="Migrations Class" href="migration.html"/>
39 <link rel="prev" title="Language Class" href="language.html"/>
40
41
42 <script src="https://cdnjs.cloudflare.com/ajax/libs/modernizr/2.6.2/modernizr.min.js"></script>
43
44</head>
45
46<body class="wy-body-for-nav" role="document">
47
48 <div id="nav">
49 <div id="nav_inner">
50
51
52
53 <div id="pulldown-menu" class="ciNav">
54 <ul>
55<li class="toctree-l1"><a class="reference internal" href="../general/welcome.html">Welcome to CodeIgniter</a></li>
56</ul>
57<ul>
58<li class="toctree-l1"><a class="reference internal" href="../installation/index.html">Installation Instructions</a><ul>
59<li class="toctree-l2"><a class="reference internal" href="../installation/downloads.html">Downloading CodeIgniter</a></li>
60<li class="toctree-l2"><a class="reference internal" href="../installation/index.html">Installation Instructions</a></li>
61<li class="toctree-l2"><a class="reference internal" href="../installation/upgrading.html">Upgrading From a Previous Version</a></li>
62<li class="toctree-l2"><a class="reference internal" href="../installation/troubleshooting.html">Troubleshooting</a></li>
63</ul>
64</li>
65</ul>
66<ul>
67<li class="toctree-l1"><a class="reference internal" href="../overview/index.html">CodeIgniter Overview</a><ul>
68<li class="toctree-l2"><a class="reference internal" href="../overview/getting_started.html">Getting Started</a></li>
69<li class="toctree-l2"><a class="reference internal" href="../overview/at_a_glance.html">CodeIgniter at a Glance</a></li>
70<li class="toctree-l2"><a class="reference internal" href="../overview/features.html">Supported Features</a></li>
71<li class="toctree-l2"><a class="reference internal" href="../overview/appflow.html">Application Flow Chart</a></li>
72<li class="toctree-l2"><a class="reference internal" href="../overview/mvc.html">Model-View-Controller</a></li>
73<li class="toctree-l2"><a class="reference internal" href="../overview/goals.html">Architectural Goals</a></li>
74</ul>
75</li>
76</ul>
77<ul>
78<li class="toctree-l1"><a class="reference internal" href="../tutorial/index.html">Tutorial</a><ul>
79<li class="toctree-l2"><a class="reference internal" href="../tutorial/static_pages.html">Static pages</a></li>
80<li class="toctree-l2"><a class="reference internal" href="../tutorial/news_section.html">News section</a></li>
81<li class="toctree-l2"><a class="reference internal" href="../tutorial/create_news_items.html">Create news items</a></li>
82<li class="toctree-l2"><a class="reference internal" href="../tutorial/conclusion.html">Conclusion</a></li>
83</ul>
84</li>
85</ul>
86<ul>
87<li class="toctree-l1"><a class="reference internal" href="../contributing/index.html">Contributing to CodeIgniter</a><ul>
88<li class="toctree-l2"><a class="reference internal" href="../documentation/index.html">Writing CodeIgniter Documentation</a></li>
89<li class="toctree-l2"><a class="reference internal" href="../DCO.html">Developer’s Certificate of Origin 1.1</a></li>
90</ul>
91</li>
92</ul>
93<ul>
94<li class="toctree-l1"><a class="reference internal" href="../general/index.html">General Topics</a><ul>
95<li class="toctree-l2"><a class="reference internal" href="../general/urls.html">CodeIgniter URLs</a></li>
96<li class="toctree-l2"><a class="reference internal" href="../general/controllers.html">Controllers</a></li>
97<li class="toctree-l2"><a class="reference internal" href="../general/reserved_names.html">Reserved Names</a></li>
98<li class="toctree-l2"><a class="reference internal" href="../general/views.html">Views</a></li>
99<li class="toctree-l2"><a class="reference internal" href="../general/models.html">Models</a></li>
100<li class="toctree-l2"><a class="reference internal" href="../general/helpers.html">Helpers</a></li>
101<li class="toctree-l2"><a class="reference internal" href="../general/libraries.html">Using CodeIgniter Libraries</a></li>
102<li class="toctree-l2"><a class="reference internal" href="../general/creating_libraries.html">Creating Libraries</a></li>
103<li class="toctree-l2"><a class="reference internal" href="../general/drivers.html">Using CodeIgniter Drivers</a></li>
104<li class="toctree-l2"><a class="reference internal" href="../general/creating_drivers.html">Creating Drivers</a></li>
105<li class="toctree-l2"><a class="reference internal" href="../general/core_classes.html">Creating Core System Classes</a></li>
106<li class="toctree-l2"><a class="reference internal" href="../general/ancillary_classes.html">Creating Ancillary Classes</a></li>
107<li class="toctree-l2"><a class="reference internal" href="../general/hooks.html">Hooks - Extending the Framework Core</a></li>
108<li class="toctree-l2"><a class="reference internal" href="../general/autoloader.html">Auto-loading Resources</a></li>
109<li class="toctree-l2"><a class="reference internal" href="../general/common_functions.html">Common Functions</a></li>
110<li class="toctree-l2"><a class="reference internal" href="../general/compatibility_functions.html">Compatibility Functions</a></li>
111<li class="toctree-l2"><a class="reference internal" href="../general/routing.html">URI Routing</a></li>
112<li class="toctree-l2"><a class="reference internal" href="../general/errors.html">Error Handling</a></li>
113<li class="toctree-l2"><a class="reference internal" href="../general/caching.html">Caching</a></li>
114<li class="toctree-l2"><a class="reference internal" href="../general/profiling.html">Profiling Your Application</a></li>
115<li class="toctree-l2"><a class="reference internal" href="../general/cli.html">Running via the CLI</a></li>
116<li class="toctree-l2"><a class="reference internal" href="../general/managing_apps.html">Managing your Applications</a></li>
117<li class="toctree-l2"><a class="reference internal" href="../general/environments.html">Handling Multiple Environments</a></li>
118<li class="toctree-l2"><a class="reference internal" href="../general/alternative_php.html">Alternate PHP Syntax for View Files</a></li>
119<li class="toctree-l2"><a class="reference internal" href="../general/security.html">Security</a></li>
120<li class="toctree-l2"><a class="reference internal" href="../general/styleguide.html">PHP Style Guide</a></li>
121</ul>
122</li>
123</ul>
124<ul class="current">
125<li class="toctree-l1 current"><a class="reference internal" href="index.html">Libraries</a><ul class="current">
126<li class="toctree-l2"><a class="reference internal" href="benchmark.html">Benchmarking Class</a></li>
127<li class="toctree-l2"><a class="reference internal" href="caching.html">Caching Driver</a></li>
128<li class="toctree-l2"><a class="reference internal" href="calendar.html">Calendaring Class</a></li>
129<li class="toctree-l2"><a class="reference internal" href="cart.html">Shopping Cart Class</a></li>
130<li class="toctree-l2"><a class="reference internal" href="config.html">Config Class</a></li>
131<li class="toctree-l2"><a class="reference internal" href="email.html">Email Class</a></li>
132<li class="toctree-l2"><a class="reference internal" href="encrypt.html">Encrypt Class</a></li>
133<li class="toctree-l2"><a class="reference internal" href="encryption.html">Encryption Library</a></li>
134<li class="toctree-l2"><a class="reference internal" href="file_uploading.html">File Uploading Class</a></li>
135<li class="toctree-l2"><a class="reference internal" href="form_validation.html">Form Validation</a></li>
136<li class="toctree-l2"><a class="reference internal" href="ftp.html">FTP Class</a></li>
137<li class="toctree-l2"><a class="reference internal" href="image_lib.html">Image Manipulation Class</a></li>
138<li class="toctree-l2"><a class="reference internal" href="input.html">Input Class</a></li>
139<li class="toctree-l2"><a class="reference internal" href="javascript.html">Javascript Class</a></li>
140<li class="toctree-l2"><a class="reference internal" href="language.html">Language Class</a></li>
141<li class="toctree-l2 current"><a class="current reference internal" href="#">Loader Class</a></li>
142<li class="toctree-l2"><a class="reference internal" href="migration.html">Migrations Class</a></li>
143<li class="toctree-l2"><a class="reference internal" href="output.html">Output Class</a></li>
144<li class="toctree-l2"><a class="reference internal" href="pagination.html">Pagination Class</a></li>
145<li class="toctree-l2"><a class="reference internal" href="parser.html">Template Parser Class</a></li>
146<li class="toctree-l2"><a class="reference internal" href="security.html">Security Class</a></li>
147<li class="toctree-l2"><a class="reference internal" href="sessions.html">Session Library</a></li>
148<li class="toctree-l2"><a class="reference internal" href="table.html">HTML Table Class</a></li>
149<li class="toctree-l2"><a class="reference internal" href="trackback.html">Trackback Class</a></li>
150<li class="toctree-l2"><a class="reference internal" href="typography.html">Typography Class</a></li>
151<li class="toctree-l2"><a class="reference internal" href="unit_testing.html">Unit Testing Class</a></li>
152<li class="toctree-l2"><a class="reference internal" href="uri.html">URI Class</a></li>
153<li class="toctree-l2"><a class="reference internal" href="user_agent.html">User Agent Class</a></li>
154<li class="toctree-l2"><a class="reference internal" href="xmlrpc.html">XML-RPC and XML-RPC Server Classes</a></li>
155<li class="toctree-l2"><a class="reference internal" href="zip.html">Zip Encoding Class</a></li>
156</ul>
157</li>
158</ul>
159<ul>
160<li class="toctree-l1"><a class="reference internal" href="../database/index.html">Database Reference</a><ul>
161<li class="toctree-l2"><a class="reference internal" href="../database/examples.html">Quick Start: Usage Examples</a></li>
162<li class="toctree-l2"><a class="reference internal" href="../database/configuration.html">Database Configuration</a></li>
163<li class="toctree-l2"><a class="reference internal" href="../database/connecting.html">Connecting to a Database</a></li>
164<li class="toctree-l2"><a class="reference internal" href="../database/queries.html">Running Queries</a></li>
165<li class="toctree-l2"><a class="reference internal" href="../database/results.html">Generating Query Results</a></li>
166<li class="toctree-l2"><a class="reference internal" href="../database/helpers.html">Query Helper Functions</a></li>
167<li class="toctree-l2"><a class="reference internal" href="../database/query_builder.html">Query Builder Class</a></li>
168<li class="toctree-l2"><a class="reference internal" href="../database/transactions.html">Transactions</a></li>
169<li class="toctree-l2"><a class="reference internal" href="../database/metadata.html">Getting MetaData</a></li>
170<li class="toctree-l2"><a class="reference internal" href="../database/call_function.html">Custom Function Calls</a></li>
171<li class="toctree-l2"><a class="reference internal" href="../database/caching.html">Query Caching</a></li>
172<li class="toctree-l2"><a class="reference internal" href="../database/forge.html">Database Manipulation with Database Forge</a></li>
173<li class="toctree-l2"><a class="reference internal" href="../database/utilities.html">Database Utilities Class</a></li>
174<li class="toctree-l2"><a class="reference internal" href="../database/db_driver_reference.html">Database Driver Reference</a></li>
175</ul>
176</li>
177</ul>
178<ul>
179<li class="toctree-l1"><a class="reference internal" href="../helpers/index.html">Helpers</a><ul>
180<li class="toctree-l2"><a class="reference internal" href="../helpers/array_helper.html">Array Helper</a></li>
181<li class="toctree-l2"><a class="reference internal" href="../helpers/captcha_helper.html">CAPTCHA Helper</a></li>
182<li class="toctree-l2"><a class="reference internal" href="../helpers/cookie_helper.html">Cookie Helper</a></li>
183<li class="toctree-l2"><a class="reference internal" href="../helpers/date_helper.html">Date Helper</a></li>
184<li class="toctree-l2"><a class="reference internal" href="../helpers/directory_helper.html">Directory Helper</a></li>
185<li class="toctree-l2"><a class="reference internal" href="../helpers/download_helper.html">Download Helper</a></li>
186<li class="toctree-l2"><a class="reference internal" href="../helpers/email_helper.html">Email Helper</a></li>
187<li class="toctree-l2"><a class="reference internal" href="../helpers/file_helper.html">File Helper</a></li>
188<li class="toctree-l2"><a class="reference internal" href="../helpers/form_helper.html">Form Helper</a></li>
189<li class="toctree-l2"><a class="reference internal" href="../helpers/html_helper.html">HTML Helper</a></li>
190<li class="toctree-l2"><a class="reference internal" href="../helpers/inflector_helper.html">Inflector Helper</a></li>
191<li class="toctree-l2"><a class="reference internal" href="../helpers/language_helper.html">Language Helper</a></li>
192<li class="toctree-l2"><a class="reference internal" href="../helpers/number_helper.html">Number Helper</a></li>
193<li class="toctree-l2"><a class="reference internal" href="../helpers/path_helper.html">Path Helper</a></li>
194<li class="toctree-l2"><a class="reference internal" href="../helpers/security_helper.html">Security Helper</a></li>
195<li class="toctree-l2"><a class="reference internal" href="../helpers/smiley_helper.html">Smiley Helper</a></li>
196<li class="toctree-l2"><a class="reference internal" href="../helpers/string_helper.html">String Helper</a></li>
197<li class="toctree-l2"><a class="reference internal" href="../helpers/text_helper.html">Text Helper</a></li>
198<li class="toctree-l2"><a class="reference internal" href="../helpers/typography_helper.html">Typography Helper</a></li>
199<li class="toctree-l2"><a class="reference internal" href="../helpers/url_helper.html">URL Helper</a></li>
200<li class="toctree-l2"><a class="reference internal" href="../helpers/xml_helper.html">XML Helper</a></li>
201</ul>
202</li>
203</ul>
204
205 </div>
206
207
208 </div>
209</div>
210<div id="nav2">
211 <a href="#" id="openToc">
212 <img src="" title="Toggle Table of Contents" alt="Toggle Table of Contents" />
213 </a>
214</div>
215
216 <div class="wy-grid-for-nav">
217
218
219 <nav data-toggle="wy-nav-shift" class="wy-nav-side">
220 <div class="wy-side-nav-search">
221
222 <a href="../index.html" class="fa fa-home"> CodeIgniter</a>
223
224
225<div role="search">
226 <form id="rtd-search-form" class="wy-form" action="../search.html" method="get">
227 <input type="text" name="q" placeholder="Search docs" />
228 <input type="hidden" name="check_keywords" value="yes" />
229 <input type="hidden" name="area" value="default" />
230 </form>
231</div>
232 </div>
233
234 <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
235
236
237
238 <ul>
239<li class="toctree-l1"><a class="reference internal" href="../general/welcome.html">Welcome to CodeIgniter</a></li>
240</ul>
241<ul>
242<li class="toctree-l1"><a class="reference internal" href="../installation/index.html">Installation Instructions</a><ul>
243<li class="toctree-l2"><a class="reference internal" href="../installation/downloads.html">Downloading CodeIgniter</a></li>
244<li class="toctree-l2"><a class="reference internal" href="../installation/index.html">Installation Instructions</a></li>
245<li class="toctree-l2"><a class="reference internal" href="../installation/upgrading.html">Upgrading From a Previous Version</a></li>
246<li class="toctree-l2"><a class="reference internal" href="../installation/troubleshooting.html">Troubleshooting</a></li>
247</ul>
248</li>
249</ul>
250<ul>
251<li class="toctree-l1"><a class="reference internal" href="../overview/index.html">CodeIgniter Overview</a><ul>
252<li class="toctree-l2"><a class="reference internal" href="../overview/getting_started.html">Getting Started</a></li>
253<li class="toctree-l2"><a class="reference internal" href="../overview/at_a_glance.html">CodeIgniter at a Glance</a></li>
254<li class="toctree-l2"><a class="reference internal" href="../overview/features.html">Supported Features</a></li>
255<li class="toctree-l2"><a class="reference internal" href="../overview/appflow.html">Application Flow Chart</a></li>
256<li class="toctree-l2"><a class="reference internal" href="../overview/mvc.html">Model-View-Controller</a></li>
257<li class="toctree-l2"><a class="reference internal" href="../overview/goals.html">Architectural Goals</a></li>
258</ul>
259</li>
260</ul>
261<ul>
262<li class="toctree-l1"><a class="reference internal" href="../tutorial/index.html">Tutorial</a><ul>
263<li class="toctree-l2"><a class="reference internal" href="../tutorial/static_pages.html">Static pages</a></li>
264<li class="toctree-l2"><a class="reference internal" href="../tutorial/news_section.html">News section</a></li>
265<li class="toctree-l2"><a class="reference internal" href="../tutorial/create_news_items.html">Create news items</a></li>
266<li class="toctree-l2"><a class="reference internal" href="../tutorial/conclusion.html">Conclusion</a></li>
267</ul>
268</li>
269</ul>
270<ul>
271<li class="toctree-l1"><a class="reference internal" href="../contributing/index.html">Contributing to CodeIgniter</a><ul>
272<li class="toctree-l2"><a class="reference internal" href="../documentation/index.html">Writing CodeIgniter Documentation</a></li>
273<li class="toctree-l2"><a class="reference internal" href="../DCO.html">Developer’s Certificate of Origin 1.1</a></li>
274</ul>
275</li>
276</ul>
277<ul>
278<li class="toctree-l1"><a class="reference internal" href="../general/index.html">General Topics</a><ul>
279<li class="toctree-l2"><a class="reference internal" href="../general/urls.html">CodeIgniter URLs</a></li>
280<li class="toctree-l2"><a class="reference internal" href="../general/controllers.html">Controllers</a></li>
281<li class="toctree-l2"><a class="reference internal" href="../general/reserved_names.html">Reserved Names</a></li>
282<li class="toctree-l2"><a class="reference internal" href="../general/views.html">Views</a></li>
283<li class="toctree-l2"><a class="reference internal" href="../general/models.html">Models</a></li>
284<li class="toctree-l2"><a class="reference internal" href="../general/helpers.html">Helpers</a></li>
285<li class="toctree-l2"><a class="reference internal" href="../general/libraries.html">Using CodeIgniter Libraries</a></li>
286<li class="toctree-l2"><a class="reference internal" href="../general/creating_libraries.html">Creating Libraries</a></li>
287<li class="toctree-l2"><a class="reference internal" href="../general/drivers.html">Using CodeIgniter Drivers</a></li>
288<li class="toctree-l2"><a class="reference internal" href="../general/creating_drivers.html">Creating Drivers</a></li>
289<li class="toctree-l2"><a class="reference internal" href="../general/core_classes.html">Creating Core System Classes</a></li>
290<li class="toctree-l2"><a class="reference internal" href="../general/ancillary_classes.html">Creating Ancillary Classes</a></li>
291<li class="toctree-l2"><a class="reference internal" href="../general/hooks.html">Hooks - Extending the Framework Core</a></li>
292<li class="toctree-l2"><a class="reference internal" href="../general/autoloader.html">Auto-loading Resources</a></li>
293<li class="toctree-l2"><a class="reference internal" href="../general/common_functions.html">Common Functions</a></li>
294<li class="toctree-l2"><a class="reference internal" href="../general/compatibility_functions.html">Compatibility Functions</a></li>
295<li class="toctree-l2"><a class="reference internal" href="../general/routing.html">URI Routing</a></li>
296<li class="toctree-l2"><a class="reference internal" href="../general/errors.html">Error Handling</a></li>
297<li class="toctree-l2"><a class="reference internal" href="../general/caching.html">Caching</a></li>
298<li class="toctree-l2"><a class="reference internal" href="../general/profiling.html">Profiling Your Application</a></li>
299<li class="toctree-l2"><a class="reference internal" href="../general/cli.html">Running via the CLI</a></li>
300<li class="toctree-l2"><a class="reference internal" href="../general/managing_apps.html">Managing your Applications</a></li>
301<li class="toctree-l2"><a class="reference internal" href="../general/environments.html">Handling Multiple Environments</a></li>
302<li class="toctree-l2"><a class="reference internal" href="../general/alternative_php.html">Alternate PHP Syntax for View Files</a></li>
303<li class="toctree-l2"><a class="reference internal" href="../general/security.html">Security</a></li>
304<li class="toctree-l2"><a class="reference internal" href="../general/styleguide.html">PHP Style Guide</a></li>
305</ul>
306</li>
307</ul>
308<ul class="current">
309<li class="toctree-l1 current"><a class="reference internal" href="index.html">Libraries</a><ul class="current">
310<li class="toctree-l2"><a class="reference internal" href="benchmark.html">Benchmarking Class</a></li>
311<li class="toctree-l2"><a class="reference internal" href="caching.html">Caching Driver</a></li>
312<li class="toctree-l2"><a class="reference internal" href="calendar.html">Calendaring Class</a></li>
313<li class="toctree-l2"><a class="reference internal" href="cart.html">Shopping Cart Class</a></li>
314<li class="toctree-l2"><a class="reference internal" href="config.html">Config Class</a></li>
315<li class="toctree-l2"><a class="reference internal" href="email.html">Email Class</a></li>
316<li class="toctree-l2"><a class="reference internal" href="encrypt.html">Encrypt Class</a></li>
317<li class="toctree-l2"><a class="reference internal" href="encryption.html">Encryption Library</a></li>
318<li class="toctree-l2"><a class="reference internal" href="file_uploading.html">File Uploading Class</a></li>
319<li class="toctree-l2"><a class="reference internal" href="form_validation.html">Form Validation</a></li>
320<li class="toctree-l2"><a class="reference internal" href="ftp.html">FTP Class</a></li>
321<li class="toctree-l2"><a class="reference internal" href="image_lib.html">Image Manipulation Class</a></li>
322<li class="toctree-l2"><a class="reference internal" href="input.html">Input Class</a></li>
323<li class="toctree-l2"><a class="reference internal" href="javascript.html">Javascript Class</a></li>
324<li class="toctree-l2"><a class="reference internal" href="language.html">Language Class</a></li>
325<li class="toctree-l2 current"><a class="current reference internal" href="#">Loader Class</a></li>
326<li class="toctree-l2"><a class="reference internal" href="migration.html">Migrations Class</a></li>
327<li class="toctree-l2"><a class="reference internal" href="output.html">Output Class</a></li>
328<li class="toctree-l2"><a class="reference internal" href="pagination.html">Pagination Class</a></li>
329<li class="toctree-l2"><a class="reference internal" href="parser.html">Template Parser Class</a></li>
330<li class="toctree-l2"><a class="reference internal" href="security.html">Security Class</a></li>
331<li class="toctree-l2"><a class="reference internal" href="sessions.html">Session Library</a></li>
332<li class="toctree-l2"><a class="reference internal" href="table.html">HTML Table Class</a></li>
333<li class="toctree-l2"><a class="reference internal" href="trackback.html">Trackback Class</a></li>
334<li class="toctree-l2"><a class="reference internal" href="typography.html">Typography Class</a></li>
335<li class="toctree-l2"><a class="reference internal" href="unit_testing.html">Unit Testing Class</a></li>
336<li class="toctree-l2"><a class="reference internal" href="uri.html">URI Class</a></li>
337<li class="toctree-l2"><a class="reference internal" href="user_agent.html">User Agent Class</a></li>
338<li class="toctree-l2"><a class="reference internal" href="xmlrpc.html">XML-RPC and XML-RPC Server Classes</a></li>
339<li class="toctree-l2"><a class="reference internal" href="zip.html">Zip Encoding Class</a></li>
340</ul>
341</li>
342</ul>
343<ul>
344<li class="toctree-l1"><a class="reference internal" href="../database/index.html">Database Reference</a><ul>
345<li class="toctree-l2"><a class="reference internal" href="../database/examples.html">Quick Start: Usage Examples</a></li>
346<li class="toctree-l2"><a class="reference internal" href="../database/configuration.html">Database Configuration</a></li>
347<li class="toctree-l2"><a class="reference internal" href="../database/connecting.html">Connecting to a Database</a></li>
348<li class="toctree-l2"><a class="reference internal" href="../database/queries.html">Running Queries</a></li>
349<li class="toctree-l2"><a class="reference internal" href="../database/results.html">Generating Query Results</a></li>
350<li class="toctree-l2"><a class="reference internal" href="../database/helpers.html">Query Helper Functions</a></li>
351<li class="toctree-l2"><a class="reference internal" href="../database/query_builder.html">Query Builder Class</a></li>
352<li class="toctree-l2"><a class="reference internal" href="../database/transactions.html">Transactions</a></li>
353<li class="toctree-l2"><a class="reference internal" href="../database/metadata.html">Getting MetaData</a></li>
354<li class="toctree-l2"><a class="reference internal" href="../database/call_function.html">Custom Function Calls</a></li>
355<li class="toctree-l2"><a class="reference internal" href="../database/caching.html">Query Caching</a></li>
356<li class="toctree-l2"><a class="reference internal" href="../database/forge.html">Database Manipulation with Database Forge</a></li>
357<li class="toctree-l2"><a class="reference internal" href="../database/utilities.html">Database Utilities Class</a></li>
358<li class="toctree-l2"><a class="reference internal" href="../database/db_driver_reference.html">Database Driver Reference</a></li>
359</ul>
360</li>
361</ul>
362<ul>
363<li class="toctree-l1"><a class="reference internal" href="../helpers/index.html">Helpers</a><ul>
364<li class="toctree-l2"><a class="reference internal" href="../helpers/array_helper.html">Array Helper</a></li>
365<li class="toctree-l2"><a class="reference internal" href="../helpers/captcha_helper.html">CAPTCHA Helper</a></li>
366<li class="toctree-l2"><a class="reference internal" href="../helpers/cookie_helper.html">Cookie Helper</a></li>
367<li class="toctree-l2"><a class="reference internal" href="../helpers/date_helper.html">Date Helper</a></li>
368<li class="toctree-l2"><a class="reference internal" href="../helpers/directory_helper.html">Directory Helper</a></li>
369<li class="toctree-l2"><a class="reference internal" href="../helpers/download_helper.html">Download Helper</a></li>
370<li class="toctree-l2"><a class="reference internal" href="../helpers/email_helper.html">Email Helper</a></li>
371<li class="toctree-l2"><a class="reference internal" href="../helpers/file_helper.html">File Helper</a></li>
372<li class="toctree-l2"><a class="reference internal" href="../helpers/form_helper.html">Form Helper</a></li>
373<li class="toctree-l2"><a class="reference internal" href="../helpers/html_helper.html">HTML Helper</a></li>
374<li class="toctree-l2"><a class="reference internal" href="../helpers/inflector_helper.html">Inflector Helper</a></li>
375<li class="toctree-l2"><a class="reference internal" href="../helpers/language_helper.html">Language Helper</a></li>
376<li class="toctree-l2"><a class="reference internal" href="../helpers/number_helper.html">Number Helper</a></li>
377<li class="toctree-l2"><a class="reference internal" href="../helpers/path_helper.html">Path Helper</a></li>
378<li class="toctree-l2"><a class="reference internal" href="../helpers/security_helper.html">Security Helper</a></li>
379<li class="toctree-l2"><a class="reference internal" href="../helpers/smiley_helper.html">Smiley Helper</a></li>
380<li class="toctree-l2"><a class="reference internal" href="../helpers/string_helper.html">String Helper</a></li>
381<li class="toctree-l2"><a class="reference internal" href="../helpers/text_helper.html">Text Helper</a></li>
382<li class="toctree-l2"><a class="reference internal" href="../helpers/typography_helper.html">Typography Helper</a></li>
383<li class="toctree-l2"><a class="reference internal" href="../helpers/url_helper.html">URL Helper</a></li>
384<li class="toctree-l2"><a class="reference internal" href="../helpers/xml_helper.html">XML Helper</a></li>
385</ul>
386</li>
387</ul>
388
389
390
391 </div>
392 &nbsp;
393 </nav>
394
395 <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
396
397
398 <nav class="wy-nav-top" role="navigation" aria-label="top navigation">
399 <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
400 <a href="../index.html">CodeIgniter</a>
401 </nav>
402
403
404
405 <div class="wy-nav-content">
406 <div class="rst-content">
407 <div role="navigation" aria-label="breadcrumbs navigation">
408 <ul class="wy-breadcrumbs">
409 <li><a href="../index.html">Docs</a> &raquo;</li>
410
411 <li><a href="index.html">Libraries</a> &raquo;</li>
412
413 <li>Loader Class</li>
414 <li class="wy-breadcrumbs-aside">
415
416 </li>
417 <div style="float:right;margin-left:5px;" id="closeMe">
418 <img title="Classic Layout" alt="classic layout" src="" />
419 </div>
420 </ul>
421 <hr/>
422</div>
423 <div role="main" class="document">
424
425 <div class="section" id="loader-class">
426<h1>Loader Class<a class="headerlink" href="#loader-class" title="Permalink to this headline"></a></h1>
427<p>Loader, as the name suggests, is used to load elements. These elements
428can be libraries (classes) <a class="reference internal" href="../general/views.html"><span class="doc">View files</span></a>,
429<a class="reference internal" href="../general/drivers.html"><span class="doc">Drivers</span></a>,
430<a class="reference internal" href="../general/helpers.html"><span class="doc">Helpers</span></a>,
431<a class="reference internal" href="../general/models.html"><span class="doc">Models</span></a>, or your own files.</p>
432<div class="admonition note">
433<p class="first admonition-title">Note</p>
434<p class="last">This class is initialized automatically by the system so there
435is no need to do it manually.</p>
436</div>
437<div class="contents local topic" id="contents">
438<ul class="simple">
439<li><a class="reference internal" href="#application-packages" id="id2">Application “Packages”</a><ul>
440<li><a class="reference internal" href="#package-view-files" id="id3">Package view files</a></li>
441</ul>
442</li>
443<li><a class="reference internal" href="#class-reference" id="id4">Class Reference</a></li>
444</ul>
445</div>
446<div class="custom-index container"></div><div class="section" id="application-packages">
447<h2><a class="toc-backref" href="#id2">Application “Packages”</a><a class="headerlink" href="#application-packages" title="Permalink to this headline"></a></h2>
448<p>An application package allows for the easy distribution of complete sets
449of resources in a single directory, complete with its own libraries,
450models, helpers, config, and language files. It is recommended that
451these packages be placed in the application/third_party directory. Below
452is a sample map of an package directory.</p>
453<p>The following is an example of a directory for an application package
454named “Foo Bar”.</p>
455<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="o">/</span><span class="nx">application</span><span class="o">/</span><span class="nx">third_party</span><span class="o">/</span><span class="nx">foo_bar</span>
456
457<span class="nx">config</span><span class="o">/</span>
458<span class="nx">helpers</span><span class="o">/</span>
459<span class="nx">language</span><span class="o">/</span>
460<span class="nx">libraries</span><span class="o">/</span>
461<span class="nx">models</span><span class="o">/</span>
462</pre></div>
463</div>
464<p>Whatever the purpose of the “Foo Bar” application package, it has its
465own config files, helpers, language files, libraries, and models. To use
466these resources in your controllers, you first need to tell the Loader
467that you are going to be loading resources from a package, by adding the
468package path via the <code class="docutils literal"><span class="pre">add_package_path()</span></code> method.</p>
469<div class="section" id="package-view-files">
470<h3><a class="toc-backref" href="#id3">Package view files</a><a class="headerlink" href="#package-view-files" title="Permalink to this headline"></a></h3>
471<p>By Default, package view files paths are set when <code class="docutils literal"><span class="pre">add_package_path()</span></code>
472is called. View paths are looped through, and once a match is
473encountered that view is loaded.</p>
474<p>In this instance, it is possible for view naming collisions within
475packages to occur, and possibly the incorrect package being loaded. To
476ensure against this, set an optional second parameter of FALSE when
477calling <code class="docutils literal"><span class="pre">add_package_path()</span></code>.</p>
478<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">add_package_path</span><span class="p">(</span><span class="nx">APPPATH</span><span class="o">.</span><span class="s1">&#39;my_app&#39;</span><span class="p">,</span> <span class="k">FALSE</span><span class="p">);</span>
479<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">view</span><span class="p">(</span><span class="s1">&#39;my_app_index&#39;</span><span class="p">);</span> <span class="c1">// Loads</span>
480<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">view</span><span class="p">(</span><span class="s1">&#39;welcome_message&#39;</span><span class="p">);</span> <span class="c1">// Will not load the default welcome_message b/c the second param to add_package_path is FALSE</span>
481
482<span class="c1">// Reset things</span>
483<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">remove_package_path</span><span class="p">(</span><span class="nx">APPPATH</span><span class="o">.</span><span class="s1">&#39;my_app&#39;</span><span class="p">);</span>
484
485<span class="c1">// Again without the second parameter:</span>
486<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">add_package_path</span><span class="p">(</span><span class="nx">APPPATH</span><span class="o">.</span><span class="s1">&#39;my_app&#39;</span><span class="p">);</span>
487<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">view</span><span class="p">(</span><span class="s1">&#39;my_app_index&#39;</span><span class="p">);</span> <span class="c1">// Loads</span>
488<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">view</span><span class="p">(</span><span class="s1">&#39;welcome_message&#39;</span><span class="p">);</span> <span class="c1">// Loads</span>
489</pre></div>
490</div>
491</div>
492</div>
493<div class="section" id="class-reference">
494<h2><a class="toc-backref" href="#id4">Class Reference</a><a class="headerlink" href="#class-reference" title="Permalink to this headline"></a></h2>
495<dl class="class">
496<dt id="CI_Loader">
497<em class="property">class </em><code class="descname">CI_Loader</code><a class="headerlink" href="#CI_Loader" title="Permalink to this definition"></a></dt>
498<dd><dl class="method">
499<dt id="CI_Loader::library">
500<code class="descname">library</code><span class="sig-paren">(</span><em>$library</em><span class="optional">[</span>, <em>$params = NULL</em><span class="optional">[</span>, <em>$object_name = NULL</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::library" title="Permalink to this definition"></a></dt>
501<dd><table class="docutils field-list" frame="void" rules="none">
502<col class="field-name" />
503<col class="field-body" />
504<tbody valign="top">
505<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
506<li><strong>$library</strong> (<em>mixed</em>) – Library name as a string or an array with multiple libraries</li>
507<li><strong>$params</strong> (<em>array</em>) – Optional array of parameters to pass to the loaded library’s constructor</li>
508<li><strong>$object_name</strong> (<em>string</em>) – Optional object name to assign the library to</li>
509</ul>
510</td>
511</tr>
512<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
513</td>
514</tr>
515<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
516</td>
517</tr>
518</tbody>
519</table>
520<p>This method is used to load core classes.</p>
521<div class="admonition note">
522<p class="first admonition-title">Note</p>
523<p class="last">We use the terms “class” and “library” interchangeably.</p>
524</div>
525<p>For example, if you would like to send email with CodeIgniter, the first
526step is to load the email class within your controller:</p>
527<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;email&#39;</span><span class="p">);</span>
528</pre></div>
529</div>
530<p>Once loaded, the library will be ready for use, using <code class="docutils literal"><span class="pre">$this-&gt;email</span></code>.</p>
531<p>Library files can be stored in subdirectories within the main
532“libraries” directory, or within your personal <em>application/libraries</em>
533directory. To load a file located in a subdirectory, simply include the
534path, relative to the “libraries” directory. For example, if you have
535file located at:</p>
536<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nx">libraries</span><span class="o">/</span><span class="nx">flavors</span><span class="o">/</span><span class="nx">Chocolate</span><span class="o">.</span><span class="nx">php</span>
537</pre></div>
538</div>
539<p>You will load it using:</p>
540<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;flavors/chocolate&#39;</span><span class="p">);</span>
541</pre></div>
542</div>
543<p>You may nest the file in as many subdirectories as you want.</p>
544<p>Additionally, multiple libraries can be loaded at the same time by
545passing an array of libraries to the load method.</p>
546<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="k">array</span><span class="p">(</span><span class="s1">&#39;email&#39;</span><span class="p">,</span> <span class="s1">&#39;table&#39;</span><span class="p">));</span>
547</pre></div>
548</div>
549<p><strong>Setting options</strong></p>
550<p>The second (optional) parameter allows you to optionally pass
551configuration setting. You will typically pass these as an array:</p>
552<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$config</span> <span class="o">=</span> <span class="k">array</span> <span class="p">(</span>
553 <span class="s1">&#39;mailtype&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;html&#39;</span><span class="p">,</span>
554 <span class="s1">&#39;charset&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;utf-8&#39;</span><span class="p">,</span>
555 <span class="s1">&#39;priority&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;1&#39;</span>
556<span class="p">);</span>
557
558<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;email&#39;</span><span class="p">,</span> <span class="nv">$config</span><span class="p">);</span>
559</pre></div>
560</div>
561<p>Config options can usually also be set via a config file. Each library
562is explained in detail in its own page, so please read the information
563regarding each one you would like to use.</p>
564<p>Please take note, when multiple libraries are supplied in an array for
565the first parameter, each will receive the same parameter information.</p>
566<p><strong>Assigning a Library to a different object name</strong></p>
567<p>If the third (optional) parameter is blank, the library will usually be
568assigned to an object with the same name as the library. For example, if
569the library is named Calendar, it will be assigned to a variable named
570<code class="docutils literal"><span class="pre">$this-&gt;calendar</span></code>.</p>
571<p>If you prefer to set your own class names you can pass its value to the
572third parameter:</p>
573<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;calendar&#39;</span><span class="p">,</span> <span class="k">NULL</span><span class="p">,</span> <span class="s1">&#39;my_calendar&#39;</span><span class="p">);</span>
574
575<span class="c1">// Calendar class is now accessed using:</span>
576<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">my_calendar</span>
577</pre></div>
578</div>
579<p>Please take note, when multiple libraries are supplied in an array for
580the first parameter, this parameter is discarded.</p>
581</dd></dl>
582
583<dl class="method">
584<dt id="CI_Loader::driver">
585<code class="descname">driver</code><span class="sig-paren">(</span><em>$library</em><span class="optional">[</span>, <em>$params = NULL</em><span class="optional">[</span>, <em>$object_name</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::driver" title="Permalink to this definition"></a></dt>
586<dd><table class="docutils field-list" frame="void" rules="none">
587<col class="field-name" />
588<col class="field-body" />
589<tbody valign="top">
590<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
591<li><strong>$library</strong> (<em>mixed</em>) – Library name as a string or an array with multiple libraries</li>
592<li><strong>$params</strong> (<em>array</em>) – Optional array of parameters to pass to the loaded library’s constructor</li>
593<li><strong>$object_name</strong> (<em>string</em>) – Optional object name to assign the library to</li>
594</ul>
595</td>
596</tr>
597<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
598</td>
599</tr>
600<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
601</td>
602</tr>
603</tbody>
604</table>
605<p>This method is used to load driver libraries, acts very much like the
606<code class="docutils literal"><span class="pre">library()</span></code> method.</p>
607<p>As an example, if you would like to use sessions with CodeIgniter, the first
608step is to load the session driver within your controller:</p>
609<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">driver</span><span class="p">(</span><span class="s1">&#39;session&#39;</span><span class="p">);</span>
610</pre></div>
611</div>
612<p>Once loaded, the library will be ready for use, using <code class="docutils literal"><span class="pre">$this-&gt;session</span></code>.</p>
613<p>Driver files must be stored in a subdirectory within the main
614“libraries” directory, or within your personal <em>application/libraries</em>
615directory. The subdirectory must match the parent class name. Read the
616<a class="reference internal" href="../general/drivers.html"><span class="doc">Drivers</span></a> description for details.</p>
617<p>Additionally, multiple driver libraries can be loaded at the same time by
618passing an array of drivers to the load method.</p>
619<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">driver</span><span class="p">(</span><span class="k">array</span><span class="p">(</span><span class="s1">&#39;session&#39;</span><span class="p">,</span> <span class="s1">&#39;cache&#39;</span><span class="p">));</span>
620</pre></div>
621</div>
622<p><strong>Setting options</strong></p>
623<p>The second (optional) parameter allows you to optionally pass
624configuration settings. You will typically pass these as an array:</p>
625<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$config</span> <span class="o">=</span> <span class="k">array</span><span class="p">(</span>
626 <span class="s1">&#39;sess_driver&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;cookie&#39;</span><span class="p">,</span>
627 <span class="s1">&#39;sess_encrypt_cookie&#39;</span> <span class="o">=&gt;</span> <span class="k">true</span><span class="p">,</span>
628 <span class="s1">&#39;encryption_key&#39;</span> <span class="o">=&gt;</span> <span class="s1">&#39;mysecretkey&#39;</span>
629<span class="p">);</span>
630
631<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">driver</span><span class="p">(</span><span class="s1">&#39;session&#39;</span><span class="p">,</span> <span class="nv">$config</span><span class="p">);</span>
632</pre></div>
633</div>
634<p>Config options can usually also be set via a config file. Each library
635is explained in detail in its own page, so please read the information
636regarding each one you would like to use.</p>
637<p><strong>Assigning a Driver to a different object name</strong></p>
638<p>If the third (optional) parameter is blank, the library will be assigned
639to an object with the same name as the parent class. For example, if
640the library is named Session, it will be assigned to a variable named
641<code class="docutils literal"><span class="pre">$this-&gt;session</span></code>.</p>
642<p>If you prefer to set your own class names you can pass its value to the
643third parameter:</p>
644<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;session&#39;</span><span class="p">,</span> <span class="s1">&#39;&#39;</span><span class="p">,</span> <span class="s1">&#39;my_session&#39;</span><span class="p">);</span>
645
646<span class="c1">// Session class is now accessed using:</span>
647<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">my_session</span>
648</pre></div>
649</div>
650</dd></dl>
651
652<dl class="method">
653<dt id="CI_Loader::view">
654<code class="descname">view</code><span class="sig-paren">(</span><em>$view</em><span class="optional">[</span>, <em>$vars = array()</em><span class="optional">[</span>, <em>return = FALSE</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::view" title="Permalink to this definition"></a></dt>
655<dd><table class="docutils field-list" frame="void" rules="none">
656<col class="field-name" />
657<col class="field-body" />
658<tbody valign="top">
659<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
660<li><strong>$view</strong> (<em>string</em>) – View name</li>
661<li><strong>$vars</strong> (<em>array</em>) – An associative array of variables</li>
662<li><strong>$return</strong> (<em>bool</em>) – Whether to return the loaded view</li>
663</ul>
664</td>
665</tr>
666<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">View content string if $return is set to TRUE, otherwise CI_Loader instance (method chaining)</p>
667</td>
668</tr>
669<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
670</td>
671</tr>
672</tbody>
673</table>
674<p>This method is used to load your View files. If you haven’t read the
675<a class="reference internal" href="../general/views.html"><span class="doc">Views</span></a> section of the user guide it is
676recommended that you do since it shows you how this method is
677typically used.</p>
678<p>The first parameter is required. It is the name of the view file you
679would like to load.</p>
680<div class="admonition note">
681<p class="first admonition-title">Note</p>
682<p class="last">The .php file extension does not need to be specified unless
683you use something other than .php.</p>
684</div>
685<p>The second <strong>optional</strong> parameter can take an associative array or an
686object as input, which it runs through the PHP
687<a class="reference external" href="http://php.net/extract">extract()</a> function to convert to variables
688that can be used in your view files. Again, read the
689<a class="reference internal" href="../general/views.html"><span class="doc">Views</span></a> page to learn how this might be useful.</p>
690<p>The third <strong>optional</strong> parameter lets you change the behavior of the
691method so that it returns data as a string rather than sending it to
692your browser. This can be useful if you want to process the data in some
693way. If you set the parameter to TRUE (boolean) it will return data. The
694default behavior is FALSE, which sends it to your browser. Remember to
695assign it to a variable if you want the data returned:</p>
696<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$string</span> <span class="o">=</span> <span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">view</span><span class="p">(</span><span class="s1">&#39;myfile&#39;</span><span class="p">,</span> <span class="s1">&#39;&#39;</span><span class="p">,</span> <span class="k">TRUE</span><span class="p">);</span>
697</pre></div>
698</div>
699</dd></dl>
700
701<dl class="method">
702<dt id="CI_Loader::vars">
703<code class="descname">vars</code><span class="sig-paren">(</span><em>$vars</em><span class="optional">[</span>, <em>$val = ''</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::vars" title="Permalink to this definition"></a></dt>
704<dd><table class="docutils field-list" frame="void" rules="none">
705<col class="field-name" />
706<col class="field-body" />
707<tbody valign="top">
708<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
709<li><strong>$vars</strong> (<em>mixed</em>) – An array of variables or a single variable name</li>
710<li><strong>$val</strong> (<em>mixed</em>) – Optional variable value</li>
711</ul>
712</td>
713</tr>
714<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
715</td>
716</tr>
717<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
718</td>
719</tr>
720</tbody>
721</table>
722<p>This method takes an associative array as input and generates
723variables using the PHP <a class="reference external" href="http://php.net/extract">extract()</a>
724function. This method produces the same result as using the second
725parameter of the <code class="docutils literal"><span class="pre">$this-&gt;load-&gt;view()</span></code> method above. The reason you
726might want to use this method independently is if you would like to
727set some global variables in the constructor of your controller and have
728them become available in any view file loaded from any method. You can
729have multiple calls to this method. The data get cached and merged
730into one array for conversion to variables.</p>
731</dd></dl>
732
733<dl class="method">
734<dt id="CI_Loader::get_var">
735<code class="descname">get_var</code><span class="sig-paren">(</span><em>$key</em><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::get_var" title="Permalink to this definition"></a></dt>
736<dd><table class="docutils field-list" frame="void" rules="none">
737<col class="field-name" />
738<col class="field-body" />
739<tbody valign="top">
740<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
741<li><strong>$key</strong> (<em>string</em>) – Variable name key</li>
742</ul>
743</td>
744</tr>
745<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">Value if key is found, NULL if not</p>
746</td>
747</tr>
748<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
749</td>
750</tr>
751</tbody>
752</table>
753<p>This method checks the associative array of variables available to
754your views. This is useful if for any reason a var is set in a library
755or another controller method using <code class="docutils literal"><span class="pre">$this-&gt;load-&gt;vars()</span></code>.</p>
756</dd></dl>
757
758<dl class="method">
759<dt id="CI_Loader::get_vars">
760<code class="descname">get_vars</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::get_vars" title="Permalink to this definition"></a></dt>
761<dd><table class="docutils field-list" frame="void" rules="none">
762<col class="field-name" />
763<col class="field-body" />
764<tbody valign="top">
765<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">An array of all assigned view variables</td>
766</tr>
767<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">array</td>
768</tr>
769</tbody>
770</table>
771<p>This method retrieves all variables available to your views.</p>
772</dd></dl>
773
774<dl class="method">
775<dt id="CI_Loader::clear_vars">
776<code class="descname">clear_vars</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::clear_vars" title="Permalink to this definition"></a></dt>
777<dd><table class="docutils field-list" frame="void" rules="none">
778<col class="field-name" />
779<col class="field-body" />
780<tbody valign="top">
781<tr class="field-odd field"><th class="field-name">Returns:</th><td class="field-body">CI_Loader instance (method chaining)</td>
782</tr>
783<tr class="field-even field"><th class="field-name">Return type:</th><td class="field-body">CI_Loader</td>
784</tr>
785</tbody>
786</table>
787<p>Clears cached view variables.</p>
788</dd></dl>
789
790<dl class="method">
791<dt id="CI_Loader::model">
792<code class="descname">model</code><span class="sig-paren">(</span><em>$model</em><span class="optional">[</span>, <em>$name = ''</em><span class="optional">[</span>, <em>$db_conn = FALSE</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::model" title="Permalink to this definition"></a></dt>
793<dd><table class="docutils field-list" frame="void" rules="none">
794<col class="field-name" />
795<col class="field-body" />
796<tbody valign="top">
797<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
798<li><strong>$model</strong> (<em>mixed</em>) – Model name or an array containing multiple models</li>
799<li><strong>$name</strong> (<em>string</em>) – Optional object name to assign the model to</li>
800<li><strong>$db_conn</strong> (<em>string</em>) – Optional database configuration group to load</li>
801</ul>
802</td>
803</tr>
804<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
805</td>
806</tr>
807<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
808</td>
809</tr>
810</tbody>
811</table>
812<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">model</span><span class="p">(</span><span class="s1">&#39;model_name&#39;</span><span class="p">);</span>
813</pre></div>
814</div>
815<p>If your model is located in a subdirectory, include the relative path
816from your models directory. For example, if you have a model located at
817<em>application/models/blog/Queries.php</em> you’ll load it using:</p>
818<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">model</span><span class="p">(</span><span class="s1">&#39;blog/queries&#39;</span><span class="p">);</span>
819</pre></div>
820</div>
821<p>If you would like your model assigned to a different object name you can
822specify it via the second parameter of the loading method:</p>
823<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">model</span><span class="p">(</span><span class="s1">&#39;model_name&#39;</span><span class="p">,</span> <span class="s1">&#39;fubar&#39;</span><span class="p">);</span>
824<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">fubar</span><span class="o">-&gt;</span><span class="na">method</span><span class="p">();</span>
825</pre></div>
826</div>
827</dd></dl>
828
829<dl class="method">
830<dt id="CI_Loader::database">
831<code class="descname">database</code><span class="sig-paren">(</span><span class="optional">[</span><em>$params = ''</em><span class="optional">[</span>, <em>$return = FALSE</em><span class="optional">[</span>, <em>$query_builder = NULL</em><span class="optional">]</span><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::database" title="Permalink to this definition"></a></dt>
832<dd><table class="docutils field-list" frame="void" rules="none">
833<col class="field-name" />
834<col class="field-body" />
835<tbody valign="top">
836<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
837<li><strong>$params</strong> (<em>mixed</em>) – Database group name or configuration options</li>
838<li><strong>$return</strong> (<em>bool</em>) – Whether to return the loaded database object</li>
839<li><strong>$query_builder</strong> (<em>bool</em>) – Whether to load the Query Builder</li>
840</ul>
841</td>
842</tr>
843<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">Loaded CI_DB instance or FALSE on failure if $return is set to TRUE, otherwise CI_Loader instance (method chaining)</p>
844</td>
845</tr>
846<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
847</td>
848</tr>
849</tbody>
850</table>
851<p>This method lets you load the database class. The two parameters are
852<strong>optional</strong>. Please see the <a class="reference internal" href="../database/index.html"><span class="doc">database</span></a>
853section for more info.</p>
854</dd></dl>
855
856<dl class="method">
857<dt id="CI_Loader::dbforge">
858<code class="descname">dbforge</code><span class="sig-paren">(</span><span class="optional">[</span><em>$db = NULL</em><span class="optional">[</span>, <em>$return = FALSE</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::dbforge" title="Permalink to this definition"></a></dt>
859<dd><table class="docutils field-list" frame="void" rules="none">
860<col class="field-name" />
861<col class="field-body" />
862<tbody valign="top">
863<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
864<li><strong>$db</strong> (<em>object</em>) – Database object</li>
865<li><strong>$return</strong> (<em>bool</em>) – Whether to return the Database Forge instance</li>
866</ul>
867</td>
868</tr>
869<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">Loaded CI_DB_forge instance if $return is set to TRUE, otherwise CI_Loader instance (method chaining)</p>
870</td>
871</tr>
872<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
873</td>
874</tr>
875</tbody>
876</table>
877<p>Loads the <a class="reference internal" href="../database/forge.html"><span class="doc">Database Forge</span></a> class, please refer
878to that manual for more info.</p>
879</dd></dl>
880
881<dl class="method">
882<dt id="CI_Loader::dbutil">
883<code class="descname">dbutil</code><span class="sig-paren">(</span><span class="optional">[</span><em>$db = NULL</em><span class="optional">[</span>, <em>$return = FALSE</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::dbutil" title="Permalink to this definition"></a></dt>
884<dd><table class="docutils field-list" frame="void" rules="none">
885<col class="field-name" />
886<col class="field-body" />
887<tbody valign="top">
888<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
889<li><strong>$db</strong> (<em>object</em>) – Database object</li>
890<li><strong>$return</strong> (<em>bool</em>) – Whether to return the Database Utilities instance</li>
891</ul>
892</td>
893</tr>
894<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">Loaded CI_DB_utility instance if $return is set to TRUE, otherwise CI_Loader instance (method chaining)</p>
895</td>
896</tr>
897<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
898</td>
899</tr>
900</tbody>
901</table>
902<p>Loads the <a class="reference internal" href="../database/utilities.html"><span class="doc">Database Utilities</span></a> class, please
903refer to that manual for more info.</p>
904</dd></dl>
905
906<dl class="method">
907<dt id="CI_Loader::helper">
908<code class="descname">helper</code><span class="sig-paren">(</span><em>$helpers</em><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::helper" title="Permalink to this definition"></a></dt>
909<dd><table class="docutils field-list" frame="void" rules="none">
910<col class="field-name" />
911<col class="field-body" />
912<tbody valign="top">
913<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
914<li><strong>$helpers</strong> (<em>mixed</em>) – Helper name as a string or an array containing multiple helpers</li>
915</ul>
916</td>
917</tr>
918<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
919</td>
920</tr>
921<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
922</td>
923</tr>
924</tbody>
925</table>
926<p>This method loads helper files, where file_name is the name of the
927file, without the _helper.php extension.</p>
928</dd></dl>
929
930<dl class="method">
931<dt id="CI_Loader::file">
932<code class="descname">file</code><span class="sig-paren">(</span><em>$path</em><span class="optional">[</span>, <em>$return = FALSE</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::file" title="Permalink to this definition"></a></dt>
933<dd><table class="docutils field-list" frame="void" rules="none">
934<col class="field-name" />
935<col class="field-body" />
936<tbody valign="top">
937<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
938<li><strong>$path</strong> (<em>string</em>) – File path</li>
939<li><strong>$return</strong> (<em>bool</em>) – Whether to return the loaded file</li>
940</ul>
941</td>
942</tr>
943<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">File contents if $return is set to TRUE, otherwise CI_Loader instance (method chaining)</p>
944</td>
945</tr>
946<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
947</td>
948</tr>
949</tbody>
950</table>
951<p>This is a generic file loading method. Supply the filepath and name in
952the first parameter and it will open and read the file. By default the
953data is sent to your browser, just like a View file, but if you set the
954second parameter to boolean TRUE it will instead return the data as a
955string.</p>
956</dd></dl>
957
958<dl class="method">
959<dt id="CI_Loader::language">
960<code class="descname">language</code><span class="sig-paren">(</span><em>$files</em><span class="optional">[</span>, <em>$lang = ''</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::language" title="Permalink to this definition"></a></dt>
961<dd><table class="docutils field-list" frame="void" rules="none">
962<col class="field-name" />
963<col class="field-body" />
964<tbody valign="top">
965<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
966<li><strong>$files</strong> (<em>mixed</em>) – Language file name or an array of multiple language files</li>
967<li><strong>$lang</strong> (<em>string</em>) – Language name</li>
968</ul>
969</td>
970</tr>
971<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
972</td>
973</tr>
974<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
975</td>
976</tr>
977</tbody>
978</table>
979<p>This method is an alias of the <a class="reference internal" href="language.html"><span class="doc">language loading
980method</span></a>: <code class="docutils literal"><span class="pre">$this-&gt;lang-&gt;load()</span></code>.</p>
981</dd></dl>
982
983<dl class="method">
984<dt id="CI_Loader::config">
985<code class="descname">config</code><span class="sig-paren">(</span><em>$file</em><span class="optional">[</span>, <em>$use_sections = FALSE</em><span class="optional">[</span>, <em>$fail_gracefully = FALSE</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::config" title="Permalink to this definition"></a></dt>
986<dd><table class="docutils field-list" frame="void" rules="none">
987<col class="field-name" />
988<col class="field-body" />
989<tbody valign="top">
990<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
991<li><strong>$file</strong> (<em>string</em>) – Configuration file name</li>
992<li><strong>$use_sections</strong> (<em>bool</em>) – Whether configuration values should be loaded into their own section</li>
993<li><strong>$fail_gracefully</strong> (<em>bool</em>) – Whether to just return FALSE in case of failure</li>
994</ul>
995</td>
996</tr>
997<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">TRUE on success, FALSE on failure</p>
998</td>
999</tr>
1000<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">bool</p>
1001</td>
1002</tr>
1003</tbody>
1004</table>
1005<p>This method is an alias of the <a class="reference internal" href="config.html"><span class="doc">config file loading
1006method</span></a>: <code class="docutils literal"><span class="pre">$this-&gt;config-&gt;load()</span></code></p>
1007</dd></dl>
1008
1009<dl class="method">
1010<dt id="CI_Loader::is_loaded">
1011<code class="descname">is_loaded</code><span class="sig-paren">(</span><em>$class</em><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::is_loaded" title="Permalink to this definition"></a></dt>
1012<dd><table class="docutils field-list" frame="void" rules="none">
1013<col class="field-name" />
1014<col class="field-body" />
1015<tbody valign="top">
1016<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
1017<li><strong>$class</strong> (<em>string</em>) – Class name</li>
1018</ul>
1019</td>
1020</tr>
1021<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">Singleton property name if found, FALSE if not</p>
1022</td>
1023</tr>
1024<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">mixed</p>
1025</td>
1026</tr>
1027</tbody>
1028</table>
1029<p>Allows you to check if a class has already been loaded or not.</p>
1030<div class="admonition note">
1031<p class="first admonition-title">Note</p>
1032<p class="last">The word “class” here refers to libraries and drivers.</p>
1033</div>
1034<p>If the requested class has been loaded, the method returns its assigned
1035name in the CI Super-object and FALSE if it’s not:</p>
1036<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;form_validation&#39;</span><span class="p">);</span>
1037<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">is_loaded</span><span class="p">(</span><span class="s1">&#39;Form_validation&#39;</span><span class="p">);</span> <span class="c1">// returns &#39;form_validation&#39;</span>
1038
1039<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">is_loaded</span><span class="p">(</span><span class="s1">&#39;Nonexistent_library&#39;</span><span class="p">);</span> <span class="c1">// returns FALSE</span>
1040</pre></div>
1041</div>
1042<div class="admonition important">
1043<p class="first admonition-title">Important</p>
1044<p class="last">If you have more than one instance of a class (assigned to
1045different properties), then the first one will be returned.</p>
1046</div>
1047<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;form_validation&#39;</span><span class="p">,</span> <span class="nv">$config</span><span class="p">,</span> <span class="s1">&#39;fv&#39;</span><span class="p">);</span>
1048<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;form_validation&#39;</span><span class="p">);</span>
1049
1050<span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">is_loaded</span><span class="p">(</span><span class="s1">&#39;Form_validation&#39;</span><span class="p">);</span> <span class="c1">// returns &#39;fv&#39;</span>
1051</pre></div>
1052</div>
1053</dd></dl>
1054
1055<dl class="method">
1056<dt id="CI_Loader::add_package_path">
1057<code class="descname">add_package_path</code><span class="sig-paren">(</span><em>$path</em><span class="optional">[</span>, <em>$view_cascade = TRUE</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::add_package_path" title="Permalink to this definition"></a></dt>
1058<dd><table class="docutils field-list" frame="void" rules="none">
1059<col class="field-name" />
1060<col class="field-body" />
1061<tbody valign="top">
1062<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
1063<li><strong>$path</strong> (<em>string</em>) – Path to add</li>
1064<li><strong>$view_cascade</strong> (<em>bool</em>) – Whether to use cascading views</li>
1065</ul>
1066</td>
1067</tr>
1068<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
1069</td>
1070</tr>
1071<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
1072</td>
1073</tr>
1074</tbody>
1075</table>
1076<p>Adding a package path instructs the Loader class to prepend a given path
1077for subsequent requests for resources. As an example, the “Foo Bar”
1078application package above has a library named Foo_bar.php. In our
1079controller, we’d do the following:</p>
1080<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">add_package_path</span><span class="p">(</span><span class="nx">APPPATH</span><span class="o">.</span><span class="s1">&#39;third_party/foo_bar/&#39;</span><span class="p">)</span>
1081 <span class="o">-&gt;</span><span class="na">library</span><span class="p">(</span><span class="s1">&#39;foo_bar&#39;</span><span class="p">);</span>
1082</pre></div>
1083</div>
1084</dd></dl>
1085
1086<dl class="method">
1087<dt id="CI_Loader::remove_package_path">
1088<code class="descname">remove_package_path</code><span class="sig-paren">(</span><span class="optional">[</span><em>$path = ''</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::remove_package_path" title="Permalink to this definition"></a></dt>
1089<dd><table class="docutils field-list" frame="void" rules="none">
1090<col class="field-name" />
1091<col class="field-body" />
1092<tbody valign="top">
1093<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
1094<li><strong>$path</strong> (<em>string</em>) – Path to remove</li>
1095</ul>
1096</td>
1097</tr>
1098<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">CI_Loader instance (method chaining)</p>
1099</td>
1100</tr>
1101<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">CI_Loader</p>
1102</td>
1103</tr>
1104</tbody>
1105</table>
1106<p>When your controller is finished using resources from an application
1107package, and particularly if you have other application packages you
1108want to work with, you may wish to remove the package path so the Loader
1109no longer looks in that directory for resources. To remove the last path
1110added, simply call the method with no parameters.</p>
1111<p>Or to remove a specific package path, specify the same path previously
1112given to <code class="docutils literal"><span class="pre">add_package_path()</span></code> for a package.:</p>
1113<div class="highlight-ci"><div class="highlight"><pre><span></span><span class="nv">$this</span><span class="o">-&gt;</span><span class="na">load</span><span class="o">-&gt;</span><span class="na">remove_package_path</span><span class="p">(</span><span class="nx">APPPATH</span><span class="o">.</span><span class="s1">&#39;third_party/foo_bar/&#39;</span><span class="p">);</span>
1114</pre></div>
1115</div>
1116</dd></dl>
1117
1118<dl class="method">
1119<dt id="CI_Loader::get_package_paths">
1120<code class="descname">get_package_paths</code><span class="sig-paren">(</span><span class="optional">[</span><em>$include_base = TRUE</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#CI_Loader::get_package_paths" title="Permalink to this definition"></a></dt>
1121<dd><table class="docutils field-list" frame="void" rules="none">
1122<col class="field-name" />
1123<col class="field-body" />
1124<tbody valign="top">
1125<tr class="field-odd field"><th class="field-name">Parameters:</th><td class="field-body"><ul class="first simple">
1126<li><strong>$include_base</strong> (<em>bool</em>) – Whether to include BASEPATH</li>
1127</ul>
1128</td>
1129</tr>
1130<tr class="field-even field"><th class="field-name">Returns:</th><td class="field-body"><p class="first">An array of package paths</p>
1131</td>
1132</tr>
1133<tr class="field-odd field"><th class="field-name">Return type:</th><td class="field-body"><p class="first last">array</p>
1134</td>
1135</tr>
1136</tbody>
1137</table>
1138<p>Returns all currently available package paths.</p>
1139</dd></dl>
1140
1141</dd></dl>
1142
1143</div>
1144</div>
1145
1146
1147 </div>
1148 <footer>
1149
1150 <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
1151
1152 <a href="migration.html" class="btn btn-neutral float-right" title="Migrations Class">Next <span class="fa fa-arrow-circle-right"></span></a>
1153
1154
1155 <a href="language.html" class="btn btn-neutral" title="Language Class"><span class="fa fa-arrow-circle-left"></span> Previous</a>
1156
1157 </div>
1158
1159
1160 <hr/>
1161
1162 <div role="contentinfo">
1163 <p>
1164 &copy; Copyright 2014 - 2019, British Columbia Institute of Technology.
1165 Last updated on Jan 16, 2019.
1166 </p>
1167 </div>
1168
1169 Built with <a href="http://sphinx-doc.org/">Sphinx</a> using a <a href="https://github.com/snide/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
1170
1171</footer>
1172 </div>
1173 </div>
1174
1175 </section>
1176
1177 </div>
1178
1179
1180
1181
1182
1183 <script type="text/javascript">
1184 var DOCUMENTATION_OPTIONS = {
1185 URL_ROOT:'../',
1186 VERSION:'3.1.10',
1187 COLLAPSE_INDEX:false,
1188 FILE_SUFFIX:'.html',
1189 HAS_SOURCE: false
1190 };
1191 </script>
1192 <script type="text/javascript" src="../_static/jquery.js"></script>
1193 <script type="text/javascript" src="../_static/underscore.js"></script>
1194 <script type="text/javascript" src="../_static/doctools.js"></script>
1195
1196
1197
1198
1199
1200 <script type="text/javascript" src="../_static/js/theme.js"></script>
1201
1202
1203
1204
1205 <script type="text/javascript">
1206 jQuery(function () {
1207 SphinxRtdTheme.StickyNav.enable();
1208 });
1209 </script>
1210
1211
1212</body>
1213</html>