Modula-3

Modula-3
Paradigmsimperative, structured, procedural, modular, concurrent, object-oriented, generic
FamilyWirth/Modula
Designed byLuca Cardelli, James Donahue, Lucille Glassman, Mick Jordan; Bill Kalsow, Greg Nelson
DevelopersDEC
Olivetti
elego Software Solutions GmbH
First appeared1988; 37 years ago (1988)
Stable release
5.8.6 / July 14, 2010; 14 years ago (2010-07-14)
Preview release
5.8.6 / July 14, 2010; 14 years ago (2010-07-14)
Typing disciplinestrong, static, safe or if unsafe explicitly safe isolated
ScopeLexical
PlatformIA-32, x86-64, PowerPC, SPARC
OSCross-platform: FreeBSD, Linux, Darwin, SunOS
Websitewww.modula3.org
Major implementations
SRC Modula-3, CM3,[1] PM3,[2] EZM3,[3] M3/PC Klagenfurt[4]
Influenced by
ALGOL, Euclid, Mesa, Modula-2, Modula-2+, Oberon, Pascal
Influenced
C#, Java, Nim,[5] OCaml, Rust,[6] Python[7]

Modula-3 is a programming language conceived as a successor to an upgraded version of Modula-2 known as Modula-2+. It has been influential in research circles (influencing the designs of languages such as Java, C#, Python[8] and Nim), but it has not been adopted widely in industry. It was designed by Luca Cardelli, James Donahue, Lucille Glassman, Mick Jordan (before at the Olivetti Software Technology Laboratory), Bill Kalsow and Greg Nelson at the Digital Equipment Corporation (DEC) Systems Research Center (SRC) and the Olivetti Research Center (ORC) in the late 1980s.

Modula-3's main features are modularity, simplicity and safety while preserving the power of a systems-programming language. Modula-3 aimed to continue the Pascal tradition of type safety, while introducing new constructs for practical real-world programming. In particular Modula-3 added support for generic programming (similar to templates), multithreading, exception handling, garbage collection, object-oriented programming, partial revelation, and explicit marking of unsafe code. The design goal of Modula-3 was a language that implements the most important features of modern imperative programming languages in quite basic forms. Thus allegedly dangerous and complicating features such as multiple inheritance and operator overloading were omitted.

Historical development

The Modula-3 project started in November 1986 when Maurice Wilkes wrote to Niklaus Wirth with some ideas for a new version of Modula. Wilkes had been working at DEC just prior to this point, and had returned to England and joined Olivetti's Research Strategy Board. Wirth had already moved on to Oberon, but had no problems with Wilkes's team continuing development under the Modula name. The language definition was completed in August 1988, and an updated version in January 1989. Compilers from DEC and Olivetti soon followed, and 3rd party implementations after that.

Its design was heavily influenced by work on the Modula-2+ language in use at SRC and at the Acorn Computers Research Center (ARC, later ORC when Olivetti acquired Acorn) at the time, which was the language in which the operating system for the DEC Firefly multiprocessor VAX workstation was written and in which the Acorn Compiler for Acorn C and Modula Execution Library (CAMEL) at ARC for the ARX operating system project of ARM based Acorn Archimedes range of computers was written. As the revised Modula-3 Report states, the language was influenced by other languages such as Mesa, Cedar, Object Pascal, Oberon and Euclid.[9]

During the 1990s, Modula-3 gained considerable currency as a teaching language, but it was never widely adopted for industrial use. Contributing to this may have been the demise of DEC, a key Modula-3 supporter (especially when it ceased to maintain it effectively before DEC was sold to Compaq in 1998). In any case, in spite of Modula-3's simplicity and power, it appears that there was little demand for a procedural compiled language with restricted implementation of object-oriented programming. For a time, a commercial compiler named CM3 maintained by one of the chief implementors prior at DEC SRC who was hired before DEC being sold to Compaq, an integrated development environment (IDE) named Reactor and an extensible Java virtual machine (licensed in binary code and source code formats and buildable with Reactor) were offered by Critical Mass, Inc., but that company ceased active operations in 2000 and gave some of the source code of its products to elego Software Solutions GmbH. Modula-3 is now taught in universities mostly in comparative programming language courses, and its textbooks are out of print. Essentially the only corporate supporter of Modula-3 is elego, which inherited the sources from Critical Mass and has since made several releases of the CM3 system in source and binary code. The Reactor IDE has been open source released after several years it had not, with the new name CM3-IDE. In March 2002, elego also took over the repository of another active Modula-3 distribution, PM3, until then maintained at the École Polytechnique de Montréal but which later continued by the work on HM3 improved over the years later until it was obsoleted.

Syntax

A common example of a language's syntax is the "Hello, World!" program.

MODULE Main; 
IMPORT IO;
BEGIN
  IO.Put("Hello World\n")
END Main.

All programs in Modula-3 have at least a module file, while most also include an interface file that is used by clients to access data from the module. As in some other languages, a Modula-3 program must export a Main module, which can either be a file named Main.m3, or a file can call EXPORT to export the Main module.

MODULE Foo EXPORTS Main

Module file names are advised to be the same as the name in source code. If they differ, the compiler only emits a warning.

Other conventions in the syntax include naming the exported type of an interface T, since types are usually qualified by their full names, so a type T inside a module named Foo will be named Foo.T. This aids in readability. Another similar convention is naming a public object Public as in the OOP examples below.

Language features

Modularity

First and foremost, all compiled units are either INTERFACE or implementation MODULEs, of one flavor or another. An interface compiled unit, starting with the keyword INTERFACE, defines constants, types, variables, exceptions, and procedures. The implementation module, starting with the keyword MODULE, provides the code, and any further constants, types, or variables needed to implement the interface. By default, an implementation module will implement the interface of the same name, but a module may explicitly EXPORT to a module not of the same name. For example, the main program exports an implementation module for the Main interface.

MODULE HelloWorld EXPORTS Main; 
IMPORT IO;
BEGIN
  IO.Put("Hello World\n")
END HelloWorld.

Any compiled unit may IMPORT other interfaces, although circular imports are forbidden. This may be resolved by doing the import from the implementation MODULE. The entities within the imported module may be imported, instead of only the module name, using the FROM Module IMPORT Item [, Item]* syntax:

MODULE HelloWorld EXPORTS Main; 
FROM IO IMPORT Put;
BEGIN
  Put("Hello World\n")
END HelloWorld.

Typically, one only imports the interface, and uses the 'dot' notation to access the items within the interface (similar to accessing the fields within a record). A typical use is to define one data structure (record or object) per interface along with any support procedures. Here the main type will get the name 'T', and one uses as in MyModule.T.

In the event of a name collision between an imported module and other entity within the module, the reserved word AS can be used as in IMPORT CollidingModule AS X;

Safe vs unsafe

Some ability is deemed unsafe, where the compiler can no longer guarantee that results will be consistent; for example, when interfacing to the C language. The keyword UNSAFE prefixed in front of INTERFACE or MODULE, may be used to tell the compiler to enable certain low level features of the language. For example, an unsafe operation is bypassing the type system using LOOPHOLE to copy the bits of an integer into a floating point REAL number.

An interface that imports an unsafe module must also be unsafe. A safe interface may be exported by an unsafe implementation module. This is the typical use when interfacing to external libraries, where two interfaces are built: one unsafe, the other safe.

Generics

A generic interface and its corresponding generic module, prefix the INTERFACE or MODULE keyword with GENERIC, and take as formal arguments other interfaces. Thus (like C++ templates) one can easily define and use abstract data types, but unlike C++, the granularity is at the module level. An interface is passed to the generic interface and implementation modules as arguments, and the compiler will generate concrete modules.

For example, one could define a GenericStack, then instantiate it with interfaces such as IntegerElem, or RealElem, or even interfaces to Objects, as long as each of those interfaces defines the properties needed by the generic modules.

The bare types INTEGER, or REAL can't be used, because they are not modules, and the system of generics is based on using modules as arguments. By comparison, in a C++ template, a bare type would be used.

FILE: IntegerElem.i3

INTERFACE IntegerElem;
CONST Name = "Integer";
TYPE T = INTEGER;
PROCEDURE Format(x: T): TEXT;
PROCEDURE Scan(txt: TEXT; VAR x: T): BOOLEAN;
END IntegerElem.

FILE: GenericStack.ig

GENERIC INTERFACE GenericStack(Element);
(* Here Element.T is the type to be stored in the generic stack. *)
TYPE
   T = Public OBJECT;
   Public = OBJECT
   METHODS
       init(): TStack;
       format(): TEXT;
       isEmpty(): BOOLEAN;
       count(): INTEGER;
       push(elm: Element.T);
       pop(VAR elem: Element.T): BOOLEAN;
   END;
END GenericStack.

FILE: GenericStack.mg

GENERIC MODULE GenericStack(Element);
< ... generic implementation details... >
PROCEDURE Format(self: T): TEXT =
VAR
   str: TEXT;
BEGIN
   str := Element.Name & "Stack{";
   FOR k := 0 TO self.n -1 DO
       IF k > 0 THEN str := str & ", "; END;
       str := str & Element.Format(self.arr[k]);
   END;
   str := str & "};";
   RETURN str;
END Format;
< ... more generic implementation details... >
END GenericStack.

FILE: IntegerStack.i3

INTERFACE IntegerStack = GenericStack(IntegerElem) END IntegerStack.

FILE: IntegerStack.m3

MODULE IntegerStack = GenericStack(IntegerElem) END IntegerStack.

Traceability

Any identifier can be traced back to where it originated, unlike the 'include' feature of other languages. A compiled unit must import identifiers from other compiled units, using an IMPORT statement. Even enumerations make use of the same 'dot' notation as used when accessing a field of a record.

INTERFACE A;

TYPE Color = {Black, Brown, Red, Orange, Yellow, Green, Blue, Violet, Gray, White};

END A;
MODULE B;

IMPORT A;
FROM A IMPORT Color;

VAR
  aColor: A.Color;  (* Uses the module name as a prefix *)
  theColor: Color;  (* Does not have the module name as a prefix *)
  anotherColor: A.Color;

BEGIN
  aColor := A.Color.Brown;
  theColor := Color.Red;
  anotherColor := Color.Orange;  (* Can't simply use Orange *)
END B.

Dynamic allocation

Modula-3 supports the allocation of data at runtime. There are two kinds of memory that can be allocated, TRACED and UNTRACED, the difference being whether the garbage collector can see it or not. NEW() is used to allocate data of either of these classes of memory. In an UNSAFE module, DISPOSE is available to free untraced memory.

Object-oriented

Object-oriented programming techniques may be used in Modula-3, but their use is not a requirement. Many of the other features provided in Modula-3 (modules, generics) can usually take the place of object-orientation.

Object support is intentionally kept to its simplest terms. An object type (termed a "class" in other object-oriented languages) is introduced with the OBJECT declaration, which has essentially the same syntax as a RECORD declaration, although an object type is a reference type, whereas RECORDs in Modula-3 are not (similar to structs in C). Exported types are usually named T by convention, and create a separate "Public" type to expose the methods and data. For example:

INTERFACE Person;

TYPE T <: Public;
  Public = OBJECT 
  METHODS
    getAge(): INTEGER;
    init(name: TEXT; age: INTEGER): T;
  END;

END Person.

This defines an interface Person with two types, T, and Public, which is defined as an object with two methods, getAge() and init(). T is defined as a subtype of Public by the use of the <: operator.

To create a new Person.T object, use the built in procedure NEW with the method init() as

VAR jim := NEW(Person.T).init("Jim", 25);

Revelation

Modula-3's REVEAL construct provides a conceptually simple and clean yet very powerful mechanism for hiding implementation details from clients, with arbitrarily many levels of friendliness. A full revelation of the form REVEAL T = V can be used to show the full implementation of the Person interface from above. A partial revelation of the form REVEAL T <: V merely reveals that T is a supertype of V without revealing any additional information on T.[10]

MODULE Person;

REVEAL T = Public BRANDED 
OBJECT 
  name: TEXT;   (* These two variables *)
  age: INTEGER; (* are private. *)
OVERRIDES
  getAge := Age;
  init := Init;
END;

PROCEDURE Age(self: T): INTEGER =
  BEGIN
    RETURN self.age;
  END Age;

PROCEDURE Init(self: T; name: TEXT; age: INTEGER): T =
  BEGIN
    self.name := name;
    self.age := age;
  RETURN self;
  END Init;

BEGIN
END Person.

Note the use of the BRANDED keyword, which "brands" objects to make them unique as to avoid structural equivalence. BRANDED can also take a string as an argument, but when omitted, a unique string is generated for you.

Modula-3 is one of a few programming languages which requires external references from a module to be strictly qualified. That is, a reference in module A to the object x exported from module B must take the form B.x. In Modula-3, it is impossible to import all exported names from a module.

Because of the language's requirements on name qualification and method overriding, it is impossible to break a working program simply by adding new declarations to an interface (any interface). This makes it possible for large programs to be edited concurrently by many programmers with no worries about naming conflicts; and it also makes it possible to edit core language libraries with the firm knowledge that no extant program will be broken in the process.

Exceptions

Exception handling is based on a TRY...EXCEPT block system, which has since[citation needed] become common. One feature that has not been adopted in other languages[citation needed], with the notable exceptions of Delphi, Python[1], Scala[2] and Visual Basic.NET, is that the EXCEPT construct defined a form of switch statement with each possible exception as a case in its own EXCEPT clause. Modula-3 also supports a LOOP...EXIT...END construct that loops until an EXIT occurs, a structure equivalent to a simple loop inside a TRY...EXCEPT clause.

Multi-threaded

The language supports the use of multi-threading, and synchronization between threads. There is a standard module within the runtime library (m3core) named Thread, which supports the use of multi-threaded applications. The Modula-3 runtime may make use of a separate thread for internal tasks such as garbage collection.

A built-in data structure MUTEX is used to synchronize multiple threads and protect data structures from simultaneous access with possible corruption or race conditions. The LOCK statement introduces a block in which the mutex is locked. Unlocking a MUTEX is implicit by the code execution locus's leaving the block. The MUTEX is an object, and as such, other objects may be derived from it.

For example, in the input/output (I/O) section of the library libm3, readers and writers (Rd.T, and Wr.T) are derived from MUTEX, and they lock themselves before accessing or modifying any internal data such as buffers.

Summary

In summary, the language features:

In Systems Programming with Modula-3, four essential points of the language design are intensively discussed. These topics are: structural vs. name equivalence, subtyping rules, generic modules, and parameter modes like READONLY.

Standard library features

Continuing a trend started with the C language, many of the features needed to write real programs were left out of the language definition and instead provided via a standard library set. Most of the interfaces below are described in detail in[11]

Standard libraries providing the following features. These are called standard interfaces and are required (must be provided) in the language.

  • Text: Operations on immutable string references, called TEXTs
  • Thread: Operations relating to threading, including MUTEX, condition variable, and thread pausing. The threading library provides pre-emptive threads switching
  • Word: Bitwise operations on unsigned integers (or machine words). Normally implemented directly by the compiler
  • Floating-point interfaces

Some recommended interfaces implemented in the available implementations but are not required

  • Lex: For parsing number and other data
  • Fmt: Formatting various datatypes for printing
  • Pkl (or Pickle): Object serialization of any reference types reachable by the garbage collector
  • Table: Generic modules for maps

As in C, I/O is also provided via libraries, in Modula-3 called Rd and Wr. The object-oriented design of the Rd (readers) and Wr (writers) libraries is covered in detail in the book by Greg Nelson. An interesting aspect of Modula-3 is that it is one of few programming languages which standard libraries have been formally verified not to contain various types of bugs, including locking bugs. This was done under the auspices of the Larch/Modula-3 (see Larch family)[12] and Extended static checking[13] projects at DEC Systems Research Center.

Implementations

Several compilers are available, most of them open source.

  • DEC-SRC M3, the original.[14]
  • Olivetti Research Center (ORC) Modula-3 toolkit, originally a compiler, now available as a library for syntactic, lexical and semantic analysis of Modula-3 programs.[15]
  • Critical Mass CM3, a different successor of DEC-SRC M3
  • Polytechnique Montreal Modula-3 PM3, a successor of DEC-SRC M3, currently merging with CM3
  • EzM3, an independent lightweight and easily portable implementation, developed in connection with CVSup
  • HM3, a successor of the pm3-1.1.15 release of PM3, with support of native threading using NPTL
  • CM3, the successor to Critical Mass CM3. This is the only up to date, maintained and developed implementation. Releases are available from http://www.opencm3.net/releng/.

Since the only aspect of C data structures that is missing from Modula-3 is the union type, all extant Modula-3 implementations are able to provide good binary code compatibility with C language type declarations of arrays and structs.

Books

None of these books are still in print, although used copies are obtainable and some are digitized, partly or fully, and some chapters of one them have prior or posterior versions obtainable as research reports from the web.

  • Greg Nelson, ed., Systems Programming with Modula-3 The definitive reference on the Modula-3 language with interesting articles on object-oriented systems software construction and a documentation of the discussion leading to the final features of the language. There are some formerly (see[9] for Chapter two,[16] for chapter four,[17] for chapter five,[18] for chapter six) and some posteriorly (see[19] for Chapter one and more updated two, thus of both prior versions of language definition[9] and,[11] for chapter three and[20] for chapter seven) of publishing versions of the majority of its eight chapters individually available from prior DEC Systems Research Center (SRC) as research reports for download.
  • Samuel P. Harbison, Modula-3 Easy to use class textbook.
  • Robert Sedgewick, Algorithms in Modula-3
  • Laszlo Boszormenyi & Carsten Weich, Programming in Modula-3: An Introduction in Programming with Style
  • Renzo Orsini, Agostino Cortesi Programmare in Modula-3: introduzione alla programmazione imperativa e a oggetti an Italian book of the language explaining its main features.

Projects using Modula-3

Software which is programmed with Modula-3 includes:

  • The SPIN operating system
  • The CVSup software repository synchronizing program
  • The Obliq language, which uses Modula-3 network objects ability to migrate objects over local networks transparently, allowing a distributed ability to Modula-3 object-oriented programming paradigm. It has been used to build distributed applications, computer animations, and web programming applications in the form of scripting extension to Modula-3.

Influences on other programming languages

Although Modula-3 did not gain mainstream status, several parts of the DEC-SRC M3 distribution did. Probably the most influential part was the Network Objects library, which formed the basis for Java's first Remote Method Invocation (RMI) implementation, including the network protocol. Only when Sun moved from the Common Object Request Broker Architecture (CORBA) standard to the IIOP based protocol was it dropped. The Java documentation on garbage collection of remote objects still refer to the pioneering work done for Modula-3 Network Objects.[21] Python's implementation of classes was also inspired by the class mechanism found in C++ and Modula-3.[22] Also the language Nim makes use of some aspects of Modula-3, such as traced vs untraced pointers.

References

  1. ^ "Critical Mass Modula-3 (CM3)". Critical Mass Modula-3. elego Software Solutions GmbH. Retrieved 2020-03-21.
  2. ^ "Polytechnique Montréal Modula-3 (PM3): What is it". Polytechnique Montréal Modula-3. elego Software Solutions GmbH. Retrieved 2020-03-21.
  3. ^ Polstra, John D. (November 9, 2006). "Ezm3: An Easier Modula-3 Distribution". CVSup.org. Archived from the original on April 10, 2013. Retrieved 2020-03-21.
  4. ^ Weich, Carsten. "M3/PC Klagenfurt 96: a Modula-3 environment for MS-DOS". Department of Informatics. University of Klagenfurt. Archived from the original on 20 May 2000. Retrieved 2020-03-21.
  5. ^ Picheta, Dominik; Locurcio, Hugo. "Frequently Asked Questions". Retrieved 2020-03-21.
  6. ^ "R/Rust - I just learned about Modula-3, a language that had a lot of similar goals to Rust, and there was even an experimental OS that relied on the safety provided by the language". September 2019.
  7. ^ van Rossum, Guido (May 1996). "Programming Python: Foreword (1st ed.)". Python.org. Retrieved 2020-03-21.
  8. ^ "Design and History FAQ: Why must 'self' be used explicitly in method definitions and calls?". Python.org. March 21, 2020. Retrieved 2020-03-21.
  9. ^ a b c Modula-3 report (revised) Luca Cardelli, James Donahue, Lucille Glassman, Mick Jordan, Bill Kalsow, Greg Nelson. DEC Systems Research Center (SRC) Research Report 52 (November 1989)
  10. ^ Cardelli, Luca; Donahue, James; Glassman, Lucille; Jordan, Mick; Kalsow, Bill; Nelson, Greg (August 1992). "Modula-3 language definition". ACM SIGPLAN Notices. 27 (8): 15–42. doi:10.1145/142137.142141. ISSN 0362-1340.
  11. ^ a b Some Useful Modula-3 Interfaces Archived 2016-03-04 at the Wayback Machine Jim Horning, Bill Kalsow, Paul McJones, Greg Nelson. DEC Systems Research Center (SRC) Research Report 113 (December 1993)
  12. ^ LM3 Archived 2016-03-03 at the Wayback Machine Kevin D. Jones. DEC Systems Research Center (SRC) Research Report 72 (June 1991)
  13. ^ Extended Static Checking Archived 2017-07-05 at the Wayback Machine David L. Detlefs, K. Rustan M. Leino, Greg Nelson, James B. Saxe. Compaq SRC Research Report 159 (December 1998)
  14. ^ SRC Modula-3 3.3[permanent dead link] Bill Kalsow and Eric Muller. Digital Equipment Corporation (January 1995)
  15. ^ Jordan, Mick (1990). "An extensible programming environment for Modula-3". SIGSOFT Softw. Eng. Notes. 15 (6): 66–76. doi:10.1145/99278.99285.
  16. ^ An Introduction to Programming with Threads Archived 2017-07-05 at the Wayback Machine Andrew D. Birrell. DEC Systems Research Center (SRC) Research Report 35 (January 1989)
  17. ^ Synchronization Primitives for a Multiprocessor: A Formal Specification Archived 2016-03-04 at the Wayback Machine A. D. Birrell, J. V. Guttag, J. J. Horning, R. Levin. DEC Systems Research Center (SRC) Research Report 20 (August 1987)
  18. ^ IO Streams: Abstract Types, Real Programs Archived 2016-03-03 at the Wayback Machine Mark R. Brown and Greg Nelson. DEC Systems Research Center (SRC) Research Report 53 (November 1989)
  19. ^ Modula-3 Reference Manual Luca Cardelli, James Donahue, Lucille Glassman, Mick Jordan, Bill Kalsow, Greg Nelson. DEC Systems Research Center (SRC) (February 1995)
  20. ^ Trestle Tutorial Archived 2016-03-03 at the Wayback Machine Mark S. Manasse and Greg Nelson. DEC Systems Research Center (SRC) Research Report 69 (May 1992)
  21. ^ Garbage Collection of Remote Objects, Java Remote Method Invocation Documentation for Java SE 8.
  22. ^ Classes, Official Python Documentation.

Read other articles:

Fergus mac Róich sedang menggendong keponakannya Setanta Fergus mac Róich adalah tokoh fiksi dari siklus ulster dari mitologi Irlandia. Karakter ini muncul sebagai seorang pria gagah perkasa, sesuai dengan namanya yang juga secara literal dapat diartikan sebagaigreat horse.[1] Kepribadian Fergus adalah pejuang laki-laki Ulster yang memiliki hasrat seksual sangat tinggi. Maniak seks adalah kata yang tepat untuk mendeskripsikan dirinya.[2] Kisah Hidup Fergus naik tahta menjadi...

 

Уолтер Айзардангл. Walter Isard Дата рождения 19 апреля 1919(1919-04-19)[1] Место рождения Филадельфия, Пенсильвания, США Дата смерти 6 ноября 2010(2010-11-06)[2] (91 год) Место смерти Дрексел-Хилл[d], Делавэр, Пенсильвания, США Страна  США Научная сфера экономика, география Место рабо�...

 

3β-Dihydroprogesterone Names IUPAC name 3β-Hydroxypregn-4-en-20-one Systematic IUPAC name 1-[(1S,3aS,3bS,7S,9aR,9bS,11aS)-7-Hydroxy-9a,11a-dimethyl-2,3,3a,3b,4,5,7,8,9,9a,9b,10,11,11a-tetradecahydro-1H-cyclopenta[a]phenanthren-1-yl]ethan-1-one Other names Pregn-4-en-3β-ol-20-one; 3β-Dihydroprogesterone; 3β-DHP; δ4-Pregnenolone; 4-Pregnenolone Identifiers CAS Number 566-66-5 3D model (JSmol) Interactive image ChemSpider 19148924 PubChem CID 12838303 UNII AW2D4ZZ5YQ Y InChI InChI=1S...

American politician For other people with the same name, see William Phelps. William Walter PhelpsMember of the U.S. House of Representativesfrom New Jersey's 5th districtIn officeMarch 4, 1873 – March 3, 1875Preceded byGeorge A. HalseySucceeded byAugustus W. CutlerIn officeMarch 4, 1883 – March 3, 1889Preceded byJohn HillSucceeded byCharles D. BeckwithUnited States Ambassador to Austria-HungaryIn officeMay 5, 1881 – June 30, 1882PresidentJames Garfield Chester A...

 

Untuk kegunaan, lihat MHTV (disambiguasi). MHTV MalangPT Media Hutama TelevisiMalang, Jawa TimurIndonesiaSaluranDigital: 31 UHFSloganInspiratif dan Menghibur[1]KepemilikanPemilikMedia Nusantara Citra (2014-2020)Dinas Kebudayaan dan Pariwisata Provinsi Jawa Timur (2023-sekarang)RiwayatSiaran perdana24 Juni 2014 (siaran percobaan)Agustus 2014 (siaran resmi)Bekas tanda panggilMH-iNews MalangBekas nomor kanal52 UHF (analog)Bekas afiliasiiNewsInformasi teknisOtoritas perizinanKementerian K...

 

Sceaux 行政国 フランス地域圏 (Région) イル=ド=フランス地域圏県 (département) オー=ド=セーヌ県郡 (arrondissement) アントニー郡小郡 (canton) 小郡庁所在地INSEEコード 92071郵便番号 92330市長(任期) フィリップ・ローラン(2008年-2014年)自治体間連合 (fr) メトロポール・デュ・グラン・パリ人口動態人口 19,679人(2007年)人口密度 5466人/km2住民の呼称 Scéens地理座標 北緯48度4...

Carte des cours d'eau de longueur supérieure à 50 km de Saône-et-Loire. Carte de l'ensemble du réseau hydrographique de Saône-et-Loire. Article principal : Réseau hydrographique de Saône-et-Loire. La liste des cours d'eau de Saône-et-Loire présente les principaux cours d'eau traversant pour tout ou partie le territoire du département français de Saône-et-Loire dans la région Bourgogne-Franche-Comté. Plus de 1 900 cours d'eau sont recensés en 2014 dans le ré...

 

ヨハネス12世 第130代 ローマ教皇 教皇就任 955年12月16日教皇離任 964年5月14日先代 アガペトゥス2世次代 レオ8世個人情報出生 937年スポレート公国(中部イタリア)スポレート死去 964年5月14日 教皇領、ローマ原国籍 スポレート公国親 父アルベリーコ2世(スポレート公)、母アルダその他のヨハネステンプレートを表示 ヨハネス12世(Ioannes XII、937年 - 964年5月14日)は、ロ...

 

Wukesong五棵松LokasiJalan Fuxing dan Jalan lingkar ke-4 TengahDistrik Haidian, BeijingChinaOperatorBeijing Mass Transit Railway Operation Corp., LtdJalur     Jalur 1Informasi lainKode stasiun108SejarahDibuka15 Agustus 1971Operasi layanan Stasiun sebelumnya   Beijing Subway   Stasiun berikutnya Yuquanlumenuju Pingguoyuan Jalur 1Wanshoulumenuju Sihui Timur Lokasi pada petaWukesongLokasi di pusat BeijingSunting kotak info • L • BBantuan penggunaan t...

National Assembly Assemblée nationaleTypeTypeLower house HistoryFounded1962LeadershipPresidentGelase Ndabirabe[1] since 7 August 2020 StructureSeats100 directly elected, additional members co-opted to meet constitutional requirements[2]Political groups  CNDD-FDD: 86 seats   CNL: 32 seats   UPRONA: 2 seats   Twa: 3 seatsLength of term5 yearsElectionsVoting systemParty list proportional representationLast election20 May 2020Meeting placeK...

 

For the Stadium and home of Scottish Rugby Union, see Murrayfield Stadium. For the area in the Wimbledon grounds named after Andy Murray, see Henman Hill. Murrayfield House, Edinburgh Murrayfield Stadium Murrayfield Ice Rink Murrayfield is an area to the west of Edinburgh city centre in Scotland.[1] It is to the east of Corstorphine and north of Balgreen, Saughtonhall and Roseburn. The A8 road runs east–west through the south of the area. Murrayfield is often considered to include ...

 

Involuntary, forceful expulsion of stomach contents, typically via the mouth Not to be confused with Regurgitation (digestion). Vomit, Emesis, Heaving, Puke, and Throw up redirect here. For other uses, see Vomit (disambiguation). For the butterfly genus, see Emesis (genus). For the 2021 Argentine film, see PussyCake. For the sailing terms, see Heaving to and Careening. For the municipality of Albania, see Pukë. For the style of graffiti, see Throw up (graffiti). For other uses, see Puke (dis...

Philosophical theory that individuals are born without innate knowledge Blank slate redirects here. For other uses, see Blank slate (disambiguation). For other uses, see Tabula rasa (disambiguation). Roman tabula, or wax tablet, with stylus Tabula rasa (/ˈtæbjələ ˈrɑːsə, -zə, ˈreɪ-/; Latin for blank slate) is the idea of individuals being born empty of any built-in mental content, so that all knowledge comes from later perceptions or sensory experiences. Proponents typically form t...

 

Repubblica Cisalpina (dettagli) (dettagli) Motto: Libertà Eguaglianza Repubblica Cisalpina - LocalizzazioneLa Repubblica Cisalpina nel 1797 Dati amministrativiNome completoRepubblica Cisalpina Lingue ufficialiitaliano Lingue parlateemiliano, romagnolo, lombardo, veneto CapitaleMilano[1]  (127000 ab. / 1798) Dipendente da Francia PoliticaForma di StatoRepubblica sorella Forma di governoRepubblica direttoriale GovernoDirettorio Organi deliberativi Gran Consigli...

 

Artikel ini sebatang kara, artinya tidak ada artikel lain yang memiliki pranala balik ke halaman ini.Bantulah menambah pranala ke artikel ini dari artikel yang berhubungan atau coba peralatan pencari pranala.Tag ini diberikan pada Oktober 2022. Festival seni ruang publik atau FSRB adalah istilah umum yang merujuk kepada suatu penyelenggaraan perhelatan (festival À la carte) dari berbagai cabang seni yang mengambil lokasi di tempat-tempat umum semisal lapangan, taman kota, jalan raya, atau ha...

Item of metadata attached to a document For the Wikipedia help page, see WP:ANNOTATION. This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these template messages) This article's lead section may be too short to adequately summarize the key points. Please consider expanding the lead to provide an accessible overview of all important aspects of the article. (February 2015) This article needs additional citations for ...

 

Allsvenskan Malmö FF:s Jan Ekström och IFK Norrköpings Åke Johansson jagar bollen vid mötet lagen emellan på Malmö stadion i april.Säsong1964VinnareDjurgårdens IF(3:e allsvenska titeln)(7:e SM-titeln)NedflyttadeIFK EskilstunaGaisEuropacupen 1964/65Malmö FFEuropacupen 1965/66Djurgårdens IFStatistikBästa målgörareKrister Granbom, Hälsingborgs IF (22)Största hemmavinstNorrköping 7–1 Eskilstuna(3 maj 1964)Malmö FF 6–0 Eskilstuna(11 juni 1964)Största bortavinstHäl...

 

此條目可参照英語維基百科和烏克蘭語維基百科相應條目来扩充。 (2024年2月12日)若您熟悉来源语言和主题,请协助参考外语维基百科扩充条目。请勿直接提交机械翻译,也不要翻译不可靠、低品质内容。依版权协议,译文需在编辑摘要注明来源,或于讨论页顶部标记{{Translated page}}标签。 一面显示有俄罗斯国防部纹样以及“特别军事行动”字样的旗帜 特别军事行动(俄語:�...

Municipality of Brazil in Minas Gerais Location of Bandeira within the state of Minas Gerais Bandeira is a Brazilian municipality located in the state of Minas Gerais. Its population as of 2020[update] was estimated to be 4,766 people living in a total area of 484 km².[1] The city belongs to the mesoregion of Jequitinhonha and to the microregion of Almenara.[2] Bandeira is located 37 km. northeast of Almenara, just south of the boundary with the state of Bah...

 

Business school of Indiana University 39°10′20″N 86°31′06″W / 39.17218°N 86.51843°W / 39.17218; -86.51843 Indiana UniversityKelley School of BusinessMottoGo from Moment to MomentumTypePublic business schoolEstablished1920; 104 years ago (1920)Parent institutionIndiana University BloomingtonEndowmentUS$107 million (2016)[1]DeanAsh SoniStudents13,538 (Bloomington, 2022)1,596 (Indianapolis, 2022)Undergraduates10,185 (Bloomington, 2022...