alvinalexander.com | career | drupal | java | mac | mysql | perl | scala | uml | unix  

What this is

This file is included in the DevDaily.com "Java Source Code Warehouse" project. The intent of this project is to help you "Learn Java by Example" TM.

Other links

The source code

/**************************************************************************
 *
 *                          Sun Public License Notice
 *
 * The contents of this file are subject to the Sun Public License Version
 * 1.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is available at http://www.sun.com/
 *
 * The Original Code is the HTTP Javadoc Filesystem.
 * The Initial Developer of the Original Code is Jeffrey A. Keyser.
 * Portions created by Jeffrey A. Keyser are Copyright (C) 2000-2002.
 * All Rights Reserved.
 *
 * Contributor(s): Jeffrey A. Keyser.
 *
 **************************************************************************/


package org.netbeans.modules.javadoc.httpfs;

import java.io.*;
import java.net.HttpURLConnection;
import java.util.*;

import org.openide.cookies.InstanceCookie;
import org.openide.filesystems.FileObject;
import org.openide.filesystems.Repository;
import org.openide.loaders.DataObject;
import org.openide.loaders.DataObjectNotFoundException;

/**
 *	

Represents the root file found on the file sysetm.

* * @since 3.4 */ class HTTPRootFileObject extends HTTPFileObject implements Runnable { private static final String IDE_SETTINGS_NAME = "Services/org-netbeans-core-IDESettings.settings"; // NOI18N private Thread refreshThread; private Date lastRefreshDate; private boolean threadIsRunning; private boolean refreshPending; private static boolean proxyInit; /** * Constructs a HTTPRootFileObject with the file system passed. * * @param parentFileSystem The file system that contains this file. * * @since 3.4 */ HTTPRootFileObject( HTTPFileSystem parentFileSystem ) { super( "/", parentFileSystem ); // NOI18N // Start reading the items in the root directory in the background refreshThread = new Thread( this ); threadIsRunning = true; refreshPending = false; refreshThread.start( ); } /** * Constructs an empty HTTPRootFileObject. This constructor is only * expected to be used during deserialization. * * @since 3.4 */ protected HTTPRootFileObject( ) { super( ); } /** * Forces the filesystem to be refreshed. * * @since 3.4 */ void triggerRefresh( ) { refreshPending = true; refreshThread.interrupt( ); } /** * Called to initialize the root file object in the background, and to * run the background refresh thread. * * @since 3.4 */ public void run( ) { // Interfal in minutes to check the web site for a new version int refreshInterval; // The next time the web site is scheduled to be checked Calendar nextRefreshTime; // Flags whether the docs have changed boolean docsHaveChanged; // Start by reading the web site's contents for the first time refreshRootContents( ); refreshThread.setPriority( Thread.MIN_PRIORITY ); while( threadIsRunning ) { docsHaveChanged = false; // If this file system is configured to be refreshed, refreshInterval = parentFileSystem.getRefreshRate( ); if( refreshInterval > 0 ) { // Calculate the next time this file object should try to refresh nextRefreshTime = new GregorianCalendar( ); nextRefreshTime.setTime( lastRefreshDate ); nextRefreshTime.add( Calendar.MINUTE, refreshInterval ); // If the next refresh time has passed, if( nextRefreshTime.before( new GregorianCalendar( ) ) ) { // Check if the documentation has changed docsHaveChanged = hasDocumentationChanged( ); } } // If the JavaDocs need to be refreshed, if( docsHaveChanged || refreshPending ) { // Refresh the contents of this root file object refreshPending = false; refreshRootContents( ); } try { // Test if it's time to check once every minute Thread.sleep( 60 * 1000 ); } catch( InterruptedException e ) { // Ignore } } } /** * Checks if the "package-list" on the web site is newer than the version * in memory. * * @return True if the web site has changed, false if not. * * @since 3.4 */ private boolean hasDocumentationChanged( ) { // File object for /package-list HTTPFileObject packageFile; // Connection to the web server for the package-list file HttpURLConnection fileConnection; // Current date/time of the current file in memory Date currentPackageFileDate; // Flag to return if the we site file has changed boolean hasChanged; // Get the local "package-list" file packageFile = child( "package-list", false ); //NOI18N // If there is a local "package-list" file, if( packageFile != null ) { try { // Compare the date of the local "package-list" file to the one on the web server currentPackageFileDate = packageFile.lastModified( ); fileConnection = (HttpURLConnection)packageFile.fileURL.openConnection( ); fileConnection.setRequestMethod( "HEAD" ); // NOI18N hasChanged = currentPackageFileDate.before( new Date( fileConnection.getLastModified( ) ) ); fileConnection.disconnect( ); } catch( IOException e ) { // There's a problem at the moment - force the refresh thread to not read this site hasChanged = false; } // If there is no local "package-list" file, } else { // Try again hasChanged = true; } return hasChanged; } /** * Reads the base files available at the URL to build the directory tree. * * @since 3.4 */ private void refreshRootContents( ) { initHTTPProxyHack(); // File object for /package-list HTTPFileObject packageFile; // File object for /index-files/ directory HTTPFileObject indexDirectory; // Reader of package names in /package-list BufferedReader packageReader; // Package name read from /package-list String packageName; // File number for the next split index file int indexFileNumber; // Tell the file system that it is being refreshed parentFileSystem.setState( HTTPFileSystem.STATE_READING ); // Remove all existing children from the root file object removeAllChildren( ); // Add the standard files for a Javadoc directory structre if( addOptionalChild( "/package-list" ) ) { //NOI18N packageFile = child( "package-list", false ); //NOI18N addChild( "/allclasses-frame.html" ); //NOI18N addOptionalChild( "/deprecated-list.html" ); //NOI18N addOptionalChild( "/help-doc.html" ); //NOI18N addOptionalChild( "/index.html" ); //NOI18N addChild( "/overview-frame.html" ); //NOI18N addChild( "/overview-summary.html" ); //NOI18N addOptionalChild( "/overview-tree.html" ); //NOI18N addChild( "/packages.html" ); //NOI18N addChild( "/serialized-form.html" ); //NOI18N addChild( "/stylesheet.css" ); //NOI18N // Add the full index file if( !addOptionalChild( "/index-all.html" ) ) { //NOI18N // If there was no full index, search for split index files indexFileNumber = 1; while( addOptionalChild( "/index-" + indexFileNumber + ".html" ) ) { //NOI18N indexFileNumber++; } // If no index were found in the root, if( indexFileNumber == 1 ) { // Look in /index-files/ indexDirectory = new HTTPFileObject( "/index-files/", parentFileSystem ); //NOI18N // Add the full index file if( !indexDirectory.addOptionalChild( "/index-files/index-all.html" ) ) { //NOI18N // If there was no full index, search for split index files indexFileNumber = 1; while( indexDirectory.addOptionalChild( "/index-files/index-" + indexFileNumber + ".html" ) ) { //NOI18N indexFileNumber++; } // If index file were found in this directory, if( indexFileNumber != 1 ) { addChild( indexDirectory ); } // If there was an index file found in this directory, } else { addChild( indexDirectory ); } } } try { // Read all of the package names from the /package-list file packageReader = new BufferedReader( new InputStreamReader( packageFile.getInputStream( ) ) ); packageName = packageReader.readLine( ); while( packageName != null ) { // Add each package to this file system addPackage( packageName ); packageName = packageReader.readLine( ); } packageReader.close( ); } catch( IOException e ) { // Ignore packages } } lastRefreshDate = new Date( ); // Tell the file system that the refresh is done parentFileSystem.setState( HTTPFileSystem.STATE_COMPLETE ); } /** * Adds the named package to this file sytem. * * @param packageName Package name to add to this file system. * * @since 3.4 */ private void addPackage( String packageName ) { // Parser to break up the package heirarchy StringTokenizer packageParser; // One level of this package heirarchy String packagePart; // The diretory that belongs to the selected package HTTPFileObject packageDirectory; // Pull apart the package heirarchy packageParser = new StringTokenizer( packageName, "." ); //NOI18N packageDirectory = this; // With each level of the package, while( packageParser.hasMoreElements( ) ) { packagePart = (String)packageParser.nextElement( ); // Find its directory object if( packageDirectory.child( packagePart, false ) == null ) { packageDirectory.addChild( packageDirectory.uriStem + packagePart + "/" ); //NOI18N } packageDirectory = packageDirectory.child( packagePart, false ); } // flag this directory as containing class files packageDirectory.makePackage( ); } /** * Cleans up this object when it is finalized. * * @throws Throwable * * @since 3.4 */ protected void finalize( ) throws Throwable { super.finalize( ); // Close the refresh thread for this file threadIsRunning = false; refreshThread.interrupt( ); } /** * Note that this is a *hack*, since it depends on some strange name given to the * IDESettings instance by the Core. But otherwise I don't know about a way * how to force the setting to be read. * //!!! */ static void initHTTPProxyHack() { if (proxyInit) return; FileObject f = Repository.getDefault().getDefaultFileSystem().findResource(IDE_SETTINGS_NAME); try { DataObject d = DataObject.find(f); InstanceCookie ic = (InstanceCookie)d.getCookie(InstanceCookie.class); if (ic != null) { Object o = ic.instanceCreate(); // OK, we've initialized. proxyInit = true; } } catch (DataObjectNotFoundException ex) { } catch (IOException ex) { proxyInit = true; } catch (ClassNotFoundException ex) { proxyInit = true; } } }
... this post is sponsored by my books ...

#1 New Release!

FP Best Seller

 

new blog posts

 

Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.

A percentage of advertising revenue from
pages under the /java/jwarehouse URI on this website is
paid back to open source projects.