Программируемая объектная модель для поддержки библиотеки пространств имен или схем в программном приложении

Иллюстрации

Показать все

Изобретение относится к программируемым объектным моделям. Техническим результатом является предоставление пользователю возможности осуществления программным путем доступа и применения библиотеки пространств имен или схем. Указанная библиотека содержит файлы XML-схем и соответствующие XML-ориентированные ресурсы для связывания файлов схем с одним или более документами и для настройки функциональных возможностей, связанных с файлами схем и XML-ориентированными ресурсами. Упомянутая программируемая объектная модель также предоставляет возможность пользователю/программисту удалять файлы схем и другие XML-ориентированные ресурсы из связи с ранее связанными документами. 3 н. и 12 з.п. ф-лы, 4 ил.

Реферат

Родственные заявки

Заявка на выдачу патента США на изобретение под номером дела заявителя 60001.0263US01/MS303917.1, озаглавленная «Programmable Object Model for Extensible Markup Language Schema Validation» («Программируемая объектная модель для проверки действительности схемы Расширяемого Языка Разметки (XML)»), и заявка на выдачу патента США на изобретение под номером дела заявителя 60001.0264US01/MS303918.1, озаглавленная «Programmable Object Model for Extensible Markup Language Markup in an Application» («Программируемая объектная модель для XML-разметки в приложении»), включены в настоящее описание посредством ссылки.

Предупреждение об авторских правах

Часть описания этого патентного документа содержит материал, который является объектом охраны авторского права. Обладатель авторского права не возражает против факсимильного репродуцирования кем-либо, имеющим отношение к патентному документу или описанию патента, при его появлении в патентном фонде Агентства США по патентам и товарным знакам, но во всех иных случаях абсолютно все любые другие авторские права защищены.

Область техники, к которой относится изобретение

Настоящее изобретение относится к программируемым объектным моделям. Более точно, настоящее изобретение относится к программируемой объектной модели для поддержки библиотеки пространств имен или схем в программном приложении.

Предшествующий уровень техники

Компьютерные программные приложения позволяют пользователям создавать различные документы для помощи им в работе, образовании и досуге. Например, известные приложения электронной обработки текстов позволяют пользователям создавать письма, статьи, книги, заметки и тому подобное. Приложения для обработки электронных таблиц позволяют пользователям сохранять, преобразовывать, печатать и отображать различные буквенно-цифровые данные. Такие приложения имеют множество широко известных возможностей, включая всевозможное редактирование, форматирование, распечатывание, вычисление и интерактивное (онлайновое) и автономное редактирование.

Большинство компьютерных программных приложений не содержат всех необходимых средств программирования для обеспечения функциональных возможностей, требуемых или желаемых всеми потенциальными пользователями. Многие программисты часто хотят улучшить существующие возможности приложения в своих собственных программах или адаптировать функциональность приложения и сделать ее более пригодной для обособленного множества пользователей или действий. Например, программист, работающий в финансовой индустрии, может пожелать переделать текстовый обработчик для круга пользователей, состоящего из финансовых аналитиков, редактирующих финансовые отчеты. В последние годы Расширяемый Язык Разметки (XML) широко использовался как взаимозаменяемый формат данных для многих пользователей. Часто пользователи функциональных возможностей XML присоединяют или ассоциируют один или более файлов XML-схем или XML-ориентированных решений с документом, находящимся в состоянии редактирования или создания пользователем. Однако пользователи и/или программисты ограничены в своих возможностях применять функциональность файлов XML-схем или XML-ориентированных решений для данного документа, потому что пользователь и/или программист не имеет прямого и легкого доступа к библиотеке пространств имен или схем, содержащей файлы XML-схем или другие XML-ориентированные решения.

Следовательно, в данной области техники существует необходимость в программируемой объектной модели для предоставления пользователю/программисту возможности получать доступ к библиотеке пространств имен и схем, состоящей из XML ресурсов, для конфигурирования на индивидуальной основе или иного манипулирования такими ресурсами, чтобы расширить использование пользователем/программистом функциональных возможностей XML совместно с документом программного приложения. Именно по этим и другим соображениям было сделано настоящее изобретение.

