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

org.seasar.framework.message.MessageResourceBundleFacade Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2004-2015 the Seasar Foundation and the Others.
 *
 * 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.
 */
package org.seasar.framework.message;

import java.io.BufferedInputStream;
import java.io.File;
import java.io.InputStream;
import java.net.URL;
import java.util.Properties;

import org.seasar.framework.util.AssertionUtil;
import org.seasar.framework.util.FileInputStreamUtil;
import org.seasar.framework.util.InputStreamUtil;
import org.seasar.framework.util.PropertiesUtil;
import org.seasar.framework.util.URLUtil;

/**
 * {@link MessageResourceBundle}をキャッシュするクラスです。
 * 
 * @author shot
 * @author higa
 */
public class MessageResourceBundleFacade {

    private File file;

    private long lastModified;

    private MessageResourceBundle bundle;

    private MessageResourceBundleFacade parent;

    /**
     * {@link MessageResourceBundleFacade}を作成します。
     * 
     * @param url url
     */
    public MessageResourceBundleFacade(URL url) {
        setup(url);
    }

    /**
     * {@link MessageResourceBundle}を返します。
     * 
     * @return {@link MessageResourceBundle}
     */
    public synchronized MessageResourceBundle getBundle() {
        if (isModified()) {
            bundle = createBundle(file);
        }
        if (parent != null) {
            bundle.setParent(parent.getBundle());
        }
        return bundle;
    }

    /**
     * 親を返します。
     * 
     * @return 親
     */
    public synchronized MessageResourceBundleFacade getParent() {
        return parent;
    }

    /**
     * 親を設定します。
     * 
     * @param parent parent
     */
    public synchronized void setParent(MessageResourceBundleFacade parent) {
        this.parent = parent;
    }

    /**
     * 更新されているかどうかを返します。
     * 
     * @return 更新されているかどうか
     */
    protected boolean isModified() {
        if (file != null && file.lastModified() > lastModified) {
            return true;
        }
        return false;
    }

    /**
     * セットアップをします。
     * 
     * @param url
     *            URL
     */
    protected void setup(URL url) {
        AssertionUtil.assertNotNull("url", url);
//i        if (HotdeployUtil.isHotdeploy()) {
//i            file = ResourceUtil.getFile(url);
//i        }
        if (file != null) {
            lastModified = file.lastModified();
            bundle = createBundle(file);
        } else {
            bundle = createBundle(url);
        }
        if (parent != null) {
            bundle.setParent(parent.getBundle());
        }
    }

    /**
     * メッセージリソースバンドルを作成します。
     * 
     * @param file
     *            ファイル
     * @return メッセージリソースバンドル
     */
    protected static MessageResourceBundle createBundle(File file) {
        return new MessageResourceBundleImpl(createProperties(file));
    }

    /**
     * メッセージリソースバンドルを作成します。
     * 
     * @param url
     *            URL
     * @return メッセージリソースバンドル
     */
    protected static MessageResourceBundle createBundle(URL url) {
        return new MessageResourceBundleImpl(createProperties(url));
    }

    /**
     * {@link Properties}を作成します。
     * 
     * @param file
     *            ファイル
     * @return {@link Properties}
     */
    protected static Properties createProperties(File file) {
        return createProperties(FileInputStreamUtil.create(file));
    }

    /**
     * {@link Properties}を作成します。
     * 
     * @param url
     *            URL
     * @return {@link Properties}
     */
    protected static Properties createProperties(URL url) {
        return createProperties(URLUtil.openStream(url));
    }

    /**
     * {@link Properties}を作成します。
     * 
     * @param is
     *            入力ストリーム
     * @return {@link Properties}
     */
    protected static Properties createProperties(InputStream is) {
        AssertionUtil.assertNotNull("is", is);
        if (!(is instanceof BufferedInputStream)) {
            is = new BufferedInputStream(is);
        }
        try {
            Properties properties = new Properties();
            PropertiesUtil.load(properties, is);
            return properties;
        } finally {
            InputStreamUtil.close(is);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy