| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- /*
- * Copyright 2024, gRPC Authors All rights reserved.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * 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 License for the specific language governing permissions and
- * limitations under the License.
- */
- /// A description of a service.
- public struct ServiceDescriptor: Sendable, Hashable {
- /// The name of the package the service belongs to. For example, "helloworld".
- /// An empty string means that the service does not belong to any package.
- public var package: String
- /// The name of the service. For example, "Greeter".
- public var service: String
- /// The fully qualified service name in the format:
- /// - "package.service": if a package name is specified. For example, "helloworld.Greeter".
- /// - "service": if a package name is not specified. For example, "Greeter".
- public var fullyQualifiedService: String {
- if self.package.isEmpty {
- return self.service
- }
- return "\(self.package).\(self.service)"
- }
- /// - Parameters:
- /// - package: The name of the package the service belongs to. For example, "helloworld".
- /// An empty string means that the service does not belong to any package.
- /// - service: The name of the service. For example, "Greeter".
- public init(package: String, service: String) {
- self.package = package
- self.service = service
- }
- }
|