blob: 2d3270377182af3c845263867f632c1079369e1a [file] [log] [blame]
//:: # Copyright 2013, Big Switch Networks, Inc.
//:: #
//:: # LoxiGen is licensed under the Eclipse Public License, version 1.0 (EPL), with
//:: # the following special exception:
//:: #
//:: # LOXI Exception
//:: #
//:: # As a special exception to the terms of the EPL, you may distribute libraries
//:: # generated by LoxiGen (LoxiGen Libraries) under the terms of your choice, provided
//:: # that copyright and licensing notices generated by LoxiGen are not altered or removed
//:: # from the LoxiGen Libraries and the notice provided below is (i) included in
//:: # the LoxiGen Libraries, if distributed in source code form and (ii) included in any
//:: # documentation for the LoxiGen Libraries, if distributed in binary form.
//:: #
//:: # Notice: "Copyright 2013, Big Switch Networks, Inc. This library was generated by the LoxiGen Compiler."
//:: #
//:: # You may not use this file except in compliance with the EPL or LOXI Exception. You may obtain
//:: # a copy of the EPL at:
//:: #
//:: # http::: #www.eclipse.org/legal/epl-v10.html
//:: #
//:: # Unless required by applicable law or agreed to in writing, software
//:: # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
//:: # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
//:: # EPL for the specific language governing permissions and limitations
//:: # under the EPL.
//::
//:: import itertools
//:: import re
//:: include('_copyright.java')
//:: include('_autogen.java')
package ${factory.package};
import org.projectfloodlight.openflow.protocol.OFOxmList;
//:: include("_imports.java")
public class ${factory.name} implements ${factory.interface.name} {
public final static ${factory.name} INSTANCE = new ${factory.name}();
//:: if factory.interface.xid_generator:
private final XidGenerator xidGenerator = XidGenerators.global();
//:: #endif
//:: for name, clazz in factory.interface.sub_factories.items():
public ${clazz} ${name}() {
return ${clazz}Ver${factory.version.dotless_version}.INSTANCE;
}
//:: #endfor
//:: general_get_match_func_written = False
//:: for i in factory.interface.members:
//:: if i.is_virtual:
//:: continue
//:: #endif
//:: is_match_object = re.match('OFMatch.*', i.name)
//:: unsupported_match_object = is_match_object and not i.has_version(factory.version)
//:: if len(i.writeable_members) > 0:
public ${i.name}.Builder ${factory.interface.method_name(i, builder=True)}() {
//:: if i.has_version(factory.version) and model.generate_class(i.versioned_class(factory.version)):
return new ${i.versioned_class(factory.version).name}.Builder()${".setXid(nextXid())" if i.member_by_name("xid") else ""};
//:: else:
throw new UnsupportedOperationException("${i.name} not supported in version ${factory.version}");
//:: #endif
}
//:: #endif
//:: if not general_get_match_func_written and is_match_object and not unsupported_match_object:
public Match.Builder buildMatch() {
return new ${i.versioned_class(factory.version).name}.Builder();
}
final static Match MATCH_WILDCARD_ALL = ${i.versioned_class(factory.version).name}.DEFAULT;
public Match matchWildcardAll() {
return MATCH_WILDCARD_ALL;
}
//:: general_get_match_func_written = True
//:: #endif
//:: if len(i.writeable_members) <= 2:
public ${i.name} ${factory.interface.method_name(i, builder=False)}(${", ".join("%s %s" % (p.java_type.public_type, p.name) for p in i.writeable_members if p.name != "xid" )}) {
//:: if i.has_version(factory.version) and model.generate_class(i.versioned_class(factory.version)):
//:: if len(i.writeable_members) > 0:
return new ${i.versioned_class(factory.version).name}(
${",\n ".join(
[ prop.name if prop.name != "xid" else "nextXid()" for prop in i.versioned_class(factory.version).data_members])}
);
//:: else:
return ${i.versioned_class(factory.version).name}.INSTANCE;
//:: #endif
//:: else:
throw new UnsupportedOperationException("${i.name} not supported in version ${factory.version}");
//:: #endif
}
//:: #endif
//:: #endfor
public OFMessageReader<${factory.base_class}> getReader() {
//:: if factory.versioned_base_class:
return ${factory.versioned_base_class.name}.READER;
//:: else:
throw new UnsupportedOperationException("Reader<${factory.base_class}> not supported in version ${factory.version}");
//:: #endif
}
//:: if factory.interface.name == "OFFactory":
@Override
public Stat.Builder buildStat() {
return buildStatV6();
}
//:: elif factory.interface.name == 'OFOxms':
@SuppressWarnings("unchecked")
public <F extends OFValueType<F>> OFOxm<F> fromValue(F value, MatchField<F> field) {
switch (field.id) {
//:: for oxm_name in model.oxm_map:
//:: type_name, value, masked = model.oxm_map[oxm_name]
//:: if masked:
//:: continue
//:: #endif
//:: method_name = oxm_name.replace('OFOxm', '')
//:: method_name = method_name[0].lower() + method_name[1:]
case ${value}:
//:: # The cast to Object is done to avoid some javac bug that in some versions cannot handle cast from generic type to other types but Object
return (OFOxm<F>)((Object)${method_name}((${type_name})((Object)value)));
//:: #endfor
default:
throw new IllegalArgumentException("No OXM known for match field " + field);
}
}
@SuppressWarnings("unchecked")
public <F extends OFValueType<F>> OFOxm<F> fromValueAndMask(F value, F mask, MatchField<F> field) {
switch (field.id) {
//:: for oxm_name in model.oxm_map:
//:: type_name, value, masked = model.oxm_map[oxm_name]
//:: if not masked:
//:: continue
//:: #endif
//:: method_name = oxm_name.replace('OFOxm', '')
//:: method_name = method_name[0].lower() + method_name[1:]
case ${value}:
//:: # The cast to Object is done to avoid some javac bug that in some versions cannot handle cast from generic type to other types but Object
return (OFOxm<F>)((Object)${method_name}((${type_name})((Object)value), (${type_name})((Object)mask)));
//:: #endfor
default:
throw new IllegalArgumentException("No OXM known for match field " + field);
}
}
@SuppressWarnings("unchecked")
public <F extends OFValueType<F>> OFOxm<F> fromMasked(Masked<F> masked, MatchField<F> field) {
switch (field.id) {
//:: for oxm_name in model.oxm_map:
//:: type_name, value, masked = model.oxm_map[oxm_name]
//:: if not masked:
//:: continue
//:: #endif
//:: method_name = oxm_name.replace('OFOxm', '')
//:: method_name = method_name[0].lower() + method_name[1:]
case ${value}:
//:: # The cast to Object is done to avoid some javac bug that in some versions cannot handle cast from generic type to other types but Object
return (OFOxm<F>)((Object)${method_name}((${type_name})((Object)(masked.getValue())), (${type_name})((Object)(masked.getMask()))));
//:: #endfor
default:
return null;
}
}
//:: elif factory.interface.name == "OFOxss":
@SuppressWarnings("unchecked")
public <F extends OFValueType<F>> OFOxs<F> fromValue(F value, StatField<F> field) {
switch (field.id) {
//:: for oxs_name in model.oxs_map:
//:: type_name, value, masked = model.oxs_map[oxs_name]
//:: method_name = oxs_name.replace('OFOxs', '')
//:: method_name = method_name[0].lower() + method_name[1:]
case ${value}:
//:: # The cast to Object is done to avoid some javac bug that in some versions cannot handle cast from generic type to other types but Object
return (OFOxs<F>)((Object)${method_name}((${type_name})((Object)value)));
//:: #endfor
default:
throw new IllegalArgumentException("No OXM known for match field " + field);
}
}
//:: #endif
//:: if factory.interface.xid_generator:
public long nextXid() {
return xidGenerator.nextXid();
}
//:: #endif
public OFVersion getVersion() {
return OFVersion.${factory.version.constant_version};
}
}