ebook img

Apparatus, Method and System for Building Software by Composition PDF

44 Pages·2014·2.88 MB·English
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Apparatus, Method and System for Building Software by Composition

US 20140040856A1 (19) United States (12) Patent Application Publication (10) Pub. No.: US 2014/0040856 A1 Miloushev et al. (43) Pub. Date: Feb. 6, 2014 (54) APPARATUS, METHOD AND SYSTEM FOR (60) Provisional application No. 60/717,387, ?led on Sep. BUILDING SOFTWARE BY COMPOSITION 15, 2005. (71) ApplicantszVladimir I. Miloushev, Aliso Viejo, CA Publication Classi?cation (US); Peter Nickolov, San Clemente, CA (US); Leonid Kalev, Haifa (IL) (51) Int. Cl. G06F 9/44 (2006.01) (72) Inventors: Vladimir I. Miloushev, Aliso Viejo, CA (52) US. Cl. (US); Peter Nickolov, San Clemente, CPC .................................... .. G06F 8/315 (2013.01) CA (US); Leonid Kalev, Haifa (IL) USPC ........................................................ .. 717/108 (21) App1.No.: 13/913,822 (57) ABSTRACT (22) Filed: Jun. 10, 2013 A method and system are disclosed for building complex real-time software that scales Well to a large number of pro Related US. Application Data cessors or CPU cores. The softWare design and implementa (63) Continuation of application No. 11/992,093, ?led on tion method are based on a combination of object composi Mar. 13, 2008, noW Pat. No. 8,464,214, ?led as appli tion (hierarchical assembly) and desynchroniZable inter cation No. PCT/US2006/036131 on Sep. 15, 2006. object interactions. Patent Application Publication Feb. 6, 2014 Sheet 2 0f 21 US 2014/0040856 A1 .gll % (I N/ 3 3 /w 3 h F “I § 93/ o E’ '1 51 “g! 1k 2 . 3 E9 /§| I E0l % $2- m w - -' " ‘.2 II 2 1 =3 '- I- a s1 —= 23 ‘a’ a‘ a a ‘a .iéé f“ /= E /= a SW5 a a .D/ :s / E 3 4| ‘_ \ .5 E5 \ Patent Application Publication Feb. 6, 2014 Sheet 3 0f 21 US 2014/0040856 A1 170 17 as _ 164 ~ “'”'* N ---> __ / a -*-> $1.8 _---.y ' STJNVALID '_-> FIG. 1C Patent Application Publication Feb. 6, 2014 Sheet 4 0f 21 US 2014/0040856 A1 attribute: / /#v self self-optimist,” / / #v prop prop-optimist,” / / #v term term-optionsul” self-options: constructor = (rd-diff destructor = cd-def constructor = (Td-dé’f, destructor = cd-def cd-de? identifier‘ NULL prop-options: prop-option. prop-option, prop-options prop-option.‘ prop-type prop-001i ? g Prop-?ag prop-type: one of string const_ptr scalar binary prop-?ag: one of mandat ory ro s igned Prop-ma?a‘ dflt = identi?er dflt = integer-(.‘onstimt min = integer-constant max = integer-constant name = identifier term-options.‘ floating im = identifier floating, im = identi?er Syntactic categories (nonterminals) are indicated by italic type, and literal Words (terminals) by bold type. A colon (z) following a nonterminal introduces its de?nition. Alternative de?nitions are listed on separate lines, or on a single line, When the definition is prefaced by the Words “one of.“ An optional symbol is indicated by the subscript “opt”. The identi?er and integer-constant non-terminals Will not be de?ned here — they are assumed to be as de?ned in the ISO/[EC standard [or the C language. FIG. 2A Patent Application Publication Feb. 6, 2014 Sheet 5 0f 21 US 2014/0040856 A1 struct SELF //#v self ( // properties in_addr__t bind__ip; ll‘v Prop scalar in_port__t bind_port: lliv prop scalar, dflt=10000 uint n_listens: //#v prop dflt==5 // terminals VTRM ctl; VTRM sac; VTRM fac: im-nop VTRM PIP; im-nop // state int lsh; 'listen' socket handle struct sockaddr_in 1a; local addr struct scckaddr__in re, remote add: pLtIhSrTe ad__mutex_t sessions; l/ list of open sessions ses__lck; // aynch lock for the sessions list pLtIhSrTe ad_mutex_t scav; // list of dead sessions scav_lck, l/ synch lock for the scavenger list H I SYS ct‘ I_SSC TOP sockets |_FAC fac SES FIG. 2B Patent Application Publication Feb. 6, 2014 Sheet 6 0f 21 US 2014/0040856 A1 g 30 N Start = Read Application Descriptor ] 4 V ?r 304 v \ Pick the next part from the PARTS list, ?nd the corresponding source file Yes 31K 0 Feed it to the Boundary Extractor 31x 32\ V PU Compile output from the Boundary Feed it to the descriptor language pre E Z‘ Extractor processor m a of 314 32 \ ‘ v compile the Pan Compile output form the pre-processor Merge compiled part code and boundary descriptor last part? No v 33' Yes A 2\ l 2 Create application init descriptor, compile it With the L compiler 3 U '5 3 mU G v Merge all into executable image (link, if building an application); or into a relocatable library (if building a part lib.) output plr)od:u c FIG. 3A Patent Application Publication Feb. 6, 2014 Sheet 7 0f 21 US 2014/0040856 A1 352\ L = list of parts With no part descriptor 35 NC = O P : ?rst entry in L V All subordinates of P have part descriptors? No 35 8\ Yis Create part descr. for P, remove entry from list L 360\ P is the last entry in list L? 364 NO P = next entry from list L 36 l Yes No End: error, circular reference FIG. 3B Patent Application Publication Feb. 6, 2014 Sheet 9 0f 21 US 2014/0040856 A1 /5OB /502 /508 Subordinate Class Names : "‘ "3W1 Subord. Instance Names ‘ nama1 /.512 Propar?gg 1 > name sub~§dx {gt-name 14 Terminais H‘w ‘ name sub'idx {gt-name /516 Interior cmneatinns = ‘ sbi-idx name1 sbZ-idx name-2 uu /518 Parameteriza?un (Int!) ' sub-Idx name value FIG: 5

Description:
constructor = (Td-dé'f, destructor = cd-def .. heroin and the phr? RQ__FAC__DEACTIVATB - deactivate an instance (call destructor code without
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.