Сущность изобретения

Настоящее изобретение обеспечивает способы и системы для предоставления пользователю возможности осуществления программным путем доступа и применения библиотеки пространств имен или схем, содержащей файлы XML-схем и соответствующие XML-ориентированные ресурсы, для связывания этих XML-ресурсов с одним или большим количеством документов и для настройки функциональных возможностей, связанных с такими XML-ориентированными ресурсами. Как только пользователь или программист получает доступ к библиотеке пространств имен и схем, такой пользователь имеет возможность программным путем связывать файлы XML-схем с XML-данными в связанном с ними документе и, наоборот, пользователь может обнаруживать и удалять связи файлов XML-схем с XML-данными, содержащимися в упомянутом документе. Пользователь может также программным путем связывать файлы преобразований с XML-данными, содержащимися в документе, и обнаруживать и удалять существующие файлы преобразований, связанные с XML-данными, содержащимися в этом документе. Пользователь может также связывать другие файлы и исполняемое программное обеспечение, связанное с XML-ориентированным и другими решениями документов, с XML-данными, содержащимися в документе. Дополнительно пользователь может обнаруживать и удалять связь XML-ориентированных решений и других типов исполняемого программного обеспечения из связи с XML-данными, содержащимися в документе.

Эти и другие признаки, преимущества и аспекты настоящего изобретения могут быть более ясно поняты и оценены из обзора последующего подробного описания раскрытых воплощений и посредством обращения к прилагаемым чертежам и формуле изобретения.

Перечень фигур чертежей

Фиг.1 - упрощенная блок-схема вычислительной системы и связанных с ней периферийного оборудования и сетевых устройств, которые обеспечивают иллюстративную рабочую среду для настоящего изобретения.

Фиг.2 - упрощенная блок-схема, иллюстрирующая взаимодействие между программными объектами в соответствии с объектно-ориентированной программной моделью.

Фиг.3 - блок-схема, иллюстрирующая взаимодействие между документом, присоединенным файлом схемы, и моделью функциональных возможностей проверки действительности схемы.

Фиг.4 - блок-схема, иллюстрирующая взаимодействие между документом, библиотекой пространств имен или схем и сторонним программным приложением.

Подробное описание предпочтительного воплощения

Воплощения настоящего изобретения направлены на способы и системы для предоставления пользователю возможности программным путем вызывать библиотеку пространств имен/схем, состоящую из файлов XML-схем и XML-ориентированных решений и ресурсов, для управления связыванием таких файлов, решений и ресурсов с одним или большим количеством документов. Такие воплощения могут комбинироваться, могут использоваться другие воплощения и могут производиться структурные изменения, не выходя за рамки сущности и объема настоящего изобретения. Последующее подробное описание, таким образом, не следует интерпретировать в смысле ограничения, и объем настоящего изобретения определяется прилагаемой формулой изобретения и ее эквивалентами.

Далее, ссылаясь на чертежи, на которых идентичные номера соответствуют одинаковым элементам на нескольких чертежах, будут описаны аспекты настоящего изобретения и иллюстративная операционная среда. Фиг.1 и последующее подробное обсуждение предназначены для предоставления краткого, общего описания подходящей вычислительной среды, в которой изобретение может быть реализовано. Хотя настоящее изобретение будет описываться в общем контексте программных модулей, которые выполняются в совокупности с прикладной программой, исполняющейся под управлением операционной системы на персональном компьютере, специалистам в этой области техники будет понятно, что изобретение может также быть реализовано в сочетании с другими программными модулями.

Обычно программные модули включают в себя процедуры, программы, компоненты, структуры данных и другие типы структур, которые выполняют конкретные задачи или реализуют определенные абстрактные типы данных. Кроме того, специалистам в данной области техники должно быть понятно, что изобретение может быть реализовано на практике с другими конфигурациями компьютерных систем, включая карманные устройства, мультипроцессорные системы, микропроцессорную или программируемую бытовую электронику, миникомпьютеры, универсальные вычислительные машины (мейнфреймы) и тому подобное. Данное изобретение может также быть реализовано в распределенных вычислительных средах, где задачи выполняются удаленными устройствами обработки данных, которые соединены через сеть связи. В распределенной вычислительной среде программный модуль может располагаться как на локальных, так и на удаленных запоминающих устройствах.

