ActiveResourceKit
v1.2 (498.0)
Main Page
Classes
Files
File List
File Members
All
Classes
Files
Functions
Variables
Typedefs
Enumerator
Properties
Macros
Pages
ActiveResourceKit
ARMacros.h
Go to the documentation of this file.
1
// ActiveResourceKit ARMacros.h
2
//
3
// Copyright © 2012, Roy Ratcliffe, Pioneering Software, United Kingdom
4
//
5
// Permission is hereby granted, free of charge, to any person obtaining a copy
6
// of this software and associated documentation files (the “Software”), to deal
7
// in the Software without restriction, including without limitation the rights
8
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
// copies of the Software, and to permit persons to whom the Software is
10
// furnished to do so, subject to the following conditions:
11
//
12
// The above copyright notice and this permission notice shall be included in
13
// all copies or substantial portions of the Software.
14
//
15
// THE SOFTWARE IS PROVIDED “AS IS,” WITHOUT WARRANTY OF ANY KIND, EITHER
16
// EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO
18
// EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
19
// OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21
// DEALINGS IN THE SOFTWARE.
22
//
23
//------------------------------------------------------------------------------
24
25
#import <Foundation/Foundation.h>
26
27
/*!
28
* @param array A standard C array of fixed-sized elements.
29
* @brief Answers the number of elements in the given array, the array's dimension.
30
* @details Assumes that the array argument is a standard C-style array where
31
* the compiler can assess the number of elements by dividing the size of the
32
* entire array by the size of its elements; the answer always equals an integer
33
* since array size is a multiple of element size. Both measurements must be
34
* static, otherwise the compiler cannot supply a fixed integer dimension. The
35
* implementation wraps the argument in parenthesis in order to enforce the
36
* necessary operator precedence.
37
* @note Beware of side effects if you pass operators in the @a array
38
* expression. The macro argument evaluates twice.
39
*/
40
#define ARDimOf(array) (sizeof(array)/sizeof((array)[0]))
Generated by
1.8.2