IsFunction

Not available in this language yet.
IsFunction( value )
IsFunction( value )
IsFunction( value )
is_function( value )
IsFunction( value )

Description

The IsFunction function returns true only if value is a function, otherwise it returns false.

Parameters

Argument Type Definition and Requirements

value

Any

Any value, which is to be tested to determine whether it is a function or not.

Returns

Returns a boolean, indicating whether value was a function or not.

Examples

The following query uses Map to iterate over an array of all of the types of values that can be tested by a type-check function, passing each item into a Lambda function that returns an object, which contains the value and the result of calling IsFunction with that value:

Not available in this language yet.
result, err := client.Query(
	f.Map(
		f.Arr{
			f.Arr{"array"},
			true,
			false,
			f.BytesV{0x01, 0x02, 0x03, 0x04},
			f.Arr{0x1, 0x2, 0x3, 0x4},
			f.Collection("Letters"),
			f.Ref("credentials/self"),
			f.Database("child_db"),
			f.Date("2019-11-12"),
			f.Ref(f.Collection("Letters"), 123),
			10.1,
			f.Function("double"),
			f.Index("letters"),
			10,
			f.Ref(f.Keys(), "1"),
			f.Query(f.Lambda("x", f.Var("x"))),
			nil,
			f.Null(),
			f.Obj{"x": 10},
			f.Role("employees"),
			f.Match(f.Index("letters")),
			"ten",
			"10",
			f.Time("2020-07-06T12:34:56.789Z"),
			f.Ref(f.Tokens(), "1"),
		},
		f.Lambda("x", f.Obj{
			"value": f.Var("x"),
			"IsFunction": f.IsFunction(f.Var("x")),
		})))

if err != nil {
	fmt.Fprintln(os.Stderr, err)
} else {
	fmt.Println(result)
}
[map[IsFunction:false value:[array]] map[IsFunction:false value:true] map[IsFunction:false value:false] map[IsFunction:false value:[1 2 3 4]] map[IsFunction:false value:[1 2 3 4]] map[IsFunction:false value:{Letters 0xc0000b1e30 0xc0000b1e30 <nil>}] map[IsFunction:false value:{280481857410171392 0xc0000b1f50 0xc0000b1f50 <nil>}] map[IsFunction:false value:{child_db 0xc000156090 0xc000156090 <nil>}] map[IsFunction:false value:{0 63709113600 <nil>}] map[IsFunction:false value:{123 0xc0001562a0 0xc0001562a0 <nil>}] map[IsFunction:false value:10.1] map[IsFunction:true value:{double 0xc0001563f0 0xc0001563f0 <nil>}] map[IsFunction:false value:{letters 0xc000156510 0xc000156510 <nil>}] map[IsFunction:false value:10] map[IsFunction:false value:{1 0xc00016e030 0xc00016e030 <nil>}] map[IsFunction:false value:{[123 34 97 112 105 95 118 101 114 115 105 111 110 34 58 34 51 34 44 34 108 97 109 98 100 97 34 58 34 120 34 44 34 101 120 112 114 34 58 123 34 118 97 114 34 58 34 120 34 125 125]}] map[IsFunction:false value:{}] map[IsFunction:false value:{}] map[IsFunction:false value:map[x:10]] map[IsFunction:false value:{employees 0xc00016e240 0xc00016e240 <nil>}] map[IsFunction:false value:{map[match:{letters 0xc00016e390 0xc00016e390 <nil>}]}] map[IsFunction:false value:ten] map[IsFunction:false value:10] map[IsFunction:false value:{789000000 63729635696 <nil>}] map[IsFunction:false value:{1 0xc00016e540 0xc00016e540 <nil>}]]
System.out.println(
    client.query(
        Map(
            Arr(
                Arr(Value("array")),
                Value(true),
                Value(false),
                Value(new byte[] {0x1, 0x2, 0x3, 0x4}),
                Arr(Value(0x1), Value(0x2), Value(0x3), Value(0x4)),
                Collection("Letters"),
                Ref("credentials/self"),
                Database("child_db"),
                Date("2019-11-12"),
                Ref(Collection("Letters"), "123"),
                Value(10.1),
                Function("double"),
                Index("letters"),
                Value(10),
                Ref(Keys(), "1"),
                Query(Lambda("x", Var("x"))),
                Null(),
                Obj("x", Value(10)),
                Role("employees"),
                Match(Index("letters")),
                Value("ten"),
                Value("10"),
                Time("2020-07-06T12:34:56.789Z"),
                Ref(Tokens(), "1")
            ),
            Lambda(
                "x",
                Obj("value", Var("x"), "IsFunction", IsFunction(Var("x")))
            )
        )
    ).get());