Далее со ссылкой на фиг.1 будет описана иллюстративная компьютерная архитектура для персонального компьютера 2, предназначенного для практической реализации разнообразных воплощений этого изобретения. Компьютерная архитектура, показанная на фиг.1, изображает обычный персональный компьютер, включающий в себя центральное процессорное устройство 4 (ЦПУ), системную память 6, включающую в себя оперативное запоминающее устройство 8 (ОЗУ) и постоянное запоминающее устройство 10 (ПЗУ), и системную шину 12, которая соединяет упомянутую память с ЦПУ 4. Базовая система ввода/вывода, содержащая основные процедуры, которые помогают передавать информацию между элементами внутри компьютера, например, во время запуска, хранится в ПЗУ 10. Персональный компьютер 2 дополнительно включает в себя запоминающее устройство 14 большой емкости для хранения операционной системы 16, прикладных программ, таких как прикладная программа 305, и данных.

Запоминающее устройство 14 большой емкости подключено к ЦПУ 4 через контроллер запоминающего устройства большой емкости (не показан), подключенный к шине 12. Запоминающее устройство 14 большой емкости и связанный с ним машиночитаемый носитель обеспечивают энергонезависимое хранилище для персонального компьютера 2. Хотя описание машиночитаемого носителя, содержащееся в материалах настоящей заявки, относится к запоминающим устройствам большой емкости, таким как жесткий диск или дисковод для компакт-дисков, специалистам в данной области техники должно быть понятно, что машиночитаемый носитель может быть любым имеющимся в наличии носителем, к которому персональный компьютер 2 может осуществить доступ.

В качестве примера, но не ограничения, машиночитаемые носители могут содержать компьютерные носители информации или среды передачи информации. Компьютерные носители информации включают в себя энергозависимые и энергонезависимые, съемные и несъемные носители, реализованные любым способом или по любой технологии для хранения информации, такой как машиночитаемые команды, структуры данных, программные модули или другие данные. Компьютерные носители информации включают в себя, но не в ограничительном смысле, ОЗУ, ПЗУ, электрически программируемое ПЗУ (EPROM), электрически стираемое программируемое ПЗУ (EEPROM), флэш-память или другую память твердотельной технологии, ПЗУ на компакт-диске (CD-ROM), цифровой многофункциональный диск (DVD) или другой оптический накопитель, магнитные дискеты, магнитную ленту, накопитель на магнитных дисках или другие магнитные запоминающие устройства либо любой другой носитель, который может использоваться для хранения желаемой информации и к которому компьютер может осуществить доступ.

В соответствии с разнообразными воплощениями изобретения персональный компьютер 2 может работать в сетевой среде, используя логические соединения с удаленными компьютерами через сеть 18 протокола управления передачей/межсетевого протокола (TCP/IP), такую как Интернет. Персональный компьютер 2 может подключаться к сети 18 TCP/IP через устройство 20 сетевого интерфейса, подключенное к шине 12. Должно быть принято во внимание, что устройство 20 сетевого интерфейса может также использоваться для подключения к другим типам сетей и удаленных компьютерных систем. Персональный компьютер 2 может также включать в себя контроллер 22 ввода/вывода для приема и обработки входной информации от некоторого количества устройств, включая клавиатуру или мышь (не показаны). Подобным образом контроллер 22 ввода/вывода может обеспечивать вывод на экран дисплея, принтер или другой тип устройства вывода.

Как коротко упомянуто выше, некоторое количество программных модулей и файлов данных могут храниться в запоминающем устройстве 14 большой емкости и ОЗУ 8 из состава персонального компьютера 2, включая операционную систему 16, подходящую для управления работой подключенного в сеть персонального компьютера, такую как операционная система WINDOWS XP, разработанная компанией MICROSOFT CORPORATION, г. Редмонд, штат Вашингтон. Запоминающее устройство 14 большой емкости и ОЗУ 8 могут также хранить одну или большее количество прикладных программ. В частности, запоминающее устройство 14 большой емкости и ОЗУ 8 могут хранить прикладную программу 305 для создания и редактирования электронного документа 310. Например, прикладная программа 305 может заключать в себе прикладную программу обработки текстов, приложение обработки электронных таблиц, приложение управления контактной информацией или подобное. Прикладные программы для создания и редактирования других типов электронных документов могут также быть использованы с разнообразными воплощениями настоящего изобретения. Файл 330 схемы и библиотека 400 пространств имен/схем, описанные ниже, также показаны.

