/* ----> DO NOT REMOVE THE FOLLOWING NOTICE <---- * * Copyright (c) 2014-2015 Datalight, Inc. * All Rights Reserved Worldwide. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; use version 2 of the License. * * This program is distributed in the hope that it will be useful, * but "AS-IS," WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ /* Businesses and individuals that for commercial or other reasons cannot * comply with the terms of the GPLv2 license may obtain a commercial license * before incorporating Reliance Edge into proprietary software for * distribution in any form. Visit http://www.datalight.com/reliance-edge for * more information. */ /** @file * @brief Implements common-code utilities for tools and tests. */ #include #include #include #include #include #include #include #include /** @brief Convert a string into a volume number. * * In a POSIX-like configuration, @p pszVolume can either be a volume number or * a volume path prefix. In case of ambiguity, the volume number of a matching * path prefix takes precedence. * * In an FSE configuration, @p pszVolume can be a volume number. * * @param pszVolume The volume string. * * @return On success, returns the volume number; on failure, returns #REDCONF_VOLUME_COUNT. */ uint8_t RedFindVolumeNumber( const char * pszVolume ) { unsigned long ulNumber; const char * pszEndPtr; uint8_t bVolNum = REDCONF_VOLUME_COUNT; #if REDCONF_API_POSIX == 1 uint8_t bIndex; #endif /* Determine if pszVolume can be interpreted as a volume number. */ errno = 0; ulNumber = strtoul( pszVolume, ( char ** ) &pszEndPtr, 10 ); if( ( errno == 0 ) && ( ulNumber != ULONG_MAX ) && ( pszEndPtr[ 0U ] == '\0' ) && ( ulNumber < REDCONF_VOLUME_COUNT ) ) { bVolNum = ( uint8_t ) ulNumber; } #if REDCONF_API_POSIX == 1 /* Determine if pszVolume is a valid path prefix. */ for( bIndex = 0U; bIndex < REDCONF_VOLUME_COUNT; bIndex++ ) { if( strcmp( gaRedVolConf[ bIndex ].pszPathPrefix, pszVolume ) == 0 ) { break; } } if( bIndex < REDCONF_VOLUME_COUNT ) { /* Edge case: It is technically possible for pszVolume to be both a * valid volume number and a valid volume prefix, for different * volumes. For example, if pszVolume is "2", that would be recognized * as volume number 2 above. But if "2" is the (poorly chosen) path * prefix for volume number 4, that would also be matched. Since the * POSIX-like API is primarily name based, and the ability to use * volume numbers with this tool is just a convenience, the volume * prefix takes precedence. */ bVolNum = bIndex; } #endif /* if REDCONF_API_POSIX == 1 */ return bVolNum; }