Open main menu
Home
Random
Recent changes
Special pages
Community portal
Preferences
About Wikipedia
Disclaimers
Incubator escapee wiki
Search
User menu
Talk
Dark mode
Contributions
Create account
Log in
Editing
EGL (programming language)
Warning:
You are not logged in. Your IP address will be publicly visible if you make any edits. If you
log in
or
create an account
, your edits will be attributed to your username, along with other benefits.
Anti-spam check. Do
not
fill this in!
{{refimprove|date=January 2017}} {{Infobox programming language |name = EGL<br />(Enterprise Generation Language) |logo = |paradigm = |year = |designer = |developer = [[IBM]] |latest_release_version = |latest_release_date = |typing = |implementations = |dialects = |influenced_by = |influenced = |current version = |operating_system = |license = [[Eclipse Public License]] |website = {{URL|http://www.eclipse.org/edt/}} }} '''EGL''' (Enterprise Generation Language), originally developed by [[IBM]] and now available as the EDT (EGL Development Tools)<ref>[http://www.eclipse.org/edt/ EDT (EGL Development Tools)]</ref> [[open source]] project under the [[Eclipse Public License]] (EPL), is a programming technology designed to meet the challenges of modern, multi-platform application development by providing a common language and programming model across languages, frameworks, and runtime platforms. ==Overview== The language borrows concepts familiar to anyone using statically typed languages like [[Java (programming language)|Java]], [[COBOL]], [[C (programming language)|C]], etc. However, it borrows the concept of [[Stereotype (UML)|stereotype]] from [[Unified Modeling Language]] (UML) that is not typically found in statically typed programming languages. In a nutshell, EGL is a higher-level, universal application development language. EGL is similar in syntax to other common languages so it can be learned by application developers with similar previous programming background. EGL application development abstractions shield programmers from the technical interfaces of systems and middleware allowing them to focus on building business functionality. EGL applications and services are written, tested and debugged at the EGL source level, and once they are satisfactorily functionally tested they can be compiled into COBOL, Java, or [[JavaScript]] code to support deployment of business applications that can run in any of the following environments: *Platforms with a [[Java virtual machine]], such as [[Microsoft Windows]], [[Linux]], and [[UNIX]], for example in the context of a Java EE servlet container ([[IBM WebSphere Application Server]], [[Apache Tomcat]], [[GlassFish]]) *[[IBM System z]]: [[CICS Transaction Server]], [[IBM Information Management System|IMS]], [[z/OS]] Batch, [[UNIX System Services]], WebSphere Application Server, [[z/VSE]], Linux *[[IBM Power Systems]]: [[IBM i]], IBM WebSphere Application Server, [[Apache Tomcat]], Integrated Web Application Server for i *[[Web browsers]] supporting JavaScript, such as [[Internet Explorer]], [[Firefox]], and [[Safari (web browser)|Safari]], for [[Ajax (programming)|Ajax]] [[Rich web application|rich web applications]] == Code examples == === Program === An EGL Program part is a generatable logic part with one entry point. Each Program part contains a main() function, which represents the logic that runs at program start up. A program can include other functions and can access functions that are outside of the program. The function main() can invoke those other functions. Program functions are composed of a set of EGL statements, variables, and constants. <syntaxhighlight lang="pascal" line highlight="5"> Program HelloWorld const GREETING string = "Hello, "; function main() myName string = "John"; sayHello(myName); end function sayHello(name String in) SysLib.writeStdOut(GREETING + name + "!"); end end </syntaxhighlight> === Record === An EGL Record part defines a set of data elements. In this example, a record with the name '''''CustomerRecord''''' is defined with 6 fields. <syntaxhighlight lang="pascal"> Record CustomerRecord type BasicRecord customerNumber INT; customerName STRING; customerAddr1 STRING; customerAddr2 STRING; customerAddr3 STRING; customerBalance MONEY; end </syntaxhighlight> EGL has a specialized type of record called '''''SQLRecord''''' that is used to exchange data with a relational database. <syntaxhighlight lang="text"> record Employee type sqlRecord { tableNames =[["Employee"]], keyItems =[EMPNO]} EMPNUMBER string{ column = "EMPNO", maxLen = 6}; FIRSTNME string{ sqlVariableLen = yes, maxLen = 12}; MIDINIT string{ isSqlNullable = yes, maxLen = 1}; LASTNAME string{ sqlVariableLen = yes, maxLen = 15}; DEPT string{ column = "WORKDEPT", isSqlNullable = yes, maxLen = 3}; PHONENO string{ isSqlNullable = yes, maxLen = 4}; HIREDATE date{ isSqlNullable = yes}; end </syntaxhighlight> * In this example, the record '''''Employee''''' is bound to a table (or view) named '''''Employee'''''. === Service === An EGL Service part contains public functions meant to be accessed from other applications or systems. In this example, a service with two functions is defined. <syntaxhighlight lang="pascal" line highlight="1,5,11"> package com.mycompany.services; service EmployeeService function getEmployees() returns(Employee[]) records Employee[0]; // define an empty array of records get records; // retrieve records from the database return (records); // return the records end function addEmployee(emp Employee in) returns (boolean) try add remp; return (true); onException (ex AnyException) return (false); end end end </syntaxhighlight> * In EGL, code is organized in packages (like [[Java (programming language)]]) * The first function, ''getEmployees'', returns an array of records populated from the records in a database. * The second function, ''addEmployee'' adds a new record to the database and returns a true or false depending on whether the record was added successfully. === RUIHandler === The main component of a Rich UI application is a Rich UI handler part. These parts are generated into JavaScript. <syntaxhighlight lang="javascript" line highlight="8"> package com.mycompany.ui; import com.mycompany.services.Employee; import com.mycompany.services.EmployeeService; import dojo.widgets.DojoGrid; import dojo.widgets.DojoGridColumn; handler EmployeeView type RUIhandler { initialUI = [ grid ], onConstructionFunction = start, cssFile = "main.css" } grid DojoGrid { behaviors = [ ], headerBehaviors = [ ], columns = [ new DojoGridColumn { displayName = "First Name", name = "FIRSTNAME" }, new DojoGridColumn { displayName = "Last Name", name = "LASTNAME" }, new DojoGridColumn { displayName = "Salary", name = "SALARY" } ] }; function start() svc EmployeeService { }; call svc.getEmployees () returning to displayEmployees; end function displayEmployees(retResult Employee [ ] in) grid.data = retResult as any [ ]; end end </syntaxhighlight> == Web 2.0 with EGL == In December 2008, IBM introduced new technology, EGL Rich UI, to simplify the creation of [[Web 2.0]]-style [[Rich web application|rich web applications]]. This technology simplifies development by hiding the complexities of [[Ajax (programming)|Ajax]], [[JavaScript]], [[REST]], and [[SOAP]] from the developer, which enables them to focus on the business requirement and not on the underlying technologies. == Commercial products == EGL programming tools are available as an Eclipse-based<ref>[http://www.eclipse.org Eclipse]</ref> commercial product, the [[IBM Rational Business Developer Extension|Rational Business Developer]] and also in the EGL edition of [[Rational Developer for System z]]. EGL is a target language for modernization of legacy applications because of the language semantics affinity with procedural languages and legacy [[4GL|4th generation languages]]: * a set of conversion tools available within the [[IBM Rational Business Developer Extension|Rational Business Developer]] product provide automated the conversion from older and stabilized IBM and [[Informix]] [[4GL|4th generation languages]] * a set of IBM service offerings and complementary products (Rational Migration Extension for Natural, Rational Migration Extension for System i, Rational Migration Extension for CA-products) provide the ability to convert from [[NATURAL|Software AG Natural]], [[IBM RPG]], CA Cool:Gen and CA Ideal/Datacom to EGL Tools for searching large EGL code bases, comparing individual EGL files for changes, and detecting duplicated code are available from Semantic Designs<ref>[http://www.semanticdesigns.com/Products/LanguageTools/EGLTools.html Semantic Designs]</ref> ==References== {{Reflist}} ==Further reading== * Enterprise Web 2.0 with EGL, {{ISBN|978-1-58347-091-6}}. * Developing Web 2.0 Applications with EGL for IBM i, {{ISBN|978-1-58347-089-3}}. ==External links== * [http://www.ibm.com/developerworks/rational/community/cafe/egl.html EGL Cafe Community Site] * [http://www.ibm.com/software/awdtools/developer/business/ IBM Rational Business Developer product page] * [http://www.ibm.com/support/docview.wss?rs=3456&uid=swg27012776 IBM Rational Business Developer Information Centers ] * [http://www.eclipse.org/edt/ Eclipse EGL Development Tools (EDT) Project] - an open implementation at [[Eclipse (software)|Eclipse]] {{IBM FOSS}} [[Category:Fourth-generation programming languages]] [[Category:IBM software]] [[Category:Scripting languages]]
Edit summary
(Briefly describe your changes)
By publishing changes, you agree to the
Terms of Use
, and you irrevocably agree to release your contribution under the
CC BY-SA 4.0 License
and the
GFDL
. You agree that a hyperlink or URL is sufficient attribution under the Creative Commons license.
Cancel
Editing help
(opens in new window)
Pages transcluded onto the current version of this page
(
help
)
:
Template:IBM FOSS
(
edit
)
Template:ISBN
(
edit
)
Template:Infobox programming language
(
edit
)
Template:Refimprove
(
edit
)
Template:Reflist
(
edit
)