Иллюстративные воплощения настоящего изобретения реализованы посредством обмена данными между различными программными объектами в объектно-ориентированном программном окружении. В целях последующего описания воплощений настоящего изобретения полезно коротко описать компоненты объектно-ориентированного программного окружения. Фиг.2 - это упрощенная блок-схема, иллюстрирующая взаимодействие между программными объектами согласно модели объектно-ориентированного программирования. В соответствии с объектно-ориентированным программным окружением первый объект 210 может включать в себя программный код, исполняемые методы, свойства и параметры. Подобным образом, второй объект 220 может также содержать программный код, исполняемые методы, свойства и параметры.

Первый объект 210 может связываться со вторым объектом 220 для получения информации или функциональных возможностей от второго объекта 220 посредством вызова второго объекта 220 через привязанный к сообщению вызов 230. Как хорошо известно специалистам данной области техники, первый объект 210 может общаться со вторым объектом 220 через программный интерфейс приложения (API), который позволяет двум разнородным программным объектам 210 и 220 общаться друг с другом для получения информации и функциональных возможностей друг от друга. Например, если первому объекту 210 требуются функциональные возможности, предоставляемые методом, содержащимся во втором объекте 220, первый объект 210 может послать привязанный к сообщению вызов 230 второму объекту 220, в котором первый объект идентифицирует такой требуемый метод и в котором первый объект посылает любые требуемые параметры второму объекту, необходимые второму объекту для управления идентифицированным методом. Как только второй объект 220 принимает вызов от первого объекта, второй объект выполняет вызываемый метод на основе предоставленных параметров и посылает возвращаемое сообщение 250, содержащее значение, полученное от выполненного метода, обратно первому объекту 210.

Например, в терминах воплощений настоящего изобретения, и как будет описано далее, первый объект 210 может быть сторонним заказным приложением, которое посылает сообщение второму объекту, такому как объект проверки действительности схемы Расширяемого Языка Разметки (XML-схемы), в соответствии с чем первый объект идентифицирует метод, требуя проверки действительности заданного XML-элемента в документе, где заданный XML-элемент - это параметр, передаваемый первым объектом совместно с идентифицированным методом. После приема такого вызова от первого объекта, согласно этому примеру, объект проверки действительности схемы исполняет идентифицированный метод в отношении заданного XML-элемента и возвращает сообщение первому объекту в форме результата или значения, ассоциированного с прошедшим проверку действительности XML-элементом. Действие объектно-ориентированного программного окружения, такого как коротко описано выше, хорошо известно специалистам в данной области техники.

Как описано ниже, воплощения настоящего изобретения реализуются через взаимодействие программных объектов при использовании, конфигурировании на индивидуальной основе и объявлении компонентов Расширяемого Языка Разметки (XML). Фиг.3 - это блок-схема, иллюстрирующая взаимодействие между документом, присоединенным файлом XML-схемы и модулем функциональных возможностей проверки действительности схемы. Как хорошо известно специалистам в данной области техники, Расширяемый Язык Разметки (XML) предоставляет способ описания текста и данных в документе путем предоставления пользователю возможности создавать имена тегов (неотображаемых элементов разметки), которые применены к тексту или данным в документе, который в свою очередь определяет текст или данные, к которым применяются ассоциированные с ними теги. Например, согласно фиг.3, документ 310, созданный посредством приложения 305, содержит текст, который был размечен XML-тегами 315, 320 и 325. Например, текст «Приветствую» аннотирован XML-тегом <title> (<заглавие>). Текст «Меня зовут Сара» аннотирован тегом <body> (<тело>). В соответствии с XML создатель тегов <title> и <body> волен создавать его собственные теги для описания тех тегов, к которым упомянутые теги будут применяться. Затем при условии, что любому приложению-потребителю или вычислительной машине-потребителю предоставлены инструкции в отношении определения тегов, применяемых к тексту, такое приложение или вычислительная машина способны использовать упомянутые данные в соответствии с тегами. Например, если приложение-потребитель запрограммировано извлекать текст, определенный как заглавия статей или публикаций, обрабатываемых таким приложением, то это приложение может анализировать документ 310 и извлекать текст «Приветствую», как показано на фиг.3, потому что такой текст аннотирован тегом <title>. Создатель именования конкретных XML-тегов для документа 310, изображенного на фиг.3, обеспечивает полезное описание для текста или данных, содержащихся в документе 310, которое может использоваться представителями третьей стороны при условии, что этим представителям третьей стороны предоставлены определения, связанные с тегами, примененными к этому тексту или данным.

