blob: 7d6b6770eda0b58415f71cb0970aa16f969064e2 [file] [log] [blame]
Andrey Andreevd1530022012-03-13 12:31:13 +02001<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreevd1530022012-03-13 12:31:13 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreevd1530022012-03-13 12:31:13 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
Greg Aker0defe5d2012-01-01 18:46:41 -060021 * @copyright Copyright (c) 2008 - 2012, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
27
Derek Allard2067d1a2008-11-13 22:59:24 +000028/**
29 * CodeIgniter Directory Helpers
30 *
31 * @package CodeIgniter
32 * @subpackage Helpers
33 * @category Helpers
Derek Jonesf4a4bd82011-10-20 12:18:42 -050034 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000035 * @link http://codeigniter.com/user_guide/helpers/directory_helper.html
36 */
37
38// ------------------------------------------------------------------------
39
Derek Allard2067d1a2008-11-13 22:59:24 +000040if ( ! function_exists('directory_map'))
41{
Timothy Warren01b129a2012-04-27 11:36:50 -040042 /**
43 * Create a Directory Map
44 *
45 * Reads the specified directory and builds an array
46 * representation of it. Sub-folders contained with the
47 * directory will be mapped as well.
48 *
49 * @param string path to source
50 * @param int depth of directories to traverse (0 = fully recursive, 1 = current dir, etc)
51 * @param bool whether to show hidden files
52 * @return array
53 */
Pascal Kriete98a447a2010-01-07 18:14:28 +000054 function directory_map($source_dir, $directory_depth = 0, $hidden = FALSE)
55 {
Derek Allard2067d1a2008-11-13 22:59:24 +000056 if ($fp = @opendir($source_dir))
57 {
Pascal Kriete98a447a2010-01-07 18:14:28 +000058 $filedata = array();
59 $new_depth = $directory_depth - 1;
Barry Mienydd671972010-10-04 16:33:58 +020060 $source_dir = rtrim($source_dir, DIRECTORY_SEPARATOR).DIRECTORY_SEPARATOR;
61
Derek Allard2067d1a2008-11-13 22:59:24 +000062 while (FALSE !== ($file = readdir($fp)))
63 {
Pascal Kriete98a447a2010-01-07 18:14:28 +000064 // Remove '.', '..', and hidden files [optional]
vlakoff82808852012-09-13 05:19:59 +020065 if ($file === '.' OR $file === '..' OR ($hidden === FALSE && $file[0] === '.'))
Derek Allard2067d1a2008-11-13 22:59:24 +000066 {
67 continue;
68 }
Pascal Kriete98a447a2010-01-07 18:14:28 +000069
70 if (($directory_depth < 1 OR $new_depth > 0) && @is_dir($source_dir.$file))
Derek Allard2067d1a2008-11-13 22:59:24 +000071 {
Pascal Kriete98a447a2010-01-07 18:14:28 +000072 $filedata[$file] = directory_map($source_dir.$file.DIRECTORY_SEPARATOR, $new_depth, $hidden);
Derek Allard2067d1a2008-11-13 22:59:24 +000073 }
74 else
75 {
76 $filedata[] = $file;
77 }
78 }
Barry Mienydd671972010-10-04 16:33:58 +020079
Derek Allard2067d1a2008-11-13 22:59:24 +000080 closedir($fp);
81 return $filedata;
82 }
Pascal Kriete98a447a2010-01-07 18:14:28 +000083
84 return FALSE;
Derek Allard2067d1a2008-11-13 22:59:24 +000085 }
86}
87
Derek Allard2067d1a2008-11-13 22:59:24 +000088/* End of file directory_helper.php */
Andrey Andreeve92df332012-03-26 22:44:20 +030089/* Location: ./system/helpers/directory_helper.php */