Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

73 lines
2.2 KiB

  1. GENERATE SELF-EXTRACTING EXECUTABLE
  2. -----------------------------------
  3. This documents describes the files necessary for performing the generation
  4. of the self-extracting-executable. The main entry-point is GenerateCAB(),
  5. which in turn manipulates INF and CDF objects,
  6. gencab - CAB control module.
  7. geninf - INF object methods.
  8. gencdf - CDF object methods.
  9. files:
  10. -----
  11. gencab.cxx, gencab.h - Cab generation control.
  12. gencdf.cxx, gencdf.h - Cdf object for IExpress file.
  13. geninf.cxx, geninf.h - Inf object for Setup file.
  14. gendbg.cxx, gendbg.h - Internel debug logging.
  15. genmem.cxx, genmem.h - Memory routines, tracks corruption.
  16. genglobl.cxx, genglobl.h - Global variables used in gen routines
  17. genpch.h - Common header includes gen*.h
  18. This design has seperated responsibilities of the various components into
  19. object-type modules. For example, anything which has to do with an INF-file
  20. is handled in the (geninf.c/geninf.h) modules. Likewise, the CDF routines
  21. use an INF interface to obtain information concerning the INF. Previous
  22. implementations of which this code was derived, utilized a monolithic approach
  23. where the CDF, INF and CAB routines had integral knowledge of each others
  24. functionality.
  25. We diverged from this approach to a more object-oriented design which we
  26. believe is more maintainable and somewhat self-documenting.
  27. Structure/Flow:
  28. cab:
  29. if (Create INF Object) {
  30. if (Create CDF Object) {
  31. query CDF, INF objects for pertinent information.
  32. if (CDF newer than CAB) {
  33. Execute IExpress to generate new cab.
  34. } else {
  35. utilize cached cabname.
  36. }
  37. Free CDF Object.
  38. }
  39. Free INF Object.
  40. }
  41. return cabname.
  42. Issues:
  43. -------
  44. 1) How do we determine op-sys versioning and archetecture? We need this
  45. to determine where to pull our INF driver-files. This should be passed
  46. in at GenerateCAB() time.
  47. 2) Generating an INF (to be or not to be)...although not huge, this could
  48. change our implementating of caching of the CDF/CAB files. Currently,
  49. we will generate a layout-file (sort of).