В соответствии с воплощениями настоящего изобретения текст и XML-разметку, введенные в документ 310, можно сохранять согласно множеству различных файловых форматов и в соответствии с собственным языком программирования приложения 305, при помощи которого документ 310 создан. Например, текст и XML-разметку можно сохранять согласно приложению электронной обработки текстов, приложению обработки электронных таблиц и им подобным. В качестве альтернативы, текст и XML-разметку, введенные в документ 310, можно сохранять в формате XML, посредством чего текст или данные, любая применяемая XML-разметка и любое форматирование, такое как шрифт, стиль, структура абзацев и т.д., могут сохраняться в XML-представлении. Следовательно, приложение-потребитель или стороннее приложение, выполненное с возможностью понимания данных, сохраненных как XML, могут открыть и обработать текст или данные, сохраненные в XML-представлении. Для детального всестороннего исследования сохранения текста и XML-разметки, а также ассоциированного форматирования и других атрибутов документа 310 в формате XML обратитесь к заявке на патент США, озаглавленной «Word Processing Document Stored in a Single XML File that may be Manipulated by Applications that Understanding XML» («Документ обработки текстов, сохраняемый в едином XML файле, которым могут манипулировать совместимые с XML приложения», серийный номер 10/187060, поданной 28 июня 2002 года, которая целиком включена в материалы настоящей заявки в качестве ссылки.

Для того чтобы предоставить оболочку области определения для элементов XML-разметки (тегов), примененных к тексту или данным, как показано на фиг.3, создаются файлы XML-схем, которые содержат информацию, необходимую для предоставления пользователям и потребителям размеченных и сохраненных данных возможности понимать определения тегирования XML, разработанные создателем документа. Каждый файл схемы, также упоминаемый в данной области техники как файл определения схемы XML (XSD), предпочтительно включает в себя список всех XML-элементов (тегов), которые могут быть применены к документу согласно данному файлу схемы. Например, файл 330 схемы, показанный на фиг.3, может являться файлом схемы, содержащим определения некоторых XML-элементов, которые могут применяться к документу 310, включая атрибуты XML-элементов или ограничения и/или правила, связанные с текстом или данными, которые могут аннотироваться XML-элементами в соответствии с файлом схемы. Например, обращаясь к файлу 330 схемы, показанному на фиг.3, упомянутый файл схемы идентифицируется пространством имен «intro» и этот же файл схемы включает в себя корневой элемент <introCard>.

В соответствии с файлом 330 схемы такой элемент <introCard> служит как корневой элемент для файла схемы и также как родительский элемент для двух дочерних элементов <title> и <body>. Как хорошо известно специалистам в данной области техники, множество родительских элементов может быть определено под единым корневым элементом и множество дочерних элементов может быть определено под каждым родительским элементом. В типичном виде, однако, заданный файл 330 схемы содержит только один корневой элемент. Ссылаясь еще раз на фиг.3, файл 330 схемы также содержит атрибуты 340 и 345, относящиеся к элементам <title> и <body> соответственно. Такие атрибуты 340 и 345 могут обеспечивать дополнительное определение или правила, связанные с применением соответствующих элементов к тексту и данным документа 310. Например, атрибут 345 определяет, что текст, аннотированный элементом <title>, должен быть не более двадцати пяти символов в длину. Следовательно, если текст, превышающий двадцать пять символов в длину, аннотируется элементом или тегом <title>, пробное аннотирование такого текста будет ошибочным в соответствии с определениями, содержащимися в файле 330 схемы.

Применяя такие определения или правила к XML-элементам в качестве атрибутов, создатель схемы может задавать структуру данных, содержащихся в документе, связанном с заданным файлом схемы. Например, если создатель файла 330 схемы для определения XML-разметки, применяемой к документу резюме, желает, чтобы раздел опыта работы в документе резюме содержал не более четырех записей о настоящей или предшествующей работе, то создатель файла 330 схемы может задать атрибут элемента <experience> (<опыт работы>), например, с целью обеспечения того, чтобы не более четырех записей о настоящем и предшествующих местах работы могло вводиться между тегами <experience>, чтобы текст в отношении опыта работы был действительным в соответствии с файлом 330 схемы. Как хорошо известно специалистам в данной области техники, файл 330 схемы может быть присоединен или иным образом ассоциирован с заданным документом 310 для применения допустимой XML-разметки, определенной в присоединенном к документу 310 файле схемы. Согласно этому же воплощению документ 310, размеченный посредством элементов XML-схемы присоединенного или ассоциированного файла 330 схемы, может указывать на этот присоединенный или ассоциированный файл схемы посредством указания на универсальный идентификатор ресурса (URI), связанный с пространством имен, идентифицирующим присоединенный или ассоциированный файл 330 схемы.

Согласно воплощениям настоящего изобретения документ 310 может иметь множество присоединенных файлов схем. То есть создатель документа 310 может ассоциативно связывать или присоединять более одного файла 330 схемы к документу 310 для того, чтобы предоставить оболочку для аннотации с помощью XML-разметки из более чем одного файла схемы. Например, документ 310 может содержать текст или данные, связанные с финансовыми данными. Создатель документа 310 может пожелать ассоциативно связать файлы 330 XML-схем, содержащие разметку и определения, связанные с множеством финансовых учреждений. Следовательно, создатель документа 310 может ассоциативно связать файл XML-схемы из одного или более финансовых учреждений с документом 310. Подобным образом, заданный файл 330 XML-схемы может быть ассоциирован с конкретной структурой документа, такой как шаблон для размещения финансовых данных в желаемом формате.

В соответствии с воплощениями настоящего изобретения коллекция файлов XML-схем и ассоциированных решений документов может поддерживаться в библиотеке пространства имен или схем, размещенной отдельно от документа 310. Документ 310, в свою очередь, может содержать указатели на универсальные идентификаторы ресурсов (URI) в библиотеке пространства имен или схем, связанной с одним или более файлов схем, присоединенных или иным образом ассоциированных с документом 310. Так как документ 310 требует информации из одного или более ассоциированных файлов схем, этот документ 310 обращается к библиотеке пространств имен или схем, чтобы получить требуемые определения схем. Для детального описания такого использования операций библиотеки пространств имен или схем обратитесь к заявке на патент США, озаглавленной «System and Method for Providing Namespace Related Information» («Система и способ для предоставления связанной с пространством имен информации»), серийный номер 10/184190, поданной 27 июня 2002 года, и к заявке на патент США, озаглавленной «System and Method for Obtaining and Using Namespace Related Information for Opening XML Documents» («Система и способ для получения и использования связанной с пространством имен информации для открытия XML-документов»), серийный номер 10/185940, поданной 27 июня 2002 года, причем обе заявки на патент США полностью включены в настоящее описание посредством ссылки. Для детального описания алгоритма для загрузки программных компонентов, таких как файлы XML-схем и ассоциированные решения, из библиотеки пространств имен или схем обратитесь к заявке на патент США, озаглавленной «Mechanism for Downloading Software Components from a Remote Source for Use by a Local Software Application» («Алгоритм для загрузки программных компонентов из удаленного источника с помощью локального программного приложения»), серийный номер 10/164260, поданной 5 июня 2002 года.

Согласно фиг.3 модуль функциональных возможностей проверки действительности схемы 350 приведен в качестве иллюстрации проверки действительности XML-разметки, примененной к документу 310, по отношению к файлу 330 XML-схемы, присоединенному или иным образом ассоциированному с документом 310, как описано выше. Как описано выше, файл 330 схемы устанавливает допустимые XML-элементы и ассоциированные атрибуты и определяет правила для действительной аннотации документа 310 XML-разметкой из ассоциированного файла 330 схемы. Например, как показано в файле 330 схемы, два дочерних элемента <title> и <body> определены под корневым или родительским элементом <introCard>. Также показаны атрибуты 340, 345, задающие допустимую длину строки текста, связанного с дочерними элементами <title> и <body>. Как описано выше, если пользователь попытается аннотировать документ 310 XML-разметкой из файла 330 схемы, присоединенного или ассоциированного с документом, в противоречие определениям XML- разметки, содержащимся в файле 330 схемы, то будет возникать недопустимое или ошибочное состояние. Например, если пользователь попытается ввести строку заголовка, длина которой превышает двадцать пять символов, то такая текстовая строка будет противоречить атрибуту максимальной символьной длины элемента <title> файла 330 схемы. Для того чтобы удостовериться в действительности XML-разметки, примененной к документу 310, в отношении ассоциированного файла 330 схемы, используется модуль 350 проверки действительности схемы. Как должно быть понято специалистами в данной области техники, модуль 350 проверки действительности схемы - это программный модуль, включающий в себя машиноисполняемые команды, достаточные для сравнения XML-разметки и ассоциированного текста, введенных в документ, с ассоциированным или присоединенным файлом 330 XML-схемы по мере введения XML-разметки и ассоциированного текста в документ 310.

Согласно воплощениям настоящего изобретения модуль 350 проверки действительности схемы сравнивает каждый элемент XML-разметки и ассоциированного текста или данных, отнесенных к документу 310, с присоединенным или ассоциированным файлом 330 схемы, чтобы определить, соответствует ли каждый элемент и ассоциированный текст или данные правилам и определениям, установленным присоединенным файлом 330 схемы. Например, если пользователь попытается ввести символьную строку, длина которой превышает двадцать пять символов, аннотированных элементами 320 <title>, модуль проверки действительности схемы сопоставит такую текстовую строку с атрибутом 340 текстовой строки присоединенного файла 330 схемы и определит, что длина текстовой строки, введенной пользователем, превышает максимальную допустимую длину текстовой строки. Следовательно, сообщение или диалог с информацией об ошибке будут предоставлены пользователю, чтобы известить пользователя о том, что длина вводимой пользователем строки превышает максимально допустимую длину в символах, соответствующую присоединенному файлу 330 схемы. Подобным образом, если пользователь попытается добавить элемент XML-разметки между элементами <title> и <body>, то модуль 350 проверки действительности определит, что элемент XML-разметки, примененный пользователем, не является действительным элементом, допустимым между элементами <title> и <body>, согласно присоединенному файлу 330 схемы. Следовательно, модуль 350 проверки действительности сгенерирует сообщение или диалог с информацией об ошибке, чтобы известить пользователя о недействительности XML-разметки.

Программируемая объектная модель для библиотек пространств имен или схем

Как описано выше со ссылкой на фиг.3, для того чтобы обеспечить оболочку области определения, ориентированную на правила для применения разметки Расширяемого Языка Разметки (XML) к документу 310, один или более файлов 330 схем могут быть присоединены или ассоциированы с упомянутым документом для задания для документа 310 определений и правил, управляющих применением элементов XML-разметки, соответствующих заданному файлу 330 схемы. Как описано, множество файлов XML-схем и других решений документов, например, предварительно структурированные шаблоны, могут быть присоединены или ассоциированы с одним XML документом 310. Более того, как описано выше, множество различных файлов XML-схем, идентифицированных идентификаторами пространства имен, и множество решений документа могут сохраняться в библиотеке пространств имен или схем отдельно от документа 310. В соответствии с воплощениями настоящего изобретения пользователям дается возможность программного вызова библиотеки пространств имен или схем, связанной с одним или более документами 310, для настройки или иного манипулирования пространствами имен файлов схем и ассоциированными определениями, правилами, ресурсами, а также решениями, связанными с различными идентификаторами пространств имен, содержащимися в библиотеке пространств имен или схем.

Фиг.4 - это блок-схема, иллюстрирующая взаимодействие между документом 310, библиотекой 400 пространств имен или схем и сторонним приложением 450. Согласно воплощениям настоящего изобретения пользователи могут программно вызывать библиотеку 400 пространств имен через совокупность объектно-ориентированных привязанных к сообщениям вызовов или программных интерфейсов 470 приложений для изменения содержимого или действия отдельных файлов 410, 430 схем или ресурсов 420, 440, связанных с файлами схем, идентифицированными в библиотеке 400 пространства имен. Пользователь может взаимодействовать с библиотекой 400 пространств имен из приложения 305 или из сторонней программы через совокупность объектно-ориентированных привязанных к сообщениям вызовов, и сторонняя программа может быть разработана с использованием разнообразных языков программирования, таких как С, С++, С#, Visual Basic и им подобных.

Имея доступ к библиотеке пространств имен через набор программных интерфейсов 470 приложений, пользователь может программным путем связывать один или более дополнительных файлов XML-схем или пространств имен с XML-данными, и наоборот, пользователь может обнаруживать и удалять существующие связи между одним или более файлов XML-схем и XML-данными или разметкой, примененной к документу 310. Пользователь может также программным путем связывать Преобразование Расширяемого Языка Таблиц Стилей (XSLT) с XML-данными, примененными к документу, и наоборот, пользователь может обнаруживать и удалять существующие XSLT-преобразования из связи с XML-данными, примененными к документу 310. Более того, пользователь может программным путем связывать другие файлы и исполняемые программные приложения с XML-данными, примененными к документу 310, и определять и удалять существующие связи других программных приложений и файлов с XML-данными.

Например, пространство 430 имен, показанное в библиотеке 400 пространств имен, может содержать решение, состоящее из предварительно отформатированной структуры для шаблона документа резюме. Когда такое решение применяется к документу 310, ассоциированные определения схемы и правила, разработанные создателем шаблона документа резюме, будут применяться к XML-разметке и ассоциированному тексту, введенным в документ 310. Если файл схемы, связанный с шаблоном документа резюме, требует, чтобы раздел опыта работы документа резюме содержал по меньшей мере три описания последней или настоящей работы, такое определение схемы будет применяться к документу 310 таким образом, что по меньшей мере три описания работы должны быть введены последующим пользователем в секцию опыта работы для того, чтобы такой XML-документ 310 был признан действительным модулем 350 проверки действительности схемы. В продолжение этого примера, если такой файл схемы шаблона документа резюме связан с документом 310, и пользователь желает удалить связь этого файла схемы с документом 310, то пользователь может действовать также программным путем из сторонней программы, посылая объектно-ориентированный привязанный к сообщению вызов в библиотеку 450 пространств имен или в приложение 305 посредством поддерживаемого программного интерфейса приложения, для управления удалением связи файла схемы шаблона документа резюме из документа 310.

Нижеследующее является описанием объектов и ассоциированных свойств, включая объектно-ориентированные привязанные к сообщениям вызовы или программные интерфейсы приложений, которые предоставляют пользователю возможность программным путем осуществлять доступ к библиотеке пространств имен, как было описано выше. Для каждого из объектов и связанных с ним свойств ниже приведено описание работы и набора функций упомянутого объекта или ассоциированного свойства.

Объект Application (Приложение)

Далее приведены методы и свойства объекта.

Свойство .XMLNamespaces (Пространства имен XML)

Доступный только на чтение указатель на коллекцию XMLNamespaces пространств имен XML, который представляет библиотеку пространств имен, доступную приложению.

Объект XMLNamespaces collection (коллекция пространств имен XML)

- объект, предоставляющий доступ к объектам XMLNamespace (пространствам имен XML). Он представляет библиотеку пространств имен. Каждый объект XMLNamespace в коллекции представляет одиночное и уникальное пространство имен в библиотеке пространств имен. Ниже приведены методы и свойства такого объекта.

Метод .Add() (добавить)

Метод, создающий и добавляющий к коллекции новы