174 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			174 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			C++
		
	
	
	
//===-- lib/Parser/tools.cpp ----------------------------------------------===//
 | 
						|
//
 | 
						|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
 | 
						|
// See https://llvm.org/LICENSE.txt for license information.
 | 
						|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
 | 
						|
//
 | 
						|
//===----------------------------------------------------------------------===//
 | 
						|
 | 
						|
#include "flang/Parser/tools.h"
 | 
						|
 | 
						|
namespace Fortran::parser {
 | 
						|
 | 
						|
const Name &GetLastName(const Name &x) { return x; }
 | 
						|
 | 
						|
const Name &GetLastName(const StructureComponent &x) {
 | 
						|
  return GetLastName(x.component);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const DataRef &x) {
 | 
						|
  return std::visit(
 | 
						|
      common::visitors{
 | 
						|
          [](const Name &name) -> const Name & { return name; },
 | 
						|
          [](const common::Indirection<StructureComponent> &sc)
 | 
						|
              -> const Name & { return GetLastName(sc.value()); },
 | 
						|
          [](const common::Indirection<ArrayElement> &sc) -> const Name & {
 | 
						|
            return GetLastName(sc.value().base);
 | 
						|
          },
 | 
						|
          [](const common::Indirection<CoindexedNamedObject> &ci)
 | 
						|
              -> const Name & { return GetLastName(ci.value().base); },
 | 
						|
      },
 | 
						|
      x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const Substring &x) {
 | 
						|
  return GetLastName(std::get<DataRef>(x.t));
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const Designator &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &y) -> const Name & { return GetLastName(y); }, x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const ProcComponentRef &x) {
 | 
						|
  return GetLastName(x.v.thing);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const ProcedureDesignator &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &y) -> const Name & { return GetLastName(y); }, x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const Call &x) {
 | 
						|
  return GetLastName(std::get<ProcedureDesignator>(x.t));
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const FunctionReference &x) { return GetLastName(x.v); }
 | 
						|
 | 
						|
const Name &GetLastName(const Variable &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &indirection) -> const Name & {
 | 
						|
        return GetLastName(indirection.value());
 | 
						|
      },
 | 
						|
      x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetLastName(const AllocateObject &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &y) -> const Name & { return GetLastName(y); }, x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const Name &x) { return x; }
 | 
						|
 | 
						|
const Name &GetFirstName(const StructureComponent &x) {
 | 
						|
  return GetFirstName(x.base);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const DataRef &x) {
 | 
						|
  return std::visit(
 | 
						|
      common::visitors{
 | 
						|
          [](const Name &name) -> const Name & { return name; },
 | 
						|
          [](const common::Indirection<StructureComponent> &sc)
 | 
						|
              -> const Name & { return GetFirstName(sc.value()); },
 | 
						|
          [](const common::Indirection<ArrayElement> &sc) -> const Name & {
 | 
						|
            return GetFirstName(sc.value().base);
 | 
						|
          },
 | 
						|
          [](const common::Indirection<CoindexedNamedObject> &ci)
 | 
						|
              -> const Name & { return GetFirstName(ci.value().base); },
 | 
						|
      },
 | 
						|
      x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const Substring &x) {
 | 
						|
  return GetFirstName(std::get<DataRef>(x.t));
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const Designator &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &y) -> const Name & { return GetFirstName(y); }, x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const ProcComponentRef &x) {
 | 
						|
  return GetFirstName(x.v.thing);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const ProcedureDesignator &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &y) -> const Name & { return GetFirstName(y); }, x.u);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const Call &x) {
 | 
						|
  return GetFirstName(std::get<ProcedureDesignator>(x.t));
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const FunctionReference &x) {
 | 
						|
  return GetFirstName(x.v);
 | 
						|
}
 | 
						|
 | 
						|
const Name &GetFirstName(const Variable &x) {
 | 
						|
  return std::visit(
 | 
						|
      [](const auto &indirect) -> const Name & {
 | 
						|
        return GetFirstName(indirect.value());
 | 
						|
      },
 | 
						|
      x.u);
 | 
						|
}
 | 
						|
 | 
						|
const CoindexedNamedObject *GetCoindexedNamedObject(const DataRef &base) {
 | 
						|
  return std::visit(
 | 
						|
      common::visitors{
 | 
						|
          [](const Name &) -> const CoindexedNamedObject * { return nullptr; },
 | 
						|
          [](const common::Indirection<CoindexedNamedObject> &x)
 | 
						|
              -> const CoindexedNamedObject * { return &x.value(); },
 | 
						|
          [](const auto &x) -> const CoindexedNamedObject * {
 | 
						|
            return GetCoindexedNamedObject(x.value().base);
 | 
						|
          },
 | 
						|
      },
 | 
						|
      base.u);
 | 
						|
}
 | 
						|
const CoindexedNamedObject *GetCoindexedNamedObject(
 | 
						|
    const Designator &designator) {
 | 
						|
  return std::visit(common::visitors{
 | 
						|
                        [](const DataRef &x) -> const CoindexedNamedObject * {
 | 
						|
                          return GetCoindexedNamedObject(x);
 | 
						|
                        },
 | 
						|
                        [](const Substring &x) -> const CoindexedNamedObject * {
 | 
						|
                          return GetCoindexedNamedObject(
 | 
						|
                              std::get<DataRef>(x.t));
 | 
						|
                        },
 | 
						|
                    },
 | 
						|
      designator.u);
 | 
						|
}
 | 
						|
const CoindexedNamedObject *GetCoindexedNamedObject(const Variable &variable) {
 | 
						|
  return std::visit(
 | 
						|
      common::visitors{
 | 
						|
          [](const common::Indirection<Designator> &designator)
 | 
						|
              -> const CoindexedNamedObject * {
 | 
						|
            return GetCoindexedNamedObject(designator.value());
 | 
						|
          },
 | 
						|
          [](const auto &) -> const CoindexedNamedObject * { return nullptr; },
 | 
						|
      },
 | 
						|
      variable.u);
 | 
						|
}
 | 
						|
const CoindexedNamedObject *GetCoindexedNamedObject(
 | 
						|
    const AllocateObject &allocateObject) {
 | 
						|
  return std::visit(
 | 
						|
      common::visitors{
 | 
						|
          [](const StructureComponent &x) -> const CoindexedNamedObject * {
 | 
						|
            return GetCoindexedNamedObject(x.base);
 | 
						|
          },
 | 
						|
          [](const auto &) -> const CoindexedNamedObject * { return nullptr; },
 | 
						|
      },
 | 
						|
      allocateObject.u);
 | 
						|
}
 | 
						|
} // namespace Fortran::parser
 |