001/* 002 * Copyright (c) 2012-2021 Institut National des Sciences Appliquées de Lyon (INSA Lyon) and others 003 * 004 * This program and the accompanying materials are made available under the 005 * terms of the Eclipse Public License 2.0 which is available at 006 * http://www.eclipse.org/legal/epl-2.0. 007 * 008 * SPDX-License-Identifier: EPL-2.0 009 */ 010 011package gololang.ir; 012 013/** 014 * A literal reference to a function. 015 * 016 * <p>Used to represent a literal function reference notation, such as 017 * {@code ^my.package::foo} 018 */ 019public final class FunctionRef { 020 021 private final String module; 022 private final String name; 023 private final int arity; 024 private final boolean varargs; 025 026 private FunctionRef(String module, String name, int arity, boolean varargs) { 027 this.module = module; 028 this.name = name; 029 this.arity = arity; 030 this.varargs = varargs; 031 } 032 033 public static FunctionRef of(String module, String name, int arity, boolean varargs) { 034 return new FunctionRef(module, name, arity, varargs); 035 } 036 037 public String module() { return this.module; } 038 public String name() { return this.name; } 039 public int arity() { return this.arity; } 040 public boolean varargs() { return this.varargs; } 041 042 @Override 043 public String toString() { 044 return String.format("FunctionRef{module=%s,name=%s,arity=%s%s}", 045 module, name, arity, (varargs ? ",varargs" : "")); 046 } 047}