(file) Return to todo.txt CVS log (file) (dir) Up to [Pegasus] / pegasus / doc / Attic

Diff for /pegasus/doc/Attic/todo.txt between version 1.14 and 1.31.2.2

version 1.14, 2001/06/11 17:39:34 version 1.31.2.2, 2001/08/02 19:15:23
Line 1 
Line 1 
 Urgent  
 ======  
  
     -   Add CIMOM handle to provider interface.      -   Get rid of usage of System (use since it
  
     -   Fix case sensitivity problems in repository (just add an _Open method      -   Migrate to use of Linkage.h files.
         that ignores the case of the file).  
  
     -   Add newly implemented repository operations to protocol and to      -   Document that lex and yacc are no longer a requirement to build
         dispatcher.          Pegasus.
  
     -   Change INVALID_CLASS exceptions to NOT_FOUND (they're wrong in      -   Figure out how to handle very large CIM respones and possibly
         Repository).          requests too.
  
     -   Add tracing of output HTTP messages.      -   Integrate client/server tests into make system somehow.
  
     -   Need CIMInstance::removeMethod() and CIMInstance::removeProperty().      -   Note that it is possible to remove an class and still have association
     -   Add a exists namespace operation under the repository stuff.  Maybe we          classes which refer to it.
     need more than this.  
  
 Topical To-Do List      -   Class inheritance not taken into consideration when resolving the
 ==================          AssocClass
  
     -   Provide way of printing out command line options help from cimserver.      -   It seems that associatios() will fail when AssocClass is a super
           class of the class which is in the association instance table.
  
     -   GetInstances() and GetClasses() need to use iterators on      -   Should there be a single associations table for the entire repository
         provider and repository end. Otherwise, all classes or instance          or should there be one per namespace as there is now?
         to be enumerated, must be sucked into memory.  
  
     -   Template bloat reduction.      -   If it is the case that a reference may only refer to an instance,
           then we must derive new types for representing object paths.
  
     -   Use YACC on Linux.      -   Many CIM operations interfaces are incorrect: GetInstance() for example
           takes a namespace and a CIMReference (which also may contain the
           namespace). According to the standard, it should take an "InstanceName".
  
     -   Need a tool to say which features are supported by a compiler.      -   Need way of signaling the cimserver so that it will reload the
           class inheritance table (after a MOF compile).
  
     -   Support unloading of dynamic libraries (presently only load() is      -   Revisit use of namespace v.s. objectName in all CIM operations.
         supported).  
  
 -   Instances:      -   What do we do when getInstance() is called and the nameSpace is
           provided both as an argument and as part of the instance name?
  
     -   Implement CIMRepository::getProperty()      -   ReferenceNames should return classes not just instances?
  
     -   Implement CIMRepository::setProperty()      -   Remove final const from const methods in non-const CIM element classes.
  
     -   Implement CIMRepository::deleteInstance()      -   Null vs. empty CIM/HTTP parameters.
  
     -   Implement CIMRepository::modifyInstance()      -   Resolve constness problems. (get rid or Const classes?)
  
     -   Implement CIMRepository::enumerateInstances()      -   Change CIMReference to CIMObjectPath?
  
     -   Implement CIMRepository::enumerateInstanceNames()      -   Finish associations.
  
     -   Handle inheritance in all instance operations.      -   Provide CIMOM Context.
  
     -   Double check that all these operations work across protocol.      -   Complete conventions document.
  
     -   Check that they have keys during validation.      -   The CIMServer.exe program should probably create the logs directory
           under PEGASUS_HOME.
  
 -   Associations:      -   Clean up exceptions.
  
     -   Implement CIMRepository::referencesOf()      -   Resolve redundancy in which the namespace is passed to certain methods
           (getClass) and the CIMReference itself may contain a namespace arguent.
  
     -   Implement CIMRepository::associatorsOf()      -   Implement consistency and constraint checking on classes and instances.
  
     -   Implement protocol stubs for these operations.      -   Implement filtering (using includeQualifiers, localOnly, etc.)
  
 -   Exceptions:      -   Consider eliminating const CIM element classes.
  
     -   Force __FILE__ and __LINE__ argument on every usage of CIMException.      -   Support for NULL property lists (in interface and protocol).
  
     -   Clean up and consolidate exception classes.      -   Rename tests (prepend "Test" to each test).
  
     -   Propagate underlying error messages across the CIM protocol.      -   Fix bug with cimserver.exe causing it to fail to start without te
           "-l" option.
  
 -   References:      -   Resolve whether the backslash should be permitted in namespaces.
  
     -   Validate arguments to CIMReference compound constructor and modifiers.      -   Create CIMOMContext (interface to CIMOM used b the provider).
         (namespaces, hosts, classnames, and keybindings)  
  
     -   Be sure that escape sequences are handled inside of object names. For      -   Define Encoding module interface.
         example:  
   
             X.key1="Hello \"You\""  
  
 -   Protocol:      -   Develop XMLEncodings module.
  
     -   Improve protocol tracing to show messages in both directions.      -   Develop BinaryEncodings module.
  
     -   The TCPChannel::writeN() method blocks when the client and server      -   Develop MOFEncodings module.
         are in the same process. That is because the client cannot read  
         anything as long as writeN() is blocked on a synchronous write.  
  
     -   Figure out how to handle getProperty() return type.      -   Employ BinaryEncodings module in repository (reduce disk usage).
  
     -   Provide ACE Channel implementation (for porting purposes)?      -   Combine repository instances, classes, and qualifiers  into their
           respective files (to reduce the number of files).
  
     -   Handle PARAMETER.REFARRAY in Procotol?      -   Employ an efficient indexing scheme in repository (B-trees or hashing).
  
     -   Ignore extraneous XML elements (loosely valid).      -   Develop module manager: interface, lookup scheme, and loading scheme.
  
 -   Porting:      -   Package Encodings classes as a module.
  
     -   Replace "std::something" with "STD(something)"      -   Finalize repository assocations.
  
     -   Replace "using namespace std" with "USING_NAMESPACE_PEGASUS"      -   Add association CIM/HTTP operations.
  
 -   Aesthetics/Consistency/Usability:      -   Design association provider infrastructure.
   
     -   Change getLength() and getSize() to just size(): "Brevity is the soul  
         of genius and of Lingerie".  
   
     -   Add methods to get objects by their names, in addition to index. For  
         example:  
  
             CIMProperty CIMClass::getProperty(const String& name);      -   Implement missing CIM protocol operations.
  
     -   Perform walkthrough to expose consistency problems.      -   Implement good observer module interface which allows different levels:
  
     -   Distinguish between private and public classes (otherwise, users may          -   Observation of client/CIMMOM connections/disconnection.
         come to depend on classes with unstable interfaces).  
  
 -   Documentation:          -   Observation of client/CIMOM communication.
  
     -   Suggest newlines after methods.          -   Observation of CIMOM/repository communication.
  
     -   Suggest use of "/** ... */" instead of "///"          -   Observation of CIMOM/provider communication.
  
     -   Refine header file documentation.          -   Observation of CIMOM state transitions.
  
     -   Write Pegasus Architecture Paper.      -   Pegasus providers for Sun WBEM Services.
  
     -   Integrate DOC++ with make system (put all docs in doc tree):      -   Pegasus providers for WMI.
  
 -   Namespaces:      -   Sun WBEM Services providers for Pegasus.
  
     -   Implement create and destroy namespace (according to the standard).      -   CIM/HTTP Proxy for WMI.
  
 -   Providers      -   Web Server/Pegasus Integration (use HTTP protocol capabilities of
           web server rather than Pegasus).
  
     -   Add CIM-Server handles to provider interface.      -   Add CIMRepository::namespaceExists() method.
  
     -   Implement MOF provider registration scheme (according to the      -   Change HTTP message id's to this format: "YYYY.MM.DD.HH.MM.SS.NNNNN".
     standard).  
  
 -   WBEM Query Language      -   GetInstances() and GetClasses() need to use iterators on
           provider and repository end. Otherwise, all classes or instance
           to be enumerated, must be sucked into memory.
  
     -   Find someone to work on standard.      -   Template bloat reduction.
  
     -   Implement leve-1 parser.      -   Need a tool to say which features are supported by a compiler.
  
 -   MOF compiler:      -   Support unloading of dynamic libraries (presently only load() is
           supported).
  
     -   Work with Bob to identify work items.      -   Clean up and consolidate exception classes.
  
 -   Threading      -   Asynchronous socket writes in the CIMOM (need write enabled flags).
  
     -   Write thread queuing document (input and output thread queue per      -   Handle PARAMETER.REFARRAY in Procotol?
         provider).  
  
     -   Implement queuing.      -   Implemented stream oriented XML parsing.
  
     -   Make reference counted objects thread safe (Mutexing and atomic      -   Ignore extraneous XML elements (implement "loose validation" concept).
         increments).  
  
 -   Connectors      -   Add methods to get objects by their names, in addition to index. For
           example:
  
     -   Work out basic concepts (write paper).              CIMProperty CIMClass::getProperty(const String& name);
  
     -   Package up pegasus in Install Shield application.      -   Distinguish between private and public classes (otherwise, users may
           come to depend on classes with unstable interfaces).
  
       -   Walk through all code to expose consistency/aesthetic issues.
  
 -   Install      -   Provide ACE Channel implementation (for porting purposes)?
  
     -   Need install mechanism for Unix and Windows.      -   Expand datatime (setCurrentTime() and comparison and increment
           functions).
  
 -   Interoperability      -   Write Pegasus Architecture Paper.
  
     -   Fix reported bugs.      -   Implement MOF provider registration scheme (according to the
           standard).
  
 -   Internationalization      -   WBEM Query Language and integration.
  
     -   Handle UCS2 characters in XML (parsing and writing).      -   Threading
  
 -   Repository:      -   Package up pegasus in Install Shield application.
  
     -   Export to MOF.      -   Internationalization: Handle UCS2 characters in XML
           (parsing and writing).
  
 -   Miscellaneous      -   Export of repository to MOF.
  
     -   Change CompareNoCase() to String::compareNoCase().     -   Change CompareNoCase() to String::compareNoCase().
  
     -   Place configuration startup parameters in Repository (e.g., port).      -   Figure out how to handle CIM NULL values.
   
     -   Integrate logging  
   
     -   Figure out how to handle CIM null values.  
   
     -   Generalize iteration.  
  
     -   Figure out how inheritance of keys works.     -   Figure out how inheritance of keys works.
  
     -   Investiage weak assocations.      -   Investigage weak associations.
   
     -   Provide conversions between DateTime and time_t.  
   
 -   Constraint hanlding  
  
     -   Enforce constraint qualifiers.     -   Enforce constraint qualifiers.
  
     -   Disallow resetting size of fixed length arrays.     -   Disallow resetting size of fixed length arrays.
  
 -   Optimization/Tuning  
   
     -   Shrink object sizes.     -   Shrink object sizes.
  
     -   Use lighter I/O system (than C++ streams).     -   Use lighter I/O system (than C++ streams).
Line 219 
Line 205 
  
     -   Optimize clear method on arrays (to not release memory).     -   Optimize clear method on arrays (to not release memory).
  
 -   Porting      -   Provide conversions between DateTime and time_t.
  
     -   Port to Solaris     -   Port to Solaris
  
     -   Port to HPUX      -   Support multiple providers of the extact same class.
           DiskController example and LanController.
     -   Port to AIX  
   
 -   Testing  
   
     -   Test case insensitivity of class names and qualifier names.  
   
     -   Run Purify on all sources (port to Sun first).  
   
     -   Run CIM/XML test suite.  
   
 -   Server  
   
     -   Use Service class in cimserver  
  
     -   Implement Service class on Unix (daemonization from Comer book).      -   SLP - Eliminate lib directory.
  


Legend:
Removed from v.1.14  
changed lines
  Added in v.1.31.2.2

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2