All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.lucene.queryparser.flexible.messages.package-info Maven / Gradle / Ivy

There is a newer version: 10.0.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.
 */
 
/** 
 * For Native Language Support (NLS), system of software internationalization.
 * 
 * 

NLS message API

*

* This utility API, adds support for NLS messages in the apache code. * It is currently used by the lucene "New Flexible Query PArser". *

* Features: *

    *
  1. Message reference in the code, using static Strings
  2. *
  3. Message resource validation at class load time, for easier debugging
  4. *
  5. Allows for message IDs to be re-factored using eclipse or other code re-factor tools
  6. *
  7. Allows for reference count on messages, just like code
  8. *
  9. Lazy loading of Message Strings
  10. *
  11. Normal loading Message Strings
  12. *
* *
*
*

* Lazy loading of Message Strings * *

 *   public class MessagesTestBundle extends NLS {
 *   
 *     private static final String BUNDLE_NAME = MessagesTestBundle.class.getName();
 *   
 *     private MessagesTestBundle() {
 *       // should never be instantiated
 *     }
 *   
 *     static {
 *       // register all string ids with NLS class and initialize static string
 *       // values
 *       NLS.initializeMessages(BUNDLE_NAME, MessagesTestBundle.class);
 *     }
 *   
 *     // static string must match the strings in the property files.
 *     public static String Q0001E_INVALID_SYNTAX;
 *     public static String Q0004E_INVALID_SYNTAX_ESCAPE_UNICODE_TRUNCATION;
 *   
 *     // this message is missing from the properties file
 *     public static String Q0005E_MESSAGE_NOT_IN_BUNDLE;
 *   }
 * 
 *     // Create a message reference
 *     Message invalidSyntax = new MessageImpl(MessagesTestBundle.Q0001E_INVALID_SYNTAX, "XXX");
 *     
 *     // Do other stuff in the code...
 *     // when is time to display the message to the user or log the message on a file
 *     // the message is loaded from the correct bundle
 *     
 *     String message1 = invalidSyntax.getLocalizedMessage();
 *     String message2 = invalidSyntax.getLocalizedMessage(Locale.JAPANESE);
 * 
* *
*
*

* Normal loading of Message Strings * *

 *   String message1 = NLS.getLocalizedMessage(MessagesTestBundle.Q0004E_INVALID_SYNTAX_ESCAPE_UNICODE_TRUNCATION);
 *   String message2 = NLS.getLocalizedMessage(MessagesTestBundle.Q0004E_INVALID_SYNTAX_ESCAPE_UNICODE_TRUNCATION, Locale.JAPANESE);
 * 
* *

* The org.apache.lucene.messages.TestNLS junit contains several other examples. * The TestNLS java code is available from the Apache Lucene code repository. */ package org.apache.lucene.queryparser.flexible.messages;





© 2015 - 2024 Weber Informatics LLC | Privacy Policy