[{value: ["array"], IsFunction: false}, {value: true, IsFunction: false}, {value: false, IsFunction: false}, {value: [0x01 0x02 0x03 0x04], IsFunction: false}, {value: [1, 2, 3, 4], IsFunction: false}, {value: ref(id = "Letters", collection = ref(id = "collections")), IsFunction: false}, {value: ref(id = "270607707725103616", collection = ref(id = "credentials")), IsFunction: false}, {value: ref(id = "child_db", collection = ref(id = "databases")), IsFunction: false}, {value: 2019-11-12, IsFunction: false}, {value: ref(id = "123", collection = ref(id = "Letters", collection = ref(id = "collections"))), IsFunction: false}, {value: 10.1, IsFunction: false}, {value: ref(id = "double", collection = ref(id = "functions")), IsFunction: true}, {value: ref(id = "letters", collection = ref(id = "indexes")), IsFunction: false}, {value: 10, IsFunction: false}, {value: ref(id = "1", collection = ref(id = "keys")), IsFunction: false}, {value: QueryV({lambda=x, expr={var=x}}), IsFunction: false}, {value: null, IsFunction: false}, {value: {x: 10}, IsFunction: false}, {value: ref(id = "employees", collection = ref(id = "roles")), IsFunction: false}, {value: {@set = {match: ref(id = "letters", collection = ref(id = "indexes"))}}, IsFunction: false}, {value: "ten", IsFunction: false}, {value: "10", IsFunction: false}, {value: 2020-07-06T12:34:56.789Z, IsFunction: false}, {value: ref(id = "1", collection = ref(id = "tokens")), IsFunction: false}]
client.query(
  q.Map(
    [
      ['array'],
      true,
      false,
      new Uint8Array([1, 2, 3, 4]),
      [0x1, 0x2, 0x3, 0x4],
      q.Collection('Letters'),
      q.Ref('credentials/self'),
      q.Database('child_db'),
      q.Date('2019-11-12'),
      q.Ref(q.Collection('Letters'), 123),
      10.1,
      q.Function('double'),
      q.Index('letters'),
      10,
      q.Ref(q.Keys(), '1'),
      q.Query(q.Lambda('x', q.Var('x'))),
      null,
      { x: 10 },
      q.Role('employees'),
      q.Match(q.Index('letters')),
      'ten',
      '10',
      q.Time('2020-07-06T12:34:56.789Z'),
      q.Ref(q.Tokens(), '1'),
    ],
    q.Lambda('x', {
      value: q.Var('x'),
      IsFunction: q.IsFunction(q.Var('x')),
    })
  )
)
.then((ret) => console.log(ret))
.catch((err) => console.error('Error: %s', err))
[
  { value: [ 'array' ], IsFunction: false },
  { value: true, IsFunction: false },
  { value: false, IsFunction: false },
  { value: Bytes("AQIDBA=="), IsFunction: false },
  { value: [ 1, 2, 3, 4 ], IsFunction: false },
  { value: Collection("Letters"), IsFunction: false },
  {
    value: Ref(Credentials(), "268432426257089024"),
    IsFunction: false
  },
  { value: Database("child_db"), IsFunction: false },
  { value: Date("2019-11-12"), IsFunction: false },
  { value: Ref(Collection("Letters"), "123"), IsFunction: false },
  { value: 10.1, IsFunction: false },
  { value: Function("double"), IsFunction: true },
  { value: Index("letters"), IsFunction: false },
  { value: 10, IsFunction: false },
  { value: Ref(Keys(), "1"), IsFunction: false },
  { value: Query(Lambda("x", Var("x"))), IsFunction: false },
  { value: null, IsFunction: false },
  { value: { x: 10 }, IsFunction: false },
  { value: Role("employees"), IsFunction: false },
  { value: Match(Index("letters")), IsFunction: false },
  { value: 'ten', IsFunction: false },
  { value: '10', IsFunction: false },
  { value: Time("2020-06-15T21:19:21.388Z"), IsFunction: false },
  { value: Ref(Tokens(), "1"), IsFunction: false }
]
result = client.query(
  q.map_(
    q.lambda_("x", {
      "value": q.var("x"),
      "IsFunction": q.is_function(q.var("x")),
    }),
    [
      ["array"],
      True,
      False,
      bytearray([1, 2, 3, 4]),
      [0x1, 0x2, 0x3, 0x4],
      q.collection("Letters"),
      q.ref("credentials/self"),
      q.database("child_db"),
      q.date("2019-11-12"),
      q.ref(q.collection("Letters"), 123),
      10.1,
      q.function("double"),
      q.index("letters"),
      10,
      q.ref(q.keys(), "1"),
      q.query(q.lambda_("x", q.var("x"))),
      None,
      {"x": 10},
      q.role("employees"),
      q.match(q.index("letters")),
      "ten",
      "10",
      q.time("2020-07-06T12:34:56.789Z"),
      q.ref(q.tokens(), "1"),
    ],
  )
)
print(result)
[{'value': ['array'], 'IsFunction': False}, {'value': True, 'IsFunction': False}, {'value': False, 'IsFunction': False}, {'value': bytearray(b'\x01\x02\x03\x04'), 'IsFunction': False}, {'value': [1, 2, 3, 4], 'IsFunction': False}, {'value': Ref(id=Letters, collection=Ref(id=collections)), 'IsFunction': False}, {'value': Ref(id=282032258185953792, collection=Ref(id=credentials)), 'IsFunction': False}, {'value': Ref(id=child_db, collection=Ref(id=databases)), 'IsFunction': False}, {'value': datetime.date(2019, 11, 12), 'IsFunction': False}, {'value': Ref(id=123, collection=Ref(id=Letters, collection=Ref(id=collections))), 'IsFunction': False}, {'value': 10.1, 'IsFunction': False}, {'value': Ref(id=double, collection=Ref(id=functions)), 'IsFunction': True}, {'value': Ref(id=letters, collection=Ref(id=indexes)), 'IsFunction': False}, {'value': 10, 'IsFunction': False}, {'value': Ref(id=1, collection=Ref(id=keys)), 'IsFunction': False}, {'value': Query({'api_version': '3', 'lambda': 'x', 'expr': {'var': 'x'}}), 'IsFunction': False}, {'value': None, 'IsFunction': False}, {'value': {'x': 10}, 'IsFunction': False}, {'value': Ref(id=employees, collection=Ref(id=roles)), 'IsFunction': False}, {'value': SetRef({'match': Ref(id=letters, collection=Ref(id=indexes))}), 'IsFunction': False}, {'value': 'ten', 'IsFunction': False}, {'value': '10', 'IsFunction': False}, {'value': FaunaTime('2020-07-06T12:34:56.789Z'), 'IsFunction': False}, {'value': Ref(id=1, collection=Ref(id=tokens)), 'IsFunction': False}]
println(Await.result(
  client.query(
    Map(
      Arr(
        Arr("array"),
        true,
        false,
        BytesV(0x1, 0x2, 0x3, 0x4),
        Arr(0x1, 0x2, 0x3, 0x4),
        Collection("Letters"),
        Ref("credentials/self"),
        Database("child_db"),
        Date("2019-11-12"),
        Ref(Collection("Letters"), 123),
        10.1,
        Function("double"),
        Index("letters"),
        10,
        Ref(Keys(), "1"),
        Query(Lambda("x", Var("x"))),
        Null,
        Obj("x" -> 10),
        Role("employees"),
        Match(Index("letters")),
        "ten",
        "10",
        Time("2020-07-06T12:34:56.789Z"),
        Ref(Tokens(), "1")
      ),
      Lambda(
        "x",
        Obj( "value" -> Var("x"), "IsFunction" -> IsFunction(Var("x")))
      )
    )
  ),
  5.seconds
))
[{value: ["array"], IsFunction: false}, {value: true, IsFunction: false}, {value: false, IsFunction: false}, {value: [0x01 0x02 0x03 0x04], IsFunction: false}, {value: [1, 2, 3, 4], IsFunction: false}, {value: ref(id = "Letters", collection = ref(id = "collections")), IsFunction: false}, {value: ref(id = "270972905842541056", collection = ref(id = "credentials")), IsFunction: false}, {value: ref(id = "child_db", collection = ref(id = "databases")), IsFunction: false}, {value: 2019-11-12, IsFunction: false}, {value: ref(id = "123", collection = ref(id = "Letters", collection = ref(id = "collections"))), IsFunction: false}, {value: 10.1, IsFunction: false}, {value: ref(id = "double", collection = ref(id = "functions")), IsFunction: true}, {value: ref(id = "letters", collection = ref(id = "indexes")), IsFunction: false}, {value: 10, IsFunction: false}, {value: ref(id = "1", collection = ref(id = "keys")), IsFunction: false}, {value: {api_version: "3", lambda: "x", expr: {var: "x"}}, IsFunction: false}, {value: NullV, IsFunction: false}, {value: {x: 10}, IsFunction: false}, {value: ref(id = "employees", collection = ref(id = "roles")), IsFunction: false}, {value: {@set = {match: ref(id = "letters", collection = ref(id = "indexes"))}}, IsFunction: false}, {value: "ten", IsFunction: false}, {value: "10", IsFunction: false}, {value: 2020-07-06T12:34:56.789Z, IsFunction: false}, {value: ref(id = "1", collection = ref(id = "tokens")), IsFunction: false}]

This query operates on a pre-existing schema, which is not provided here.

Also, the query is executed via a client connection, that uses a secret acquired by calling Login (not shown here), so that Ref("credentials/self") returns a valid value.

Was this article helpful?

We're sorry to hear that.
Tell us how we can improve!
Visit Fauna's Discourse forums or email docs@fauna.com

Thank you for your feedback!