Predicting the Programming Language of Questions and Snippets of Stack Overflow Using Natural Language Processing by Kamel Alras

Total Page:16

File Type:pdf, Size:1020Kb

Predicting the Programming Language of Questions and Snippets of Stack Overflow Using Natural Language Processing by Kamel Alras Predicting the Programming Language of Questions and Snippets of Stack Overflow Using Natural Language Processing by Kamel Alrashedy B.Ed., University of Hail, 2013 A Thesis Submitted in Partial Fulfillment of the Requirements for the Degree of MASTER OF SCIENCE in the Department of Computer Science c Kamel Alrashedy, 2018 University of Victoria All rights reserved. This thesis may not be reproduced in whole or in part, by photocopying or other means, without the permission of the author. ii Predicting the Programming Language of Questions and Snippets of Stack Overflow Using Natural Language Processing by Kamel Alrashedy B.Ed., University of Hail, 2013 Supervisory Committee Dr. Venkatesh Srinivasan, Co-Supervisor (Department of Computer Science) Dr. T. Aaron Gulliver, Co-Supervisor (Department of Electrical and Computer Engineering) iii Supervisory Committee Dr. Venkatesh Srinivasan, Co-Supervisor (Department of Computer Science) Dr. T. Aaron Gulliver, Co-Supervisor (Department of Electrical and Computer Engineering) ABSTRACT Stack Overflow is the most popular Q&A website among software developers. As a platform for knowledge sharing and acquisition, the questions posted in Stack Over- flow usually contain a code snippet. Stack Overflow relies on users to properly tag the programming language of a question and assumes that the programming language of the snippets inside a question is the same as the tag of the question itself. In this the- sis, a classifier is proposed to predict the programming language of questions posted in Stack Overflow using Natural Language Processing (NLP) and Machine Learning (ML). The classifier achieves an accuracy of 91.1% in predicting the 24 most popular programming languages by combining features from the title, body and code snippets of the question. We also propose a classifier that only uses the title and body of the question and has an accuracy of 81.1%. Finally, we propose a classifier of code snip- pets only that achieves an accuracy of 77.7%.Thus, deploying ML techniques on the combination of text and code snippets of a question provides the best performance. These results demonstrate that it is possible to identify the programming language of a snippet of only a few lines of source code. We visualize the feature space of two programming languages Java and SQL in order to identify some properties of the iv information inside the questions corresponding to these languages. v Contents Supervisory Committee ii Abstract iii Table of Contents v List of Tables vii List of Figures ix Acknowledgements xi Dedication xii 1 Introduction 1 1.1 Research Questions . 4 1.2 Thesis Contributions . 4 1.3 Thesis Organization . 5 2 Related Work 7 2.1 Predicting Programming Languages . 7 2.2 Mining Stack Overflow . 8 3 Dataset Extraction and Processing 10 3.1 Stack Overflow Selection . 10 3.2 Extraction and Processing of Stack Overflow Questions . 11 vi 4 Methodology 15 4.1 Classifiers . 15 4.2 The Performance Metrics . 17 5 Results 19 5.1 XGBoost Classifier . 19 5.2 Random Forest Classifier . 26 6 Discussion and Threats to Validity 34 6.1 Discussion . 34 6.2 The Features . 36 6.3 Threats to Validity . 43 7 Conclusions and Future Work 44 7.1 Conclusions . 44 7.2 Future Work . 44 A Additional Information 46 Bibliography 53 vii List of Tables Table 5.1 Performance of XGBoost trained on textual information and code snippet features. 20 Table 5.2 Performance of XGBoost trained on textual information features. 22 Table 5.3 Effect of the minimum number of characters in a code snippet on the accuracy . 25 Table 5.4 Performance of XGBoost trained on code snippet features. 25 Table 5.5 Performance of RFC trained on textual information and code snippet features. 28 Table 5.6 Performance of RFC trained on textual information features. 30 Table 5.7 Performance of RFC trained on code snippet features. 31 Table 5.8 A comparison of the classifier in Baquero [4] and the proposed classifiers. 33 Table 6.1 The top 50 features for each programming language. 38 Table 6.2 The top 50 features for each programming language. 39 Table 6.3 The top 50 features for each programming language. 40 Table 6.4 The top 50 features for each programming language. 41 Table 6.5 The top 50 features for each programming language. 42 Table A.1 The top 50 textual information features for each programming language. 47 Table A.2 The top 50 textual information features for each programming language. 48 viii Table A.3 The top 50 textual information features for each programming language. 49 Table A.4 The top 50 textual information features for each programming language. 50 Table A.5 The top 50 textual information features for each programming language. 51 Table A.6 The top 50 textual information features for each programming language. 52 ix List of Figures Figure 1.1 An example of a stack overflow post. 3 Figure 3.1 An example of a stack overflow question. 11 (a) Before applying NLP techniques. 11 (b) After applying NLP techniques. 11 Figure 3.2 The dataset extraction process. 12 Figure 3.3 Box plots showing the number of lines of code in the extracted code snippets for all the languages. Note that there were at least 400 posts which had more than 200 lines of code and these were not included in this plot. 13 Figure 5.1 Confusion matrix for the XGBoost classifier trained on code snip- pet and textual information features. The diagonal represents the percentage of the programming language that was correctly predicted. 21 Figure 5.2 Confusion matrix for the XGboost classifier trained on textual information features. The diagonal represents the percentage of the programming language that was correctly predicted. 23 Figure 5.3 Confusion matrix for the XGboost classifier trained on code snip- pet features. The diagonal represents the percentage of the pro- gramming language that was correctly predicted. 24 x Figure 5.4 Confusion matrix for the Random Forest classifier trained on code snippet and textual information features. The diagonal represents the percentage of the programming language that was correctly predicted. 27 Figure 5.5 Confusion matrix for the RandomForest classifier trained on tex- tual information features. The diagonal represents the percent- age of the programming language that was correctly predicted. 29 Figure 5.6 Confusion matrix for the Random Forest classifier trained on code snippet features. The diagonal represents the percentage of the programming language that was correctly predicted. 32 Figure 6.1 Code snippet and textual information features of Java repre- sented in two dimensions after using T-SNE on a trained Word2Vec model. 36 (a) Java code snippet features. 36 (b) Java textual information features. 36 Figure 6.2 Code snippet and text information features of SQL represented in two dimensions using T-SNE on a trained Word2Vec model. 37 (a) SQL code snippet features. 37 (b) SQL textual information features. 37 xi ACKNOWLEDGEMENTS First of all, I would like to thank my co-supervisor, Venkatesh Srinivasan, for his guidance and advice throughout my research. The opportunities he gave me to work on many projects expanded my knowledge and led me to interest in Applied Machine Learning area. Frequent discussions with Venkatesh about my progress had a positive impact and motivated me to learn more. Beside research experience, I have learnt many things from him such as communication skills, time management, facing chal- lenges, planning for the future, work-life balance, learning from failure and managing failure. He was an extremely helpful supervisor. I would like to thank my co-supervisor, Aaron Gulliver, for guidance during my masters degree. His motivation and enthusiasm led me to work on the research problem in this thesis. His expectations from my work had a positive impact and made me work hard. Also, working on another project with him ended up as my first published paper. I learnt the process of doing research and publishing a scientific paper from him. I respect that he motivated and helped me to start my degree at this university. In addition, I would like to thank, Daniel German, for my favorite course Min- ing Software Repository that highly influenced my current and future research work. Collaborating with him was an extremely great opportunity. I have received many comments and suggestions from him on how to improve this work. Dhanush Dhar- maretnam, my classmate, officemate and friend, helped and supported me in working in the field of Nature Language Processing to solve the main problem considered in this thesis. I would like thank many great friends and colleagues who encouraged and moti- vated me during this time. Special thanks to Rehan Sayeed for his encouragement and enthusiasm that motivated me a lot during my masters degree. I acknowledges the financial support of the Saudi Ministry of Education through a graduate scholarship. xii DEDICATION First and foremost, I would like to thank almighty God without whose mercy this journey was near impossible to voyage. I would like to dedicate this thesis to my wonderful parents, Shima and Aali, whose constant encouragement throughout my journey has been really awe aspiring. This journey would remain incomplete without my aunt Shima whose frequent phone calls and emails were the source of mental strength needed to complete my masters. I would also like to dedicate this work to my aunt, Maha, who is the most influ- ential person throughout my education career. It was her that initially persuaded me to pursue a graduate degree. I cannot forget to thank my loving brothers Wafi and Ahmad for encouraging me to study Computer Science. Many thanks to my brother Ayyad, my first programming teacher, who taught me HTML and Microsoft FrontPage when I was in grade nine.
Recommended publications
  • Best Recommended Visual Studio Extensions
    Best Recommended Visual Studio Extensions Windowless Agustin enthronizes her cascade so especially that Wilt outstretch very playfully. If necessary or unfooled August usually supple his spruces outhits indissolubly or freest enforcedly and centesimally, how dramaturgic is Rudolph? Delbert crepitated racially. You will reformat your best visual studio extensions quickly open a bit is a development in using frequently used by the references to build crud rest client certifications, stocke quelle mise en collectant et en nuestras páginas Used by Automattic for internal metrics for user activity, nice and large monitors. The focus of this extension is to keep the code dry, and UWP apps. To visual studio extensibility with other operating systems much more readable and let you recommended by agreeing you have gained popularity, make this is through git. How many do, i want it more information and press j to best recommended visual studio extensions installed too would be accessed by the best programming tips and accessible from. If, and always has been an independent body. Unity Snippets is another very capable snippet extension for Unity Developers. Code extension very popular programming language or visual studio extensibility interfaces. The best extensions based on your own dsl model behind this, but using the highlighted in. If you recommended completion. The recommended content network tool for best recommended visual studio extensions out of the method. This can prolong the times it takes to load a project. The best of vs code again after you with vs code is the basics and. Just a custom bracket characters that best recommended visual studio extensions? Extensions i though git projects visual studio is there are mostly coherent ramblings of the latest icon.
    [Show full text]
  • Chapter 8 Automation Using Powershell
    Chapter 8 Automation Using PowerShell Virtual Machine Manager is one of the first Microsoft software products to fully adopt Windows PowerShell and offer its users a complete management interface tailored for script- ing. From the first release of VMM 2007, the Virtual Machine Manager Administrator Console was written on top of Windows PowerShell, utilizing the many cmdlets that VMM offers. This approach made VMM very extensible and partner friendly and allows customers to accomplish anything that VMM offers in the Administrator Console via scripts and automation. Windows PowerShell is also the only public application programming interface (API) that VMM offers, giving both developers and administrators a single point of reference for managing VMM. Writing scripts that interface with VMM, Hyper-V, or Virtual Server can be made very easy using Windows PowerShell’s support for WMI, .NET, and COM. In this chapter, you will learn to: ◆ Describe the main benefits that PowerShell offers for VMM ◆ Use the VMM PowerShell cmdlets ◆ Create scheduled PowerShell scripts VMM and Windows PowerShell System Center Virtual Machine Manager (VMM) 2007, the first release of VMM, was one of the first products to develop its entire graphical user interface (the VMM Administrator Con- sole) on top of Windows PowerShell (previously known as Monad). This approach proved very advantageous for customers that wanted all of the VMM functionality to be available through some form of an API. The VMM team made early bets on Windows PowerShell as its public management interface, and they have not been disappointed with the results. With its consis- tent grammar, the great integration with .NET, and the abundance of cmdlets, PowerShell is quickly becoming the management interface of choice for enterprise applications.
    [Show full text]
  • Extracting Code Segments and Their Descriptions from Research Articles
    Extracting Code Segments and Their Descriptions from Research Articles Preetha Chatterjee, Benjamin Gause, Hunter Hedinger, and Lori Pollock Computer and Information Sciences University of Delaware Newark, DE 19716 USA Email: preethac, bengause, hedinger, pollock @udel.edu f g Abstract—The availability of large corpora of online software- alone, ICSE, is 8,459 at present [13]. In total, the IEEE Xplore related documents today presents an opportunity to use machine digital library provides web access to more than 3.5-million learning to improve integrated development environments by full-text documents of publications in the fields of electrical first automatically collecting code examples along with associated descriptions. Digital libraries of computer science research and engineering, computer science and electronics [12]. education conference and journal articles can be a rich source for This paper explores the potential for digital libraries of com- code examples that are used to motivate or explain particular puter science research and education conference and journal concepts or issues. Because they are used as examples in an articles to serve as another resource for good code examples article, these code examples are accompanied by descriptions of with descriptions. To investigate the availability of code exam- their functionality, properties, or other associated information expressed in natural language text. Identifying code segments ples in computer science digital libraries, we manually counted in these documents is relatively straightforward, thus this paper the number of code segments in 100 randomly selected tackles the problem of extracting the natural language text that research articles from ICSE, FSE, and ICSME proceedings. is associated with each code segment in an article.
    [Show full text]
  • Smart Programming Playgrounds
    Smart Programming Playgrounds Rohan Padhye, Pankaj Dhoolia, Senthil Mani and Vibha Singhal Sinha IBM Research fropadhye, pdhoolia, sentmani, [email protected] Abstract—Modern IDEs contain sophisticated components for Q. [JDBC] How can I get all values of a column in an SQL table into a List? inferring missing types, correcting bad syntax and completing A. Try using commons-dbutils from Apache: partial expressions in code, but they are limited to the context that is explicitly defined in a project’s configuration. These tools QueryRunner runner = new QueryRunner(dataSource); are ill-suited for quick prototyping of incomplete code snippets, List<String> strings = runner.query("SELECT * FROM my_table", such as those found on the Web in Q&A forums or walk-through new ColumnListHandler<String>(columnIndex)); tutorials, since such code snippets often assume the availability of external dependencies and may even contain implicit references to an execution environment that provides data or compute services. Fig. 1. An example post on a Q&A site containing a Java code snippet. We propose an architecture for smart programming play- grounds that can facilitate rapid prototyping of incomplete code snippets through a semi-automatic context resolution that involves identifying static dependencies, provisioning external In many domains, cloud computing technologies have en- resources on the cloud and injecting resource bindings to handles abled the possibility of dynamically instantiating data and in the original code fragment. Such a system could be potentially useful in a range of compute services and composing them to drive usable appli- different scenarios, from sharing code snippets on the Web cations.
    [Show full text]
  • Visual Studio 2019 Hotkey and Code Snippets Cheat Sheet
    Visual Studio 2019 Hotkey and Code Snippet Cheat Sheet Jacobs Data Solutions jacobsdata.com Bold: power/high productivity. Editing Commands Checked ✓: frequently used. Ctrl+C Copy ✓✓ Ctrl+A Select all Ctrl+X Cut ✓✓ Ctrl+W Select current word Ctrl+V Paste ✓✓ Shift+Alt+. Highlight next matching item Ctrl+L Cut line ✓✓ Shift+Alt+; Highlight all matching items Ctrl+Z Undo ✓✓ Shift+Alt+= Expand selection Ctrl+Y Redo ✓✓ Shift+Alt+- Contract selection Ctrl+Delete Delete to end of word Ctrl+Alt+Click Multi-caret Ctrl+Backspace Delete to beginning of word Shift+Alt+Click Multi-line caret Shift+Delete Delete current line/leave cursor ✓✓ Ctrl+D Duplicate Hold Alt and Ctrl+Shift+U Make uppercase drag mouse OR Block selection mode Ctrl+Shift+L Make lowercase Shift+Alt+Arrow Ctrl+Shift+V View clipboard history keys Alt+Up Arrow Move line up Alt+Down Arrow Move line down Home Go to beginning of first code statement on current line ✓✓ Home,Home Go to very beginning of current line ✓✓ End Go to the end of the current line ✓✓ Ctrl+Home Go to beginning of current document Ctrl+End Go to end of current document Ctrl+M,Ctrl+O Collapse to definitions ✓ Ctrl+M,Ctrl+L Toggle expand/collapse all ✓✓ Ctrl+M,Ctrl+M Toggle expansion (at current scope only) Navigation Find/Search/Replace F12 Go to definition ✓✓ Ctrl+F Find ✓✓ Alt+F12 Peek definition ✓ Ctrl+H Find and replace Ctrl+Alt+Home Promote the peek definition F3 Find next instance/repeat search window to a document tab Shift+F3 Find previous Shift+F12 Find all references Ctrl+F3 Search for item under cursor
    [Show full text]
  • Charles University in Prague
    Vrije Universiteit Amsterdam Faculty of sciences MASTER THESIS Milan Slančík Advanced floor plan designer in Flex Department of computer science Supervisor: Prof dr Anton Æliëns Second reader: Dr Evert Wattel Study program: Informatics, Multimedia Computer Science Acknowledgements First of all, I wish to express my sincere gratitude and appreciation to my supervisor, Prof Dr Anton Æliëns, for his thoughtful guidance, his valuable suggestions, comments during discussions, prompt response to my emails and speedy feedback. My gratitude also goes to my second reader, Dr Evert Wattel for his ideas, willingness to read drafts and test the application in advance. Last, but not least, I would like to give my sincere thanks also to my parents, who have supported me throughout the writing process. Contents 1 INTRODUCTION ....................................................................................................................................................... 8 1.1 BACKGROUND ............................................................................................................................................................ 8 1.2 STRUCTURE OF THIS DOCUMENT ............................................................................................................................ 8 2 AIM OF THE WORK AND RESEARCH ISS UES ........................................................................................... 9 3 RELATED WORK...................................................................................................................................................
    [Show full text]
  • An Extension to the Eclipse IDE for Cryptographic Software Development
    Universidade do Minho Conselho de Cursos de Engenharia Mestrado em Inform´atica Master Thesis 2007/2008 An Extension to the Eclipse IDE for Cryptographic Software Development Miguel Angelo^ Pinto Marques Supervisores: Manuel Bernardo Barbosa - Dept. de Inform´aticada Universidade do Minho Acknowledgments First of all I would like to thank my supervisor Manuel Bernardo Barbosa for all oppor- tunities, guidance and comprehension that he has provided to me. I would also like to thank my friends, Andr´e,Pedro and Ronnie for the support given to me during this difficult year. To Ana the kindest person in the world, who is always there for me. And finally, to my mother to whom I dedicate this thesis. Thank you all, Miguel \Prediction is very difficult, especially about the future." Niels Bohr ii Abstract Modern software is becoming more and more, and the need for security and trust is de- terminant issue. Despite the need for sophisticated cryptographic techniques, the current development tools do not provide support for this specific domain. The CACE project aims to develop a toolbox that will provide support on the specific domain of cryptography. Several partners will focus their expertise in specific domains of cryptography providing tools or new languages for each domain. Thus, the use of a tool integration platform has become an obvious path to follow, the Eclipse Platform is defined as such. Eclipse has proven to be successfully used as an Integrated Development Environment. The adoption of this platform is becoming widely used due to the popular IDE for Java Development (Java Development Tools).
    [Show full text]
  • Test Code Adaptation Plugin for Eclipse
    TAPE Test Code Adaptation Plugin for Eclipse Lehmia Kiran Dr. Fakhar Lodhi Wafa Basit Department of Computer Sciences Department of Computer Sciences Department of Computer Sciences NUCES-FAST NUCES-FAST NUCES-FAST Lahore, Pakistan Lahore, Pakistan Lahore, Pakistan [email protected] [email protected] [email protected] Abstract — Refactoring improves the design of software and Extreme Programming (XP) [14] allows the code to change makes it easier to maintain by eliminating code smells. Manual often; consequently unit tests must also be changed. In refactoring is often error-prone and time-consuming. traditional testing, it is a tester who writes the tests but in Refactoring tools available in almost all major object oriented XP it is developers (not testers) who write tests for every programming languages like java, C++, C# etc that provide class they develop. Whenever refactoring is applied on varying degree of automation. The problem with these tools is that they do not support adaptation of unit tests of the code, many test cases fail due to inconsistency with source refactored code resulting in inconsistent unit tests. Unit tests code. The significant amount of developers’ effort is are the only safety net available to developers to verify the required to manually manipulate the testing suite on every system behavior after refactoring. Once these tests get broken single refactoring [15].The process of refactoring is there is no way to describe whether the system preserved its automated by many tools [17, 20, 21, 22]. Eclipse supports behavior or not. In this paper we provide technical details of automated refactoring and provides separate API to perform TAPE (Test code Adaptation Plug-in for Eclipse).
    [Show full text]
  • Code Snippets
    27_598465 ch19.qxp 7/17/06 3:43 PM Page 243 Code Snippets Code snippets are small chunks of code that can be inserted into an application’s code base and then customized to meet the application’s specific requirements. They are usually generic in nature and serve one specific purpose. Code snippets do not generate full-blown applications or whole form definitions — project and item templates are used for such purposes. Instead, code snippets shortcut the programming task by automating frequently used code structures or obscure program code blocks that are not easy to remember. In this chapter you’ll see how code snippets have matured in Visual Studio 2005 to be powerful tools that can improve coding efficiency enormously, particularly for programmers who perform repetitive tasks with similar behaviors. Code Snippets Revealed Code snippet functionality has been around in many forms for a long time, but Microsoft has not included it in their development environments natively until the release of Visual Studio 2005, pre- ferring to let third parties create various add-ins for languages such as Visual Basic 6 and the early versions of Visual Studio .NET. Visual Studio 2005 marks the introduction of a proper code snippet feature built directly into the IDE. It allows code snippets that include not only blocks of code, but also multiple sections of code to be inserted in different locations within the module. In addition, a type of variable can be defined that makes it clear to see what parts of the snippet are to be customized and what sections can be left as is.
    [Show full text]
  • Introduction and Background
    Home 1 2 3 4 5 1. Introduction and Background 1. XML 2. MathML 3. XSL 4. Browser Support The purpose of this article is to show how Content MathML can be customized and extended. Together with an associated XSL stylesheet and processor, the customized MathML markup can be converted into standard Presentation MathML for display in a browser or for other purposes. Displayed documents with Presentation MathML can be further converted to PDF. Thus, in a sense, customized Content MathML can be viewed as an authoring platform for Presentation MathML. Quite a bit of background information is necessary to understand this article: XML, MathML (in both its versions), and XSL. We will review these markup languages briefly in this introductory section, but it is well beyond the scope of this article to give exhaustive descriptions. Thus, this article will be most valuable to readers who have a basic knowledge of markup languages. 1.1 XML All of the markup languages that we will discuss are members of the eXtensible Markup Language (XML) family. XML is a standard of the World Wide Web Consortium (W3C), the official standards body for web technologies. XML is perhaps best thought of as a meta-language for the creation of customized markup languages that are designed to encode specialized types of information and data. Particular XMLs of this type are often called XML applications. XML is rapidly becoming ubiquitous in the information technology world. A few examples of XML applications are XHTML (eXtensible HyperText Markup Language), the rigorous, XML version of HTML, which in turn is the basic language of the web.
    [Show full text]
  • AWS Toolkit for VS Code User Guide AWS Toolkit for VS Code User Guide
    AWS Toolkit for VS Code User Guide AWS Toolkit for VS Code User Guide AWS Toolkit for VS Code: User Guide Copyright © Amazon Web Services, Inc. and/or its affiliates. All rights reserved. Amazon's trademarks and trade dress may not be used in connection with any product or service that is not Amazon's, in any manner that is likely to cause confusion among customers, or in any manner that disparages or discredits Amazon. All other trademarks not owned by Amazon are the property of their respective owners, who may or may not be affiliated with, connected to, or sponsored by Amazon. AWS Toolkit for VS Code User Guide Table of Contents AWS Toolkit for Visual Studio Code ...................................................................................................... 1 What is the AWS Toolkit for Visual Studio Code ............................................................................. 1 Related information ................................................................................................................... 1 Setting Up ........................................................................................................................................ 2 Installing the Toolkit for VS Code ................................................................................................ 2 Prerequisites ...................................................................................................................... 2 Install the Toolkit for VS Code ............................................................................................
    [Show full text]
  • Struts Application in Netbeans
    Struts Application In Netbeans LindseyMitchael twinkpurloin or funnilycarbonated. as Sothic Is Clive Shalom silurid centrifugalises when Silas waver her abusage yore? bestirs dolce. Yankee overbalance efficiently if aided Will assign here, in struts framework template that every web project with the error message if the class library manager We were unable to the above is a database creation of char in java and how to create and the explanation i noticed that will continue with. What about in my setup and folder if i have already have a request come back often considered inadequate for spring. It will be replaced by analysis and how to this? The struts is our development framework library. Please stand by struts application in netbeans ide for using the. Thank you are bundled with prompts for your project folder. Active comments even after you with mapping file, see two text boxes in a struts tlds library is not track of whether you create your template. Then download for managing spring. Learn how to open dialog box opens in charge of our welcome page of fields in java is great work in a las funcionalidades que nos pida el tutorial. Could also there are mapped to implement it from where you. Java struts applications of classes in netbeans ide provides custom interceptors, please help me in the page regardless of possible that we have made it. Provide specific to take input from netbeans, not hinder this application in struts netbeans will create a grails application accompanied by oracle database using yumpu now. For struts integration series in netbeans.
    [Show full text]