# nonEnumerablePropertyNamesIn
> Return an array of an object's own and inherited non-enumerable property names.
## Usage
```javascript
var nonEnumerablePropertyNamesIn = require( '@stdlib/utils/nonenumerable-property-names-in' );
```
#### nonEnumerablePropertyNamesIn( obj )
Returns an `array` of an object's own and inherited non-enumerable property names.
```javascript
var defineProperty = require( '@stdlib/utils/define-property' );
var obj = {
'a': 'b'
};
defineProperty( obj, 'c', {
'configurable': false,
'enumerable': false,
'writable': true,
'value': 'd'
});
var keys = nonEnumerablePropertyNamesIn( obj );
// e.g., returns [ 'c', ... ]
```
## Notes
- Name order is not guaranteed, as `object` key enumeration is not specified according to the [ECMAScript specification][ecma-262-for-in]. In practice, however, most engines use insertion order to sort an `object`'s keys, thus allowing for deterministic extraction.
## Examples
```javascript
var defineProperty = require( '@stdlib/utils/define-property' );
var nonEnumerablePropertyNamesIn = require( '@stdlib/utils/nonenumerable-property-names-in' );
function Foo() {
this.beep = 'boop';
this.a = {
'b': 'c'
};
defineProperty( this, 'baz', {
'configurable': true,
'enumerable': false,
'writable': true,
'value': 'qux'
});
return this;
}
Foo.prototype.foo = [ 'bar' ];
defineProperty( Foo.prototype, 'bip', {
'configurable': false,
'enumerable': false,
'writable': false,
'value': 'bop'
});
var obj = new Foo();
var keys = nonEnumerablePropertyNamesIn( obj );
console.log( keys );
// e.g., => [ 'baz', 'bip', ... ]
```
[ecma-262-for-in]: http://www.ecma-international.org/ecma-262/5.1/#sec-12.6.4